Changes for page Per Year
      From version  161.2 
    
    
              edited by Andrea Omicini
        
on 02/07/2023 13:03
     on 02/07/2023 13:03
      Change comment:
              There is no comment for this version
          
         
      To version  149.1 
    
    
              edited by Andrea Omicini
        
on 30/06/2023 20:37
     on 30/06/2023 20:37
      Change comment:
              There is no comment for this version
          
         Summary
- 
          Page properties (1 modified, 0 added, 0 removed)
Details
- Page properties
- 
      - Content
-   ... ... @@ -1,13 +1,17 @@ 1 1 {{velocity}} 2 2 {{html wiki="true" clean="false"}} 3 3 #template('apice_boolean.vm') 4 -#### SETPARAMETERS / START4 +#### HANDLE PARAMETERS / START 5 5 #template('apice_theses.vm') 6 6 #template('apice_user_param.vm') 7 +## YEARS / START 8 +#set( $yearPar = $request.year.trim() ) 9 +#set( $firstYearPar = $request.from.trim() ) 10 +#set( $lastYearPar = $request.to.trim() ) 7 7 ## years / personal 8 8 #if( $isUserSpace ) 9 9 #set( $query = ", BaseObject as objPersonalThesis, LargeStringProperty as propUser 10 - where objPersonalThesis.name = doc.fullName and objPersonalThesis.className = '${objectSpace}.Personal.Class' and propUser.id.id = objPersonalThesis.id and propUser.name = 'user' and propUser.value = '$userName' " ) 14 + 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 11 #set( $personalThesisDocs = $xwiki.searchDocuments($query) ) 12 12 #if( $personalThesisDocs.size() > 0 ) 13 13 #set( $personalThesisDoc = $xwiki.getDocument($personalThesisDocs[0]) ) ... ... @@ -24,9 +24,44 @@ 24 24 ## years / parameters takes precedence 25 25 #set( $firstYear = $firstYearThesis ) 26 26 #set( $lastYear = $lastYearThesis ) 27 -#template('apice_year_param.vm') 28 -## 29 -## CYCLES / START 31 +#if( $yearPar ) 32 + #set( $yearInt = $numbertool.toNumber($yearPar) ) 33 + #if( $yearInt > 0 ) 34 + #set( $firstYear = $yearInt ) 35 + #set( $lastYear = $yearInt ) 36 + #end 37 +#end 38 +#if( $firstYearPar ) 39 + #set( $yearInt = $numbertool.toNumber($firstYearPar) ) 40 + #if( $yearInt > 0 ) 41 + #set( $firstYear = $yearInt ) 42 + #end 43 +#end 44 +#if( $lastYearPar ) 45 + #set( $yearInt = $numbertool.toNumber($lastYearPar) ) 46 + #if( $yearInt > 0 ) 47 + #set( $lastYear = $yearInt ) 48 + #end 49 +#end 50 +#if( $lastYear < $firstYear ) 51 +## swap 52 + #set( $yearTemp = $lastYear ) 53 + #set( $lastYear = $firstYear ) 54 + #set( $firstYear = $yearTemp ) 55 +#end 56 +## invariant: $lastYear >= $firstYear 57 +#if( $lastYear > $firstYear ) 58 + #set( $year = -1 ) 59 + #set( $yearList = [$lastYear..$firstYear] ) 60 + #set( $oneYear = false ) 61 +#else 62 +## $lastYear = $firstYear 63 + #set( $year = $lastYear ) 64 + #set( $yearList = [$year] ) 65 + #set( $oneYear = true ) 66 +#end 67 +## YEARS / END 68 +#### handle cycle 30 30 ## $cycleList gets the list of cycles to be shown 31 31 ## $oneCycle true if just one cycle to be shown 32 32 #if( $request.cycle && $request.cycle.trim() != "" ) ... ... @@ -48,16 +48,14 @@ 48 48 #set( $cycle = "" ) 49 49 #end 50 50 ## INVARIANT: $oneCycle and $cycleList are correctly and coherently initialised 51 -## CYCLES / END90 +#### HANDLE PARAMETERS / END 52 52 ## 53 -#### SET PARAMETERS / END 54 -## 55 55 ## DATA STRUCTURES / START 56 56 #set( $itemMap = {} ) 57 57 #set( $itemNo = 0 ) 58 58 #foreach( $year in $yearList ) 59 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}.Class' 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 + 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" ) 61 61 ## do query 62 62 #set( $itemFound = $xwiki.searchDocuments($query) ) 63 63 ## set counters ... ... @@ -106,14 +106,8 @@ 106 106 ## page index 107 107 #if( $itemMap.keySet().size() > 1 ) 108 108 ## found more than one year 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> 146 +{{id name="index"/}} 147 +(% 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))) 117 117 #end 118 118 ## theses displayed per year 119 119 ## ... ... @@ -120,46 +120,15 @@ 120 120 #template('apice_thesis_macros.vm') 121 121 ## 122 122 #foreach( $year in $itemMap.keySet() ) 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 154 +(% 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']] 132 132 <div style="font-style: normal"><ul> 133 - 134 -<li>#thesis year($item)</li>135 - 156 +#foreach( $item in $itemMap[$year] ) 157 +<li>#thesislinked($item)</li> 158 +#end 136 136 </ul></div> 137 -## year display / end 138 -## 139 -## year bottom / start 140 -<div #if( $foreach.last )id="bottom"#end class="mainselectbottom"> 141 141 #set( $itemYearNo = $itemMap[$year].size() ) 142 - $itemYearNo 143 - #if( $oneCycle ) 144 - #if( $itemYearNo == 1 ) 145 - {{thesisCycle plural="false" uppercase="false"}}$cycle{{/thesisCycle}} 146 - #else 147 - {{thesisCycle plural="true" uppercase="false"}}$cycle{{/thesisCycle}} 148 - #end 149 - #else 150 - #if( $itemYearNo == 1 ) 151 - $services.localization.render('thesis').toLowerCase() 152 - #else 153 - $services.localization.render('theses').toLowerCase() 154 - #end 155 - #end 156 - <span class="textsecondary"> / </span> 157 - $year 158 -  •  159 - #anchorlinks() 160 -</div> 161 -## year bottom / end 161 +(% 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"]] 162 162 #end 163 -## DISPLAY / END 164 164 {{/html}} 165 -{{/velocity}}{{pageDisplay sort="objectservice"/}} 164 +{{/velocity}} 165 +{{id name="bottom"/}}