Merge branch 'master' of github.com:WoltLab/com.woltlab.wcf.conversation
[GitHub/WoltLab/com.woltlab.wcf.conversation.git] / templates / conversation.tpl
1 {include file='documentHeader'}
2
3 <head>
4 <title>{$conversation->subject} {if $pageNo > 1}- {lang}wcf.page.pageNo{/lang} {/if} - {PAGE_TITLE|language}</title>
5
6 {include file='headInclude'}
7
8 <script type="text/javascript" src="{@$__wcf->getPath()}js/WCF.Conversation.js"></script>
9 <script type="text/javascript" src="{@$__wcf->getPath()}js/WCF.Moderation.js"></script>
10 <script type="text/javascript">
11 //<![CDATA[
12 $(function() {
13 WCF.Language.addObject({
14 'wcf.conversation.edit.addParticipants': '{lang}wcf.conversation.edit.addParticipants{/lang}',
15 'wcf.conversation.edit.assignLabel': '{lang}wcf.conversation.edit.assignLabel{/lang}',
16 'wcf.conversation.edit.close': '{lang}wcf.conversation.edit.close{/lang}',
17 'wcf.conversation.edit.leave': '{lang}wcf.conversation.edit.leave{/lang}',
18 'wcf.conversation.edit.open': '{lang}wcf.conversation.edit.open{/lang}',
19 'wcf.conversation.leave.title': '{lang}wcf.conversation.leave.title{/lang}',
20 'wcf.global.state.closed': '{lang}wcf.global.state.closed{/lang}',
21 'wcf.moderation.report.reportContent': '{lang}wcf.moderation.report.reportContent{/lang}',
22 'wcf.moderation.report.success': '{lang}wcf.moderation.report.success{/lang}',
23 'wcf.conversation.label.assignLabels': '{lang}wcf.conversation.label.assignLabels{/lang}'
24 });
25
26 var $availableLabels = [ {implode from=$labelList item=label}{ cssClassName: '{if $label->cssClassName}{@$label->cssClassName}{/if}', labelID: {@$label->labelID}, label: '{$label->label}' }{/implode} ];
27 var $editorHandler = new WCF.Conversation.EditorHandlerConversation($availableLabels);
28 var $inlineEditor = new WCF.Conversation.InlineEditor('.conversation');
29 $inlineEditor.setEditorHandler($editorHandler);
30
31 new WCF.Conversation.Message.InlineEditor({@$conversation->conversationID});
32
33 {include file='__messageQuoteManager' wysiwygSelector='text' supportPaste=true}
34 new WCF.Conversation.Message.QuoteHandler($quoteManager);
35 {if !$conversation->isClosed}new WCF.Conversation.QuickReply($quoteManager);{/if}
36
37 new WCF.Moderation.Report.Content('com.woltlab.wcf.conversation.message', '.jsReportConversationMessage');
38 new WCF.Conversation.RemoveParticipant({@$conversation->conversationID});
39 });
40 //]]>
41 </script>
42 </head>
43
44 <body id="tpl{$templateName|ucfirst}">
45
46 {include file='header'}
47
48 <header class="boxHeadline marginTop conversationHeadline">
49 <hgroup>
50 <h1><a href="{link controller='Conversation' object=$conversation}{/link}">{$conversation->subject}</a>{if $conversation->isClosed} <span class="icon icon16 icon-lock jsTooltip jsIconLock" title="{lang}wcf.global.state.closed{/lang}"></span>{/if}</h1>
51 </hgroup>
52
53 {hascontent}
54 <ul class="labelList">
55 {content}
56 {foreach from=$conversation->getAssignedLabels() item=label}
57 <li><span class="label badge{if $label->cssClassName} {$label->cssClassName}{/if}">{lang}{$label->label}{/lang}</span></li>
58 {/foreach}
59 {/content}
60 </ul>
61 {/hascontent}
62
63 {event name='headlineData'}
64 </header>
65
66 {include file='userNotice'}
67
68 {if !$conversation->isDraft}
69 <div class="container containerPadding marginTop">
70 <fieldset>
71 <legend>{lang}wcf.conversation.participants{/lang}</legend>
72
73 <ul class="containerBoxList tripleColumned conversationParticipantList">
74 {foreach from=$participants item=participant}
75 <li class="jsParticipant{if $participant->hideConversation == 2} conversationLeft{/if}">
76 <div class="box24">
77 <a href="{link controller='User' object=$participant}{/link}" class="framed">{@$participant->getAvatar()->getImageTag(24)}</a>
78 <hgroup>
79 <h1>
80 <a href="{link controller='User' object=$participant}{/link}" class="userLink" data-user-id="{@$participant->userID}">{$participant->username}</a>
81 {if $participant->isInvisible}<small>({lang}wcf.conversation.invisible{/lang})</small>{/if}
82 {if ($conversation->userID == $__wcf->getUser()->userID) && ($participant->userID != $__wcf->getUser()->userID) && $participant->hideConversation != 2}
83 <a class="jsDeleteButton jsTooltip jsOnly" title="{lang}wcf.conversation.participants.removeParticipant{/lang}" data-confirm-message="{lang}wcf.conversation.participants.removeParticipant.confirmMessage{/lang}" data-object-id="{@$participant->userID}"><span class="icon icon16 icon-remove"></span></a>
84 {/if}
85 </h1>
86 <h2><dl class="plain inlineDataList">
87 <dt>{lang}wcf.conversation.lastVisitTime{/lang}</dt>
88 <dd>{if $participant->lastVisitTime}{@$participant->lastVisitTime|time}{else}-{/if}</dd>
89 </dl></h2>
90 </hgroup>
91 </div>
92 </li>
93 {/foreach}
94 </ul>
95 </fieldset>
96 </div>
97 {/if}
98
99 <div class="contentNavigation">
100 {pages print=true assign=pagesLinks controller='Conversation' object=$conversation link="pageNo=%d"}
101
102 <nav>
103 <ul class="conversation jsConversationInlineEditorContainer" data-conversation-id="{@$conversation->conversationID}" data-label-ids="[ {implode from=$conversation->getAssignedLabels() item=label}{@$label->labelID}{/implode} ]" data-is-closed="{@$conversation->isClosed}" data-can-close-conversation="{if $conversation->userID == $__wcf->getUser()->userID}1{else}0{/if}" data-can-add-participants="{if $conversation->canAddParticipants()}1{else}0{/if}">
104 <li class="jsOnly"><a class="button jsConversationInlineEditor"><span class="icon icon16 icon-pencil"></span> <span>{lang}wcf.global.button.edit{/lang}</span></a></li>
105 {if !$conversation->isClosed}<li><a href="{link controller='ConversationMessageAdd' id=$conversationID}{/link}" title="{lang}wcf.conversation.message.add{/lang}" class="button buttonPrimary jsQuickReply"><span class="icon icon16 icon-plus"></span> <span>{lang}wcf.conversation.message.button.add{/lang}</span></a></li>{/if}
106 {event name='contentNavigationButtonsTop'}
107 </ul>
108 </nav>
109 </div>
110
111 <div class="marginTop">
112 <ul class="messageList">
113 {include file='conversationMessageList'}
114 {if !$conversation->isClosed}{include file='conversationQuickReply'}{/if}
115 </ul>
116 </div>
117
118 <div class="contentNavigation">
119 {@$pagesLinks}
120
121 {hascontent}
122 <nav>
123 <ul>
124 {content}
125 {if !$conversation->isClosed}<li><a href="{link controller='ConversationMessageAdd' id=$conversationID}{/link}" title="{lang}wcf.conversation.message.add{/lang}" class="button buttonPrimary jsQuickReply"><span class="icon icon16 icon-plus"></span> <span>{lang}wcf.conversation.message.button.add{/lang}</span></a></li>{/if}
126 {event name='contentNavigationButtonsBottom'}
127 {/content}
128 </ul>
129 </nav>
130 {/hascontent}
131 </div>
132
133 {include file='footer'}
134
135 </body>
136 </html>