Изменения документа Загрузить документ

Редактировал(а) HRlink 30.05.2025

От версии 74.1
отредактировано HRlink
на 30.05.2025
Изменить комментарий: К данной версии нет комментариев
К версии 75.1
отредактировано HRlink
на 30.05.2025
Изменить комментарий: К данной версии нет комментариев

Сводка

Подробности

Свойства страницы
Содержимое
... ... @@ -143,40 +143,143 @@
143 143  [[Добавьте к документу сотрудников>>https://wiki.myhrlink.ru/bin/view/Main/Кадровик/Документы/Добавить%20в%20документ%20нескольких%20сотрудников%20/]] или отправьте загруженные документы на [[подпись>>https://wiki.myhrlink.ru/bin/view/Main/Кадровик/Документы/Отправить%20документ%20на%20подпись%20/]]
144 144  
145 145  ----
146 -{{velocity}}
147 -#set($likesKey = "$doc.fullName_LikeCount")
148 -#set($cookieName = "like_given_${likesKey}")
149 -#set($hasLiked = $request.getCookie($cookieName))
150 -#set($likesDoc = $xwiki.getDocument("XWiki.XWikiPreferences"))
151 -#set($obj = $likesDoc.getObject("XWiki.LikesStorageClass", "key", $likesKey))
152 -#if(!$obj)
153 - #set($discard = $likesDoc.newObject("XWiki.LikesStorageClass"))
154 - #set($obj = $likesDoc.getObject("XWiki.LikesStorageClass", "key", $likesKey))
146 +
147 + {{velocity}}#set($likesKey = $doc.fullName)
148 +#set($likesDocRef = $services.model.resolveDocument("XWiki.LikesStorage"))
149 +#set($likesDoc = $xwiki.getDocument("XWiki.LikesStorage"))
150 +#set($likesObject = $likesDoc.getObject("XWiki.LikesStorageClass", "key", $likesKey))
151 +
152 +## Создание объекта, если ещё нет
153 +#if(!$likesObject)
154 + #set($likesDoc = $xwiki.getDocument("XWiki.LikesStorage"))
155 + #set($obj = $likesDoc.newObject("XWiki.LikesStorageClass"))
155 155   $obj.set("key", $likesKey)
156 156   $obj.set("value", 0)
157 157   $xwiki.saveDocument($likesDoc)
159 + #set($likes = 0)
160 +#else
161 + #set($likes = $likesObject.get("value"))
158 158  #end
159 159  
160 -#set($likes = $obj.getIntValue("value"))
164 +## Проверка, ставил ли пользователь лайк через cookie
165 +#set($liked = $request.getCookie("liked-$likesKey"))
166 +#set($userLiked = false)
167 +#if("$!liked" == "true")
168 + #set($userLiked = true)
169 +#end
161 161  
162 -## Увеличение, если кнопка нажата и не было лайка
163 -#if($request.getParameter("like") && !$hasLiked)
164 - #set($likes = $likes + 1)
165 - $obj.set("value", $likes)
171 +## HTML-блок
172 +{{html clean="false"}}
173 +<div id="like-container" style="margin-top:20px; display:flex; align-items:center; gap:10px;">
174 + <button id="like-button" style="cursor:pointer; font-size: 20px; background: none; border: none;" title="Нравится">
175 + <span id="heart" style="color:#e74c3c;">❤️</span>
176 + </button>
177 + <span id="like-count" style="font-size:18px;">$likes</span>
178 + <span style="font-size:14px; color: #555;">Нравится статья?</span>
179 +</div>
180 +<script>
181 + document.addEventListener('DOMContentLoaded', function () {
182 + const key = "$likesKey";
183 + const likeButton = document.getElementById('like-button');
184 + const likeCount = document.getElementById('like-count');
185 +
186 + function setCookie(name, value, days) {
187 + const d = new Date();
188 + d.setTime(d.getTime() + (days*24*60*60*1000));
189 + document.cookie = name + "=" + value + "; expires=" + d.toUTCString() + "; path=/";
190 + }
191 +
192 + function getCookie(name) {
193 + const value = `; ${document.cookie}`;
194 + const parts = value.split(`; ${name}=`);
195 + if (parts.length === 2) return parts.pop().split(';').shift();
196 + }
197 +
198 + if (getCookie("liked-" + key) === "true") {
199 + likeButton.disabled = true;
200 + likeButton.style.opacity = 0.6;
201 + }
202 +
203 + likeButton.addEventListener('click', function () {
204 + if (getCookie("liked-" + key) !== "true") {
205 + fetch(location.href, {
206 + method: 'POST',
207 + headers: { 'Content-Type': 'application/x-www-form-urlencoded' },
208 + body: 'like=1&xredirect=' + encodeURIComponent(window.location.pathname)
209 + }).then(() => {
210 + let current = parseInt(likeCount.innerText);
211 + likeCount.innerText = current + 1;
212 + setCookie("liked-" + key, "true", 365);
213 + likeButton.disabled = true;
214 + likeButton.style.opacity = 0.6;
215 + });
216 + }
217 + });
218 + });
219 +</script>
220 +{{/html}}
221 +
222 +## Серверная часть для учёта лайка
223 +#if($request.getParameter("like") == "1")
224 + #set($likesDoc = $xwiki.getDocument("XWiki.LikesStorage"))
225 + #set($likesObject = $likesDoc.getObject("XWiki.LikesStorageClass", "key", $likesKey))
226 + #set($count = $likesObject.get("value"))
227 + $likesObject.set("value", $math.add($count, 1))
166 166   $xwiki.saveDocument($likesDoc)
167 - $response.setCookie($cookieName, "true", 365*24*60*60)
168 -#end
169 -{{/velocity}}
229 +#end{{/velocity}}
170 170  
231 +
232 +$xwiki.saveDocument($likesDoc)
233 +
234 +
171 171  {{html clean="false"}}
172 -<div style="margin-top:30px; display:flex; align-items:center; gap:10px; font-size:16px;">
173 - <form method="post">
174 - <input type="hidden" name="like" value="1"/>
175 - <button type="submit" title="Поставить лайк" style="background:none; border:none; font-size:24px; cursor:pointer;">❤️</button>
176 - </form>
177 - <span style="font-size:18px;">$likes</span>
178 - <span>Нравится статья?</span>
236 +<div id="like-container" style="margin-top:20px; display:flex; align-items:center; gap:10px;">
237 +<button id="like-button" style="cursor:pointer; font-size: 20px; background: none; border: none;" title="Нравится">
238 +<span id="heart" style="color:#e74c3c;">❤️</span>
239 +</button>
240 +<span id="like-count" style="font-size:18px;">0</span>
241 +<span style="font-size:14px; color: #555;">Нравится статья?</span>
179 179  </div>
243 +<script>
244 +document.addEventListener('DOMContentLoaded', function () {
245 +const key = "Main.Кадровик.Документы.Загрузить документ .WebHome";
246 +const likeButton = document.getElementById('like-button');
247 +const likeCount = document.getElementById('like-count');
248 +
249 +function setCookie(name, value, days) {
250 +const d = new Date();
251 +d.setTime(d.getTime() + (days*24*60*60*1000));
252 +document.cookie = name + "=" + value + "; expires=" + d.toUTCString() + "; path=/";
253 +}
254 +
255 +function getCookie(name) {
256 +const value = `; ${document.cookie}`;
257 +const parts = value.split(`; ${name}=`);
258 +if (parts.length === 2) return parts.pop().split(';').shift();
259 +}
260 +
261 +if (getCookie("liked-" + key) === "true") {
262 +likeButton.disabled = true;
263 +likeButton.style.opacity = 0.6;
264 +}
265 +
266 +likeButton.addEventListener('click', function () {
267 +if (getCookie("liked-" + key) !== "true") {
268 +fetch(location.href, {
269 +method: 'POST',
270 +headers: { 'Content-Type': 'application/x-www-form-urlencoded' },
271 +body: 'like=1&xredirect=' + encodeURIComponent(window.location.pathname)
272 +}).then(() => {
273 +let current = parseInt(likeCount.innerText);
274 +likeCount.innerText = current + 1;
275 +setCookie("liked-" + key, "true", 365);
276 +likeButton.disabled = true;
277 +likeButton.style.opacity = 0.6;
278 +});
279 +}
280 +});
281 +});
282 +</script>
180 180  {{/html}}
181 181  
182 182