109 lines
3.8 KiB
TypeScript
Raw Normal View History

2024-07-21 02:51:00 +00:00
import { Box, Center, Flex, Heading, Slider, SliderFilledTrack, SliderThumb, SliderTrack } from '@chakra-ui/react';
2024-07-16 09:11:03 +00:00
import React, { useMemo, useState } from 'react';
2024-07-21 02:51:00 +00:00
export const Logo = (props) => {
2024-07-16 09:11:03 +00:00
// a completely dynamic and interactive logo
// uses borders, border radius, and colour themes to create a simple timeless beautiful logo
// const defaultThemeRaw = ['white', '#F20009', '#FD5F00', '#FFEB03', '#52E013', '#09A7EC', '#982E77', 'white'];
const defaultThemeRaw = ['#F20009', '#FD5F00', '#FFEB03', '#52E013', '#09A7EC', '#982E77', 'white'];
const [reverseColours, setReverseColours] = useState(false);
const defaultTheme = reverseColours ? defaultThemeRaw?.reverse() : defaultThemeRaw;
const [theme, setTheme] = useState('blue');
const [squares, setSquares] = useState(9);
const initialWidth = props?.width || 300;
const [width, setWidth] = useState(initialWidth);
2024-07-16 09:11:03 +00:00
// logo is a T/plus shape made of two intersecting squares
// you can toggle border sides on both squares to create different shapes
const [borderWidth, setBorderWidth] = useState(18);
2024-07-21 02:51:00 +00:00
const [borderRadius, setBorderRadius] = useState(0);
const [padding, setPadding] = useState(0);
2024-07-16 09:11:03 +00:00
const squaresArray = Array.from({ length: squares }, (_, index) => index);
const [spacing, setSpacing] = useState(borderWidth);
// log squaresArray
console.debug('tt.squaresArray', squaresArray);
// basically the 5 squares that make up a plus but with the centre one missing
const [divisions, setDivisions] = useState(3);
2024-07-21 02:51:00 +00:00
const [boxWidth, setBoxWidth] = useState(100 / divisions + '%');
2024-07-16 09:11:03 +00:00
const uuid = useMemo(() => {
return Math.random().toString(36).substring(2) + Date.now().toString(36);
}, []);
2024-07-21 02:51:00 +00:00
const boxStyles = {
padding: `${padding}px`
};
const InnerBox = (props: any = {}) => <Box borderRadius={`${borderRadius}px`} background="hotpink" w="100%" h="100%" {...props}></Box>;
2024-07-21 02:51:00 +00:00
const Square = (props: any = {}) => (
<Box {...boxStyles} display="inline-block" w={boxWidth} h={boxWidth}>
<InnerBox {...props}></InnerBox>
2024-07-21 02:51:00 +00:00
</Box>
);
2024-07-16 09:11:03 +00:00
return (
<>
{/* these are the controls */}
{/* border radius use chakra slider */}
{props?.editable && (
<Flex pb={12} flexDir={'column'}>
<Heading my={4} as="h2" size="md">
Logo Controls
</Heading>
<Heading my={4} as="h3" size="sm">
Width {width}px
</Heading>
<Slider aria-label="slider-ex-1" defaultValue={width} min={0} max={initialWidth * 10} onChange={setWidth}>
<SliderTrack>
<SliderFilledTrack />
</SliderTrack>
<SliderThumb>🟡</SliderThumb>
</Slider>
<Heading my={4} as="h3" size="sm">
Border Radius {borderRadius}px
</Heading>
<Slider aria-label="slider-ex-1" defaultValue={borderRadius} min={0} max={width} onChange={setBorderRadius}>
<SliderTrack>
<SliderFilledTrack />
</SliderTrack>
<SliderThumb>🟡</SliderThumb>
</Slider>
<Heading my={4} as="h3" size="sm">
Padding {padding}px
</Heading>
<Slider aria-label="slider-ex-1" defaultValue={padding} min={0} max={width} onChange={setPadding}>
<SliderTrack>
<SliderFilledTrack />
</SliderTrack>
<SliderThumb>🟡</SliderThumb>
</Slider>
</Flex>
)}
2024-07-21 02:51:00 +00:00
<Box className="tt.logo" fontSize={0} overflow="hidden" w={width + 'px'} h={width + 'px'} position="relative">
{squaresArray.map((_, index) => {
const odd = index % 2 === 0;
const even = !odd;
return <Square key={uuid + 'tt.logo' + index} bg={even ? 'hotpink' : 'transparent'} />;
2024-07-16 09:11:03 +00:00
})}
</Box>
</>
);
};