Use new template engine.
[Sone.git] / src / main / java / net / pterodactylus / sone / web / ViewSonePage.java
index ba69eed..0792a6f 100644 (file)
 
 package net.pterodactylus.sone.web;
 
+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;
+import net.pterodactylus.util.template.TemplateContext;
 
 /**
  * Lets the user browser another Sone.
@@ -36,7 +41,7 @@ public class ViewSonePage extends SoneTemplatePage {
         *            The Sone web interface
         */
        public ViewSonePage(Template template, WebInterface webInterface) {
-               super("viewSone.html", template, "Page.ViewSone.Title", webInterface);
+               super("viewSone.html", template, "Page.ViewSone.Title", webInterface, false);
        }
 
        //
@@ -47,11 +52,30 @@ public class ViewSonePage extends SoneTemplatePage {
         * {@inheritDoc}
         */
        @Override
-       protected void processTemplate(Request request, Template template) throws RedirectException {
-               super.processTemplate(request, template);
+       protected void processTemplate(Request request, TemplateContext templateContext) throws RedirectException {
+               super.processTemplate(request, templateContext);
                String soneId = request.getHttpRequest().getParam("sone");
-               Sone sone = webInterface.core().getSone(soneId);
-               template.set("sone", sone);
+               Sone sone = webInterface.getCore().getSone(soneId, false);
+               templateContext.set("sone", sone);
+       }
+
+       /**
+        * {@inheritDoc}
+        */
+       @Override
+       protected void postProcess(Request request, TemplateContext templateContext) {
+               Sone sone = (Sone) templateContext.get("sone");
+               if (sone == null) {
+                       return;
+               }
+               webInterface.getCore().markSoneKnown(sone);
+               List<Post> posts = sone.getPosts();
+               for (Post post : posts) {
+                       webInterface.getCore().markPostKnown(post);
+                       for (Reply reply : webInterface.getCore().getReplies(post)) {
+                               webInterface.getCore().markReplyKnown(reply);
+                       }
+               }
        }
 
 }