Changes for page Per Status

From version 86.10
edited by Andrea Omicini
on 22/06/2023 12:52
Change comment: There is no comment for this version
To version 90.1
edited by Andrea Omicini
on 22/06/2023 13:01
Change comment: There is no comment for this version

Summary

Details

Page properties
Content
... ... @@ -31,6 +31,7 @@
31 31  ## HANDLE INLINE / END
32 32  ##
33 33  ## HANDLE STATUS / START
34 +#template('apice_publications.vm')
34 34  ## $oneStatus false gets a list of statuses, true just one
35 35  #set( $oneStatus = false )
36 36  #set( $showRejected = false )
... ... @@ -105,7 +105,7 @@
105 105  ## map & counter initialisation
106 106  #set( $itemMap = {} )
107 107  #set( $itemNo = 0 )
108 -## cycle over sorts
109 +## 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,6 +117,7 @@
117 117   #set( $itemNo = $itemNo + $itemStatusNo )
118 118   #end
119 119  #end
121 +$itemStatusNo
120 120  ##
121 121  ## output results
122 122  ## page subtitle
... ... @@ -143,8 +143,8 @@
143 143   <div style="flex-grow: 1">
144 144   </div>
145 145   <div">
146 - <a class="basebutton" style="padding: .5em" href='$doc.getURL("view","bibtex=$showBibtex&inline=#if( $showInline )false#{else}true#end#if( $oneSort )&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>
147 - <a class="basebutton" style="padding: .5em" href='$doc.getURL("view","inline=$showInline&bibtex=#if( $showBibtex )false#{else}true#end#if( $oneSort )&status=${statusList[0]}#end#if( $apiceUser )&user=$userName#elseif( $oneUser )&name=$userFirstName&surname=$userLastName#end")'>#if( $showBibtex )text#{else}bib#end</a>
148 + <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>
149 + <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>
148 148   </div>
149 149  </div>
150 150  ## stop if no pubs are found
... ... @@ -154,19 +154,63 @@
154 154  #end
155 155  ## some pubs found
156 156  ## page index
157 -#if( $pubMap.keySet().size() > 1 )
159 +#if( $itemMap.keySet().size() > 1 )
158 158  ## found more than one status
159 -{{id name="index"/}}
160 -(% 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)))
161 +<div class="mainselectbar" id="index">
162 + #foreach( $status in $itemMap.keySet() )
163 + #if( !$foreach.first )
164 + &ensp;&bull;&ensp;
165 + #end
166 + [[$services.localization.render("${objectSpace}.${objectClass}_status_${status}_short_plural").toLowerCase()>>||anchor="$status"]]
167 + #end
168 +</div>
161 161  #end
162 -## pubs displayed per year
163 -#foreach( $status in $pubMap.keySet() )
164 -(% 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']]
165 - #foreach( $pub in $pubMap[$status] )
166 -(% style="border-style:hidden hidden hidden hidden" %)|{{pub inline='false' linked='title'}}$pub{{/pub}}
170 +##
171 +#template('apice_publication_macros.vm')
172 +##
173 +#foreach( $status in $itemMap.keySet() )
174 +## status top / start
175 +<div class="mainselectseparator">
176 + <a class="mainselectseparatorlink" id="$status" href=$xwiki.getURL($doc,"view","status=$status#if( $apiceUser )&user=$userName#elseif( $oneUser )&name=$userFirstName&surname=$userLastName#end")>
177 + $services.localization.render("${objectSpace}.${objectClass}_status_${status}_plural").toLowerCase()
178 + </a>
179 +</div>
180 +## status top / end
181 +##
182 +## status display / start
183 +<div>
184 + #if( $showInline && !$showBibtex )
185 + <ul>
186 + #foreach( $item in $itemMap[$status] )
187 + <li>#publinked($item)</li>
188 +## <li>#pubperstatus($item)</li>
189 + #end
190 + </ul>
191 + #else
192 + #foreach( $item in $itemMap[$sort] )
193 + #if( $showBibtex)
194 + #if( $showInline )
195 + ((({{{ $xwiki.getDocument($item).getValue('bibtex') }}})))
196 + #else
197 + ((({{code language="bibtex"}}$xwiki.getDocument($item).getValue('bibtex'){{/code}})))
198 + #end
199 + #else
200 + <div style="border-style:hidden hidden hidden hidden; font-size:smaller; line-height: 1.25em; margin-bottom: .5em">
201 + #pubauthed($item)<br/>
202 + #pubtitle($item)<br/>
203 + <span class="textsecondary">(#pubstatus($item))</span> {{pubVenue linked="false"}}$item{{/pubVenue}}
204 + </div>
205 + #end
206 + #end
167 167   #end
168 - #set( $pubStatusNo = $pubMap[$status].size() )
169 -(% 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"]]
208 +</div>
209 +## status display / end
210 +##
211 +## status bottom / start
212 +<div #if( $foreach.last )id="bottom"#end class="mainselectbottom">
213 + #set( $itemStatusNo = $itemMap[$status].size() )
214 +$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"]]
215 +</div>
170 170  ## status bottom / end
171 171  #end
172 172  {{/html}}