import be.nikiroo.jvcard.Data;
import be.nikiroo.jvcard.TypeInfo;
import be.nikiroo.jvcard.launcher.Main;
-import be.nikiroo.jvcard.resources.StringUtils;
-import be.nikiroo.jvcard.resources.enums.ColorOption;
-import be.nikiroo.jvcard.resources.enums.StringId;
+import be.nikiroo.jvcard.resources.ColorOption;
+import be.nikiroo.jvcard.resources.StringId;
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.TuiLauncher;
+import be.nikiroo.utils.StringUtils;
+import com.googlecode.lanterna.gui2.MultiWindowTextGUI;
+import com.googlecode.lanterna.gui2.dialogs.ActionListDialogBuilder;
import com.googlecode.lanterna.input.KeyType;
public class ContactDetailsRaw extends MainContentList {
StringId.KEY_ACTION_EDIT_FIELD) {
@Override
public Object getObject() {
- return getSelectedData();
+ Data data = getSelectedData();
+ if (data != null && data.getB64Key() != -1) {
+ setMessage("Cannot modify binary values in RAW mode", true);
+ data = null;
+ }
+
+ return data;
}
@Override
return null;
}
});
- // TODO: ui
+ // TODO: ui and i18n
actions.add(new KeyAction(Mode.ASK_USER, 'a', StringId.KEY_ACTION_ADD) {
+ private String name;
+
+ @Override
+ public boolean onAction() {
+ new ActionListDialogBuilder()
+ .setTitle("New data")
+ .setDescription("Choose a data type")
+ .addAction("Email address", new Runnable() {
+ @Override
+ public void run() {
+ name = "EMAIL";
+ }
+ })
+ .addAction("Telephone number", new Runnable() {
+ @Override
+ public void run() {
+ name = "TEL";
+ }
+ })
+ .addAction("Birthday", new Runnable() {
+ @Override
+ public void run() {
+ name = "BDAY";
+ }
+ })
+ .addAction("[other]", new Runnable() {
+ @Override
+ public void run() {
+ name = "";
+ }
+ })
+ .build()
+ .showDialog(
+ new MultiWindowTextGUI(TuiLauncher.getScreen()));
+
+ String name = this.name;
+ this.name = null;
+
+ if (name != null) {
+ if (name.length() > 0) {
+ Data data = new Data(null, name, "", null);
+ getContact().add(data);
+ addItem("x");
+ }
+
+ return (name.length() == 0);
+ }
+
+ return false;
+ }
+
@Override
public Object getObject() {
return contact;
@Override
public String getQuestion() {
// TODO i18n
- return "new data (xx.group = yy): ";
+ if (name == null)
+ return "Data name: ";
+
+ return null;
}
@Override
public String callback(String answer) {
- int indexEq = answer.indexOf('=');
- if (indexEq >= 0) {
- String name = answer.substring(0, indexEq).trim();
- String value = answer.substring(indexEq + 1).trim();
- String group = null;
-
- int indexDt = name.indexOf('.');
- if (indexDt >= 0) {
- group = name.substring(indexDt + 1).trim();
- name = name.substring(0, indexDt).trim();
- }
-
- Data data = new Data(null, name, value, group);
+ if (answer != null & answer.length() > 0) {
+ Data data = new Data(null, answer, "", null);
getContact().add(data);
addItem("x");
}
+
return null;
}
});
@Override
protected List<TextPart> getLabel(int index, int width, boolean selected,
boolean focused) {
+
// TODO: from ini file?
int SIZE_COL_1 = 15;
int SIZE_COL_2_OPT = 10;
StringBuilder valueBuilder = new StringBuilder(" ");
if (!extMode) {
- valueBuilder.append(data.getValue().replaceAll("\n", "\\\\n"));
+ if (data.getB64Key() != -1) {
+ // TODO: i18n
+ valueBuilder.append("<BKey " + data.getB64Key() + ">");
+ } else {
+ valueBuilder.append(data.getValue().replaceAll("\n", "\\\\n"));
+ }
if (data.getGroup() != null && data.getGroup().length() > 0) {
- valueBuilder.append("(");
+ valueBuilder.append(" (");
valueBuilder.append(data.getGroup());
valueBuilder.append(")");
}
* @param data
* the {@link Data} from which to take the {@link TypeInfo}s
* @param builder
- * an optional {@link StringBuilder} to append the serialized
+ * an optional {@link StringBuilder} to append the serialised
* version to
*
* @return the given {@link StringBuilder} or a new one if the given one is
}
if (previous != '\\' && car == ',') {
- String[] tab = value.substring(done, index).split("\\:");
- infos.add(new TypeInfo( //
- tab[0].replaceAll("\\,", ",").replaceAll("\\:", ":")
- .trim(), //
- tab[1].replaceAll("\\,", ",").replaceAll("\\:", ":")
- .trim()));
+ String subValue = value.substring(done, index);
+ int indexColumn = subValue.indexOf(':');
+ while (indexColumn > 0
+ && subValue.charAt(indexColumn - 1) == '\\') {
+ if (indexColumn == subValue.length() - 1) {
+ indexColumn = -1;
+ } else {
+ indexColumn = subValue.indexOf(':', indexColumn + 1);
+ }
+ }
+
+ String n = "";
+ String v = "";
+ if (indexColumn >= 0) {
+ n = subValue.substring(0, indexColumn).trim();
+ v = subValue.substring(indexColumn + 1)
+ .replaceAll("\\\\:", ":").trim();
+ } else {
+ n = subValue.trim();
+ }
+
+ infos.add(new TypeInfo(n, v));
+
done = index + 1;
}