X-Git-Url: http://git.nikiroo.be/?p=jvcard.git;a=blobdiff_plain;f=src%2Fbe%2Fnikiroo%2Fjvcard%2Ftui%2Fpanes%2FContactDetails.java;h=fc6a198feda3dd316c77cd4c415d766a2e886af0;hp=b2bb5626c91e5296ce9962f65051b8c36b1812bd;hb=7da41ecd30228908bf2afcd07ff7943ab59d4c01;hpb=ae22c2473f7203b8713dec1c1de532c312000d1e diff --git a/src/be/nikiroo/jvcard/tui/panes/ContactDetails.java b/src/be/nikiroo/jvcard/tui/panes/ContactDetails.java index b2bb562..fc6a198 100644 --- a/src/be/nikiroo/jvcard/tui/panes/ContactDetails.java +++ b/src/be/nikiroo/jvcard/tui/panes/ContactDetails.java @@ -1,72 +1,136 @@ package be.nikiroo.jvcard.tui.panes; import java.awt.Image; -import java.util.Base64; +import java.io.ByteArrayInputStream; import java.util.LinkedList; import java.util.List; -import javax.swing.ImageIcon; +import javax.imageio.ImageIO; +import javax.xml.bind.DatatypeConverter; import be.nikiroo.jvcard.Contact; import be.nikiroo.jvcard.Data; import be.nikiroo.jvcard.TypeInfo; -import be.nikiroo.jvcard.i18n.Trans; +import be.nikiroo.jvcard.resources.Trans; import be.nikiroo.jvcard.tui.ImageTextControl; import be.nikiroo.jvcard.tui.KeyAction; import be.nikiroo.jvcard.tui.KeyAction.DataType; import be.nikiroo.jvcard.tui.KeyAction.Mode; +import be.nikiroo.jvcard.tui.UiColors; import com.googlecode.lanterna.TerminalSize; import com.googlecode.lanterna.gui2.BorderLayout; +import com.googlecode.lanterna.gui2.Direction; +import com.googlecode.lanterna.gui2.Label; +import com.googlecode.lanterna.gui2.LinearLayout; import com.googlecode.lanterna.gui2.Panel; import com.googlecode.lanterna.input.KeyType; public class ContactDetails extends MainContent { private Contact contact; private Panel top; - private ImageTextControl txt; + private ImageTextControl txtImage; private Image image; private boolean fullscreenImage; + private Panel infoPanel; + private Label note; public ContactDetails(Contact contact) { - this.contact = contact; - BorderLayout blayout = new BorderLayout(); setLayoutManager(blayout); top = new Panel(); + blayout = new BorderLayout(); + top.setLayoutManager(blayout); + + infoPanel = new Panel(); + infoPanel.setLayoutManager(new LinearLayout(Direction.VERTICAL)); + top.addComponent(infoPanel, BorderLayout.Location.CENTER); + + Panel notePanel = new Panel(); + notePanel.setLayoutManager(new LinearLayout(Direction.HORIZONTAL)); + + notePanel.addComponent(UiColors.Element.VIEW_CONTACT_NOTES_TITLE + .createLabel("Notes:")); + note = UiColors.Element.VIEW_CONTACT_NORMAL.createLabel(""); + notePanel.addComponent(note); + setContact(contact); + addComponent(top, BorderLayout.Location.TOP); + addComponent(notePanel, BorderLayout.Location.CENTER); } + /** + * Change the enclosed {@link Contact} from this {@link ContactDetails}. + * Also re-set the image. + * + * @param contact + * the new {@link Contact} + */ public void setContact(Contact contact) { - Image img = null; this.contact = contact; + image = null; if (contact != null) { + infoPanel.removeAllComponents(); + + String name = contact.getPreferredDataValue("FN"); + if (name == null || name.length() == 0) { + // TODO format it ourself + name = contact.getPreferredDataValue("N"); + } + + // TODO: i18n + do it properly + infoPanel.addComponent(UiColors.Element.VIEW_CONTACT_NAME + .createLabel(name)); + + infoPanel.addComponent(UiColors.Element.VIEW_CONTACT_NORMAL + .createLabel("")); + infoPanel.addComponent(UiColors.Element.VIEW_CONTACT_NORMAL + .createLabel("Phone: " + + contact.getPreferredDataValue("TEL"))); + infoPanel.addComponent(UiColors.Element.VIEW_CONTACT_NORMAL + .createLabel("eMail: " + + contact.getPreferredDataValue("EMAIL"))); + infoPanel.addComponent(UiColors.Element.VIEW_CONTACT_NORMAL + .createLabel("")); + + String notes = contact.getPreferredDataValue("NOTE"); + if (notes == null) + notes = ""; + note.setText(notes.replaceAll("\\\\n", "\n")); + Data photo = contact.getPreferredData("PHOTO"); if (photo != null) { TypeInfo encoding = null; - TypeInfo type = null; - for (TypeInfo info : photo.getTypes()) { + for (int index = 0; index < photo.size(); index++) { + TypeInfo info = photo.get(index); if (info.getName() != null) { if (info.getName().equalsIgnoreCase("ENCODING")) encoding = info; - if (info.getName().equalsIgnoreCase("TYPE")) - type = info; + // We don't check for the "TYPE" anymore, we just defer + // it to ImageIcon } } if (encoding != null && encoding.getValue() != null && encoding.getValue().equalsIgnoreCase("b")) { - img = new ImageIcon(Base64.getDecoder().decode( - photo.getValue())).getImage(); + try { + image = ImageIO.read(new ByteArrayInputStream( + DatatypeConverter.parseBase64Binary(photo + .getValue()))); + image.toString(); + } catch (Exception e) { + System.err.println("Cannot parse image for contact: " + + contact.getPreferredDataValue("UID")); + } } } } - setImage(img); + setImage(image); } @Override @@ -83,8 +147,8 @@ public class ContactDetails extends MainContent { Trans.StringId.KEY_ACTION_SWITCH_FORMAT) { @Override public boolean onAction() { - if (txt != null) { - txt.switchMode(); + if (txtImage != null) { + txtImage.switchMode(); } return false; @@ -94,8 +158,8 @@ public class ContactDetails extends MainContent { Trans.StringId.KEY_ACTION_INVERT) { @Override public boolean onAction() { - if (txt != null) { - txt.invertColor(); + if (txtImage != null) { + txtImage.invertColor(); } return false; @@ -110,6 +174,14 @@ public class ContactDetails extends MainContent { return false; } }); + // TODO: add "normal" edit and remove this one into RAW edit + actions.add(new KeyAction(Mode.CONTACT_DETAILS_RAW, 'e', + Trans.StringId.KEY_ACTION_EDIT_CONTACT) { + @Override + public Object getObject() { + return contact; + } + }); return actions; } @@ -122,7 +194,8 @@ public class ContactDetails extends MainContent { } /** - * Set the {@link Image} to render. + * Set the {@link Image} to render and refresh it to the current size + * constraints. * * @param image * the new {@link Image} @@ -130,19 +203,22 @@ public class ContactDetails extends MainContent { private void setImage(Image image) { this.image = image; + if (txtImage != null && top.containsComponent(txtImage)) + top.removeComponent(txtImage); + TerminalSize size = getTxtSize(); if (size != null) { - if (txt != null) - txt.setSize(size); + if (txtImage != null) + txtImage.setSize(size); else - txt = new ImageTextControl(image, size); + txtImage = new ImageTextControl(image, size); } - if (top.getChildCount() > 0) - top.removeAllComponents(); + if (size != null) { + top.addComponent(txtImage, BorderLayout.Location.LEFT); + } - if (size != null) - top.addComponent(txt); + invalidate(); } /** @@ -157,8 +233,13 @@ public class ContactDetails extends MainContent { if (fullscreenImage) { return getSize(); } else { - // TODO: - return new TerminalSize(40, 20); + // TODO: configure size? + int w = getSize().getColumns() - 40; + int h = getSize().getRows() - 5; + if (w <= 0 || h <= 0) + return null; + + return new TerminalSize(w, h); } }