mirror of
https://github.com/docmost/docmost.git
synced 2026-05-15 13:14:11 +08:00
05b3c65b0f
* feat: notifications * feat: watchers * improvements * handle page move for watchers * make watchers non-blocking * more
71 lines
2.0 KiB
TypeScript
71 lines
2.0 KiB
TypeScript
import { useAtom } from "jotai";
|
|
import { currentUserAtom } from "@/features/user/atoms/current-user-atom";
|
|
import React, { useEffect } from "react";
|
|
import useCurrentUser from "@/features/user/hooks/use-current-user";
|
|
import { useTranslation } from "react-i18next";
|
|
import { socketAtom } from "@/features/websocket/atoms/socket-atom.ts";
|
|
import { io } from "socket.io-client";
|
|
import { SOCKET_URL } from "@/features/websocket/types";
|
|
import { useQuerySubscription } from "@/features/websocket/use-query-subscription.ts";
|
|
import { useTreeSocket } from "@/features/websocket/use-tree-socket.ts";
|
|
import { useNotificationSocket } from "@/features/notification/hooks/use-notification-socket.ts";
|
|
import { useCollabToken } from "@/features/auth/queries/auth-query.tsx";
|
|
import { Error404 } from "@/components/ui/error-404.tsx";
|
|
|
|
export function UserProvider({ children }: React.PropsWithChildren) {
|
|
const [, setCurrentUser] = useAtom(currentUserAtom);
|
|
const { data, isLoading, error, isError } = useCurrentUser();
|
|
const { i18n } = useTranslation();
|
|
const [, setSocket] = useAtom(socketAtom);
|
|
// fetch collab token on load
|
|
const { data: collab } = useCollabToken();
|
|
|
|
useEffect(() => {
|
|
if (isLoading || isError) {
|
|
return;
|
|
}
|
|
|
|
const newSocket = io(SOCKET_URL, {
|
|
transports: ["websocket"],
|
|
withCredentials: true,
|
|
});
|
|
|
|
// @ts-ignore
|
|
setSocket(newSocket);
|
|
|
|
newSocket.on("connect", () => {
|
|
console.log("ws connected");
|
|
});
|
|
|
|
return () => {
|
|
console.log("ws disconnected");
|
|
newSocket.disconnect();
|
|
};
|
|
}, [isError, isLoading]);
|
|
|
|
useQuerySubscription();
|
|
useTreeSocket();
|
|
useNotificationSocket();
|
|
|
|
useEffect(() => {
|
|
if (data && data.user && data.workspace) {
|
|
setCurrentUser(data);
|
|
i18n.changeLanguage(
|
|
data.user.locale === "en" ? "en-US" : data.user.locale,
|
|
);
|
|
}
|
|
}, [data, isLoading]);
|
|
|
|
if (isLoading) return <></>;
|
|
|
|
if (isError && error?.["response"]?.status === 404) {
|
|
return <Error404 />;
|
|
}
|
|
|
|
if (error) {
|
|
return <></>;
|
|
}
|
|
|
|
return <>{children}</>;
|
|
}
|