Changes for page Per Status
From version 84.1
edited by Andrea Omicini
on 03/01/2023 00:18
on 03/01/2023 00:18
Change comment:
There is no comment for this version
To version 90.1
edited by Andrea Omicini
on 22/06/2023 13:01
on 22/06/2023 13:01
Change comment:
There is no comment for this version
Summary
-
Page properties (2 modified, 0 added, 0 removed)
Details
- Page properties
-
- Title
-
... ... @@ -1,0 +1,1 @@ 1 +$services.localization.render('perstatus') - Content
-
... ... @@ -1,29 +1,66 @@ 1 -= {{italiano}}Per stato{{/italiano}}{{english}}Per Status{{/english}} = 2 - 3 -{{include reference="Publications.Environment" excludeFirstHeading="true"/}}{{velocity}} 4 -## a Publications page 5 -#set( $publicationMenu = true ) 6 -#### get parameters 1 +{{velocity}} 2 +{{html wiki="true" clean="false"}} 3 +## GET PARAMETERS / START 4 +## inline display 5 +#set( $inlinePar = $request.inline.trim().toLowerCase() ) 6 +## show BibTeX 7 +#set( $bibtexPar = $request.bibtex.trim().toLowerCase() ) 7 7 ## who 8 8 #set( $userNamePar = $request.user.trim() ) 9 9 #set( $firstNamePar = $request.name.trim() ) 10 10 #set( $lastNamePar = $request.surname.trim() ) 11 -## which status 12 -#set( $statusPar = $request.status.trim() ) 12 +## GET PARAMETERS / END 13 13 ## 14 -#### handle who 15 -#if( $userName ) 16 -## from a personal page, "XWiki.$userName" $userName form 17 - #if( !$xwiki.exists( $userName ) ) 18 -{{warning}}User $userName does not exist{{/warning}} 19 - #stop 14 +#template('apice_boolean.vm') 15 +## HANDLE BIBTEX / START 16 +## default: false 17 +#set( $showBibtex = false ) 18 +## check $bibtexPar 19 +#if( $bibtexPar != "" && $trueStringList.contains($bibtexPar.toLowerCase()) ) 20 + #set( $showBibtex = true ) 21 +#end 22 +## HANDLE BIBTEX / END 23 +## 24 +## HANDLE INLINE / START 25 +## default: true 26 +#set( $showInline = true ) 27 +## check $inlinePar 28 +#if( $inlinePar != "" && $falseStringList.contains($inlinePar) ) 29 + #set( $showInline = false ) 30 +#end 31 +## HANDLE INLINE / END 32 +## 33 +## HANDLE STATUS / START 34 +#template('apice_publications.vm') 35 +## $oneStatus false gets a list of statuses, true just one 36 +#set( $oneStatus = false ) 37 +#set( $showRejected = false ) 38 +## $statusList gets the list of statuses to be shown 39 +#set( $statusList = $publicationStatuses ) 40 +## 41 +#set( $statusPar = $request.status.trim() ) 42 +#if( $statusPar.toLowerCase() == "all" ) 43 +## 'all' value gets all unpublished papers including "Rejected" ones 44 + #set( $showRejected = true ) 45 +#else 46 + #if( $publicationStatuses.contains($statusPar) ) 47 + ## 'status' parameter is an admissible publication status value 48 + #set( $oneStatus = true ) 49 + #set( $statusList = [$statusPar] ) 20 20 #end 51 +#end 52 +## 53 +## HANDLE STATUS / END 54 +## HANDLE WHO / START 55 +#template('apice_macros.vm') 56 +#isuserspace() 57 +#if( $isUserSpace ) 58 + #userspace() 59 +## from a personal page 21 21 #set( $apiceUser = true ) 22 22 #set( $oneUser = true ) 23 - #set( $userdoc = $xwiki.getDocument($userName) ) 24 - #set( $userFirstName = $userdoc.display("first_name") ) 25 - #set( $userLastName = $userdoc.display("last_name") ) 26 -#elseif( $userNamePar ) ## from the URL, "user=$userNamePar" parameter 62 +#elseif( $userNamePar ) 63 +## from the URL, "user=$userNamePar" parameter 27 27 #if( $userNamePar.contains('XWiki.') ) 28 28 #set( $userName = "$userNamePar" ) 29 29 #else ... ... @@ -63,62 +63,120 @@ 63 63 #else 64 64 #set( $userString = "%%" ) 65 65 #end 103 +## HANDLE WHO / END 66 66 ## 67 -#### handle status 68 -## $oneStatus false gets a list of statuses, true just one 69 -#set( $oneStatus = false ) 70 -## $statusList gets the list of statuses to be shown 71 -#set( $statusList = [] ) 72 -## default: all unpublished papers except Rejected ones 73 -#set( $discard = $statusList.addAll($unpublishedStatuses) ) 74 -#if( $statusPar.toLowerCase() == "all" ) 75 -## 'all' value gets all unpublished papers including "Rejected" ones 76 - #set( $discard = $statusList.add("rejected") ) 77 -#else 78 - #if( $allStatusesPlus.contains($statusPar) ) 79 - ## 'status' parameter is an admissible publication status value 80 - #set( $oneStatus = true ) 81 - #set( $statusList = [$statusPar] ) 82 - #end 83 -#end 84 -## 85 -## query to structures 86 -#set( $pubMap = {} ) 87 -#set( $pubNo = 0 ) 105 +### query to structures 106 +## map & counter initialisation 107 +#set( $itemMap = {} ) 108 +#set( $itemNo = 0 ) 109 +## cycle over statuses 88 88 #foreach( $status in $statusList ) 89 - #set( $ from= ", BaseObject as obj, LargeStringProperty as prop0, LargeStringProperty as prop1, StringProperty as prop2")90 - #set( $where= "obj.name = doc.fullName and obj.className = '${objectSpace}.${objectClass}' and obj.name <> '${objectSpace}.${objectTemplate}'and prop0.id.id=obj.idand prop1.id.id = obj.id and prop2.id.id = obj.id and prop0.name = 'author' and prop1.name = 'editor' and ( prop0.value like '$userString' or ( prop0.value = '' and prop1.value like '$userString' ) ) and prop2.name = 'status' and prop2.value = '$status'" )91 - #set( $ sql= $from+ " where " +$where)92 - ($pubFound = $xwiki.searchDocuments($sql) )93 - #set( $ pubStatusNo = $pubFound.size() )94 - #if( $ pubStatusNo > 0 )95 - #set( $ pubMap[$status] = $pubFound )96 - #set( $ pubNo = $pubNo + $pubStatusNo )111 + #set( $query = ", BaseObject as obj, #if( $oneUser ) LargeStringProperty as propAuthor, LargeStringProperty as propEditor, #end StringProperty as propStatus #if( !$hasEdit ), StringProperty as propAccess #end 112 + 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" ) 113 + #set( $itemFound = $xwiki.searchDocuments($query) ) 114 +## set counters 115 + #set( $itemStatusNo = $itemFound.size() ) 116 + #if( $itemStatusNo > 0 ) 117 + #set( $itemMap[$status] = $itemFound ) 118 + #set( $itemNo = $itemNo + $itemStatusNo ) 97 97 #end 98 98 #end 121 +$itemStatusNo 122 +## 99 99 ## output results 100 100 ## page subtitle 101 -{{id name="top"/}} 102 ->(%%)$pubNo #if( $pubNo == 1 ){{stringEngIta eng="$objectEngSingular.toLowerCase()" ita="$objectItaSingular.toLowerCase()"/}}#{else}{{stringEngIta eng="$objectEngPlural.toLowerCase()" ita="$objectItaPlural.toLowerCase()"/}}#{end} / #if( $oneStatus ){{pubStatus uppercase='true' plural='true'}}$statusPar{{/pubStatus}}#{else}{{pubStatus uppercase='true' plural='true'}}unpublished{{/pubStatus}}#{end}#if( $oneUser ) / $userFirstName $userLastName#{end}(%%) 125 +<div style="display: flex"> 126 + <div class="mainheader"> 127 +$itemNo 128 +#if( $oneStatus ) 129 + #if( $itemNo == 1 ) 130 + $services.localization.render("${objectSpace}.${objectClass}_status_${statusList[0]}").toLowerCase() 131 + #else 132 +$services.localization.render("${objectSpace}.${objectClass}_status_${statusList[0]}_plural").toLowerCase() #end 133 +#else 134 + #if( $itemNo == 1 ) 135 + $services.localization.render('yetunpublished_singular').toLowerCase() 136 + #else 137 + $services.localization.render('yetunpublished').toLowerCase() 138 + #end 139 +#end 140 +#if( $oneUser ) 141 + <span class="textsecondary"> / </span> 142 + $userFirstName $userLastName 143 +#end 144 + </div> 145 + <div style="flex-grow: 1"> 146 + </div> 147 + <div"> 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> 150 + </div> 151 +</div> 103 103 ## stop if no pubs are found 104 -#if( $ pubNo == 0 || $pubMap.keySet().size() == 0 )153 +#if( $itemNo == 0 || $itemMap.keySet().size() == 0 ) 105 105 ## redundant double check 106 106 #stop 107 107 #end 108 108 ## some pubs found 109 109 ## page index 110 -#if( $ pubMap.keySet().size() > 1 )159 +#if( $itemMap.keySet().size() > 1 ) 111 111 ## found more than one status 112 -{{id name="index"/}} 113 -(% 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 +  •  165 + #end 166 + [[$services.localization.render("${objectSpace}.${objectClass}_status_${status}_short_plural").toLowerCase()>>||anchor="$status"]] 167 + #end 168 +</div> 114 114 #end 115 -## pubs displayed per year 116 -#foreach( $status in $pubMap.keySet() ) 117 -(% 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']] 118 - #foreach( $pub in $pubMap[$status] ) 119 -(% 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 120 120 #end 121 - #set( $pubStatusNo = $pubMap[$year].size() ) 122 -(% 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 • [[{{stringEngIta eng='top' ita='in cima'/}}>>||anchor="top"]] • [[{{stringEngIta eng='index' ita='indice'/}}>>||anchor="index"]] • [[{{stringEngIta eng='bottom' ita='in fondo'/}}>>||anchor="bottom"]] 215 +</div> 216 +## status bottom / end 123 123 #end 124 -{{/velocity}} 218 +{{/html}} 219 +{{/velocity}}{{pageDisplay sort="objectservice"/}}