Changes for page Per Status
      From version  98.1 
    
    
              edited by Andrea Omicini
        
on 25/06/2023 13:49
     on 25/06/2023 13:49
      Change comment:
              There is no comment for this version
          
         
      To version  86.10 
    
    
              edited by Andrea Omicini
        
on 22/06/2023 12:52
     on 22/06/2023 12:52
      Change comment:
              There is no comment for this version
          
         Summary
- 
          Page properties (1 modified, 0 added, 0 removed)
Details
- Page properties
- 
      - Content
-   ... ... @@ -1,9 +1,18 @@ 1 1 {{velocity}} 2 -{{html clean="false" wiki="true"}} 3 -#template('apice_boolean.vm') 4 -## BIBTEX / START 2 +{{html wiki="true" clean="false"}} 3 +## GET PARAMETERS / START 4 +## inline display 5 +#set( $inlinePar = $request.inline.trim().toLowerCase() ) 5 5 ## show BibTeX 6 6 #set( $bibtexPar = $request.bibtex.trim().toLowerCase() ) 8 +## who 9 +#set( $userNamePar = $request.user.trim() ) 10 +#set( $firstNamePar = $request.name.trim() ) 11 +#set( $lastNamePar = $request.surname.trim() ) 12 +## GET PARAMETERS / END 13 +## 14 +#template('apice_boolean.vm') 15 +## HANDLE BIBTEX / START 7 7 ## default: false 8 8 #set( $showBibtex = false ) 9 9 ## check $bibtexPar ... ... @@ -10,11 +10,9 @@ 10 10 #if( $bibtexPar != "" && $trueStringList.contains($bibtexPar.toLowerCase()) ) 11 11 #set( $showBibtex = true ) 12 12 #end 13 -## BIBTEX / END 22 +## HANDLE BIBTEX / END 14 14 ## 15 -## INLINE / START 16 -## inline display 17 -#set( $inlinePar = $request.inline.trim().toLowerCase() ) 24 +## HANDLE INLINE / START 18 18 ## default: true 19 19 #set( $showInline = true ) 20 20 ## check $inlinePar ... ... @@ -21,15 +21,12 @@ 21 21 #if( $inlinePar != "" && $falseStringList.contains($inlinePar) ) 22 22 #set( $showInline = false ) 23 23 #end 24 -## INLINE / END 25 -#template('apice_publications.vm') 26 -#template('apice_user_param.vm') 31 +## HANDLE INLINE / END 27 27 ## 28 -## STATUS / START 33 +## HANDLE STATUS / START 29 29 ## $oneStatus false gets a list of statuses, true just one 30 30 #set( $oneStatus = false ) 31 31 #set( $showRejected = false ) 32 -#set( $showPublished = false ) 33 33 ## $statusList gets the list of statuses to be shown 34 34 #set( $statusList = $publicationStatuses ) 35 35 ## ... ... @@ -37,42 +37,84 @@ 37 37 #if( $statusPar.toLowerCase() == "all" ) 38 38 ## 'all' value gets all unpublished papers including "Rejected" ones 39 39 #set( $showRejected = true ) 40 -#elseif( $statusPar.toLowerCase() == "published" ) 41 - #set( $oneStatus = true ) 42 - #set( $statusList = ["published"] ) 43 - #set( $showPublished = true ) 44 -#elseif( $statusPar.toLowerCase() == "rejected" ) 45 - #set( $oneStatus = true ) 46 - #set( $statusList = ["rejected"] ) 47 - #set( $showRejected = true ) 48 -#elseif( $publicationStatuses.contains($statusPar) ) 49 -## 'status' parameter is an admissible publication status value 50 - #set( $oneStatus = true ) 51 - #set( $statusList = [$statusPar] ) 44 +#else 45 + #if( $publicationStatuses.contains($statusPar) ) 46 + ## 'status' parameter is an admissible publication status value 47 + #set( $oneStatus = true ) 48 + #set( $statusList = [$statusPar] ) 49 + #end 52 52 #end 53 53 ## 54 -## STATUS / END 52 +## HANDLE STATUS / END 53 +## HANDLE WHO / START 54 +#template('apice_macros.vm') 55 +#isuserspace() 56 +#if( $isUserSpace ) 57 + #userspace() 58 +## from a personal page 59 + #set( $apiceUser = true ) 60 + #set( $oneUser = true ) 61 +#elseif( $userNamePar ) 62 +## from the URL, "user=$userNamePar" parameter 63 + #if( $userNamePar.contains('XWiki.') ) 64 + #set( $userName = "$userNamePar" ) 65 + #else 66 + #set( $userName = "XWiki.$userNamePar" ) 67 + #end 68 + #if( !$xwiki.exists( $userName ) ) 69 + #if( $services.localization.currentLocale == 'it' ) 70 +{{warning}}L'utente “$userNamePar” non esiste{{/warning}} 71 + #else 72 +{{warning}}User “$userNamePar” does not exist{{/warning}} 73 + #end 74 + #stop 75 + #end 76 + #set( $apiceUser = true ) 77 + #set( $oneUser = true) 78 + #set( $userdoc = $xwiki.getDocument($userName) ) 79 + #set( $userFirstName = $userdoc.display("first_name") ) 80 + #set( $userLastName = $userdoc.display("last_name") ) 81 +#elseif( $firstNamePar && $lastNamePar ) 82 +## from the URL, "name=Firstname&surname=Lastname" parameter 83 + #set( $apiceUser = false ) 84 + #set( $oneUser = true ) 85 + #set( $userFirstName = $firstNamePar ) 86 + #set( $userLastName = $lastNamePar ) 87 +#else 88 + #set( $apiceUser = false ) 89 + #set( $oneUser = false ) 90 + #set( $userFirstName = "" ) 91 + #set( $userLastName = "" ) 92 +#end 93 +#if( $oneUser ) 94 + #if( $apiceUser ) 95 + #set( $userString = "%$userName%" ) 96 + #else 97 + #set( $userString = "%$userFirstName $userLastName%" ) 98 + #end 99 +#else 100 + #set( $userString = "%%" ) 101 +#end 102 +## HANDLE WHO / END 55 55 ## 56 -## DATA STRUCTURES / START 104 +### query to structures 105 +## map & counter initialisation 57 57 #set( $itemMap = {} ) 58 58 #set( $itemNo = 0 ) 59 -## cycle over st atuses108 +## cycle over sorts 60 60 #foreach( $status in $statusList ) 61 - #if( $status != "published" && $status != "rejected" || $status == "published" && $showPublished || $status == "rejected" && $showRejected ) 62 - #set( $query = ", BaseObject as obj, #if( $oneUser ) LargeStringProperty as propAuthor, LargeStringProperty as propEditor, #end StringProperty as propStatus #if( !$hasEdit ), StringProperty as propAccess #end 63 - 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" ) 64 - #set( $itemFound = $xwiki.searchDocuments($query) ) 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 + 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" ) 112 + #set( $itemFound = $xwiki.searchDocuments($query) ) 65 65 ## set counters 66 - #set( $itemStatusNo = $itemFound.size() ) 67 - #if( $itemStatusNo > 0 ) 68 - #set( $itemMap[$status] = $itemFound ) 69 - #set( $itemNo = $itemNo + $itemStatusNo ) 70 - #end 114 + #set( $itemStatusNo = $itemFound.size() ) 115 + #if( $itemStatusNo > 0 ) 116 + #set( $itemMap[$status] = $itemFound ) 117 + #set( $itemNo = $itemNo + $itemStatusNo ) 71 71 #end 72 72 #end 73 -## DATA STRUCTURES / END 74 74 ## 75 -## DISPLAY/ START121 +## output results 76 76 ## page subtitle 77 77 <div style="display: flex"> 78 78 <div class="mainheader"> ... ... @@ -79,26 +79,14 @@ 79 79 $itemNo 80 80 #if( $oneStatus ) 81 81 #if( $itemNo == 1 ) 82 - $services.localization.render('work').toLowerCase() 83 - <span class="textsecondary"> / </span> 84 84 $services.localization.render("${objectSpace}.${objectClass}_status_${statusList[0]}").toLowerCase() 85 85 #else 86 - $services.localization.render('works').toLowerCase() 87 - <span class="textsecondary"> / </span> 88 - $services.localization.render("${objectSpace}.${objectClass}_status_${statusList[0]}_plural").toLowerCase() #end 130 +$services.localization.render("${objectSpace}.${objectClass}_status_${statusList[0]}_plural").toLowerCase() #end 89 89 #else 90 90 #if( $itemNo == 1 ) 91 - #if( $showPublished ) 92 - $services.localization.render('work').toLowerCase() 93 - #else 94 - $services.localization.render('yetunpublished_singular').toLowerCase() 95 - #end 133 + $services.localization.render('yetunpublished_singular').toLowerCase() 96 96 #else 97 - #if( $showPublished ) 98 - $services.localization.render('works').toLowerCase() 99 - #else 100 - $services.localization.render('yetunpublished').toLowerCase() 101 - #end 135 + $services.localization.render('yetunpublished').toLowerCase() 102 102 #end 103 103 #end 104 104 #if( $oneUser ) ... ... @@ -108,11 +108,9 @@ 108 108 </div> 109 109 <div style="flex-grow: 1"> 110 110 </div> 111 - <div> 112 - <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> 113 -#if( $showPublished ) 114 - <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> 115 -#end 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> 116 116 </div> 117 117 </div> 118 118 ## stop if no pubs are found ... ... @@ -122,64 +122,20 @@ 122 122 #end 123 123 ## some pubs found 124 124 ## page index 125 -#if( $ itemMap.keySet().size() > 1 )157 +#if( $pubMap.keySet().size() > 1 ) 126 126 ## found more than one status 127 -<div class="mainselectbar" id="index"> 128 - #foreach( $status in $itemMap.keySet() ) 129 - #if( !$foreach.first ) 130 -  •  131 - #end 132 - [[$services.localization.render("${objectSpace}.${objectClass}_status_${status}_short_plural").toLowerCase()>>||anchor="$status"]] 133 - #end 134 -</div> 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))) 135 135 #end 136 -## 137 -#template('apice_publication_macros.vm') 138 -## 139 -#foreach( $status in $itemMap.keySet() ) 140 -## status top / start 141 -<div class="mainselectseparator"> 142 - <a class="mainselectseparatorlink" id="$status" href=$xwiki.getURL($doc,"view","status=$status#if( $apiceUser )&user=$userName#elseif( $oneUser )&name=$userFirstName&surname=$userLastName#end")> 143 - $services.localization.render("${objectSpace}.${objectClass}_status_${status}_plural").toLowerCase() 144 - </a> 145 -</div> 146 -## status top / end 147 -## 148 -## status display / start 149 -<div> 150 - #if( $showInline && !$showBibtex ) 151 - <ul> 152 - #foreach( $item in $itemMap[$status] ) 153 - <li>#pubperstatus($item)</li> 154 - #end 155 - </ul> 156 - #else 157 - #foreach( $item in $itemMap[$status] ) 158 - #if( $showBibtex) 159 - #if( $showInline ) 160 - ((({{{ $xwiki.getDocument($item).getValue('bibtex') }}}))) 161 - #else 162 - ((({{code language="bibtex"}}$xwiki.getDocument($item).getValue('bibtex'){{/code}}))) 163 - #end 164 - #else 165 - <div style="border-style:hidden hidden hidden hidden; font-size:smaller; line-height: 1.25em; margin-bottom: .5em"> 166 - #pubauthed($item)<br/> 167 - #pubtitle($item)<br/> 168 - <span class="textsecondary">(#pubsort($item))</span> {{pubVenue linked="false"}}$item{{/pubVenue}} 169 - </div> 170 - #end 171 - #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}} 172 172 #end 173 -</div> 174 -## status display / end 175 -## 176 -## status bottom / start 177 -<div #if( $foreach.last )id="bottom"#end class="mainselectbottom"> 178 - #set( $itemStatusNo = $itemMap[$status].size() ) 179 -$itemStatusNo #if( $itemStatusNo == 1 )$services.localization.render("${objectSpace}.${objectClass}_status_${status}").toLowerCase()#{else}$services.localization.render("${objectSpace}.${objectClass}_status_${status}_plural").toLowerCase()#end • #anchorlinks() 180 -</div> 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"]] 181 181 ## status bottom / end 182 182 #end 183 -## DISPLAY / END 184 184 {{/html}} 185 185 {{/velocity}}{{pageDisplay sort="objectservice"/}}