Files
zulip/static/js/user_status.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

76 lines
1.7 KiB
JavaScript

const away_user_ids = new Set();
const user_info = new Map();
exports.server_update = function (opts) {
channel.post({
url: '/json/users/me/status',
data: {
away: opts.away,
status_text: opts.status_text,
},
idempotent: true,
success: function () {
if (opts.success) {
opts.success();
}
},
});
};
exports.server_set_away = function () {
exports.server_update({away: true});
};
exports.server_revoke_away = function () {
exports.server_update({away: false});
};
exports.set_away = function (user_id) {
if (typeof user_id !== 'number') {
blueslip.error('need ints for user_id');
}
away_user_ids.add(user_id);
};
exports.revoke_away = function (user_id) {
if (typeof user_id !== 'number') {
blueslip.error('need ints for user_id');
}
away_user_ids.delete(user_id);
};
exports.is_away = function (user_id) {
return away_user_ids.has(user_id);
};
exports.get_status_text = function (user_id) {
return user_info.get(user_id);
};
exports.set_status_text = function (opts) {
if (!opts.status_text) {
user_info.delete(opts.user_id);
return;
}
user_info.set(opts.user_id, opts.status_text);
};
exports.initialize = function (params) {
for (const [str_user_id, dct] of Object.entries(params.user_status)) {
// JSON does not allow integer keys, so we
// convert them here.
const user_id = parseInt(str_user_id, 10);
if (dct.away) {
away_user_ids.add(user_id);
}
if (dct.status_text) {
user_info.set(user_id, dct.status_text);
}
}
};
window.user_status = exports;