Changes for page Per Year
      From version  127.1 
    
    
              edited by Andrea Omicini
        
on 11/03/2022 15:56
     on 11/03/2022 15:56
      Change comment:
              There is no comment for this version
          
         
      To version  131.4 
    
    
              edited by Andrea Omicini
        
on 30/01/2023 13:13
     on 30/01/2023 13:13
      Change comment:
              There is no comment for this version
          
         Summary
- 
          Page properties (1 modified, 0 added, 0 removed)
Details
- Page properties
- 
      - Content
-   ... ... @@ -1,153 +1,187 @@ 1 -= {{italiano}}Per anno e livello{{/italiano}}{{english}}Per Year& Cycle{{/english}} =1 += {{italiano}}Per anno{{/italiano}}{{english}}Per Year{{/english}} = 2 2 3 3 {{include reference="Theses.Environment" excludeFirstHeading="true"/}}{{velocity}} 4 4 #set( $thesisMenu = true ) 5 -## get environment variables & derived 6 -#set( $firstYear = $mathtool.toInteger($firstYearThesis) ) 7 -#set( $lastYear = $mathtool.toInteger($lastYearThesis) ) 8 -#set( $yearList = [$lastYear..$firstYear] ) 9 -### START YEAR 10 -## defaults 11 -#set( $oneYear = false ) 12 -#set( $selectedYear = '' ) 13 -## year parameters 14 -#if( $request.year ) 15 - #set( $yearPar = $mathtool.toInteger($request.year) ) 16 -#end 17 -#if( $request.from ) 18 - #set( $fromPar = $mathtool.toInteger($request.from) ) 19 -#end 20 -#if( $request.to ) 21 - #set( $toPar = $mathtool.toInteger($request.to) ) 22 -#end 23 -##set years 24 -#if( $yearPar > 0 ) 25 - #set( $oneYear = true ) 26 - #set( $firstYear = $yearPar ) 27 - #set( $lastYear = $yearPar ) 28 - #set( $selectedYear = $yearPar ) 29 - #set( $yearList = [$yearPar] ) 30 -#else 31 - #if( $fromPar != '' && ($fromPar > $firstYear) ) 32 - #set( $firstYear = $fromPar ) 33 - #set( $yearList = [$lastYear..$firstYear] ) 5 +#### HANDLE PARAMETERS / START 6 +## 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}} 16 + #stop 34 34 #end 35 - # if( $toPar!='' && ($toPar< $lastYear))36 - lastYear =$toPar )37 - yearList=[$lastYear..$firstYear])38 - #e nd39 - # if( $lastYear<= $firstYear)40 - t( $oneYear= true)41 - #set($lastYear= $firstYear)42 - set( $selectedYear = $firstYear)43 - #set( $ yearList=[$firstYear])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" ) 44 44 #else 45 - #set( $ yearList=[$lastYear..$firstYear])28 + #set( $userName = "XWiki.$userNamePar" ) 46 46 #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 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 = "" ) 47 47 #end 48 -## $selectedYear, $yearList and $oneYear set properly 49 -### END YEAR 50 -## 51 -### START USER 52 -## default values 53 -#set( $oneUser = false ) 54 -#set( $selectedUser = '' ) 55 -#set( $userFirstName = "" ) 56 -#set( $userLastName = "" ) 57 -## user parameter 58 -#if( $request.user ) 59 - #set( $userNamePar = $request.user.trim() ) 60 -#end 61 -#if( $userName || $userNamePar ) 62 -## try to specify a user 63 - #if( !$userName ) 64 - #set( $selectedUser = "XWiki.$userNamePar" ) 55 +#if( $oneUser ) 56 + #if( $apiceUser ) 57 + #set( $userString = "%$userName%" ) 65 65 #else 66 - #set( $se lectedUser = $userName )59 + #set( $userString = "%$userFirstName $userLastName%" ) 67 67 #end 68 - #if( $xwiki.exists($selectedUser) ) 69 - #set( $oneUser = true ) 70 - #set( $userdoc = $xwiki.getDocument($selectedUser) ) 71 - #set( $userFirstName = $userdoc.display("first_name") ) 72 - #set( $userLastName = $userdoc.display("last_name") ) 61 +#else 62 + #set( $userString = "%%" ) 63 +#end 64 +#### handle cycle 65 +## $cycleList gets the list of cycles to be shown 66 +## $oneCycle true if just one cycle to be shown 67 +#if( $request.cycle && $request.cycle.trim() != "" ) 68 + #set( $cyclePar = $request.cycle.trim().toUpperCase() ) 69 + #if( $allThesisCycles.contains($cyclePar) ) 70 +## 'cycle' parameter is an admissible thesis cycle value 71 + #set( $cycleList = [$cyclePar]) 72 + #set( $oneCycle = true ) 73 + #set( $cycle = $cyclePar ) 73 73 #else 74 -{{warning}} $selectedUser is not an {{apice/}} user{{/warning}} 75 +## 'cycle' parameter is not an admissible thesis cycle value 76 +{{warning}}$cyclePar is not an admissible cycle for APICe theses{{/warning}} 75 75 #stop 76 76 #end 79 +#else 80 +## default: all cycles 81 + #if( $showPhDTheses ) 82 + #set( $cycleList = $allThesisCycles ) 83 + #else 84 + #set( $cycleList = $lowThesisCycles ) 85 + #end 86 + #set( $oneCycle = false ) 87 + #set( $cycle = "" ) 77 77 #end 78 -## $selectedUser and $oneUser set properly 79 -### END USER 89 +## INVARIANT: $oneCycle and $cycleList are correctly and coherently initialised 80 80 ## 81 -### START CYCLE 82 -#set( $oneCycle = false ) 83 -#set( $selectedCycle = '' ) 84 -## cycle parameter 85 -#if( $request.cycle ) 86 - #set( $cyclePar = $request.cycle.trim().toUpperCase() ) 91 +## when 92 +#set( $yearPar = $request.year.trim() ) 93 +#set( $firstYearPar = $request.from.trim() ) 94 +#set( $lastYearPar = $request.to.trim() ) 95 +#### handle when 96 +#set( $firstYear = $mathtool.toInteger($firstYearThesis) ) 97 +#set( $lastYear = $mathtool.toInteger($lastYearThesis) ) 98 +#if( $lastYear < $firstYear ) 99 + #set( $lastYear = $firstYear ) 87 87 #end 88 -## set cycle 89 -#if( $cyclePar != '' && $allThesisCycles.contains($cyclePar) ) 90 - #set( $oneCycle = true ) 91 - #set( $selectedCycle = $cyclePar ) 101 +## parameters takes precedence 102 +#if( $yearPar ) 103 + #set( $yearInt = $mathtool.toInteger($yearPar) ) 104 + #if( $yearInt > 0 ) 105 + #set( $firstYear = $yearInt ) 106 + #set( $lastYear = $yearInt ) 107 + #end 92 92 #end 93 -## $selectedCycle and $oneCycle set properly 94 -#if( $showPhDTheses ) 95 - #set( $cycles = $allThesisCycles ) 109 +#if( $firstYearPar ) 110 + #set( $yearInt = $mathtool.toInteger($firstYearPar) ) 111 + #if( $yearInt > 0 ) 112 + #set( $firstYear = $yearInt ) 113 + #end 114 +#end 115 +#if( $lastYearPar ) 116 + #set( $yearInt = $mathtool.toInteger($lastYearPar) ) 117 + #if( $yearInt > 0 ) 118 + #set( $lastYear = $yearInt ) 119 + #end 120 +#end 121 +#if( $lastYear < $firstYear ) 122 +## swap 123 + #set( $yearTemp = $lastYear ) 124 + #set( $lastYear = $firstYear ) 125 + #set( $firstYear = $yearTemp ) 126 +#end 127 +## invariant: $lastYear >= $firstYear 128 +#if( $lastYear > $firstYear ) 129 + #set( $year = -1 ) 130 + #set( $yearList = [$lastYear..$firstYear] ) 131 + #set( $oneYear = false ) 96 96 #else 97 - #set( $cycles = $lowThesisCycles ) 133 +## $lastYear = $firstYear 134 + #set( $year = $lastYear ) 135 + #set( $yearList = [$year] ) 136 + #set( $oneYear = true ) 98 98 #end 99 -## #ENDCYCLE138 +## handle when / end 100 100 ## 101 -## title 102 ->#if( $oneCycle ){{thesisCycle uppercase='yes' short='no'}}$selectedCycle{{/thesisCycle}}#else{{stringEngIta eng="Theses" ita="Tesi"/}}#end / #if( $oneYear )**$selectedYear**#else**$firstYear–$lastYear**#end#if( $oneUser ) / $userFirstName $userLastName#end{{id name='top'/}} 103 -## index 104 -#if( !$oneYear ) 105 -(% style="font-size: smaller; padding:1em 1.5em 0.25em 1.5em; background-color:$theme.highlightColor" %)(((#foreach( $year in $yearList )#if ($velocityCount > 1) | #end[[$year>>||anchor="$year"]]#end))) 106 -###elseif( $oneUser && !$oneCycle ) 107 -#elseif( !$oneCycle ) 108 -(% style="font-size: smaller; padding:1em 1.5em 0.25em 1.5em; background-color:$theme.highlightColor" %)(((#foreach( $cycle in $cycles )#if ($velocityCount > 1) | #end [[{{thesisCycle}}$cycle{{/thesisCycle}}>>||anchor="$cycle"]]#end))) 109 -#end{{id name='index'/}} 110 -## search theses 111 -#set( $thesisNo = 0 ) 140 +## $oneUser, $apiceUser, $userString, $userFirstName, $userLastName, $oneCycle, $cycleList, $oneYear, $yearList are properly set 141 +## 142 +#### HANDLE PARAMETERS / END 143 +## 144 +## query to structures 145 +#set( $itemMap = {} ) 146 +#set( $itemNo = 0 ) 112 112 #foreach( $year in $yearList ) 113 - #set( $thesisYearNo = 0 ) 114 - #if( !$oneYear ) 115 -(% style="border-style:solid hidden hidden solid; border-color:$theme.borderColor; text-align:left; font-style:oblique" %)|{{id name='$year'/}}[[$year>>$doc.name||queryString='year=$year#if( $oneCycle )&cycle=$selectedCycle#end']] 148 + #set( $query = ", BaseObject as obj, StringProperty as prop0, DateProperty as prop1, StringProperty as prop2, LargeStringProperty as prop3, LargeStringProperty as prop4, LargeStringProperty as prop5 149 + where obj.name = doc.fullName and obj.className = '${objectSpace}.${objectClass}' and obj.name <> '${objectSpace}.${objectTemplate}' and prop0.id.id = obj.id and prop1.id.id = obj.id and prop2.id.id = obj.id and prop3.id.id = obj.id and prop4.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" ) 150 +## do query 151 + #set( $itemFound = $xwiki.searchDocuments($query) ) 152 +## set counters 153 + #set( $itemYearNo = $itemFound.size() ) 154 + #if( $itemYearNo > 0 ) 155 + #set( $itemMap[$year] = $itemFound ) 156 + #set( $itemNo = $itemNo + $itemYearNo ) 116 116 #end 117 -## some selected year or year list / now $year 118 - #foreach( $cycle in $cycles ) 119 - #set( $thesisYearCycleNo = 0 ) 120 - #if( !$oneCycle || $selectedCycle == $cycle ) 121 -## some selected cycle or all cycles / now $cycle 122 - #if( $oneUser) 123 - #set ($sql = ", BaseObject as obj, StringProperty as prop0, DateProperty as prop1, StringProperty as prop2, LargeStringProperty as prop3, LargeStringProperty as prop4, LargeStringProperty as prop5 124 - where obj.name = doc.fullName and obj.className = 'Theses.ThesisClass' and obj.name <> 'Theses.ThesisTemplate' and prop0.id.id = obj.id and prop1.id.id = obj.id and prop2.id.id = obj.id and prop3.id.id = obj.id and prop4.id.id = obj.id and prop5.id.id = obj.id and prop0.name = 'cycle' and prop1.name = 'endDate' and prop2.name = 'status' and prop3.name = 'supervisors' and prop4.name = 'cosupervisors' and prop5.name = 'contacts' and prop0.value = '$cycle' and year(prop1.value) = '$year' and prop2.value = 'Completed' and ( prop3.value like '%$selectedUser%' or prop4.value like '%$selectedUser%' or prop5.value like '%$selectedUser%' ) order by prop1.value desc" ) 125 - #else 126 - #set ($sql = ", BaseObject as obj, StringProperty as prop0, DateProperty as prop1, StringProperty as prop2 127 - where obj.name = doc.fullName and obj.className = 'Theses.ThesisClass' and obj.name <> 'Theses.ThesisTemplate' and prop0.id.id = obj.id and prop1.id.id = obj.id and prop2.id.id = obj.id and prop0.name = 'cycle' and prop1.name = 'endDate' and prop2.name = 'status' and prop0.value = '$cycle' and year(prop1.value) = '$year 'and prop2.value = 'Completed' order by prop1.value desc" ) 128 - #end 129 - #set( $thesisFound = $xwiki.searchDocuments($sql) ) 130 - #set( $thesisFoundNo = $thesisFound.size() ) 131 - #set( $thesisYearCycleNo = $thesisYearCycleNo + $thesisFoundNo ) 132 - #if( $thesisFoundNo > 0 && !$oneCycle ) 133 -(% style="border-style:#if( $oneYear )solid hidden hidden solid#{else}hidden hidden hidden dotted#end; border-color:$theme.borderColor; text-align:left; font-style:oblique; font-size:smaller" %)|#if( $oneYear ){{id name='$cycle'/}}#else{{id name='$year-$cycle'/}}#end[[{{thesisCycle plural='no' uppercase='yes' short='yes'}}$cycle{{/thesisCycle}}>>$doc.name||queryString='cycle=$cycle&year=$year']] 134 - #end 135 - #foreach( $thesis in $thesisFound ) 136 -* {{thesis}}$thesis{{/thesis}} 137 - #end 138 - #if( $thesisFoundNo > 0 && !$oneCycle ) 139 -(% style="border-style:#if( $oneYear )hidden solid solid hidden#{else}hidden dotted hidden hidden#end; border-color:$theme.borderColor; text-align:right; font-style:oblique; font-weight:normal; font-size:smaller; color:$theme.textSecondaryColor" %)|#if( $oneYear ){{id name='$cycle-bottom'/}}#else{{id name='$cycle-$year-bottom'/}}#end($thesisYearCycleNo #if( $thesisYearCycleNo == 1 ){{thesisCycle plural='no' uppercase='no' short='no'}}$cycle{{/thesisCycle}}#else{{thesisCycle plural='yes' uppercase='no' short='no'}}$cycle{{/thesisCycle}}#end {{stringEngIta eng='in' ita='nel'/}} $year [[[{{stringEngIta eng='top' ita='in cima'/}}]>>||anchor="top"]] [[[{{stringEngIta eng='bottom' ita='in fondo'/}}]>>||anchor="bottom"]] 140 - #end 141 - #end 142 - #set( $thesisYearNo = $thesisYearNo + $thesisYearCycleNo ) 143 - #end 144 - #if( !$oneYear ) 145 -(% style="border-style:hidden solid solid hidden; border-color:$theme.borderColor; text-align:right; font-style:oblique; font-weight:normal; font-size:smaller; color:$theme.textSecondaryColor" %)|($thesisYearNo #if($thesisYearNo == 1){{stringEngIta eng='thesis in' ita='tesi nel'/}}#else{{stringEngIta eng='theses in' ita='tesi nel'/}}#end $year{{id name='$year-bottom'/}}) [[[{{stringEngIta eng='top' ita='in cima'/}}]>>||anchor="top"]] [[[{{stringEngIta eng='bottom' ita='in fondo'/}}]>>||anchor="bottom"]] 146 - #end 147 - #set( $thesisNo = $thesisNo + $thesisYearNo ) 148 148 #end 149 -#if( $thesisNo > 0 ) 150 -(% style="text-align:right; font-style:oblique; font-weight:normal; font-size:smaller; color:$theme.textSecondaryColor; border-color:$theme.borderColor; border-bottom-style:dotted" %)|($thesisNo #if( $oneCycle )#if($thesisNo == 1){{thesisCycle plural='no' short='no' uppercase='no'}}$selectedCycle{{/thesisCycle}}#else{{thesisCycle plural='yes' short='no' uppercase='no'}}$selectedCycle{{/thesisCycle}}#end#else#if($thesisNo == 1){{stringEngIta eng='thesis' ita='tesi'/}}#else{{stringEngIta eng='theses' ita='tesi'/}}#end#end#if( $oneYear ) {{stringEngIta eng='in' ita='nel'/}} $selectedYear#else {{stringEngIta eng='from' ita='dal'/}} $firstYear {{stringEngIta eng='to' ita='al'/}} $lastYear#end) 159 +## 160 +## output results 161 +## page subtitle 162 +{{id name="top"/}} 163 +>(%%)$itemNo #if( $itemNo == 1 )#if( $oneCycle ){{thesisCycle plural="false" uppercase="false"}}$cycle{{/thesisCycle}}#else{{stringEngIta eng="$objectEngSingular.toLowerCase()" ita="$objectItaSingular.toLowerCase()"/}}#end#{else}#if( $oneCycle ){{thesisCycle plural="true" uppercase="false"}}$cycle{{/thesisCycle}}#else{{stringEngIta eng="$objectEngPlural.toLowerCase()" ita="$objectItaPlural.toLowerCase()"/}}#end#{end} / #if( $oneYear )$year#else$firstYear–$lastYear#{end}#if( $oneUser ) / $userFirstName $userLastName#{end}(%%) 164 + 165 +## stop if no thesis is found 166 +#if( $itemNo == 0 || $itemMap.keySet().size() == 0 ) 167 +## redundant double check 168 + #stop 151 151 #end 152 -{{id name='bottom'/}} 170 +## some theses found 171 +## page index 172 +#if( $itemMap.keySet().size() > 1 ) 173 +## found more than one year 174 +{{id name="index"/}} 175 +(% 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>>||anchor=$year]]#end))) 176 +#end 177 +## theses displayed per year 178 +#foreach( $year in $itemMap.keySet() ) 179 +(% 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']] 180 +(% style="border-style:hidden hidden hidden hidden; font-style:normal" %)#foreach( $item in $itemMap[$year] ) 181 +|{{thesis inline='false' linked='title'}}$item{{/thesis}} 182 +#end 183 + #set( $itemYearNo = $itemMap[$year].size() ) 184 +(% 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 ){{stringEngIta eng=$objectEngSingular.toLowerCase() ita=$objectItaSingular.toLowerCase()/}}#else{{stringEngIta eng=$objectEngPlural.toLowerCase() ita=$objectItaPlural.toLowerCase()/}}#end#end / $year) [[[{{stringEngIta eng='top' ita='in cima'/}}]>>||anchor="top"]] [[[{{stringEngIta eng='bottom' ita='in fondo'/}}]>>||anchor="bottom"]] 185 +#end 153 153 {{/velocity}} 187 +{{id name="bottom"/}}