mirror of https://github.com/zulip/zulip.git
38 lines
1.4 KiB
JavaScript
38 lines
1.4 KiB
JavaScript
// Miscellaneous early setup.
|
|
|
|
var csrf_token;
|
|
$(function () {
|
|
// Display loading indicator. This disappears after the first
|
|
// get_updates completes.
|
|
if (page_params.have_initial_messages) {
|
|
util.make_loading_indicator($('#page_loading_indicator'), 'Loading...');
|
|
} else {
|
|
util.show_first_run_message();
|
|
}
|
|
|
|
// This requires that we used Django's {% csrf_token %} somewhere on the page.
|
|
csrf_token = $('input[name="csrfmiddlewaretoken"]').attr('value');
|
|
|
|
$.ajaxSetup({
|
|
beforeSend: function (xhr, settings) {
|
|
if (!(/^http:.*/.test(settings.url) || /^https:.*/.test(settings.url))) {
|
|
// Only send the token to relative URLs i.e. locally.
|
|
xhr.setRequestHeader("X-CSRFToken", csrf_token);
|
|
}
|
|
}
|
|
});
|
|
|
|
// For some reason, jQuery wants this to be attached to an element.
|
|
$('body').ajaxError(function (event, xhr) {
|
|
if (xhr.status === 401) {
|
|
// We got logged out somehow, perhaps from another window or a session timeout.
|
|
// We could display an error message, but jumping right to the login page seems
|
|
// smoother and conveys the same information.
|
|
window.location.replace('/accounts/login');
|
|
}
|
|
});
|
|
|
|
// zxcvbn.js is pretty big, and is only needed on password change, so load it asynchronously.
|
|
$.getScript('/static/third/zxcvbn/zxcvbn.js');
|
|
});
|