X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=src%2Fmain%2Fjava%2Fnet%2Fpterodactylus%2Fsone%2Ftemplate%2FReplyAccessor.java;h=e81c819448b86c7868954218cc189db0e308b74f;hb=953c41bc82b474680d84266fd7227ce08480883c;hp=db6c528040d9d8fd46499e656e5ba5e14253a437;hpb=915e48ef36a444907c00e818c8215db172c089a6;p=Sone.git diff --git a/src/main/java/net/pterodactylus/sone/template/ReplyAccessor.java b/src/main/java/net/pterodactylus/sone/template/ReplyAccessor.java index db6c528..e81c819 100644 --- a/src/main/java/net/pterodactylus/sone/template/ReplyAccessor.java +++ b/src/main/java/net/pterodactylus/sone/template/ReplyAccessor.java @@ -1,5 +1,5 @@ /* - * Sone - ReplyAccessor.java - Copyright © 2010 David Roden + * Sone - ReplyAccessor.java - Copyright © 2010–2013 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,18 +17,13 @@ package net.pterodactylus.sone.template; -import java.io.IOException; -import java.io.StringReader; - import net.pterodactylus.sone.core.Core; +import net.pterodactylus.sone.data.PostReply; import net.pterodactylus.sone.data.Reply; import net.pterodactylus.sone.data.Sone; -import net.pterodactylus.sone.text.FreenetLinkParser; -import net.pterodactylus.sone.text.FreenetLinkParserContext; import net.pterodactylus.util.template.Accessor; -import net.pterodactylus.util.template.DataProvider; import net.pterodactylus.util.template.ReflectionAccessor; -import net.pterodactylus.util.template.TemplateFactory; +import net.pterodactylus.util.template.TemplateContext; /** * {@link Accessor} implementation that adds a couple of properties to @@ -38,9 +33,6 @@ import net.pterodactylus.util.template.TemplateFactory; */ public class ReplyAccessor extends ReflectionAccessor { - /** Parser for Freenet links. */ - private final FreenetLinkParser linkParser; - /** The core. */ private final Core core; @@ -49,36 +41,25 @@ public class ReplyAccessor extends ReflectionAccessor { * * @param core * The core - * @param templateFactory - * The template factory for the text parser */ - public ReplyAccessor(Core core, TemplateFactory templateFactory) { + public ReplyAccessor(Core core) { this.core = core; - linkParser = new FreenetLinkParser(templateFactory); } - /** - * {@inheritDoc} - */ @Override - public Object get(DataProvider dataProvider, Object object, String member) { - Reply reply = (Reply) object; + public Object get(TemplateContext templateContext, Object object, String member) { + PostReply reply = (PostReply) object; if ("likes".equals(member)) { - return core.getLikes(reply); + return reply.getLikes(); } else if (member.equals("liked")) { - Sone currentSone = (Sone) dataProvider.getData("currentSone"); - return (currentSone != null) && (currentSone.isLikedReplyId(reply.getId())); + Sone currentSone = (Sone) templateContext.get("currentSone"); + return (currentSone != null) && reply.isLiked(currentSone); } else if (member.equals("new")) { - return core.isNewReply(reply.getId(), false); - } else if (member.equals("text")) { - String text = reply.getText(); - try { - return linkParser.parse(new FreenetLinkParserContext(reply.getSone()), new StringReader(text)); - } catch (IOException ioe1) { - /* ignore. */ - } + return !reply.isKnown(); + } else if (member.equals("loaded")) { + return reply.getSone() != null; } - return super.get(dataProvider, object, member); + return super.get(templateContext, object, member); } }