Silence warnings on invalid images in image proxy
[GitHub/WoltLab/WCF.git] / com.woltlab.wcf / templates / pageHeaderUser.tpl
CommitLineData
b8eab696
AE
1<nav id="topMenu" class="userPanel">
2 <ul class="userPanelItems">
3 {if $__wcf->user->userID}
4 <!-- user menu -->
5 <li id="userMenu">
6e2b711e 6 <a class="jsTooltip" href="{link controller='User' object=$__wcf->user}{/link}" title="{lang}wcf.user.controlPanel{/lang}">{@$__wcf->getUserProfileHandler()->getAvatar()->getImageTag(32)} <span>{lang}wcf.user.userNote{/lang}</span></a>
b8eab696
AE
7 <div class="interactiveDropdown interactiveDropdownStatic interactiveDropdownUserMenu">
8 <div class="interactiveDropdownHeader">
9 <span class="interactiveDropdownTitle">{lang}wcf.user.controlPanel{/lang}</span>
10
11 {hascontent}
12 <ul class="interactiveDropdownLinks">
13 {content}
14 {event name='userMenuLinks'}
15 {/content}
16 </ul>
17 {/hascontent}
18 </div>
19 <div class="interactiveDropdownItemsContainer">
20 <ul class="interactiveDropdownItems interactiveDropdownItemsUserMenu">
21 <li>
ca1d60e5 22 <div class="box48">
95961bdf 23 <a href="{link controller='User' object=$__wcf->user}{/link}">{@$__wcf->getUserProfileHandler()->getAvatar()->getImageTag(48)}</a>
a82bf781 24
b8eab696 25 <div class="containerHeadline">
ca1d60e5
MW
26 <h3>
27 <a href="{link controller='User' object=$__wcf->user}{/link}">{$__wcf->user->username}</a>
28 {if MODULE_USER_RANK}
b8eab696
AE
29 {if $__wcf->getUserProfileHandler()->getUserTitle()}
30 <span class="badge userTitleBadge{if $__wcf->getUserProfileHandler()->getRank() && $__wcf->getUserProfileHandler()->getRank()->cssClassName} {@$__wcf->getUserProfileHandler()->getRank()->cssClassName}{/if}">{$__wcf->getUserProfileHandler()->getUserTitle()}</span>
31 {/if}
32 {if $__wcf->getUserProfileHandler()->getRank() && $__wcf->getUserProfileHandler()->getRank()->rankImage}
33 <span class="userRankImage">{@$__wcf->getUserProfileHandler()->getRank()->getImage()}</span>
34 {/if}
ca1d60e5
MW
35 {/if}
36 </h3>
b8eab696 37
ca1d60e5 38 <ul class="inlineList dotSeparated">
b8eab696
AE
39 <li><a href="{link controller='User' object=$__wcf->user}{/link}">{lang}wcf.user.myProfile{/lang}</a></li>
40 {if $__wcf->getUserProfileHandler()->canEditOwnProfile()}<li><a href="{link controller='User' object=$__wcf->user}editOnInit=true#about{/link}">{lang}wcf.user.editProfile{/lang}</a></li>{/if}
41 {if $__wcf->session->getPermission('admin.general.canUseAcp')}<li><a href="{link isACP=true}{/link}">{lang}wcf.global.acp.short{/lang}</a></li>{/if}
42 </ul>
43 </div>
a82bf781 44 </div>
b8eab696
AE
45 </li>
46
47 {event name='userMenuItemsBefore'}
48
49 {foreach from=$__wcf->getUserMenu()->getMenuItems('') item=menuCategory}
b8eab696 50 <li class="interactiveDropdownUserMenuItem">
ca1d60e5
MW
51 <div class="box48">
52 <div><span class="icon icon48 {@$menuCategory->getIconClassName()}"></span></div>
b8eab696
AE
53
54 <div class="containerHeadline">
55 <h3>{lang}{$menuCategory->menuItem}{/lang}</h3>
56
ca1d60e5 57 <ul class="inlineList dotSeparated">
b8eab696
AE
58 {foreach from=$__wcf->getUserMenu()->getMenuItems($menuCategory->menuItem) item=menuItem}
59 <li><a href="{$menuItem->getProcessor()->getLink()}">{@$menuItem}</a></li>
60 {/foreach}
61 </ul>
62 </div>
63 </div>
64 </li>
65 {/foreach}
66
67 {event name='userMenuItemsAfter'}
68 </ul>
69 </div>
70 <a class="interactiveDropdownShowAll" href="{link controller='Logout'}t={@SECURITY_TOKEN}{/link}" onclick="WCF.Dropdown.Interactive.Handler.close('userMenu'); 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>
71 </div>
51547f2c 72 <script data-relocate="true">
51547f2c 73 $(function() {
b8eab696 74 new WCF.User.Panel.UserMenu();
320f4a6d 75 });
51547f2c 76 </script>
b8eab696
AE
77 </li>
78
b8eab696
AE
79 <!-- user notifications -->
80 {if !$__hideUserMenu|isset}
81 <li id="userNotifications" data-count="{#$__wcf->getUserNotificationHandler()->getNotificationCount()}">
6e2b711e 82 <a class="jsTooltip" href="{link controller='NotificationList'}{/link}" title="{lang}wcf.user.notification.notifications{/lang}"><span class="icon icon32 fa-bell-o"></span> <span>{lang}wcf.user.notification.notifications{/lang}</span>{if $__wcf->getUserNotificationHandler()->getNotificationCount()} <span class="badge badgeUpdate">{#$__wcf->getUserNotificationHandler()->getNotificationCount()}</span>{/if}</a>
b8eab696
AE
83 {if !OFFLINE || $__wcf->session->getPermission('admin.general.canViewPageDuringOfflineMode')}
84 <script data-relocate="true">
b8eab696
AE
85 $(function() {
86 new WCF.User.Panel.Notification({
87 markAllAsReadConfirmMessage: '{lang}wcf.user.notification.markAllAsConfirmed.confirmMessage{/lang}',
88 noItems: '{lang}wcf.user.notification.noMoreNotifications{/lang}',
89 settingsLink: '{link controller='NotificationSettings' encode=false}{/link}',
90 showAllLink: '{link controller='NotificationList' encode=false}{/link}',
91 title: '{lang}wcf.user.notification.notifications{/lang}'
92 });
93 });
b8eab696 94 </script>
320f4a6d 95 {/if}
b8eab696
AE
96 </li>
97 {/if}
98 {else}
d4e8bc05
AE
99 {if $__wcf->getLanguage()->getLanguages()|count > 1}
100 <li id="pageLanguageContainer">
101 <script data-relocate="true">
58d7e8f8 102 require(['EventHandler', 'WoltLabSuite/Core/Language/Chooser'], function(EventHandler, LanguageChooser) {
d4e8bc05 103 var languages = {
fb062f13
MS
104 {implode from=$__wcf->getLanguage()->getLanguages() item=_language}
105 '{@$_language->languageID}': {
106 iconPath: '{@$_language->getIconPath()|encodeJS}',
107 languageName: '{@$_language|encodeJS}',
108 languageCode: '{@$_language->languageCode|encodeJS}'
d4e8bc05
AE
109 }
110 {/implode}
111 };
ff110591 112
d4e8bc05 113 var callback = function(listItem) {
ff110591
MW
114 var location;
115 var languageCode = elData(listItem, 'language-code');
116 var link = elBySel('link[hreflang="' + languageCode + '"]');
117 if (link !== null) {
118 location = link.href;
119 }
120 else {
121 location = window.location.toString().replace(/#.*/, '').replace(/(\?|&)l=[0-9]+/g, '');
122 }
d4e8bc05 123
ff110591 124 var delimiter = (location.indexOf('?') == -1) ? '?' : '&';
d4e8bc05
AE
125 window.location = location + delimiter + 'l=' + elData(listItem, 'language-id') + window.location.hash;
126 };
127
51ab1086 128 LanguageChooser.init('pageLanguageContainer', 'pageLanguageID', {@$__wcf->getLanguage()->languageID}, languages, callback);
d4e8bc05
AE
129 EventHandler.add('com.woltlab.wcf.UserMenuMobile', 'more', function(data) {
130 if (data.identifier === 'com.woltlab.wcf.language') {
131 callback(data.parent);
132 }
133 });
134 });
135 </script>
136 </li>
137 {/if}
b8eab696
AE
138 {if !$__disableLoginLink|isset}
139 <!-- login box -->
140 <li id="userLogin">
141 <a class="loginLink" href="{link controller='Login'}{/link}">{lang}wcf.user.loginOrRegister{/lang}</a>
5ea92119 142 <div id="loginForm" class="loginForm" style="display: none">
b8eab696 143 <form method="post" action="{link controller='Login'}{/link}">
5ea92119
AE
144 <section class="section loginFormLogin">
145 <h2 class="sectionTitle">{lang}wcf.user.login.login{/lang}</h2>
b8eab696
AE
146
147 <dl>
148 <dt><label for="username">{lang}wcf.user.usernameOrEmail{/lang}</label></dt>
149 <dd>
6f2bc235 150 <input type="text" id="username" name="username" value="" required class="long jsDialogAutoFocus">
b8eab696
AE
151 </dd>
152 </dl>
153
b8eab696
AE
154 <dl>
155 <dt><label for="password">{lang}wcf.user.password{/lang}</label></dt>
156 <dd>
0ba63443 157 <input type="password" id="password" name="password" value="" class="long">
5ea92119 158 <small><a href="{link controller='LostPassword'}{/link}">{lang}wcf.user.lostPassword{/lang}</a></small>
b8eab696
AE
159 </dd>
160 </dl>
161
162 {if $__wcf->getUserAuthenticationFactory()->getUserAuthentication()->supportsPersistentLogins()}
163 <dl>
164 <dt></dt>
5ea92119
AE
165 <dd>
166 <label for="useCookies"><input type="checkbox" id="useCookies" name="useCookies" value="1" checked> {lang}wcf.user.useCookies{/lang}</label>
167 </dd>
b8eab696
AE
168 </dl>
169 {/if}
170
5ea92119 171 {event name='fields'}
b8eab696 172
5ea92119
AE
173 <div class="userLoginButtons">
174 <input type="submit" value="{lang}wcf.global.button.submit{/lang}" accesskey="s">
0ba63443 175 <input type="hidden" name="url" value="{$__wcf->session->requestURI}">
b8eab696
AE
176 {@SECURITY_TOKEN_INPUT_TAG}
177 </div>
5ea92119 178 </section>
b8eab696 179
5ea92119
AE
180 {if !REGISTER_DISABLED}
181 <section class="section loginFormRegister">
182 <h2 class="sectionTitle">{lang}wcf.user.login.register{/lang}</h2>
183
184 <p>{lang}wcf.user.login.register.teaser{/lang}</p>
185
186 <div class="userLoginButtons">
187 <a href="{link controller='Register'}{/link}" class="button loginFormRegisterButton">{lang}wcf.user.login.register.registerNow{/lang}</a>
188 </div>
95961bdf 189 </section>
b8eab696 190 {/if}
5ea92119
AE
191
192 {hascontent}
193 <section class="section loginFormThirdPartyLogin">
194 <h2 class="sectionTitle">{lang}wcf.user.login.3rdParty{/lang}</h2>
195
196 <dl>
197 <dt></dt>
198 <dd>
199 <ul class="buttonList smallButtons">
200 {content}
201 {if GITHUB_PUBLIC_KEY !== '' && GITHUB_PRIVATE_KEY !== ''}
202 <li id="githubAuth" class="thirdPartyLogin">
203 <a href="{link controller='GithubAuth'}{/link}" class="button thirdPartyLoginButton githubLoginButton"><span class="icon icon16 fa-github"></span> <span>{lang}wcf.user.3rdparty.github.login{/lang}</span></a>
204 </li>
205 {/if}
206
207 {if TWITTER_PUBLIC_KEY !== '' && TWITTER_PRIVATE_KEY !== ''}
208 <li id="twitterAuth" class="thirdPartyLogin">
209 <a href="{link controller='TwitterAuth'}{/link}" class="button thirdPartyLoginButton twitterLoginButton"><span class="icon icon16 fa-twitter"></span> <span>{lang}wcf.user.3rdparty.twitter.login{/lang}</span></a>
210 </li>
211 {/if}
212
213 {if FACEBOOK_PUBLIC_KEY !== '' && FACEBOOK_PRIVATE_KEY !== ''}
214 <li id="facebookAuth" class="thirdPartyLogin">
215 <a href="{link controller='FacebookAuth'}{/link}" class="button thirdPartyLoginButton facebookLoginButton"><span class="icon icon16 fa-facebook"></span> <span>{lang}wcf.user.3rdparty.facebook.login{/lang}</span></a>
216 </li>
217 {/if}
218
219 {if GOOGLE_PUBLIC_KEY !== '' && GOOGLE_PRIVATE_KEY !== ''}
220 <li id="googleAuth" class="thirdPartyLogin">
221 <a href="{link controller='GoogleAuth'}{/link}" class="button thirdPartyLoginButton googleLoginButton"><span class="icon icon16 fa-google-plus"></span> <span>{lang}wcf.user.3rdparty.google.login{/lang}</span></a>
222 </li>
223 {/if}
224
225 {event name='3rdpartyButtons'}
226 {/content}
227 </ul>
228 </dd>
229 </dl>
230 </section>
231 {/hascontent}
b8eab696
AE
232 </form>
233 </div>
320f4a6d 234
b8eab696 235 <script data-relocate="true">
b8eab696
AE
236 $(function() {
237 WCF.Language.addObject({
238 'wcf.user.button.login': '{lang}wcf.user.button.login{/lang}',
239 'wcf.user.button.register': '{lang}wcf.user.button.register{/lang}',
240 'wcf.user.login': '{lang}wcf.user.login{/lang}'
241 });
242 new WCF.User.Login(true);
b2e0e0cd 243 });
b8eab696
AE
244 </script>
245 </li>
246 {/if}
b8eab696
AE
247 {/if}
248
249 {if !$__hideUserMenu|isset}
250 {if $__wcf->user->userID && $__wcf->session->getPermission('mod.general.canUseModeration')}
251 <li id="outstandingModeration" data-count="{#$__wcf->getModerationQueueManager()->getOutstandingModerationCount()}">
6e2b711e 252 <a class="jsTooltip" href="{link controller='ModerationList'}{/link}" title="{lang}wcf.moderation.moderation{/lang}">
e2368a74 253 <span class="icon icon32 fa-exclamation-triangle"></span>
b8eab696 254 <span>{lang}wcf.moderation.moderation{/lang}</span>
e2368a74 255 {if $__wcf->getModerationQueueManager()->getUnreadModerationCount()}<span class="badge badgeUpdate">{#$__wcf->getModerationQueueManager()->getUnreadModerationCount()}</span>{/if}
b8eab696
AE
256 </a>
257 {if !OFFLINE || $__wcf->session->getPermission('admin.general.canViewPageDuringOfflineMode')}
258 <script data-relocate="true">
b8eab696
AE
259 $(function() {
260 new WCF.User.Panel.Moderation({
261 deletedContent: '{lang}wcf.moderation.showDeletedContent{/lang}',
262 deletedContentLink: '{link controller='DeletedContentList' encode=false}{/link}',
263 markAllAsReadConfirmMessage: '{lang}wcf.moderation.markAllAsRead.confirmMessage{/lang}',
264 noItems: '{lang}wcf.moderation.noMoreItems{/lang}',
265 showAllLink: '{link controller='ModerationList' encode=false}{/link}',
266 title: '{lang}wcf.moderation.moderation{/lang}'
267 });
268 });
b8eab696
AE
269 </script>
270 {/if}
271 </li>
51547f2c 272 {/if}
b8eab696
AE
273
274 {event name='menuItems'}
275 {/if}
74029e21
AE
276
277 <!-- page search -->
278 <li class="jsOnly">
279 <a href="#" id="userPanelSearchButton" class="jsTooltip" title="{lang}wcf.global.search{/lang}"><span class="icon icon32 fa-search"></span> <span>{lang}wcf.global.search{/lang}</span></a>
280 </li>
b8eab696
AE
281 </ul>
282</nav>