mirror of https://github.com/zulip/zulip.git
203 lines
5.9 KiB
JavaScript
203 lines
5.9 KiB
JavaScript
var muting_ui = (function () {
|
|
|
|
var exports = {};
|
|
|
|
function timestamp_ms() {
|
|
return (new Date()).getTime();
|
|
}
|
|
|
|
var last_topic_update = 0;
|
|
|
|
exports.rerender = function () {
|
|
// Note: We tend to optimistically rerender muting preferences before
|
|
// the back end actually acknowledges the mute. This gives a more
|
|
// immediate feel to the user, and if the back end fails temporarily,
|
|
// re-doing a mute or unmute is a pretty recoverable thing.
|
|
|
|
stream_list.update_streams_sidebar();
|
|
current_msg_list.rerender_after_muting_changes();
|
|
if (current_msg_list !== home_msg_list) {
|
|
home_msg_list.rerender_after_muting_changes();
|
|
}
|
|
};
|
|
|
|
exports.notify_with_undo_option = (function () {
|
|
var meta = {
|
|
stream: null,
|
|
topic: null,
|
|
hide_me_time: null,
|
|
alert_hover_state: false,
|
|
$mute: null,
|
|
};
|
|
var animate = {
|
|
fadeOut: function () {
|
|
if (meta.$mute) {
|
|
meta.$mute.fadeOut(500).removeClass("show");
|
|
}
|
|
},
|
|
fadeIn: function () {
|
|
if (meta.$mute) {
|
|
meta.$mute.fadeIn(500).addClass("show");
|
|
}
|
|
},
|
|
};
|
|
setInterval(function () {
|
|
if (meta.hide_me_time < new Date().getTime() && !meta.alert_hover_state) {
|
|
animate.fadeOut();
|
|
}
|
|
}, 100);
|
|
|
|
return function (stream, topic) {
|
|
var $exit = $("#unmute_muted_topic_notification .exit-me");
|
|
|
|
if (!meta.$mute) {
|
|
meta.$mute = $("#unmute_muted_topic_notification");
|
|
|
|
$exit.click(function () {
|
|
animate.fadeOut();
|
|
});
|
|
|
|
meta.$mute.find("#unmute").click(function () {
|
|
// it should reference the meta variable and not get stuck with
|
|
// a pass-by-value of stream, topic.
|
|
exports.unmute(meta.stream, meta.topic);
|
|
animate.fadeOut();
|
|
});
|
|
}
|
|
|
|
meta.stream = stream;
|
|
meta.topic = topic;
|
|
// add a four second delay before closing up.
|
|
meta.hide_me_time = new Date().getTime() + 4000;
|
|
|
|
meta.$mute.find(".topic").html(topic);
|
|
meta.$mute.find(".stream").html(stream);
|
|
|
|
animate.fadeIn();
|
|
|
|
// if the user mouses over the notification, don't hide it.
|
|
meta.$mute.mouseenter(function () {
|
|
meta.alert_hover_state = true;
|
|
});
|
|
|
|
// once the user's mouse leaves the notification, restart the countdown.
|
|
meta.$mute.mouseleave(function () {
|
|
meta.alert_hover_state = false;
|
|
// add at least 2000ms but if more than that exists just keep the
|
|
// current amount.
|
|
meta.hide_me_time = Math.max(meta.hide_me_time, new Date().getTime() + 2000);
|
|
});
|
|
};
|
|
}());
|
|
|
|
exports.dismiss_mute_confirmation = function () {
|
|
var $mute = $("#unmute_muted_topic_notification");
|
|
if ($mute) {
|
|
$mute.fadeOut(500).removeClass("show");
|
|
}
|
|
};
|
|
|
|
exports.persist_mute = function (stream_name, topic_name) {
|
|
var data = {
|
|
stream: stream_name,
|
|
topic: topic_name,
|
|
op: 'add',
|
|
};
|
|
last_topic_update = timestamp_ms();
|
|
channel.patch({
|
|
url: '/json/users/me/subscriptions/muted_topics',
|
|
idempotent: true,
|
|
data: data,
|
|
});
|
|
};
|
|
|
|
exports.persist_unmute = function (stream_name, topic_name) {
|
|
var data = {
|
|
stream: stream_name,
|
|
topic: topic_name,
|
|
op: 'remove',
|
|
};
|
|
last_topic_update = timestamp_ms();
|
|
channel.patch({
|
|
url: '/json/users/me/subscriptions/muted_topics',
|
|
idempotent: true,
|
|
data: data,
|
|
});
|
|
};
|
|
|
|
exports.handle_updates = function (muted_topics) {
|
|
if (timestamp_ms() < last_topic_update + 1000) {
|
|
// This topic update is either the one that we just rendered, or,
|
|
// much less likely, it's coming from another device and would probably
|
|
// be overwriting this device's preferences with stale data.
|
|
return;
|
|
}
|
|
|
|
exports.update_muted_topics(muted_topics);
|
|
exports.rerender();
|
|
};
|
|
|
|
exports.mute_topic = function (stream, topic) {
|
|
muting.add_muted_topic(stream, topic);
|
|
unread_ui.update_unread_counts();
|
|
};
|
|
|
|
exports.unmute_topic = function (stream, topic) {
|
|
muting.remove_muted_topic(stream, topic);
|
|
unread_ui.update_unread_counts();
|
|
};
|
|
|
|
exports.update_muted_topics = function (muted_topics) {
|
|
muting.set_muted_topics(muted_topics);
|
|
unread_ui.update_unread_counts();
|
|
};
|
|
|
|
exports.set_up_muted_topics_ui = function (muted_topics) {
|
|
var muted_topics_table = $("#muted_topics_table tbody");
|
|
muted_topics_table.empty();
|
|
_.each(muted_topics, function (list) {
|
|
var row = templates.render('muted_topic_ui_row', {stream: list[0], topic: list[1]});
|
|
muted_topics_table.append(row);
|
|
});
|
|
};
|
|
|
|
exports.mute = function (stream, topic) {
|
|
stream_popover.hide_topic_popover();
|
|
exports.mute_topic(stream, topic);
|
|
exports.rerender();
|
|
exports.persist_mute(stream, topic);
|
|
exports.notify_with_undo_option(stream, topic);
|
|
exports.set_up_muted_topics_ui(muting.get_muted_topics());
|
|
};
|
|
|
|
exports.unmute = function (stream, topic) {
|
|
// we don't run a unmute_notify function because it isn't an issue as much
|
|
// if someone accidentally unmutes a stream rather than if they mute it
|
|
// and miss out on info.
|
|
stream_popover.hide_topic_popover();
|
|
exports.unmute_topic(stream, topic);
|
|
exports.rerender();
|
|
exports.persist_unmute(stream, topic);
|
|
exports.set_up_muted_topics_ui(muting.get_muted_topics());
|
|
exports.dismiss_mute_confirmation();
|
|
};
|
|
|
|
exports.toggle_mute = function (msg) {
|
|
if (muting.is_topic_muted(msg.stream, msg.subject)) {
|
|
exports.unmute(msg.stream, msg.subject);
|
|
} else if (msg.type === 'stream') {
|
|
exports.mute(msg.stream, msg.subject);
|
|
}
|
|
};
|
|
|
|
$(function () {
|
|
exports.update_muted_topics(page_params.muted_topics);
|
|
});
|
|
|
|
return exports;
|
|
}());
|
|
|
|
if (typeof module !== 'undefined') {
|
|
module.exports = muting_ui;
|
|
}
|