Spaces:
Running
Running
File size: 1,715 Bytes
cbe4c9d |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 |
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,
textGenerationStatePubSub,
textSearchStatePubSub,
} from "../../../modules/pubSub";
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"));
export default function MainPage() {
const [query, updateQuery] = usePubSub(queryPubSub);
const [textSearchState] = usePubSub(textSearchStatePubSub);
const [imageSearchState] = usePubSub(imageSearchStatePubSub);
const [textGenerationState] = usePubSub(textGenerationStatePubSub);
return (
<Container>
<Stack
py="md"
mih="100vh"
justify={query.length === 0 ? "center" : undefined}
>
<Suspense
fallback={
<Center>
<Loader type="bars" />
</Center>
}
>
<SearchForm
query={query}
updateQuery={updateQuery}
additionalButtons={<MenuButton />}
/>
</Suspense>
{textGenerationState !== "idle" && (
<Suspense>
<AiResponseSection />
</Suspense>
)}
{(textSearchState !== "idle" || imageSearchState !== "idle") && (
<Suspense>
<SearchResultsSection />
</Suspense>
)}
</Stack>
</Container>
);
}
|