2018-05-09 12:01:36 +05:30
|
|
|
import $ from 'jquery';
|
|
|
|
|
2018-03-17 18:26:18 +05:30
|
|
|
export default class AjaxLoadingSpinner {
|
2017-08-17 22:00:37 +05:30
|
|
|
static init() {
|
|
|
|
const $elements = $('.js-ajax-loading-spinner');
|
|
|
|
|
|
|
|
$elements.on('ajax:beforeSend', AjaxLoadingSpinner.ajaxBeforeSend);
|
|
|
|
$elements.on('ajax:complete', AjaxLoadingSpinner.ajaxComplete);
|
|
|
|
}
|
|
|
|
|
|
|
|
static ajaxBeforeSend(e) {
|
|
|
|
e.target.setAttribute('disabled', '');
|
|
|
|
const iconElement = e.target.querySelector('i');
|
|
|
|
// get first fa- icon
|
2017-09-10 17:25:29 +05:30
|
|
|
const originalIcon = iconElement.className.match(/(fa-)([^\s]+)/g)[0];
|
2017-08-17 22:00:37 +05:30
|
|
|
iconElement.dataset.icon = originalIcon;
|
|
|
|
AjaxLoadingSpinner.toggleLoadingIcon(iconElement);
|
|
|
|
$(e.target).off('ajax:beforeSend', AjaxLoadingSpinner.ajaxBeforeSend);
|
|
|
|
}
|
|
|
|
|
|
|
|
static ajaxComplete(e) {
|
|
|
|
e.target.removeAttribute('disabled');
|
|
|
|
const iconElement = e.target.querySelector('i');
|
|
|
|
AjaxLoadingSpinner.toggleLoadingIcon(iconElement);
|
|
|
|
$(e.target).off('ajax:complete', AjaxLoadingSpinner.ajaxComplete);
|
|
|
|
}
|
|
|
|
|
|
|
|
static toggleLoadingIcon(iconElement) {
|
2018-11-08 19:23:39 +05:30
|
|
|
const { classList } = iconElement;
|
2017-08-17 22:00:37 +05:30
|
|
|
classList.toggle(iconElement.dataset.icon);
|
|
|
|
classList.toggle('fa-spinner');
|
|
|
|
classList.toggle('fa-spin');
|
|
|
|
}
|
|
|
|
}
|