Изменения документа Загрузить документ
Редактировал(а) HRlink 30.05.2025
Сводка
-
Свойства страницы (1 изменено, 0 добавлено, 0 удалено)
Подробности
- Свойства страницы
-
- Содержимое
-
... ... @@ -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