Changes for page Profile of XWikiUserSheet

Last modified by Ludovic Dubost on 2024/07/22 15:51

From version 7.1
edited by Ludovic Dubost
on 2018/12/09 12:24
Change comment: Install extension [org.xwiki.platform:xwiki-platform-user-profile-ui/10.10]
To version 12.1
edited by Ludovic Dubost
on 2024/07/22 15:51
Change comment: Install extension [org.xwiki.platform:xwiki-platform-user-profile-ui/16.5.0]

Summary

Details

Page properties
Title
... ... @@ -1,1 +1,1 @@
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])
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])
Content
... ... @@ -8,38 +8,21 @@
8 8  ## Setting categories
9 9  #########################
10 10  #set($categories = [])
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'}))
15 -#end
16 -#set($discard = $categories.add({'id':'groups', 'sheet':'XWiki.XWikiUserMembershipSheet', 'glyphicon': 'group'}))
17 -## TODO: add APIs to be able to display users watchlists to admins
18 -#if($isMyProfile && $hasWatch)
19 - #set($discard = $categories.add({'id':'watchlist', 'sheet':'XWiki.XWikiUserWatchListSheet', 'glyphicon': 'eye'}))
20 -#end
21 -#if($isMyProfile)
22 - #if ("$!services.notification.watch" != '' || $hasWatch)
23 - #set($discard = $categories.add({'id':'network', 'sheet':'XWiki.XWikiUserNetworkSheet', 'glyphicon': 'world'}))
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 24   #end
25 - ## TODO: add an enhancement system instead
26 - #set($notificationsSheet = $services.model.createDocumentReference('', ['XWiki', 'Notifications', 'Code'], 'XWikiUserNotificationsSheet'))
27 - #if ($xwiki.exists($notificationsSheet))
28 - #set($discard = $categories.add({'id':'notifications', 'sheet':'XWiki.Notifications.Code.XWikiUserNotificationsSheet', 'glyphicon': 'bell'}))
29 - #end
30 30  #end
31 -#set($userWikiSheet = 'WikiManager.UserWikiSheet')
32 -#if($xcontext.isMainWiki() && $xwiki.exists($userWikiSheet))
33 - #set($discard = $categories.add({
34 - 'id': 'wikis',
35 - 'name': $services.localization.render('platform.wiki.menu.userwikis'),
36 - 'sheet': $userWikiSheet,
37 - 'glyphicon': 'list'
38 - }))
39 -#end
40 -#if($isMyProfile && $hasDashboard)
41 - #set($discard = $categories.add({'id':'dashboard', 'sheet':'Dashboard.XWikiUserDashboardSheet', 'glyphicon': 'th'}))
42 -#end
43 43  #########################
44 44  ## Current category
45 45  #########################
... ... @@ -82,7 +82,7 @@
82 82   ## By specifying the image width we enable server side resizing. The width value we use is greater than the
83 83   ## available space because we don't want to loose too much of the image quality (we rely on the browser to fit the
84 84   ## image in the available space).
85 - {{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"/}}
68 + {{attachmentSelector classname="XWiki.XWikiUsers" object="$obj.number" property="avatar" #if ($hasEdit) 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"/}}
86 86   #end
87 87   )))
88 88   ##########
... ... @@ -103,8 +103,7 @@
103 103   #set($tabKey = $subcategory.get('id'))
104 104   (% id="${tabKey}Pane" class="user-page-pane#if($tabKey != $currentCategory) hidden#end" %)
105 105   (((
106 - #set($tabInclude = $subcategory.get('sheet'))
107 - {{include reference="${tabInclude}" /}}
89 + {{html}}$services.rendering.render($subcategory.uix.execute(), 'html/5.0'){{/html}}
108 108   )))
109 109   #end
110 110   #end
XWiki.JavaScriptExtension[0]
Code
... ... @@ -63,7 +63,7 @@
63 63   if (history.pushState) {
64 64   var params = window.location.search.toQueryParams();
65 65   params.category = category;
66 - newQueryString = Object.toQueryString(params);
66 + var newQueryString = Object.toQueryString(params);
67 67  
68 68   var newURL = window.location.protocol + '//' + window.location.host + window.location.pathname + '?' + newQueryString;
69 69   window.history.pushState({category : category}, '', newURL);
... ... @@ -72,7 +72,7 @@
72 72  
73 73   updateField : function (fieldName, value) {
74 74   var element = $$('input[name=' + fieldName + ']');
75 - if (element && element.size() > 0) {
75 + if (element && element.length) {
76 76   element[0].value = value;
77 77   }
78 78   },
... ... @@ -79,7 +79,7 @@
79 79  
80 80   handleCancelAction : function() {
81 81   var elements = $$('form .buttons input[type=submit][name=action_cancel]');
82 - if (elements && elements.size() > 0) {
82 + if (elements && elements.length) {
83 83   var button = elements[0];
84 84   Event.stopObserving(button, 'click');
85 85   button.observe('click', function(event){
XWiki.StyleSheetExtension[0]
Code
... ... @@ -12,7 +12,7 @@
12 12  
13 13  #avatar img {
14 14   border: 1px solid $theme.borderColor;
15 - border-radius: 5px 5px 5px 5px;
15 + border-radius: 8px 8px 8px 8px;
16 16   box-shadow: 0 1px 2px rgba(0, 0, 0, 0.15);
17 17   margin: 0 auto;
18 18   padding: 0.3em;
... ... @@ -72,13 +72,13 @@
72 72   margin-left: 14em;
73 73  }
74 74  
75 -.column h1 {
76 - font-weight:bold;
77 - font-size:115%;
78 - margin:10px 0;
75 +.column h1, .column h2 {
76 + font-weight: bold;
77 + font-size: 115%;
78 + margin: 10px 0;
79 79  }
80 80  
81 -.column h2 {
81 +.column h3 {
82 82   font-size: 110%;
83 83  }
84 84  
... ... @@ -96,7 +96,7 @@
96 96  
97 97  /* ----- Profile ----- */
98 98  td.recentChangesLeft, .recentChangesMoreActions {
99 - display:none;
99 + display: none;
100 100  }
101 101  
102 102  td.recentChangesRight {
... ... @@ -115,10 +115,6 @@
115 115   background-color: $theme.backgroundSecondaryColor;
116 116  }
117 117  
118 -.userInfo {
119 - -ms-word-break: break-all; /* IE8, IE9 */
120 -}
121 -
122 122  .userInfo a {
123 123   word-wrap: break-word;
124 124  }
... ... @@ -126,21 +126,21 @@
126 126  .userInfo img {
127 127   max-width: 100%;
128 128  }
129 -
125 +
126 +.userInfo h2 {
127 + font-size: larger;
128 + font-weight: bolder;
129 + margin-top: 10px;
130 +}
131 +
130 130  div.userInfo input[type="text"], div.userInfo input[type="password"], div.userInfo textarea, div.userInfo select, div.userPreferences select {
131 131   width: 100%;
132 132  }
133 133  
134 134  div.editProfileCategory {
135 - float:right;
137 + float: right;
136 136  }
137 137  
138 -div.editProfileCategory a {
139 - display:block;
140 - width: 16px;
141 - height: 16px;
142 - background: url("$xwiki.getSkinFile('icons/silk/pencil.png')") no-repeat;
143 -}
144 144  
145 145  /* Watchlist */
146 146  
... ... @@ -151,9 +151,9 @@
151 151  }
152 152  
153 153  span#avatarUpload {
154 - display:block;
155 - width:$tabswidth;
156 - position:absolute;
150 + display: block;
151 + width: $tabswidth;
152 + position: absolute;
157 157   font-size: 10px;
158 158   font-weight: bold;
159 159   background-color: white;
... ... @@ -168,28 +168,35 @@
168 168   margin: 0;
169 169   padding: 0;
170 170  }
167 +
171 171  #networkPane .following li {
172 172   padding: 2px 20px 2px 2px;
173 173  }
171 +
174 174  #networkPane .following li:hover {
175 175   background-color: $theme.highlightColor;
176 176  }
175 +
177 177  #networkPane .following img {
178 178   float: left;
179 179   margin-right: 5px;
180 180  }
180 +
181 181  #networkPane .following .user-info {
182 182   float: left;
183 183  }
184 +
184 184  #networkPane .following .user-id {
185 185   font-size: .8em;
186 186   font-weight: 900;
187 187  }
189 +
188 188  #networkPane .following .unfollow {
189 189   float: right;
190 190   margin-right: -16px;
191 191   padding: 0;
192 192  }
195 +
193 193  ## --------------------------------------
194 194  ## Picker style
195 195  .attachment-picker {
... ... @@ -197,6 +197,7 @@
197 197   margin: auto;
198 198   width: 100%;
199 199  }
203 +
200 200  .attachment-picker p {
201 201   padding: 0;
202 202   margin: 0;
... ... @@ -205,6 +205,7 @@
205 205  .attachment-picker .picture {
206 206   z-index: -1;
207 207  }
212 +
208 208  .attachment-picker .buttonwrapper {
209 209   margin: 0;
210 210  }
Content Type
... ... @@ -1,0 +1,1 @@
1 +LESS