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

From version 13.85
edited by Alex Cotiugă
on 2026/05/02 08:12
Change comment: There is no comment for this version
To version 13.106
edited by Alex Cotiugă
on 2026/05/02 08:28
Change comment: There is no comment for this version

Summary

Details

Page properties
Content
... ... @@ -41,6 +41,20 @@
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>
44 44   </div>
45 45   <div class="col-xs-5">
46 46   <div class="widget">
... ... @@ -62,18 +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 - <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>
77 77   </div>
78 78   </div>
79 79  {{/html}}
XWiki.JavaScriptExtension[0]
code
... ... @@ -20,25 +20,10 @@
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 -
38 38   form.on('submit', function (event) {
39 39   event.preventDefault();
40 40  
41 - var data = getFormData();
26 + var data = $.param(form.serializeArray());
42 42  
43 43   submitButton.prop('disabled', true);
44 44  
... ... @@ -62,6 +62,7 @@
62 62   if (successBox.is(':visible')) {
63 63   successBox.toggleClass('hidden');
64 64   }
50 + }).always(function () {
65 65   submitButton.prop('disabled', false);
66 66   });
67 67   });