Changes for page Profile of XWikiUserSheet
Last modified by Ludovic Dubost on 2024/07/22 15:51
From version 9.1
edited by Ludovic Dubost
on 2020/07/30 11:17
on 2020/07/30 11:17
Change comment:
Install extension [org.xwiki.platform:xwiki-platform-user-profile-ui/12.3]
To version 5.1
edited by Ludovic Dubost
on 2017/02/07 23:57
on 2017/02/07 23:57
Change comment:
Install extension [org.xwiki.platform:xwiki-platform-user-profile-ui-8.4.4]
Summary
-
Page properties (2 modified, 0 added, 0 removed)
-
Objects (2 modified, 0 added, 0 removed)
Details
- Page properties
-
- Title
-
... ... @@ -1,1 +1,1 @@ 1 -#set($userName="$!doc.getValue('first_name') $!doc.getValue('last_name')")#if($userName==' ')#set($userName=$doc. documentReference.name)#{end}$services.localization.render('platform.core.profile.title', [$userName])1 +#set($userName="$!doc.getValue('first_name') $!doc.getValue('last_name')")#if($userName==' ')#set($userName=$doc.name)#{end}$services.localization.render('platform.core.profile.title', [$userName]) - Content
-
... ... @@ -8,21 +8,30 @@ 8 8 ## Setting categories 9 9 ######################### 10 10 #set($categories = []) 11 - 12 -## load the user menu from the 'org.xwiki.plaftorm.user.profile.menu' UIXP. 13 -#foreach ($uix in $services.uix.getExtensions('org.xwiki.plaftorm.user.profile.menu', {'sortByParameter': 'priority'})) 14 - #if(!$uix.parameters.containsKey('isActive') || $uix.parameters.get('isActive') != 'false') 15 - #if (!$uix.parameters.containsKey('id')) 16 - ## when no id is explicitly provided, we use the id of the UIX. 17 - #set ($discard = $uix.parameters.put('id', $uix.id)) 18 - #end 19 - #if ($uix.parameters.containsKey('icon')) 20 - #set ($discard = $uix.parameters.put('glyphicon', $uix.parameters.get('icon'))) 21 - #end 22 - #set ($discard = $uix.parameters.put('uix', $uix)) 23 - #set($discard = $categories.add($uix.parameters)) 24 - #end 11 +#set($discard = $categories.add({'id':'profile', 'sheet':'XWiki.XWikiUserProfileSheet', 'glyphicon': 'user'})) 12 +#set($isMyProfile = ($services.model.resolveDocument($xcontext.user) == $doc.documentReference)) 13 +#if($isMyProfile || $hasAdmin) 14 + #set($discard = $categories.add({'id':'preferences', 'sheet':'XWiki.XWikiUserPreferencesSheet', 'glyphicon': 'wrench'})) 25 25 #end 16 +## TODO: add APIs to be able to display users watchlists to admins 17 +#if($isMyProfile && $hasWatch) 18 + #set($discard = $categories.add({'id':'watchlist', 'sheet':'XWiki.XWikiUserWatchListSheet', 'glyphicon': 'eye-open'})) 19 +#end 20 +#if($isMyProfile) 21 + #set($discard = $categories.add({'id':'network', 'sheet':'XWiki.XWikiUserNetworkSheet', 'glyphicon': 'globe'})) 22 +#end 23 +#set($userWikiSheet = 'WikiManager.UserWikiSheet') 24 +#if($xcontext.isMainWiki() && $xwiki.exists($userWikiSheet)) 25 + #set($discard = $categories.add({ 26 + 'id': 'wikis', 27 + 'name': $services.localization.render('platform.wiki.menu.userwikis'), 28 + 'sheet': $userWikiSheet, 29 + 'glyphicon': 'list' 30 + })) 31 +#end 32 +#if($isMyProfile && $hasDashboard) 33 + #set($discard = $categories.add({'id':'dashboard', 'sheet':'Dashboard.XWikiUserDashboardSheet', 'glyphicon': 'th'})) 34 +#end 26 26 ######################### 27 27 ## Current category 28 28 ######################### ... ... @@ -65,8 +65,7 @@ 65 65 ## By specifying the image width we enable server side resizing. The width value we use is greater than the 66 66 ## available space because we don't want to loose too much of the image quality (we rely on the browser to fit the 67 67 ## image in the available space). 68 - #set($isMyProfile = ($services.model.resolveDocument($xcontext.user) == $doc.documentReference)) 69 - {{attachmentSelector classname="XWiki.XWikiUsers" object="$obj.number" property="avatar" #if ($isMyProfile) savemode="direct" #end defaultValue="XWiki.XWikiUserSheet@noavatar.png" width="180" alternateText="$xwiki.getUserName($doc.fullName, false)" buttontext="$services.localization.render('platform.core.profile.changePhoto')" displayImage="true" filter="png,jpg,jpeg,gif"/}} 77 + {{attachmentSelector classname="XWiki.XWikiUsers" object="$obj.number" property="avatar" #if ($isMyProfile) savemode="direct" #end defaultValue="XWiki.XWikiUserSheet@noavatar.png" width="180" alternateText="$xwiki.getUserName($doc.fullName, false)" buttontext="$services.localization.render('platform.core.profile.changePhoto')" displayImage="true" filter="png,jpg,gif"/}} 70 70 #end 71 71 ))) 72 72 ########## ... ... @@ -87,7 +87,8 @@ 87 87 #set($tabKey = $subcategory.get('id')) 88 88 (% id="${tabKey}Pane" class="user-page-pane#if($tabKey != $currentCategory) hidden#end" %) 89 89 ((( 90 - {{html}}$services.rendering.render($subcategory.uix.execute(), 'html/5.0'){{/html}} 98 + #set($tabInclude = $subcategory.get('sheet')) 99 + {{include reference="${tabInclude}" /}} 91 91 ))) 92 92 #end 93 93 #end ... ... @@ -100,5 +100,10 @@ 100 100 <input type='hidden' name='category' value="$!{escapetool.xml($currentCategory)}" /> 101 101 #end 102 102 <div class="clearfloats"> </div> 112 + #if($request.get('xpage')) 113 + <script type="text/javascript"> 114 + document.fire('lightbox:userprofile:loaded'); 115 + </script> 116 + #end 103 103 {{/html}} 104 104 {{/velocity}}
- XWiki.JavaScriptExtension[0]
-
- Code
-
... ... @@ -2,9 +2,9 @@ 2 2 // Start XWiki augmentation. 3 3 Object.extend(XWiki, { 4 4 userprofile : { 5 - init : function( container) {5 + init : function() { 6 6 this.crtCategory = ''; 7 - this.tabsContainer = (container ||$('body')).down('#user-vertical-menu');7 + this.tabsContainer = $('user-vertical-menu'); 8 8 if (!this.tabsContainer) { 9 9 return; 10 10 } ... ... @@ -17,7 +17,6 @@ 17 17 this.tabsContainer.select('.category-tab.current').each(function (activeTab) { 18 18 this.updateCategoryFields(activeTab.id); 19 19 document.fire('xwiki:profile:switchedCategory', {'category' : activeTab.id}); 20 - document.fire('xwiki:dom:refresh'); 21 21 }.bind(this)); 22 22 this.handleCancelAction(); 23 23 ... ... @@ -48,7 +48,6 @@ 48 48 this.updateURL(tabName); 49 49 } 50 50 document.fire('xwiki:profile:switchedCategory', {'category' : tab}); 51 - document.fire('xwiki:dom:refresh'); 52 52 }, 53 53 54 54 updateCategoryFields : function (category) { ... ... @@ -91,14 +91,12 @@ 91 91 } 92 92 }); 93 93 94 -var init = function(event) { 95 - ((event && event.memo.elements) || [$('body')]).each(function(element) { 96 - XWiki.userprofile.init(element); 97 - }); 92 +var init = function() { 93 + XWiki.userprofile.init(); 98 98 return true; 99 99 }; 100 100 (XWiki.domIsLoaded && init()) || document.observe('xwiki:dom:loaded', init); 101 -document.observe(' xwiki:dom:updated', init);97 +document.observe('lightbox:userprofile:loaded', init); 102 102 // End XWiki augmentation. 103 103 return XWiki; 104 104 }(XWiki || {}));
- XWiki.StyleSheetExtension[0]
-
- Code
-
... ... @@ -126,12 +126,7 @@ 126 126 .userInfo img { 127 127 max-width: 100%; 128 128 } 129 - 130 -.userInfo h2 { 131 - font-size: larger; 132 - font-weight: bolder; 133 -} 134 - 129 + 135 135 div.userInfo input[type="text"], div.userInfo input[type="password"], div.userInfo textarea, div.userInfo select, div.userPreferences select { 136 136 width: 100%; 137 137 }