From 63bfd818325afbb0d5575b4eb385614967097ab9 Mon Sep 17 00:00:00 2001 From: matushl Date: Sat, 23 Nov 2024 19:52:36 +0100 Subject: [PATCH] resolve #132: Add Crossroad for root page --- next.config.js | 11 ------ src/components/Crossroad/Crossroad.tsx | 54 ++++++++++++++++++++++++++ src/pages/index.tsx | 7 ++++ src/svg/strom.svg | 5 +++ src/theme.ts | 20 ++++++++++ 5 files changed, 86 insertions(+), 11 deletions(-) create mode 100644 src/components/Crossroad/Crossroad.tsx create mode 100644 src/pages/index.tsx create mode 100644 src/svg/strom.svg diff --git a/next.config.js b/next.config.js index 25413c0f..8f0aedff 100644 --- a/next.config.js +++ b/next.config.js @@ -1,16 +1,5 @@ /** @type import('next').NextConfig */ module.exports = { - // docs: https://nextjs.org/docs/api-reference/next.config.js/redirects - async redirects() { - return [ - // redirect home stranky na strom podstranku - { - source: '/', - destination: '/strom', - permanent: true, - }, - ] - }, // docs: https://nextjs.org/docs/api-reference/next.config.js/rewrites async rewrites() { return [ diff --git a/src/components/Crossroad/Crossroad.tsx b/src/components/Crossroad/Crossroad.tsx new file mode 100644 index 00000000..91b40db0 --- /dev/null +++ b/src/components/Crossroad/Crossroad.tsx @@ -0,0 +1,54 @@ +import {Box, Stack, Typography} from '@mui/material' +import Grid from '@mui/material/Unstable_Grid2' +import React, {useState} from 'react' + +import Strom from '@/svg/strom.svg' + +import {Button} from '../Clickable/Button' +import {Link} from '../Clickable/Link' + +export const Crossroad: React.FC = () => { + const [isProblem, setIsProblem] = useState(false) + + const corssroadItems = [ + {label: 'STROM', url: 'strom/'}, + {label: 'Matik', url: 'matik/'}, + {label: 'Malynár', url: 'malynar/'}, + {label: 'Kôš', url: 'https://kos.strom.sk/'}, + {label: 'Máš problém', url: 'https://masproblem.strom.sk/'}, + ] + return !isProblem ? ( + + + Máš problém? + + + + Áno + + + + + ) : ( + + + + + + + + + + {corssroadItems.map(({label, url}) => ( + + {label} + + ))} + + + + + ) +} diff --git a/src/pages/index.tsx b/src/pages/index.tsx new file mode 100644 index 00000000..c0b23e2d --- /dev/null +++ b/src/pages/index.tsx @@ -0,0 +1,7 @@ +import {NextPage} from 'next' + +import {Crossroad} from '@/components/Crossroad/Crossroad' + +const Page: NextPage = () => + +export default Page diff --git a/src/svg/strom.svg b/src/svg/strom.svg new file mode 100644 index 00000000..2eb53c67 --- /dev/null +++ b/src/svg/strom.svg @@ -0,0 +1,5 @@ + + + + + diff --git a/src/theme.ts b/src/theme.ts index b8a58c65..81575bff 100644 --- a/src/theme.ts +++ b/src/theme.ts @@ -8,6 +8,7 @@ declare module '@mui/material/styles' { button1: React.CSSProperties button2: React.CSSProperties button3: React.CSSProperties + crossroadButton: React.CSSProperties seminarButton: React.CSSProperties postTitle: React.CSSProperties postBody: React.CSSProperties @@ -25,6 +26,7 @@ declare module '@mui/material/styles' { button1?: React.CSSProperties button2?: React.CSSProperties button3?: React.CSSProperties + crossroadButton?: React.CSSProperties seminarButton?: React.CSSProperties postTitle?: React.CSSProperties postBody?: React.CSSProperties @@ -44,6 +46,7 @@ declare module '@mui/material/Typography' { button1: true button2: true button3: true + crossroadButton: true seminarButton: true postTitle: true postBody: true @@ -142,6 +145,12 @@ const _theme = createTheme({ fontWeight: 800, fontStyle: 'italic', }, + crossroadButton: { + ...font.style, + textTransform: 'uppercase', + fontWeight: 800, + fontStyle: 'italic', + }, seminarButton: { ...font.style, textTransform: 'uppercase', @@ -196,6 +205,7 @@ const _theme = createTheme({ button1: 'span', button2: 'span', button3: 'span', + crossroadButton: 'span', seminarButton: 'span', postTitle: 'h1', postBody: 'span', @@ -339,6 +349,16 @@ export const theme: Theme = { [xl]: {fontSize: pxToRem(14)}, lineHeight: 1.5, }, + crossroadButton: { + ..._theme.typography.button1, + // original Figma fontSize: 50px + fontSize: pxToRem(20), + [sm]: {fontSize: pxToRem(32)}, + [md]: {fontSize: pxToRem(38)}, + [lg]: {fontSize: pxToRem(44)}, + [xl]: {fontSize: pxToRem(50)}, // design + lineHeight: 1.5, + }, seminarButton: { ..._theme.typography.seminarButton, // original Figma fontSize: 30px, mobile non-existent