Изменения документа Загрузить документ
Редактировал(а) HRlink 30.05.2025
Сводка
-
Свойства страницы (1 изменено, 0 добавлено, 0 удалено)
Подробности
- Свойства страницы
-
- Содержимое
-
... ... @@ -141,3 +141,81 @@ 141 141 == Дальнейшие действия == 142 142 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 + 145 +---- 146 + 147 +{{velocity}} 148 +#set($likesKey = $doc.fullName) 149 +#set($likesDoc = $xwiki.getDocument("XWiki.LikesStorage")) 150 +#set($likesObject = $likesDoc.getObject("XWiki.LikesStorageClass", "key", $likesKey)) 151 + 152 +#if(!$likesObject) 153 + #set($likesObject = $likesDoc.newObject("XWiki.LikesStorageClass")) 154 + $likesObject.set("key", $likesKey) 155 + $likesObject.set("value", 0) 156 + $xwiki.saveDocument($likesDoc) 157 +#end 158 + 159 +#set($likes = $likesObject.get("value")) 160 +#set($liked = $request.getCookie("liked-$likesKey")) 161 +#set($userLiked = false) 162 +#if("$!liked" == "true") 163 + #set($userLiked = true) 164 +#end 165 + 166 +{{html clean="false"}} 167 +<div id="like-container" style="margin-top:20px; display:flex; align-items:center; gap:10px;"> 168 + <button id="like-button" style="cursor:pointer; font-size: 20px; background: none; border: none;" title="Нравится" aria-label="Лайк"> 169 + <span id="heart" style="color:#e74c3c;">❤️</span> 170 + </button> 171 + <span id="like-count" style="font-size:18px;">$likes</span> 172 + <span style="font-size:14px; color: #555;">Нравится статья?</span> 173 +</div> 174 + 175 +<script> 176 + document.addEventListener('DOMContentLoaded', function () { 177 + const key = "$likesKey"; 178 + const likeButton = document.getElementById('like-button'); 179 + const likeCount = document.getElementById('like-count'); 180 + 181 + function setCookie(name, value, days) { 182 + const d = new Date(); 183 + d.setTime(d.getTime() + (days*24*60*60*1000)); 184 + document.cookie = name + "=" + value + "; expires=" + d.toUTCString() + "; path=/"; 185 + } 186 + 187 + function getCookie(name) { 188 + const value = `; ${document.cookie}`; 189 + const parts = value.split(`; ${name}=`); 190 + if (parts.length === 2) return parts.pop().split(';').shift(); 191 + } 192 + 193 + if (getCookie("liked-" + key) === "true") { 194 + likeButton.disabled = true; 195 + likeButton.style.opacity = 0.6; 196 + } 197 + 198 + likeButton.addEventListener('click', function () { 199 + if (getCookie("liked-" + key) !== "true") { 200 + fetch(window.location.href + "?like=1", { method: 'GET' }) 201 + .then(() => { 202 + let current = parseInt(likeCount.innerText); 203 + likeCount.innerText = current + 1; 204 + setCookie("liked-" + key, "true", 365); 205 + likeButton.disabled = true; 206 + likeButton.style.opacity = 0.6; 207 + }); 208 + } 209 + }); 210 + }); 211 +</script> 212 +{{/html}} 213 + 214 +#if($request.getParameter("like") == "1") 215 + #set($likes = $likesObject.get("value")) 216 + $likesObject.set("value", $math.add($likes, 1)) 217 + $xwiki.saveDocument($likesDoc) 218 +#end 219 +{{/velocity}} 220 + 221 +