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

From version 13.60
edited by Alex Cotiugă
on 2026/05/02 07:40
Change comment: There is no comment for this version
To version 13.77
edited by Alex Cotiugă
on 2026/05/02 08:07
Change comment: There is no comment for this version

Summary

Details

Page properties
Content
... ... @@ -62,6 +62,18 @@
62 62   <li>If useful, we schedule a short call to discuss scope, timeline, and estimated effort.</li>
63 63   </ol>
64 64   </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>
65 65   </div>
66 66   </div>
67 67  {{/html}}
XWiki.JavaScriptExtension[0]
code
... ... @@ -1,8 +1,12 @@
1 1  require(['jquery'], function ($) {
2 2   var serviceURL = new XWiki.Document('WebHome', 'content').getURL('get', 'xpage=plain');
3 - var form = $('#agneaseContactForm');
4 - var submitButton = $('#agneaseContactSubmit');
3 + var form = $('#contactForm');
4 + var submitButton = $('#contactSubmit');
5 5  
6 + console.log(serviceURL)
7 + var successBox = $('.reviewNotificationSuccess');
8 + var errorBox = $('.reviewNotificationError');
9 +
6 6   function getFormData() {
7 7   var data = {};
8 8  
... ... @@ -13,6 +13,21 @@
13 13   return data;
14 14   }
15 15  
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 +
16 16   form.on('submit', function (event) {
17 17   event.preventDefault();
18 18  
... ... @@ -22,21 +22,24 @@
22 22  
23 23   $.post({
24 24   url: serviceURL,
25 - data: data,
26 - dataType: 'json'
44 + data: data
27 27   }).done(function (response) {
28 - alert(response.message || 'Your request was sent successfully.');
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 + }
29 29   form[0].reset();
30 30   }).fail(function (xhr) {
31 - var message = 'The request could not be sent. Please try again or contact Agnease by email.';
32 -
33 - if (xhr.responseJSON && xhr.responseJSON.message) {
34 - message = xhr.responseJSON.message;
35 - } else if (xhr.responseText) {
36 - message = xhr.responseText;
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');
37 37   }
38 -
39 - alert(message);
40 40   submitButton.prop('disabled', false);
41 41   });
42 42   });