mirror of https://github.com/zulip/zulip.git
45 lines
1.5 KiB
TypeScript
45 lines
1.5 KiB
TypeScript
import type {Message} from "./message_store";
|
|
import * as sub_store from "./sub_store";
|
|
import type {Recipient} from "./util";
|
|
import * as util from "./util";
|
|
|
|
let focused_recipient: Recipient | undefined;
|
|
|
|
export function should_fade_message(message: Message): boolean {
|
|
return !util.same_recipient(focused_recipient, message);
|
|
}
|
|
|
|
export function clear_focused_recipient(): void {
|
|
focused_recipient = undefined;
|
|
}
|
|
|
|
export function set_focused_recipient(recipient?: Recipient): void {
|
|
focused_recipient = recipient;
|
|
}
|
|
|
|
export function want_normal_display(): boolean {
|
|
// If we're not composing show a normal display.
|
|
if (focused_recipient === undefined) {
|
|
return true;
|
|
}
|
|
|
|
// If the user really hasn't specified anything let, then we want a normal display
|
|
if (focused_recipient.type === "stream") {
|
|
// If a stream doesn't exist, there is no real chance of a mix, so fading
|
|
// is just noise to the user.
|
|
if (!sub_store.get(focused_recipient.stream_id)) {
|
|
return true;
|
|
}
|
|
|
|
// This is kind of debatable. If the topic is empty, it could be that
|
|
// the user simply hasn't started typing it yet, but disabling fading here
|
|
// means the feature doesn't help realms where topics aren't mandatory
|
|
// (which is most realms as of this writing).
|
|
if (focused_recipient.topic === "") {
|
|
return true;
|
|
}
|
|
}
|
|
|
|
return focused_recipient.type === "private" && focused_recipient.reply_to === "";
|
|
}
|