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

From version 13.104
edited by Alex Cotiugă
on 2026/05/02 08:28
Change comment: There is no comment for this version
To version 13.84
edited by Alex Cotiugă
on 2026/05/02 08:11
Change comment: There is no comment for this version

Summary

Details

Page properties
Content
... ... @@ -41,20 +41,6 @@
41 41   ##<p>Your information will only be used to respond to this request. See the Privacy Policy for details.</p>
42 42   <input id="contactSubmit" type="submit" class="btn btn-primary" value="Send my request">
43 43   </form>
44 - {{/html}}
45 - {{html clean="false" wiki="true"}}
46 - <div class="reviewNotifications">
47 - <div class="hidden reviewNotificationSuccess">
48 -
49 - {{success}}reviewNotification{{/success}}
50 -
51 - </div>
52 - <div class="hidden reviewNotificationError">
53 -
54 - {{error}}reviewNotification{{/error}}
55 -
56 - </div>
57 - </div>
58 58   </div>
59 59   <div class="col-xs-5">
60 60   <div class="widget">
... ... @@ -76,6 +76,18 @@
76 76   <li>If useful, we schedule a short call to discuss scope, timeline, and estimated effort.</li>
77 77   </ol>
78 78   </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>
79 79   </div>
80 80   </div>
81 81  {{/html}}
XWiki.JavaScriptExtension[0]
code
... ... @@ -6,9 +6,6 @@
6 6   var successBox = $('.reviewNotificationSuccess');
7 7   var errorBox = $('.reviewNotificationError');
8 8  
9 - var nameFieldName = 'Agnease.Code.ContactForm.ContactFormClass_0_name';
10 - var emailFieldName = 'Agnease.Code.ContactForm.ContactFormClass_0_email';
11 -
12 12   function getFormData() {
13 13   var data = {};
14 14  
... ... @@ -20,10 +20,25 @@
20 20   return data;
21 21   }
22 22  
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 +
23 23   form.on('submit', function (event) {
24 24   event.preventDefault();
25 25  
26 - var data = $.param(form.serializeArray());
38 + var data = getFormData();
27 27  
28 28   submitButton.prop('disabled', true);
29 29  
... ... @@ -47,7 +47,6 @@
47 47   if (successBox.is(':visible')) {
48 48   successBox.toggleClass('hidden');
49 49   }
50 - }).always(function () {
51 51   submitButton.prop('disabled', false);
52 52   });
53 53   });