import jexer.TCommand;
import jexer.TKeypress;
import jexer.TMessageBox;
+import jexer.TMessageBox.Result;
+import jexer.TMessageBox.Type;
import jexer.TStatusBar;
import jexer.TWidget;
import jexer.TWindow;
import be.nikiroo.fanfix.reader.BasicReader;
import be.nikiroo.fanfix.reader.Reader;
import be.nikiroo.fanfix.reader.tui.TuiReaderMainWindow.Mode;
+import be.nikiroo.fanfix.supported.SupportType;
import be.nikiroo.utils.Progress;
/**
* @author niki
*/
class TuiReaderApplication extends TApplication implements Reader {
- public static final int MENU_OPEN = 1025;
- public static final int MENU_IMPORT_URL = 1026;
- public static final int MENU_IMPORT_FILE = 1027;
- public static final int MENU_EXPORT = 1028;
- public static final int MENU_LIBRARY = 1029;
- public static final int MENU_EXIT = 1030;
-
- public static final TCommand CMD_EXIT = new TCommand(MENU_EXIT) {
+ public static final int MENU_FILE_OPEN = 1025;
+ public static final int MENU_FILE_IMPORT_URL = 1026;
+ public static final int MENU_FILE_IMPORT_FILE = 1027;
+ public static final int MENU_FILE_EXPORT = 1028;
+ public static final int MENU_FILE_DELETE = 1029;
+ public static final int MENU_FILE_LIBRARY = 1030;
+ public static final int MENU_FILE_EXIT = 1031;
+ //
+ public static final int MENU_OPT_FANFIX = 1032;
+ public static final int MENU_OPT_TUI = 1033;
+
+
+ public static final TCommand CMD_EXIT = new TCommand(MENU_FILE_EXIT) {
};
private Reader reader;
super(backend);
init(reader);
- MetaData meta = getMeta();
- if (meta != null) {
- read();
+ if (getMeta() != null) {
+ read(false);
}
}
TApplication.BackendType backend) throws Exception {
super(backend);
init(reader);
-
+
showMain();
main.setMode(Mode.SOURCE, source);
}
@Override
- public void read() throws IOException {
- read(getStory(null));
+ public void read(boolean sync) throws IOException {
+ read(getStory(null), sync);
}
@Override
}
@Override
- public Story getStory(Progress pg) {
+ public Story getStory(Progress pg) throws IOException {
return reader.getStory(pg);
}
@Override
public void browse(String source) {
- reader.browse(source);
+ try {
+ reader.browse(source);
+ } catch (IOException e) {
+ Instance.getTraceHandler().error(e);
+ }
}
@Override
reader.setChapter(chapter);
}
- public void read(Story story) throws IOException {
+ @Override
+ public void search(boolean sync) throws IOException {
+ reader.search(sync);
+ }
+
+ @Override
+ public void search(SupportType searchOn, String keywords, int page,
+ int item, boolean sync) throws IOException {
+ reader.search(searchOn, keywords, page, item, sync);
+ }
+
+ @Override
+ public void searchTag(SupportType searchOn, int page, int item,
+ boolean sync, Integer... tags) throws IOException {
+ reader.searchTag(searchOn, page, item, sync, tags);
+ }
+
+ /**
+ * Open the given {@link Story} for reading. This may or may not start an
+ * external program to read said {@link Story}.
+ *
+ * @param story
+ * the {@link Story} to read
+ * @param sync
+ * execute the process synchronously (wait until it is terminated
+ * before returning)
+ *
+ * @throws IOException
+ * in case of I/O errors
+ */
+ public void read(Story story, boolean sync) throws IOException {
if (story == null) {
throw new IOException("No story to read");
}
window.maximize();
} else {
try {
- openExternal(getLibrary(), story.getMeta().getLuid());
+ openExternal(getLibrary(), story.getMeta().getLuid(), sync);
} catch (IOException e) {
messageBox("Error when trying to open the story",
e.getMessage(), TMessageBox.Type.OK);
// Add the menus TODO: i18n
TMenu fileMenu = addMenu("&File");
- fileMenu.addItem(MENU_OPEN, "&Open");
- fileMenu.addItem(MENU_EXPORT, "&Save as...");
+ fileMenu.addItem(MENU_FILE_OPEN, "&Open...");
+ fileMenu.addItem(MENU_FILE_EXPORT, "&Save as...");
+ fileMenu.addItem(MENU_FILE_DELETE, "&Delete...");
// TODO: Move to...
fileMenu.addSeparator();
- fileMenu.addItem(MENU_IMPORT_URL, "Import &URL...");
- fileMenu.addItem(MENU_IMPORT_FILE, "Import &file...");
+ fileMenu.addItem(MENU_FILE_IMPORT_URL, "Import &URL...");
+ fileMenu.addItem(MENU_FILE_IMPORT_FILE, "Import &file...");
fileMenu.addSeparator();
- fileMenu.addItem(MENU_LIBRARY, "Lib&rary");
+ fileMenu.addItem(MENU_FILE_LIBRARY, "Lib&rary");
fileMenu.addSeparator();
- fileMenu.addItem(MENU_EXIT, "E&xit");
+ fileMenu.addItem(MENU_FILE_EXIT, "E&xit");
+
+ TMenu OptionsMenu = addMenu("&Options");
+ OptionsMenu.addItem(MENU_OPT_FANFIX, "&Fanfix Configuration");
+ OptionsMenu.addItem(MENU_OPT_TUI, "&UI Configuration");
setStatusBar(fileMenu, "File-management "
+ "commands (Open, Save, Print, etc.)");
+
// TODO: Edit: re-download, delete
protected boolean onMenu(TMenuEvent menu) {
// TODO: i18n
switch (menu.getId()) {
- case MENU_EXIT:
+ case MENU_FILE_EXIT:
close(this);
return true;
- case MENU_OPEN:
+ case MENU_FILE_OPEN:
String openfile = null;
try {
openfile = fileOpenBox(".");
reader.setMeta(BasicReader.getUrl(openfile), null);
- read();
+ read(false);
} catch (IOException e) {
// TODO: i18n
error("Fail to open file"
}
return true;
- case MENU_IMPORT_URL:
+ case MENU_FILE_DELETE:
+ String luid = null;
+ String story = null;
+ MetaData meta = null;
+ if (main != null) {
+ meta = main.getSelectedMeta();
+ }
+ if (meta != null) {
+ luid = meta.getLuid();
+ story = luid + ": " + meta.getTitle();
+ }
+
+ // TODO: i18n
+ TMessageBox mbox = messageBox("Delete story", "Delete story \""
+ + story + "\"", Type.OKCANCEL);
+ if (mbox.getResult() == Result.OK) {
+ try {
+ reader.getLibrary().delete(luid);
+ if (main != null) {
+ main.refreshStories();
+ }
+ } catch (IOException e) {
+ // TODO: i18n
+ error("Fail to delete the story: \"" + story + "\"",
+ "Error", e);
+ }
+ }
+
+ return true;
+ case MENU_FILE_IMPORT_URL:
String clipboard = "";
try {
clipboard = ("" + Toolkit.getDefaultToolkit()
}
return true;
- case MENU_IMPORT_FILE:
+ case MENU_FILE_IMPORT_FILE:
String filename = null;
try {
filename = fileOpenBox(".");
"Import error", e);
}
return true;
- case MENU_LIBRARY:
+ case MENU_FILE_LIBRARY:
showMain();
return true;
+
+ case MENU_OPT_FANFIX:
+ new TuiReaderOptionWindow(this, false).maximize();
+ return true;
+
+ case MENU_OPT_TUI:
+ new TuiReaderOptionWindow(this, true).maximize();
+ return true;
+
}
return super.onMenu(menu);
}
@Override
- public void openExternal(BasicLibrary lib, String luid) throws IOException {
- reader.openExternal(lib, luid);
+ public void openExternal(BasicLibrary lib, String luid, boolean sync)
+ throws IOException {
+ reader.openExternal(lib, luid, sync);
}
/**