From 66cc61ffa024daf131e149d38658207e402e70a7 Mon Sep 17 00:00:00 2001 From: Sasha Chabin Date: Thu, 20 Jun 2024 01:18:45 +0500 Subject: [PATCH] Add `size` prop for `` (#110) --- client/api/main-page/main-page.types.ts | 2 ++ client/components/MainPage/Card/Card.module.css | 12 ++++++++++++ client/components/MainPage/Card/Card.tsx | 3 ++- client/components/MainPage/Card/Card.types.ts | 3 ++- client/components/MainPage/MainPage.module.css | 13 ------------- client/components/MainPage/MainPage.tsx | 1 + 6 files changed, 19 insertions(+), 15 deletions(-) diff --git a/client/api/main-page/main-page.types.ts b/client/api/main-page/main-page.types.ts index 9d49bcac..aa0d78f6 100644 --- a/client/api/main-page/main-page.types.ts +++ b/client/api/main-page/main-page.types.ts @@ -1,4 +1,5 @@ export type TCardType = "public" | "car" | "pedestrian" | "other"; +export type TCardSize = "large" | "small"; export type background = { data: { @@ -32,6 +33,7 @@ export interface Card { backgroundImage: background; backgroundImageHover: background; type: TCardType; + size: TCardSize; priority: number; cardId: null; headerCaption: null | string; diff --git a/client/components/MainPage/Card/Card.module.css b/client/components/MainPage/Card/Card.module.css index 525c2731..a0ea5bfb 100644 --- a/client/components/MainPage/Card/Card.module.css +++ b/client/components/MainPage/Card/Card.module.css @@ -42,6 +42,18 @@ } } +.Card_Size-small { + aspect-ratio: 1 / 1; + max-width: 100%; +} + +.Card_Size-large { + grid-area: span 1 / span 2; + aspect-ratio: 2 / 1; + align-self: stretch; +} + + .Card_Public { background-color: var(--cards-public-bg); color: var(--cards-public-text); diff --git a/client/components/MainPage/Card/Card.tsx b/client/components/MainPage/Card/Card.tsx index bcd070fa..004b9ab9 100644 --- a/client/components/MainPage/Card/Card.tsx +++ b/client/components/MainPage/Card/Card.tsx @@ -22,6 +22,7 @@ export function Card({ titleBackgroundColor, type, url, + size, backgroundImage, backgroundImageHover, dynamicContent, @@ -39,7 +40,7 @@ export function Card({ return ( * { - aspect-ratio: 1 / 1; - max-width: 100%; -} - -.MainPageCardGrid > *:first-child, -.MainPageCardGrid > *:nth-last-child(3) { - grid-area: span 1 / span 2; - aspect-ratio: 2 / 1; - align-self: stretch; -} - - @media screen and (min-width: 991px) { .MainPageLogo { margin: 0 auto 0.7em 0.5em; diff --git a/client/components/MainPage/MainPage.tsx b/client/components/MainPage/MainPage.tsx index 11989588..26298e00 100644 --- a/client/components/MainPage/MainPage.tsx +++ b/client/components/MainPage/MainPage.tsx @@ -122,6 +122,7 @@ export function MainPage({ cards, cardsDynamicData, marqueeItems, articles }: Ma headerCaption={attributes.headerCaption} footerCaption={attributes.footerCaption} dynamicContent={getDynamicContent(attributes.dynamicId)} + size={attributes.size} key={id} onClick={ attributes.url.startsWith('/')