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

From version 13.107
edited by Alex Cotiugă
on 2026/05/02 08:28
Change comment: There is no comment for this version
To version 13.88
edited by Alex Cotiugă
on 2026/05/02 08:14
Change comment: There is no comment for this version

Summary

Details

Page properties
Content
... ... @@ -41,22 +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 - {{/html}}
59 - {{html clean="false"}}
60 60   </div>
61 61   <div class="col-xs-5">
62 62   <div class="widget">
... ... @@ -78,6 +78,18 @@
78 78   <li>If useful, we schedule a short call to discuss scope, timeline, and estimated effort.</li>
79 79   </ol>
80 80   </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>
81 81   </div>
82 82   </div>
83 83  {{/html}}
XWiki.JavaScriptExtension[0]
code
... ... @@ -20,13 +20,30 @@
20 20   return data;
21 21   }
22 22  
23 + function isValidEmail(value) {
24 + return /^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(value);
25 + }
26 +
27 + function updateSubmitState() {
28 + var data = getFormData();
29 + var name = $.trim(data[nameFieldName] || '');
30 + var email = $.trim(data[emailFieldName] || '');
31 +
32 + submitButton.prop('disabled', !(name.length > 0 && isValidEmail(email)));
33 + }
34 +
35 + form.on('input change keyup', 'input, textarea, select', updateSubmitState);
36 + updateSubmitState();
37 +
23 23   form.on('submit', function (event) {
24 24   event.preventDefault();
25 25  
26 - var data = $.param(form.serializeArray());
41 + var data = getFormData();
42 +
43 + console.log(data)
27 27  
28 28   submitButton.prop('disabled', true);
29 -
46 +/*
30 30   $.post({
31 31   url: serviceURL,
32 32   data: data
... ... @@ -47,8 +47,7 @@
47 47   if (successBox.is(':visible')) {
48 48   successBox.toggleClass('hidden');
49 49   }
50 - }).always(function () {
51 51   submitButton.prop('disabled', false);
52 - });
68 + });*/
53 53   });
54 54  });