Modifications pour le document RatingWidget
Modifié par Pascale STEIMETZ-LE CACHEUX le 2026/03/27 17:23
Depuis la version 3.1
modifié par Pascale STEIMETZ-LE CACHEUX
sur 2026/03/24 12:46
sur 2026/03/24 12:46
Commentaire de modification :
Il n'y a aucun commentaire pour cette version
À la version 15.1
modifié par Pascale STEIMETZ-LE CACHEUX
sur 2026/03/27 17:23
sur 2026/03/27 17:23
Commentaire de modification :
Il n'y a aucun commentaire pour cette version
Résumé
-
Propriétés de la Page (1 modifications, 0 ajouts, 0 suppressions)
-
Objets (0 modifications, 3 ajouts, 0 suppressions)
Détails
- Propriétés de la Page
-
- Contenu
-
... ... @@ -1,3 +1,36 @@ 1 +{{velocity}} 2 +#set($currentDoc = $xcontext.doc.fullName) 3 + 4 +#set($storeDoc = $xwiki.getDocument("Flora.RatingStore3")) 5 +#set($objects = $storeDoc.getObjects("Flora.RatingVoteClass3")) 6 + 7 +#set($total = 0) 8 +#set($count = 0) 9 + 10 +#foreach($obj in $objects) 11 + #if($obj && $obj.getValue("document") && $obj.getValue("document").toString() == $currentDoc) 12 + #set($note = $obj.getValue("note")) 13 + #if($note) 14 + #set($total = $total + $note) 15 + #set($count = $count + 1) 16 + #end 17 + #end 18 +#end 19 + 20 +#if($count > 0) 21 + #set($avg = $total / $count) 22 +#else 23 + #set($avg = 0) 24 +#end 25 + 26 +#set($stars = "") 27 +#foreach($i in [1..5]) 28 + #if($i <= $avg.round()) 29 + #set($stars = "${stars}★") 30 + #else 31 + #set($stars = "${stars}☆") 32 + #end 33 +#end 1 1 {{html clean="false"}} 2 2 <style> 3 3 .flora-rating-wrap { ... ... @@ -10,22 +10,41 @@ 10 10 flex-wrap: wrap; 11 11 font-size: 14px; 12 12 } 13 - 14 14 .flora-rating-label { 15 15 font-weight: 600; 16 16 color: #2A2B69; 17 17 } 18 - 50 +.flora-stars { 51 + display: inline-flex; 52 + gap: 4px; 53 +} 19 19 .flora-stars button { 20 20 background: none; 21 21 border: none; 22 - font-size: 2 2px;57 + font-size: 24px; 23 23 cursor: pointer; 24 - color: #d4af37; 59 + color: #ffffff; 60 + padding: 0; 61 + margin: 0; 62 + line-height: 1; 63 + text-shadow: 64 + -1px 0 #5b63c3, 65 + 0 1px #5b63c3, 66 + 1px 0 #5b63c3, 67 + 0 -1px #5b63c3; 68 + transition: color 0.15s ease, transform 0.15s ease; 25 25 } 26 26 27 -.flora-stars button:hover { 71 +.flora-stars button:hover, 72 +.flora-stars button.hovered, 73 +.flora-stars button.selected { 28 28 color: #f2c94c; 75 + text-shadow: 76 + -1px 0 #5b63c3, 77 + 0 1px #5b63c3, 78 + 1px 0 #5b63c3, 79 + 0 -1px #5b63c3; 80 + transform: scale(1.08); 29 29 } 30 30 31 31 .flora-rating-result { ... ... @@ -32,54 +32,19 @@ 32 32 color: #2F2F2F; 33 33 } 34 34 </style> 35 -{{/html}} 36 36 37 -{{velocity}} 38 -#set($currentDoc = $doc.fullName) 39 -{{/velocity}} 88 +<div class="flora-rating-wrap" data-doc="$escapetool.xml($currentDoc)"> 89 + <span class="flora-rating-label">Votre avis compte pour nous, que pensez-vous de cet article ?</span> 40 40 41 -{{groovy}} 42 -def store = xwiki.getDocument("Flora.RatingStore3") 43 -def objects = store.getObjects("Flora.RatingVoteClass3") 91 + <div class="flora-stars"> 92 + <button class="flora-star" data-note="1" type="button">★</button> 93 + <button class="flora-star" data-note="2" type="button">★</button> 94 + <button class="flora-star" data-note="3" type="button">★</button> 95 + <button class="flora-star" data-note="4" type="button">★</button> 96 + <button class="flora-star" data-note="5" type="button">★</button> 97 + </div> 44 44 45 -def total = 0 46 -def count = 0 47 - 48 -if (objects != null) { 49 - for (o in objects) { 50 - if (o != null) { 51 - def docValue = o.getValue("document") 52 - def noteValue = o.getValue("note") 53 - 54 - if (docValue != null && docValue.toString() == "$currentDoc" && noteValue != null) { 55 - total += Integer.parseInt(noteValue.toString()) 56 - count += 1 57 - } 58 - } 59 - } 60 -} 61 - 62 -def avg = count > 0 ? total / count : 0 63 - 64 -print('<div class="flora-rating-wrap" data-doc="' + "$currentDoc" + '">') 65 -print('<span class="flora-rating-label">Noter cette page</span>') 66 - 67 -print('<div class="flora-stars">') 68 -for (int i = 1; i <= 5; i++) { 69 - print('<button class="flora-star" data-note="' + i + '">★</button>') 70 -} 71 -print('</div>') 72 - 73 -print('<span class="flora-rating-result">') 74 - 75 -for (int i = 1; i <= 5; i++) { 76 - if (i <= Math.round(avg)) { 77 - print('★') 78 - } else { 79 - print('☆') 80 - } 81 -} 82 - 83 -print(' (' + count + ' votes)</span>') 84 -print('</div>') 85 -{{/groovy}} 99 + <span class="flora-rating-result">$stars ($count votes)</span> 100 +</div> 101 +{{/html}} 102 +{{/velocity}}
- XWiki.XWikiRights[0]
-
- Autoriser / Interdire
-
... ... @@ -1,0 +1,1 @@ 1 +Autoriser - Groupes
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.XWikiAllGroup - Niveaux
-
... ... @@ -1,0 +1,1 @@ 1 +view,comment
- XWiki.XWikiRights[1]
-
- Autoriser / Interdire
-
... ... @@ -1,0 +1,1 @@ 1 +Autoriser - Groupes
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.XWikiAdminGroup - Niveaux
-
... ... @@ -1,0 +1,1 @@ 1 +view,comment
- XWiki.XWikiRights[2]
-
- Autoriser / Interdire
-
... ... @@ -1,0 +1,1 @@ 1 +Autoriser - Niveaux
-
... ... @@ -1,0 +1,1 @@ 1 +view,comment - Utilisateurs
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.XWikiGuest