Changes for page Per Status
From version 91.1
edited by Andrea Omicini
on 22/06/2023 13:09
on 22/06/2023 13:09
Change comment:
There is no comment for this version
To version 86.1
edited by Andrea Omicini
on 03/01/2023 00:19
on 03/01/2023 00:19
Change comment:
There is no comment for this version
Summary
-
Page properties (2 modified, 0 added, 0 removed)
Details
- Page properties
-
- Title
-
... ... @@ -1,1 +1,0 @@ 1 -$services.localization.render('perstatus') - Content
-
... ... @@ -1,73 +1,29 @@ 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() ) 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 8 8 ## who 9 9 #set( $userNamePar = $request.user.trim() ) 10 10 #set( $firstNamePar = $request.name.trim() ) 11 11 #set( $lastNamePar = $request.surname.trim() ) 12 -## GET PARAMETERS / END 13 -## 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 -#set( $showPublished = false ) 39 -## $statusList gets the list of statuses to be shown 40 -#set( $statusList = $publicationStatuses ) 41 -## 11 +## which status 42 42 #set( $statusPar = $request.status.trim() ) 43 -#if( $statusPar.toLowerCase() == "all" ) 44 -## 'all' value gets all unpublished papers including "Rejected" ones 45 - #set( $showRejected = true ) 46 -#elseif( $statusPar.toLowerCase() == "published" ) 47 - #set( $oneStatus = true ) 48 - #set( $statusList = ["published"] ) 49 - #set( $showPublished = true ) 50 -#elseif( $statusPar.toLowerCase() == "rejected" ) 51 - #set( $oneStatus = true ) 52 - #set( $statusList = ["rejected"] ) 53 - #set( $showRejected = true ) 54 -#elseif( $publicationStatuses.contains($statusPar) ) 55 -## 'status' parameter is an admissible publication status value 56 - #set( $oneStatus = true ) 57 - #set( $statusList = [$statusPar] ) 58 -#end 59 59 ## 60 -## HANDLESTATUS / END61 -# #HANDLEWHO / START62 -# template('apice_macros.vm')63 -#isuser space()64 - #if($isUserSpace)65 - # userspace()66 - ##froma personal page14 +#### 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 20 + #end 67 67 #set( $apiceUser = true ) 68 68 #set( $oneUser = true ) 69 -#elseif( $userNamePar ) 70 -## from the URL, "user=$userNamePar" parameter 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 71 71 #if( $userNamePar.contains('XWiki.') ) 72 72 #set( $userName = "$userNamePar" ) 73 73 #else ... ... @@ -107,120 +107,62 @@ 107 107 #else 108 108 #set( $userString = "%%" ) 109 109 #end 110 -## HANDLE WHO / END 111 111 ## 112 -### querytostructures113 -## map & counterinitialisation114 -#set( $ itemMap={})115 -#set ($itemNo=0)116 -# # cycleoverstatuses117 -# foreach( $statusin$statusList)118 - if( $status!= "published" && $status != "rejected"||$status== "published" &&$showPublished|| $status== "rejected" && $showRejected)119 - set( $query = ", BaseObject as obj, #if( $oneUser ) LargeStringPropertyas propAuthor,LargeStringPropertyaspropEditor, #end StringProperty as propStatus #if(!$hasEdit),StringPropertyaspropAccess #end120 - where obj.name = doc.fullNameand obj.className= '${objectSpace}.${objectClass}'and obj.name <> '${objectPool}.${objectTemplate}'#if( $oneUser ) and propAuthor.id.id = obj.id andpropEditor.id.id = obj.id and propAuthor.name = 'author' and propEditor.name = 'editor' and ( propAuthor.value like '$userString' or ( propAuthor.value= '' and propEditor.valuelike '$userString' ) ) #end and propStatus.id.id= obj.id and propStatus.name = 'status' and propStatus.value = '$status' #if( !$hasEdit ) andpropAccess.id.id = obj.id and propAccess.name = 'access' andpropAccess.value <> 'hidden' #end" )121 - #set( $i temFound = $xwiki.searchDocuments($query) )122 -# # set counters123 - # set( $itemStatusNo = $itemFound.size() )124 - # if($itemStatusNo> 0 )125 - #set( $ itemMap[$status]=$itemFound)126 - #set( $it emNo= $itemNo + $itemStatusNo)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] ) 127 127 #end 128 128 #end 129 129 ## 130 -## output results 131 -## page subtitle 132 -<div style="display: flex"> 133 - <div class="mainheader"> 134 -$itemNo 135 -#if( $oneStatus ) 136 - #if( $itemNo == 1 ) 137 - $services.localization.render("${objectSpace}.${objectClass}_status_${statusList[0]}").toLowerCase() 138 - #else 139 -$services.localization.render("${objectSpace}.${objectClass}_status_${statusList[0]}_plural").toLowerCase() #end 140 -#else 141 - #if( $itemNo == 1 ) 142 - $services.localization.render('yetunpublished_singular').toLowerCase() 143 - #else 144 - $services.localization.render('yetunpublished').toLowerCase() 85 +## query to structures 86 +#set( $pubMap = {} ) 87 +#set( $pubNo = 0 ) 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.id and 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 + #set( $pubFound = $xwiki.searchDocuments($sql) ) 93 + #set( $pubStatusNo = $pubFound.size() ) 94 + #if( $pubStatusNo > 0 ) 95 + #set( $pubMap[$status] = $pubFound ) 96 + #set( $pubNo = $pubNo + $pubStatusNo ) 145 145 #end 146 146 #end 147 -#if( $oneUser ) 148 - <span class="textsecondary"> / </span> 149 - $userFirstName $userLastName 150 -#end 151 - </div> 152 - <div style="flex-grow: 1"> 153 - </div> 154 - <div"> 155 - <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> 156 - <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> 157 - </div> 158 -</div> 99 +## output results 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='false' plural='true'}}$statusPar{{/pubStatus}}#{else}{{pubStatus uppercase='false' plural='true'}}unpublished{{/pubStatus}}#{end}#if( $oneUser ) / $userFirstName $userLastName#{end}(%%) 159 159 ## stop if no pubs are found 160 -#if( $ itemNo == 0 || $itemMap.keySet().size() == 0 )104 +#if( $pubNo == 0 || $pubMap.keySet().size() == 0 ) 161 161 ## redundant double check 162 162 #stop 163 163 #end 164 164 ## some pubs found 165 165 ## page index 166 -#if( $ itemMap.keySet().size() > 1 )110 +#if( $pubMap.keySet().size() > 1 ) 167 167 ## found more than one status 168 -<div class="mainselectbar" id="index"> 169 - #foreach( $status in $itemMap.keySet() ) 170 - #if( !$foreach.first ) 171 -  •  172 - #end 173 - [[$services.localization.render("${objectSpace}.${objectClass}_status_${status}_short_plural").toLowerCase()>>||anchor="$status"]] 174 - #end 175 -</div> 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))) 176 176 #end 177 -## 178 -#template('apice_publication_macros.vm') 179 -## 180 -#foreach( $status in $itemMap.keySet() ) 181 -## status top / start 182 -<div class="mainselectseparator"> 183 - <a class="mainselectseparatorlink" id="$status" href=$xwiki.getURL($doc,"view","status=$status#if( $apiceUser )&user=$userName#elseif( $oneUser )&name=$userFirstName&surname=$userLastName#end")> 184 - $services.localization.render("${objectSpace}.${objectClass}_status_${status}_plural").toLowerCase() 185 - </a> 186 -</div> 187 -## status top / end 188 -## 189 -## status display / start 190 -<div> 191 - #if( $showInline && !$showBibtex ) 192 - <ul> 193 - #foreach( $item in $itemMap[$status] ) 194 - <li>#publinked($item)</li> 195 -## <li>#pubperstatus($item)</li> 196 - #end 197 - </ul> 198 - #else 199 - #foreach( $item in $itemMap[$sort] ) 200 - #if( $showBibtex) 201 - #if( $showInline ) 202 - ((({{{ $xwiki.getDocument($item).getValue('bibtex') }}}))) 203 - #else 204 - ((({{code language="bibtex"}}$xwiki.getDocument($item).getValue('bibtex'){{/code}}))) 205 - #end 206 - #else 207 - <div style="border-style:hidden hidden hidden hidden; font-size:smaller; line-height: 1.25em; margin-bottom: .5em"> 208 - #pubauthed($item)<br/> 209 - #pubtitle($item)<br/> 210 - <span class="textsecondary">(#pubstatus($item))</span> {{pubVenue linked="false"}}$item{{/pubVenue}} 211 - </div> 212 - #end 213 - #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}} 214 214 #end 215 -</div> 216 -## status display / end 217 -## 218 -## status bottom / start 219 -<div #if( $foreach.last )id="bottom"#end class="mainselectbottom"> 220 - #set( $itemStatusNo = $itemMap[$status].size() ) 221 -$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"]] 222 -</div> 223 -## status bottom / end 121 + #set( $pubStatusNo = $pubMap[$status].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"]] 224 224 #end 225 -{{/html}} 226 -{{/velocity}}{{pageDisplay sort="objectservice"/}} 124 +{{/velocity}}