diff --git a/src/components/ChatItem.tsx b/src/components/ChatItem.tsx
new file mode 100644
index 0000000..9a901a8
--- /dev/null
+++ b/src/components/ChatItem.tsx
@@ -0,0 +1,88 @@
+import { ActionIcon, Flex, Menu } from "@mantine/core";
+import {
+ IconDotsVertical,
+ IconMessages,
+ IconPencil,
+ IconPin,
+ IconPinned,
+ IconPinnedOff,
+ IconTrash
+} from "@tabler/icons-react";
+import { Link } from "@tanstack/react-location";
+import { Chat, db } from "../db";
+import { DeleteChatModal } from "./DeleteChatModal";
+import { EditChatModal } from "./EditChatModal";
+import { MainLink } from "./MainLink";
+import { notifications } from "@mantine/notifications";
+
+export function ChatItem({ chat, isActive }: { chat: Chat, isActive: boolean }) {
+ const toggleChatPin = async (chatId: string, event: React.UIEvent) => {
+ try {
+ event.preventDefault();
+ await db.chats.where({ id: chatId }).modify((chat) => {
+ chat.pinned = !chat.pinned;
+ });
+ } catch (error: any) {
+ if (error.toJSON().message === "Network Error") {
+ notifications.show({
+ title: "Error",
+ color: "red",
+ message: "No internet connection.",
+ });
+ }
+ const message = error.response?.data?.error?.message;
+ if (message) {
+ notifications.show({
+ title: "Error",
+ color: "red",
+ message,
+ });
+ }
+ }
+ };
+
+ return (
+ ({
+ marginTop: 1,
+ "&:hover, &.active": {
+ backgroundColor: theme.colorScheme === "dark" ? theme.colors.dark[6] : theme.colors.gray[1],
+ },
+ })}
+ >
+
+ : }
+ color="teal"
+ chat={chat}
+ label={chat.description}
+ />
+
+
+
+ )
+}
diff --git a/src/components/Chats.tsx b/src/components/Chats.tsx
index 278b54d..0fc6bd4 100644
--- a/src/components/Chats.tsx
+++ b/src/components/Chats.tsx
@@ -1,22 +1,9 @@
-import { ActionIcon, Flex, Menu, Text } from "@mantine/core";
-import {
- IconDotsVertical,
- IconMessages,
- IconPencil,
- IconPin,
- IconPinned,
- IconPinnedOff,
- IconTrash
-} from "@tabler/icons-react";
-import { Link } from "@tanstack/react-location";
+import { Text } from "@mantine/core";
import { useLiveQuery } from "dexie-react-hooks";
import { useMemo } from "react";
-import { Chat, db } from "../db";
+import { db } from "../db";
import { useChatId } from "../hooks/useChatId";
-import { DeleteChatModal } from "./DeleteChatModal";
-import { EditChatModal } from "./EditChatModal";
-import { MainLink } from "./MainLink";
-import { notifications } from "@mantine/notifications";
+import { ChatItem } from "./ChatItem";
export function Chats({ search }: { search: string }) {
const chatId = useChatId();
@@ -32,91 +19,25 @@ export function Chats({ search }: { search: string }) {
[chats, search]
);
- const toggleChatPin = async (chatId: string, event: React.UIEvent) => {
- try {
- event.preventDefault();
- await db.chats.where({ id: chatId }).modify((chat) => {
- chat.pinned = !chat.pinned;
- });
- } catch (error: any) {
- if (error.toJSON().message === "Network Error") {
- notifications.show({
- title: "Error",
- color: "red",
- message: "No internet connection.",
- });
- }
- const message = error.response?.data?.error?.message;
- if (message) {
- notifications.show({
- title: "Error",
- color: "red",
- message,
- });
- }
- }
- };
-
- const ChatItem = ({ chat }: { chat: Chat }) => (
- ({
- marginTop: 1,
- "&:hover, &.active": {
- backgroundColor: theme.colorScheme === "dark" ? theme.colors.dark[6] : theme.colors.gray[1],
- },
- })}
- >
-
- : }
- color="teal"
- chat={chat}
- label={chat.description}
- />
-
-
-
- );
+ const pinnedChats = useMemo(() => filteredChats.filter((chat) => chat.pinned), [filteredChats]);
+ const unpinnedChats = useMemo(() => filteredChats.filter((chat) => !chat.pinned), [filteredChats]);
return (
<>
-
- {filteredChats
- .filter((chat) => chat.pinned)
- .map((chat) => (
-
- ))}
+ {pinnedChats.length > 0 ? (
+ <>
+
+ {pinnedChats.map((chat) => (
+
+ ))}
-
- {filteredChats
- .filter((chat) => !chat.pinned)
- .map((chat) => (
-
- ))}
+ {unpinnedChats.length > 0 ? : null}
+ >
+ ) : null}
+
+ {unpinnedChats.map((chat) => (
+
+ ))}
>
- );
+ )
}