Changes for page Per Year

From version 96.3
edited by Andrea Omicini
on 30/10/2021 16:14
Change comment: There is no comment for this version
To version 70.1
edited by Andrea Omicini
on 29/10/2021 15:21
Change comment: There is no comment for this version

Summary

Details

Page properties
Content
... ... @@ -1,48 +1,63 @@
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") )
7 +#set( $fromPar = $mathtool.toInteger("$!$request.from") )
8 +#set( $toPar = $mathtool.toInteger("$!$request.to") )
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 +
38 +STOP
39 +##check velocity variable, takes precedence
40 +#if( $thesisStatus && $thesisStatus != '' && $allThesisStatuses.contains($thesisStatus.trim().toLowerCase()) )
41 + #set( $oneStatus = true )
42 + #set( $selectedStatus = $thesisStatus.trim().toLowerCase() )
43 +#end
44 +## set ordering field
45 +#if( $selectedStatus == "available" )
46 + #set( $orderingDateFieldName = "availabilityDate" )
47 +#elseif( $selectedStatus == "ongoing" )
48 + #set( $orderingDateFieldName = "startDate" )
49 +#else
50 +## default for no selected status, too
51 + #set( $orderingDateFieldName = "endDate" )
52 +#end
53 +## invariant: $oneStatus set, $selectedStatus & $orderingDateFieldName set accordingly
54 +### END STATUS
40 40  ##
41 -### START USER & CYCLE
56 +### START USER & ROLE
42 42  #set( $userNamePar = $request.user.trim() )
43 43  ## default values
44 44  #set( $oneUser = false )
45 -#set( $oneCycle = false )
60 +#set( $oneRole = false )
46 46  #set( $userFirstName = "" )
47 47  #set( $userLastName = "" )
48 48  #if( $userName || $userNamePar )
... ... @@ -62,42 +62,41 @@
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 )
80 + #set( $rolePar = $request.role.trim().toLowerCase() )
81 + #set( $selectedRole = '' )
82 + #if( $rolePar != '' && $allThesisRoles.contains($rolePar) )
83 + #set( $oneRole = true )
84 + #set( $selectedRole = $rolePar )
70 70   #end
71 71  #end
72 -## $oneUser and $oneCycle set properly
73 -$oneUser
74 -$oneCycle
75 -### END USER & CYCLE
87 +## $oneUser and $oneRole set properly, other related variables set accordingly
88 +## $oneRole has meaning only if $oneUser
89 +## if $oneUser, $oneRole false means one user for all roles
90 +## if $oneUser, $oneRole true means one specific role for one user selected
91 +## 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'/}}
94 +>#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)))
96 +#if( !$oneStatus )
97 +(% 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)))
98 +#elseif( $oneUser && !$oneRole )
99 +(% 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 )
92 - #if( !$oneYear || $selectedYear == $year )
93 - #set( $thesisYearNo = 0 )
94 - #if( !$oneYear )
95 -(% style="border-style:solid hidden hidden solid; border-color:$theme.borderColor; text-align:left; font-style:oblique" %)|{{id name='$year'/}}$year
103 +#foreach( $status in $allThesisStatuses )
104 + #if( !$oneStatus || $selectedStatus == $status )
105 + #set( $thesisStatusNo = 0 )
106 + #if( !$oneStatus )
107 +(% style="border-style:solid hidden hidden solid; border-color:$theme.borderColor; text-align:left; font-style:oblique" %)|{{id name='$status'/}}{{thesisStatus plural='true' uppercase='true' short='true'}}$status{{/thesisStatus}}
96 96   #end
97 -## some selected year or year list / now $year
98 - #foreach( $cycle in $allThesisCycles )
99 - #set( $thesisYearCycleNo = 0 )
100 - #if( !$oneCycle || $selectedCycle == $cycle )
109 +## some selected status or all statuses / now $status
110 + #if( $oneUser )
111 +## some user selected
112 + #foreach( $role in $allThesisRoles )
113 + #set( $thesisStatusRoleNo = 0 )
114 + #if( !$oneRole || $selectedRole == $role )
101 101   #if( $role == "contact" )
102 102   #set( $selectedRoleFieldName = "contacts" )
103 103   #elseif( $role == "cosupervisor" )