Add separate “show more” and “show less” links.
[Sone.git] / src / main / resources / templates / include / viewPost.html
1 <div id="<% post.id|html>" class="post<%if loop.last> last<%/if><%if post.new> new<%/if>">
2         <a name="post-<% post.id|html>"></a>
3         <div class="post-time hidden"><% post.time|html></div>
4         <div class="post-author hidden"><% post.sone.id|html></div>
5         <div class="post-author-local hidden"><% post.sone.local></div>
6         <div class="avatar">
7                 <%if post.loaded>
8                         <img src="/WebOfTrust/GetIdenticon?identity=<% post.sone.id|html>&amp;width=48&height=48" width="48" height="48" alt="Avatar Image" />
9                 <%else>
10                         <img src="images/sone-avatar.png" width="48" height="48" alt="Avatar Image" />
11                 <%/if>
12         </div>
13         <div class="inner-part">
14                 <div<%if !post.loaded> class="hidden"<%/if>>
15                         <div class="author profile-link"><a href="viewSone.html?sone=<% post.sone.id|html>"><% post.sone.niceName|html></a></div>
16                         <%ifnull !post.recipient>
17                                 <span class="recipient-to">→</span>
18                                 <%ifnull post.recipient.identity>
19                                         <div class="recipient profile-link"><a href="viewSone.html?sone=<% post.recipient.id|html>"><%= View.Post.UnknownAuthor|l10n|html></a></div>
20                                 <%else>
21                                         <div class="recipient profile-link"><a href="viewSone.html?sone=<% post.recipient.id|html>"><% post.recipient.niceName|html></a></div>
22                                 <%/if>
23                         <%/if>
24                         <% post.text|html|store key=originalText text=true>
25                         <% post.text|parse sone=post.sone|store key=parsedText text=true>
26                         <% post.text|parse sone=post.sone length=200|store key=shortText text=true>
27                         <div class="post-text raw-text<%if !raw> hidden<%/if>"><% originalText></div>
28                         <div class="post-text text<%if raw> hidden<%/if><%if !shortText|match key=parsedText> hidden<%/if>"><% parsedText></div>
29                         <div class="post-text short-text<%if raw> hidden<%/if><%if shortText|match key=parsedText> hidden<%/if>"><% shortText></div>
30                         <%if !shortText|match key=parsedText><%if !raw><a class="expand-post-text" href="viewPost.html?post=<% post.id|html>&amp;raw=true"><%= View.Post.ShowMore|l10n|html></a><%/if><%/if>
31                         <%if !shortText|match key=parsedText><%if !raw><a class="shrink-post-text hidden"><%= View.Post.ShowLess|l10n|html></a><%/if><%/if>
32                 </div>
33                 <div class="post-status-line status-line<%if !post.loaded> hidden<%/if>">
34                         <div class="bookmarks">
35                                 <form class="unbookmark<%if !post.bookmarked> hidden<%/if>" action="unbookmark.html" method="post">
36                                         <input type="hidden" name="formPassword" value="<% formPassword|html>" />
37                                         <input type="hidden" name="returnPage" value="<% request.uri|html>" />
38                                         <input type="hidden" name="post" value="<% post.id|html>" />
39                                         <button type="submit" title="<%= View.Post.Bookmarks.PostIsBookmarked|l10n|html>">★</button>
40                                 </form>
41                                 <form class="bookmark<%if post.bookmarked> hidden<%/if>" action="bookmark.html" method="post">
42                                         <input type="hidden" name="formPassword" value="<% formPassword|html>" />
43                                         <input type="hidden" name="returnPage" value="<% request.uri|html>" />
44                                         <input type="hidden" name="post" value="<% post.id|html>" />
45                                         <button type="submit" title="<%= View.Post.Bookmarks.PostIsNotBookmarked|l10n|html>">☆</button>
46                                 </form>
47                         </div>
48                         <span class='separator'>·</span>
49                         <div class="time"><a href="viewPost.html?post=<% post.id|html>"><% post.time|date format="MMM d, yyyy, HH:mm:ss"></a></div>
50                         <span class='separator'>·</span>
51                         <div class="permalink permalink-post"><a href="post://<%post.id|html>">[<%= View.Post.Permalink|l10n|html>]</a></div>
52                         <span class='separator'>·</span>
53                         <div class="permalink permalink-author"><a href="sone://<%post.sone.id|html>">[<%= View.Post.PermalinkAuthor|l10n|html>]</a></div>
54                         <%if ! originalText|match key=parsedText>
55                                 <span class='separator'>·</span>
56                                 <div class="show-source"><a href="viewPost.html?post=<% post.id|html>&amp;raw=<%if raw>false<%else>true<%/if>"><%= View.Post.ShowSource|l10n|html></a></div>
57                         <%/if>
58                         <div class="likes<%if post.likes.size|match value=0> hidden<%/if>">
59                                 <span class='separator'>·</span>
60                                 <span title="<% post.likes.soneNames|html>">↑<span class="like-count"><% post.likes.size></span></span>
61                         </div>
62                         <%ifnull ! currentSone>
63                                 <span class='separator'>·</span>
64                                 <form class="like like-post<%if post.liked> hidden<%/if>" action="like.html" method="post">
65                                         <input type="hidden" name="formPassword" value="<% formPassword|html>" />
66                                         <input type="hidden" name="returnPage" value="<% request.uri|html>" />
67                                         <input type="hidden" name="type" value="post" />
68                                         <input type="hidden" name="post" value="<% post.id|html>" />
69                                         <button type="submit" value="1"><%= View.Post.LikeLink|l10n|html></button>
70                                 </form>
71                                 <form class="unlike unlike-post<%if ! post.liked> hidden<%/if>" action="unlike.html" method="post">
72                                         <input type="hidden" name="formPassword" value="<% formPassword|html>" />
73                                         <input type="hidden" name="returnPage" value="<% request.uri|html>" />
74                                         <input type="hidden" name="type" value="post" />
75                                         <input type="hidden" name="post" value="<% post.id|html>" />
76                                         <button type="submit" value="1"><%= View.Post.UnlikeLink|l10n|html></button>
77                                 </form>
78                                 <%if !post.sone.current>
79                                         <span class='separator'>·</span>
80                                         <form class="trust post-trust<%if post.sone.trust.assigned> hidden<%/if>" action="trust.html" method="post">
81                                                 <input type="hidden" name="formPassword" value="<% formPassword|html>" />
82                                                 <input type="hidden" name="returnPage" value="<% request.uri|html>" />
83                                                 <input type="hidden" name="sone" value="<% post.sone.id|html>" />
84                                                 <button type="submit" title="<%= View.Trust.Tooltip.Trust|l10n|html>">✓</button>
85                                         </form>
86                                         <form class="distrust post-distrust<%if post.sone.trust.assigned> hidden<%/if>" action="distrust.html" method="post">
87                                                 <input type="hidden" name="formPassword" value="<% formPassword|html>" />
88                                                 <input type="hidden" name="returnPage" value="<% request.uri|html>" />
89                                                 <input type="hidden" name="sone" value="<% post.sone.id|html>" />
90                                                 <button type="submit" title="<%= View.Trust.Tooltip.Distrust|l10n|html>">✗</button>
91                                         </form>
92                                         <form class="untrust post-untrust<%if !post.sone.trust.assigned> hidden<%/if>" action="untrust.html" method="post">
93                                                 <input type="hidden" name="formPassword" value="<% formPassword|html>" />
94                                                 <input type="hidden" name="returnPage" value="<% request.uri|html>" />
95                                                 <input type="hidden" name="sone" value="<% post.sone.id|html>" />
96                                                 <button type="submit" title="<%= View.Trust.Tooltip.Untrust|l10n|html>">↶</button>
97                                         </form>
98                                 <%/if>
99                         <%/if>
100                         <%if post.sone.local>
101                                 <span class='separator'>·</span>
102                                 <form class="delete delete-post" action="deletePost.html" method="post">
103                                         <input type="hidden" name="formPassword" value="<% formPassword|html>" />
104                                         <input type="hidden" name="returnPage" value="<% request.uri|html>" />
105                                         <input type="hidden" name="post" value="<% post.id|html>" />
106                                         <button type="submit"><%= View.Post.DeleteLink|l10n|html></button>
107                                 </form>
108                         <%/if>
109                 </div>
110                 <div<%if post.loaded> class="hidden"<%/if>>
111                         <%= View.Post.NotDownloaded|l10n|html>
112                 </div>
113                 <div class="replies">
114                         <%foreach post.replies reply>
115                                 <%include include/viewReply.html>
116                         <%/foreach>
117                         <%ifnull ! currentSone>
118                                 <div class="create-reply">
119                                         <form method="post" action="createReply.html">
120                                                 <input type="hidden" name="formPassword" value="<% formPassword|html>" />
121                                                 <input type="hidden" name="returnPage" value="<% request.uri|html>" />
122                                                 <input type="hidden" name="post" value="<% post.id|html>" />
123                                                 <div class="sender">
124                                                         <select name="sender" title="<%= View.UpdateStatus.Text.ChooseSenderIdentity|l10n|html>">
125                                                                 <%foreach localSones localSone|sort>
126                                                                         <option value="<% localSone.id|html>"<%if localSone.current> selected="selected"<%/if>><% localSone.niceName|html></option>
127                                                                 <%/foreach>
128                                                         </select>
129                                                 </div>
130                                                 <div class="select-sender"><button type="button" title="<%= View.UpdateStatus.Text.ChooseSenderIdentity|l10n|html>">+</button></div>
131                                                 <input type="text" class="reply-input" name="text" value="" />
132                                                 <button type="submit"><%= View.Post.SendReply|l10n|html></button>
133                                         </form>
134                                 </div>
135                         <%/if>
136                 </div>
137         </div>
138 </div>