mirror of
https://github.com/zulip/zulip.git
synced 2025-11-12 18:06:44 +00:00
ts: Migrate user_group_pill module to TypeScript.
This commit is contained in:
@@ -58,7 +58,7 @@ type InputPillRenderingDetails = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
// These are the functions that are exposed to other modules.
|
// These are the functions that are exposed to other modules.
|
||||||
type InputPillContainer<T> = {
|
export type InputPillContainer<T> = {
|
||||||
appendValue: (text: string) => void;
|
appendValue: (text: string) => void;
|
||||||
appendValidatedData: (item: InputPillItem<T>) => void;
|
appendValidatedData: (item: InputPillItem<T>) => void;
|
||||||
getByElement: (element: HTMLElement) => InputPill<T> | undefined;
|
getByElement: (element: HTMLElement) => InputPill<T> | undefined;
|
||||||
|
|||||||
@@ -1,10 +1,22 @@
|
|||||||
|
import type {InputPillContainer, InputPillItem} from "./input_pill";
|
||||||
|
import type {UserGroup} from "./user_groups";
|
||||||
import * as user_groups from "./user_groups";
|
import * as user_groups from "./user_groups";
|
||||||
|
|
||||||
function display_pill(group) {
|
type UserGroupPill = {
|
||||||
return group.name + ": " + group.members.size + " users";
|
id: number;
|
||||||
|
group_name: string;
|
||||||
|
};
|
||||||
|
|
||||||
|
type UserGroupPillWidget = InputPillContainer<UserGroupPill>;
|
||||||
|
|
||||||
|
function display_pill(group: UserGroup): string {
|
||||||
|
return `${group.name}: ${group.members.size} users`;
|
||||||
}
|
}
|
||||||
|
|
||||||
export function create_item_from_group_name(group_name, current_items) {
|
export function create_item_from_group_name(
|
||||||
|
group_name: string,
|
||||||
|
current_items: InputPillItem<UserGroupPill>[],
|
||||||
|
): InputPillItem<UserGroupPill> | undefined {
|
||||||
group_name = group_name.trim();
|
group_name = group_name.trim();
|
||||||
const group = user_groups.get_user_group_from_name(group_name);
|
const group = user_groups.get_user_group_from_name(group_name);
|
||||||
if (!group) {
|
if (!group) {
|
||||||
@@ -26,18 +38,18 @@ export function create_item_from_group_name(group_name, current_items) {
|
|||||||
return item;
|
return item;
|
||||||
}
|
}
|
||||||
|
|
||||||
export function get_group_name_from_item(item) {
|
export function get_group_name_from_item(item: InputPillItem<UserGroupPill>): string {
|
||||||
return item.group_name;
|
return item.group_name;
|
||||||
}
|
}
|
||||||
|
|
||||||
function get_user_ids_from_user_groups(items) {
|
function get_user_ids_from_user_groups(items: InputPillItem<UserGroupPill>[]): number[] {
|
||||||
const group_ids = items.map((item) => item.id).filter(Boolean);
|
const group_ids = items.map((item) => item.id).filter(Boolean);
|
||||||
return group_ids.flatMap((group_id) => [
|
return group_ids.flatMap((group_id) => [
|
||||||
...user_groups.get_user_group_from_id(group_id).members,
|
...user_groups.get_user_group_from_id(group_id).members,
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
export function get_user_ids(pill_widget) {
|
export function get_user_ids(pill_widget: UserGroupPillWidget): number[] {
|
||||||
const items = pill_widget.items();
|
const items = pill_widget.items();
|
||||||
let user_ids = get_user_ids_from_user_groups(items);
|
let user_ids = get_user_ids_from_user_groups(items);
|
||||||
user_ids = [...new Set(user_ids)];
|
user_ids = [...new Set(user_ids)];
|
||||||
@@ -47,18 +59,17 @@ export function get_user_ids(pill_widget) {
|
|||||||
return user_ids;
|
return user_ids;
|
||||||
}
|
}
|
||||||
|
|
||||||
export function append_user_group(group, pill_widget) {
|
export function append_user_group(group: UserGroup, pill_widget: UserGroupPillWidget): void {
|
||||||
if (group !== undefined && group !== null) {
|
|
||||||
pill_widget.appendValidatedData({
|
pill_widget.appendValidatedData({
|
||||||
type: "user_group",
|
type: "user_group",
|
||||||
display_value: display_pill(group),
|
display_value: display_pill(group),
|
||||||
id: group.id,
|
id: group.id,
|
||||||
|
group_name: group.name,
|
||||||
});
|
});
|
||||||
pill_widget.clear_text();
|
pill_widget.clear_text();
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
export function get_group_ids(pill_widget) {
|
export function get_group_ids(pill_widget: UserGroupPillWidget): number[] {
|
||||||
const items = pill_widget.items();
|
const items = pill_widget.items();
|
||||||
let group_ids = items.map((item) => item.id);
|
let group_ids = items.map((item) => item.id);
|
||||||
group_ids = group_ids.filter(Boolean);
|
group_ids = group_ids.filter(Boolean);
|
||||||
@@ -66,13 +77,16 @@ export function get_group_ids(pill_widget) {
|
|||||||
return group_ids;
|
return group_ids;
|
||||||
}
|
}
|
||||||
|
|
||||||
export function filter_taken_groups(items, pill_widget) {
|
export function filter_taken_groups(
|
||||||
|
items: UserGroup[],
|
||||||
|
pill_widget: UserGroupPillWidget,
|
||||||
|
): UserGroup[] {
|
||||||
const taken_group_ids = get_group_ids(pill_widget);
|
const taken_group_ids = get_group_ids(pill_widget);
|
||||||
items = items.filter((item) => !taken_group_ids.includes(item.id));
|
items = items.filter((item) => !taken_group_ids.includes(item.id));
|
||||||
return items;
|
return items;
|
||||||
}
|
}
|
||||||
|
|
||||||
export function typeahead_source(pill_widget) {
|
export function typeahead_source(pill_widget: UserGroupPillWidget): UserGroup[] {
|
||||||
const groups = user_groups.get_realm_user_groups();
|
const groups = user_groups.get_realm_user_groups();
|
||||||
return filter_taken_groups(groups, pill_widget);
|
return filter_taken_groups(groups, pill_widget);
|
||||||
}
|
}
|
||||||
@@ -5,7 +5,7 @@ import {page_params} from "./page_params";
|
|||||||
import * as settings_config from "./settings_config";
|
import * as settings_config from "./settings_config";
|
||||||
import type {User, UserGroupUpdateEvent} from "./types";
|
import type {User, UserGroupUpdateEvent} from "./types";
|
||||||
|
|
||||||
type UserGroup = {
|
export type UserGroup = {
|
||||||
description: string;
|
description: string;
|
||||||
id: number;
|
id: number;
|
||||||
name: string;
|
name: string;
|
||||||
|
|||||||
Reference in New Issue
Block a user