mirror of https://github.com/zulip/zulip.git
145 lines
4.5 KiB
JavaScript
145 lines
4.5 KiB
JavaScript
import render_admin_default_streams_list from "../templates/admin_default_streams_list.hbs";
|
|
|
|
import * as channel from "./channel";
|
|
import * as ListWidget from "./list_widget";
|
|
import * as loading from "./loading";
|
|
import * as stream_data from "./stream_data";
|
|
import * as typeahead_helper from "./typeahead_helper";
|
|
import * as ui_report from "./ui_report";
|
|
|
|
const meta = {
|
|
loaded: false,
|
|
};
|
|
|
|
export function reset() {
|
|
meta.loaded = false;
|
|
}
|
|
|
|
export function maybe_disable_widgets() {
|
|
if (page_params.is_admin) {
|
|
return;
|
|
}
|
|
|
|
$(".organization-box [data-name='default-streams-list']")
|
|
.find("input:not(.search), button, select")
|
|
.prop("disabled", true);
|
|
}
|
|
|
|
export function build_default_stream_table() {
|
|
const table = $("#admin_default_streams_table").expectOne();
|
|
|
|
const stream_ids = stream_data.get_default_stream_ids();
|
|
const subs = stream_ids.map((stream_id) => stream_data.get_sub_by_id(stream_id));
|
|
|
|
ListWidget.create(table, subs, {
|
|
name: "default_streams_list",
|
|
modifier(item) {
|
|
return render_admin_default_streams_list({
|
|
stream: item,
|
|
can_modify: page_params.is_admin,
|
|
});
|
|
},
|
|
filter: {
|
|
element: table.closest(".settings-section").find(".search"),
|
|
predicate(item, query) {
|
|
return item.name.toLowerCase().includes(query.toLowerCase());
|
|
},
|
|
onupdate() {
|
|
ui.reset_scrollbar(table);
|
|
},
|
|
},
|
|
parent_container: $("#admin-default-streams-list").expectOne(),
|
|
init_sort: ["alphabetic", "name"],
|
|
simplebar_container: $("#admin-default-streams-list .progressive-table-wrapper"),
|
|
});
|
|
|
|
loading.destroy_indicator($("#admin_page_default_streams_loading_indicator"));
|
|
}
|
|
|
|
export function update_default_streams_table() {
|
|
if (/#*organization/.test(window.location.hash) || /#*settings/.test(window.location.hash)) {
|
|
$("#admin_default_streams_table").expectOne().find("tr.default_stream_row").remove();
|
|
build_default_stream_table();
|
|
}
|
|
}
|
|
|
|
function make_stream_default(stream_id) {
|
|
const data = {
|
|
stream_id,
|
|
};
|
|
const default_stream_status = $("#admin-default-stream-status");
|
|
default_stream_status.hide();
|
|
|
|
channel.post({
|
|
url: "/json/default_streams",
|
|
data,
|
|
error(xhr) {
|
|
if (xhr.status.toString().charAt(0) === "4") {
|
|
ui_report.error(i18n.t("Failed"), xhr, default_stream_status);
|
|
} else {
|
|
ui_report.error(i18n.t("Failed"), default_stream_status);
|
|
}
|
|
default_stream_status.show();
|
|
},
|
|
});
|
|
}
|
|
|
|
export function delete_default_stream(stream_id, default_stream_row, alert_element) {
|
|
channel.del({
|
|
url: "/json/default_streams?" + $.param({stream_id}),
|
|
error(xhr) {
|
|
ui_report.generic_row_button_error(xhr, alert_element);
|
|
},
|
|
success() {
|
|
default_stream_row.remove();
|
|
},
|
|
});
|
|
}
|
|
|
|
export function set_up() {
|
|
build_page();
|
|
maybe_disable_widgets();
|
|
}
|
|
|
|
export function build_page() {
|
|
meta.loaded = true;
|
|
|
|
update_default_streams_table();
|
|
|
|
$(".create_default_stream").on("keypress", (e) => {
|
|
if (e.which === 13) {
|
|
e.preventDefault();
|
|
e.stopPropagation();
|
|
const default_stream_input = $(".create_default_stream");
|
|
make_stream_default(stream_data.get_stream_id(default_stream_input.val()));
|
|
default_stream_input[0].value = "";
|
|
}
|
|
});
|
|
|
|
$(".create_default_stream").typeahead({
|
|
items: 5,
|
|
fixed: true,
|
|
source() {
|
|
return stream_data.get_non_default_stream_names();
|
|
},
|
|
highlighter(item) {
|
|
return typeahead_helper.render_typeahead_item({primary: item});
|
|
},
|
|
});
|
|
|
|
$(".default-stream-form").on("click", "#do_submit_stream", (e) => {
|
|
e.preventDefault();
|
|
e.stopPropagation();
|
|
const default_stream_input = $(".create_default_stream");
|
|
make_stream_default(stream_data.get_stream_id(default_stream_input.val()));
|
|
// Clear value inside input box
|
|
default_stream_input[0].value = "";
|
|
});
|
|
|
|
$("body").on("click", ".default_stream_row .remove-default-stream", function (e) {
|
|
const row = $(this).closest(".default_stream_row");
|
|
const stream_id = Number.parseInt(row.attr("data-stream-id"), 10);
|
|
delete_default_stream(stream_id, row, $(e.target));
|
|
});
|
|
}
|