-
Notifications
You must be signed in to change notification settings - Fork 0
/
jquery-unobtrusive-ajax.js
83 lines (67 loc) · 2.07 KB
/
jquery-unobtrusive-ajax.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
$(function () {
bindUnobtrusiveAjax();
});
function bindUnobtrusiveAjax() {
var activatedElements = $('[data-ajax="true"]');
activatedElements.not('form').on('click', function (event) {
makeAjaxRequest(this);
});
activatedElements.filter('form').on('submit', function (event) {
event.preventDefault();
makeAjaxRequest(this);
return false;
});
}
function makeAjaxRequest(element) {
var ajaxMethod = $(element).data('ajax-method');
if (!ajaxMethod)
ajaxMethod = "get";
var ajaxMode = $(element).data('ajax-mode');
if (!ajaxMode)
ajaxMode = "replace";
var ajaxLoading = $(element).data('ajax-loading');
var ajaxComplete = $(element).data('ajax-complete');
var ajaxFailure = $(element).data('ajax-failure');
var ajaxUpdate = $(element).data('ajax-update');
var ajaxUrl = $(element).data('ajax-url');
if (!ajaxUrl)
ajaxUrl = window.location.href;
var request = null;
if (ajaxLoading)
$(ajaxLoading).show();
if (ajaxMethod === "get") {
request = Ajax.Get(ajaxUrl, {}, "html");
}
else if (ajaxMethod === "post") {
request = Ajax.PostForm(element, ajaxUrl, "html");
}
request.always(function () {
$(ajaxLoading).hide();
});
request.done(function (data) {
if (ajaxUpdate) {
switch (ajaxMode) {
case "before":
$(ajaxUpdate).prepend(data);
break;
case "afer":
$(ajaxUpdate).append(data);
break;
default:
$(ajaxUpdate).empty();
$(ajaxUpdate).append(data);
break;
}
}
bindUnobtrusiveAjax();
if (ajaxComplete)
window[ajaxComplete](data);
});
request.fail(function (error) {
$(ajaxUpdate).empty();
$(ajaxUpdate).append(error.responseText);
if (ajaxFailure)
window[ajaxFailure](error);
bindUnobtrusiveAjax();
});
}