import java.awt.Image;
import java.util.LinkedList;
import java.util.List;
-import java.util.MissingResourceException;
-import java.util.ResourceBundle;
import be.nikiroo.jvcard.Contact;
import be.nikiroo.jvcard.Data;
import be.nikiroo.jvcard.TypeInfo;
-import be.nikiroo.jvcard.resources.Bundles;
import be.nikiroo.jvcard.resources.StringUtils;
-import be.nikiroo.jvcard.resources.Trans;
+import be.nikiroo.jvcard.resources.bundles.DisplayBundle;
+import be.nikiroo.jvcard.resources.enums.ColorOption;
+import be.nikiroo.jvcard.resources.enums.DisplayOption;
+import be.nikiroo.jvcard.resources.enums.StringId;
import be.nikiroo.jvcard.tui.ImageTextControl;
import be.nikiroo.jvcard.tui.KeyAction;
import be.nikiroo.jvcard.tui.KeyAction.DataType;
import com.googlecode.lanterna.gui2.BorderLayout;
import com.googlecode.lanterna.gui2.Borders;
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.gui2.TextBox;
+import com.googlecode.lanterna.gui2.TextBox.Style;
import com.googlecode.lanterna.input.KeyType;
public class ContactDetails extends MainContent {
private Image image;
private boolean fullscreenImage;
private Panel infoPanel;
- private Label note;
+ private TextBox note;
// from .properties file:
private int labelSize = -1;
private String infoFormat = "";
+
//
public ContactDetails(Contact contact) {
// Get the .properties info:
- ResourceBundle map = Bundles.getBundle("display");
-
- try {
- labelSize = Integer.parseInt(map
- .getString("CONTACT_DETAILS_LABEL_WIDTH"));
-
- } catch (NumberFormatException e) {
- e.printStackTrace();
- labelSize = -1;
- } catch (MissingResourceException e) {
- labelSize = -1;
- }
-
- try {
- infoFormat = map.getString("CONTACT_DETAILS_INFO");
- } catch (MissingResourceException e) {
- e.printStackTrace();
- }
+ DisplayBundle map = new DisplayBundle();
+ labelSize = map.getInteger(DisplayOption.CONTACT_DETAILS_LABEL_WIDTH,
+ -1);
+ infoFormat = map.getString(DisplayOption.CONTACT_DETAILS_INFO);
//
BorderLayout blayout = new BorderLayout();
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(UiColors.createLabel(
+ ColorOption.VIEW_CONTACT_NOTES_TITLE, "Notes:"));
+ // 10000x10000 is probably enough or "max"
+ note = new TextBox(new TerminalSize(10000, 10000), Style.MULTI_LINE);
+ note.setReadOnly(true);
notePanel.addComponent(note);
+ note.setVerticalFocusSwitching(false);
+ note.setHorizontalFocusSwitching(false);
setContact(contact);
infoPanel.removeAllComponents();
String name = contact.getPreferredDataValue("FN");
- infoPanel.addComponent(UiColors.Element.VIEW_CONTACT_NAME
- .createLabel(name));
- infoPanel.addComponent(UiColors.Element.VIEW_CONTACT_NORMAL
- .createLabel(""));
+ infoPanel.addComponent(UiColors.createLabel(
+ ColorOption.VIEW_CONTACT_NAME, name));
+ infoPanel.addComponent(UiColors.createLabel(
+ ColorOption.VIEW_CONTACT_NORMAL, ""));
// List of infos:
String[] infos = infoFormat.split("\\|");
all = true;
if (all || hl || info.contains("=")) {
- UiColors.Element el = hl ? UiColors.Element.VIEW_CONTACT_HIGHLIGHT
- : UiColors.Element.VIEW_CONTACT_NORMAL;
+ ColorOption el = hl ? ColorOption.VIEW_CONTACT_HIGHLIGHT
+ : ColorOption.VIEW_CONTACT_NORMAL;
int index = info.indexOf('=');
if (index < 0)
String field = info.substring(index + 1);
if (all) {
+ Data pref = contact.getPreferredData(field);
for (Data data : contact.getData(field)) {
- if (data.isPreferred()) {
- infoPanel.addComponent(el
- .createLabel(StringUtils.padString(
- label, labelSize)
+ if (data == pref) {
+ infoPanel.addComponent(UiColors.createLabel(el,
+ StringUtils.padString(label, labelSize)
+ data.toString()));
} else {
- infoPanel
- .addComponent(UiColors.Element.VIEW_CONTACT_NORMAL
- .createLabel(StringUtils
- .padString(label,
- labelSize)
- + data.toString()));
+ infoPanel.addComponent(UiColors.createLabel(
+ ColorOption.VIEW_CONTACT_NORMAL,
+ StringUtils.padString(label, labelSize)
+ + data.toString()));
}
}
} else {
String val = contact.getPreferredDataValue(field);
if (val == null)
val = "";
- infoPanel.addComponent(el.createLabel(StringUtils
- .padString(label, labelSize) + val));
+ infoPanel.addComponent(UiColors.createLabel(el,
+ StringUtils.padString(label, labelSize) + val));
}
} else {
String label = info;
- infoPanel.addComponent(UiColors.Element.VIEW_CONTACT_NORMAL
- .createLabel(StringUtils
- .padString(label, labelSize)));
+ infoPanel.addComponent(UiColors.createLabel(
+ ColorOption.VIEW_CONTACT_NORMAL,
+ StringUtils.padString(label, labelSize)));
}
}
// end of list
- infoPanel.addComponent(UiColors.Element.VIEW_CONTACT_NORMAL
- .createLabel(""));
+ infoPanel.addComponent(UiColors.createLabel(
+ ColorOption.VIEW_CONTACT_NORMAL, ""));
String notes = contact.getPreferredDataValue("NOTE");
if (notes == null)
List<KeyAction> actions = new LinkedList<KeyAction>();
actions.add(new KeyAction(Mode.NONE, KeyType.Tab,
- Trans.StringId.KEY_ACTION_SWITCH_FORMAT) {
+ StringId.KEY_ACTION_SWITCH_FORMAT) {
@Override
public boolean onAction() {
if (txtImage != null) {
return false;
}
});
- actions.add(new KeyAction(Mode.NONE, 'i',
- Trans.StringId.KEY_ACTION_INVERT) {
+ actions.add(new KeyAction(Mode.NONE, 'i', StringId.KEY_ACTION_INVERT) {
@Override
public boolean onAction() {
if (txtImage != null) {
}
});
actions.add(new KeyAction(Mode.NONE, 'f',
- Trans.StringId.KEY_ACTION_FULLSCREEN) {
+ StringId.KEY_ACTION_FULLSCREEN) {
@Override
public boolean onAction() {
fullscreenImage = !fullscreenImage;
});
// TODO: add "normal" edit
actions.add(new KeyAction(Mode.CONTACT_DETAILS_RAW, 'r',
- Trans.StringId.KEY_ACTION_EDIT_CONTACT_RAW) {
+ StringId.KEY_ACTION_EDIT_CONTACT_RAW) {
@Override
public Object getObject() {
return contact;