mirror of
https://github.com/StanGirard/quivr.git
synced 2024-12-19 08:42:08 +03:00
b0514d6149
* add libraries for traslation purposes * Add button and service for language selection * add spanish translation on login page * add spanish translation on upload page * Add spanish translations for explore page * Add translations on user page * Add translations for config page * Add spanish translations on chat page * add translations for brain page * fix GUI and save on local storage * fix (i18n) init and types * fix (i18n): typos * add translation on new brain modal * add translations on metadata * Add translations on home page * fixes types * fix(frontend-tests): use get by id instead of text --------- Co-authored-by: Gustavo Maciel <gustavo_m13@outlook.com>
46 lines
1.3 KiB
TypeScript
46 lines
1.3 KiB
TypeScript
/* eslint-disable max-lines */
|
|
import { useEffect, useState } from "react";
|
|
import { useTranslation } from 'react-i18next'
|
|
|
|
import { Subscription } from "@/lib/api/brain/brain";
|
|
import { useBrainApi } from "@/lib/api/brain/useBrainApi";
|
|
import { useSupabase } from "@/lib/context/SupabaseProvider";
|
|
import { useToast } from "@/lib/hooks";
|
|
|
|
// eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types
|
|
export const useBrainUsers = (brainId: string) => {
|
|
const [brainUsers, setBrainUsers] = useState<Subscription[]>([]);
|
|
const [isFetchingBrainUsers, setFetchingBrainUsers] = useState(false);
|
|
|
|
const { publish } = useToast();
|
|
const { getBrainUsers } = useBrainApi();
|
|
const { session } = useSupabase();
|
|
const { t } = useTranslation(['brain']);
|
|
|
|
const fetchBrainUsers = async () => {
|
|
// Optimistic update
|
|
setFetchingBrainUsers(brainUsers.length === 0);
|
|
try {
|
|
const users = await getBrainUsers(brainId);
|
|
setBrainUsers(users.filter(({ email }) => email !== session?.user.email));
|
|
} catch {
|
|
publish({
|
|
variant: "danger",
|
|
text: t('errorFetchingBrainUsers',{ns:'brain'})
|
|
});
|
|
} finally {
|
|
setFetchingBrainUsers(false);
|
|
}
|
|
};
|
|
|
|
useEffect(() => {
|
|
void fetchBrainUsers();
|
|
}, []);
|
|
|
|
return {
|
|
brainUsers,
|
|
fetchBrainUsers,
|
|
isFetchingBrainUsers,
|
|
};
|
|
};
|