mirror of
https://github.com/QuivrHQ/quivr.git
synced 2024-12-15 01:21:48 +03:00
202daac77a
# Description US: #1490
52 lines
1.5 KiB
TypeScript
52 lines
1.5 KiB
TypeScript
import { useQuery, useQueryClient } from "@tanstack/react-query";
|
|
import { useParams } from "next/navigation";
|
|
|
|
import { ONBOARDING_DATA_KEY } from "@/lib/api/onboarding/config";
|
|
import { useOnboardingApi } from "@/lib/api/onboarding/useOnboardingApi";
|
|
|
|
import { Onboarding } from "../types/Onboarding";
|
|
|
|
// eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types
|
|
export const useOnboarding = () => {
|
|
const { getOnboarding } = useOnboardingApi();
|
|
const params = useParams();
|
|
const { updateOnboarding } = useOnboardingApi();
|
|
const queryClient = useQueryClient();
|
|
|
|
const chatId = params?.chatId as string | undefined;
|
|
|
|
const { data } = useQuery({
|
|
queryFn: getOnboarding,
|
|
queryKey: [ONBOARDING_DATA_KEY],
|
|
});
|
|
|
|
const onboarding: Onboarding = data ?? {
|
|
onboarding_a: false,
|
|
onboarding_b1: false,
|
|
onboarding_b2: false,
|
|
onboarding_b3: false,
|
|
};
|
|
|
|
const isOnboarding = Object.values(onboarding).some((value) => value);
|
|
|
|
const updateOnboardingHandler = async (
|
|
newOnboardingStatus: Partial<Onboarding>
|
|
) => {
|
|
await updateOnboarding(newOnboardingStatus);
|
|
await queryClient.invalidateQueries({ queryKey: [ONBOARDING_DATA_KEY] });
|
|
};
|
|
|
|
const shouldDisplayWelcomeChat = onboarding.onboarding_a;
|
|
|
|
const shouldDisplayOnboardingAInstructions =
|
|
chatId === undefined && shouldDisplayWelcomeChat;
|
|
|
|
return {
|
|
onboarding,
|
|
shouldDisplayOnboardingAInstructions,
|
|
shouldDisplayWelcomeChat,
|
|
updateOnboarding: updateOnboardingHandler,
|
|
isOnboarding,
|
|
};
|
|
};
|