Files
zulip/static/js/user_groups.js
Steve Howell da79fd206a ui_init: Handle page_params more cleanly.
This cleans up the handoff of page_params
data between ui_init and modules that
take over ownership of page_params-derived
data.

Read the long comment in ui_init for a bit
more context.

Most of this diff is actually test cleanup.
And a lot of the diff to "real" code is
just glorified `s/page_params/params/`
in the `initialize` functions.

One little oddity is that we don't actually
surrender ownership of `page_params.user_id`
to `people.js`.  We could plausibly sweep
the rest of the codebase to just use
`people.my_user_id()` consistently, but it's
not a super high priority thing to fix,
since the value never changes.

The stream_data situation is a bit messy,
since we consume `page_params` data in the
initialize() function in addition to the
`params` data we "own".  I added a comment
there and intend to follow up.  I tried
to mostly avoid the "word soup" by extracting
three locals at the top.

Finally, I don't touch `alert_words` yet,
despite it also doing the delete-page-params-data
dance.  The problem is that `alert_words`
doesn't have a proper `initialize()`.  We
should clean that up and have it use a
`Map` internally, too.
2020-02-26 13:14:09 -08:00

98 lines
2.8 KiB
JavaScript

const FoldDict = require('./fold_dict').FoldDict;
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 () {
user_group_name_dict = new FoldDict();
user_group_by_id_dict = new Map();
};
// WE INITIALIZE DATA STRUCTURES HERE!
exports.init();
exports.add = function (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) {
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) {
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);
}
return;
}
return user_group_by_id_dict.get(group_id);
};
exports.update = function (event) {
const group = exports.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);
user_group_name_dict.set(group.name, group);
}
if (event.data.description !== undefined) {
group.description = event.data.description;
user_group_name_dict.delete(group.name);
user_group_name_dict.set(group.name, group);
}
};
exports.get_user_group_from_name = function (name) {
return user_group_name_dict.get(name);
};
exports.get_realm_user_groups = function () {
return Array.from(user_group_by_id_dict.values()).sort(function (a, b) {
return a.id - b.id;
});
};
exports.is_member_of = function (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) {
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) {
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) {
for (const user_group of params.realm_user_groups) {
exports.add(user_group);
}
};
exports.is_user_group = function (item) {
return item.hasOwnProperty('members');
};
window.user_groups = exports;