Last modified by Alex Cotiugă on 2026/05/04 06:15

From version 13.12
edited by Alex Cotiugă
on 2026/05/01 16:56
Change comment: There is no comment for this version
To version 13.160
edited by Alex Cotiugă
on 2026/05/02 09:07
Change comment: There is no comment for this version

Summary

Details

Page properties
Content
... ... @@ -1,40 +1,85 @@
1 +{{velocity wiki="false"}}
2 +#if ($xcontext.action == 'get')
3 + #set ($message = '')
4 + #set ($now = $datetool.get('yyyyMMddHHmm'))
5 + #set ($random = $mathtool.random(100000, 999999))
6 + #set ($uniqueName = "ContactRequest-${now}-${random}")
7 + #set ($contactRequestDoc = $xwiki.getDocument('ContactRequests.' + $uniqueName))
8 + #set ($contactRequestObj = $contactRequestDoc.getObject('Agnease.Code.ContactForm.ContactFormClass', true))
9 + #set ($statusCode = 200)
10 + #set ($message = "$$contactRequestObj")
11 +
12 + #foreach ($parameterName in $request.parameterNames)
13 + #set ($message = "$message $parameterName")
14 + #end
15 +
16 + ##set ($statusCode = 400)
17 + ##set ($message = 'error')
18 +
19 + #set ($discard = $response.setStatus($statusCode))
20 + #jsonResponse({'message': $message})
21 +#end
22 +{{/velocity}}
23 +
1 1  {{velocity}}
2 2  #set ($discard = $xwiki.ssx.use('contact.WebHome'))
3 3  #set ($xobject = $doc.getObject('Agnease.Code.ContactForm.ContactFormClass'))
4 4  #set ($xclass = $xobject.xWikiClass)
5 5  #set ($editing = true)
6 -= Tell Agnease About Your Project =
7 -Share a few details about your documentation, intranet, workflow, migration, upgrade, or XWiki support need. We will review your request and suggest practical next steps.
29 += Tell Us More About Your Project =
30 +You do not need to have a full specification. A short description is enough to start the conversation.
8 8  {{html clean="false"}}
9 9   <div class="row">
10 10   <div class="xform col-xs-7">
11 - <form>
34 + <form id="contactForm">
12 12   <dl>
13 - #foreach ($property in $xclass.properties)
14 - <dt #if (!$editing && $hasEdit)
15 - class="editableProperty"
16 - #set ($xobjectPropertyReference = $xobject.getPropertyReference($property.name))
17 - data-property="$escapetool.xml($services.model.serialize($xobjectPropertyReference))"
18 - data-property-type="object"#end>
19 - ## This must match the id generated by the $doc.display() method below.
20 - #set ($propertyId = "${xclass.name}_${xobject.number}_$property.name")
21 - <label#if ($editing) for="$escapetool.xml($propertyId)"#end>
22 - $escapetool.xml($property.translatedPrettyName)
23 - </label>
24 - ## Support for specifying a translation key as hint in the property definition.
25 - <span class="xHint">$!escapetool.xml($services.localization.render($property.hint))</span>
26 - </dt>
27 - <dd>$doc.display($property.name, 'edit').replace('{{html clean="false" wiki="false"}}', '').replace("{{/html}}", '')</dd>
28 - #end
29 - #if (!$xclass.properties || $xclass.properties.size() == 0)
30 - ## Keep the empty definition term in order to have valid HTML.
31 - <dt></dt>
32 - <dd>$escapetool.xml($services.localization.render('xclass.defaultObjectSheet.noProperties'))</dd>
33 - #end
36 + #foreach ($property in $xclass.properties)
37 + #if ($property.name == 'hosting')
38 + <hr>
39 + <h3>Optional project details</h3>
40 + <p>These details help us understand the scope and suggest practical next steps.</p>
41 + #end
42 + <dt #if (!$editing && $hasEdit)
43 + class="editableProperty"
44 + #set ($xobjectPropertyReference = $xobject.getPropertyReference($property.name))
45 + data-property="$escapetool.xml($services.model.serialize($xobjectPropertyReference))"
46 + data-property-type="object"#end>
47 + ## This must match the id generated by the $doc.display() method below.
48 + #set ($propertyId = "${xclass.name}_${xobject.number}_$property.name")
49 + <label#if ($editing) for="$escapetool.xml($propertyId)"#end>
50 + $escapetool.xml($property.translatedPrettyName)
51 + </label>
52 + ## Support for specifying a translation key as hint in the property definition.
53 + <span class="xHint">$!escapetool.xml($services.localization.render($property.hint))</span>
54 + </dt>
55 + <dd>$doc.display($property.name, 'edit').replace('{{html clean="false" wiki="false"}}', '').replace("{{/html}}", '')</dd>
56 + #end
57 + #if (!$xclass.properties || $xclass.properties.size() == 0)
58 + ## Keep the empty definition term in order to have valid HTML.
59 + <dt></dt>
60 + <dd>$escapetool.xml($services.localization.render('xclass.defaultObjectSheet.noProperties'))</dd>
61 + #end
34 34   </dl>
35 - <p>Your information will only be used to respond to this request. See the Privacy Policy for details.</p>
36 - <input type="submit" class="btn btn-primary" value="Send my request">
63 + <p>Your information will only be used to respond to this request.</p>
64 + ##<p>Your information will only be used to respond to this request. See the Privacy Policy for details.</p>
65 + <input id="contactSubmit" type="submit" class="btn btn-primary" value="Send my request">
37 37   </form>
67 + {{/html}}
68 + {{html clean="false" wiki="true"}}
69 + <div class="reviewNotifications">
70 + <div class="hidden reviewNotificationSuccess">
71 +
72 + {{success}}reviewNotification{{/success}}
73 +
74 + </div>
75 + <div class="hidden reviewNotificationError">
76 +
77 + {{error}}reviewNotification{{/error}}
78 +
79 + </div>
80 + </div>
81 + {{/html}}
82 + {{html clean="false"}}
38 38   </div>
39 39   <div class="col-xs-5">
40 40   <div class="widget">
... ... @@ -41,8 +41,7 @@
41 41   <h4>$services.icon.renderHTML('check') How Agnease can help</h4>
42 42   <ul>
43 43   <li>XWiki upgrades and long-term maintenance</li>
44 - <li>Knowledge bases and internal portals</li>
45 - <li>SOP, approval, and documentation workflows</li>
89 + <li>Knowledge bases, intranets, SOP and documentation workflows</li>
46 46   <li>Custom XWiki applications and integrations</li>
47 47   <li>LDAP, SSO, OIDC, SAML, and MFA setup</li>
48 48   <li>Migrations from SharePoint, Confluence, MediaWiki, or file-based documentation</li>
... ... @@ -49,7 +49,6 @@
49 49   <li>Security-aware reviews and platform stabilization</li>
50 50   </ul>
51 51   </div>
52 -
53 53   <div class="widget">
54 54   <h4>$services.icon.renderHTML('right') What happens next?</h4>
55 55   <ol>
... ... @@ -58,20 +58,7 @@
58 58   <li>If useful, we schedule a short call to discuss scope, timeline, and estimated effort.</li>
59 59   </ol>
60 60   </div>
61 -
62 - <div class="widget">
63 - <h4>$services.icon.renderHTML('envelope') Prefer direct email?</h4>
64 - <p>
65 - For project inquiries, upgrade requests, or support discussions, you can contact Agnease directly.
66 - </p>
67 - <p class="email-highlight">
68 - <a href="mailto:alex@agnease.com">alex@agnease.com</a>
69 - </p>
70 - <p>
71 - Based in Romania, working remotely with international clients.
72 - </p>
73 - </div>
74 74   </div>
75 - </div
105 + </div>
76 76  {{/html}}
77 77  {{/velocity}}
Agnease.Code.ContactForm.ContactFormClass[0]
organizationType
... ... @@ -1,1 +1,0 @@
1 -1
XWiki.StyleSheetExtension[0]
code
... ... @@ -1,5 +1,22 @@
1 +@brand: #00937D;
2 +@brand-strong: #007B6A;
3 +@text: #2D3A34;
4 +@muted: #5B6B64;
5 +@line: #E4ECE9;
6 +@radius: 16px;
7 +@shadow-sm: 0 6px 20px rgba(0,0,0,.06);
8 +@shadow: 0 12px 36px rgba(0,0,0,.08);
9 +@maxw: 1140px;
10 +
1 1  /* ===== Contact page widgets ===== */
12 +#mainContentArea {
13 + padding: 0;
14 +}
2 2  
16 +.col-xs-5 {
17 + padding-top: 45px;
18 +}
19 +
3 3  .col-xs-5 .widget {
4 4   margin-bottom: 16px;
5 5   padding: 16px;
... ... @@ -49,23 +49,3 @@
49 49   color: @brand;
50 50   font-weight: 700;
51 51  }
52 -
53 -.col-xs-5 .widget .email-highlight {
54 - margin: 10px 0;
55 -}
56 -
57 -.col-xs-5 .widget .email-highlight a {
58 - display: inline-block;
59 - padding: 6px 10px;
60 - border-radius: 8px;
61 - background: fade(@brand, 8%);
62 - border: 1px solid fade(@brand, 18%);
63 - text-decoration: none;
64 -}
65 -
66 -.col-xs-5 .widget .email-highlight a:hover,
67 -.col-xs-5 .widget .email-highlight a:focus {
68 - background: fade(@brand, 12%);
69 - color: @brand-strong;
70 - text-decoration: none;
71 -}
XWiki.JavaScriptExtension[0]
cache
... ... @@ -1,0 +1,1 @@
1 +long
code
... ... @@ -1,0 +1,40 @@
1 +require(['jquery'], function ($) {
2 + var serviceURL = new XWiki.Document('WebHome', 'contact').getURL('get');
3 + var form = $('#contactForm');
4 + var submitButton = $('#contactSubmit');
5 +
6 + var successBox = $('.reviewNotificationSuccess');
7 + var errorBox = $('.reviewNotificationError');
8 +
9 + form.on('submit', function (event) {
10 + event.preventDefault();
11 +
12 + var data = $.param(form.serializeArray());
13 +
14 + submitButton.prop('disabled', true);
15 +
16 + $.post({
17 + url: serviceURL,
18 + data: data
19 + }).done(function (response) {
20 + // replace with succcess message alert(response.message || 'Your request was sent successfully.');
21 + //var message = 'The request could not be sent. Please try again or contact Agnease by email.';
22 + var successBoxContent = successBox.find('.box div p');
23 + successBoxContent.text(data.message);
24 + successBox.toggleClass('hidden');
25 + if (errorBox.is(':visible')) {
26 + errorBox.toggleClass('hidden');
27 + }
28 + form[0].reset();
29 + }).fail(function (xhr) {
30 + var errorBoxContent = errorBox.find('.box div p');
31 + errorBoxContent.text(xhr.statusText);
32 + errorBox.toggleClass('hidden');
33 + if (successBox.is(':visible')) {
34 + successBox.toggleClass('hidden');
35 + }
36 + }).always(function () {
37 + submitButton.prop('disabled', false);
38 + });
39 + });
40 +});
use
... ... @@ -1,0 +1,1 @@
1 +currentPage