fix see word count on source/author, step 1
[fanfix.git] / src / be / nikiroo / fanfix / reader / ui / GuiReaderGroup.java
CommitLineData
16a81ef7 1package be.nikiroo.fanfix.reader.ui;
4310bae9
NR
2
3import java.awt.BorderLayout;
4import java.awt.Color;
5import java.awt.event.ActionListener;
6import java.awt.event.MouseEvent;
7import java.util.ArrayList;
8import java.util.List;
9
10import javax.swing.JLabel;
11import javax.swing.JPanel;
12
16a81ef7 13import be.nikiroo.fanfix.reader.ui.GuiReaderBook.BookActionListener;
4310bae9
NR
14import be.nikiroo.utils.ui.WrapLayout;
15
16/**
5dd985cf 17 * A group of {@link GuiReaderBook}s for display.
4310bae9
NR
18 *
19 * @author niki
20 */
5dd985cf 21public class GuiReaderGroup extends JPanel {
4310bae9
NR
22 private static final long serialVersionUID = 1L;
23 private BookActionListener action;
24 private Color backgroundColor;
5dd985cf 25 private GuiReader reader;
79a99506 26 private List<GuiReaderBookInfo> infos;
5dd985cf 27 private List<GuiReaderBook> books;
4310bae9 28 private JPanel pane;
793f1071 29 private boolean words; // words or authors (secondary info on books)
4310bae9
NR
30
31 /**
5dd985cf 32 * Create a new {@link GuiReaderGroup}.
4310bae9
NR
33 *
34 * @param reader
e42573a0
NR
35 * the {@link GuiReaderBook} used to probe some information about
36 * the stories
4310bae9
NR
37 * @param title
38 * the title of this group
39 * @param backgroundColor
40 * the background colour to use (or NULL for default)
41 */
e42573a0 42 public GuiReaderGroup(GuiReader reader, String title, Color backgroundColor) {
4310bae9
NR
43 this.reader = reader;
44 this.backgroundColor = backgroundColor;
45
46 this.pane = new JPanel();
47
48 pane.setLayout(new WrapLayout(WrapLayout.LEADING, 5, 5));
49 if (backgroundColor != null) {
50 pane.setBackground(backgroundColor);
51 setBackground(backgroundColor);
52 }
53
54 setLayout(new BorderLayout(0, 10));
55 add(pane, BorderLayout.CENTER);
56
57 if (title != null) {
58 if (title.isEmpty()) {
59 title = "[unknown]";
60 }
61
62 JLabel label = new JLabel();
63 label.setText(String.format("<html>"
71d72f34
NR
64 + "<body style='text-align: center; color: gray;'><br><b>"
65 + "%s" + "</b></body>" + "</html>", title));
4310bae9
NR
66 label.setHorizontalAlignment(JLabel.CENTER);
67 add(label, BorderLayout.NORTH);
68 }
69 }
70
71 /**
72 * Set the {@link ActionListener} that will be fired on each
5dd985cf 73 * {@link GuiReaderBook} action.
4310bae9
NR
74 *
75 * @param action
76 * the action
77 */
78 public void setActionListener(BookActionListener action) {
79 this.action = action;
79a99506 80 refreshBooks(infos, words);
4310bae9
NR
81 }
82
83 /**
5dd985cf 84 * Refresh the list of {@link GuiReaderBook}s displayed in the control.
4310bae9
NR
85 *
86 * @param stories
87 * the stories
793f1071
NR
88 * @param seeWordcount
89 * TRUE to see word counts, FALSE to see authors
4310bae9 90 */
fb1ffdd0
NR
91 public void refreshBooks(List<GuiReaderBookInfo> infos, boolean seeWordcount) {
92 this.infos = infos;
793f1071 93 this.words = seeWordcount;
4310bae9 94
5dd985cf 95 books = new ArrayList<GuiReaderBook>();
4310bae9
NR
96 invalidate();
97 pane.invalidate();
98 pane.removeAll();
99
fb1ffdd0
NR
100 if (infos != null) {
101 for (GuiReaderBookInfo info : infos) {
79a99506
NR
102 boolean isCached = false;
103 if (info.getMeta() != null) {
104 isCached = reader.isCached(info.getMeta().getLuid());
105 }
106
107 GuiReaderBook book = new GuiReaderBook(reader, info, isCached,
fb1ffdd0 108 words);
4310bae9
NR
109 if (backgroundColor != null) {
110 book.setBackground(backgroundColor);
111 }
112
113 books.add(book);
114
115 book.addActionListener(new BookActionListener() {
211f7ddb 116 @Override
5dd985cf
NR
117 public void select(GuiReaderBook book) {
118 for (GuiReaderBook abook : books) {
4310bae9
NR
119 abook.setSelected(abook == book);
120 }
121 }
122
211f7ddb 123 @Override
e42573a0 124 public void popupRequested(GuiReaderBook book, MouseEvent e) {
4310bae9
NR
125 }
126
211f7ddb 127 @Override
5dd985cf 128 public void action(GuiReaderBook book) {
4310bae9
NR
129 }
130 });
131
132 if (action != null) {
133 book.addActionListener(action);
134 }
135
136 pane.add(book);
137 }
138 }
139
140 pane.validate();
141 pane.repaint();
142 validate();
143 repaint();
144 }
145
146 /**
147 * Enables or disables this component, depending on the value of the
148 * parameter <code>b</code>. An enabled component can respond to user input
149 * and generate events. Components are enabled initially by default.
150 * <p>
151 * Disabling this component will also affect its children.
152 *
153 * @param b
154 * If <code>true</code>, this component is enabled; otherwise
155 * this component is disabled
156 */
157 @Override
158 public void setEnabled(boolean b) {
159 if (books != null) {
5dd985cf 160 for (GuiReaderBook book : books) {
4310bae9
NR
161 book.setEnabled(b);
162 book.repaint();
163 }
164 }
165
166 pane.setEnabled(b);
167 super.setEnabled(b);
168 repaint();
169 }
170}