Changes for page Per Year
From version 165.1
edited by Andrea Omicini
on 06/07/2023 19:27
on 06/07/2023 19:27
Change comment:
There is no comment for this version
To version 133.8
edited by Andrea Omicini
on 09/02/2023 00:46
on 09/02/2023 00:46
Change comment:
There is no comment for this version
Summary
-
Page properties (2 modified, 0 added, 0 removed)
Details
- Page properties
-
- Title
-
... ... @@ -1,1 +1,0 @@ 1 -$services.localization.render('peryear') - Content
-
... ... @@ -1,38 +1,74 @@ 1 -{{velocity}} 2 -{{html wiki="true" clean="false"}} 3 -#template('apice_macros.vm') 4 -#setobjectspace("Theses") 5 -#template('apice_thesis_macros.vm') 6 -#### SET PARAMETERS / START 7 -#template('apice_user_param.vm') 8 -## years / personal 9 -#if( $isUserSpace ) 10 - #set( $query = ", BaseObject as objPersonalThesis, LargeStringProperty as propUser 11 - where objPersonalThesis.name = doc.fullName and objPersonalThesis.className = '${mainSpace}.Personal.Class' and propUser.id.id = objPersonalThesis.id and propUser.name = 'user' and propUser.value = '$userName' " ) 12 - #set( $personalThesisDocs = $xwiki.searchDocuments($query) ) 13 - #if( $personalThesisDocs.size() > 0 ) 14 - #set( $personalThesisDoc = $xwiki.getDocument($personalThesisDocs[0]) ) 15 - #else 1 += {{italiano}}Per anno{{/italiano}}{{english}}Per Year{{/english}} = 2 + 3 +{{include reference="Main.Environment" excludeFirstHeading="true"/}}{{include reference="Theses.Environment" excludeFirstHeading="true"/}}{{velocity}} 4 +#set( $thesisMenu = true ) 5 +#### HANDLE PARAMETERS / START 6 +## 7 +## inline display 8 +#set( $inlinePar = $request.inline.trim() ) 9 +## who 10 +#set( $userNamePar = $request.user.trim() ) 11 +#set( $firstNamePar = $request.name.trim() ) 12 +#set( $lastNamePar = $request.surname.trim() ) 13 +#### handle who 14 +#if( $userName ) 15 +## from a personal page, "XWiki.$userName" $userName form 16 + #if( !$xwiki.exists( $userName ) ) 17 +{{warning}}User $userName does not exist{{/warning}} 16 16 #stop 17 17 #end 18 - #if( $personalThesisDoc.firstYear && $personalThesisDoc.firstYear != "" ) 19 - #set( $firstYearThesis = $personalThesisDoc.display('firstYear','view') ) 20 + #set( $apiceUser = true ) 21 + #set( $oneUser = true ) 22 + #set( $userdoc = $xwiki.getDocument($userName) ) 23 + #set( $userFirstName = $userdoc.display("first_name") ) 24 + #set( $userLastName = $userdoc.display("last_name") ) 25 +#elseif( $userNamePar ) 26 +## from the URL, "user=$userNamePar" parameter 27 + #if( $userNamePar.contains('XWiki.') ) 28 + #set( $userName = "$userNamePar" ) 29 + #else 30 + #set( $userName = "XWiki.$userNamePar" ) 20 20 #end 21 - #if( $personalThesisDoc.lastYear && $personalThesisDoc.lastYear != "" ) 22 - #set( $lastYearThesis = $personalThesisDoc.display('lastYear','view') ) 32 + #if( !$xwiki.exists( $userName ) ) 33 + #if( $services.localization.currentLocale == 'it' ) 34 +{{warning}}L'utente “$userNamePar” non esiste{{/warning}} 35 + #else 36 +{{warning}}User “$userNamePar” does not exist{{/warning}} 37 + #end 38 + #stop 23 23 #end 40 + #set( $apiceUser = true ) 41 + #set( $oneUser = true) 42 + #set( $userdoc = $xwiki.getDocument($userName) ) 43 + #set( $userFirstName = $userdoc.display("first_name") ) 44 + #set( $userLastName = $userdoc.display("last_name") ) 45 +#elseif( $firstNamePar && $lastNamePar ) 46 +## from the URL, "name=Firstname&surname=Lastname" parameter 47 + #set( $apiceUser = false ) 48 + #set( $oneUser = true ) 49 + #set( $userFirstName = $firstNamePar ) 50 + #set( $userLastName = $lastNamePar ) 51 +#else 52 + #set( $apiceUser = false ) 53 + #set( $oneUser = false ) 54 + #set( $userFirstName = "" ) 55 + #set( $userLastName = "" ) 24 24 #end 25 -## years / parameters takes precedence 26 -#set( $firstYear = $firstYearThesis ) 27 -#set( $lastYear = $lastYearThesis ) 28 -#template('apice_year_param.vm') 29 -## 30 -## CYCLES / START 57 +#if( $oneUser ) 58 + #if( $apiceUser ) 59 + #set( $userString = "%$userName%" ) 60 + #else 61 + #set( $userString = "%$userFirstName $userLastName%" ) 62 + #end 63 +#else 64 + #set( $userString = "%%" ) 65 +#end 66 +#### handle cycle 31 31 ## $cycleList gets the list of cycles to be shown 32 32 ## $oneCycle true if just one cycle to be shown 33 33 #if( $request.cycle && $request.cycle.trim() != "" ) 34 34 #set( $cyclePar = $request.cycle.trim().toUpperCase() ) 35 - #if( $ thesisCycles.contains($cyclePar) )71 + #if( $allThesisCycles.contains($cyclePar) ) 36 36 ## 'cycle' parameter is an admissible thesis cycle value 37 37 #set( $cycleList = [$cyclePar]) 38 38 #set( $oneCycle = true ) ... ... @@ -44,21 +44,86 @@ 44 44 #end 45 45 #else 46 46 ## default: all cycles 47 - #set( $cycleList = $showcaseThesisCycles ) 83 + #if( $showPhDTheses ) 84 + #set( $cycleList = $allThesisCycles ) 85 + #else 86 + #set( $cycleList = $lowThesisCycles ) 87 + #end 48 48 #set( $oneCycle = false ) 49 49 #set( $cycle = "" ) 50 50 #end 51 51 ## INVARIANT: $oneCycle and $cycleList are correctly and coherently initialised 52 -## CYCLES / END 53 53 ## 54 -#### SET PARAMETERS / END 93 +## when 94 +#set( $yearPar = $request.year.trim() ) 95 +#set( $firstYearPar = $request.from.trim() ) 96 +#set( $lastYearPar = $request.to.trim() ) 97 +#### handle when 98 +#set( $firstYear = $mathtool.toInteger($firstYearThesis) ) 99 +#set( $lastYear = $mathtool.toInteger($lastYearThesis) ) 100 +#if( $lastYear < $firstYear ) 101 + #set( $lastYear = $firstYear ) 102 +#end 103 +## parameters takes precedence 104 +#if( $yearPar ) 105 + #set( $yearInt = $mathtool.toInteger($yearPar) ) 106 + #if( $yearInt > 0 ) 107 + #set( $firstYear = $yearInt ) 108 + #set( $lastYear = $yearInt ) 109 + #end 110 +#end 111 +#if( $firstYearPar ) 112 + #set( $yearInt = $mathtool.toInteger($firstYearPar) ) 113 + #if( $yearInt > 0 ) 114 + #set( $firstYear = $yearInt ) 115 + #end 116 +#end 117 +#if( $lastYearPar ) 118 + #set( $yearInt = $mathtool.toInteger($lastYearPar) ) 119 + #if( $yearInt > 0 ) 120 + #set( $lastYear = $yearInt ) 121 + #end 122 +#end 123 +#if( $lastYear < $firstYear ) 124 +## swap 125 + #set( $yearTemp = $lastYear ) 126 + #set( $lastYear = $firstYear ) 127 + #set( $firstYear = $yearTemp ) 128 +#end 129 +## invariant: $lastYear >= $firstYear 130 +#if( $lastYear > $firstYear ) 131 + #set( $year = -1 ) 132 + #set( $yearList = [$lastYear..$firstYear] ) 133 + #set( $oneYear = false ) 134 +#else 135 +## $lastYear = $firstYear 136 + #set( $year = $lastYear ) 137 + #set( $yearList = [$year] ) 138 + #set( $oneYear = true ) 139 +#end 140 +## handle when / end 55 55 ## 56 -## DATA STRUCTURES / START 142 +## $oneUser, $apiceUser, $userString, $userFirstName, $userLastName, $oneCycle, $cycleList, $oneYear, $yearList are properly set 143 +## 144 +## handle inline / start 145 +## 146 +## default: false 147 +#set( $showInline = false ) 148 +## check $inlinePar 149 +#if( $inlinePar != "" && $trueStringList.contains($inlinePar.toLowerCase()) ) 150 + #set( $showInline = true ) 151 +#end 152 +## 153 +## handle inline / end 154 +## 155 +#### HANDLE PARAMETERS / END 156 +## 157 +## query to structures 57 57 #set( $itemMap = {} ) 58 58 #set( $itemNo = 0 ) 59 59 #foreach( $year in $yearList ) 60 - #set( $query = ", BaseObject as obj Thesis #if( $oneCycle ), StringProperty as propCycle #end, DateProperty as propEnddate, StringProperty as propStatus, LargeStringProperty as propSupervisor, LargeStringProperty as propCosupervisor, LargeStringProperty as propContact61 - where obj Thesis.name = doc.fullName and objThesis.className = '${mainSpace}.Class' and objThesis.name <> '${objectPool}.Template' 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'Enddate.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" )161 + #set( $query = ", BaseObject as obj, StringProperty as prop0, DateProperty as prop1, StringProperty as prop2, LargeStringProperty as prop3, LargeStringProperty as prop4, LargeStringProperty as prop5 162 + 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" ) 62 62 ## do query 63 63 #set( $itemFound = $xwiki.searchDocuments($query) ) 64 64 ## set counters ... ... @@ -68,36 +68,12 @@ 68 68 #set( $itemNo = $itemNo + $itemYearNo ) 69 69 #end 70 70 #end 71 -## DATA STRUCTURES / END 72 72 ## 73 -## DISPLAY/ START173 +## output results 74 74 ## page subtitle 75 -<div class="mainheader"> 76 -$itemNo 77 -#if( $itemNo == 1 ) 78 - #if( $oneCycle ) 79 - {{thesisCycle plural="false" uppercase="false"}}$cycle{{/thesisCycle}} 80 - #else 81 - $services.localization.render('thesis').toLowerCase() 82 - #end 83 -#{else} 84 - #if( $oneCycle ) 85 - {{thesisCycle plural="true" uppercase="false"}}$cycle{{/thesisCycle}} 86 - #else 87 - $services.localization.render('theses').toLowerCase() 88 - #end 89 -#{end} 90 -<span class="textsecondary"> / </span> 91 -#if( $oneYear ) 92 - $year 93 -#else 94 - $firstYear–$lastYear 95 -#{end} 96 -#if( $oneUser ) 97 - <span class="textsecondary"> / </span> 98 - $userFirstName $userLastName 99 -#end 100 -</div> 175 +{{id name="top"/}} 176 +>(%%)$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}(%%) 177 + 101 101 ## stop if no thesis is found 102 102 #if( $itemNo == 0 || $itemMap.keySet().size() == 0 ) 103 103 ## redundant double check ... ... @@ -107,57 +107,20 @@ 107 107 ## page index 108 108 #if( $itemMap.keySet().size() > 1 ) 109 109 ## found more than one year 110 -<div class="mainselectbar" id="index"> 111 - #foreach( $year in $itemMap.keySet() ) 112 - #if( !$foreach.first ) 113 -  •  114 - #end 115 - [[$year>>||anchor="$year"]] 116 - #end 117 -</div> 187 +{{id name="index"/}} 188 +(% 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))) 118 118 #end 119 119 ## theses displayed per year 120 120 #foreach( $year in $itemMap.keySet() ) 121 -## year top / start 122 -<div class="mainselectseparator"> 123 - <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")> 124 - $year 125 - </a> 126 -</div> 127 -## year top / end 128 -## 129 -## year display / start 130 -<div style="font-style: normal"><ul> 131 - #foreach( $item in $itemMap[$year] ) 132 -<li>#thesisyear($item)</li> 192 +(% 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']] 193 +#foreach( $item in $itemMap[$year] ) 194 + #if( $showInline ) 195 + #if( $foreach.first ) 196 + #end 197 +* #else(% style="border-style:hidden hidden hidden hidden; font-style:normal" %)|#end{{thesis inline=$showInline linked='title'}}$item{{/thesis}} 133 133 #end 134 -</ul></div> 135 -## year display / end 136 -## 137 -## year bottom / start 138 -<div #if( $foreach.last )id="bottom"#end class="mainselectbottom"> 139 139 #set( $itemYearNo = $itemMap[$year].size() ) 140 - $itemYearNo 141 - #if( $oneCycle ) 142 - #if( $itemYearNo == 1 ) 143 - {{thesisCycle plural="false" uppercase="false"}}$cycle{{/thesisCycle}} 144 - #else 145 - {{thesisCycle plural="true" uppercase="false"}}$cycle{{/thesisCycle}} 146 - #end 147 - #else 148 - #if( $itemYearNo == 1 ) 149 - $services.localization.render('thesis').toLowerCase() 150 - #else 151 - $services.localization.render('theses').toLowerCase() 152 - #end 153 - #end 154 - <span class="textsecondary"> / </span> 155 - $year 156 -  •  157 - #anchorlinks() 158 -</div> 159 -## year bottom / end 200 +(% 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"]] 160 160 #end 161 -## DISPLAY / END 162 -{{/html}} 163 -{{/velocity}}{{pageDisplay sort="objectservice"/}} 202 +{{/velocity}} 203 +{{id name="bottom"/}}