mirror of
https://github.com/zulip/zulip.git
synced 2025-11-10 17:07:07 +00:00
Fixes #23588 When a new message arrives in an inactive stream, it will lead to stream being marked as active from inactive which leads to stream list being rearranged which zooms out the user since the active stream is reset momentarily. To avoid this, we delay the stream list redraw until user zooms out and only update the topics list.
78 lines
1.6 KiB
JavaScript
78 lines
1.6 KiB
JavaScript
import $ from "jquery";
|
|
|
|
import * as popovers from "./popovers";
|
|
import * as stream_list from "./stream_list";
|
|
import * as topic_list from "./topic_list";
|
|
|
|
let pending_stream_list_rerender = false;
|
|
let zoomed_in = false;
|
|
|
|
export function is_zoomed_in() {
|
|
return zoomed_in;
|
|
}
|
|
|
|
function zoom_in() {
|
|
const stream_id = topic_list.active_stream_id();
|
|
|
|
popovers.hide_all_except_sidebars();
|
|
topic_list.zoom_in();
|
|
stream_list.zoom_in_topics({
|
|
stream_id,
|
|
});
|
|
|
|
zoomed_in = true;
|
|
}
|
|
|
|
export function set_pending_stream_list_rerender(value) {
|
|
pending_stream_list_rerender = value;
|
|
}
|
|
|
|
export function zoom_out() {
|
|
if (pending_stream_list_rerender) {
|
|
stream_list.update_streams_sidebar(true);
|
|
}
|
|
const $stream_li = topic_list.get_stream_li();
|
|
|
|
popovers.hide_all_except_sidebars();
|
|
topic_list.zoom_out();
|
|
stream_list.zoom_out_topics();
|
|
|
|
if ($stream_li) {
|
|
stream_list.scroll_stream_into_view($stream_li);
|
|
}
|
|
|
|
zoomed_in = false;
|
|
}
|
|
|
|
export function clear_topics() {
|
|
const $stream_li = topic_list.get_stream_li();
|
|
|
|
topic_list.close();
|
|
|
|
if (zoomed_in) {
|
|
stream_list.zoom_out_topics();
|
|
|
|
if ($stream_li) {
|
|
stream_list.scroll_stream_into_view($stream_li);
|
|
}
|
|
}
|
|
|
|
zoomed_in = false;
|
|
}
|
|
|
|
export function initialize() {
|
|
$("#stream_filters").on("click", ".show-more-topics", (e) => {
|
|
zoom_in();
|
|
|
|
e.preventDefault();
|
|
e.stopPropagation();
|
|
});
|
|
|
|
$(".show-all-streams").on("click", (e) => {
|
|
zoom_out();
|
|
|
|
e.preventDefault();
|
|
e.stopPropagation();
|
|
});
|
|
}
|