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

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

Summary

Details

Page properties
Content
... ... @@ -5,7 +5,7 @@
5 5  #set ($editing = true)
6 6  = Tell Us More About Your Project =
7 7  You do not need to have a full specification. A short description is enough to start the conversation.
8 -{{html clean="false"}}
8 +{{html clean="false" wiki="true"}}
9 9   <div class="row">
10 10   <div class="xform col-xs-7">
11 11   <form id="contactForm">
... ... @@ -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
... ... @@ -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  });