Merge pull request #4744 from WoltLab/deprecate-fetchRemoteAvatar
[GitHub/WoltLab/WCF.git] / com.woltlab.wcf / templates / pageHeaderUser.tpl
CommitLineData
0a6f84dc
MW
1<nav id="topMenu" class="userPanel{if $__wcf->user->userID} userPanelLoggedIn{/if}">
2 {if $__wcf->user->userID}
690e409d 3 <span class="userPanelAvatar" aria-hidden="true">{@$__wcf->getUserProfileHandler()->getAvatar()->getImageTag(32)}</span>
6e5b3652 4 {else}
931a1eff 5 <a href="{link controller='Login' url=$__wcf->getRequestURI()}{/link}" class="userPanelLoginLink jsTooltip" title="{lang}wcf.user.loginOrRegister{/lang}">
690e409d 6 <span class="icon icon32 fa-sign-in" aria-hidden="true"></span>
6e5b3652 7 </a>
0a6f84dc
MW
8 {/if}
9
b8eab696
AE
10 <ul class="userPanelItems">
11 {if $__wcf->user->userID}
12 <!-- user menu -->
13 <li id="userMenu">
677bdb69
AE
14 <a
15 class="jsTooltip"
16 href="{$__wcf->user->getLink()}"
17 title="{lang}wcf.user.controlPanel{/lang}"
18 role="button"
19 tabindex="0"
20 aria-haspopup="true"
21 aria-expanded="false"
22 >
23 {@$__wcf->getUserProfileHandler()->getAvatar()->getImageTag(32)} <span>{lang}wcf.user.userNote{/lang}</span>
24 </a>
25 <div class="userMenu userMenuControlPanel" data-origin="userMenu" tabindex="-1" hidden>
26 <div class="userMenuHeader">
27 <div class="userMenuTitle">{lang}wcf.user.controlPanel{/lang}</div>
b8eab696 28 </div>
677bdb69
AE
29 <div class="userMenuContent">
30 <div class="userMenuItem">
31 <div class="userMenuItemImage">
32 {@$__wcf->getUserProfileHandler()->getUserProfile()->getAvatar()->getImageTag(48)}
33 </div>
34 <div class="userMenuItemContent">
35 {* This is the unformatted username, custom styles might not work nicely here and
36 the consistent styling is used to provide visual anchors to identify links. *}
37 <a href="{$__wcf->user->getLink()}" class="userMenuItemLink">{$__wcf->user->username}</a>
38
39 {if MODULE_USER_RANK}
40 {if $__wcf->getUserProfileHandler()->getUserTitle()}
41 <span class="badge userTitleBadge{if $__wcf->getUserProfileHandler()->getRank() && $__wcf->getUserProfileHandler()->getRank()->cssClassName} {@$__wcf->getUserProfileHandler()->getRank()->cssClassName}{/if}">{$__wcf->getUserProfileHandler()->getUserTitle()}</span>
42 {/if}
43 {if $__wcf->getUserProfileHandler()->getRank() && $__wcf->getUserProfileHandler()->getRank()->rankImage}
44 <span class="userRankImage">{@$__wcf->getUserProfileHandler()->getRank()->getImage()}</span>
45 {/if}
46 {/if}
47 </div>
48 <div class="userMenuItemMeta">
49 {lang}wcf.user.myProfile{/lang}
50 </div>
51 </div>
52 </div>
53 <div class="userMenuContentDivider"></div>
54 {if $__wcf->session->getPermission('admin.general.canUseAcp')}
55 <div class="userMenuContent">
56 <div class="userMenuItem userMenuItemNarrow userMenuItemSingleLine">
57 <div class="userMenuItemImage">
58 <span class="icon icon32 fa-wrench"></span>
59 </div>
60 <div class="userMenuItemContent">
61 <a href="{link isACP=true}{/link}" class="userMenuItemLink">{lang}wcf.global.acp{/lang}</a>
62 </div>
63 </div>
64 </div>
65 <div class="userMenuContentDivider"></div>
66 {/if}
4996d792 67 <div class="userMenuContent userMenuContentScrollable">
677bdb69
AE
68 {foreach from=$__wcf->getUserMenu()->getUserMenuItems() item=menuItem}
69 <div class="userMenuItem userMenuItemNarrow" data-category="{$menuItem[category]->menuItem}">
70 <div class="userMenuItemImage">
71 <span class="icon icon32 {$menuItem[category]->getIconClassName()}"></span>
72 </div>
73 <div class="userMenuItemContent">
74 <a href="{$menuItem[link]}" class="userMenuItemLink">
75 {$menuItem[category]->getTitle()}
76 </a>
77 </div>
78 <div class="userMenuItemMeta">
79 {implode from=$menuItem[items] item=title glue=' · '}{$title}{/implode}
80 </div>
81 </div>
82 {/foreach}
83 </div>
84 <div class="userMenuFooter">
372f863c
AE
85 <form method="post" action="{link controller='Logout'}{/link}">
86 <a href="#" class="userMenuFooterLink" role="button">{lang}wcf.user.logout{/lang}</a>
87 {csrfToken}
88 </form>
b8eab696 89 </div>
b8eab696 90 </div>
51547f2c 91 <script data-relocate="true">
677bdb69 92 require(["WoltLabSuite/Core/Ui/User/Menu/ControlPanel"], ({ setup }) => setup());
51547f2c 93 </script>
b8eab696
AE
94 </li>
95
b8eab696
AE
96 <!-- user notifications -->
97 {if !$__hideUserMenu|isset}
f030cb76 98 <li id="userNotifications" data-count="{#$__wcf->getUserNotificationHandler()->getNotificationCount()}" data-title="Benachrichtigungen">
ea0c0ef6
AE
99 <a
100 class="jsTooltip"
101 href="{link controller='NotificationList'}{/link}"
102 title="{lang}wcf.user.notification.notifications{/lang}"
103 role="button"
104 tabindex="0"
105 aria-haspopup="true"
106 aria-expanded="false"
107 >
108 <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}
109 </a>
b8eab696
AE
110 {if !OFFLINE || $__wcf->session->getPermission('admin.general.canViewPageDuringOfflineMode')}
111 <script data-relocate="true">
f99a0caf
AE
112 require(["WoltLabSuite/Core/Language", "WoltLabSuite/Core/Ui/User/Menu/Data/Notification"], (Language, { setup }) => {
113 Language.addObject({
114 "wcf.user.notification.enableDesktopNotifications": "{jslang}wcf.user.notification.enableDesktopNotifications{/jslang}",
115 "wcf.user.notification.enableDesktopNotifications.button": "{jslang}wcf.user.notification.enableDesktopNotifications.button{/jslang}",
116 });
117
8eaab6e0 118 setup({
9f663473 119 noItems: '{jslang}wcf.user.notification.noMoreNotifications{/jslang}',
b8eab696 120 settingsLink: '{link controller='NotificationSettings' encode=false}{/link}',
8eaab6e0 121 settingsTitle: '{jslang}wcf.user.notification.settings{/jslang}',
b8eab696 122 showAllLink: '{link controller='NotificationList' encode=false}{/link}',
8eaab6e0
AE
123 showAllTitle: '{jslang}wcf.user.notification.showAll{/jslang}',
124 title: '{jslang}wcf.user.notification.notifications{/jslang}',
677bdb69 125 });
b8eab696 126 });
b8eab696 127 </script>
320f4a6d 128 {/if}
b8eab696
AE
129 </li>
130 {/if}
131 {else}
d4e8bc05
AE
132 {if $__wcf->getLanguage()->getLanguages()|count > 1}
133 <li id="pageLanguageContainer">
134 <script data-relocate="true">
6e5b3652 135 require(['WoltLabSuite/Core/Language/Chooser'], function(LanguageChooser) {
d4e8bc05 136 var languages = {
fb062f13
MS
137 {implode from=$__wcf->getLanguage()->getLanguages() item=_language}
138 '{@$_language->languageID}': {
139 iconPath: '{@$_language->getIconPath()|encodeJS}',
140 languageName: '{@$_language|encodeJS}',
141 languageCode: '{@$_language->languageCode|encodeJS}'
d4e8bc05
AE
142 }
143 {/implode}
144 };
ff110591 145
d4e8bc05 146 var callback = function(listItem) {
ff110591
MW
147 var location;
148 var languageCode = elData(listItem, 'language-code');
149 var link = elBySel('link[hreflang="' + languageCode + '"]');
150 if (link !== null) {
151 location = link.href;
152 }
153 else {
154 location = window.location.toString().replace(/#.*/, '').replace(/(\?|&)l=[0-9]+/g, '');
155 }
d4e8bc05 156
ff110591 157 var delimiter = (location.indexOf('?') == -1) ? '?' : '&';
d4e8bc05
AE
158 window.location = location + delimiter + 'l=' + elData(listItem, 'language-id') + window.location.hash;
159 };
160
51ab1086 161 LanguageChooser.init('pageLanguageContainer', 'pageLanguageID', {@$__wcf->getLanguage()->languageID}, languages, callback);
b2e0e0cd 162 });
b8eab696
AE
163 </script>
164 </li>
165 {/if}
6e5b3652 166 <li id="userLogin">
931a1eff 167 <a class="loginLink" href="{link controller='Login' url=$__wcf->getRequestURI()}{/link}">{lang}wcf.user.loginOrRegister{/lang}</a>
6e5b3652 168 </a>
b8eab696
AE
169 {/if}
170
171 {if !$__hideUserMenu|isset}
172 {if $__wcf->user->userID && $__wcf->session->getPermission('mod.general.canUseModeration')}
0882d872 173 <li id="outstandingModeration" data-count="{#$__wcf->getModerationQueueManager()->getUnreadModerationCount()}">
ea0c0ef6
AE
174 <a
175 class="jsTooltip"
176 href="{link controller='ModerationList'}{/link}"
177 title="{lang}wcf.moderation.moderation{/lang}"
178 role="button"
179 tabindex="0"
180 aria-haspopup="true"
181 aria-expanded="false"
182 >
e2368a74 183 <span class="icon icon32 fa-exclamation-triangle"></span>
b8eab696 184 <span>{lang}wcf.moderation.moderation{/lang}</span>
e2368a74 185 {if $__wcf->getModerationQueueManager()->getUnreadModerationCount()}<span class="badge badgeUpdate">{#$__wcf->getModerationQueueManager()->getUnreadModerationCount()}</span>{/if}
b8eab696
AE
186 </a>
187 {if !OFFLINE || $__wcf->session->getPermission('admin.general.canViewPageDuringOfflineMode')}
188 <script data-relocate="true">
cf9e11c3
AE
189 require(["WoltLabSuite/Core/Ui/User/Menu/Data/ModerationQueue"], ({ setup }) => {
190 setup({
9f663473 191 deletedContent: '{jslang}wcf.moderation.showDeletedContent{/jslang}',
b8eab696 192 deletedContentLink: '{link controller='DeletedContentList' encode=false}{/link}',
9f663473 193 noItems: '{jslang}wcf.moderation.noMoreItems{/jslang}',
b8eab696 194 showAllLink: '{link controller='ModerationList' encode=false}{/link}',
cf9e11c3 195 showAllTitle: '{jslang}wcf.moderation.showAll{/jslang}',
9f663473 196 title: '{jslang}wcf.moderation.moderation{/jslang}'
677bdb69 197 });
b8eab696 198 });
b8eab696
AE
199 </script>
200 {/if}
201 </li>
51547f2c 202 {/if}
b8eab696
AE
203
204 {event name='menuItems'}
205 {/if}
74029e21
AE
206
207 <!-- page search -->
e7500593
AE
208 <li>
209 <a href="{link controller='Search'}{/link}" 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>
ee983961 210 </li>
b8eab696 211 </ul>
bf1461c2 212</nav>