Changes for page Get in Touch About Your XWiki Project
Last modified by Alex Cotiugă on 2026/05/04 06:15
From version 13.76
edited by Alex Cotiugă
on 2026/05/02 08:06
on 2026/05/02 08:06
Change comment:
There is no comment for this version
To version 13.144
edited by Alex Cotiugă
on 2026/05/02 08:48
on 2026/05/02 08:48
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
-
... ... @@ -1,3 +1,18 @@ 1 +{{velocity wiki="false"}} 2 +#if ($xcontext.action == 'get') 3 +$request.parameterNames 4 +test 5 + #set ($message = '') 6 + #set ($statusCode = 200) 7 + 8 + #set ($statusCode = 400) 9 + #set ($message = 'error') 10 + 11 + #set ($discard = $response.setStatus($statusCode)) 12 + #jsonResponse({'message': $request}) 13 +#end 14 +{{/velocity}} 15 + 1 1 {{velocity}} 2 2 #set ($discard = $xwiki.ssx.use('contact.WebHome')) 3 3 #set ($xobject = $doc.getObject('Agnease.Code.ContactForm.ContactFormClass')) ... ... @@ -39,8 +39,24 @@ 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">57 + <input id="contactSubmit" type="submit" class="btn btn-primary" value="Send my request"> 43 43 </form> 59 + {{/html}} 60 + {{html clean="false" wiki="true"}} 61 + <div class="reviewNotifications"> 62 + <div class="hidden reviewNotificationSuccess"> 63 + 64 + {{success}}reviewNotification{{/success}} 65 + 66 + </div> 67 + <div class="hidden reviewNotificationError"> 68 + 69 + {{error}}reviewNotification{{/error}} 70 + 71 + </div> 72 + </div> 73 + {{/html}} 74 + {{html clean="false"}} 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
-
... ... @@ -1,41 +1,15 @@ 1 1 require(['jquery'], function ($) { 2 - var serviceURL = new XWiki.Document('WebHome', 'cont ent').getURL('get', 'xpage=plain');2 + var serviceURL = new XWiki.Document('WebHome', 'contact').getURL('get'); 3 3 var form = $('#contactForm'); 4 4 var submitButton = $('#contactSubmit'); 5 5 6 - console.log(serviceURL) 7 7 var successBox = $('.reviewNotificationSuccess'); 8 8 var errorBox = $('.reviewNotificationError'); 9 9 10 - function getFormData() { 11 - var data = {}; 12 - 13 - $.each(form.serializeArray(), function (_, field) { 14 - data[field.name] = field.value; 15 - }); 16 - 17 - return data; 18 - } 19 - 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 - 35 35 form.on('submit', function (event) { 36 36 event.preventDefault(); 37 37 38 - var data = getFormData();12 + var data = $.param(form.serializeArray()); 39 39 40 40 submitButton.prop('disabled', true); 41 41 ... ... @@ -54,11 +54,12 @@ 54 54 form[0].reset(); 55 55 }).fail(function (xhr) { 56 56 var errorBoxContent = errorBox.find('.box div p'); 57 - errorBoxContent.text(xhr. responseJSON.message);31 + errorBoxContent.text(xhr.statusText); 58 58 errorBox.toggleClass('hidden'); 59 59 if (successBox.is(':visible')) { 60 60 successBox.toggleClass('hidden'); 61 61 } 36 + }).always(function () { 62 62 submitButton.prop('disabled', false); 63 63 }); 64 64 });