Last modified by Alex Cotiugă on 2026/05/04 06:15

From version 13.58
edited by Alex Cotiugă
on 2026/05/02 07:39
Change comment: There is no comment for this version
To version 13.126
edited by Alex Cotiugă
on 2026/05/02 08:34
Change comment: There is no comment for this version

Summary

Details

Page properties
Content
... ... @@ -1,3 +1,17 @@
1 +{{velocity wiki="false"}}
2 +#if ($xcontext.action == 'get')
3 +test
4 + #set ($message = '')
5 + #set ($statusCode = 200)
6 +
7 + #set ($statusCode = 400)
8 + #set ($message = 'error')
9 +
10 + #set ($discard = $response.setStatus($statusCode))
11 + #jsonResponse({'message': $message})
12 +#end
13 +{{/velocity}}
14 +
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">
56 + <input id="contactSubmit" type="submit" class="btn btn-primary" value="Send my request">
43 43   </form>
58 + {{/html}}
59 + {{html clean="false" wiki="true"}}
60 + <div class="reviewNotifications">
61 + <div class="hidden reviewNotificationSuccess">
62 +
63 + {{success}}reviewNotification{{/success}}
64 +
65 + </div>
66 + <div class="hidden reviewNotificationError">
67 +
68 + {{error}}reviewNotification{{/error}}
69 +
70 + </div>
71 + </div>
72 + {{/html}}
73 + {{html clean="false"}}
44 44   </div>
45 45   <div class="col-xs-5">
46 46   <div class="widget">
XWiki.JavaScriptExtension[0]
code
... ... @@ -1,0 +1,41 @@
1 +require(['jquery'], function ($) {
2 + var serviceURL = new XWiki.Document('WebHome', 'content').getURL('get', 'outputSyntax=plain');
3 + console.log(serviceURL)
4 + var form = $('#contactForm');
5 + var submitButton = $('#contactSubmit');
6 +
7 + var successBox = $('.reviewNotificationSuccess');
8 + var errorBox = $('.reviewNotificationError');
9 +
10 + form.on('submit', function (event) {
11 + event.preventDefault();
12 +
13 + var data = $.param(form.serializeArray());
14 +
15 + submitButton.prop('disabled', true);
16 +
17 + $.post({
18 + url: serviceURL,
19 + data: data
20 + }).done(function (response) {
21 + // replace with succcess message alert(response.message || 'Your request was sent successfully.');
22 + //var message = 'The request could not be sent. Please try again or contact Agnease by email.';
23 + var successBoxContent = successBox.find('.box div p');
24 + successBoxContent.text(data.message);
25 + successBox.toggleClass('hidden');
26 + if (errorBox.is(':visible')) {
27 + errorBox.toggleClass('hidden');
28 + }
29 + form[0].reset();
30 + }).fail(function (xhr) {
31 + var errorBoxContent = errorBox.find('.box div p');
32 + errorBoxContent.text(xhr.responseJSON.message);
33 + errorBox.toggleClass('hidden');
34 + if (successBox.is(':visible')) {
35 + successBox.toggleClass('hidden');
36 + }
37 + }).always(function () {
38 + submitButton.prop('disabled', false);
39 + });
40 + });
41 +});