Changes for page Per A.Y.

From version 45.1
edited by Andrea Omicini
on 08/02/2023 00:11
Change comment: There is no comment for this version
To version 45.24
edited by Andrea Omicini
on 20/07/2023 09:16
Change comment: There is no comment for this version

Summary

Details

Page properties
Title
... ... @@ -1,0 +1,1 @@
1 +$services.localization.render('pera')
Default language
... ... @@ -1,1 +1,0 @@
1 -en
Content
... ... @@ -1,5 +3,3 @@
1 -= {{italiano}}Per A.A.{{/italiano}}{{english}}Per A.Y.{{/english}} =
2 -
3 3  {{include reference="Courses.Environment" excludeFirstHeading="true"/}}{{velocity}}
4 4  #set( $courseMenu = true )
5 5  #set( $currentCourseDoc = "" )
... ... @@ -9,6 +9,10 @@
9 9  #set( $firstYearPar = $context.getRequest().getParameter("from") )
10 10  #set( $lastYearPar = $context.getRequest().getParameter("to") )
11 11  ## who
10 +#set( $oneUser = false )
11 +#set( $oneProfessor = false )
12 +#set( $oneTutor = false )
13 +##
12 12  #set( $userNamePar = $context.getRequest().getParameter("user") )
13 13  #set( $professorNamePar = $context.getRequest().getParameter("professor") )
14 14  #set( $tutorNamePar = $context.getRequest().getParameter("tutor") )
... ... @@ -18,16 +18,18 @@
18 18   #set( $userdoc = $xwiki.getDocument($userName) )
19 19   #set( $userFirstName = $userdoc.display("first_name") )
20 20   #set( $userLastName = $userdoc.display("last_name") )
23 + #set( $oneUser = true )
21 21  #elseif ( $userNamePar )
22 22  ## from the URL, "user=UserName" parameter
23 - #set( $userName = "XWiki.$userNamePar" )
26 + #if( $userNamePar.contains("XWiki.") )
27 + #set( $userName = $userNamePar )
28 + #else
29 + #set( $userName = "XWiki.$userNamePar" )
30 + #end
24 24   #set( $userdoc = $xwiki.getDocument($userName) )
25 25   #set( $userFirstName = $userdoc.display("first_name") )
26 26   #set( $userLastName = $userdoc.display("last_name") )
27 -#else
28 - #set( $userName = "" )
29 - #set( $userFirstName = "" )
30 - #set( $userLastName = "" )
34 + #set( $oneUser = true )
31 31  #end
32 32  #if ( $professorName )
33 33  ## from a personal page, "XWiki.UserName" $professorName form
... ... @@ -34,16 +34,18 @@
34 34   #set( $professordoc = $xwiki.getDocument($professorName) )
35 35   #set( $professorFirstName = $professordoc.display("first_name") )
36 36   #set( $professorLastName = $professordoc.display("last_name") )
41 + #set( $oneProfessor = true )
37 37  #elseif ( $professorNamePar )
38 38  ## from the URL, "professor=UserName" parameter
39 - #set( $professorName = "XWiki.$professorNamePar" )
44 + #if( $professorNamePar.contains("XWiki.") )
45 + #set( $professorName = $professorNamePar )
46 + #else
47 + #set( $professorName = "XWiki.$professorNamePar" )
48 + #end
40 40   #set( $professordoc = $xwiki.getDocument($professorName) )
41 41   #set( $professorFirstName = $professordoc.display("first_name") )
42 42   #set( $professorLastName = $professordoc.display("last_name") )
43 -#else
44 - #set( $professorName = "" )
45 - #set( $professorFirstName = "" )
46 - #set( $professorLastName = "" )
52 + #set( $oneProfessor = true )
47 47  #end
48 48  #if ( $tutorName )
49 49  ## from a personal page, "XWiki.UserName" $tutorName form
... ... @@ -52,19 +52,30 @@
52 52   #set( $tutorLastName = $tutordoc.display("last_name") )
53 53  #elseif ( $tutorNamePar )
54 54  ## from the URL, "tutor=UserName" parameter
55 - #set( $tutorName = "XWiki.$tutorNamePar" )
61 + #if( $tutorNamePar.contains("XWiki.") )
62 + #set( $tutorName = $tutorNamePar )
63 + #else
64 + #set( $tutorName = "XWiki.$tutorNamePar" )
65 + #end
56 56   #set( $tutordoc = $xwiki.getDocument($tutorName) )
57 57   #set( $tutorFirstName = $tutordoc.display("first_name") )
58 58   #set( $tutorLastName = $tutordoc.display("last_name") )
59 -#else
60 - #set( $tutorName = "" )
61 - #set( $tutorFirstName = "" )
62 - #set( $tutorLastName = "" )
69 + #set( $oneTutor = true )
63 63  #end
64 -## professor takes precedence over tutor
65 -#if( $professorName != "" )#set( $tutorName = "" )#end
71 +## who, in the end
72 +#if( $oneUser )
66 66  ## user takes precedence over both professor and tutor and gets them all
67 -#if( $userName != "" )#set( $professorName = $userName )#set( $tutorName = $userName )#end
74 + #set( $oneProfessor = false )
75 + #set( $oneTutor = false )
76 +#elseif( $oneProfessor )
77 +## professor takes precedence over tutor
78 + #set( $oneUser = false )
79 + #set( $oneTutor = false )
80 +#elseif( $oneTutor )
81 +## just tutor
82 + #set( $oneUser = false )
83 + #set( $oneProfessor = false )
84 +#end
68 68  ##
69 69  #if( $firstYearCou )#set( $firstYear = $firstYearCou )#end
70 70  #if( $lastYearCou )#set( $lastYear = $lastYearCou )#end
... ... @@ -117,7 +117,7 @@
117 117  ##
118 118  #foreach( $yearr in $yearList)#set($yearr1 = $yearr + 1)#set($ayearr = $yearr + "/" + $yearr1 )
119 119   #set ($sql = ", BaseObject as obj, StringProperty as prop, LargeStringProperty as prop1, LargeStringProperty as prop2, LargeStringProperty as prop3, StringProperty as prop4
120 - where obj.name = doc.fullName and obj.className = '${objectSpace}.${objectClass}' and obj.name <> '${objectSpace}.${objectTemplate}' and prop.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 prop.name = 'ay' and prop1.name = 'professor' and prop2.name = 'otherProfessors' and prop3.name = 'tutors' and prop4.name = '$sortField' and prop.value = '$ayearr' and ( prop1.value like '%$professorName%' or prop2.value like '%$professorName%' or prop3.value like '%$tutorName%' ) order by prop4.value asc ")
137 + where obj.name = doc.fullName and obj.className = '${objectSpace}.${objectClass}' and obj.name <> '${objectSpace}.${objectTemplate}' and prop.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 prop.name = 'ay' and prop1.name = 'professor' and prop2.name = 'otherProfessors' and prop3.name = 'tutors' and prop4.name = '$sortField' and prop.value = '$ayearr' #if( $oneUser )and ( prop1.value like '%$userName%' or prop2.value like '%$userName%' or prop3.value like '%$userName%' )#end#if( $oneProfessor )and ( prop1.value like '%$professorName%' or prop2.value like '%$professorName%' )#end#if( $oneTutor )and prop3.value like '%$tutorName%'#end order by prop4.value asc ")
121 121   #set( $courseFound = $xwiki.searchDocuments($sql) )
122 122   #set( $courseYearNo = $courseFound.size() )
123 123   #if( $$courseYearNo >0 )
... ... @@ -128,7 +128,8 @@
128 128  ### output results
129 129  ## page subtitle
130 130  {{id name="top"/}}
131 ->(%%)$courseNo #if( $courseNo == 1 ){{stringEngIta eng="$objectEngSingular.toLowerCase()" ita="$objectItaSingular.toLowerCase()"/}}#{else}{{stringEngIta eng="$objectEngPlural.toLowerCase()" ita="$objectItaPlural.toLowerCase()"/}}#{end} / #if( $oneYear )$aYear#else$lastAYear–$firstAYear#end#if( $userName != "" ) / $userFirstName $userLastName#elseif( $professorName != "" ) / $professorFirstName $professorLastName#elseif( $tutorName != "" ) / $tutorFirstName $tutorLastName (tutor)#end
148 +>(%%)$courseNo #if( $courseNo == 1 ){{stringEngIta eng=$objectEngSingular.toLowerCase() ita=$objectItaSingular.toLowerCase()/}}#{else}{{stringEngIta eng=$objectEngPlural.toLowerCase() ita=$objectItaPlural.toLowerCase()/}}#{end} / #if( $oneYear )$year#{else}${firstYear}–${lastYear}#{end}#if( $oneUser ) / $userFirstName $userLastName#{elseif}( $oneProfessor ) / $professorFirstName $professorLastName#{elseif}( $oneTutor ) / $tutorFirstName $tutorLastName (tutor)#{end}(%%)
149 +##
132 132  ## stop if no course are found
133 133  #if( $courseNo == 0 || $courseMap.keySet().size() == 0 )
134 134  ## redundant double check
... ... @@ -143,14 +143,18 @@
143 143  #end
144 144  ## courses displayed per academic year
145 145  #foreach( $yearr in $courseMap.keySet() )#set($yearr1 = $yearr + 1)#set($ayearr = $yearr + "/" + $yearr1 )
146 -(% style="border-style:solid hidden hidden solid; border-color:$theme.borderColor; text-align:left; font-style:oblique" %)|{{id name='$ayearr'/}}[[$ayearr>>$doc||style='text-decoration:none; color:$theme.textPrimaryColor' queryString='year=$yearr#if( $userName != "" )&user=$userName#elseif( $professorName != "" )&professor=$professorName#elseif( $tutorName != "" )&tutor=$tutorName#end']]
164 +(% style="border-style:solid hidden hidden solid; border-color:$theme.borderColor; text-align:left; font-style:oblique" %)|{{id name='$ayearr'/}}[[$ayearr>>$doc||style='text-decoration:none; color:$theme.textPrimaryColor' queryString='year=$yearr#if( $oneUser )&user=$userName#elseif( $oneProfessor )&professor=$professorName#elseif( $oneTutor )&tutor=$tutorName#end']]
147 147  (% style="border-style:hidden hidden hidden hidden; font-style:normal" %)
148 -#foreach( $course in $courseMap[$yearr] )
149 -* {{courseName}}$course{{/courseName}}
166 + #foreach( $course in $courseMap[$yearr] )
167 + #if( $oneUser || $oneProfessor || $oneTutor )
168 +* {{courseName}}$course{{/courseName}} (% style="font-style:normal; font-size:normal; color:$theme.textSecondaryColor" %)({{courseCycle}}$course{{/courseCycle}})(%%)
169 + #else
170 +* {{course linked="title"}}$course{{/course}}
171 + #end
150 150   #end
151 151  (%%)
152 152   #set( $courseYearNo = $courseMap[$yearr].size() )
153 -(% style="border-style:hidden solid solid hidden; border-color:$theme.borderColor; text-align:right; font-style:oblique; font-size:smaller" %)|($courseYearNo #if( $courseYearNo == 1 ){{stringEngIta eng='course in' ita='corso nel'/}}#{else}{{stringEngIta eng='courses in' ita='corsi nel'/}}#end $year) [[[{{stringEngIta eng='top' ita='in cima'/}}]>>||anchor="top"]] [[[{{stringEngIta eng='bottom' ita='in fondo'/}}]>>||anchor="bottom"]]
175 +(% style="border-style:hidden solid solid hidden; border-color:$theme.borderColor; text-align:right; font-style:oblique; font-size:smaller" %)|($courseYearNo #if( $courseYearNo == 1 ){{stringEngIta eng='course in' ita='corso nel'/}}#{else}{{stringEngIta eng='courses in' ita='corsi nel'/}}#end $yearr) [[[{{stringEngIta eng='top' ita='in cima'/}}]>>||anchor="top"]] [[[{{stringEngIta eng='bottom' ita='in fondo'/}}]>>||anchor="bottom"]]
154 154  #end
155 155  {{/velocity}}
156 156  {{id name="bottom"/}}