Modifications pour le document RatingWidget

Modifié par Pascale STEIMETZ-LE CACHEUX le 2026/03/25 16:54

Depuis la version 2.1
modifié par Pascale STEIMETZ-LE CACHEUX
sur 2026/03/24 11:52
Commentaire de modification : Il n'y a aucun commentaire pour cette version
À la version 8.3
modifié par Pascale STEIMETZ-LE CACHEUX
sur 2026/03/24 19:04
Commentaire de modification : allow view droit pour XWiki.XWikiAdminGroup

Résumé

Détails

Propriétés de la Page
Contenu
... ... @@ -1,7 +1,36 @@
1 1  {{velocity}}
2 2  #set($currentDoc = $doc.fullName)
3 -{{/velocity}}
4 4  
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") == $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
5 5  {{html clean="false"}}
6 6  <style>
7 7  .flora-rating-wrap {
... ... @@ -14,140 +14,44 @@
14 14   flex-wrap: wrap;
15 15   font-size: 14px;
16 16  }
17 -
18 18  .flora-rating-label {
19 19   font-weight: 600;
20 20   color: #2A2B69;
21 21  }
22 -
23 -.flora-rating-actions {
50 +.flora-stars {
24 24   display: inline-flex;
25 25   gap: 4px;
26 26  }
27 -
28 -.flora-rating-actions button {
54 +.flora-stars button {
29 29   background: none;
30 30   border: none;
31 - padding: 0;
32 - margin: 0;
33 - font-size: 24px;
34 - line-height: 1;
57 + font-size: 22px;
35 35   cursor: pointer;
36 36   color: #d4af37;
60 + padding: 0;
61 + margin: 0;
37 37  }
38 -
39 -.flora-rating-actions button:hover,
40 -.flora-rating-actions button.hovered {
63 +.flora-stars button:hover,
64 +.flora-stars button.hovered {
41 41   color: #f2c94c;
42 42  }
43 -
44 44  .flora-rating-result {
45 45   color: #2F2F2F;
46 46  }
47 -
48 -.flora-rating-message {
49 - font-size: 13px;
50 - color: #2F2F2F;
51 -}
52 52  </style>
53 53  
54 -<div class="flora-rating-wrap">
72 +<div class="flora-rating-wrap" data-doc="$escapetool.xml($currentDoc)">
55 55   <span class="flora-rating-label">Noter cette page</span>
56 56  
57 - <div class="flora-rating-actions" data-doc="$escapetool.xml($currentDoc)">
58 - <button type="button" data-note="1" aria-label="1 étoile">★</button>
59 - <button type="button" data-note="2" aria-label="2 étoiles">★</button>
60 - <button type="button" data-note="3" aria-label="3 étoiles">★</button>
61 - <button type="button" data-note="4" aria-label="4 étoiles">★</button>
62 - <button type="button" data-note="5" aria-label="5 étoiles">★</button>
75 + <div class="flora-stars">
76 + <button class="flora-star" data-note="1" type="button">★</button>
77 + <button class="flora-star" data-note="2" type="button">★</button>
78 + <button class="flora-star" data-note="3" type="button">★</button>
79 + <button class="flora-star" data-note="4" type="button">★</button>
80 + <button class="flora-star" data-note="5" type="button">★</button>
63 63   </div>
64 64  
65 - <span class="flora-rating-message"></span>
83 + <span class="flora-rating-result">$stars ($count votes)</span>
66 66  </div>
67 -
68 -<script>
69 -(function () {
70 - const actions = document.querySelector('.flora-rating-actions');
71 - if (!actions) return;
72 -
73 - const stars = Array.from(actions.querySelectorAll('button'));
74 - const message = document.querySelector('.flora-rating-message');
75 - const doc = actions.getAttribute('data-doc');
76 -
77 - function floraGetCookieId() {
78 - let id = localStorage.getItem('flora_rating_cookie');
79 - if (!id) {
80 - id = 'browser-' + Math.random().toString(36).slice(2);
81 - localStorage.setItem('flora_rating_cookie', id);
82 - }
83 - return id;
84 - }
85 -
86 - function paintStars(count) {
87 - stars.forEach((star, index) => {
88 - star.classList.toggle('hovered', index < count);
89 - });
90 - }
91 -
92 - stars.forEach((star) => {
93 - star.addEventListener('mouseenter', function () {
94 - paintStars(parseInt(this.dataset.note, 10));
95 - });
96 -
97 - star.addEventListener('click', function () {
98 - const note = parseInt(this.dataset.note, 10);
99 - const cookieId = floraGetCookieId();
100 - const url = '/bin/view/Flora/RatingService3?xpage=plain'
101 - + '&note=' + encodeURIComponent(note)
102 - + '&doc=' + encodeURIComponent(doc)
103 - + '&cookieId=' + encodeURIComponent(cookieId);
104 -
105 - fetch(url)
106 - .then(r => r.text())
107 - .then(() => window.location.reload())
108 - .catch(() => {
109 - if (message) {
110 - message.innerText = 'Erreur lors de l’enregistrement.';
111 - }
112 - });
113 - });
114 - });
115 -
116 - actions.addEventListener('mouseleave', function () {
117 - paintStars(0);
118 - });
119 -})();
120 -</script>
121 121  {{/html}}
122 -
123 -{{groovy}}
124 -def currentDoc = xcontext.getDoc().getFullName()
125 -
126 -def store = xwiki.getDocument("Flora.RatingStore3")
127 -def objects = store.getObjects("Flora.RatingVoteClass3")
128 -
129 -def notes = []
130 -
131 -if (objects != null) {
132 - for (o in objects) {
133 - if (o != null && o.getValue("document") == currentDoc) {
134 - notes.add(o.getValue("note"))
135 - }
136 - }
137 -}
138 -
139 -def moyenne = 0
140 -if (notes.size() > 0) {
141 - moyenne = notes.sum() / notes.size()
142 -}
143 -
144 -for (int i = 1; i <= 5; i++) {
145 - if (i <= Math.round(moyenne)) {
146 - print("★")
147 - } else {
148 - print("☆")
149 - }
150 -}
151 -
152 -print(" (" + notes.size() + " votes)")
153 -{{/groovy}}
86 +{{/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
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