41 lines
1.3 KiB
JavaScript
41 lines
1.3 KiB
JavaScript
import Rails from '@rails/ujs';
|
|
import jQuery from 'jquery';
|
|
|
|
// `smart_listing` gem is overriding `$.rails.href` method. When using newer
|
|
// jQuery-less version of rails-ujs it breaks.
|
|
// https://github.com/Sology/smart_listing/blob/master/app/assets/javascripts/smart_listing.coffee.erb#L9
|
|
addEventListener('load', () => {
|
|
const { href, handleRemote } = Rails;
|
|
Rails.href = function (element) {
|
|
return element.href || href(element);
|
|
};
|
|
Rails.handleRemote = function (e) {
|
|
if (this instanceof HTMLElement) {
|
|
handleRemote.call(this, e);
|
|
} else {
|
|
let element = e.find('[data-remote]')[0];
|
|
let event = new CustomEvent('click');
|
|
Object.defineProperty(event, 'target', { value: element });
|
|
return handleRemote.call(element, event);
|
|
}
|
|
};
|
|
});
|
|
|
|
// rails-ujs installs CSRFProtection for its own ajax implementation. We might need
|
|
// CSRFProtection for jQuery initiated requests. This code is from jquery-ujs.
|
|
jQuery.ajaxPrefilter((options, originalOptions, xhr) => {
|
|
if (!options.crossDomain) {
|
|
CSRFProtection(xhr);
|
|
}
|
|
});
|
|
|
|
function csrfToken() {
|
|
return jQuery('meta[name=csrf-token]').attr('content');
|
|
}
|
|
|
|
function CSRFProtection(xhr) {
|
|
let token = csrfToken();
|
|
if (token) {
|
|
xhr.setRequestHeader('X-CSRF-Token', token);
|
|
}
|
|
}
|