Исходный код вики HRlink. Новости об обновлениях
Скрыть последних авторов
author | version | line-number | content |
---|---|---|---|
![]() |
16.1 | 1 | {{velocity}} |
![]() |
21.1 | 2 | #set($PERPAGE = 10) |
3 | |||
![]() |
22.1 | 4 | ## 1) Текущая страница категории |
5 | #set($full = $doc.fullName) | ||
![]() |
21.1 | 6 | |
![]() |
22.1 | 7 | ## 2) Родитель может храниться как "...WebHome" или без него. |
8 | ## Сформируем обе ссылки и превратим их в DocumentReference. | ||
9 | #set($pWith = $full.endsWith('.WebHome') ? $full : $full + '.WebHome') | ||
10 | #set($pBare = $full.endsWith('.WebHome') ? $full.substring(0, $full.length() - 8) : $full) | ||
11 | |||
12 | #set($parentRefWith = $services.model.resolveDocument($pWith)) | ||
13 | #set($parentRefBare = $services.model.resolveDocument($pBare)) | ||
14 | |||
15 | ## Префикс ветки (для фоллбэка по fullName, включая подкатегории) | ||
16 | #set($prefix = $pBare + '.') | ||
17 | |||
18 | ## 3) Пагинация | ||
![]() |
21.1 | 19 | #set($p = $request.get('p')) #if(!$p) #set($p = 1) #end |
20 | #set($p = $numbertool.toInteger($p)) #if($p < 1) #set($p = 1) #end | ||
21 | #set($offset = ($p - 1) * $PERPAGE) | ||
22 | |||
![]() |
22.1 | 23 | ## 4) Сначала ищем детей по parent = (ref c WebHome ИЛИ без него) |
![]() |
21.1 | 24 | #set($total = $services.query.xwql( |
![]() |
22.1 | 25 | "select count(doc.fullName) from Document doc " + |
26 | "where doc.parent = :r1 or doc.parent = :r2" | ||
27 | ).bindValue('r1', $parentRefWith).bindValue('r2', $parentRefBare).execute().get(0)) | ||
![]() |
21.1 | 28 | |
29 | #set($rows = []) | ||
30 | #if($total > 0) | ||
31 | #set($rows = $services.query.xwql( | ||
32 | "select doc.fullName from Document doc " + | ||
![]() |
22.1 | 33 | "where doc.parent = :r1 or doc.parent = :r2 " + |
![]() |
21.1 | 34 | "order by doc.date desc" |
![]() |
22.1 | 35 | ).bindValue('r1', $parentRefWith).bindValue('r2', $parentRefBare).setLimit($PERPAGE).setOffset($offset).execute()) |
![]() |
21.1 | 36 | #end |
37 | |||
![]() |
22.1 | 38 | ## 5) Если вдруг пусто — берём все документы по префиксу fullName (включая подкатегории) |
![]() |
21.1 | 39 | #if($total == 0) |
40 | #set($total = $services.query.xwql( | ||
41 | "select count(doc.fullName) from Document doc where doc.fullName like :prefix" | ||
![]() |
22.1 | 42 | ).bindValue('prefix', $prefix + '%').execute().get(0)) |
43 | #set($rows = $services.query.xwql( | ||
44 | "select doc.fullName from Document doc where doc.fullName like :prefix order by doc.date desc" | ||
45 | ).bindValue('prefix', $prefix + '%').setLimit($PERPAGE).setOffset($offset).execute()) | ||
![]() |
21.1 | 46 | #end |
47 | |||
![]() |
22.1 | 48 | ## 6) Рендер ленты + пагинация |
![]() |
21.1 | 49 | #if($total == 0) |
50 | <p>Пока нет публикаций в этой ветке.</p> | ||
51 | #else | ||
52 | #foreach($fn in $rows) | ||
53 | #set($d = $xwiki.getDocument($fn)) | ||
54 | <article style="margin:14px 0; padding-bottom:10px; border-bottom:1px solid #e5e7eb"> | ||
55 | <div style="color:#6b7280; font-size:.9em">$datetool.format('dd MMM yyyy', $d.date)</div> | ||
56 | <h3 style="margin:.2rem 0"><a href="$d.getURL('view')">$escapetool.html($d.displayTitle)</a></h3> | ||
57 | <div>$!d.getPlainContent().substring(0,300)…</div> | ||
58 | </article> | ||
59 | #end | ||
60 | |||
61 | #if($total > $PERPAGE) | ||
62 | #set($pages = ($total + $PERPAGE - 1) / $PERPAGE) | ||
63 | #set($base = $doc.getURL('view')) | ||
64 | #set($prev = $math.sub($p, 1)) | ||
65 | #set($next = $math.add($p, 1)) | ||
66 | <nav style="margin-top:1em; display:flex; gap:1em; align-items:center"> | ||
67 | #if($p > 1)<a href="$base?p=$prev">← Назад</a>#else<span style="opacity:.5">← Назад</span>#end | ||
68 | <span>Стр. $p / $pages</span> | ||
69 | #if($p < $pages)<a href="$base?p=$next">Далее →</a>#else<span style="opacity:.5">Далее →</span>#end | ||
70 | </nav> | ||
71 | #end | ||
72 | #end | ||
![]() |
16.1 | 73 | {{/velocity}} |