mirror of
https://github.com/zulip/zulip.git
synced 2025-11-04 22:13:26 +00:00
Ever since we started bundling the app with webpack, there’s been less and less overlap between our ‘static’ directory (files belonging to the frontend app) and Django’s interpretation of the ‘static’ directory (files served directly to the web). Split the app out to its own ‘web’ directory outside of ‘static’, and remove all the custom collectstatic --ignore rules. This makes it much clearer what’s actually being served to the web, and what’s being bundled by webpack. It also shrinks the release tarball by 3%. Signed-off-by: Anders Kaseorg <anders@zulip.com>
95 lines
3.0 KiB
TypeScript
95 lines
3.0 KiB
TypeScript
import $ from "jquery";
|
|
|
|
import loading_black_image from "../../static/images/loading/loader-black.svg";
|
|
import loading_white_image from "../../static/images/loading/loader-white.svg";
|
|
import render_loader from "../templates/loader.hbs";
|
|
|
|
export function make_indicator(
|
|
$outer_container: JQuery,
|
|
{
|
|
abs_positioned = false,
|
|
text,
|
|
width,
|
|
height,
|
|
}: {abs_positioned?: boolean; text?: string; width?: number; height?: number} = {},
|
|
): void {
|
|
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 (abs_positioned) {
|
|
// Create some additional containers to facilitate absolutely
|
|
// positioned spinners.
|
|
const container_id = $container.attr("id")!;
|
|
let $inner_container = $("<div>").attr("id", `${container_id}_box_container`);
|
|
$container.append($inner_container);
|
|
$container = $inner_container;
|
|
$inner_container = $("<div>").attr("id", `${container_id}_box`);
|
|
$container.append($inner_container);
|
|
$container = $inner_container;
|
|
}
|
|
|
|
const $spinner_elem = $("<div>")
|
|
.addClass("loading_indicator_spinner")
|
|
.attr("aria-hidden", "true");
|
|
$spinner_elem.html(render_loader({container_id: $outer_container.attr("id")}));
|
|
$container.append($spinner_elem);
|
|
let text_width = 0;
|
|
|
|
if (text !== undefined) {
|
|
const $text_elem = $("<span>").addClass("loading_indicator_text");
|
|
$text_elem.text(text);
|
|
$container.append($text_elem);
|
|
// See note, below
|
|
if (!abs_positioned) {
|
|
text_width = 20 + ($text_elem.width() ?? 0);
|
|
}
|
|
}
|
|
|
|
// These width calculations are tied to the spinner width and
|
|
// margins defined via CSS
|
|
if (width !== undefined) {
|
|
$container.css({width: width + text_width});
|
|
} else {
|
|
$container.css({width: 38 + text_width});
|
|
}
|
|
if (height !== undefined) {
|
|
$container.css({height});
|
|
} else {
|
|
$container.css({height: 0});
|
|
}
|
|
|
|
$outer_container.data("destroying", false);
|
|
}
|
|
|
|
export function destroy_indicator($container: JQuery): void {
|
|
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});
|
|
}
|
|
|
|
export function show_button_spinner($elt: JQuery, using_dark_theme: boolean): void {
|
|
if (!using_dark_theme) {
|
|
$elt.attr("src", loading_black_image);
|
|
} else {
|
|
$elt.attr("src", loading_white_image);
|
|
}
|
|
$elt.css("display", "inline-block");
|
|
}
|