Fixed time zone calculation issue
[GitHub/WoltLab/WCF.git] / wcfsetup / install / files / acp / templates / header.tpl
1 <!DOCTYPE html>
2 <html dir="{@$__wcf->getLanguage()->getPageDirection()}" lang="{@$__wcf->getLanguage()->getFixedLanguageCode()}">
3 <head>
4 <base href="{$baseHref}" />
5 <meta charset="utf-8" />
6 <title>{if $pageTitle|isset}{@$pageTitle|language} - {/if}{lang}wcf.global.acp{/lang}{if PACKAGE_ID} - {PAGE_TITLE|language}{/if}</title>
7 <script data-relocate="true">
8 //<![CDATA[
9 var SID_ARG_2ND = '{@SID_ARG_2ND_NOT_ENCODED}';
10 var WCF_PATH = '{@$__wcf->getPath()}';
11 var SECURITY_TOKEN = '{@SECURITY_TOKEN}';
12 var LANGUAGE_ID = {@$__wcf->getLanguage()->languageID};
13 var TIME_NOW = {@TIME_NOW};
14 //]]>
15 </script>
16 <script data-relocate="true" src="{@$__wcf->getPath()}js/3rdParty/jquery.min.js?v={@$__wcfVersion}"></script>
17 <script data-relocate="true" src="{@$__wcf->getPath()}js/3rdParty/jquery-ui.min.js?v={@$__wcfVersion}"></script>
18 <script data-relocate="true" src="{@$__wcf->getPath()}js/3rdParty/jquery-ui.nestedSortable.min.js?v={@$__wcfVersion}"></script>
19 <script data-relocate="true" src="{@$__wcf->getPath()}js/3rdParty/jquery-ui.timepicker.min.js?v={@$__wcfVersion}"></script>
20 <script data-relocate="true" src="{@$__wcf->getPath()}js/WCF.js?v={@$__wcfVersion}"></script>
21 <script data-relocate="true" src="{@$__wcf->getPath()}acp/js/WCF.ACP.js?v={@$__wcfVersion}"></script>
22 <script data-relocate="true">
23 //<![CDATA[
24 WCF.User.init({$__wcf->user->userID}, '{@$__wcf->user->username|encodeJS}');
25 //]]>
26 </script>
27 {event name='javascriptInclude'}
28
29 <!-- Stylesheets -->
30 {@$__wcf->getStyleHandler()->getStylesheet()}
31 {event name='stylesheets'}
32
33 <!-- Icons -->
34 <link rel="shortcut icon" href="{@$__wcf->getPath()}images/favicon.ico" />
35 <link rel="apple-touch-icon" href="{@$__wcf->getPath()}images/apple-touch-icon.png" />
36
37 <script data-relocate="true">
38 //<![CDATA[
39 $(function() {
40 {* work-around for unknown core-object during WCFSetup *}
41 {if PACKAGE_ID}
42 {assign var=activeMenuItems value=$__wcf->getACPMenu()->getActiveMenuItems()|array_reverse}
43 var $activeMenuItems = [{implode from=$activeMenuItems item=_menuItem}'{$_menuItem}'{/implode}];
44 new WCF.ACP.Menu($activeMenuItems);
45 {/if}
46
47 WCF.Language.addObject({
48 '__days': [ '{lang}wcf.date.day.sunday{/lang}', '{lang}wcf.date.day.monday{/lang}', '{lang}wcf.date.day.tuesday{/lang}', '{lang}wcf.date.day.wednesday{/lang}', '{lang}wcf.date.day.thursday{/lang}', '{lang}wcf.date.day.friday{/lang}', '{lang}wcf.date.day.saturday{/lang}' ],
49 '__daysShort': [ '{lang}wcf.date.day.sun{/lang}', '{lang}wcf.date.day.mon{/lang}', '{lang}wcf.date.day.tue{/lang}', '{lang}wcf.date.day.wed{/lang}', '{lang}wcf.date.day.thu{/lang}', '{lang}wcf.date.day.fri{/lang}', '{lang}wcf.date.day.sat{/lang}' ],
50 '__months': [ '{lang}wcf.date.month.january{/lang}', '{lang}wcf.date.month.february{/lang}', '{lang}wcf.date.month.march{/lang}', '{lang}wcf.date.month.april{/lang}', '{lang}wcf.date.month.may{/lang}', '{lang}wcf.date.month.june{/lang}', '{lang}wcf.date.month.july{/lang}', '{lang}wcf.date.month.august{/lang}', '{lang}wcf.date.month.september{/lang}', '{lang}wcf.date.month.october{/lang}', '{lang}wcf.date.month.november{/lang}', '{lang}wcf.date.month.december{/lang}' ],
51 '__monthsShort': [ '{lang}wcf.date.month.short.jan{/lang}', '{lang}wcf.date.month.short.feb{/lang}', '{lang}wcf.date.month.short.mar{/lang}', '{lang}wcf.date.month.short.apr{/lang}', '{lang}wcf.date.month.short.may{/lang}', '{lang}wcf.date.month.short.jun{/lang}', '{lang}wcf.date.month.short.jul{/lang}', '{lang}wcf.date.month.short.aug{/lang}', '{lang}wcf.date.month.short.sep{/lang}', '{lang}wcf.date.month.short.oct{/lang}', '{lang}wcf.date.month.short.nov{/lang}', '{lang}wcf.date.month.short.dec{/lang}' ],
52 'wcf.acp.search.noResults': '{lang}wcf.acp.search.noResults{/lang}',
53 'wcf.clipboard.item.unmarkAll': '{lang}wcf.clipboard.item.unmarkAll{/lang}',
54 'wcf.date.relative.now': '{lang}wcf.date.relative.now{/lang}',
55 'wcf.date.relative.minutes': '{capture assign=relativeMinutes}{lang}wcf.date.relative.minutes{/lang}{/capture}{@$relativeMinutes|encodeJS}',
56 'wcf.date.relative.hours': '{capture assign=relativeHours}{lang}wcf.date.relative.hours{/lang}{/capture}{@$relativeHours|encodeJS}',
57 'wcf.date.relative.pastDays': '{capture assign=relativePastDays}{lang}wcf.date.relative.pastDays{/lang}{/capture}{@$relativePastDays|encodeJS}',
58 'wcf.date.dateFormat': '{lang}wcf.date.dateFormat{/lang}',
59 'wcf.date.dateTimeFormat': '{lang}wcf.date.dateTimeFormat{/lang}',
60 'wcf.date.shortDateTimeFormat': '{lang}wcf.date.shortDateTimeFormat{/lang}',
61 'wcf.date.hour': '{lang}wcf.date.hour{/lang}',
62 'wcf.date.minute': '{lang}wcf.date.minute{/lang}',
63 'wcf.date.timeFormat': '{lang}wcf.date.timeFormat{/lang}',
64 'wcf.date.firstDayOfTheWeek': '{lang}wcf.date.firstDayOfTheWeek{/lang}',
65 'wcf.global.button.add': '{lang}wcf.global.button.add{/lang}',
66 'wcf.global.button.cancel': '{lang}wcf.global.button.cancel{/lang}',
67 'wcf.global.button.close': '{lang}wcf.global.button.close{/lang}',
68 'wcf.global.button.collapsible': '{lang}wcf.global.button.collapsible{/lang}',
69 'wcf.global.button.delete': '{lang}wcf.global.button.delete{/lang}',
70 'wcf.global.button.disable': '{lang}wcf.global.button.disable{/lang}',
71 'wcf.global.button.disabledI18n': '{lang}wcf.global.button.disabledI18n{/lang}',
72 'wcf.global.button.edit': '{lang}wcf.global.button.edit{/lang}',
73 'wcf.global.button.enable': '{lang}wcf.global.button.enable{/lang}',
74 'wcf.global.button.next': '{lang}wcf.global.button.next{/lang}',
75 'wcf.global.button.preview': '{lang}wcf.global.button.preview{/lang}',
76 'wcf.global.button.reset': '{lang}wcf.global.button.reset{/lang}',
77 'wcf.global.button.save': '{lang}wcf.global.button.save{/lang}',
78 'wcf.global.button.search': '{lang}wcf.global.button.search{/lang}',
79 'wcf.global.button.submit': '{lang}wcf.global.button.submit{/lang}',
80 'wcf.global.confirmation.cancel': '{lang}wcf.global.confirmation.cancel{/lang}',
81 'wcf.global.confirmation.confirm': '{lang}wcf.global.confirmation.confirm{/lang}',
82 'wcf.global.confirmation.title': '{lang}wcf.global.confirmation.title{/lang}',
83 'wcf.global.decimalPoint': '{capture assign=decimalPoint}{lang}wcf.global.decimalPoint{/lang}{/capture}{$decimalPoint|encodeJS}',
84 'wcf.global.error.timeout': '{lang}wcf.global.error.timeout{/lang}',
85 'wcf.global.error.title': '{lang}wcf.global.error.title{/lang}',
86 'wcf.global.form.error.empty': '{lang}wcf.global.form.error.empty{/lang}',
87 'wcf.global.form.error.greaterThan': '{lang}wcf.global.form.error.greaterThan.javaScript{/lang}',
88 'wcf.global.form.error.lessThan': '{lang}wcf.global.form.error.lessThan.javaScript{/lang}',
89 'wcf.global.loading': '{lang}wcf.global.loading{/lang}',
90 'wcf.global.page.jumpTo': '{lang}wcf.global.page.jumpTo{/lang}',
91 'wcf.global.page.jumpTo.description': '{lang}wcf.global.page.jumpTo.description{/lang}',
92 'wcf.global.page.pageNavigation': '{lang}wcf.global.page.pageNavigation{/lang}',
93 'wcf.global.page.next': '{capture assign=pageNext}{lang}wcf.global.page.next{/lang}{/capture}{@$pageNext|encodeJS}',
94 'wcf.global.page.previous': '{capture assign=pagePrevious}{lang}wcf.global.page.previous{/lang}{/capture}{@$pagePrevious|encodeJS}',
95 'wcf.global.pageDirection': '{lang}wcf.global.pageDirection{/lang}',
96 'wcf.global.success': '{lang}wcf.global.success{/lang}',
97 'wcf.global.success.add': '{lang}wcf.global.success.add{/lang}',
98 'wcf.global.success.edit': '{lang}wcf.global.success.edit{/lang}',
99 'wcf.global.thousandsSeparator': '{capture assign=thousandsSeparator}{lang}wcf.global.thousandsSeparator{/lang}{/capture}{@$thousandsSeparator|encodeJS}'
100 {event name='javascriptLanguageImport'}
101 });
102
103 if (jQuery.browser.touch) $('html').addClass('touch');
104 new WCF.Date.Time();
105 new WCF.Effect.SmoothScroll();
106 new WCF.Effect.BalloonTooltip();
107
108 WCF.Dropdown.init();
109 WCF.System.PageNavigation.init('.pageNavigation');
110 WCF.Date.Picker.init();
111 WCF.System.FlexibleMenu.init();
112
113 {if $__wcf->user->userID}
114 new WCF.ACP.Search();
115 {/if}
116
117 {event name='javascriptInit'}
118 });
119 //]]>
120 </script>
121 </head>
122
123 <body id="tpl{$templateName|ucfirst}">
124 <a id="top"></a>
125
126 <header id="pageHeader" class="layoutFluid">
127 <div>
128 {if $__wcf->user->userID}
129 <nav id="topMenu" class="userPanel">
130 <div class="layoutFluid">
131 <ul class="userPanelItems">
132 <li id="userMenu" class="dropdown">
133 <a class="dropdownToggle framed" data-toggle="userMenu">{if PACKAGE_ID}{@$__wcf->getUserProfileHandler()->getAvatar()->getImageTag(24)} {/if}{lang}wcf.user.userNote{/lang}</a>
134 <ul class="dropdownMenu">
135 {if PACKAGE_ID > 1}
136 <li><a href="{link controller='User' object=$__wcf->user forceFrontend=true}{/link}" class="box32">
137 <div class="framed">{@$__wcf->getUserProfileHandler()->getAvatar()->getImageTag(32)}</div>
138
139 <div class="containerHeadline">
140 <h3>{$__wcf->user->username}</h3>
141 <small>{lang}wcf.user.myProfile{/lang}</small>
142 </div>
143 </a></li>
144 {if $__wcf->getUserProfileHandler()->canEditOwnProfile()}<li><a href="{link controller='User' object=$__wcf->user forceFrontend=true}editOnInit=true#about{/link}">{lang}wcf.user.editProfile{/lang}</a></li>{/if}
145 <li><a href="{link controller='Settings' forceFrontend=true}{/link}">{lang}wcf.user.menu.settings{/lang}</a></li>
146
147 {event name='userMenuItems'}
148
149 <li class="dropdownDivider"></li>
150 {/if}
151 <li><a href="{link controller='Logout'}t={@SECURITY_TOKEN}{/link}" onclick="WCF.System.Confirmation.show('{lang}wcf.user.logout.sure{/lang}', $.proxy(function (action) { if (action == 'confirm') window.location.href = $(this).attr('href'); }, this)); return false;">{lang}wcf.user.logout{/lang}</a></li>
152 </ul>
153 </li>
154
155 {if PACKAGE_ID > 1}
156 <li id="jumpToPage" class="dropdown">
157 <a href="{link forceFrontend=true}{/link}" class="dropdownToggle" data-toggle="jumpToPage"><span class="icon icon16 icon-home"></span> <span>{lang}wcf.global.jumpToPage{/lang}</span></a>
158 <ul class="dropdownMenu">
159 {foreach from=$__wcf->getPageMenu()->getMenuItems('header') item=_menuItem}
160 <li><a href="{$_menuItem->getProcessor()->getLink()}">{lang}{$_menuItem->menuItem}{/lang}</a></li>
161 {/foreach}
162 </ul>
163 </li>
164
165 {if $__wcf->session->getPermission('admin.system.package.canUpdatePackage') && $__wcf->getAvailableUpdates()}
166 <li>
167 <a href="{link controller='PackageUpdate'}{/link}"><span class="icon icon16 icon-refresh"></span> <span>{lang}wcf.acp.package.updates{/lang}</span> <span class="badge badgeInverse">{#$__wcf->getAvailableUpdates()}</span></a>
168 </li>
169 {/if}
170 {/if}
171
172 <li id="woltlab" class="dropdown">
173 <a class="dropdownToggle" data-toggle="woltlab"><span class="icon icon16 icon-info-sign"></span> <span>WoltLab&reg;</span></a>
174
175 <ul class="dropdownMenu">
176 <li><a class="externalURL" href="{@$__wcf->getPath()}acp/dereferrer.php?url={"http://www.woltlab.com"|rawurlencode}">{lang}wcf.acp.index.woltlab.website{/lang}</a></li>
177 <li><a class="externalURL" href="{@$__wcf->getPath()}acp/dereferrer.php?url={"http://www.woltlab.com/forum/"|rawurlencode}">{lang}wcf.acp.index.woltlab.forums{/lang}</a></li>
178 <li><a class="externalURL" href="{@$__wcf->getPath()}acp/dereferrer.php?url={"http://www.woltlab.com/index.php/TicketAdd/"|rawurlencode}">{lang}wcf.acp.index.woltlab.tickets{/lang}</a></li>
179 <li><a class="externalURL" href="{@$__wcf->getPath()}acp/dereferrer.php?url={"http://www.woltlab.com/pluginstore/"|rawurlencode}">{lang}wcf.acp.index.woltlab.pluginStore{/lang}</a></li>
180 </ul>
181 </li>
182
183 {event name='topMenu'}
184 </ul>
185
186 {if $__wcf->getSession()->getPermission('admin.general.canUseAcp')}
187 <aside id="search" class="searchBar">
188 <form>
189 <input type="search" name="q" placeholder="{lang}wcf.global.search.enterSearchTerm{/lang}" value="" />
190 </form>
191 </aside>
192 {/if}
193 </div>
194 </nav>
195 {/if}
196
197 <div id="logo" class="logo">
198 <a href="{link}{/link}">
199 <h1>{lang}wcf.global.acp{/lang}</h1>
200 {if PACKAGE_ID > 1}
201 {event name='headerLogo'}
202 {else}
203 <img src="{@$__wcf->getPath()}acp/images/wcfLogo.png" alt="" style="height: 80px; width: 502px;" />
204 {/if}
205 </a>
206 </div>
207
208 {* work-around for unknown core-object during WCFSetup *}
209 {if PACKAGE_ID && $__wcf->user->userID}
210 {hascontent}
211 <nav id="mainMenu" class="mainMenu">
212 <ul>{content}{foreach from=$__wcf->getACPMenu()->getMenuItems('') item=_menuItem}<li data-menu-item="{$_menuItem->menuItem}"><a>{lang}{@$_menuItem->menuItem}{/lang}</a></li>{/foreach}{/content}</ul>
213 </nav>
214 {/hascontent}
215 {/if}
216
217 <nav class="navigation navigationHeader">
218 <ul class="navigationIcons">
219 <li id="toBottomLink" class="toBottomLink"><a href="{@$__wcf->getAnchor('bottom')}" title="{lang}wcf.global.scrollDown{/lang}" class="jsTooltip"><span class="icon icon16 icon-arrow-down"></span> <span class="invisible">{lang}wcf.global.scrollDown{/lang}</span></a></li>
220 {event name='navigationIcons'}
221 </ul>
222 </nav>
223 </div>
224 </header>
225
226 <div id="main" class="layoutFluid{if PACKAGE_ID && $__wcf->user->userID && $__wcf->getACPMenu()->getMenuItems('')|count} sidebarOrientationLeft{/if}">
227 <div>
228 <div>
229 {hascontent}
230 <aside class="sidebar collapsibleMenu">
231 <div>
232 {content}
233 {* work-around for unknown core-object during WCFSetup *}
234 {if PACKAGE_ID && $__wcf->user->userID}
235 {foreach from=$__wcf->getACPMenu()->getMenuItems('') item=_parentMenuItem}
236 <div id="{$_parentMenuItem->menuItem}-container" style="display: none;" class="menuGroup collapsibleMenus" data-parent-menu-item="{$_parentMenuItem->menuItem}">
237 {foreach from=$__wcf->getACPMenu()->getMenuItems($_parentMenuItem->menuItem) item=_menuItem}
238 <fieldset>
239 <legend class="menuHeader" data-menu-item="{$_menuItem->menuItem}">{@$_menuItem}</legend>
240
241 <nav class="menuGroupItems">
242 <ul id="{$_menuItem->menuItem}">
243 {foreach from=$__wcf->getACPMenu()->getMenuItems($_menuItem->menuItem) item=menuItemCategory}
244 {if $__wcf->getACPMenu()->getMenuItems($menuItemCategory->menuItem)|count > 0}
245 {foreach from=$__wcf->getACPMenu()->getMenuItems($menuItemCategory->menuItem) item=subMenuItem}
246 <li id="{$subMenuItem->menuItem}" data-menu-item="{$subMenuItem->menuItem}"><a href="{$subMenuItem->getLink()}">{@$subMenuItem}</a></li>
247 {/foreach}
248 {else}
249 <li id="{$menuItemCategory->menuItem}" data-menu-item="{$menuItemCategory->menuItem}"><a href="{$menuItemCategory->getLink()}">{@$menuItemCategory}</a></li>
250 {/if}
251 {/foreach}
252 </ul>
253 </nav>
254 </fieldset>
255 {/foreach}
256 </div>
257 {/foreach}
258 {/if}
259 {/content}
260 </div>
261 </aside>
262 {/hascontent}
263
264 <section id="content" class="content">
265