Changes for page Home

Last modified by Isaac Mejia on 2025/12/15 18:27

From version 22.1
edited by Isaac Mejia
on 2025/12/05 17:59
Change comment: There is no comment for this version
To version 35.1
edited by Isaac Mejia
on 2025/12/15 18:27
Change comment: There is no comment for this version

Summary

Details

Page properties
Content
... ... @@ -2,6 +2,7 @@
2 2  ## ---------------------------------------------
3 3  ## KB Home (Main.WebHome)
4 4  ## Discover category landing pages dynamically.
5 +## (WITH HARD ALLOWLIST)
5 5  ## ---------------------------------------------
6 6  
7 7  ## 1) Find all top-level category pages under "Main"
... ... @@ -17,9 +17,9 @@
17 17   "and doc.name not like 'KB%' " +
18 18   "and doc.hidden <> true " +
19 19   "order by lower(doc.title)"
20 -)
21 -#set ($query = $services.query.xwql($xwql))
22 -#set ($rows = $query.execute())
21 +)##
22 +#set ($query = $services.query.xwql($xwql))##
23 +#set ($rows = $query.execute())##
23 23  
24 24  ## 2) Icon map (optional overrides)
25 25  #set ($kbCategoryIcons = {
... ... @@ -30,7 +30,7 @@
30 30   "Reporting & Analytics": "📊",
31 31   "Notifications": "🔔",
32 32   "Integrations": "🔗"
33 -})
34 +})##
34 34  
35 35  ## 3) Optional hand-authored descriptions for known categories
36 36  #set ($kbCategoryDescriptions = {
... ... @@ -41,71 +41,88 @@
41 41   "Reporting & Analytics": "Understand your numbers and performance.",
42 42   "Notifications": "Articles and guides for Notifications.",
43 43   "Integrations": "Connect Member Solutions with other tools in your stack."
44 -})
45 +})##
45 45  
47 +## --- HARD ALLOWLIST: only show these categories on the homepage ---
48 +## IMPORTANT: These must match the CATEGORY PAGE DISPLAY TITLE / NAME shown on cards.
49 +#set ($allowedCategories = [
50 + "Check-In",
51 + "Configuration",
52 + "Lead Management",
53 + "Member Management",
54 + "Member Portal",
55 + "Notifications",
56 + "Payment Management",
57 + "Reporting",
58 + "Feature Release Notes"
59 +])##
60 +
46 46  ## 4) Build a normalized list of category objects
47 -#set ($kbCategories = [])
62 +#set ($kbCategories = [])##
48 48  
49 -#foreach ($row in $rows)
50 - #set ($fullName = $row.get(0)) ## e.g. "Main.Member Management"
51 - #set ($title = $row.get(1)) ## display title
52 - #set ($pageName = $row.get(2)) ## page name, used in URL & article space
53 - #set ($catDoc = $xwiki.getDocument($fullName))
64 +#foreach ($row in $rows)##
65 + #set ($fullName = $row.get(0))## ## e.g. "Main.Member Management"
66 + #set ($title = $row.get(1))## ## display title
67 + #set ($pageName = $row.get(2))## ## page name, used in URL & article space
68 + #set ($catDoc = $xwiki.getDocument($fullName))##
54 54  
55 55   ## Label shown on the card
56 - #set ($label = $catDoc.displayTitle)
57 - #if ("$!label" == "")
58 - #set ($label = $pageName)
59 - #end
71 + #set ($label = $catDoc.displayTitle)##
72 + #if ("$!label" == "")##
73 + #set ($label = $pageName)##
74 + #end##
60 60  
61 - ## Default description (auto-generated if we don't have a custom one)
62 - #set ($desc = $kbCategoryDescriptions.get($label))
63 - #if ("$!desc" == "")
64 - #set ($desc = "Articles and guides for $label.")
65 - #end
76 + ## Only include categories we actually want
77 + #if ($allowedCategories.contains($label))##
66 66  
67 - ## Article space follows the convention:
68 - ## Main.<PageName with spaces replaced by underscores>
69 - ## e.g. Member Management -> space "Main.Member_Management"
70 - #set ($articleSpace = "Main." + $pageName.replace(" ", "_"))
79 + ## Description (custom if defined, otherwise auto)
80 + #set ($desc = $kbCategoryDescriptions.get($label))##
81 + #if ("$!desc" == "")##
82 + #set ($desc = "Articles and guides for $label.")##
83 + #end##
71 71  
72 - ## Count non-hidden, non-WebHome pages in that article space
73 - #set ($articleCount = 0)
74 - #set ($countXwql =
75 - "select count(doc.fullName) " +
76 - "from XWikiDocument doc " +
77 - "where doc.space = :space " +
78 - "and doc.name <> 'WebHome' " +
79 - "and doc.hidden <> true"
80 - )
81 - #set ($countQuery = $services.query.xwql($countXwql).bindValue("space", $articleSpace))
82 - #set ($resultList = $countQuery.execute())
83 - #if ($resultList && $resultList.size() > 0)
84 - #set ($articleCount = $resultList.get(0))
85 - #end
85 + ## Article space: Main.<PageName with spaces replaced by underscores>
86 + #set ($articleSpace = "Main." + $pageName.replace(" ", "_"))##
86 86  
87 - ## Icon, with a sensible default
88 - #set ($icon = $kbCategoryIcons.get($label))
89 - #if ("$!icon" == "")
90 - #set ($icon = "📘")
91 - #end
88 + ## Count non-hidden, non-WebHome pages in that article space
89 + #set ($articleCount = 0)##
90 + #set ($countXwql =
91 + "select count(doc.fullName) " +
92 + "from XWikiDocument doc " +
93 + "where doc.space = :space " +
94 + "and doc.name <> 'WebHome' " +
95 + "and doc.hidden <> true"
96 + )##
97 + #set ($countQuery = $services.query.xwql($countXwql).bindValue("space", $articleSpace))##
98 + #set ($resultList = $countQuery.execute())##
99 + #if ($resultList && $resultList.size() > 0)##
100 + #set ($articleCount = $resultList.get(0))##
101 + #end##
92 92  
93 - ## Build clean URL: /bin/view/Main/<PageName> (no trailing slash)
94 - #set ($encoded = $escapetool.url($pageName))
95 - #set ($cleanUrl = "/bin/view/Main/$encoded")
103 + ## Icon, with a sensible default
104 + #set ($icon = $kbCategoryIcons.get($label))##
105 + #if ("$!icon" == "")##
106 + #set ($icon = "📘")##
107 + #end##
96 96  
97 - ## Push into our categories array as a small map
98 - #set ($entry = {
99 - "label": $label,
100 - "pageName": $pageName,
101 - "desc": $desc,
102 - "icon": $icon,
103 - "url": $cleanUrl,
104 - "count": $articleCount
105 - })
106 - #set ($discard = $kbCategories.add($entry))
107 -#end
109 + ## Build clean URL: /bin/view/Main/<PageName> (no trailing slash)
110 + #set ($encoded = $escapetool.url($pageName))##
111 + #set ($cleanUrl = "/bin/view/Main/$encoded")##
108 108  
113 + ## Push into our categories array as a small map
114 + #set ($entry = {
115 + "label": $label,
116 + "pageName": $pageName,
117 + "desc": $desc,
118 + "icon": $icon,
119 + "url": $cleanUrl,
120 + "count": $articleCount
121 + })##
122 + #set ($discard = $kbCategories.add($entry))##
123 +
124 + #end##
125 +#end##
126 +
109 109  {{html clean="false"}}
110 110  <div class="kb-home">
111 111  
... ... @@ -116,9 +116,9 @@
116 116   Guides, walkthroughs, and best practices to help you and your team get the most out of the platform.
117 117   </p>
118 118  
119 - <!-- Enhanced search box (still uses XWiki search under the hood) -->
137 + <!-- Hero search wired to custom KB search page -->
120 120   <div class="kb-hero-search">
121 - <form action="$xwiki.getURL('Main.WebHome', 'view')" method="get">
139 + <form action="$xwiki.getURL('Main.KBSearch', 'view')" method="get">
122 122   <input
123 123   type="text"
124 124   name="text"
... ... @@ -166,8 +166,60 @@
166 166   </div>
167 167  
168 168  </div>
169 -{{/html}}
170 170  
188 +<style>
189 +/* HOMEPAGE HERO OVERRIDE – BIGGER + MORE BREATHING ROOM */
190 +
191 +/* Scope tightly so we only touch KB home hero */
192 +body.viewbody.page-WebHome[class*="space-Main"] #xwikicontent .kb-hero {
193 + padding: 4.2rem 1rem 3.3rem !important;
194 + max-width: 1100px;
195 + margin: 0 auto;
196 +}
197 +
198 +/* Title */
199 +body.viewbody.page-WebHome[class*="space-Main"] #xwikicontent .kb-hero-title {
200 + font-size: 3.5rem !important;
201 + font-weight: 800 !important;
202 + line-height: 1.15;
203 + margin-bottom: 1rem !important;
204 + color: #0f172a;
205 +}
206 +
207 +/* Subtitle */
208 +body.viewbody.page-WebHome[class*="space-Main"] #xwikicontent .kb-hero-subtitle {
209 + font-size: 1.35rem !important;
210 + line-height: 1.7;
211 + color: #4b5563 !important;
212 + max-width: 720px;
213 + margin: 0 auto 2.3rem !important;
214 +}
215 +
216 +/* Search bar – taller + larger text */
217 +body.viewbody.page-WebHome[class*="space-Main"] #xwikicontent .kb-hero-search input[type="text"] {
218 + max-width: 650px !important;
219 + padding: 1.25rem 1.6rem !important;
220 + font-size: 1.2rem !important;
221 + border-radius: 999px;
222 + border: 1px solid #d1d5db;
223 + box-shadow:
224 + 0 26px 60px rgba(15, 23, 42, 0.14),
225 + 0 2px 4px rgba(15, 23, 42, 0.06) !important;
226 +}
227 +
228 +/* Placeholder text tone/size */
229 +body.viewbody.page-WebHome[class*="space-Main"] #xwikicontent .kb-hero-search input[type="text"]::placeholder {
230 + font-size: 1.15rem;
231 + color: #9ca3af;
232 +}
233 +
234 +/* Extra space between hero and "Browse by category" */
235 +body.viewbody.page-WebHome[class*="space-Main"] #xwikicontent .kb-section {
236 + margin-top: 4.6rem !important;
237 +}
238 +</style>
239 +
240 +{{/html}}
171 171  {{/velocity}}
172 172  
173 173  {{include reference="KBSupportCTA.WebHome"/}}