Changes for page Public Web Site
Last modified by Alex Cotiugă on 2026/03/02 20:58
From version 3.85
edited by Alex Cotiugă
on 2025/11/27 10:41
on 2025/11/27 10:41
Change comment:
There is no comment for this version
To version 3.2
edited by Alex Cotiugă
on 2025/11/24 07:19
on 2025/11/24 07:19
Change comment:
There is no comment for this version
Summary
-
Page properties (1 modified, 0 added, 0 removed)
-
Objects (1 modified, 0 added, 0 removed)
Details
- Page properties
-
- Content
-
... ... @@ -1,218 +1,147 @@ 1 1 {{velocity}} 2 -#macro (displayPublicContent) 3 - #set ($discard = $xwiki.ssx.use('PublicWebSite.WebHome')) 4 - {{html clean="false"}} 5 - ## HERO 6 - <section class="hero hero-centered" aria-labelledby="hero-title"> 7 - <div class="container hero-inner"> 8 - <h1 id="hero-title">Professional XWiki solutions, from setup to long-term stability</h1> 9 - <p class="lead">Need your XWiki upgraded, secured, or improved? Let’s make it happen.</p> 10 - <div class="hero-cta"> 11 - Need help with your XWiki? <a href="mailto:alex@agnease.com">Contact Agnease</a>. 12 - #*<a class="btn btn-primary" href="#contact" aria-label="Request a consultation" data-toggle="modal" data-target="#requestConsultation"> 13 - Request a consultation 14 - </a> 15 - #requestConsultationModal()*# 16 - ##data-toggle="modal" data-target="#requestConsultationModal" 17 - </div> 18 - <ul class="benefits"> 19 - <li>Smooth upgrades</li> 20 - <li>Reliable support plans</li> 21 - <li>Custom integrations</li> 22 - <li>Secure, optimized platforms</li> 23 - </ul> 2 +#set ($discard = $xwiki.ssx.use('PublicWebSite.WebHome')) 3 +{{html clean="false"}} 4 + ## HERO 5 + <section class="hero hero-centered" aria-labelledby="hero-title"> 6 + <div class="container hero-inner"> 7 + <h1 id="hero-title">Professional XWiki solutions, from setup to long-term stability</h1> 8 + <p class="lead">Need your XWiki upgraded, secured, or improved? Let’s make it happen.</p> 9 + <div class="hero-cta"> 10 + <a class="btn btn-primary" href="#contact" aria-label="Schedule a call with Agnease"> 11 + Request a consultation 12 + </a> 24 24 </div> 25 - </section> 26 - ## WHY CHOOSE 27 - #set ($whySectionData = [{ 28 - 'title': 'Stability & security', 29 - 'icon': 'shield', 30 - 'content': 'Proven upgrade steps, rollback safety, and proactive hardening keep your wiki reliable.' 31 - },{ 32 - 'title': 'Predictable delivery', 33 - 'icon': 'check-square-o', 34 - 'content': 'Clear scope, defined steps, and documented results to avoid surprises.' 35 - },{ 36 - 'title': 'Clean integrations', 37 - 'icon': 'link', 38 - 'content': 'Maintainable SSO, API, and system connections tailored to your environment.' 39 - },{ 40 - 'title': 'Long-term support', 41 - 'icon': 'life-ring', 42 - 'content': 'Guaranteed response times, regular checks, and fast assistance when needed.' 43 - }]) 44 - <section aria-labelledby="why-title"> 45 - <div class="container"> 46 - <h2 id="why-title">Why choose Agnease</h2> 47 - <p class="lead">10+ years of XWiki expertise with structured delivery and lasting collaboration</p> 48 - <div class="widgets"> 49 - #foreach ($entry in $whySectionData) 50 - <article class="widget"> 51 - <div class="icon" aria-hidden="true"> 52 - <i class="fa fa-$entry.icon"></i> 53 - <h4>$entry.title</h4> 54 - </div> 55 - <p>$entry.content</p> 56 - </article> 57 - #end 58 - </div> 14 + <ul class="benefits"> 15 + <li>Smooth upgrades</li> 16 + <li>Reliable support plans</li> 17 + <li>Custom integrations</li> 18 + <li>Secure, optimized platforms</li> 19 + </ul> 20 + </div> 21 + </section> 22 + ## WHY CHOOSE 23 + #set ($whySectionData = [{ 24 + 'title': 'Stability & security', 25 + 'icon': 'shield', 26 + 'content': 'Proven upgrade steps, rollback safety, and proactive hardening keep your wiki reliable.' 27 + },{ 28 + 'title': 'Predictable delivery', 29 + 'icon': 'check-square-o', 30 + 'content': 'Clear scope, defined steps, and documented results to avoid surprises.' 31 + },{ 32 + 'title': 'Clean integrations', 33 + 'icon': 'link', 34 + 'content': 'Maintainable SSO, API, and system connections tailored to your environment.' 35 + },{ 36 + 'title': 'Long-term support', 37 + 'icon': 'life-ring', 38 + 'content': 'Guaranteed response times, regular checks, and fast assistance when needed.' 39 + }]) 40 + <section aria-labelledby="why-title"> 41 + <div class="container"> 42 + <h2 id="why-title">Why choose Agnease</h2> 43 + <p class="lead">10+ years of XWiki expertise with structured delivery and lasting collaboration</p> 44 + <div class="widgets"> 45 + #foreach ($entry in $whySectionData) 46 + <article class="widget"> 47 + <div class="icon" aria-hidden="true"> 48 + <i class="fa fa-$entry.icon"></i> 49 + <h4>$entry.title</h4> 50 + </div> 51 + <p>$entry.content</p> 52 + </article> 53 + #end 59 59 </div> 60 - </section> 61 - ## SERVICES 62 - #set ($servicesSectionData = [{ 63 - 'title': 'Upgrades', 64 - 'icon': 'refresh', 65 - 'content': 'Stay current with the latest XWiki LTS and keep your instance reliable.', 66 - 'items': [ 67 - 'Audit setup, extensions, and configurations', 68 - 'Test upgrades with backups and validation', 69 - 'Safe production rollout with minimal downtime' 70 - ] 71 - },{ 72 - 'title': 'Maintenance, Support & Recovery', 73 - 'icon': 'stethoscope', 74 - 'content': 'Ensure long-term stability and quick response when issues appear.', 75 - 'items': [ 76 - 'Monitoring and performance checks', 77 - 'Security patching, log analysis, triage', 78 - 'Issue recovery, data repair, hardening' 79 - ] 80 - },{ 81 - 'title': 'Development & Integrations', 82 - 'icon': 'cogs', 83 - 'content': 'Extend and connect XWiki to fit your workflow and systems.', 84 - 'items': [ 85 - 'Custom apps, macros, automation', 86 - 'SSO, REST APIs, LDAP, CRM links', 87 - 'Maintainable extensions for long-term use' 88 - ] 89 - },{ 90 - 'title': 'Hosting & Deployment', 91 - 'icon': 'cloud', 92 - 'content': 'Cloud-ready environments designed for reliability and performance.', 93 - 'items': [ 94 - 'Containerized deployment and TLS', 95 - 'Backups, restore strategy, observability', 96 - 'Optimization and load tuning' 97 - ] 98 - },{ 99 - 'title': 'Migrations to XWiki', 100 - 'icon': 'exchange', 101 - 'content': 'Move from Confluence, SharePoint, or MediaWiki to XWiki with full data integrity and structure.', 102 - 'items': [ 103 - 'Preserve hierarchy, attachments, and permissions', 104 - 'Convert macros, categories, and metadata for XWiki', 105 - 'Redirect old URLs and maintain SEO consistency' 106 - ] 107 - }]) 108 - <section class="services" aria-labelledby="services-title"> 109 - <div class="container"> 110 - <h2 id="services-title">Services</h2> 111 - <p class="lead"> 112 - All the XWiki services you need, delivered with precision and care 113 - </p> 55 + </div> 56 + </section> 57 + ## SERVICES 58 + #set ($servicesSectionData = [{ 59 + 'title': 'Upgrades', 60 + 'icon': 'refresh', 61 + 'content': 'Stay current with the latest XWiki LTS and keep your instance reliable.', 62 + 'items': [ 63 + 'Audit setup, extensions, and configurations', 64 + 'Test upgrades with backups and validation', 65 + 'Safe production rollout with minimal downtime' 66 + ] 67 + },{ 68 + 'title': 'Maintenance, Support & Recovery', 69 + 'icon': 'stethoscope', 70 + 'content': 'Ensure long-term stability and quick response when issues appear.', 71 + 'items': [ 72 + 'Monitoring and performance checks', 73 + 'Security patching, log analysis, triage', 74 + 'Issue recovery, data repair, hardening' 75 + ] 76 + },{ 77 + 'title': 'Development & Integrations', 78 + 'icon': 'cogs', 79 + 'content': 'Extend and connect XWiki to fit your workflow and systems.', 80 + 'items': [ 81 + 'Custom apps, macros, automation', 82 + 'SSO, REST APIs, LDAP, CRM links', 83 + 'Maintainable extensions for long-term use' 84 + ] 85 + },{ 86 + 'title': 'Hosting & Deployment', 87 + 'icon': 'cloud', 88 + 'content': 'Cloud-ready environments designed for reliability and performance.', 89 + 'items': [ 90 + 'Containerized deployment and TLS', 91 + 'Backups, restore strategy, observability', 92 + 'Optimization and load tuning' 93 + ] 94 + },{ 95 + 'title': 'Migrations to XWiki', 96 + 'icon': 'exchange', 97 + 'content': 'Move from Confluence, SharePoint, or MediaWiki to XWiki with full data integrity and structure.', 98 + 'items': [ 99 + 'Preserve hierarchy, attachments, and permissions', 100 + 'Convert macros, categories, and metadata for XWiki', 101 + 'Redirect old URLs and maintain SEO consistency' 102 + ] 103 + }]) 104 + <section class="services" aria-labelledby="services-title"> 105 + <div class="container"> 106 + <h2 id="services-title">Services</h2> 107 + <p class="lead"> 108 + All the XWiki services you need, delivered with precision and care 109 + </p> 114 114 115 - #set ($servicesSize = $servicesSectionData.size()) 116 - <div class="services-grid"> 117 - #foreach ($entry in $servicesSectionData) 118 - #set ($classes = "service") 119 - ## If this is the last item AND the total number is odd, center it 120 - #if ($foreach.count == $servicesSize && ($servicesSize % 2) == 1) 121 - #set ($classes = "service service-center") 122 - #end 123 - 124 - <article class="$classes"> 125 - <div class="service-icon"> 126 - <i class="fa fa-$entry.icon" aria-hidden="true"></i> 127 - </div> 128 - <div class="service-body"> 129 - <h4>$entry.title</h4> 130 - <p>$entry.content</p> 131 - <ul> 132 - #foreach ($item in $entry.items) 133 - <li>$item</li> 134 - #end 135 - </ul> 136 - </div> 137 - </article> 111 + #set ($servicesSize = $servicesSectionData.size()) 112 + <div class="services-grid"> 113 + #foreach ($entry in $servicesSectionData) 114 + #set ($classes = "service") 115 + ## If this is the last item AND the total number is odd, center it 116 + #if ($foreach.count == $servicesSize && ($servicesSize % 2) == 1) 117 + #set ($classes = "service service-center") 138 138 #end 139 - </div> 140 - </div> 141 - </section> 142 - ## CTA INLINE 143 - <section id="contact" class="cta-section"> 144 - <div class="container"> 145 - <p class="text-center contact-inline"> 146 - Need help with your XWiki? <a href="mailto:alex@agnease.com">Contact Agnease</a>. 147 - </p> 148 - </div> 149 - </section> 150 - {{/html}} 151 -#end 152 152 153 -#macro(requestConsultationModal) 154 - <div class="modal fade" id="requestConsultation" tabindex="-1" role="dialog"> 155 - <div class="modal-dialog"> 156 - <div class="modal-content"> 157 - <div class="modal-header"> 158 - <button type="button" class="close" data-dismiss="modal">×</button> 159 - <h4 class="modal-title">Request a consultation</h4> 160 - </div> 161 - <div class="modal-body"> 162 - <div> 163 - ##Need help with your XWiki? <a href="mailto:alex@agnease.com">Contact Agnease</a> 164 - #displayFormFromSheetCode() 165 - </div> 166 - </div> 167 - <div class="modal-footer"> 168 - ##<input id="continueCategorySelection" type="button" class="btn btn-default" data-dismiss="modal" 169 - ## value="$escapetool.xml($services.localization.render('yesno_1'))"> 170 - </div> 120 + <article class="$classes"> 121 + <div class="service-icon"> 122 + <i class="fa fa-$entry.icon" aria-hidden="true"></i> 123 + </div> 124 + <div class="service-body"> 125 + <h4>$entry.title</h4> 126 + <p>$entry.content</p> 127 + <ul> 128 + #foreach ($item in $entry.items) 129 + <li>$item</li> 130 + #end 131 + </ul> 132 + </div> 133 + </article> 134 + #end 171 171 </div> 172 172 </div> 173 - </div> 174 -#end 175 - 176 -#macro (stripHTMLMacro $displayOutput) 177 - $stringtool.removeEnd($stringtool.removeStart($displayOutput, '{{html clean="false" wiki="false"}}'), '{{/html}}').replace('Agnease.Code.Lead.LeadClass_0_', 'acl-') 178 -#end 179 - 180 -#macro (displayFormFromSheetCode) 181 - #set ($editing = true) 182 - ## The object to display. 183 - #set ($xobject = $doc.newObject('Agnease.Code.Lead.LeadClass')) 184 - ## The class that describes the object properties. 185 - #set ($xclass = $xwiki.getClass('Agnease.Code.Lead.LeadClass')) 186 - ## Make sure the following display* method calls use the right object. 187 - #set ($discard = $doc.use($xobject)) 188 - ## Using the xform vertical form layout. 189 - <div class="xform"> 190 - <dl> 191 - #foreach ($property in $xclass.properties) 192 - #if ($property.name != 'status') 193 - <dt #if (!$editing) 194 - class="editableProperty" 195 - #set ($xobjectPropertyReference = $xobject.getPropertyReference($property.name)) 196 - data-property="$escapetool.xml($services.model.serialize($xobjectPropertyReference))" 197 - data-property-type="object"#end> 198 - ## This must match the id generated by the $doc.display() method below. 199 - #set ($propertyId = "acl-$property.name") 200 - <label#if ($editing) for="$escapetool.xml($propertyId)"#end> 201 - $escapetool.xml($property.translatedPrettyName) 202 - </label> 203 - ## Support for specifying a translation key as hint in the property definition. 204 - <span class="xHint">$!escapetool.xml($services.localization.render($property.hint))</span> 205 - </dt> 206 - #set ($displayOutput = $doc.display($property.name, 'edit')) 207 - <dd>#stripHTMLMacro($displayOutput)</dd> 208 - #end 209 - #end 210 - #if (!$xclass.properties || $xclass.properties.size() == 0) 211 - ## Keep the empty definition term in order to have valid HTML. 212 - <dt></dt> 213 - <dd>$escapetool.xml($services.localization.render('xclass.defaultObjectSheet.noProperties'))</dd> 214 - #end 215 - </dl> 216 - </div> 217 -#end 137 + </section> 138 + ## CTA INLINE 139 + <section id="contact" class="cta-section"> 140 + <div class="container"> 141 + <p class="text-center contact-inline"> 142 + Need help with your XWiki? <a href="mailto:alex@agnease.com">Contact Agnease</a>. 143 + </p> 144 + </div> 145 + </section> 146 +{{/html}} 218 218 {{/velocity}}
- XWiki.StyleSheetExtension[0]
-
- Code
-
... ... @@ -13,6 +13,21 @@ 13 13 padding: 0; 14 14 } 15 15 16 +a { 17 + color: @brand; 18 + text-decoration: none; 19 + &:hover { 20 + color: @brand-strong; 21 + text-decoration: underline; 22 + } 23 +} 24 + 25 +img { 26 + max-width: 100%; 27 + height: auto; 28 + display: block; 29 +} 30 + 16 16 .container { 17 17 max-width: @maxw; 18 18 } ... ... @@ -34,6 +34,35 @@ 34 34 } 35 35 } 36 36 52 +/* Buttons */ 53 +.btn { 54 + display: inline-flex; 55 + align-items: center; 56 + justify-content: center; 57 + padding: .85rem 1.1rem; 58 + border-radius: 12px; 59 + border: 2px solid transparent; 60 + font-weight: 650; 61 + letter-spacing: .2px; 62 + cursor: pointer; 63 + box-shadow: @shadow-sm; 64 + 65 + &:focus-visible { 66 + outline: 3px solid @brand; 67 + outline-offset: 2px; 68 + } 69 + 70 + &-primary { 71 + background: @brand; 72 + color: #fff; 73 + &:hover, 74 + &:focus { 75 + background: @brand-strong; 76 + color: #fff; 77 + } 78 + } 79 +} 80 + 37 37 /* ===== HERO ===== */ 38 38 .hero { 39 39 overflow: hidden;