Changes for page Get in Touch About Your XWiki Project
Last modified by Alex Cotiugă on 2026/05/11 05:57
From version 13.61
edited by Alex Cotiugă
on 2026/05/02 07:42
on 2026/05/02 07:42
Change comment:
There is no comment for this version
To version 15.30
edited by Alex Cotiugă
on 2026/05/11 05:54
on 2026/05/11 05:54
Change comment:
There is no comment for this version
Summary
-
Page properties (1 modified, 0 added, 0 removed)
-
Objects (1 modified, 1 added, 1 removed)
Details
- Page properties
-
- Content
-
... ... @@ -1,68 +1,121 @@ 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.getDocumentAsAuthor('ContactRequests.' + $uniqueName)) 8 + #set ($contactRequestObj = $contactRequestDoc.getObject('Agnease.Code.ContactRequest.ContactRequestClass', true)) 9 + #set ($statusCode = 200) 10 + #set ($message = 'Your request was successfully sent.') 11 + 12 + ##var message = 'The request could not be sent. Please try again or contact Agnease by email.'; 13 + 14 + #foreach ($parameterName in $request.parameterNames) 15 + #set ($discard = $contactRequestObj.set("$parameterName.split('_0_')[1]", $request.get($parameterName))) 16 + ##set ($message = "$message $parameterName.split('_0_')[1] : $request.get($parameterName)") 17 + #end 18 + 19 + #set ($discard = $contactRequestDoc.saveAsAuthor()) 20 + 21 + #set ($message = "$message") 22 + 23 + ##set ($statusCode = 400) 24 + ##set ($message = 'error') 25 + 26 + #set ($discard = $response.setStatus($statusCode)) 27 + #jsonResponse({'message': $message}) 28 +#end 29 +{{/velocity}} 30 + 1 1 {{velocity}} 2 2 #set ($discard = $xwiki.ssx.use('contact.WebHome')) 3 -#set ($xobject = $doc.getObject('Agnease.Code.ContactForm.ContactFormClass')) 4 -#set ($xclass = $xobject.xWikiClass) 5 -#set ($editing = true) 6 -= Tell Us More About Your Project = 7 -You do not need to have a full specification. A short description is enough to start the conversation. 8 -{{html clean="false"}} 9 - <div class="row"> 10 - <div class="xform col-xs-7"> 11 - <form id="contactForm"> 12 - <dl> 13 - #foreach ($property in $xclass.properties) 14 - #if ($property.name == 'hosting') 15 - <hr> 16 - <h3>Optional project details</h3> 17 - <p>These details help us understand the scope and suggest practical next steps.</p> 33 +#set ($xobject = $doc.getObject('Agnease.Code.ContactRequest.ContactRequestClass')) 34 +#set ($totalRequests = $services.query.xwql('from doc.object(Agnease.Code.ContactRequest.ContactRequestClass) contact').execute()) 35 +##$totalRequests.size() 36 +#if ($totalRequest.size() > 50) 37 + ## As a measure to avoid high load on website. 38 + Tell us more about your project at alex@agnease.com. 39 +#else 40 + #set ($xclass = $xobject.xWikiClass) 41 + #set ($editing = true) 42 + = Tell Us More About Your Project = 43 + You do not need to have a full specification. A short description is enough to start the conversation. 44 + {{html clean="false"}} 45 + <div class="row"> 46 + <div class="xform col-md-7"> 47 + <form id="contactForm"> 48 + <dl> 49 + #foreach ($property in $xclass.properties) 50 + #if ($property.name == 'hosting') 51 + <hr> 52 + <h3>Optional project details</h3> 53 + <p>These details help us understand the scope and suggest practical next steps.</p> 54 + #end 55 + <dt #if (!$editing && $hasEdit) 56 + class="editableProperty" 57 + #set ($xobjectPropertyReference = $xobject.getPropertyReference($property.name)) 58 + data-property="$escapetool.xml($services.model.serialize($xobjectPropertyReference))" 59 + data-property-type="object"#end> 60 + ## This must match the id generated by the $doc.display() method below. 61 + #set ($propertyId = "${xclass.name}_${xobject.number}_$property.name") 62 + <label#if ($editing) for="$escapetool.xml($propertyId)"#end> 63 + $escapetool.xml($property.translatedPrettyName) 64 + </label> 65 + ## Support for specifying a translation key as hint in the property definition. 66 + <span class="xHint">$!escapetool.xml($services.localization.render($property.hint))</span> 67 + </dt> 68 + <dd>$doc.display($property.name, 'edit').replace('{{html clean="false" wiki="false"}}', '').replace("{{/html}}", '')</dd> 18 18 #end 19 - <dt #if (!$editing && $hasEdit) 20 - class="editableProperty" 21 - #set ($xobjectPropertyReference = $xobject.getPropertyReference($property.name)) 22 - data-property="$escapetool.xml($services.model.serialize($xobjectPropertyReference))" 23 - data-property-type="object"#end> 24 - ## This must match the id generated by the $doc.display() method below. 25 - #set ($propertyId = "${xclass.name}_${xobject.number}_$property.name") 26 - <label#if ($editing) for="$escapetool.xml($propertyId)"#end> 27 - $escapetool.xml($property.translatedPrettyName) 28 - </label> 29 - ## Support for specifying a translation key as hint in the property definition. 30 - <span class="xHint">$!escapetool.xml($services.localization.render($property.hint))</span> 31 - </dt> 32 - <dd>$doc.display($property.name, 'edit').replace('{{html clean="false" wiki="false"}}', '').replace("{{/html}}", '')</dd> 33 - #end 34 - #if (!$xclass.properties || $xclass.properties.size() == 0) 35 - ## Keep the empty definition term in order to have valid HTML. 36 - <dt></dt> 37 - <dd>$escapetool.xml($services.localization.render('xclass.defaultObjectSheet.noProperties'))</dd> 38 - #end 39 - </dl> 40 - <p>Your information will only be used to respond to this request.</p> 41 - ##<p>Your information will only be used to respond to this request. See the Privacy Policy for details.</p> 42 - <input id="contactSubmit" type="submit" class="btn btn-primary" value="Send my request" disabled="disabled"> 43 - </form> 44 - </div> 45 - <div class="col-xs-5"> 46 - <div class="widget"> 47 - <h4>$services.icon.renderHTML('check') How Agnease can help</h4> 48 - <ul> 49 - <li>XWiki upgrades and long-term maintenance</li> 50 - <li>Knowledge bases, intranets, SOP and documentation workflows</li> 51 - <li>Custom XWiki applications and integrations</li> 52 - <li>LDAP, SSO, OIDC, SAML, and MFA setup</li> 53 - <li>Migrations from SharePoint, Confluence, MediaWiki, or file-based documentation</li> 54 - <li>Security-aware reviews and platform stabilization</li> 55 - </ul> 70 + #if (!$xclass.properties || $xclass.properties.size() == 0) 71 + ## Keep the empty definition term in order to have valid HTML. 72 + <dt></dt> 73 + <dd>$escapetool.xml($services.localization.render('xclass.defaultObjectSheet.noProperties'))</dd> 74 + #end 75 + </dl> 76 + <p>Your information will only be used to respond to this request.</p> 77 + ##<p>Your information will only be used to respond to this request. See the Privacy Policy for details.</p> 78 + <input id="contactSubmit" type="submit" class="btn btn-primary" value="Send my request"> 79 + </form> 80 + {{/html}} 81 + {{html clean="false" wiki="true"}} 82 + <div class="reviewNotifications"> 83 + <div class="hidden reviewNotificationSuccess"> 84 + 85 + {{success}}reviewNotification{{/success}} 86 + 87 + </div> 88 + <div class="hidden reviewNotificationError"> 89 + 90 + {{error}}reviewNotification{{/error}} 91 + 92 + </div> 93 + </div> 94 + {{/html}} 95 + {{html clean="false"}} 56 56 </div> 57 - <div class="widget"> 58 - <h4>$services.icon.renderHTML('right') What happens next?</h4> 59 - <ol> 60 - <li>Your request is reviewed.</li> 61 - <li>You receive a reply with clarifying questions or suggested next steps.</li> 62 - <li>If useful, we schedule a short call to discuss scope, timeline, and estimated effort.</li> 63 - </ol> 97 + <div class="col-md-5"> 98 + <div class="widget"> 99 + <h4>$services.icon.renderHTML('check') How Agnease can help</h4> 100 + <ul> 101 + <li>XWiki upgrades and long-term maintenance</li> 102 + <li>Knowledge bases, intranets, SOP and documentation workflows</li> 103 + <li>Custom XWiki applications and integrations</li> 104 + <li>LDAP, SSO, OIDC, SAML, and MFA setup</li> 105 + <li>Migrations from SharePoint, Confluence, MediaWiki, or file-based documentation</li> 106 + <li>Security-aware reviews and platform stabilization</li> 107 + </ul> 108 + </div> 109 + <div class="widget"> 110 + <h4>$services.icon.renderHTML('right') What happens next?</h4> 111 + <ol> 112 + <li>Your request is reviewed.</li> 113 + <li>You receive a reply with clarifying questions or suggested next steps.</li> 114 + <li>If useful, we schedule a short call to discuss scope, timeline, and estimated effort.</li> 115 + </ol> 116 + </div> 64 64 </div> 65 65 </div> 66 - </div>67 - {{/html}}119 + {{/html}} 120 +#end 68 68 {{/velocity}}
- Agnease.Code.ContactForm.ContactFormClass[0]
-
- alreadyUseXWiki
-
... ... @@ -1,1 +1,0 @@ 1 -1 - customDevelopment
-
... ... @@ -1,1 +1,0 @@ 1 -1 - hosting
-
... ... @@ -1,1 +1,0 @@ 1 -1 - users
-
... ... @@ -1,1 +1,0 @@ 1 -1
- XWiki.JavaScriptExtension[0]
-
- code
-
... ... @@ -1,22 +1,15 @@ 1 1 require(['jquery'], function ($) { 2 - var serviceURL = new XWiki.Document('WebHome', 'cont ent').getURL('get', 'xpage=plain');3 - var form = $('# agneaseContactForm');4 - var submitButton = $('# agneaseContactSubmit');2 + var serviceURL = new XWiki.Document('WebHome', 'contact').getURL('get'); 3 + var form = $('#contactForm'); 4 + var submitButton = $('#contactSubmit'); 5 5 6 - functiongetFormData(){7 - vardata={};6 + var successBox = $('.reviewNotificationSuccess'); 7 + var errorBox = $('.reviewNotificationError'); 8 8 9 - $.each(form.serializeArray(), function (_, field) { 10 - data[field.name] = field.value; 11 - }); 12 - 13 - return data; 14 - } 15 - 16 16 form.on('submit', function (event) { 17 17 event.preventDefault(); 18 18 19 - var data = getFormData();12 + var data = $.param(form.serializeArray()); 20 20 21 21 submitButton.prop('disabled', true); 22 22 ... ... @@ -23,19 +23,22 @@ 23 23 $.post({ 24 24 url: serviceURL, 25 25 data: data 26 - }).done(function (response) { 27 - // replace with succcess message alert(response.message || 'Your request was sent successfully.'); 19 + }).done(function (data) { 20 + var successBoxContent = successBox.find('.box div p'); 21 + successBoxContent.text(data.message); 22 + successBox.toggleClass('hidden'); 23 + if (errorBox.is(':visible')) { 24 + errorBox.toggleClass('hidden'); 25 + } 28 28 form[0].reset(); 29 29 }).fail(function (xhr) { 30 - var message = 'The request could not be sent. Please try again or contact Agnease by email.'; 31 - 32 - if (xhr.responseJSON && xhr.responseJSON.message) { 33 - message = xhr.responseJSON.message; 34 - } else if (xhr.responseText) { 35 - message = xhr.responseText; 28 + var errorBoxContent = errorBox.find('.box div p'); 29 + errorBoxContent.text(xhr.statusText); 30 + errorBox.toggleClass('hidden'); 31 + if (successBox.is(':visible')) { 32 + successBox.toggleClass('hidden'); 36 36 } 37 - 38 - // replace with error box message alert(message); 34 + }).always(function () { 39 39 submitButton.prop('disabled', false); 40 40 }); 41 41 });
- Agnease.Code.ContactRequest.ContactRequestClass[0]
-
- alreadyUseXWiki
-
... ... @@ -1,0 +1,1 @@ 1 +1 - hosting
-
... ... @@ -1,0 +1,1 @@ 1 +1