Changes for page Per Status

From version 86.8
edited by Andrea Omicini
on 22/06/2023 12:42
Change comment: There is no comment for this version
To version 89.1
edited by Andrea Omicini
on 22/06/2023 13:00
Change comment: There is no comment for this version

Summary

Details

Page properties
Content
... ... @@ -105,7 +105,7 @@
105 105  ## map & counter initialisation
106 106  #set( $itemMap = {} )
107 107  #set( $itemNo = 0 )
108 -## cycle over sorts
108 +## cycle over statuses
109 109  #foreach( $status in $statusList )
110 110   #set( $query = ", BaseObject as obj, #if( $oneUser ) LargeStringProperty as propAuthor, LargeStringProperty as propEditor, #end StringProperty as propStatus #if( !$hasEdit ), StringProperty as propAccess #end
111 111   where obj.name = doc.fullName and obj.className = '${objectSpace}.${objectClass}' and obj.name <> '${objectPool}.${objectTemplate}' #if( $oneUser ) and propAuthor.id.id = obj.id and propEditor.id.id = obj.id and propAuthor.name = 'author' and propEditor.name = 'editor' and ( propAuthor.value like '$userString' or ( propAuthor.value = '' and propEditor.value like '$userString' ) ) #end and propStatus.id.id = obj.id and propStatus.name = 'status' and propStatus.value = '$status' #if( !$hasEdit ) and propAccess.id.id = obj.id and propAccess.name = 'access' and propAccess.value <> 'hidden' #end" )
... ... @@ -117,31 +117,101 @@
117 117   #set( $itemNo = $itemNo + $itemStatusNo )
118 118   #end
119 119  #end
120 +$itemStatusNo
120 120  ##
121 121  ## output results
122 122  ## page subtitle
123 -{{id name="top"/}}
124 ->(%%)$pubNo #if( $pubNo == 1 ){{stringEngIta eng="$objectEngSingular.toLowerCase()" ita="$objectItaSingular.toLowerCase()"/}}#{else}{{stringEngIta eng="$objectEngPlural.toLowerCase()" ita="$objectItaPlural.toLowerCase()"/}}#{end} / #if( $oneStatus ){{pubStatus uppercase='false' plural='true'}}$statusPar{{/pubStatus}}#{else}{{pubStatus uppercase='false' plural='true'}}unpublished{{/pubStatus}}#{end}#if( $oneUser ) / $userFirstName $userLastName#{end}(%%)
124 +<div style="display: flex">
125 + <div class="mainheader">
126 +$itemNo
127 +#if( $oneStatus )
128 + #if( $itemNo == 1 )
129 + $services.localization.render("${objectSpace}.${objectClass}_status_${statusList[0]}").toLowerCase()
130 + #else
131 +$services.localization.render("${objectSpace}.${objectClass}_status_${statusList[0]}_plural").toLowerCase() #end
132 +#else
133 + #if( $itemNo == 1 )
134 + $services.localization.render('yetunpublished_singular').toLowerCase()
135 + #else
136 + $services.localization.render('yetunpublished').toLowerCase()
137 + #end
138 +#end
139 +#if( $oneUser )
140 + <span class="textsecondary">&ensp;/&ensp;</span>
141 + $userFirstName $userLastName
142 +#end
143 + </div>
144 + <div style="flex-grow: 1">
145 + </div>
146 + <div">
147 + <a class="basebutton" style="padding: .5em" href='$doc.getURL("view","bibtex=$showBibtex&inline=#if( $showInline )false#{else}true#end#if( $oneStatus )&status=${statusList[0]}#end#if( $apiceUser )&user=$userName#elseif( $oneUser )&name=$userFirstName&surname=$userLastName#end")'>#if( $showBibtex )#if( $showInline )formatted#{else}plain#end#else#if( $showInline )long#{else}short#end#end</a>
148 + <a class="basebutton" style="padding: .5em" href='$doc.getURL("view","inline=$showInline&bibtex=#if( $showBibtex )false#{else}true#end#if( $oneStatus )&status=${statusList[0]}#end#if( $apiceUser )&user=$userName#elseif( $oneUser )&name=$userFirstName&surname=$userLastName#end")'>#if( $showBibtex )text#{else}bib#end</a>
149 + </div>
150 +</div>
125 125  ## stop if no pubs are found
126 -#if( $pubNo == 0 || $pubMap.keySet().size() == 0 )
152 +#if( $itemNo == 0 || $itemMap.keySet().size() == 0 )
127 127  ## redundant double check
128 128   #stop
129 129  #end
130 130  ## some pubs found
131 131  ## page index
132 -#if( $pubMap.keySet().size() > 1 )
158 +#if( $itemMap.keySet().size() > 1 )
133 133  ## found more than one status
134 -{{id name="index"/}}
135 -(% style="font-size:smaller; text-align:right; padding:1em 1.5em 0.25em 1.5em; background-color:$theme.highlightColor" %)(((#foreach( $status in $pubMap.keySet() )#if( !$foreach.first ) | #end[[{{pubStatus uppercase='false' plural='true'}}$status{{/pubStatus}}>>||anchor="$status"]]#end)))
160 +<div class="mainselectbar" id="index">
161 + #foreach( $status in $itemMap.keySet() )
162 + #if( !$foreach.first )
163 + &ensp;&bull;&ensp;
164 + #end
165 + [[$services.localization.render("${objectSpace}.${objectClass}_status_${status}_short_plural").toLowerCase()>>||anchor="$status"]]
166 + #end
167 +</div>
136 136  #end
137 -## pubs displayed per year
138 -#foreach( $status in $pubMap.keySet() )
139 -(% style="border-style:solid hidden hidden solid; border-color:$theme.borderColor; text-align:left; font-style:oblique" %)|{{id name='$status'/}}[[{{pubStatus uppercase='false' plural='true'}}$status{{/pubStatus}}>>$doc.name||queryString='status=$status#if( $oneUser )#if( $apiceUser )&user=$userName#{else}&name=$userFirstName&surname=$userLastName#end#end']]
140 - #foreach( $pub in $pubMap[$status] )
141 -(% style="border-style:hidden hidden hidden hidden" %)|{{pub inline='false' linked='title'}}$pub{{/pub}}
169 +##
170 +#template('apice_publication_macros.vm')
171 +##
172 +#foreach( $status in $itemMap.keySet() )
173 +## status top / start
174 +<div class="mainselectseparator">
175 + <a class="mainselectseparatorlink" id="$status" href=$xwiki.getURL($doc,"view","status=$status#if( $apiceUser )&user=$userName#elseif( $oneUser )&name=$userFirstName&surname=$userLastName#end")>
176 + $services.localization.render("${objectSpace}.${objectClass}_status_${status}_plural").toLowerCase()
177 + </a>
178 +</div>
179 +## status top / end
180 +##
181 +## status display / start
182 +<div>
183 + #if( $showInline && !$showBibtex )
184 + <ul>
185 + #foreach( $item in $itemMap[$status] )
186 + <li>#publinked($item)</li>
187 +## <li>#pubperstatus($item)</li>
188 + #end
189 + </ul>
190 + #else
191 + #foreach( $item in $itemMap[$sort] )
192 + #if( $showBibtex)
193 + #if( $showInline )
194 + ((({{{ $xwiki.getDocument($item).getValue('bibtex') }}})))
195 + #else
196 + ((({{code language="bibtex"}}$xwiki.getDocument($item).getValue('bibtex'){{/code}})))
197 + #end
198 + #else
199 + <div style="border-style:hidden hidden hidden hidden; font-size:smaller; line-height: 1.25em; margin-bottom: .5em">
200 + #pubauthed($item)<br/>
201 + #pubtitle($item)<br/>
202 + <span class="textsecondary">(#pubstatus($item))</span> {{pubVenue linked="false"}}$item{{/pubVenue}}
203 + </div>
204 + #end
205 + #end
142 142   #end
143 - #set( $pubStatusNo = $pubMap[$status].size() )
144 -(% style="border-style:hidden solid solid hidden; border-color:$theme.borderColor; text-align:right; font-style:oblique; font-size:smaller" %)|($pubStatusNo #if( $pubStatusNo == 1 ){{stringEngIta eng='publication' ita='pubblicazione'/}} {{pubStatus uppercase='false' plural='false'}}$status{{/pubStatus}}#{else}{{stringEngIta eng='publications' ita='pubblicazioni'/}} {{pubStatus uppercase='false' plural='true'}}$status{{/pubStatus}}#end) [[[{{stringEngIta eng='top' ita='in cima'/}}]>>||anchor="top"]] [[[{{stringEngIta eng='bottom' ita='in fondo'/}}]>>||anchor="bottom"]]
207 +</div>
208 +## status display / end
209 +##
210 +## status bottom / start
211 +<div #if( $foreach.last )id="bottom"#end class="mainselectbottom">
212 + #set( $itemStatusNo = $itemMap[$status].size() )
213 +$itemStatusNo #if( $itemStatusNo == 1 )$services.localization.render("${objectSpace}.${objectClass}_status_${status}").toLowerCase()#{else}$services.localization.render("${objectSpace}.${objectClass}_status_${status}_plural").toLowerCase()#end &bull; [[{{stringEngIta eng='top' ita='in cima'/}}>>||anchor="top"]] &bull; [[{{stringEngIta eng='index' ita='indice'/}}>>||anchor="index"]] &bull; [[{{stringEngIta eng='bottom' ita='in fondo'/}}>>||anchor="bottom"]]
214 +</div>
145 145  ## status bottom / end
146 146  #end
147 147  {{/html}}