import java.util.ArrayList;
import java.util.Collections;
-import java.util.Comparator;
import java.util.List;
import net.pterodactylus.sone.data.Post;
+import net.pterodactylus.sone.data.Reply;
import net.pterodactylus.sone.data.Sone;
import net.pterodactylus.util.template.Template;
* The Sone web interface
*/
public IndexPage(Template template, WebInterface webInterface) {
- super("index.html", template, "Page.Index.Title", webInterface);
+ super("index.html", template, "Page.Index.Title", webInterface, true);
}
//
@Override
protected void processTemplate(Request request, Template template) throws RedirectException {
super.processTemplate(request, template);
- Sone sone = getCurrentSone(request.getToadletContext());
+ Sone currentSone = getCurrentSone(request.getToadletContext());
List<Post> allPosts = new ArrayList<Post>();
- allPosts.addAll(sone.getPosts());
- for (Sone friendSone : sone.getFriends()) {
- allPosts.addAll(friendSone.getPosts());
+ allPosts.addAll(currentSone.getPosts());
+ for (String friendSoneId : currentSone.getFriends()) {
+ if (!webInterface.getCore().hasSone(friendSoneId)) {
+ continue;
+ }
+ allPosts.addAll(webInterface.getCore().getSone(friendSoneId).getPosts());
}
- Collections.sort(allPosts, new Comparator<Post>() {
-
- @Override
- public int compare(Post leftPost, Post rightPost) {
- return (int) Math.max(Integer.MIN_VALUE, Math.min(Integer.MAX_VALUE, rightPost.getTime() - leftPost.getTime()));
+ for (Sone sone : webInterface.getCore().getSones()) {
+ for (Post post : sone.getPosts()) {
+ if (currentSone.equals(post.getRecipient()) && !allPosts.contains(post)) {
+ allPosts.add(post);
+ }
}
-
- });
+ }
+ Collections.sort(allPosts, Post.TIME_COMPARATOR);
template.set("posts", allPosts);
}
- //
- // SONETEMPLATEPAGE METHODS
- //
-
/**
* {@inheritDoc}
*/
@Override
- protected boolean requiresLogin() {
- return true;
+ protected void postProcess(Request request, Template template) {
+ @SuppressWarnings("unchecked")
+ List<Post> posts = (List<Post>) template.get("posts");
+ for (Post post : posts) {
+ webInterface.getCore().markPostKnown(post);
+ for (Reply reply : webInterface.getCore().getReplies(post)) {
+ webInterface.getCore().markReplyKnown(reply);
+ }
+ }
}
}