import javax.swing.JButton;
import javax.swing.JComboBox;
import javax.swing.JFrame;
+import javax.swing.JLabel;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JTabbedPane;
private JComboBox<SupportType> comboSupportTypes;
private JTabbedPane searchTabs;
private JTextField keywordsField;
+ private JButton submitKeywords;
private boolean seeWordcount;
private GuiReaderGroup books;
public GuiReaderSearch(final GuiReader reader) {
- // TODO: i18n
super("Browse stories");
setLayout(new BorderLayout());
setSize(800, 600);
}
supportType = supportTypes.isEmpty() ? null : supportTypes.get(0);
- JPanel top = new JPanel(new BorderLayout());
comboSupportTypes = new JComboBox<SupportType>(
supportTypes.toArray(new SupportType[] {}));
comboSupportTypes.addActionListener(new ActionListener() {
.getSelectedItem());
}
});
- top.add(comboSupportTypes, BorderLayout.NORTH);
+ JPanel searchSites = new JPanel(new BorderLayout());
+ searchSites.add(comboSupportTypes, BorderLayout.CENTER);
+ searchSites.add(new JLabel(" " + "Website : "), BorderLayout.WEST);
- // TODO: i18n
searchTabs = new JTabbedPane();
searchTabs.addTab("By name", createByNameSearchPanel());
searchTabs.addTab("By tags", createByTagSearchPanel());
+ JPanel top = new JPanel(new BorderLayout());
+ top.add(searchSites, BorderLayout.NORTH);
top.add(searchTabs, BorderLayout.CENTER);
add(top, BorderLayout.NORTH);
keywordsField = new JTextField();
byName.add(keywordsField, BorderLayout.CENTER);
- // TODO: i18n
- JButton submit = new JButton("Search");
- byName.add(submit, BorderLayout.EAST);
+ submitKeywords = new JButton("Search");
+ byName.add(submitKeywords, BorderLayout.EAST);
// TODO: ENTER -> search
- submit.addActionListener(new ActionListener() {
+ submitKeywords.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent e) {
search(supportType, keywordsField.getText(), page, 0);
});
}
+ // cannot be NULL
private void updateKeywords(final String keywords) {
- inUi(new Runnable() {
- @Override
- public void run() {
- GuiReaderSearch.this.keywords = keywords;
- keywordsField.setText(keywords);
- }
- });
+ if (!keywords.equals(this.keywords)) {
+ inUi(new Runnable() {
+ @Override
+ public void run() {
+ GuiReaderSearch.this.keywords = keywords;
+ keywordsField.setText(keywords);
+ }
+ });
+ }
}
// can be NULL
}
private void updateBooks(final List<GuiReaderBookInfo> infos) {
+ setWaitingScreen(true);
inUi(new Runnable() {
@Override
public void run() {
books.refreshBooks(infos, seeWordcount);
+ setWaitingScreen(false);
}
});
}
public void search(final SupportType searchOn, final String keywords,
final int page, final int item) {
+ setWaitingScreen(true);
+
updateSupportType(searchOn);
updateSearchBy(false);
updateKeywords(keywords);
// TODO: "click" on item ITEM
}
}
+
+ setWaitingScreen(false);
}
}).start();
}
- public void searchTag(SupportType searchOn, int page, int item,
- SearchableTag tag) {
+ public void searchTag(final SupportType searchOn, final int page,
+ final int item, final SearchableTag tag) {
+
+ setWaitingScreen(true);
updateSupportType(searchOn);
updateSearchBy(true);
updateTags(tag);
updatePages(page, maxPage);
- BasicSearchable search = BasicSearchable.getSearchable(searchOn);
-
- if (tag != null) {
- int maxPage = 0;
- try {
- maxPage = search.searchPages(tag);
- } catch (IOException e) {
- Instance.getTraceHandler().error(e);
- }
-
- updatePages(page, maxPage);
-
- if (page > 0) {
- List<MetaData> metas = null;
- List<SearchableTag> subtags = null;
- int count;
+ new Thread(new Runnable() {
+ @Override
+ public void run() {
+ BasicSearchable search = BasicSearchable
+ .getSearchable(searchOn);
- if (tag.isLeaf()) {
+ if (tag != null) {
+ int maxPage = 0;
try {
- metas = search.search(tag, page);
+ maxPage = search.searchPages(tag);
} catch (IOException e) {
- metas = new ArrayList<MetaData>();
Instance.getTraceHandler().error(e);
}
- count = metas.size();
- } else {
- subtags = tag.getChildren();
- count = subtags.size();
- }
- if (item > 0) {
- if (item <= count) {
- if (metas != null) {
- MetaData meta = metas.get(item - 1);
- // TODO: select story
+ updatePages(page, maxPage);
+
+ if (page > 0) {
+ List<MetaData> metas = null;
+ List<SearchableTag> subtags = null;
+ int count;
+
+ if (tag.isLeaf()) {
+ try {
+ metas = search.search(tag, page);
+ } catch (IOException e) {
+ metas = new ArrayList<MetaData>();
+ Instance.getTraceHandler().error(e);
+ }
+ count = metas.size();
} else {
- SearchableTag subtag = subtags.get(item - 1);
- // TODO: search on tag
+ subtags = tag.getChildren();
+ count = subtags.size();
+ }
+
+ if (item > 0) {
+ if (item <= count) {
+ if (metas != null) {
+ MetaData meta = metas.get(item - 1);
+ // TODO: select story
+ } else {
+ SearchableTag subtag = subtags
+ .get(item - 1);
+ // TODO: search on tag
+ }
+ }
}
}
}
+ setWaitingScreen(false);
}
- }
+ }).start();
}
/**
* @param run
* the action to run
*/
- public void inUi(final Runnable run) {
+ private void inUi(final Runnable run) {
if (EventQueue.isDispatchThread()) {
run.run();
} else {
}
}
}
+
+ private void setWaitingScreen(final boolean waiting) {
+ inUi(new Runnable() {
+ @Override
+ public void run() {
+ GuiReaderSearch.this.setEnabled(!waiting);
+ books.setEnabled(!waiting);
+ submitKeywords.setEnabled(!waiting);
+ }
+ });
+ }
}