Changes for page Per Year
From version 142.1
edited by Andrea Omicini
on 30/06/2023 17:05
on 30/06/2023 17:05
Change comment:
There is no comment for this version
To version 155.1
edited by Andrea Omicini
on 30/06/2023 21:31
on 30/06/2023 21:31
Change comment:
There is no comment for this version
Summary
-
Page properties (1 modified, 0 added, 0 removed)
Details
- Page properties
-
- Content
-
... ... @@ -1,67 +1,32 @@ 1 1 {{velocity}} 2 +{{html wiki="true" clean="false"}} 3 +#template('apice_boolean.vm') 4 +#### SET PARAMETERS / START 2 2 #template('apice_theses.vm') 3 -#### HANDLE PARAMETERS / START 4 -## 5 -## inline display 6 -#set( $inlinePar = $request.inline.trim() ) 7 -## who 8 -#set( $userNamePar = $request.user.trim() ) 9 -#set( $firstNamePar = $request.name.trim() ) 10 -#set( $lastNamePar = $request.surname.trim() ) 11 -#### handle who 12 -#if( $userName ) 13 -## from a personal page, "XWiki.$userName" $userName form 14 - #if( !$xwiki.exists( $userName ) ) 15 -{{warning}}User $userName does not exist{{/warning}} 6 +#template('apice_user_param.vm') 7 +## years / personal 8 +#if( $isUserSpace ) 9 + #set( $query = ", BaseObject as objPersonalThesis, LargeStringProperty as propUser 10 + where objPersonalThesis.name = doc.fullName and objPersonalThesis.className = '${objectSpace}.Personal.${objectClass}' and propUser.id.id = objPersonalThesis.id and propUser.name = 'user' and propUser.value = '$userName' " ) 11 + #set( $personalThesisDocs = $xwiki.searchDocuments($query) ) 12 + #if( $personalThesisDocs.size() > 0 ) 13 + #set( $personalThesisDoc = $xwiki.getDocument($personalThesisDocs[0]) ) 14 + #else 16 16 #stop 17 17 #end 18 - #set( $apiceUser = true ) 19 - #set( $oneUser = true ) 20 - #set( $userdoc = $xwiki.getDocument($userName) ) 21 - #set( $userFirstName = $userdoc.display("first_name") ) 22 - #set( $userLastName = $userdoc.display("last_name") ) 23 -#elseif( $userNamePar ) 24 -## from the URL, "user=$userNamePar" parameter 25 - #if( $userNamePar.contains('XWiki.') ) 26 - #set( $userName = "$userNamePar" ) 27 - #else 28 - #set( $userName = "XWiki.$userNamePar" ) 17 + #if( $personalThesisDoc.firstYear && $personalThesisDoc.firstYear != "" ) 18 + #set( $firstYearThesis = $personalThesisDoc.display('firstYear','view') ) 29 29 #end 30 - #if( !$xwiki.exists( $userName ) ) 31 - #if( $services.localization.currentLocale == 'it' ) 32 -{{warning}}L'utente “$userNamePar” non esiste{{/warning}} 33 - #else 34 -{{warning}}User “$userNamePar” does not exist{{/warning}} 35 - #end 36 - #stop 20 + #if( $personalThesisDoc.lastYear && $personalThesisDoc.lastYear != "" ) 21 + #set( $lastYearThesis = $personalThesisDoc.display('lastYear','view') ) 37 37 #end 38 - #set( $apiceUser = true ) 39 - #set( $oneUser = true) 40 - #set( $userdoc = $xwiki.getDocument($userName) ) 41 - #set( $userFirstName = $userdoc.display("first_name") ) 42 - #set( $userLastName = $userdoc.display("last_name") ) 43 -#elseif( $firstNamePar && $lastNamePar ) 44 -## from the URL, "name=Firstname&surname=Lastname" parameter 45 - #set( $apiceUser = false ) 46 - #set( $oneUser = true ) 47 - #set( $userFirstName = $firstNamePar ) 48 - #set( $userLastName = $lastNamePar ) 49 -#else 50 - #set( $apiceUser = false ) 51 - #set( $oneUser = false ) 52 - #set( $userFirstName = "" ) 53 - #set( $userLastName = "" ) 54 54 #end 55 -#if( $oneUser ) 56 - #if( $apiceUser ) 57 - #set( $userString = "%$userName%" ) 58 - #else 59 - #set( $userString = "%$userFirstName $userLastName%" ) 60 - #end 61 -#else 62 - #set( $userString = "%%" ) 63 -#end 64 -#### handle cycle 24 +## years / parameters takes precedence 25 +#set( $firstYear = $firstYearThesis ) 26 +#set( $lastYear = $lastYearThesis ) 27 +#template('apice_year_param.vm') 28 +## 29 +## CYCLES / START 65 65 ## $cycleList gets the list of cycles to be shown 66 66 ## $oneCycle true if just one cycle to be shown 67 67 #if( $request.cycle && $request.cycle.trim() != "" ) ... ... @@ -83,66 +83,16 @@ 83 83 #set( $cycle = "" ) 84 84 #end 85 85 ## INVARIANT: $oneCycle and $cycleList are correctly and coherently initialised 51 +## CYCLES / END 86 86 ## 87 -## when 88 -#set( $yearPar = $request.year.trim() ) 89 -#set( $firstYearPar = $request.from.trim() ) 90 -#set( $lastYearPar = $request.to.trim() ) 91 -#### handle when 92 -#set( $firstYear = $mathtool.toInteger($firstYearThesis) ) 93 -#set( $lastYear = $mathtool.toInteger($lastYearThesis) ) 94 -#if( $lastYear < $firstYear ) 95 - #set( $lastYear = $firstYear ) 96 -#end 97 -## parameters takes precedence 98 -#if( $yearPar ) 99 - #set( $yearInt = $mathtool.toInteger($yearPar) ) 100 - #if( $yearInt > 0 ) 101 - #set( $firstYear = $yearInt ) 102 - #set( $lastYear = $yearInt ) 103 - #end 104 -#end 105 -#if( $firstYearPar ) 106 - #set( $yearInt = $mathtool.toInteger($firstYearPar) ) 107 - #if( $yearInt > 0 ) 108 - #set( $firstYear = $yearInt ) 109 - #end 110 -#end 111 -#if( $lastYearPar ) 112 - #set( $yearInt = $mathtool.toInteger($lastYearPar) ) 113 - #if( $yearInt > 0 ) 114 - #set( $lastYear = $yearInt ) 115 - #end 116 -#end 117 -#if( $lastYear < $firstYear ) 118 -## swap 119 - #set( $yearTemp = $lastYear ) 120 - #set( $lastYear = $firstYear ) 121 - #set( $firstYear = $yearTemp ) 122 -#end 123 -## invariant: $lastYear >= $firstYear 124 -#if( $lastYear > $firstYear ) 125 - #set( $year = -1 ) 126 - #set( $yearList = [$lastYear..$firstYear] ) 127 - #set( $oneYear = false ) 128 -#else 129 -## $lastYear = $firstYear 130 - #set( $year = $lastYear ) 131 - #set( $yearList = [$year] ) 132 - #set( $oneYear = true ) 133 -#end 134 -## handle when / end 53 +#### SET PARAMETERS / END 135 135 ## 136 -## $oneUser, $apiceUser, $userString, $userFirstName, $userLastName, $oneCycle, $cycleList, $oneYear, $yearList are properly set 137 -## 138 -#### HANDLE PARAMETERS / END 139 -## 140 -## query to structures 55 +## DATA STRUCTURES / START 141 141 #set( $itemMap = {} ) 142 142 #set( $itemNo = 0 ) 143 143 #foreach( $year in $yearList ) 144 - #set( $query = ", BaseObject as obj, StringProperty as prop 0, DateProperty as prop1, StringProperty as prop2, LargeStringProperty as prop3, LargeStringProperty as prop4, LargeStringProperty as prop5145 - where obj.name = doc.fullName and obj.className = '${objectSpace}.${objectClass}' and obj.name <> '${objectSpace}.${objectTemplate}' and prop 0.id.id = obj.id and prop1.id.id = obj.id and prop2.id.id = obj.id and prop3.id.id =obj.id andprop4.id.id = obj.id and prop5.id.id = obj.id and prop0.name= 'cycle' and prop1.name = 'end' and prop2.name = 'status' and prop3.name = 'supervisors' and prop4.name = 'cosupervisors' and prop5.name = 'contacts' #if( $oneCycle ) and prop0.value = '$cycle'#end and year(prop1.value) = $year and lower(prop2.value) = 'completed' #if( $oneUser )and ( prop3.value like '%$userString%' or prop4.value like '%$userString%' or prop5.value like '%$userString%' )#end order by prop1.value desc" )59 + #set( $query = ", BaseObject as objThesis #if( $oneCycle ), StringProperty as propCycle #end, DateProperty as propEnddate, StringProperty as propStatus, LargeStringProperty as propSupervisor, LargeStringProperty as propCosupervisor, LargeStringProperty as propContact 60 + where objThesis.name = doc.fullName and objThesis.className = '${objectSpace}.${objectClass}' and objThesis.name <> '${objectSpace}.${objectTemplate}' and propEnddate.id.id = objThesis.id and propStatus.id.id = objThesis.id and propSupervisor.id.id = objThesis.id and propCosupervisor.id.id = objThesis.id and propContact.id.id = objThesis.id and propEnddate.name = 'end' and propStatus.name = 'status' and propSupervisor.name = 'supervisors' and propCosupervisor.name = 'cosupervisors' and propContact.name = 'contacts' #if( $oneCycle ) and propCycle.id.id = objThesis.id and propCycle.name = 'cycle' and propCycle.value = '$cycle' #end and year(propEnddate.value) = $year and lower(propStatus.value) = 'completed' #if( $oneUser )and ( propSupervisor.value like '%$userString%' or propCosupervisor.value like '%$userString%' or propContact.value like '%$userString%' )#end order by propEnddate.value desc" ) 146 146 ## do query 147 147 #set( $itemFound = $xwiki.searchDocuments($query) ) 148 148 ## set counters ... ... @@ -152,12 +152,36 @@ 152 152 #set( $itemNo = $itemNo + $itemYearNo ) 153 153 #end 154 154 #end 70 +## DATA STRUCTURES / END 155 155 ## 156 -## outputresults72 +## DISPLAY / START 157 157 ## page subtitle 158 -{{id name="top"/}} 159 ->(%%)$itemNo #if( $itemNo == 1 )#if( $oneCycle ){{thesisCycle plural="false" uppercase="false"}}$cycle{{/thesisCycle}}#else$services.localization.render('thesis').toLowerCase()#end#{else}#if( $oneCycle ){{thesisCycle plural="true" uppercase="false"}}$cycle{{/thesisCycle}}#else$services.localization.render('theses').toLowerCase()#end#{end} / #if( $oneYear )$year#else$firstYear–$lastYear#{end}#if( $oneUser ) / $userFirstName $userLastName#{end}(%%) 160 - 74 +<div class="mainheader"> 75 +$itemNo 76 +#if( $itemNo == 1 ) 77 + #if( $oneCycle ) 78 + {{thesisCycle plural="false" uppercase="false"}}$cycle{{/thesisCycle}} 79 + #else 80 + $services.localization.render('thesis').toLowerCase() 81 + #end 82 +#{else} 83 + #if( $oneCycle ) 84 + {{thesisCycle plural="true" uppercase="false"}}$cycle{{/thesisCycle}} 85 + #else 86 + $services.localization.render('theses').toLowerCase() 87 + #end 88 +#{end} 89 +<span class="textsecondary"> / </span> 90 +#if( $oneYear ) 91 + $year 92 +#else 93 + $firstYear–$lastYear 94 +#{end} 95 +#if( $oneUser ) 96 + <span class="textsecondary"> / </span> 97 + $userFirstName $userLastName 98 +#end 99 +</div> 161 161 ## stop if no thesis is found 162 162 #if( $itemNo == 0 || $itemMap.keySet().size() == 0 ) 163 163 ## redundant double check ... ... @@ -167,8 +167,14 @@ 167 167 ## page index 168 168 #if( $itemMap.keySet().size() > 1 ) 169 169 ## found more than one year 170 -{{id name="index"/}} 171 -(% style="font-size:smaller; text-align:right; padding:1em 1.5em 0.25em 1.5em; background-color:$theme.highlightColor" %)(((#foreach( $year in $itemMap.keySet() )#if( !$foreach.first ) | #end[[$year>>$doc||anchor=$year]]#end))) 109 +<div class="mainselectbar" id="index"> 110 + #foreach( $year in $itemMap.keySet() ) 111 + #if( !$foreach.first ) 112 +  •  113 + #end 114 + [[$year>>||anchor="$year"]] 115 + #end 116 +</div> 172 172 #end 173 173 ## theses displayed per year 174 174 ## ... ... @@ -175,16 +175,24 @@ 175 175 #template('apice_thesis_macros.vm') 176 176 ## 177 177 #foreach( $year in $itemMap.keySet() ) 178 -(% style="border-style:solid hidden hidden solid; border-color:$theme.borderColor; text-align:left; font-style:oblique" %)|{{id name='$year'/}}[[$year>>$doc||style="text-decoration:none; color:$theme.textPrimaryColor" queryString='year=$year#if( $oneUser )#if( $apiceUser )&user=$userName#{else}&name=$userFirstName&surname=$userLastName#end#end#if( $oneCycle )&cycle=$cycle#end']] 179 -{{html wiki="true" clean="false"}} 123 +## year top / start 124 +<div class="mainselectseparator"> 125 + <a class="mainselectseparatorlink" id="$year" href=$xwiki.getURL($doc,"view","year=$year#if( $apiceUser )&user=$userName#elseif( $oneUser )&name=$userFirstName&surname=$userLastName#end#if( $oneCycle )&cycle=$cycle#end")> 126 + $year 127 + </a> 128 +</div> 129 +## year top / end 130 +## 131 +## year display / start 180 180 <div style="font-style: normal"><ul> 181 181 #foreach( $item in $itemMap[$year] ) 182 182 <li>#thesislinked($item)</li> 183 183 #end 184 184 </ul></div> 185 -{{/html}} 186 - #set( $itemYearNo = $itemMap[$year].size() ) 137 +<div> #set( $itemYearNo = $itemMap[$year].size() ) 187 187 (% style="border-style:hidden solid solid hidden; border-color:$theme.borderColor; text-align:right; font-style:oblique; font-size:smaller" %)|($itemYearNo #if( $oneCycle )#if( $itemYearNo == 1 ){{thesisCycle plural="false" uppercase="false"}}$cycle{{/thesisCycle}}#{else}{{thesisCycle plural="true" uppercase="false"}}$cycle{{/thesisCycle}}#end#else#if( $itemYearNo == 1 )$services.localization.render('thesis').toLowerCase()#else$services.localization.render('theses').toLowerCase()#end#end / $year) [[[{{stringEngIta eng='top' ita='in cima'/}}]>>||anchor="top"]] [[[{{stringEngIta eng='bottom' ita='in fondo'/}}]>>||anchor="bottom"]] 139 +</div> 188 188 #end 141 +{{/html}} 189 189 {{/velocity}} 190 190 {{id name="bottom"/}}