mirror of https://github.com/zulip/zulip.git
185 lines
5.5 KiB
JavaScript
185 lines
5.5 KiB
JavaScript
var muting_ui = (function () {
|
|
|
|
var exports = {};
|
|
|
|
function timestamp_ms() {
|
|
return (new Date()).getTime();
|
|
}
|
|
|
|
var last_topic_update = 0;
|
|
|
|
exports.rerender = function () {
|
|
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_and_rerender = function () {
|
|
// Optimistically rerender our new muting preferences. The back
|
|
// end should eventually save it, and if it doesn't, it's a recoverable
|
|
// error--the user can just mute the topic again, and the topic might
|
|
// die down before the next reload anyway, making the muting moot.
|
|
exports.rerender();
|
|
var data = {
|
|
muted_topics: JSON.stringify(muting.get_muted_topics()),
|
|
};
|
|
last_topic_update = timestamp_ms();
|
|
channel.post({
|
|
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.persist_and_rerender();
|
|
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.persist_and_rerender();
|
|
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;
|
|
}
|