Last modified by Alex Cotiugă on 2026/05/02 12:23

From version 13.44
edited by Alex Cotiugă
on 2026/05/02 07:01
Change comment: There is no comment for this version
To version 13.80
edited by Alex Cotiugă
on 2026/05/02 08:08
Change comment: There is no comment for this version

Summary

Details

Page properties
Content
... ... @@ -4,7 +4,7 @@
4 4  #set ($xclass = $xobject.xWikiClass)
5 5  #set ($editing = true)
6 6  = Tell Us More About Your Project =
7 -Share a few details about your documentation, intranet, migration, upgrade, integration, support, or custom development need. We will review your request and suggest practical next steps.
7 +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,6 +11,11 @@
11 11   <form id="contactForm">
12 12   <dl>
13 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>
18 + #end
14 14   <dt #if (!$editing && $hasEdit)
15 15   class="editableProperty"
16 16   #set ($xobjectPropertyReference = $xobject.getPropertyReference($property.name))
... ... @@ -42,8 +42,7 @@
42 42   <h4>$services.icon.renderHTML('check') How Agnease can help</h4>
43 43   <ul>
44 44   <li>XWiki upgrades and long-term maintenance</li>
45 - <li>Knowledge bases and internal portals</li>
46 - <li>SOP, approval, and documentation workflows</li>
50 + <li>Knowledge bases, intranets, SOP and documentation workflows</li>
47 47   <li>Custom XWiki applications and integrations</li>
48 48   <li>LDAP, SSO, OIDC, SAML, and MFA setup</li>
49 49   <li>Migrations from SharePoint, Confluence, MediaWiki, or file-based documentation</li>
... ... @@ -58,6 +58,18 @@
58 58   <li>If useful, we schedule a short call to discuss scope, timeline, and estimated effort.</li>
59 59   </ol>
60 60   </div>
65 + <div class="reviewNotifications">
66 + <div class="hidden reviewNotificationSuccess">
67 +
68 + {{success}}reviewNotification{{/success}}
69 +
70 + </div>
71 + <div class="hidden reviewNotificationError">
72 +
73 + {{error}}reviewNotification{{/error}}
74 +
75 + </div>
76 + </div>
61 61   </div>
62 62   </div>
63 63  {{/html}}
Agnease.Code.ContactForm.ContactFormClass[0]
organizationType
... ... @@ -1,1 +1,0 @@
1 -1
XWiki.JavaScriptExtension[0]
code
... ... @@ -1,0 +1,65 @@
1 +require(['jquery'], function ($) {
2 + var serviceURL = new XWiki.Document('WebHome', 'content').getURL('get', 'xpage=plain');
3 + var form = $('#contactForm');
4 + var submitButton = $('#contactSubmit');
5 +
6 + console.log(submitButton)
7 + var successBox = $('.reviewNotificationSuccess');
8 + var errorBox = $('.reviewNotificationError');
9 +
10 + function getFormData() {
11 + var data = {};
12 +
13 + $.each(form.serializeArray(), function (_, field) {
14 + data[field.name] = field.value;
15 + });
16 +
17 + return data;
18 + }
19 +
20 + function isValidEmail(value) {
21 + return /^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(value);
22 + }
23 +
24 + /*function updateSubmitState() {
25 + var data = getFormData();
26 + var name = $.trim(data[fields.name] || '');
27 + var email = $.trim(data[fields.email] || '');
28 +
29 + submitButton.prop('disabled', !(name.length > 0 && isValidEmail(email)));
30 + }*/
31 +
32 + /*form.on('input change keyup', 'input, textarea, select', updateSubmitState);
33 + updateSubmitState();
34 +*/
35 + form.on('submit', function (event) {
36 + event.preventDefault();
37 +
38 + var data = getFormData();
39 +
40 + submitButton.prop('disabled', true);
41 +
42 + $.post({
43 + url: serviceURL,
44 + data: data
45 + }).done(function (response) {
46 + // replace with succcess message alert(response.message || 'Your request was sent successfully.');
47 + //var message = 'The request could not be sent. Please try again or contact Agnease by email.';
48 + var successBoxContent = successBox.find('.box div p');
49 + successBoxContent.text(data.message);
50 + successBox.toggleClass('hidden');
51 + if (errorBox.is(':visible')) {
52 + errorBox.toggleClass('hidden');
53 + }
54 + form[0].reset();
55 + }).fail(function (xhr) {
56 + var errorBoxContent = errorBox.find('.box div p');
57 + errorBoxContent.text(xhr.responseJSON.message);
58 + errorBox.toggleClass('hidden');
59 + if (successBox.is(':visible')) {
60 + successBox.toggleClass('hidden');
61 + }
62 + submitButton.prop('disabled', false);
63 + });
64 + });
65 +});