Changes for page Per Year
      From version  132.2 
    
    
              edited by Andrea Omicini
        
on 30/01/2023 13:43
     on 30/01/2023 13:43
      Change comment:
              There is no comment for this version
          
         
      To version  120.21 
    
    
              edited by Andrea Omicini
        
on 30/10/2021 19:45
     on 30/10/2021 19:45
      Change comment:
              There is no comment for this version
          
         Summary
- 
          Page properties (3 modified, 0 added, 0 removed)
Details
- Page properties
- 
      - Title
-   ... ... @@ -1,0 +1,1 @@ 1 +#if($xcontext.language=='it')Tesi per anno e livello#{else}Theses per Year & Cycle#end 
- Default language
-   ... ... @@ -1,0 +1,1 @@ 1 +en 
- Content
-   ... ... @@ -1,187 +1,149 @@ 1 -= {{italiano}}Per anno{{/italiano}}{{english}}Per Year{{/english}} = 2 - 3 -{{include reference="Theses.Environment" excludeFirstHeading="true"/}}{{velocity}} 1 +{{include reference="Theses.Environment"/}}{{include reference="Environment"/}}{{velocity}} 4 4 #set( $thesisMenu = true ) 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 3 +## get environment variables & derived 4 +#set( $firstYear = $mathtool.toInteger($firstYearTh) ) 5 +#set( $lastYear = $mathtool.toInteger($lastYearTh) ) 6 +#set( $yearList = [$lastYear..$firstYear] ) 7 +### START YEAR 8 +## defaults 9 +#set( $oneYear = false ) 10 +#set( $selectedYear = '' ) 11 +## year parameters 12 +#if( $request.year ) 13 + #set( $yearPar = $mathtool.toInteger($request.year) ) 14 +#end 15 +#if( $request.from ) 16 + #set( $fromPar = $mathtool.toInteger($request.from) ) 17 +#end 18 +#if( $request.to ) 19 + #set( $toPar = $mathtool.toInteger($request.to) ) 20 +#end 21 +##set years 22 +#if( $yearPar > 0 ) 23 + #set( $oneYear = true ) 24 + #set( $firstYear = $yearPar ) 25 + #set( $lastYear = $yearPar ) 26 + #set( $selectedYear = $yearPar ) 27 + #set( $yearList = [$yearPar] ) 28 +#else 29 + #if( $fromPar != '' && ($fromPar > $firstYear) ) 30 + #set( $firstYear = $fromPar ) 31 + #set( $yearList = [$lastYear..$firstYear] ) 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 - ##fromtheURL,"user=$userNamePar"parameter25 - # if( $userNamePar.contains('XWiki.'))26 - #set( $ userName="$userNamePar")33 + #if( $toPar != '' && ($toPar < $lastYear) ) 34 + #set( $lastYear = $toPar ) 35 + #set( $yearList = [$lastYear..$firstYear] ) 36 + #end 37 + #if( $lastYear <= $firstYear ) 38 + #set( $oneYear = true ) 39 + #set( $lastYear = $firstYear ) 40 + #set( $selectedYear = $firstYear ) 41 + #set( $yearList = [$firstYear] ) 27 27 #else 28 - #set( $ userName="XWiki.$userNamePar")43 + #set( $yearList = [$lastYear..$firstYear] ) 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 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%" ) 46 +## $selectedYear, $yearList and $oneYear set properly 47 +### END YEAR 48 +## 49 +### START USER 50 +## default values 51 +#set( $oneUser = false ) 52 +#set( $selectedUser = '' ) 53 +#set( $userFirstName = "" ) 54 +#set( $userLastName = "" ) 55 +## user parameter 56 +#if( $request.user ) 57 + #set( $userNamePar = $request.user.trim() ) 58 +#end 59 +#if( $userName || $userNamePar ) 60 +## try to specify a user 61 + #if( !$userName ) 62 + #set( $selectedUser = "XWiki.$userNamePar" ) 58 58 #else 59 - userString="%$userFirstName$userLastName%")64 + #set( $selectedUser = $userName ) 60 60 #end 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 ) 66 + #if( $xwiki.exists($selectedUser) ) 67 + #set( $oneUser = true ) 68 + #set( $userdoc = $xwiki.getDocument($selectedUser) ) 69 + #set( $userFirstName = $userdoc.display("first_name") ) 70 + #set( $userLastName = $userdoc.display("last_name") ) 74 74 #else 75 -## 'cycle' parameter is not an admissible thesis cycle value 76 -{{warning}}$cyclePar is not an admissible cycle for APICe theses{{/warning}} 72 +{{warning}} $selectedUser is not an {{apice/}} user{{/warning}} 77 77 #stop 78 78 #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 = "" ) 88 88 #end 89 -## INVARIANT: $oneCycle and $cycleList are correctly and coherently initialised 76 +## $selectedUser and $oneUser set properly 77 +### END USER 90 90 ## 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 ) 79 +### START CYCLE 80 +#set( $oneCycle = false ) 81 +#set( $selectedCycle = '' ) 82 +## cycle parameter 83 +#if( $request.cycle ) 84 + #set( $cyclePar = $request.cycle.trim().toUpperCase() ) 100 100 #end 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 86 +## set cycle 87 +#if( $cyclePar != '' && $allThesisCycles.contains($cyclePar) ) 88 + #set( $oneCycle = true ) 89 + #set( $selectedCycle = $cyclePar ) 108 108 #end 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 ) 132 -#else 133 -## $lastYear = $firstYear 134 - #set( $year = $lastYear ) 135 - #set( $yearList = [$year] ) 136 - #set( $oneYear = true ) 137 -#end 138 -## handle when / end 91 +## $selectedCycle and $oneCycle set properly 92 +### END CYCLE 139 139 ## 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 ) 94 +## title 95 +>#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'/}} 96 +## index 97 +#if( !$oneYear ) 98 +(% 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))) 99 +###elseif( $oneUser && !$oneCycle ) 100 +#elseif( !$oneCycle ) 101 +(% style="font-size: smaller; padding:1em 1.5em 0.25em 1.5em; background-color:$theme.highlightColor" %)(((#foreach( $cycle in $allThesisCycles )#if ($velocityCount > 1) | #end [[{{thesisCycle}}$cycle{{/thesisCycle}}>>||anchor="$cycle"]]#end))) 102 +#end{{id name='index'/}} 103 +## search theses 104 +#set( $thesisNo = 0 ) 147 147 #foreach( $year in $yearList ) 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 ) 106 + #set( $thesisYearNo = 0 ) 107 + #if( !$oneYear ) 108 +(% 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']] 157 157 #end 158 -#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}(%%) 110 +## some selected year or year list / now $year 111 + #foreach( $cycle in $allThesisCycles ) 112 + #set( $thesisYearCycleNo = 0 ) 113 + #if( !$oneCycle || $selectedCycle == $cycle ) 114 +## some selected cycle or all cycles / now $cycle 115 + #if( $oneUser) 116 + #set ($sql = ", BaseObject as obj, StringProperty as prop0, DateProperty as prop1, StringProperty as prop2, LargeStringProperty as prop3, LargeStringProperty as prop4, LargeStringProperty as prop5 117 + where obj.name = doc.fullName and obj.className = 'Theses.ThesisClass' and obj.name <> 'Theses.ThesisClassTemplate' 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" ) 118 + #else 119 + #set ($sql = ", BaseObject as obj, StringProperty as prop0, DateProperty as prop1, StringProperty as prop2 120 + where obj.name = doc.fullName and obj.className = 'Theses.ThesisClass' and obj.name <> 'Theses.ThesisClassTemplate' 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" ) 121 + #end 122 + #set( $thesisFound = $xwiki.searchDocuments($sql) ) 123 + #set( $thesisFoundNo = $thesisFound.size() ) 124 + #set( $thesisYearCycleNo = $thesisYearCycleNo + $thesisFoundNo ) 125 + #if( $thesisFoundNo > 0 && !$oneCycle ) 126 +(% 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#if( $oneYear )&year=$selectedYear#end']] 127 + #end 128 + #foreach( $thesis in $thesisFound ) 129 + #set( $thesisDoc = $xwiki.getDocument($thesis) ) 130 + #set( $thesisObj = $thesisDoc.getObject('Theses.ThesisClass') ) 131 +* [[$thesisObj.title>>$thesisDoc]]#if( $thesisObj.endDate != "" ) //($thesisObj.endDate)//#end#if( $thesisDoc.getValue('studentUserName') != "" ) – [[$xwiki.getUserName($thesisDoc.getValue('studentUserName'), false)>>$thesisDoc.getValue('studentUserName')]]#elseif( $thesisObj.studentFirstName != "" && $thesisObj.studentLastName != "" ) – $thesisObj.studentFirstName $thesisObj.studentLastName#end 164 164 165 -## stop if no thesis is found 166 -#if( $itemNo == 0 || $itemMap.keySet().size() == 0 ) 167 -## redundant double check 168 - #stop 133 + #end 134 + #if( $thesisFoundNo > 0 && !$oneCycle ) 135 +(% 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"]] 136 + #end 137 + #end 138 + #set( $thesisYearNo = $thesisYearNo + $thesisYearCycleNo ) 139 + #end 140 + #if( !$oneYear ) 141 +(% 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"]] 142 + #end 143 + #set( $thesisNo = $thesisNo + $thesisYearNo ) 169 169 #end 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>>$doc||anchor=$year]]#end))) 145 +#if( $thesisNo > 0 ) 146 +(% style="text-align:right; font-style:oblique; font-weight:normal; font-size:smaller; color:$theme.textSecondaryColor" %)|($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'/}} $firstYearTh {{stringEngIta eng='to' ita='al'/}} $lastYearTh#end) 176 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 148 +{{id name='bottom'/}} 186 186 {{/velocity}} 187 -{{id name="bottom"/}}