Changes for page Card Navigation

Last modified by Calvin Henderson on 2025/03/11 10:29

From version 21.3
edited by calvin_henderson
on 2024/12/19 14:34
Change comment: There is no comment for this version
To version 18.9
edited by calvin_henderson
on 2024/12/18 13:45
Change comment: There is no comment for this version

Summary

Details

Page properties
Title
... ... @@ -1,1 +1,1 @@
1 -Card Navigation
1 +Card View
XWiki.WikiMacroClass[0]
code
... ... @@ -2,44 +2,35 @@
2 2  #set($wikiRef = $doc.documentReference.getWikiReference().getName())
3 3  #set($docRef = $doc.getFullName())
4 4  #set($entries = $wikimacro.content)
5 -#if("$xcontext.action" != "edit")
5 +#set ($targetSyntaxId = $wikimacro.context.transformationContext.targetSyntax.type.id)
6 +#if ($targetSyntaxId == 'annotatedhtml' || $targetSyntaxId == 'annotatedxhtml')
7 +[[Icon search>>https://fontawesome.com/v6/search?m=free]]
8 +Icon Name|Title|URL
9 +---------|-----|---
10 +{{wikimacrocontent/}}
11 +#else
6 6  
7 7  
8 8  {{html wiki="false"}}
9 - <div style="display: flex; flex-direction: row; gap: 10px; max-width: 1790px; flex-wrap: wrap;">
15 + <div style="display: grid;
16 + grid-template-columns: 1fr 1fr 1fr;
17 + gap: 10px;
18 + ">
10 10   #foreach($entry in $entries.split('\n'))
11 11   #set($card = $entry.split('\|'))
12 - #set($href = $card[2])
13 - #if (!$href.toString().startsWith('http') && !$href.contains('.'))
14 - #set($href = "$wikiref:$docRef.$href")
15 - #end
16 - #set($doc = $xwiki.getDocument($card[2]))
17 - #set($canView =
18 - $href.toString().startsWith('http')
19 - || $services.security.authorization.hasAccess('view', $href)
20 - || $services.security.authorization.hasAccess('edit', $href)
21 - || $services.security.authorization.hasAccess('admin', $href)
22 - )
23 - $href
24 - #if ($canView)
25 - <a href="$href" style="text-decoration:none;">
26 - <div style="
27 - display:grid;
28 - text-align:center;
29 - align-items: center;
30 - justify-items: center;
31 - padding:8px;
32 - border-radius:5px;
33 - border:1px solid rgba(222,222,222,1);
34 - border-bottom: 3px solid rgba(222,222,222,1);
35 - min-width: 350px; max-width: 350px;
36 - min-height: 150px; max-height: 150px;
37 - ">
38 - <i class="fa $card[0]" style="font-size:4em;"></i>
39 - <h3 style="margin-top: 0;">$card[1]</h3>
40 - </div>
41 - </a>
42 - #end
21 + <a href="$card[2]" style="text-decoration:none;">
22 + <div style="
23 + display:grid;
24 + text-align:center;
25 + padding:8px;
26 + border-radius:5px;
27 + border:1px solid rgba(222,222,222,1);
28 + border-bottom: 3px solid rgba(222,222,222,1);
29 + ">
30 + <i class="fa $card[0]" style="font-size:4em;"></i>
31 + <h3>$card[1]</h3>
32 + </div>
33 + </a>
43 43   #end
44 44   </div>
45 45  {{/html}}