package be.nikiroo.jvcard.tui.panes;
+import java.io.IOException;
import java.util.LinkedList;
import java.util.List;
import be.nikiroo.jvcard.Card;
import be.nikiroo.jvcard.Contact;
-import be.nikiroo.jvcard.i18n.Trans;
+import be.nikiroo.jvcard.Data;
+import be.nikiroo.jvcard.launcher.Main;
+import be.nikiroo.jvcard.resources.Bundles;
+import be.nikiroo.jvcard.resources.Trans;
import be.nikiroo.jvcard.tui.KeyAction;
-import be.nikiroo.jvcard.tui.UiColors;
import be.nikiroo.jvcard.tui.KeyAction.DataType;
import be.nikiroo.jvcard.tui.KeyAction.Mode;
import be.nikiroo.jvcard.tui.UiColors.Element;
public class ContactList extends MainContentList {
private Card card;
+ private List<Contact> contacts;
+ private String filter;
- private List<String> formats = new LinkedList<String>();
- private int selectedFormat = -1;
- private String format = "";
+ private List<String> formats;
+ private int selectedFormat;
+ private String format;
public ContactList(Card card) {
- super(UiColors.Element.CONTACT_LINE,
- UiColors.Element.CONTACT_LINE_SELECTED);
+ formats = new LinkedList<String>();
+ for (String format : Bundles.getBundle("display")
+ .getString("CONTACT_LIST_FORMAT").split(",")) {
+ formats.add(format);
+ }
- // TODO: should get that in an INI file
- formats.add("NICKNAME@3|FN@+|EMAIL@30");
- formats.add("FN@+|EMAIL@40");
+ selectedFormat = -1;
switchFormat();
setCard(card);
}
/**
- * Change the currently displayed contacts card.
+ * Change the currently displayed contacts card, only allowing those that
+ * satisfy the current filter.
*
* @param card
* the new {@link Card}
+ * @param filter
+ * the text filter or NULL for all contacts
*/
public void setCard(Card card) {
clearItems();
this.card = card;
+ this.contacts = new LinkedList<Contact>();
if (card != null) {
- for (int i = 0; i < card.getContacts().size(); i++) {
- addItem("[contact line]");
+ for (Contact c : card) {
+ if (filter == null
+ || c.toString(format, "|").toLowerCase()
+ .contains(filter.toLowerCase())) {
+ addItem("x");
+ contacts.add(c);
+ }
}
}
public void refreshData() {
int index = getSelectedIndex();
setCard(card);
+ if (index >= contacts.size())
+ index = contacts.size() - 1;
setSelectedIndex(index);
+
super.refreshData();
}
public List<KeyAction> getKeyBindings() {
List<KeyAction> actions = new LinkedList<KeyAction>();
- // TODO add, del, save...
- actions.add(new KeyAction(Mode.CONTACT_DETAILS, 'e',
- Trans.StringId.KEY_ACTION_EDIT_CONTACT) {
+ // TODO ui
+ actions.add(new KeyAction(Mode.ASK_USER, 'a',
+ Trans.StringId.KEY_ACTION_ADD) {
@Override
public Object getObject() {
- return getSelectedContact();
+ return card;
+ }
+
+ @Override
+ public String getQuestion() {
+ return Main.trans(Trans.StringId.ASK_USER_CONTACT_NAME);
+ }
+
+ @Override
+ public String callback(String answer) {
+ if (answer.length() > 0) {
+ List<Data> datas = new LinkedList<Data>();
+ datas.add(new Data(null, "FN", answer, null));
+ getCard().add(new Contact(datas));
+ addItem("x");
+ }
+
+ return null;
}
});
- actions.add(new KeyAction(Mode.DELETE_CONTACT, 'd',
+ actions.add(new KeyAction(Mode.ASK_USER_KEY, 'd',
Trans.StringId.KEY_ACTION_DELETE_CONTACT) {
@Override
public Object getObject() {
return getSelectedContact();
}
+
+ @Override
+ public String getQuestion() {
+ Contact contact = getSelectedContact();
+ String contactName = "null";
+ if (contact != null)
+ contactName = "" + contact.getPreferredDataValue("FN");
+
+ return Main.trans(Trans.StringId.CONFIRM_USER_DELETE_CONTACT,
+ contactName);
+ }
+
+ @Override
+ public String callback(String answer) {
+ if (answer.equalsIgnoreCase("y")) {
+ Contact contact = getSelectedContact();
+ if (contact != null && contact.delete()) {
+ removeItem("x");
+ return null;
+ }
+
+ String contactName = "null";
+ if (contact != null)
+ contactName = "" + contact.getPreferredDataValue("FN");
+
+ return Main.trans(Trans.StringId.ERR_CANNOT_DELETE_CONTACT,
+ contactName);
+ }
+
+ return null;
+ }
});
- actions.add(new KeyAction(Mode.SAVE_CARD, 's',
+ actions.add(new KeyAction(Mode.ASK_USER_KEY, 's',
Trans.StringId.KEY_ACTION_SAVE_CARD) {
@Override
public Object getObject() {
return card;
}
+
+ @Override
+ public String getQuestion() {
+ return "Save changes? [Y/N]";
+ }
+
+ @Override
+ public String callback(String answer) {
+ if (answer.equalsIgnoreCase("y")) {
+ boolean ok = false;
+ try {
+ if (card != null && card.save())
+ ok = true;
+ } catch (IOException ioe) {
+ ioe.printStackTrace();
+ }
+
+ if (!ok) {
+ return "Cannot save to file";
+ }
+ }
+
+ return null;
+ }
+
});
actions.add(new KeyAction(Mode.CONTACT_DETAILS, KeyType.Enter,
Trans.StringId.KEY_ACTION_VIEW_CONTACT) {
return false;
}
});
+ actions.add(new KeyAction(Mode.ASK_USER, 'w',
+ Trans.StringId.KEY_ACTION_SEARCH) {
+
+ @Override
+ public String getQuestion() {
+ return "Search:";
+ }
+
+ @Override
+ public String getDefaultAnswer() {
+ return filter;
+ }
+
+ @Override
+ public String callback(String answer) {
+ filter = answer;
+ setCard(card);
+ return null;
+ }
+ });
return actions;
}
return DataType.CARD;
}
- @Override
- public Mode getMode() {
- return Mode.CONTACT_LIST;
- }
-
@Override
public String getTitle() {
if (card != null) {
+ if (filter != null)
+ return card.getName() + " [" + filter + "]";
return card.getName();
}
List<TextPart> parts = new LinkedList<TextPart>();
Contact contact = null;
- if (index > -1 && index < card.size())
- contact = card.get(index);
+ if (index > -1 && index < contacts.size())
+ contact = contacts.get(index);
if (contact == null)
return parts;
width -= 2; // dirty mark space
String[] array = contact.toStringArray(format, getSeparator(), " ",
- width);
+ width, Main.isUnicode());
if (contact.isDirty()) {
parts.add(new TextPart(" ", el));
*/
private Contact getSelectedContact() {
int index = getSelectedIndex();
- if (index > -1 && index < card.size())
- return card.get(index);
+ if (index > -1 && index < contacts.size())
+ return contacts.get(index);
return null;
}