X-Git-Url: https://git.pterodactylus.net/?p=Sone.git;a=blobdiff_plain;f=src%2Fmain%2Fjava%2Fnet%2Fpterodactylus%2Fsone%2Fweb%2FViewPostPage.java;h=56bac8d37662727d87982a4c2ba463dec210df7d;hp=0918e55564556b05ddba9e20e9538b211823d159;hb=7b55e0be6a3283e43a9bbab98f82aebdd948eb33;hpb=d9e840e34436f648179a318512b92836187f31e0 diff --git a/src/main/java/net/pterodactylus/sone/web/ViewPostPage.java b/src/main/java/net/pterodactylus/sone/web/ViewPostPage.java index 0918e55..56bac8d 100644 --- a/src/main/java/net/pterodactylus/sone/web/ViewPostPage.java +++ b/src/main/java/net/pterodactylus/sone/web/ViewPostPage.java @@ -1,5 +1,5 @@ /* - * Sone - ViewPostPage.java - Copyright © 2010 David Roden + * Sone - ViewPostPage.java - Copyright © 2010–2016 David Roden * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by @@ -17,8 +17,15 @@ package net.pterodactylus.sone.web; +import java.net.URI; + +import com.google.common.base.Optional; + import net.pterodactylus.sone.data.Post; +import net.pterodactylus.sone.template.SoneAccessor; +import net.pterodactylus.sone.web.page.FreenetRequest; import net.pterodactylus.util.template.Template; +import net.pterodactylus.util.template.TemplateContext; /** * This page lets the user view a post and all its replies. @@ -36,7 +43,7 @@ public class ViewPostPage extends SoneTemplatePage { * The Sone web interface */ public ViewPostPage(Template template, WebInterface webInterface) { - super("viewPost.html", template, "Page.ViewPost.Title", webInterface); + super("viewPost.html", template, "Page.ViewPost.Title", webInterface, false); } // @@ -47,22 +54,35 @@ public class ViewPostPage extends SoneTemplatePage { * {@inheritDoc} */ @Override - protected void processTemplate(Request request, Template template) throws RedirectException { - super.processTemplate(request, template); + protected String getPageTitle(FreenetRequest request) { String postId = request.getHttpRequest().getParam("post"); - Post post = webInterface.core().getPost(postId); - template.set("post", post); + Optional post = webInterface.getCore().getPost(postId); + String title = ""; + if (post.isPresent()) { + title = post.get().getText().substring(0, Math.min(20, post.get().getText().length())) + "…"; + title += " - " + SoneAccessor.getNiceName(post.get().getSone()) + " - "; + } + title += webInterface.getL10n().getString("Page.ViewPost.Title"); + return title; } - // - // SONETEMPLATEPAGE METHODS - // + /** + * {@inheritDoc} + */ + @Override + protected void handleRequest(FreenetRequest request, TemplateContext templateContext) throws RedirectException { + String postId = request.getHttpRequest().getParam("post"); + boolean raw = request.getHttpRequest().getParam("raw").equals("true"); + Optional post = webInterface.getCore().getPost(postId); + templateContext.set("post", post.orNull()); + templateContext.set("raw", raw); + } /** * {@inheritDoc} */ @Override - protected boolean requiresLogin() { + public boolean isLinkExcepted(URI link) { return true; }