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

From version 13.102
edited by Alex Cotiugă
on 2026/05/02 08:26
Change comment: There is no comment for this version
To version 13.78
edited by Alex Cotiugă
on 2026/05/02 08:07
Change comment: There is no comment for this version

Summary

Details

Page properties
Content
... ... @@ -39,7 +39,7 @@
39 39   </dl>
40 40   <p>Your information will only be used to respond to this request.</p>
41 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">
42 + <input id="contactSubmit" type="submit" class="btn btn-primary" value="Send my request" disabled="disabled">
43 43   </form>
44 44   </div>
45 45   <div class="col-xs-5">
... ... @@ -62,8 +62,6 @@
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 - {{/html}}
66 - {{html clean="false" wiki="true"}}
67 67   <div class="reviewNotifications">
68 68   <div class="hidden reviewNotificationSuccess">
69 69  
XWiki.JavaScriptExtension[0]
code
... ... @@ -3,12 +3,10 @@
3 3   var form = $('#contactForm');
4 4   var submitButton = $('#contactSubmit');
5 5  
6 + console.log(serviceURL)
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  
... ... @@ -15,15 +15,29 @@
15 15   $.each(form.serializeArray(), function (_, field) {
16 16   data[field.name] = field.value;
17 17   });
18 - console.log(data)
19 19  
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   });