Changes for page Get in Touch About Your XWiki Project
Last modified by Alex Cotiugă on 2026/05/02 12:23
From version 13.64
edited by Alex Cotiugă
on 2026/05/02 07:57
on 2026/05/02 07:57
Change comment:
There is no comment for this version
To version 13.84
edited by Alex Cotiugă
on 2026/05/02 08:11
on 2026/05/02 08:11
Change comment:
There is no comment for this version
Summary
-
Page properties (1 modified, 0 added, 0 removed)
-
Objects (1 modified, 0 added, 0 removed)
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" disabled="disabled">42 + <input id="contactSubmit" type="submit" class="btn btn-primary" value="Send my request"> 43 43 </form> 44 44 </div> 45 45 <div class="col-xs-5">
- XWiki.JavaScriptExtension[0]
-
- code
-
... ... @@ -1,8 +1,11 @@ 1 1 require(['jquery'], function ($) { 2 2 var serviceURL = new XWiki.Document('WebHome', 'content').getURL('get', 'xpage=plain'); 3 - var form = $('# agneaseContactForm');4 - var submitButton = $('# agneaseContactSubmit');3 + var form = $('#contactForm'); 4 + var submitButton = $('#contactSubmit'); 5 5 6 + var successBox = $('.reviewNotificationSuccess'); 7 + var errorBox = $('.reviewNotificationError'); 8 + 6 6 function getFormData() { 7 7 var data = {}; 8 8 ... ... @@ -9,10 +9,26 @@ 9 9 $.each(form.serializeArray(), function (_, field) { 10 10 data[field.name] = field.value; 11 11 }); 15 + console.log(data) 12 12 13 13 return data; 14 14 } 15 15 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 + 16 16 form.on('submit', function (event) { 17 17 event.preventDefault(); 18 18 ... ... @@ -25,17 +25,21 @@ 25 25 data: data 26 26 }).done(function (response) { 27 27 // replace with succcess message alert(response.message || 'Your request was sent successfully.'); 47 + //var message = 'The request could not be sent. Please try again or contact Agnease by email.'; 48 + var successBoxContent = successBox.find('.box div p'); 49 + successBoxContent.text(data.message); 50 + successBox.toggleClass('hidden'); 51 + if (errorBox.is(':visible')) { 52 + errorBox.toggleClass('hidden'); 53 + } 28 28 form[0].reset(); 29 29 }).fail(function (xhr) { 30 - var message = 'The request could not be sent. Please try again or contact Agnease by email.'; 31 - 32 - if (xhr.responseJSON && xhr.responseJSON.message) { 33 - message = xhr.responseJSON.message; 34 - } else if (xhr.responseText) { 35 - message = xhr.responseText; 56 + var errorBoxContent = errorBox.find('.box div p'); 57 + errorBoxContent.text(xhr.responseJSON.message); 58 + errorBox.toggleClass('hidden'); 59 + if (successBox.is(':visible')) { 60 + successBox.toggleClass('hidden'); 36 36 } 37 - 38 - // replace with error box message alert(message); 39 39 submitButton.prop('disabled', false); 40 40 }); 41 41 });