mirror of
				https://github.com/zulip/zulip.git
				synced 2025-11-03 21:43:21 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			119 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			119 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
import $ from "jquery";
 | 
						|
 | 
						|
import render_mark_as_read_turned_off_banner from "../templates/mark_as_read_turned_off_banner.hbs";
 | 
						|
 | 
						|
import * as activity from "./activity";
 | 
						|
import * as message_lists from "./message_lists";
 | 
						|
import * as notifications from "./notifications";
 | 
						|
import {page_params} from "./page_params";
 | 
						|
import * as pm_list from "./pm_list";
 | 
						|
import * as stream_list from "./stream_list";
 | 
						|
import * as top_left_corner from "./top_left_corner";
 | 
						|
import * as topic_list from "./topic_list";
 | 
						|
import * as unread from "./unread";
 | 
						|
import {notify_server_messages_read} from "./unread_ops";
 | 
						|
 | 
						|
let last_mention_count = 0;
 | 
						|
 | 
						|
function do_new_messages_animation($li) {
 | 
						|
    $li.addClass("new_messages");
 | 
						|
    function mid_animation() {
 | 
						|
        $li.removeClass("new_messages");
 | 
						|
        $li.addClass("new_messages_fadeout");
 | 
						|
    }
 | 
						|
    function end_animation() {
 | 
						|
        $li.removeClass("new_messages_fadeout");
 | 
						|
    }
 | 
						|
    setTimeout(mid_animation, 3000);
 | 
						|
    setTimeout(end_animation, 6000);
 | 
						|
}
 | 
						|
 | 
						|
export function animate_mention_changes($li, new_mention_count) {
 | 
						|
    if (new_mention_count > last_mention_count) {
 | 
						|
        do_new_messages_animation($li);
 | 
						|
    }
 | 
						|
    last_mention_count = new_mention_count;
 | 
						|
}
 | 
						|
 | 
						|
export function set_count_toggle_button($elem, count) {
 | 
						|
    if (count === 0) {
 | 
						|
        if ($elem.is(":animated")) {
 | 
						|
            return $elem.stop(true, true).hide();
 | 
						|
        }
 | 
						|
        return $elem.hide(500);
 | 
						|
    } else if (count > 0 && count < 1000) {
 | 
						|
        $elem.show(500);
 | 
						|
        return $elem.text(count);
 | 
						|
    }
 | 
						|
    $elem.show(500);
 | 
						|
    return $elem.text("1k+");
 | 
						|
}
 | 
						|
 | 
						|
export function update_unread_counts() {
 | 
						|
    // Pure computation:
 | 
						|
    const res = unread.get_counts();
 | 
						|
 | 
						|
    // Side effects from here down:
 | 
						|
    // This updates some DOM elements directly, so try to
 | 
						|
    // avoid excessive calls to this.
 | 
						|
    activity.update_dom_with_unread_counts(res);
 | 
						|
    top_left_corner.update_dom_with_unread_counts(res);
 | 
						|
    stream_list.update_dom_with_unread_counts(res);
 | 
						|
    pm_list.update_dom_with_unread_counts(res);
 | 
						|
    topic_list.update();
 | 
						|
    const notifiable_unread_count = unread.calculate_notifiable_count(res);
 | 
						|
    notifications.update_unread_counts(notifiable_unread_count, res.private_message_count);
 | 
						|
 | 
						|
    // Set the unread counts that we show in the buttons that
 | 
						|
    // toggle open the sidebar menus when we have a thin window.
 | 
						|
    set_count_toggle_button($("#streamlist-toggle-unreadcount"), res.home_unread_messages);
 | 
						|
    set_count_toggle_button($("#userlist-toggle-unreadcount"), res.private_message_count);
 | 
						|
}
 | 
						|
 | 
						|
export function should_display_bankruptcy_banner() {
 | 
						|
    // Until we've handled possibly declaring bankruptcy, don't show
 | 
						|
    // unread counts since they only consider messages that are loaded
 | 
						|
    // client side and may be different from the numbers reported by
 | 
						|
    // the server.
 | 
						|
 | 
						|
    if (!page_params.furthest_read_time) {
 | 
						|
        // We've never read a message.
 | 
						|
        return false;
 | 
						|
    }
 | 
						|
 | 
						|
    const now = Date.now() / 1000;
 | 
						|
    if (
 | 
						|
        page_params.unread_msgs.count > 500 &&
 | 
						|
        now - page_params.furthest_read_time > 60 * 60 * 24 * 2
 | 
						|
    ) {
 | 
						|
        // 2 days.
 | 
						|
        return true;
 | 
						|
    }
 | 
						|
 | 
						|
    return false;
 | 
						|
}
 | 
						|
 | 
						|
export function notify_messages_remain_unread() {
 | 
						|
    $("#mark_as_read_turned_off_banner").show();
 | 
						|
}
 | 
						|
 | 
						|
export function initialize() {
 | 
						|
    update_unread_counts();
 | 
						|
 | 
						|
    $("#mark_as_read_turned_off_banner").html(render_mark_as_read_turned_off_banner());
 | 
						|
    $("#mark_as_read_turned_off_banner").hide();
 | 
						|
    $("#mark_view_read").on("click", () => {
 | 
						|
        // Mark all messages in the current view as read.
 | 
						|
        //
 | 
						|
        // BUG: This logic only supports marking messages visible in
 | 
						|
        // the present view as read; we need a server API to mark
 | 
						|
        // every message matching the current search as read.
 | 
						|
        const unread_messages = message_lists.current.data
 | 
						|
            .all_messages()
 | 
						|
            .filter((message) => unread.message_unread(message));
 | 
						|
        notify_server_messages_read(unread_messages);
 | 
						|
 | 
						|
        $("#mark_as_read_turned_off_banner").hide();
 | 
						|
    });
 | 
						|
}
 |