mirror of https://github.com/zulip/zulip.git
muted_users: Convert muted_users to typescript.
muted_users.js is another dependency of people.js to be converted into typescript. Note that for filter_muted_users, we avoid typing persons with a type that might get added to people.ts in the future, as it otherwise might introduce cyclic dependency. Signed-off-by: Zixuan James Li <p359101898@gmail.com>
This commit is contained in:
parent
bec8e48616
commit
6d9aba8aff
|
@ -1,23 +1,33 @@
|
|||
import {page_params} from "./page_params";
|
||||
import * as timerender from "./timerender";
|
||||
import {get_time_from_date_muted} from "./util";
|
||||
|
||||
const muted_users = new Map();
|
||||
type RawMutedUser = {
|
||||
id: number;
|
||||
timestamp: number;
|
||||
};
|
||||
|
||||
export function add_muted_user(user_id, date_muted) {
|
||||
type MutedUser = {
|
||||
id: number;
|
||||
date_muted: number;
|
||||
date_muted_str: string;
|
||||
};
|
||||
|
||||
const muted_users: Map<number, number> = new Map();
|
||||
|
||||
export function add_muted_user(user_id: number, date_muted?: number): void {
|
||||
const time = get_time_from_date_muted(date_muted);
|
||||
if (user_id) {
|
||||
muted_users.set(user_id, time);
|
||||
}
|
||||
}
|
||||
|
||||
export function remove_muted_user(user_id) {
|
||||
export function remove_muted_user(user_id: number): void {
|
||||
if (user_id) {
|
||||
muted_users.delete(user_id);
|
||||
}
|
||||
}
|
||||
|
||||
export function is_user_muted(user_id) {
|
||||
export function is_user_muted(user_id: number): boolean {
|
||||
if (user_id === undefined) {
|
||||
return false;
|
||||
}
|
||||
|
@ -25,19 +35,19 @@ export function is_user_muted(user_id) {
|
|||
return muted_users.has(user_id);
|
||||
}
|
||||
|
||||
export function filter_muted_user_ids(user_ids) {
|
||||
export function filter_muted_user_ids(user_ids: number[]): number[] {
|
||||
// Returns a copy of the user ID list, after removing muted user IDs.
|
||||
const base_user_ids = [...user_ids];
|
||||
return base_user_ids.filter((user_id) => !is_user_muted(user_id));
|
||||
}
|
||||
|
||||
export function filter_muted_users(persons) {
|
||||
export function filter_muted_users<T extends {user_id: number}>(persons: T[]): T[] {
|
||||
// Returns a copy of the people list, after removing muted users.
|
||||
const base_users = [...persons];
|
||||
return base_users.filter((person) => !is_user_muted(person.user_id));
|
||||
}
|
||||
|
||||
export function get_muted_users() {
|
||||
export function get_muted_users(): MutedUser[] {
|
||||
const users = [];
|
||||
for (const [id, date_muted] of muted_users) {
|
||||
const date_muted_str = timerender.render_now(new Date(date_muted)).time_str;
|
||||
|
@ -50,7 +60,7 @@ export function get_muted_users() {
|
|||
return users;
|
||||
}
|
||||
|
||||
export function set_muted_users(list) {
|
||||
export function set_muted_users(list: RawMutedUser[]): void {
|
||||
muted_users.clear();
|
||||
|
||||
for (const user of list) {
|
||||
|
@ -60,6 +70,6 @@ export function set_muted_users(list) {
|
|||
}
|
||||
}
|
||||
|
||||
export function initialize(params) {
|
||||
export function initialize(params: {muted_users: RawMutedUser[]}): void {
|
||||
set_muted_users(params.muted_users);
|
||||
}
|
|
@ -36,6 +36,7 @@ export const page_params: {
|
|||
server_web_public_streams_enabled: boolean;
|
||||
translation_data: Record<string, string>;
|
||||
zulip_plan_is_not_limited: boolean;
|
||||
muted_users: {id: number; timestamp: number}[];
|
||||
} = $("#page-params").remove().data("params");
|
||||
const t2 = performance.now();
|
||||
export const page_params_parse_time = t2 - t1;
|
||||
|
|
Loading…
Reference in New Issue