2024-06-09 19:43:18 +03:00
|
|
|
import { useEffect, useMemo, useState } from "react";
|
2024-02-11 03:17:05 +03:00
|
|
|
import { useTranslation } from "react-i18next";
|
2024-01-31 00:34:32 +03:00
|
|
|
|
|
|
|
import { KnowledgeToFeed } from "@/app/chat/[chatId]/components/ActionsBar/components";
|
2024-06-09 19:43:18 +03:00
|
|
|
import { useFromConnectionsContext } from "@/app/chat/[chatId]/components/ActionsBar/components/KnowledgeToFeed/components/FromConnections/FromConnectionsProvider/hooks/useFromConnectionContext";
|
|
|
|
import { OpenedConnection } from "@/lib/api/sync/types";
|
2024-02-11 03:17:05 +03:00
|
|
|
import { useBrainContext } from "@/lib/context/BrainProvider/hooks/useBrainContext";
|
2024-01-31 00:34:32 +03:00
|
|
|
import { useKnowledgeToFeedContext } from "@/lib/context/KnowledgeToFeedProvider/hooks/useKnowledgeToFeedContext";
|
2024-06-09 19:43:18 +03:00
|
|
|
import { createHandleGetButtonProps } from "@/lib/helpers/handleConnectionButtons";
|
2024-01-31 00:34:32 +03:00
|
|
|
|
|
|
|
import styles from "./UploadDocumentModal.module.scss";
|
2024-02-29 03:42:14 +03:00
|
|
|
import { useAddKnowledge } from "./hooks/useAddKnowledge";
|
2024-01-31 00:34:32 +03:00
|
|
|
|
2024-02-11 03:17:05 +03:00
|
|
|
import { Modal } from "../ui/Modal/Modal";
|
|
|
|
import { QuivrButton } from "../ui/QuivrButton/QuivrButton";
|
2024-02-07 03:05:07 +03:00
|
|
|
|
2024-01-31 00:34:32 +03:00
|
|
|
export const UploadDocumentModal = (): JSX.Element => {
|
2024-02-11 03:17:05 +03:00
|
|
|
const { shouldDisplayFeedCard, setShouldDisplayFeedCard, knowledgeToFeed } =
|
2024-02-07 03:05:07 +03:00
|
|
|
useKnowledgeToFeedContext();
|
2024-02-11 03:17:05 +03:00
|
|
|
const { currentBrain } = useBrainContext();
|
|
|
|
const { feedBrain } = useAddKnowledge();
|
|
|
|
const [feeding, setFeeding] = useState<boolean>(false);
|
2024-06-09 19:43:18 +03:00
|
|
|
const {
|
|
|
|
currentSyncId,
|
|
|
|
setCurrentSyncId,
|
|
|
|
openedConnections,
|
|
|
|
setOpenedConnections,
|
|
|
|
} = useFromConnectionsContext();
|
|
|
|
const [currentConnection, setCurrentConnection] = useState<
|
|
|
|
OpenedConnection | undefined
|
|
|
|
>(undefined);
|
2024-02-11 03:17:05 +03:00
|
|
|
|
|
|
|
useKnowledgeToFeedContext();
|
|
|
|
const { t } = useTranslation(["knowledge"]);
|
|
|
|
|
2024-06-09 19:43:18 +03:00
|
|
|
const disabled = useMemo(() => {
|
|
|
|
return (
|
|
|
|
(knowledgeToFeed.length === 0 &&
|
|
|
|
openedConnections.filter((connection) => {
|
|
|
|
return connection.submitted || !!connection.last_synced;
|
|
|
|
}).length === 0) ||
|
|
|
|
!currentBrain
|
|
|
|
);
|
|
|
|
}, [knowledgeToFeed, openedConnections, currentBrain, currentSyncId]);
|
|
|
|
|
2024-02-11 03:17:05 +03:00
|
|
|
const handleFeedBrain = async () => {
|
|
|
|
setFeeding(true);
|
|
|
|
await feedBrain();
|
|
|
|
setFeeding(false);
|
|
|
|
setShouldDisplayFeedCard(false);
|
|
|
|
};
|
2024-01-31 00:34:32 +03:00
|
|
|
|
2024-06-09 19:43:18 +03:00
|
|
|
const getButtonProps = createHandleGetButtonProps(
|
|
|
|
currentConnection,
|
|
|
|
openedConnections,
|
|
|
|
setOpenedConnections,
|
|
|
|
currentSyncId,
|
|
|
|
setCurrentSyncId
|
|
|
|
);
|
|
|
|
const buttonProps = getButtonProps();
|
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
setCurrentConnection(
|
|
|
|
openedConnections.find(
|
|
|
|
(connection) => connection.user_sync_id === currentSyncId
|
|
|
|
)
|
|
|
|
);
|
|
|
|
}, [currentSyncId]);
|
|
|
|
|
2024-01-31 00:34:32 +03:00
|
|
|
if (!shouldDisplayFeedCard) {
|
|
|
|
return <></>;
|
|
|
|
}
|
|
|
|
|
|
|
|
return (
|
2024-02-07 03:05:07 +03:00
|
|
|
<Modal
|
|
|
|
isOpen={shouldDisplayFeedCard}
|
|
|
|
setOpen={setShouldDisplayFeedCard}
|
2024-02-11 03:17:05 +03:00
|
|
|
title={t("addKnowledgeTitle", { ns: "knowledge" })}
|
|
|
|
desc={t("addKnowledgeSubtitle", { ns: "knowledge" })}
|
2024-03-29 00:22:16 +03:00
|
|
|
size="big"
|
2024-02-07 03:05:07 +03:00
|
|
|
CloseTrigger={<div />}
|
|
|
|
>
|
|
|
|
<div className={styles.knowledge_modal}>
|
2024-02-11 03:17:05 +03:00
|
|
|
<KnowledgeToFeed />
|
2024-06-09 19:43:18 +03:00
|
|
|
<div
|
|
|
|
className={`${styles.buttons} ${
|
|
|
|
!currentSyncId ? styles.standalone : ""
|
|
|
|
}`}
|
|
|
|
>
|
|
|
|
{!!currentSyncId && (
|
|
|
|
<QuivrButton
|
|
|
|
label="Back to connections"
|
|
|
|
color="primary"
|
|
|
|
iconName="chevronLeft"
|
|
|
|
onClick={() => {
|
|
|
|
setCurrentSyncId(undefined);
|
|
|
|
}}
|
|
|
|
/>
|
|
|
|
)}
|
|
|
|
{currentSyncId ? (
|
|
|
|
<QuivrButton
|
|
|
|
label={buttonProps.label}
|
|
|
|
color={buttonProps.type}
|
|
|
|
iconName={buttonProps.type === "dangerous" ? "delete" : "add"}
|
|
|
|
onClick={buttonProps.callback}
|
|
|
|
important={true}
|
|
|
|
disabled={buttonProps.disabled}
|
|
|
|
/>
|
|
|
|
) : (
|
|
|
|
<QuivrButton
|
|
|
|
label="Feed Brain"
|
|
|
|
color="primary"
|
|
|
|
iconName="add"
|
|
|
|
onClick={() => {
|
|
|
|
setOpenedConnections([]);
|
|
|
|
void handleFeedBrain();
|
|
|
|
}}
|
|
|
|
disabled={disabled}
|
|
|
|
isLoading={feeding}
|
|
|
|
important={true}
|
|
|
|
/>
|
|
|
|
)}
|
2024-02-11 03:17:05 +03:00
|
|
|
</div>
|
2024-02-07 03:05:07 +03:00
|
|
|
</div>
|
|
|
|
</Modal>
|
2024-01-31 00:34:32 +03:00
|
|
|
);
|
|
|
|
};
|