Changes for page Per Year

From version 1.11
edited by Andrea Omicini
on 16/06/2021 11:08
Change comment: There is no comment for this version
To version 17.3
edited by Andrea Omicini
on 25/10/2021 16:19
Change comment: There is no comment for this version

Summary

Details

Page properties
Title
... ... @@ -1,1 +1,1 @@
1 -SelectPerStatus
1 +Theses per Status
Syntax
... ... @@ -1,1 +1,1 @@
1 -XWiki 1.0
1 +XWiki 2.1
Content
... ... @@ -1,14 +1,32 @@
1 -#includeMacros("Main.MacroSheet")
2 -#includeMacros("Theses.MacroSheet")
3 -#includeMacros("Theses.GlobalVars")
4 -
1 +{{include reference="Theses.Environment"/}}{{include reference="Environment"/}}{{velocity}}
2 +#set( $thesisMenu = true )
5 5  #### get parameters
4 +## hypothesis: $thesisStatus set, default "Completed"
5 +## status parameter
6 +#set( $statusPar = $request.status.trim().toLowerCase() )
7 +#if( $statusPar != '' && $allThesisStatuses.contains($statusPar) )
8 + #set( $selectedStatus = $statusPar )
9 +#else
10 + #set( $selectedStatus = 'all' )
11 +#end
12 +##check velocity variable, takes precedence
13 +#if( $thesisStatus && $thesisStatus != '' && $allThesisStatuses.contains($thesisStatus.trim().toLowerCase()) )
14 + #set( $selectedStatus = $thesisStatus.trim().toLowerCase() )
15 +#end
16 +## set ordering field
17 +#if( $selectedStatus == "available" )
18 + #set( $orderingDateFieldName = "availabilityDate" )
19 +#elseif( $selectedStatus == "ongoing" )
20 + #set( $orderingDateFieldName = "startDate" )
21 +#else
22 + #set( $orderingDateFieldName = "endDate" )
23 +#end
24 +## invariant: $thesisStatus set, $orderingDateFieldName set correspondingly
6 6  ## who
7 -#set( $userNamePar = $context.getRequest().getParameter("user") )
8 -#set( $supervisorNamePar = $context.getRequest().getParameter("supervisor") )
9 -#set( $cosupervisorNamePar = $context.getRequest().getParameter("cosupervisor") )
10 -#set( $contactNamePar = $context.getRequest().getParameter("contact") )
11 -
26 +#set( $userNamePar = $request.user )
27 +#set( $supervisorNamePar = $request.supervisor )
28 +#set( $cosupervisorNamePar = $request.cosupervisor )
29 +#set( $contactNamePar = $request.contact )
12 12  #### set default values
13 13  #set( $userSelected = false )
14 14  #set( $roleSelected = false )
... ... @@ -23,7 +23,7 @@
23 23  #set( $contactName = "" )
24 24  #set( $contactFirstName = "" )
25 25  #set( $contactLastName = "" )
26 -
44 +##
27 27  #### handle who & roles
28 28  ##
29 29  #if ( $userName || $userNamePar ) ## a user is specified for all roles
... ... @@ -74,30 +74,25 @@
74 74   #set( $contactFirstName = $contactdoc.display("first_name") )
75 75   #set( $contactLastName = $contactdoc.display("last_name") )
76 76  #end
77 -
78 -## $userSelected true means one user for all roles
95 +##
96 +## $userSelected true and $roleSelected false means one user for all roles
79 79  ## $userSelected true and $roleSelected true for one user with one specific role
80 80  ## if $userSelected false and $roleSelected true mean at least one role with an assigned user
81 81  ## both false means all theses
82 -#if ($userSelected)
83 -1 #stringEnIt("Theses with ","Tesi con") $userFirstName $userLastName #if($supervisor)#stringEnIt("as a supervisor","come relatore")#end#if($cosupervisor)#stringEnIt("as a co-supervisor","come correlatore")#end#if($contact)#stringEnIt("as a contact","come contatto")#end #stringEnIt("in the #apice() space","nello spazio #apice()")
84 -#elseif ( $roleSelected )
85 -1 #stringEnIt("Theses","Tesi") #if($supervisorLastName != "") #stringEnIt("supervised by","con relatore") $supervisorFirstName $supervisorLastName#if($cosupervisorLastName != "" || $contactLastName != ""), #end#end#if($cosupervisorLastName != "") #stringEnIt("co-supervised by","con correlatore") $cosupervisorFirstName $cosupervisorLastName#if($contactLastName != ""), #end#end #if($contactLastName != "") #stringEnIt("with contact","con contatto") $contactFirstName $contactLastName#end #stringEnIt("in the #apice() space","nello spazio #apice()")
100 +#if( $userSelected )
101 + #if( $roleSelected ) // //
102 +> #FullThesisStatusesString($thesisStatus) / $userFirstName $userLastName / #if( $supervisor ){{stringEngIta eng="Supervisor" ita="Relatore"/}}#end#if( $cosupervisor ){{stringEngIta eng="Co-supervisor" ita="Correlatore"/}}#end#if( $contact ){{stringEngIta eng="Contact" ita="Contatto"/}}#end // //
103 + #else // //
104 +> #FullThesisStatusesString($thesisStatus) / $userFirstName $userLastName // //
105 + #end
86 86  #else
87 - 1 #stringEnIt("Theses","Tesi") #stringEnIt("in the #apice() space","nello spazio #apice()")
107 + #if( $roleSelected ) // //
108 +> #FullThesisStatusesString($thesisStatus)#if( $supervisorLastName != "" ) / $supervisorFirstName $supervisorLastName //({{stringEngIta eng="supervisor" ita="relatore"/}})//#end#if( $cosupervisorLastName != "" ) / $cosupervisorFirstName $cosupervisorLastName //({{stringEngIta eng="co-supervisor" ita="correlatore"/}})//#end#if( $contactLastName != "" ) / $contactFirstName $contactLastName //({{stringEngIta eng="Contact" ita="Contatto"/}})//#end // //
109 + #else // //
110 +## > #FullThesisStatusesString($thesisStatus) // //
111 + #end
88 88  #end
89 -
90 -## hypothesis: $thesisStatus set, default "Completed"
91 -## to do: get from parameter
92 -#if ($thesisStatus == "Available")
93 - #set ($orderingDateFieldName = "availabilityDate")
94 -#elseif ($thesisStatus == "Ongoing")
95 - #set ($orderingDateFieldName = "startDate")
96 -#else
97 - #set ($thesisStatus = "Completed")
98 - #set ($orderingDateFieldName = "endDate")
99 -#end
100 -##
113 +##
101 101  #if ( $cosupervisor )
102 102   #set ( $roleSelectedFieldName = "coSupervisors" )
103 103  #elseif ( $contact )
... ... @@ -105,9 +105,7 @@
105 105  #else
106 106   #set ( $roleSelectedFieldName = "supervisor" )
107 107  #end
108 -
109 -1.1 #ThesisStatusesString($thesisStatus)
110 -
121 +##
111 111  #if ($userSelected)
112 112   #if ( $roleSelected )
113 113   #set ($sql = ", BaseObject as obj, StringProperty as prop, LargeStringProperty as prop1, DateProperty as prop2
... ... @@ -177,9 +177,9 @@
177 177   order by prop1.value desc")
178 178  #end
179 179  #set($thesisFound = $xwiki.searchDocuments($sql))
180 -
191 +##
181 181  #foreach ($thesis in $thesisFound)#set($thesisDoc = $xwiki.getDocument($thesis))
182 -* [$thesisDoc.getValue('title') | $thesis]#if ($thesisDoc.getValue('studentUserName') != "" && $xwiki.exists($thesisDoc.getValue('studentUserName')) )(#thesisStudentUser($thesis))
193 +* #thesisTitleLink($thesis)#if( $thesisDoc.getValue("studentUserName") != "" || $thesisDoc.getValue("studentName") != "" || ( $thesisDoc.getValue("studentFirstName") != "" && $thesisDoc.getValue("studentLastName") != "" ) ) //(#thesisAuthorLink($thesis)#if( $thesisDoc.display("endDate") != "" ), #thesisYear($thesis)#end)//#end
183 183  
184 -#end#end
185 -
195 +#end
196 +{{/velocity}}