zulip/static/js/loading.js

68 lines
2.3 KiB
JavaScript

"use strict";
const render_loader = require("../templates/loader.hbs");
exports.make_indicator = function (outer_container, opts) {
opts = opts || {};
let container = outer_container;
// TODO: We set white-space to 'nowrap' because under some
// unknown circumstances (it happens on Keegan's laptop) the text
// width calculation, above, returns a result that's a few pixels
// too small. The container's div will be slightly too small,
// but that's probably OK for our purposes.
outer_container.css({"white-space": "nowrap"});
container.empty();
if (opts.abs_positioned !== undefined && opts.abs_positioned) {
// Create some additional containers to facilitate absolutely
// positioned spinners.
const container_id = container.attr("id");
let inner_container = $('<div id="' + container_id + '_box_container"></div>');
container.append(inner_container);
container = inner_container;
inner_container = $('<div id="' + container_id + '_box"></div>');
container.append(inner_container);
container = inner_container;
}
const spinner_elem = $('<div class="loading_indicator_spinner"></div>');
spinner_elem.html(render_loader({container_id: outer_container.attr("id")}));
container.append(spinner_elem);
let text_width = 0;
if (opts.text !== undefined && opts.text !== "") {
const text_elem = $('<span class="loading_indicator_text"></span>');
text_elem.text(opts.text);
container.append(text_elem);
// See note, below
if (!(opts.abs_positioned !== undefined && opts.abs_positioned)) {
text_width = 20 + text_elem.width();
}
}
// These width calculations are tied to the spinner width and
// margins defined via CSS
container.css({width: 38 + text_width, height: 0});
outer_container.data("destroying", false);
};
exports.destroy_indicator = function (container) {
if (container.data("destroying")) {
return;
}
container.data("destroying", true);
const spinner = container.data("spinner_obj");
if (spinner !== undefined) {
spinner.stop();
}
container.removeData("spinner_obj");
container.empty();
container.css({width: 0, height: 0});
};
window.loading = exports;