mirror of
https://github.com/wbbaddons/Tims-Chat.git
synced 2025-01-02 23:20:08 +00:00
279 lines
12 KiB
Smarty
279 lines
12 KiB
Smarty
{include file='documentHeader'}
|
|
|
|
<head>
|
|
<title>{if $room}{$room} - {/if}{lang}chat.global.title{/lang} - {PAGE_TITLE|language}</title>
|
|
|
|
{include file='headInclude'}
|
|
{if $room && (!$room->maxUsers || $room->getUsers()|count < $room->maxUsers || $room->canAlwaysEnter())}
|
|
{include file='javascriptInclude' application='chat'}
|
|
<script data-relocate="true">
|
|
//<![CDATA[
|
|
(function ($, window) {
|
|
$(function(){
|
|
WCF.Language.addObject({
|
|
'chat.global.autoAway': '{lang}chat.global.autoAway{/lang}',
|
|
'chat.global.ban': '{lang}chat.global.ban{/lang}',
|
|
'chat.global.closePrivateChannel': '{lang}chat.global.closePrivateChannel{/lang}',
|
|
'chat.global.closeTopic': '{lang}chat.global.closeTopic{/lang}',
|
|
'chat.global.notify.title': '{lang}chat.global.notify.title{/lang}',
|
|
'chat.global.mute': '{lang}chat.global.mute{/lang}',
|
|
'chat.global.privateChannelTopic': '{lang}chat.global.privateChannelTopic{/lang}',
|
|
'chat.global.profile': '{lang}chat.global.profile{/lang}',
|
|
'chat.global.query': '{lang}chat.global.query{/lang}',
|
|
'chat.global.smilies': '{lang}chat.global.smilies{/lang}',
|
|
'chat.global.whisper': '{lang}chat.global.whisper{/lang}',
|
|
'chat.global.invite': '{lang}chat.global.invite{/lang}',
|
|
'chat.error.duplicateTab': '{lang}chat.error.duplicateTab{/lang}',
|
|
'chat.error.join': '{lang}chat.error.join{/lang}',
|
|
'chat.error.onMessageLoad': '{@"chat.error.onMessageLoad"|language|encodeJS}',
|
|
'chat.error.reload': '{lang}chat.error.reload{/lang}',
|
|
'chat.message.{$messageTypes[TYPE_ATTACHMENT]}': '{lang}chat.message.{$messageTypes[TYPE_ATTACHMENT]}{/lang}',
|
|
'wcf.attachment.insert': '{lang}wcf.attachment.insert{/lang}',
|
|
'wcf.attachment.delete.sure': '{lang}wcf.attachment.delete.sure{/lang}',
|
|
'wcf.attachment.upload.error.invalidExtension': '{lang}wcf.attachment.upload.error.invalidExtension{/lang}',
|
|
'wcf.attachment.upload.error.tooLarge': '{lang}wcf.attachment.upload.error.tooLarge{/lang}',
|
|
'wcf.attachment.upload.error.reachedLimit': '{lang}wcf.attachment.upload.error.reachedLimit{/lang}',
|
|
'wcf.attachment.upload.error.reachedRemainingLimit': '{lang}wcf.attachment.upload.error.reachedRemainingLimit{/lang}',
|
|
'wcf.attachment.upload.error.uploadFailed': '{lang}wcf.attachment.upload.error.uploadFailed{/lang}',
|
|
'wcf.global.button.upload': '{lang}wcf.global.button.upload{/lang}'
|
|
});
|
|
|
|
// Boot the chat
|
|
{if MODULE_ATTACHMENT && $__wcf->session->getPermission('user.chat.canUploadAttachment')}
|
|
new be.bastelstu.Chat.Attachment();
|
|
new be.bastelstu.Chat.Action.Delete('wcf\\data\\attachment\\AttachmentAction', '#timsChatUploadDropdownMenu > li');
|
|
{/if}
|
|
|
|
WCF.TabMenu.init();
|
|
|
|
{if MODULE_SMILEY}
|
|
new WCF.Message.Smilies();
|
|
|
|
if (typeof $.fn.messageTabMenu === 'function') {
|
|
$('.messageTabMenu > .messageTabMenu').messageTabMenu().show();
|
|
}
|
|
{/if}
|
|
|
|
{capture assign='messageTemplate'}{include application='chat' file='message'}{/capture}
|
|
{capture assign='userTemplate'}{include application='chat' file='userListUser'}{/capture}
|
|
{capture assign='userMenuTemplate'}{include application='chat' file='userListUserMenu'}{/capture}
|
|
{capture assign='userInviteDialogTemplate'}{include application='chat' file='userInviteDialog'}{/capture}
|
|
|
|
var config = {
|
|
reloadTime: {@CHAT_RELOADTIME},
|
|
messageURL: '{link application="chat" controller="NewMessages"}{/link}',
|
|
installedCommands: [ {implode from=$commands item='command'}'{$command|encodeJS}'{/implode} ],
|
|
messageTypes: { {implode from=$messageTypes key='name' item='messageType'}'{$name|substr:5|encodeJS}': {$messageType}{/implode} },
|
|
autoAwayTime: {@CHAT_AUTOAWAY},
|
|
messagesPerTab: {@$__wcf->getUser()->chatMessagesPerTab}
|
|
};
|
|
|
|
{event name='beforeInit'}
|
|
|
|
be.bastelstu.Chat.init(
|
|
{$roomID},
|
|
config,
|
|
new WCF.Template('{literal}{if $newMessageCount}({#$newMessageCount}) {/if}{$title} - {/literal}{"chat.global.title"|language|encodeJS} - {PAGE_TITLE|language|encodeJS}'),
|
|
new WCF.Template('{@$messageTemplate|encodeJS}'),
|
|
new WCF.Template('{@$userTemplate|encodeJS}'),
|
|
new WCF.Template('{@$userMenuTemplate|encodeJS}'),
|
|
new WCF.Template('{@$userInviteDialogTemplate|encodeJS}')
|
|
);
|
|
|
|
{event name='afterInit'}
|
|
|
|
$('#timsChatCopyright a').click(function (event) {
|
|
event.preventDefault();
|
|
if (!$.wcfIsset('timsChatCopyrightDialog')) $('<div id="timsChatCopyrightDialog"></div>').appendTo('body');
|
|
$('#timsChatCopyrightDialog').load('{link application="chat" controller="Copyright"}{/link}').wcfDialog({
|
|
title: '<img width="246" height="90" alt="" src="{$__wcf->getPath("chat")|encodeJS}images/chatLogo.png"> {if SHOW_VERSION_NUMBER} {PACKAGE_VERSION}{/if}'
|
|
});
|
|
});
|
|
});
|
|
})(jQuery, this);
|
|
//]]>
|
|
</script>
|
|
{/if}
|
|
</head>
|
|
|
|
<body id="tpl{$templateName|ucfirst}">
|
|
{if $room && (!$room->maxUsers || $room->getUsers()|count < $room->maxUsers || $room->canAlwaysEnter())}
|
|
{capture assign='sidebar'}{include application='chat' file='sidebar'}{/capture}
|
|
{include file='header' sandbox=false sidebarOrientation='right'}
|
|
|
|
<div class="clearfix">
|
|
<div id="timsChatTopic" class="container containerPadding marginTop{if $room->topic|language === ''} empty{/if}">
|
|
<span id="timsChatTopicCloser" class="icon icon16 icon-remove jsTooltip" title="{lang}chat.global.closeTopic{/lang}"></span>
|
|
<span class="topic">{$room->topic|language}</span>
|
|
</div>
|
|
|
|
<div id="timsChatMessageTabMenu" class="tabMenuContainer singleTab" data-active="timsChatMessageContainer0">
|
|
<nav class="tabMenu">
|
|
<ul>
|
|
<li>
|
|
<a id="timsChatMessageTabMenuAnchor0" href="{$__wcf->getAnchor('timsChatMessageContainer0')}" class="timsChatMessageTabMenuAnchor" data-user-id="0">
|
|
<span class="icon icon16 icon-warning-sign notifyIcon"></span>{*
|
|
*}<span class="userAvatar framed">
|
|
<span class="icon icon16 icon-group"></span>
|
|
</span>{*
|
|
*}<span>{$room}</span>
|
|
</a>
|
|
</li>
|
|
</ul>
|
|
</nav>
|
|
|
|
<div id="timsChatMessageContainer0" class="tabMenuContent timsChatMessageContainer container containerPadding active" data-user-id="0">
|
|
<p class="error noJsOnly" style="display: none;">{lang}chat.global.noJs{/lang}</p>
|
|
<ul></ul>
|
|
</div>
|
|
</div>
|
|
|
|
<form id="timsChatForm" action="{link application='chat' controller='Chat' action='Send'}{/link}" method="post">
|
|
<fieldset>
|
|
<dl class="wide" id="timsChatInputContainer">
|
|
<dt>
|
|
{lang}chat.global.message{/lang}
|
|
</dt>
|
|
<dd>
|
|
<input id="timsChatInput" accesskey="w" type="text" class="inputText long" name="text" autocomplete="off" maxlength="{@CHAT_MAX_LENGTH}" disabled="disabled" placeholder="{lang}chat.global.submit.default{/lang}" />
|
|
<small class="innerError" style="display: none;">Lorem ipsum dolor sit amet.</small>
|
|
</dd>
|
|
</dl>
|
|
</fieldset>
|
|
<button type="submit" class="marginTop invisible" accesskey="s">{lang}wcf.global.button.submit{/lang}</button>
|
|
</form>
|
|
|
|
{if MODULE_SMILEY && $smileyCategories|count}
|
|
<div id="timsChatSmileyContainer" class="messageTabMenu marginTop">
|
|
{include file='messageFormSmilies' wysiwygSelector=''}
|
|
</div>
|
|
{/if}
|
|
|
|
<div id="timsChatOptions" class="marginTop">
|
|
<span id="timsChatSmileyPopupButton" class="button smallButtons">
|
|
<span class="icon icon16 icon-smile"></span>
|
|
<span>{lang}chat.global.smilies{/lang}</span>
|
|
</span>
|
|
|
|
<nav class="jsMobileNavigation buttonGroupNavigation">
|
|
<ul class="buttonGroup">
|
|
<li>
|
|
<a id="timsChatAutoscroll" accesskey="d" class="button active timsChatToggle jsTooltip" title="{lang}chat.global.scroll{/lang}" data-status="1">
|
|
<span class="icon icon16 icon-arrow-down"></span>
|
|
<span class="invisible">{lang}chat.global.scroll{/lang}</span>
|
|
</a>
|
|
</li>
|
|
|
|
<li>
|
|
<a id="timsChatFullscreen" accesskey="f" class="button{if $__wcf->getUser()->chatButtonFullscreen} active{/if} timsChatToggle persists jsTooltip" title="{lang}chat.global.fullscreen{/lang}" data-status="{@$__wcf->getUser()->chatButtonFullscreen}">
|
|
<span class="icon icon16 icon-fullscreen"></span>
|
|
<span class="invisible">{lang}chat.global.fullscreen{/lang}</span>
|
|
</a>
|
|
</li>
|
|
|
|
<li>
|
|
<a id="timsChatNotify" accesskey="n" class="button{if $__wcf->getUser()->chatButtonNotify} active{/if} timsChatToggle persists jsTooltip" title="{lang}chat.global.notify{/lang}" data-status="{@$__wcf->getUser()->chatButtonNotify}">
|
|
<span class="icon icon16 icon-bell-alt"></span>
|
|
<span class="invisible">{lang}chat.global.notify{/lang}</span>
|
|
</a>
|
|
</li>
|
|
|
|
{if MODULE_SMILEY && $smileyCategories|count}
|
|
<li>
|
|
<a id="timsChatSmilies" accesskey="e" class="button{if $__wcf->getUser()->chatButtonSmilies} active{/if} timsChatToggle persists jsTooltip" title="{lang}chat.global.smilies{/lang}" data-status="{@$__wcf->getUser()->chatButtonSmilies}">
|
|
<span class="icon icon16 icon-smile"></span>
|
|
<span class="invisible">{lang}chat.global.smilies{/lang}</span>
|
|
</a>
|
|
</li>
|
|
{/if}
|
|
|
|
{if MODULE_ATTACHMENT && $__wcf->session->getPermission('user.chat.canUploadAttachment')}
|
|
<li id="timsChatUploadContainer" class="dropdown" data-max-size="{$attachmentHandler->getMaxSize()}">
|
|
<a id="timsChatUpload" class="dropdownToggle button jsTooltip" title="{lang}wcf.attachment.attachments{/lang}" data-toggle="timsChatUploadContainer">
|
|
<span class="icon icon16 icon-paper-clip"></span>
|
|
<span class="invisible">{lang}wcf.attachment.attachments{/lang}</span>
|
|
</a>
|
|
<ul id="timsChatUploadDropdownMenu" class="dropdownMenu">
|
|
<li class="uploadButton" style="margin-top: 0;">
|
|
<span><label for="timsChatUploadInput" class="pointer">{lang}wcf.global.button.upload{/lang}</label></span>
|
|
</li>
|
|
</ul>
|
|
</li>
|
|
{/if}
|
|
|
|
{if $__wcf->session->getPermission('user.chat.canInvite')}
|
|
<li>
|
|
<a id="timsChatInvite" class="button jsTooltip" title="{lang}chat.global.invite{/lang}">
|
|
<span class="icon icon16 icon-user"></span>
|
|
<span class="invisible">{lang}chat.global.invite{/lang}</span>
|
|
</a>
|
|
</li>
|
|
{/if}
|
|
|
|
<li>
|
|
<a id="timsChatClear" class="button jsTooltip" title="{lang}chat.global.clear{/lang}">
|
|
<span class="icon icon16 icon-remove"></span>
|
|
<span class="invisible">{lang}chat.global.clear{/lang}</span>
|
|
</a>
|
|
</li>
|
|
|
|
<li>
|
|
<a id="timsChatMark" class="button timsChatToggle jsTooltip" title="{lang}chat.global.mark{/lang}" data-status="0">
|
|
<span class="icon icon16 icon-check"></span>
|
|
<span class="invisible">{lang}chat.global.mark{/lang}</span>
|
|
</a>
|
|
</li>
|
|
|
|
{event name='buttons'}
|
|
</ul>
|
|
</nav>
|
|
</div>
|
|
</div>
|
|
{else}
|
|
{include file='header' sandbox=false}
|
|
<header class="boxHeadline">
|
|
<h1>{lang}chat.global.title{/lang}</h1>
|
|
</header>
|
|
|
|
{include file='userNotice'}
|
|
|
|
{if $room && ($room->getUsers()|count >= $room->maxUsers)}
|
|
<p class="warning">{lang room=$room}chat.global.error.join.full{/lang}</p>
|
|
{/if}
|
|
|
|
<div id="chatRoomListContainer" class="container marginTop">
|
|
<ul class="containerList">
|
|
{include application='chat' file='boxRoomList' showEmptyRooms=true}
|
|
</ul>
|
|
<script data-relocate="true">
|
|
//<![CDATA[
|
|
(function($, window, undefined) {
|
|
var proxy = new WCF.Action.Proxy({
|
|
data: {
|
|
actionName: 'getBoxRoomList',
|
|
className: 'chat\\data\\room\\RoomAction',
|
|
parameters: {
|
|
showEmptyRooms: 1
|
|
}
|
|
},
|
|
showLoadingOverlay: false,
|
|
suppressErrors: true,
|
|
success: function(data) {
|
|
$('#chatRoomListContainer ul').html(data.returnValues.template);
|
|
}
|
|
});
|
|
|
|
$(function () {
|
|
be.bastelstu.wcf.push.onMessage('be.bastelstu.chat.join', proxy.sendRequest.bind(proxy));
|
|
be.bastelstu.wcf.push.onMessage('be.bastelstu.chat.leave', proxy.sendRequest.bind(proxy));
|
|
});
|
|
})(jQuery, this);
|
|
//]]>
|
|
</script>
|
|
</div>
|
|
{/if}
|
|
|
|
{include file='footer' sandbox=false}
|
|
</body>
|
|
</html>
|