mirror of
https://github.com/zulip/zulip.git
synced 2025-11-13 18:36:36 +00:00
js: Convert static/js/user_groups.js to ES6 module.
Signed-off-by: Anders Kaseorg <anders@zulip.com>
This commit is contained in:
committed by
Tim Abbott
parent
592cd780f5
commit
5a68bda15b
@@ -1,33 +1,31 @@
|
||||
"use strict";
|
||||
|
||||
const {FoldDict} = require("./fold_dict");
|
||||
import {FoldDict} from "./fold_dict";
|
||||
|
||||
let user_group_name_dict;
|
||||
let user_group_by_id_dict;
|
||||
|
||||
// We have an init() function so that our automated tests
|
||||
// can easily clear data.
|
||||
exports.init = function () {
|
||||
export function init() {
|
||||
user_group_name_dict = new FoldDict();
|
||||
user_group_by_id_dict = new Map();
|
||||
};
|
||||
}
|
||||
|
||||
// WE INITIALIZE DATA STRUCTURES HERE!
|
||||
exports.init();
|
||||
init();
|
||||
|
||||
exports.add = function (user_group) {
|
||||
export function add(user_group) {
|
||||
// Reformat the user group members structure to be a set.
|
||||
user_group.members = new Set(user_group.members);
|
||||
user_group_name_dict.set(user_group.name, user_group);
|
||||
user_group_by_id_dict.set(user_group.id, user_group);
|
||||
};
|
||||
}
|
||||
|
||||
exports.remove = function (user_group) {
|
||||
export function remove(user_group) {
|
||||
user_group_name_dict.delete(user_group.name);
|
||||
user_group_by_id_dict.delete(user_group.id);
|
||||
};
|
||||
}
|
||||
|
||||
exports.get_user_group_from_id = function (group_id, suppress_errors) {
|
||||
export function get_user_group_from_id(group_id, suppress_errors) {
|
||||
if (!user_group_by_id_dict.has(group_id)) {
|
||||
if (suppress_errors === undefined) {
|
||||
blueslip.error("Unknown group_id in get_user_group_from_id: " + group_id);
|
||||
@@ -35,10 +33,10 @@ exports.get_user_group_from_id = function (group_id, suppress_errors) {
|
||||
return undefined;
|
||||
}
|
||||
return user_group_by_id_dict.get(group_id);
|
||||
};
|
||||
}
|
||||
|
||||
exports.update = function (event) {
|
||||
const group = exports.get_user_group_from_id(event.group_id);
|
||||
export function update(event) {
|
||||
const group = get_user_group_from_id(event.group_id);
|
||||
if (event.data.name !== undefined) {
|
||||
group.name = event.data.name;
|
||||
user_group_name_dict.delete(group.name);
|
||||
@@ -49,49 +47,47 @@ exports.update = function (event) {
|
||||
user_group_name_dict.delete(group.name);
|
||||
user_group_name_dict.set(group.name, group);
|
||||
}
|
||||
};
|
||||
}
|
||||
|
||||
exports.get_user_group_from_name = function (name) {
|
||||
export function get_user_group_from_name(name) {
|
||||
return user_group_name_dict.get(name);
|
||||
};
|
||||
}
|
||||
|
||||
exports.get_realm_user_groups = function () {
|
||||
export function get_realm_user_groups() {
|
||||
return Array.from(user_group_by_id_dict.values()).sort((a, b) => a.id - b.id);
|
||||
};
|
||||
}
|
||||
|
||||
exports.is_member_of = function (user_group_id, user_id) {
|
||||
export function is_member_of(user_group_id, user_id) {
|
||||
const user_group = user_group_by_id_dict.get(user_group_id);
|
||||
if (user_group === undefined) {
|
||||
blueslip.error("Could not find user group with ID " + user_group_id);
|
||||
return false;
|
||||
}
|
||||
return user_group.members.has(user_id);
|
||||
};
|
||||
}
|
||||
|
||||
exports.add_members = function (user_group_id, user_ids) {
|
||||
export function add_members(user_group_id, user_ids) {
|
||||
const user_group = user_group_by_id_dict.get(user_group_id);
|
||||
|
||||
for (const user_id of user_ids) {
|
||||
user_group.members.add(user_id);
|
||||
}
|
||||
};
|
||||
}
|
||||
|
||||
exports.remove_members = function (user_group_id, user_ids) {
|
||||
export function remove_members(user_group_id, user_ids) {
|
||||
const user_group = user_group_by_id_dict.get(user_group_id);
|
||||
|
||||
for (const user_id of user_ids) {
|
||||
user_group.members.delete(user_id);
|
||||
}
|
||||
};
|
||||
}
|
||||
|
||||
exports.initialize = function (params) {
|
||||
export function initialize(params) {
|
||||
for (const user_group of params.realm_user_groups) {
|
||||
exports.add(user_group);
|
||||
add(user_group);
|
||||
}
|
||||
};
|
||||
}
|
||||
|
||||
exports.is_user_group = function (item) {
|
||||
export function is_user_group(item) {
|
||||
return item.members !== undefined;
|
||||
};
|
||||
|
||||
window.user_groups = exports;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user