Files
zulip/web/src/user_group_create.ts
Sahil Batra 63a7c9061b settings: Use new pills UI for can_manage_group setting.
This UI enables the user to set can_manage_group setting to a
combination of users and groups, replacing the old dropdown UI
which just allowed setting user to a single system group.

Fixes part of #28808.
2024-09-19 09:08:33 -07:00

250 lines
8.2 KiB
TypeScript

import $ from "jquery";
import assert from "minimalistic-assert";
import * as channel from "./channel";
import {$t, $t_html} from "./i18n";
import * as keydown_util from "./keydown_util";
import * as loading from "./loading";
import {page_params} from "./page_params";
import * as settings_components from "./settings_components";
import * as ui_report from "./ui_report";
import * as user_group_components from "./user_group_components";
import * as user_group_create_members from "./user_group_create_members";
import * as user_group_create_members_data from "./user_group_create_members_data";
import * as user_groups from "./user_groups";
let created_group_name: string | undefined;
export function reset_name(): void {
created_group_name = undefined;
}
export function set_name(group_name: string): void {
created_group_name = group_name;
}
export function get_name(): string | undefined {
return created_group_name;
}
class UserGroupMembershipError {
report_no_members_to_user_group(): void {
$("#user_group_membership_error").text(
$t({defaultMessage: "You cannot create a user group with no members."}),
);
$("#user_group_membership_error").show();
}
clear_errors(): void {
$("#user_group_membership_error").hide();
}
}
const user_group_membership_error = new UserGroupMembershipError();
class UserGroupNameError {
report_already_exists(): void {
$("#user_group_name_error").text(
$t({defaultMessage: "A user group with this name already exists."}),
);
$("#user_group_name_error").show();
}
clear_errors(): void {
$("#user_group_name_error").hide();
}
report_empty_user_group(): void {
$("#user_group_name_error").text(
$t({defaultMessage: "Choose a name for the new user group."}),
);
$("#user_group_name_error").show();
}
select(): void {
$("#create_user_group_name").trigger("focus").trigger("select");
}
pre_validate(user_group_name: string): void {
if (user_group_name && user_groups.get_user_group_from_name(user_group_name)) {
this.report_already_exists();
return;
}
this.clear_errors();
}
validate_for_submit(user_group_name: string): boolean {
if (!user_group_name) {
this.report_empty_user_group();
this.select();
return false;
}
if (user_groups.get_user_group_from_name(user_group_name)) {
this.report_already_exists();
this.select();
return false;
}
return true;
}
}
const user_group_name_error = new UserGroupNameError();
$("body").on("click", ".settings-sticky-footer #user_group_go_to_members", (e) => {
e.preventDefault();
e.stopPropagation();
const group_name = $<HTMLInputElement>("input#create_user_group_name").val()!.trim();
const is_user_group_name_valid = user_group_name_error.validate_for_submit(group_name);
if (is_user_group_name_valid) {
user_group_components.show_user_group_settings_pane.create_user_group(
"user_group_members_container",
group_name,
);
}
});
$("body").on("click", ".settings-sticky-footer #user_group_go_to_configure_settings", (e) => {
e.preventDefault();
e.stopPropagation();
user_group_components.show_user_group_settings_pane.create_user_group(
"configure_user_group_settings",
);
});
function clear_error_display(): void {
user_group_name_error.clear_errors();
$(".user_group_create_info").hide();
user_group_membership_error.clear_errors();
}
export function show_new_user_group_modal(): void {
$("#user-group-creation").removeClass("hide");
$(".right .settings").hide();
user_group_create_members.build_widgets();
clear_error_display();
if (!page_params.development_environment) {
$("#new_group_can_manage_group_widget_container").hide();
}
}
function create_user_group(): void {
const group_name = $<HTMLInputElement>("input#create_user_group_name").val()!.trim();
const description = $<HTMLInputElement>("input#create_user_group_description").val()!.trim();
set_name(group_name);
// Even though we already check to make sure that while typing the user cannot enter
// newline characters (by pressing the Enter key) it would still be possible to copy
// and paste over a description with newline characters in it. Prevent that.
if (description.includes("\n")) {
ui_report.client_error(
$t_html({defaultMessage: "The group description cannot contain newline characters."}),
$(".user_group_create_info"),
);
return;
}
const user_ids = user_group_create_members.get_principals();
const can_manage_group = settings_components.get_group_setting_widget_value(
$("#id_new_group_can_manage_group"),
);
assert(settings_components.new_group_can_mention_group_widget !== null);
const can_mention_group_value = settings_components.new_group_can_mention_group_widget.value();
assert(can_mention_group_value !== undefined);
const can_mention_group =
typeof can_mention_group_value === "number"
? can_mention_group_value
: Number.parseInt(can_mention_group_value, 10);
const data = {
name: group_name,
description,
members: JSON.stringify(user_ids),
can_mention_group,
can_manage_group: JSON.stringify(can_manage_group),
};
loading.make_indicator($("#user_group_creating_indicator"), {
text: $t({defaultMessage: "Creating group..."}),
});
void channel.post({
url: "/json/user_groups/create",
data,
success() {
$("#create_user_group_name").val("");
$("#create_user_group_description").val("");
user_group_create_members.clear_member_list();
loading.destroy_indicator($("#user_group_creating_indicator"));
// TODO: The rest of the work should be done via the create event we will get for user group.
},
error(xhr) {
ui_report.error(
$t_html({defaultMessage: "Error creating user group."}),
xhr,
$(".user_group_create_info"),
);
reset_name();
loading.destroy_indicator($("#user_group_creating_indicator"));
},
});
}
export function set_up_handlers(): void {
const $people_to_add_holder = $("#people_to_add_in_group").expectOne();
user_group_create_members.create_handlers($people_to_add_holder);
const $container = $("#user-group-creation").expectOne();
$container.on("click", ".finalize_create_user_group", (e) => {
e.preventDefault();
clear_error_display();
const group_name = $<HTMLInputElement>("input#create_user_group_name").val()!.trim();
const name_ok = user_group_name_error.validate_for_submit(group_name);
if (!name_ok) {
user_group_components.show_user_group_settings_pane.create_user_group(
"configure_user_group_settings",
);
return;
}
const principals = user_group_create_members_data.get_principals();
if (principals.length === 0) {
user_group_membership_error.report_no_members_to_user_group();
return;
}
create_user_group();
});
$container.on("input", "#create_user_group_name", () => {
const user_group_name = $<HTMLInputElement>("input#create_user_group_name").val()!.trim();
// This is an inexpensive check.
user_group_name_error.pre_validate(user_group_name);
});
// Do not allow the user to enter newline characters while typing out the
// group's description during it's creation.
$container.on("keydown", "#create_user_group_description", (e) => {
if (keydown_util.is_enter_event(e)) {
e.preventDefault();
}
});
const $pill_container = $container.find(".can-manage-group-container .pill-container");
settings_components.create_group_setting_widget({
$pill_container,
setting_name: "can_manage_group",
});
user_group_components.setup_permissions_dropdown("can_mention_group", undefined, true);
}