Changes for page Per Year

From version 96.2
edited by Andrea Omicini
on 30/10/2021 16:11
Change comment: There is no comment for this version
To version 73.1
edited by Andrea Omicini
on 29/10/2021 15:27
Change comment: There is no comment for this version

Summary

Details

Page properties
Content
... ... @@ -1,48 +1,61 @@
1 1  {{include reference="Theses.Environment"/}}{{include reference="Environment"/}}{{velocity}}
2 2  #set( $thesisMenu = true )
3 3  #set( $oneYear = false )
4 -#set( $selectedYear = '' )
5 5  ### START YEAR
6 6  ## year parameter
7 -#set( $yearPar = $mathtool.toInteger($request.year) )
8 -#set( $fromPar = $mathtool.toInteger($request.from) )
9 -#set( $toPar = $mathtool.toInteger($request.to) )
10 -#set( $firstYear = $mathtool.toInteger($firstYearTh) )
11 -#set( $lastYear = $mathtool.toInteger($lastYearTh) )
6 +#set( $yearPar = $mathtool.toInteger($request.year) )$yearPar
7 +#set( $fromPar = $mathtool.toInteger($request.from) )$fromPar
8 +#set( $toPar = $mathtool.toInteger($request.to) )$toPar
9 +#set( $firstYear = $firstYearTh )
10 +#set( $lastYear = $lastYearTh )
12 12  #set( $yearList = [$lastYear..$firstYear] )
13 -#if( $yearPar > 0 )
12 +#if( $yearPar != '' )
14 14   #set( $oneYear = true )
15 - #set( $firstYear = $yearPar )
16 - #set( $lastYear = $yearPar )
17 17   #set( $selectedYear = $yearPar )
18 - #set( $yearList = [$yearPar] )
19 19  #else
20 - #if( $fromPar != '' && ($fromPar > $firstYear) )
16 + #if( $fromPar != '' && $yearList.contains($fromPar) )
21 21   #set( $firstYear = $fromPar )
22 22   #set( $yearList = [$lastYear..$firstYear] )
23 23   #end
24 - #if( $toPar != '' && ($toPar < $lastYear) )
20 + #if( $toPar != '' && $yearList.contains($toPar) )
25 25   #set( $lastYear = $toPar )
26 26   #set( $yearList = [$lastYear..$firstYear] )
27 27   #end
28 28   #if( $lastYear <= $firstYear )
29 29   #set( $oneYear = true )
30 - #set( $lastYear = $firstYear )
31 31   #set( $selectedYear = $firstYear )
32 - #set( $yearList = [$firstYear] )
33 33   #else
34 34   #set( $yearList = [$lastYear..$firstYear] )
35 35   #end
36 36  #end
37 37  $oneYear
32 +$selectedYear
33 +$firstYear
34 +$lastYear
38 38  $yearList
39 -### END YEAR
36 +#stop
37 +##check velocity variable, takes precedence
38 +#if( $thesisStatus && $thesisStatus != '' && $allThesisStatuses.contains($thesisStatus.trim().toLowerCase()) )
39 + #set( $oneStatus = true )
40 + #set( $selectedStatus = $thesisStatus.trim().toLowerCase() )
41 +#end
42 +## set ordering field
43 +#if( $selectedStatus == "available" )
44 + #set( $orderingDateFieldName = "availabilityDate" )
45 +#elseif( $selectedStatus == "ongoing" )
46 + #set( $orderingDateFieldName = "startDate" )
47 +#else
48 +## default for no selected status, too
49 + #set( $orderingDateFieldName = "endDate" )
50 +#end
51 +## invariant: $oneStatus set, $selectedStatus & $orderingDateFieldName set accordingly
52 +### END STATUS
40 40  ##
41 -### START USER & CYCLE
54 +### START USER & ROLE
42 42  #set( $userNamePar = $request.user.trim() )
43 43  ## default values
44 44  #set( $oneUser = false )
45 -#set( $oneCycle = false )
58 +#set( $oneRole = false )
46 46  #set( $userFirstName = "" )
47 47  #set( $userLastName = "" )
48 48  #if( $userName || $userNamePar )
... ... @@ -62,33 +62,30 @@
62 62   #stop
63 63   #end
64 64  ##user selected and existing user page
65 - #set( $cyclePar = $request.cycle.trim().toUpperCase() )
66 - #set( $selectedCycle = '' )
67 - #if( $cyclePar != '' && $allThesisCycles.contains($cyclePar) )
68 - #set( $oneCycle = true )
69 - #set( $selectedCycle = $cyclePar )
78 + #set( $rolePar = $request.role.trim().toLowerCase() )
79 + #set( $selectedRole = '' )
80 + #if( $rolePar != '' && $allThesisRoles.contains($rolePar) )
81 + #set( $oneRole = true )
82 + #set( $selectedRole = $rolePar )
70 70   #end
71 71  #end
72 -## $oneUser and $oneCycle set properly
73 -$oneUser
74 -$oneCycle
75 -### END USER & CYCLE
85 +## $oneUser and $oneRole set properly, other related variables set accordingly
86 +## $oneRole has meaning only if $oneUser
87 +## if $oneUser, $oneRole false means one user for all roles
88 +## if $oneUser, $oneRole true means one specific role for one user selected
89 +## if $oneUser is false, $oneRole means nothing -- so all users, all roles / just status
76 76  ##
77 77  ## title
78 ->#if( $oneRole ){{thesisCycle short='no'}}$selecteCycle{{/thesisCycle}}#else{{stringEngIta eng="Theses" ita="Tesi"/}}#end / #if( $oneYear )$selectedYear#else$firstYear–$lastYear#end#if( $oneUser ) / $userFirstName **$userLastName**#end{{id name='top'/}}
92 +>#if( $oneStatus ){{thesisStatus plural='yes' uppercase='yes'}}$selectedStatus{{/thesisStatus}}#else{{stringEngIta eng="Theses" ita="Tesi"/}}#end#if( $oneUser ) / $userFirstName **$userLastName**#end#if( $oneRole ) / {{thesisRole short='yes'}}$selectedRole{{/thesisRole}}#end{{id name='top'/}}
79 79  ## index
80 -#if( !$oneYear )
81 -(% 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)))
82 -###elseif( $oneUser && !$oneCycle )
83 -#elseif( !$oneCycle )
84 -(% 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)))
94 +#if( !$oneStatus )
95 +(% style="font-size: smaller; padding:1em 1.5em 0.25em 1.5em; background-color:$theme.highlightColor" %)(((#foreach( $status in $allThesisStatuses )#if ($velocityCount > 1) | #end[[{{thesisStatus plural="true" uppercase="false"}}$status{{/thesisStatus}}>>||anchor="$status"]]#end)))
96 +#elseif( $oneUser && !$oneRole )
97 +(% style="font-size: smaller; padding:1em 1.5em 0.25em 1.5em; background-color:$theme.highlightColor" %)(((#foreach( $role in $allThesisRoles )#if ($velocityCount > 1) | #end [[{{thesisRole}}$role{{/thesisRole}}>>||anchor="$role"]]#end)))
85 85  #end{{id name='index'/}}
86 -
87 -#stop
88 -
89 89  ## search theses
90 90  #set( $thesisNo = 0 )
91 -#foreach( $year in $yearList )
101 +#foreach( $status in $allThesisStatuses )
92 92   #if( !$oneStatus || $selectedStatus == $status )
93 93   #set( $thesisStatusNo = 0 )
94 94   #if( !$oneStatus )