From ab0b83d9a22a718d1ab19953493879e066778993 Mon Sep 17 00:00:00 2001 From: Oleksandra Okhotnykova Date: Fri, 27 Sep 2024 11:17:11 +0200 Subject: [PATCH] OV-421: * load user templates in creations section --- .../creations-section/creations-section.tsx | 6 +-- .../templates-section/templates-section.tsx | 35 +++------------- .../src/bundles/template/pages/templates.tsx | 40 ++++++++++++++++--- .../bundles/template/types/template.type.ts | 9 +---- 4 files changed, 44 insertions(+), 46 deletions(-) diff --git a/frontend/src/bundles/template/components/creations-section/creations-section.tsx b/frontend/src/bundles/template/components/creations-section/creations-section.tsx index ab95f6d9a..53cd0fbca 100644 --- a/frontend/src/bundles/template/components/creations-section/creations-section.tsx +++ b/frontend/src/bundles/template/components/creations-section/creations-section.tsx @@ -10,14 +10,12 @@ import { type Template } from '~/bundles/template/types/types.js'; import { TemplateCard } from '../template-card/template-card.js'; import styles from './styles.module.css'; -//TODO: Change with the backend information -const templates: Template[] = []; - type Properties = { onClick: () => void; + templates: Template[]; }; -const CreationsSection: React.FC = ({ onClick }) => { +const CreationsSection: React.FC = ({ onClick, templates }) => { return ( diff --git a/frontend/src/bundles/template/components/templates-section/templates-section.tsx b/frontend/src/bundles/template/components/templates-section/templates-section.tsx index ed1a24e27..a19604e39 100644 --- a/frontend/src/bundles/template/components/templates-section/templates-section.tsx +++ b/frontend/src/bundles/template/components/templates-section/templates-section.tsx @@ -8,41 +8,25 @@ import { Input, InputGroup, InputLeftElement, - Loader, - Overlay, Select, SimpleGrid, } from '~/bundles/common/components/components.js'; -import { EMPTY_VALUE } from '~/bundles/common/constants/constants.js'; -import { DataStatus } from '~/bundles/common/enums/data-status.enum.js'; import { - useAppDispatch, useAppForm, - useAppSelector, useCallback, - useEffect, useState, } from '~/bundles/common/hooks/hooks.js'; import { IconName } from '~/bundles/common/icons/icons.js'; -import { actions as studioActions } from '~/bundles/studio/store/studio.js'; +import { type Template } from '~/bundles/template/types/types.js'; import { TemplateCard } from '../template-card/template-card.js'; import { DEFAULT_TEMPLATE_PAYLOAD } from './constants.js'; -const TemplatesSection: React.FC = () => { - const dispatch = useAppDispatch(); - - const { templates, dataStatus } = useAppSelector(({ studio }) => studio); - - useEffect(() => { - if (templates.public.length === EMPTY_VALUE) { - void dispatch(studioActions.loadPublicTemplates()); - } - if (!templates.isUserLoaded) { - void dispatch(studioActions.loadUserTemplates()); - } - }, [dispatch, templates]); +type Properties = { + templates: Template[]; +}; +const TemplatesSection: React.FC = ({ templates }) => { const [selectedFormat, setSelectedFormat] = useState< 'landscape' | 'portrait' | null >(null); @@ -61,10 +45,6 @@ const TemplatesSection: React.FC = () => { return ( - - - - { - {templates.public.map(({ id, ...template }) => ( - - ))} - {templates.user.map(({ id, ...template }) => ( + {templates.map(({ id, ...template }) => ( ))} diff --git a/frontend/src/bundles/template/pages/templates.tsx b/frontend/src/bundles/template/pages/templates.tsx index 9e326cb35..4a52c8739 100644 --- a/frontend/src/bundles/template/pages/templates.tsx +++ b/frontend/src/bundles/template/pages/templates.tsx @@ -4,13 +4,24 @@ import { Flex, Header, Icon, + Loader, + Overlay, Sidebar, Text, } from '~/bundles/common/components/components.js'; import { useCollapse } from '~/bundles/common/components/sidebar/hooks/use-collapse.hook.js'; +import { EMPTY_VALUE } from '~/bundles/common/constants/constants.js'; +import { DataStatus } from '~/bundles/common/enums/data-status.enum.js'; import { AppRoute } from '~/bundles/common/enums/enums.js'; -import { useCallback, useNavigate } from '~/bundles/common/hooks/hooks.js'; +import { + useAppDispatch, + useAppSelector, + useCallback, + useEffect, + useNavigate, +} from '~/bundles/common/hooks/hooks.js'; import { IconName } from '~/bundles/common/icons/icons.js'; +import { actions as studioActions } from '~/bundles/studio/store/studio.js'; import { CreationsSection, TemplatesSection, @@ -19,9 +30,21 @@ import { import styles from './styles.module.css'; const Templates: React.FC = () => { - const { isCollapsed } = useCollapse(); - const navigate = useNavigate(); + const dispatch = useAppDispatch(); + + const { templates, dataStatus } = useAppSelector(({ studio }) => studio); + + useEffect(() => { + if (templates.public.length === EMPTY_VALUE) { + void dispatch(studioActions.loadPublicTemplates()); + } + if (!templates.isUserLoaded) { + void dispatch(studioActions.loadUserTemplates()); + } + }, [dispatch, templates]); + + const { isCollapsed } = useCollapse(); const handleClick = useCallback(() => { navigate(AppRoute.STUDIO); @@ -29,6 +52,10 @@ const Templates: React.FC = () => { return ( + + + +
{ > - - + + diff --git a/frontend/src/bundles/template/types/template.type.ts b/frontend/src/bundles/template/types/template.type.ts index 5bf45cdc3..bc3f2eca2 100644 --- a/frontend/src/bundles/template/types/template.type.ts +++ b/frontend/src/bundles/template/types/template.type.ts @@ -1,8 +1 @@ -type Template = { - id: string; - name: string; - url: string | null; - previewUrl: string; -}; - -export { type Template }; +export { type Template } from 'shared';