Changes for page Per Year
From version 143.1
edited by Andrea Omicini
on 30/06/2023 17:10
on 30/06/2023 17:10
Change comment:
There is no comment for this version
To version 158.1
edited by Andrea Omicini
on 30/06/2023 21:39
on 30/06/2023 21:39
Change comment:
There is no comment for this version
Summary
-
Page properties (1 modified, 0 added, 0 removed)
Details
- Page properties
-
- Content
-
... ... @@ -1,12 +1,9 @@ 1 1 {{velocity}} 2 +{{html wiki="true" clean="false"}} 2 2 #template('apice_boolean.vm') 3 -#### HANDLE PARAMETERS / START4 -#template('apice_ publications.vm')4 +#### SET PARAMETERS / START 5 +#template('apice_theses.vm') 5 5 #template('apice_user_param.vm') 6 -## YEARS / START 7 -#set( $yearPar = $request.year.trim() ) 8 -#set( $firstYearPar = $request.from.trim() ) 9 -#set( $lastYearPar = $request.to.trim() ) 10 10 ## years / personal 11 11 #if( $isUserSpace ) 12 12 #set( $query = ", BaseObject as objPersonalThesis, LargeStringProperty as propUser ... ... @@ -21,50 +21,15 @@ 21 21 #set( $firstYearThesis = $personalThesisDoc.display('firstYear','view') ) 22 22 #end 23 23 #if( $personalThesisDoc.lastYear && $personalThesisDoc.lastYear != "" ) 24 - #set( $lastYearThesis = $.display('lastYear','view') ) 21 + #set( $lastYearThesis = $personalThesisDoc.display('lastYear','view') ) 25 25 #end 26 26 #end 27 27 ## years / parameters takes precedence 28 28 #set( $firstYear = $firstYearThesis ) 29 29 #set( $lastYear = $lastYearThesis ) 30 -#if( $yearPar ) 31 - #set( $yearInt = $numbertool.toNumber($yearPar) ) 32 - #if( $yearInt > 0 ) 33 - #set( $firstYear = $yearInt ) 34 - #set( $lastYear = $yearInt ) 35 - #end 36 -#end 37 -#if( $firstYearPar ) 38 - #set( $yearInt = $numbertool.toNumber($firstYearPar) ) 39 - #if( $yearInt > 0 ) 40 - #set( $firstYear = $yearInt ) 41 - #end 42 -#end 43 -#if( $lastYearPar ) 44 - #set( $yearInt = $numbertool.toNumber($lastYearPar) ) 45 - #if( $yearInt > 0 ) 46 - #set( $lastYear = $yearInt ) 47 - #end 48 -#end 49 -#if( $lastYear < $firstYear ) 50 -## swap 51 - #set( $yearTemp = $lastYear ) 52 - #set( $lastYear = $firstYear ) 53 - #set( $firstYear = $yearTemp ) 54 -#end 55 -## invariant: $lastYear >= $firstYear 56 -#if( $lastYear > $firstYear ) 57 - #set( $year = -1 ) 58 - #set( $yearList = [$lastYear..$firstYear] ) 59 - #set( $oneYear = false ) 60 -#else 61 -## $lastYear = $firstYear 62 - #set( $year = $lastYear ) 63 - #set( $yearList = [$year] ) 64 - #set( $oneYear = true ) 65 -#end 66 -## YEARS / END 67 -#### handle cycle 27 +#template('apice_year_param.vm') 28 +## 29 +## CYCLES / START 68 68 ## $cycleList gets the list of cycles to be shown 69 69 ## $oneCycle true if just one cycle to be shown 70 70 #if( $request.cycle && $request.cycle.trim() != "" ) ... ... @@ -86,14 +86,16 @@ 86 86 #set( $cycle = "" ) 87 87 #end 88 88 ## INVARIANT: $oneCycle and $cycleList are correctly and coherently initialised 89 -## ##HANDLEPARAMETERS / END51 +## CYCLES / END 90 90 ## 91 -## query to structures 53 +#### SET PARAMETERS / END 54 +## 55 +## DATA STRUCTURES / START 92 92 #set( $itemMap = {} ) 93 93 #set( $itemNo = 0 ) 94 94 #foreach( $year in $yearList ) 95 - #set( $query = ", BaseObject as obj, StringProperty as prop 0, DateProperty as prop1, StringProperty as prop2, LargeStringProperty as prop3, LargeStringProperty as prop4, LargeStringProperty as prop596 - 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" ) 97 97 ## do query 98 98 #set( $itemFound = $xwiki.searchDocuments($query) ) 99 99 ## set counters ... ... @@ -103,12 +103,36 @@ 103 103 #set( $itemNo = $itemNo + $itemYearNo ) 104 104 #end 105 105 #end 70 +## DATA STRUCTURES / END 106 106 ## 107 -## outputresults72 +## DISPLAY / START 108 108 ## page subtitle 109 -{{id name="top"/}} 110 ->(%%)$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}(%%) 111 - 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> 112 112 ## stop if no thesis is found 113 113 #if( $itemNo == 0 || $itemMap.keySet().size() == 0 ) 114 114 ## redundant double check ... ... @@ -118,8 +118,14 @@ 118 118 ## page index 119 119 #if( $itemMap.keySet().size() > 1 ) 120 120 ## found more than one year 121 -{{id name="index"/}} 122 -(% 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> 123 123 #end 124 124 ## theses displayed per year 125 125 ## ... ... @@ -126,16 +126,29 @@ 126 126 #template('apice_thesis_macros.vm') 127 127 ## 128 128 #foreach( $year in $itemMap.keySet() ) 129 -(% 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']] 130 -{{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 131 131 <div style="font-style: normal"><ul> 132 132 #foreach( $item in $itemMap[$year] ) 133 133 <li>#thesislinked($item)</li> 134 134 #end 135 135 </ul></div> 136 -{{/html}} 137 +## year display / end 138 +## 139 +## year bottom / start 140 +<div #if( $foreach.last )id="bottom"#end class="mainselectbottom"> 137 137 #set( $itemYearNo = $itemMap[$year].size() ) 138 -(% 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"]] 142 +$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 • #anchorlinks() 143 +</div> 144 +## year bottom / end 139 139 #end 140 -{{/velocity}} 141 -{{id name="bottom"/}} 146 +## DISPLAY / END 147 +{{/html}} 148 +{{/velocity}}{{pageDisplay sort="objectservice"/}}