github-actions[bot]
Sync from https://github.com/felladrin/MiniSearch
6e29063
import { Center, Container, Loader, Stack } from "@mantine/core";
import { usePubSub } from "create-pubsub/react";
import { Suspense } from "react";
import { lazy } from "react";
import {
imageSearchStatePubSub,
queryPubSub,
settingsPubSub,
textGenerationStatePubSub,
textSearchStatePubSub,
} from "../../../modules/pubSub";
import { searchAndRespond } from "../../../modules/textGeneration";
const AiResponseSection = lazy(
() => import("../../AiResponse/AiResponseSection"),
);
const SearchResultsSection = lazy(
() => import("../../Search/Results/SearchResultsSection"),
);
const MenuButton = lazy(() => import("./Menu/MenuButton"));
const SearchForm = lazy(() => import("../../Search/Form/SearchForm"));
const EnableAiResponsePrompt = lazy(
() => import("../../AiResponse/EnableAiResponsePrompt"),
);
export default function MainPage() {
const [query, updateQuery] = usePubSub(queryPubSub);
const [textSearchState] = usePubSub(textSearchStatePubSub);
const [imageSearchState] = usePubSub(imageSearchStatePubSub);
const [textGenerationState] = usePubSub(textGenerationStatePubSub);
const [settings, setSettings] = usePubSub(settingsPubSub);
const isQueryEmpty = query.length === 0;
return (
<Container>
<Stack py="md" mih="100vh" justify={isQueryEmpty ? "center" : undefined}>
<Suspense
fallback={
<Center>
<Loader type="bars" />
</Center>
}
>
<SearchForm
query={query}
updateQuery={updateQuery}
additionalButtons={<MenuButton />}
/>
</Suspense>
{!isQueryEmpty && (
<>
{settings.showEnableAiResponsePrompt && (
<Suspense>
<EnableAiResponsePrompt
onAccept={() => {
setSettings({
...settings,
showEnableAiResponsePrompt: false,
enableAiResponse: true,
});
searchAndRespond();
}}
onDecline={() => {
setSettings({
...settings,
showEnableAiResponsePrompt: false,
enableAiResponse: false,
});
}}
/>
</Suspense>
)}
{!settings.showEnableAiResponsePrompt &&
textGenerationState !== "idle" && (
<Suspense>
<AiResponseSection />
</Suspense>
)}
{(textSearchState !== "idle" || imageSearchState !== "idle") && (
<Suspense>
<SearchResultsSection />
</Suspense>
)}
</>
)}
</Stack>
</Container>
);
}