Browse Source

wip

pull/497/head
Hunter Thornsberry 1 year ago
parent
commit
3bfd96defe
  1. 11
      src/core/stores/deviceStore.ts
  2. 2
      src/core/subscriptions.ts
  3. 9
      src/pages/Messages.tsx

11
src/core/stores/deviceStore.ts

@ -151,7 +151,7 @@ export const useDeviceStore = createStore<DeviceState>((set, get) => ({
},
pendingSettingsChanges: false,
messageDraft: "",
unreadCounts: new Map([[0, 100],[2718471552, 1]]),
unreadCounts: new Map([[0, 100],[3663106604, 1]]),
setStatus: (status: Types.DeviceStatusEnum) => {
set(
@ -634,13 +634,16 @@ export const useDeviceStore = createStore<DeviceState>((set, get) => ({
}),
);
},
setUnread: (id: number, count: number) => {
setUnread: (unread_id: number, count?: number) => {
set(
produce<DeviceState>((draft) => {
console.log(id, count);
const device = draft.devices.get(id);
if (device) {
device.unreadCounts.set(id, count);
if (count == null) {
let currentCount = device.unreadCounts.get(unread_id) ?? 0;
count = currentCount + 1;
}
device.unreadCounts.set(unread_id, count);
}
})
);

2
src/core/subscriptions.ts

@ -85,7 +85,7 @@ export const subscribeAll = (
...messagePacket,
state: messagePacket.from !== myNodeNum ? "ack" : "waiting",
});
device.unreadCounts.set(messagePacket.from, 1);
device.setUnread(messagePacket.from);
});
connection.events.onTraceRoutePacket.subscribe((traceRoutePacket) => {

9
src/pages/Messages.tsx

@ -14,14 +14,15 @@ import { HashIcon, LockIcon, LockOpenIcon } from "lucide-react";
import { useState } from "react";
export const MessagesPage = () => {
const { channels, nodes, hardware, messages, unreadCounts } = useDevice();
const { channels, nodes, hardware, messages, unreadCounts, setUnread } = useDevice();
const { activeChat, chatType, setActiveChat, setChatType } = useAppStore();
const [searchTerm, setSearchTerm] = useState<string>("");
const filteredNodes = Array.from(nodes.values()).filter((node) => {
if (node.num === hardware.myNodeNum) return false;
const nodeName = node.user?.longName ?? `!${numberToHexUnpadded(node.num)}`;
return nodeName.toLowerCase().includes(searchTerm.toLowerCase());
});
}).map((node) => { node.unreadCount = unreadCounts.get(node.num) ?? 0; return node;})
.sort((a, b) => b.unreadCount - a.unreadCount);
const allChannels = Array.from(channels.values());
const filteredChannels = allChannels.filter(
(ch) => ch.role !== Protobuf.Channel.Channel_Role.DISABLED,
@ -48,7 +49,7 @@ export const MessagesPage = () => {
onClick={() => {
setChatType("broadcast");
setActiveChat(channel.index);
unreadCounts.set(channel.index, 0);
setUnread(channel.index, 0);
}}
element={<HashIcon size={16} className="mr-2" />}
/>
@ -75,7 +76,7 @@ export const MessagesPage = () => {
onClick={() => {
setChatType("direct");
setActiveChat(node.num);
unreadCounts.set(node.num, 1)
setUnread(node.num, 0)
}}
element={
<Avatar

Loading…
Cancel
Save