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

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

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

Сводка

Подробности

Свойства страницы
Содержимое
... ... @@ -143,143 +143,40 @@
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 -
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"))
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))
156 156   $obj.set("key", $likesKey)
157 157   $obj.set("value", 0)
158 158   $xwiki.saveDocument($likesDoc)
159 - #set($likes = 0)
160 -#else
161 - #set($likes = $likesObject.get("value"))
162 162  #end
163 163  
164 -## Проверка, ставил ли пользователь лайк через cookie
165 -#set($liked = $request.getCookie("liked-$likesKey"))
166 -#set($userLiked = false)
167 -#if("$!liked" == "true")
168 - #set($userLiked = true)
169 -#end
160 +#set($likes = $obj.getIntValue("value"))
170 170  
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))
162 +## Увеличение, если кнопка нажата и не было лайка
163 +#if($request.getParameter("like") && !$hasLiked)
164 + #set($likes = $likes + 1)
165 + $obj.set("value", $likes)
228 228   $xwiki.saveDocument($likesDoc)
229 -#end{{/velocity}}
167 + $response.setCookie($cookieName, "true", 365*24*60*60)
168 +#end
169 +{{/velocity}}
230 230  
231 -
232 -$xwiki.saveDocument($likesDoc)
233 -
234 -
235 235  {{html clean="false"}}
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>
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>
242 242  </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>
283 283  {{/html}}
284 284  
285 285