mirror of
https://gitlab.com/biskuteri-cafe/JKomasto2.git
synced 2025-01-24 10:11:39 +01:00
More satisfactory..
This commit is contained in:
parent
b47a97e8ad
commit
31277c7871
149
PostWindow.java
149
PostWindow.java
@ -53,40 +53,34 @@ implements ActionListener {
|
||||
|
||||
this.post = post;
|
||||
|
||||
List<RepliesComponent.Reply> replies = null;
|
||||
{
|
||||
List<Post> posts = null;
|
||||
// We should make a request to JKomasto here.
|
||||
}
|
||||
if (replies == null)
|
||||
{
|
||||
RepliesComponent.Reply reply1, reply2, reply3;
|
||||
reply1 = new RepliesComponent.Reply();
|
||||
reply1.author = "Black tea";
|
||||
reply1.text = "Rich..";
|
||||
reply2 = new RepliesComponent.Reply();
|
||||
reply2.author = "Green tea";
|
||||
reply2.text = "Clean!";
|
||||
reply3 = new RepliesComponent.Reply();
|
||||
reply3.author = "Coffee";
|
||||
reply3.text = "sleepy..";
|
||||
|
||||
replies = new ArrayList<>();
|
||||
replies.add(reply1);
|
||||
replies.add(reply2);
|
||||
replies.add(reply3);
|
||||
}
|
||||
|
||||
postDisplay.setAuthor(post.authorName);
|
||||
postDisplay.setTime(post.date);
|
||||
postDisplay.setText(post.text);
|
||||
|
||||
/*
|
||||
* We also have to display the replies for that post.
|
||||
* Are we supposed to request those replies ourselves?
|
||||
* Shouldn't the caller of setPost also give us the
|
||||
* reply posts?
|
||||
*/
|
||||
|
||||
if (post == null)
|
||||
{
|
||||
List<String> authors = new ArrayList<>();
|
||||
List<String> texts = new ArrayList<>();
|
||||
authors.add("Black tea");
|
||||
authors.add("Green tea");
|
||||
authors.add("White tea");
|
||||
texts.add("Rich..");
|
||||
texts.add("Clean!");
|
||||
texts.add("Myu..");
|
||||
repliesDisplay.setReplies(authors, texts);
|
||||
/*
|
||||
* THe replies display contains a reduction of every
|
||||
* reply post. Rather than repeatedly loop through the
|
||||
* replies to assemble lists of individual information,
|
||||
* we should loop once and assemble a list of structs.
|
||||
* Then repliesDisplay should support that struct..
|
||||
*
|
||||
* Alternatively, repliesDisplay can accept (reply) posts
|
||||
* directly, avoiding a new struct. But that goes against
|
||||
* our communication model here.
|
||||
*/
|
||||
}
|
||||
repliesDisplay.setReplies(replies);
|
||||
}
|
||||
|
||||
// - -%- -
|
||||
@ -238,8 +232,10 @@ PostComponent extends JPanel {
|
||||
class
|
||||
RepliesComponent extends JPanel {
|
||||
|
||||
private List<String>
|
||||
authors, texts;
|
||||
private List<RepliesComponent.Reply>
|
||||
replies;
|
||||
|
||||
// - -%- -
|
||||
|
||||
private JButton
|
||||
prevPage, nextPage;
|
||||
@ -253,71 +249,73 @@ RepliesComponent extends JPanel {
|
||||
// ---%-@-%---
|
||||
|
||||
public void
|
||||
setReplies(List<String> authors, List<String> texts)
|
||||
setReplies(List<RepliesComponent.Reply> replies)
|
||||
{
|
||||
assert authors != null;
|
||||
assert texts != null;
|
||||
assert authors.size() == texts.size();
|
||||
|
||||
this.authors.clear();
|
||||
this.authors.addAll(authors);
|
||||
this.texts.clear();
|
||||
this.texts.addAll(texts);
|
||||
|
||||
assert replies != null;
|
||||
this.replies = replies;
|
||||
displayPage(1);
|
||||
int currentPage = authors.isEmpty() ? 0 : 1;
|
||||
int pages = (7 + authors.size()) / 8;
|
||||
// (0 + 7) / 8 = 0
|
||||
// (1 + 7) / 8 = 1
|
||||
// (8 + 7) / 8 = 1
|
||||
// (9 + 7) / 8 = 2
|
||||
// (32 + 7) / 8 = 4
|
||||
pageLabel.setText(currentPage + "/" + pages);
|
||||
}
|
||||
|
||||
// - -%- -
|
||||
|
||||
private void
|
||||
displayPage(int pageNumber)
|
||||
{
|
||||
assert pageNumber > 0;
|
||||
assert this.replies != null;
|
||||
|
||||
List<RepliesComponent.Reply> page;
|
||||
{
|
||||
int oS = (pageNumber - 1) * 8;
|
||||
if (oS >= authors.size()) return;
|
||||
// (悪) Quietly fail?
|
||||
int oE = Math.min(oS + 8, authors.size());
|
||||
List<String> authors = this.authors.subList(oS, oE);
|
||||
List<String> texts = this.texts.subList(oS, oE);
|
||||
int l = oE - oS;
|
||||
|
||||
for (int o = 0; o < 8; ++o)
|
||||
{
|
||||
ReplyPreviewComponent preview = previews[o];
|
||||
|
||||
if (o >= l) // That doesn't seem right..
|
||||
{
|
||||
preview.setVisible(false);
|
||||
int oE = Math.min(oS + 8, replies.size());
|
||||
if (oS > oE) page = new ArrayList<>();
|
||||
else page = this.replies.subList(oS, oE);
|
||||
}
|
||||
else
|
||||
|
||||
for (int o = 0; o < page.size(); ++o)
|
||||
{
|
||||
preview.setAuthor(authors.get(oS + o));
|
||||
preview.setText(texts.get(oS + o));
|
||||
assert o < previews.length;
|
||||
|
||||
ReplyPreviewComponent preview = previews[o];
|
||||
Reply reply = replies.get(o);
|
||||
preview.setAuthor(reply.author);
|
||||
preview.setText(reply.text);
|
||||
preview.setVisible(true);
|
||||
}
|
||||
|
||||
for (int o = page.size(); o < previews.length; ++o)
|
||||
{
|
||||
ReplyPreviewComponent preview = previews[o];
|
||||
preview.setVisible(false);
|
||||
}
|
||||
|
||||
int pages = 1 + ((replies.size() - 1) / 8);
|
||||
pageLabel.setText(pageNumber + "/" + pages);
|
||||
}
|
||||
|
||||
// ---%-@-%---
|
||||
|
||||
public static class
|
||||
Reply {
|
||||
|
||||
public String
|
||||
author;
|
||||
|
||||
public String
|
||||
text;
|
||||
|
||||
}
|
||||
|
||||
// ---%-@-%---
|
||||
|
||||
RepliesComponent()
|
||||
{
|
||||
authors = new ArrayList<>();
|
||||
texts = new ArrayList<>();
|
||||
|
||||
prevPage = new JButton("<");
|
||||
nextPage = new JButton(">");
|
||||
prevPage.setEnabled(false);
|
||||
nextPage.setEnabled(false);
|
||||
|
||||
pageLabel = new JLabel("0 / 0");
|
||||
pageLabel = new JLabel();
|
||||
|
||||
Box bottom = Box.createHorizontalBox();
|
||||
bottom.add(Box.createGlue());
|
||||
@ -344,12 +342,13 @@ RepliesComponent extends JPanel {
|
||||
add(bottom, BorderLayout.SOUTH);
|
||||
|
||||
setBorder(BorderFactory.createEmptyBorder(8, 8, 8, 8));
|
||||
|
||||
setReplies(new ArrayList<>());
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
class
|
||||
ReplyPreviewComponent extends JButton {
|
||||
|
||||
@ -396,8 +395,4 @@ ReplyPreviewComponent extends JButton {
|
||||
g.drawString(getText(), 8, 2 * getHeight() / 3);
|
||||
}
|
||||
|
||||
// ---%-@-%---
|
||||
|
||||
ReplyPreviewComponent() { }
|
||||
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user