X-Git-Url: http://git.nikiroo.be/?a=blobdiff_plain;f=src%2Fbe%2Fnikiroo%2Ffanfix%2Freader%2FTuiReaderStoryWindow.java;h=9bc18fe992c46a396ffb9debb076f7a581a32850;hb=bc2ea776b67cabcbdcbbc6d8a4e2df1aafa9101a;hp=c942624bc4adc6de296386f9e3fd3549b6f876b6;hpb=0861d62ac01062a3cd20624cdd6a826df284695e;p=fanfix.git diff --git a/src/be/nikiroo/fanfix/reader/TuiReaderStoryWindow.java b/src/be/nikiroo/fanfix/reader/TuiReaderStoryWindow.java index c942624..9bc18fe 100644 --- a/src/be/nikiroo/fanfix/reader/TuiReaderStoryWindow.java +++ b/src/be/nikiroo/fanfix/reader/TuiReaderStoryWindow.java @@ -9,44 +9,48 @@ import jexer.TButton; import jexer.TCommand; import jexer.TKeypress; import jexer.TLabel; -import jexer.TText2; +import jexer.TText; import jexer.TWindow; import jexer.event.TResizeEvent; -import be.nikiroo.fanfix.Instance; import be.nikiroo.fanfix.data.Chapter; import be.nikiroo.fanfix.data.MetaData; import be.nikiroo.fanfix.data.Paragraph; import be.nikiroo.fanfix.data.Story; +import be.nikiroo.fanfix.library.BasicLibrary; -public class TuiReaderStoryWindow extends TWindow { +class TuiReaderStoryWindow extends TWindow { + private BasicLibrary lib; private MetaData meta; private Story story; - private TText2 textField; - private int chapter = -2; + private TText textField; + private int chapter = -1; private List navigationButtons; private TLabel chapterName; - public TuiReaderStoryWindow(TApplication app, MetaData meta) { - this(app, meta, 0); - } - - public TuiReaderStoryWindow(TApplication app, MetaData meta, int chapter) { + // chapter: -1 for "none" (0 is desc) + public TuiReaderStoryWindow(TApplication app, BasicLibrary lib, + MetaData meta, int chapter) { super(app, desc(meta), 0, 0, 60, 18, CENTERED | RESIZABLE); + + this.lib = lib; this.meta = meta; // TODO: show all meta info before? - textField = new TText2(this, "", 0, 0, getWidth() - 2, getHeight() - 2); + textField = new TText(this, "", 0, 0, getWidth() - 2, getHeight() - 2); statusBar = newStatusBar(desc(meta)); statusBar.addShortcutKeypress(TKeypress.kbF10, TCommand.cmExit, "Exit"); - navigationButtons = new ArrayList(4); + navigationButtons = new ArrayList(5); // -3 because 0-based and 2 for borders int row = getHeight() - 3; - addButton(" ", 0, row, null); // for bg colour when << button is pressed + navigationButtons.add(addButton(" ", 0, row, null)); // for bg colour + // when << + // button is + // pressed navigationButtons.add(addButton("<< ", 0, row, new TAction() { public void DO() { setChapter(0); @@ -68,6 +72,10 @@ public class TuiReaderStoryWindow extends TWindow { } })); + navigationButtons.get(0).setEnabled(false); + navigationButtons.get(1).setEnabled(false); + navigationButtons.get(2).setEnabled(false); + chapterName = addLabel("", 14, row); chapterName.setWidth(getWidth() - 10); setChapter(chapter); @@ -109,6 +117,14 @@ public class TuiReaderStoryWindow extends TWindow { if (chapter != this.chapter) { this.chapter = chapter; + + int max = getStory().getChapters().size(); + navigationButtons.get(0).setEnabled(chapter > 0); + navigationButtons.get(1).setEnabled(chapter > 0); + navigationButtons.get(2).setEnabled(chapter > 0); + navigationButtons.get(3).setEnabled(chapter < max); + navigationButtons.get(4).setEnabled(chapter < max); + Chapter chap; String name; if (chapter == 0) { @@ -116,8 +132,8 @@ public class TuiReaderStoryWindow extends TWindow { name = String.format(" %s", chap.getName()); } else { chap = getStory().getChapters().get(chapter - 1); - name = String.format(" %d/%d: %s", chapter, getStory() - .getChapters().size(), chap.getName()); + name = String + .format(" %d/%d: %s", chapter, max, chap.getName()); } while (name.length() < getWidth() - chapterName.getX()) { @@ -139,13 +155,14 @@ public class TuiReaderStoryWindow extends TWindow { } textField.setText(builder.toString()); textField.reflow(); + textField.toTop(); } } private Story getStory() { if (story == null) { // TODO: progress bar? - story = Instance.getLibrary().getStory(meta.getLuid(), null); + story = lib.getStory(meta.getLuid(), null); } return story; }