2023-05-09 07:20:10 +00:00
|
|
|
import { ChevronUpIcon } from '@chakra-ui/icons';
|
feat(ui): remove themes, add hand-crafted dark and light modes
Themes are very fun but due to the differences in perceived saturation and lightness across the
the color spectrum, it's impossible to have have multiple themes that look great without hand-
crafting *every* shade for *every* theme. We've ended up with 4 OK themes (well, 3, because the
light theme was pretty bad).
I've removed the themes and added color mode support. There is now a single dark and light mode,
each with their own color palette and the classic grey / purple / yellow invoke colors that
@blessedcoolant first designed.
I've re-styled almost everything except the model manager and lightbox, which I keep forgetting
to work on.
One new concept is the Chakra `layerStyle`. This lets us define "layers" - think body, first layer,
second layer, etc - that can be applied on various components. By defining layers, we can be more
consistent about the z-axis and its relationship to color and lightness.
2023-06-26 14:12:33 +00:00
|
|
|
import {
|
|
|
|
Box,
|
|
|
|
Collapse,
|
|
|
|
Flex,
|
|
|
|
Spacer,
|
2023-07-05 07:33:03 +00:00
|
|
|
Text,
|
feat(ui): remove themes, add hand-crafted dark and light modes
Themes are very fun but due to the differences in perceived saturation and lightness across the
the color spectrum, it's impossible to have have multiple themes that look great without hand-
crafting *every* shade for *every* theme. We've ended up with 4 OK themes (well, 3, because the
light theme was pretty bad).
I've removed the themes and added color mode support. There is now a single dark and light mode,
each with their own color palette and the classic grey / purple / yellow invoke colors that
@blessedcoolant first designed.
I've re-styled almost everything except the model manager and lightbox, which I keep forgetting
to work on.
One new concept is the Chakra `layerStyle`. This lets us define "layers" - think body, first layer,
second layer, etc - that can be applied on various components. By defining layers, we can be more
consistent about the z-axis and its relationship to color and lightness.
2023-06-26 14:12:33 +00:00
|
|
|
useColorMode,
|
2023-07-05 07:33:03 +00:00
|
|
|
useDisclosure,
|
feat(ui): remove themes, add hand-crafted dark and light modes
Themes are very fun but due to the differences in perceived saturation and lightness across the
the color spectrum, it's impossible to have have multiple themes that look great without hand-
crafting *every* shade for *every* theme. We've ended up with 4 OK themes (well, 3, because the
light theme was pretty bad).
I've removed the themes and added color mode support. There is now a single dark and light mode,
each with their own color palette and the classic grey / purple / yellow invoke colors that
@blessedcoolant first designed.
I've re-styled almost everything except the model manager and lightbox, which I keep forgetting
to work on.
One new concept is the Chakra `layerStyle`. This lets us define "layers" - think body, first layer,
second layer, etc - that can be applied on various components. By defining layers, we can be more
consistent about the z-axis and its relationship to color and lightness.
2023-06-26 14:12:33 +00:00
|
|
|
} from '@chakra-ui/react';
|
2023-07-05 07:33:03 +00:00
|
|
|
import { AnimatePresence, motion } from 'framer-motion';
|
2023-05-08 09:05:43 +00:00
|
|
|
import { PropsWithChildren, memo } from 'react';
|
feat(ui): remove themes, add hand-crafted dark and light modes
Themes are very fun but due to the differences in perceived saturation and lightness across the
the color spectrum, it's impossible to have have multiple themes that look great without hand-
crafting *every* shade for *every* theme. We've ended up with 4 OK themes (well, 3, because the
light theme was pretty bad).
I've removed the themes and added color mode support. There is now a single dark and light mode,
each with their own color palette and the classic grey / purple / yellow invoke colors that
@blessedcoolant first designed.
I've re-styled almost everything except the model manager and lightbox, which I keep forgetting
to work on.
One new concept is the Chakra `layerStyle`. This lets us define "layers" - think body, first layer,
second layer, etc - that can be applied on various components. By defining layers, we can be more
consistent about the z-axis and its relationship to color and lightness.
2023-06-26 14:12:33 +00:00
|
|
|
import { mode } from 'theme/util/mode';
|
2023-05-08 09:05:43 +00:00
|
|
|
|
|
|
|
export type IAIToggleCollapseProps = PropsWithChildren & {
|
|
|
|
label: string;
|
2023-07-05 07:33:03 +00:00
|
|
|
activeLabel?: string;
|
|
|
|
defaultIsOpen?: boolean;
|
2023-05-08 09:05:43 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
const IAICollapse = (props: IAIToggleCollapseProps) => {
|
2023-07-05 07:33:03 +00:00
|
|
|
const { label, activeLabel, children, defaultIsOpen = false } = props;
|
|
|
|
const { isOpen, onToggle } = useDisclosure({ defaultIsOpen });
|
feat(ui): remove themes, add hand-crafted dark and light modes
Themes are very fun but due to the differences in perceived saturation and lightness across the
the color spectrum, it's impossible to have have multiple themes that look great without hand-
crafting *every* shade for *every* theme. We've ended up with 4 OK themes (well, 3, because the
light theme was pretty bad).
I've removed the themes and added color mode support. There is now a single dark and light mode,
each with their own color palette and the classic grey / purple / yellow invoke colors that
@blessedcoolant first designed.
I've re-styled almost everything except the model manager and lightbox, which I keep forgetting
to work on.
One new concept is the Chakra `layerStyle`. This lets us define "layers" - think body, first layer,
second layer, etc - that can be applied on various components. By defining layers, we can be more
consistent about the z-axis and its relationship to color and lightness.
2023-06-26 14:12:33 +00:00
|
|
|
const { colorMode } = useColorMode();
|
2023-07-05 07:33:03 +00:00
|
|
|
|
2023-05-08 09:05:43 +00:00
|
|
|
return (
|
|
|
|
<Box>
|
|
|
|
<Flex
|
|
|
|
onClick={onToggle}
|
|
|
|
sx={{
|
|
|
|
alignItems: 'center',
|
|
|
|
p: 2,
|
|
|
|
px: 4,
|
2023-07-05 07:33:03 +00:00
|
|
|
gap: 2,
|
2023-05-08 09:05:43 +00:00
|
|
|
borderTopRadius: 'base',
|
|
|
|
borderBottomRadius: isOpen ? 0 : 'base',
|
2023-08-23 12:48:51 +00:00
|
|
|
bg: mode('base.250', 'base.750')(colorMode),
|
feat(ui): remove themes, add hand-crafted dark and light modes
Themes are very fun but due to the differences in perceived saturation and lightness across the
the color spectrum, it's impossible to have have multiple themes that look great without hand-
crafting *every* shade for *every* theme. We've ended up with 4 OK themes (well, 3, because the
light theme was pretty bad).
I've removed the themes and added color mode support. There is now a single dark and light mode,
each with their own color palette and the classic grey / purple / yellow invoke colors that
@blessedcoolant first designed.
I've re-styled almost everything except the model manager and lightbox, which I keep forgetting
to work on.
One new concept is the Chakra `layerStyle`. This lets us define "layers" - think body, first layer,
second layer, etc - that can be applied on various components. By defining layers, we can be more
consistent about the z-axis and its relationship to color and lightness.
2023-06-26 14:12:33 +00:00
|
|
|
color: mode('base.900', 'base.100')(colorMode),
|
2023-05-08 09:05:43 +00:00
|
|
|
_hover: {
|
2023-08-23 12:48:51 +00:00
|
|
|
bg: mode('base.300', 'base.700')(colorMode),
|
2023-05-08 09:05:43 +00:00
|
|
|
},
|
|
|
|
fontSize: 'sm',
|
|
|
|
fontWeight: 600,
|
|
|
|
cursor: 'pointer',
|
|
|
|
transitionProperty: 'common',
|
|
|
|
transitionDuration: 'normal',
|
|
|
|
userSelect: 'none',
|
|
|
|
}}
|
|
|
|
>
|
|
|
|
{label}
|
2023-07-05 07:33:03 +00:00
|
|
|
<AnimatePresence>
|
|
|
|
{activeLabel && (
|
|
|
|
<motion.div
|
|
|
|
key="statusText"
|
|
|
|
initial={{
|
|
|
|
opacity: 0,
|
|
|
|
}}
|
|
|
|
animate={{
|
|
|
|
opacity: 1,
|
|
|
|
transition: { duration: 0.1 },
|
|
|
|
}}
|
|
|
|
exit={{
|
|
|
|
opacity: 0,
|
|
|
|
transition: { duration: 0.1 },
|
|
|
|
}}
|
|
|
|
>
|
|
|
|
<Text
|
|
|
|
sx={{ color: 'accent.500', _dark: { color: 'accent.300' } }}
|
|
|
|
>
|
|
|
|
{activeLabel}
|
|
|
|
</Text>
|
|
|
|
</motion.div>
|
|
|
|
)}
|
|
|
|
</AnimatePresence>
|
2023-05-08 09:05:43 +00:00
|
|
|
<Spacer />
|
2023-07-05 07:33:03 +00:00
|
|
|
<ChevronUpIcon
|
|
|
|
sx={{
|
|
|
|
w: '1rem',
|
|
|
|
h: '1rem',
|
|
|
|
transform: isOpen ? 'rotate(0deg)' : 'rotate(180deg)',
|
|
|
|
transitionProperty: 'common',
|
|
|
|
transitionDuration: 'normal',
|
|
|
|
}}
|
|
|
|
/>
|
2023-05-08 09:05:43 +00:00
|
|
|
</Flex>
|
2023-06-01 04:17:32 +00:00
|
|
|
<Collapse in={isOpen} animateOpacity style={{ overflow: 'unset' }}>
|
feat(ui): remove themes, add hand-crafted dark and light modes
Themes are very fun but due to the differences in perceived saturation and lightness across the
the color spectrum, it's impossible to have have multiple themes that look great without hand-
crafting *every* shade for *every* theme. We've ended up with 4 OK themes (well, 3, because the
light theme was pretty bad).
I've removed the themes and added color mode support. There is now a single dark and light mode,
each with their own color palette and the classic grey / purple / yellow invoke colors that
@blessedcoolant first designed.
I've re-styled almost everything except the model manager and lightbox, which I keep forgetting
to work on.
One new concept is the Chakra `layerStyle`. This lets us define "layers" - think body, first layer,
second layer, etc - that can be applied on various components. By defining layers, we can be more
consistent about the z-axis and its relationship to color and lightness.
2023-06-26 14:12:33 +00:00
|
|
|
<Box
|
|
|
|
sx={{
|
2023-08-29 20:40:17 +00:00
|
|
|
p: 4,
|
|
|
|
pb: 4,
|
feat(ui): remove themes, add hand-crafted dark and light modes
Themes are very fun but due to the differences in perceived saturation and lightness across the
the color spectrum, it's impossible to have have multiple themes that look great without hand-
crafting *every* shade for *every* theme. We've ended up with 4 OK themes (well, 3, because the
light theme was pretty bad).
I've removed the themes and added color mode support. There is now a single dark and light mode,
each with their own color palette and the classic grey / purple / yellow invoke colors that
@blessedcoolant first designed.
I've re-styled almost everything except the model manager and lightbox, which I keep forgetting
to work on.
One new concept is the Chakra `layerStyle`. This lets us define "layers" - think body, first layer,
second layer, etc - that can be applied on various components. By defining layers, we can be more
consistent about the z-axis and its relationship to color and lightness.
2023-06-26 14:12:33 +00:00
|
|
|
borderBottomRadius: 'base',
|
2023-08-23 12:48:51 +00:00
|
|
|
bg: 'base.150',
|
2023-07-21 10:02:54 +00:00
|
|
|
_dark: {
|
|
|
|
bg: 'base.800',
|
|
|
|
},
|
feat(ui): remove themes, add hand-crafted dark and light modes
Themes are very fun but due to the differences in perceived saturation and lightness across the
the color spectrum, it's impossible to have have multiple themes that look great without hand-
crafting *every* shade for *every* theme. We've ended up with 4 OK themes (well, 3, because the
light theme was pretty bad).
I've removed the themes and added color mode support. There is now a single dark and light mode,
each with their own color palette and the classic grey / purple / yellow invoke colors that
@blessedcoolant first designed.
I've re-styled almost everything except the model manager and lightbox, which I keep forgetting
to work on.
One new concept is the Chakra `layerStyle`. This lets us define "layers" - think body, first layer,
second layer, etc - that can be applied on various components. By defining layers, we can be more
consistent about the z-axis and its relationship to color and lightness.
2023-06-26 14:12:33 +00:00
|
|
|
}}
|
|
|
|
>
|
2023-05-08 09:05:43 +00:00
|
|
|
{children}
|
|
|
|
</Box>
|
|
|
|
</Collapse>
|
|
|
|
</Box>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
export default memo(IAICollapse);
|