revite/src/components/navigation/left/common.ts

104 lines
3 KiB
TypeScript
Raw Normal View History

2021-06-19 10:29:04 -04:00
import { Channel } from "revolt.js";
2021-07-05 06:23:23 -04:00
2021-06-19 10:29:04 -04:00
import { useLayoutEffect } from "preact/hooks";
2021-07-05 06:23:23 -04:00
import { dispatch } from "../../../redux";
2021-06-19 10:29:04 -04:00
import { Unreads } from "../../../redux/reducers/unreads";
2021-07-05 06:23:23 -04:00
2021-06-19 10:29:04 -04:00
import { HookContext, useForceUpdate } from "../../../context/revoltjs/hooks";
type UnreadProps = {
2021-07-05 06:25:20 -04:00
channel: Channel;
unreads: Unreads;
2021-07-05 06:23:23 -04:00
};
export function useUnreads(
2021-07-05 06:25:20 -04:00
{ channel, unreads }: UnreadProps,
context?: HookContext,
2021-07-05 06:23:23 -04:00
) {
2021-07-05 06:25:20 -04:00
const ctx = useForceUpdate(context);
2021-06-19 10:29:04 -04:00
2021-07-05 06:25:20 -04:00
useLayoutEffect(() => {
function checkUnread(target?: Channel) {
if (!target) return;
if (target._id !== channel._id) return;
if (
target.channel_type === "SavedMessages" ||
target.channel_type === "VoiceChannel"
)
return;
2021-06-19 10:29:04 -04:00
2021-07-05 06:25:20 -04:00
const unread = unreads[channel._id]?.last_id;
if (target.last_message) {
const message =
typeof target.last_message === "string"
? target.last_message
: target.last_message._id;
if (!unread || (unread && message.localeCompare(unread) > 0)) {
dispatch({
type: "UNREADS_MARK_READ",
channel: channel._id,
message,
});
2021-06-19 10:29:04 -04:00
2021-07-05 06:25:20 -04:00
ctx.client.req(
"PUT",
`/channels/${channel._id}/ack/${message}` as "/channels/id/ack/id",
);
}
}
}
2021-06-19 10:29:04 -04:00
2021-07-05 06:25:20 -04:00
checkUnread(channel);
2021-06-19 10:29:04 -04:00
2021-07-05 06:25:20 -04:00
ctx.client.channels.addListener("mutation", checkUnread);
return () =>
ctx.client.channels.removeListener("mutation", checkUnread);
}, [channel, unreads]);
2021-06-19 10:29:04 -04:00
}
export function mapChannelWithUnread(channel: Channel, unreads: Unreads) {
2021-07-05 06:25:20 -04:00
let last_message_id;
if (
channel.channel_type === "DirectMessage" ||
channel.channel_type === "Group"
) {
last_message_id = channel.last_message?._id;
} else if (channel.channel_type === "TextChannel") {
last_message_id = channel.last_message;
} else {
return {
...channel,
unread: undefined,
alertCount: undefined,
timestamp: channel._id,
};
}
2021-06-19 10:29:04 -04:00
2021-07-05 06:25:20 -04:00
let unread: "mention" | "unread" | undefined;
let alertCount: undefined | number;
if (last_message_id && unreads) {
const u = unreads[channel._id];
if (u) {
if (u.mentions && u.mentions.length > 0) {
alertCount = u.mentions.length;
unread = "mention";
} else if (
u.last_id &&
last_message_id.localeCompare(u.last_id) > 0
) {
unread = "unread";
}
} else {
unread = "unread";
}
}
2021-06-19 10:29:04 -04:00
2021-07-05 06:25:20 -04:00
return {
...channel,
timestamp: last_message_id ?? channel._id,
unread,
alertCount,
};
2021-06-19 10:29:04 -04:00
}