Merge branch '2.0'
[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 data-relocate="true" src="{@$__wcf->getPath()}js/WCF.Conversation{if !ENABLE_DEBUG_MODE}.min{/if}.js?v={@LAST_UPDATE_TIME}"></script>
9 <script data-relocate="true">
10 //<![CDATA[
11 $(function() {
12 WCF.Language.addObject({
13 'wcf.conversation.edit.addParticipants': '{lang}wcf.conversation.edit.addParticipants{/lang}',
14 'wcf.conversation.edit.assignLabel': '{lang}wcf.conversation.edit.assignLabel{/lang}',
15 'wcf.conversation.edit.close': '{lang}wcf.conversation.edit.close{/lang}',
16 'wcf.conversation.edit.leave': '{lang}wcf.conversation.edit.leave{/lang}',
17 'wcf.conversation.edit.open': '{lang}wcf.conversation.edit.open{/lang}',
18 'wcf.conversation.leave.title': '{lang}wcf.conversation.leave.title{/lang}',
19 'wcf.global.state.closed': '{lang}wcf.global.state.closed{/lang}',
20 'wcf.message.bbcode.code.copy': '{lang}wcf.message.bbcode.code.copy{/lang}',
21 'wcf.message.error.editorAlreadyInUse': '{lang}wcf.message.error.editorAlreadyInUse{/lang}',
22 'wcf.moderation.report.reportContent': '{lang}wcf.moderation.report.reportContent{/lang}',
23 'wcf.moderation.report.success': '{lang}wcf.moderation.report.success{/lang}',
24 'wcf.conversation.label.assignLabels': '{lang}wcf.conversation.label.assignLabels{/lang}'
25 });
26
27 var $availableLabels = [ {implode from=$labelList item=label}{ cssClassName: '{if $label->cssClassName}{@$label->cssClassName}{/if}', labelID: {@$label->labelID}, label: '{$label->label}' }{/implode} ];
28 var $editorHandler = new WCF.Conversation.EditorHandlerConversation($availableLabels);
29 var $inlineEditor = new WCF.Conversation.InlineEditor('.conversation');
30 $inlineEditor.setEditorHandler($editorHandler);
31
32 {assign var=__supportPaste value=true}
33 {if $conversation->isClosed}{assign var=__supportPaste value=false}{/if}
34 {include file='__messageQuoteManager' wysiwygSelector='text' supportPaste=$__supportPaste}
35
36 new WCF.Conversation.Message.InlineEditor({@$conversation->conversationID}, $quoteManager);
37 new WCF.Conversation.Message.QuoteHandler($quoteManager);
38 {if !$conversation->isClosed}new WCF.Conversation.QuickReply($quoteManager);{/if}
39
40 {if $__wcf->session->getPermission('user.profile.canReportContent')}
41 new WCF.Moderation.Report.Content('com.woltlab.wcf.conversation.message', '.jsReportConversationMessage');
42 {/if}
43 new WCF.Conversation.RemoveParticipant({@$conversation->conversationID});
44 new WCF.Message.BBCode.CodeViewer();
45 });
46 //]]>
47 </script>
48 </head>
49
50 <body id="tpl{$templateName|ucfirst}" data-template="{$templateName}" data-application="{$templateNameApplication}">
51
52 {include file='header'}
53
54 <header class="boxHeadline marginTop conversationHeadline labeledHeadline">
55 <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>
56
57 {hascontent}
58 <ul class="labelList">
59 {content}
60 {foreach from=$conversation->getAssignedLabels() item=label}
61 <li><span class="label badge{if $label->cssClassName} {$label->cssClassName}{/if}">{lang}{$label->label}{/lang}</span></li>
62 {/foreach}
63 {/content}
64 </ul>
65 {/hascontent}
66
67 {event name='headlineData'}
68 </header>
69
70 {include file='userNotice'}
71
72 {if !$conversation->isDraft}
73 <div class="container containerPadding marginTop">
74 <fieldset>
75 <legend>{lang}wcf.conversation.participants{/lang}</legend>
76
77 <ul class="containerBoxList tripleColumned conversationParticipantList">
78 {foreach from=$participants item=participant}
79 <li class="jsParticipant{if !$participant->userID || $participant->hideConversation == 2} conversationLeft{/if}">
80 <div class="box24">
81 {if $participant->userID}<a href="{link controller='User' object=$participant}{/link}" class="framed">{@$participant->getAvatar()->getImageTag(24)}</a>{else}<span class="framed">{@$participant->getAvatar()->getImageTag(24)}</span>{/if}
82 <div>
83 <p>
84 {if $participant->userID}<a href="{link controller='User' object=$participant}{/link}" class="userLink" data-user-id="{@$participant->userID}">{$participant->username}</a>{else}<span>{$participant->username}</span>{/if}
85 {if $participant->isInvisible}<small>({lang}wcf.conversation.invisible{/lang})</small>{/if}
86 {if $participant->userID && ($conversation->userID == $__wcf->getUser()->userID) && ($participant->userID != $__wcf->getUser()->userID) && $participant->hideConversation != 2}
87 <a href="#" 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>
88 {/if}
89 </p>
90 <dl class="plain inlineDataList">
91 <dt>{lang}wcf.conversation.lastVisitTime{/lang}</dt>
92 <dd>{if $participant->lastVisitTime}{@$participant->lastVisitTime|time}{else}-{/if}</dd>
93 </dl>
94 </div>
95 </div>
96 </li>
97 {/foreach}
98 </ul>
99 </fieldset>
100 </div>
101 {/if}
102
103 <div class="contentNavigation">
104 {pages print=true assign=pagesLinks controller='Conversation' object=$conversation link="pageNo=%d"}
105
106 <nav>
107 <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}">
108 <li class="jsOnly"><a href="#" class="button jsConversationInlineEditor"><span class="icon icon16 icon-pencil"></span> <span>{lang}wcf.global.button.edit{/lang}</span></a></li>
109 {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}
110 {event name='contentNavigationButtonsTop'}
111 </ul>
112 </nav>
113 </div>
114
115 <div class="marginTop">
116 <ul class="messageList">
117 {include file='conversationMessageList'}
118 {if !$conversation->isClosed}{include file='conversationQuickReply'}{/if}
119 </ul>
120 </div>
121
122 <div class="contentNavigation">
123 {@$pagesLinks}
124
125 {hascontent}
126 <nav>
127 <ul>
128 {content}
129 {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}
130 {event name='contentNavigationButtonsBottom'}
131 {/content}
132 </ul>
133 </nav>
134 {/hascontent}
135 </div>
136
137 {include file='footer'}
138
139 </body>
140 </html>