This is a react base component which will reduce considerably necessity to write css code.
- Installation
npm install @cronocode/react-box
- Use component
Sizes is equal to 1/4rem
padding={3}
means 1/4 * 3 => 0.75rem
In the example below is creating a box with maring: 0.5rem
and padding: 1.75rem
import Box from "@cronocode/react-box";
export default function Component(props: Props) {
return (
<Box className="custom-class" m={2} p={7}>
basic example
</Box>
);
}
NOTE: Root font-size
is set to 16px
- Box - base component with a tons of props
import Box from "@cronocode/react-box";
- Flex - this is a
Box
component withdisplay: flex
style
import Flex from "@cronocode/react-box/components/flex";
- Button - this is a
Box
component with html tagbutton
andonClick
prop
import Button from "@cronocode/react-box/components/button";
- Textbox - this is a
Box
component with html taginput
import Textbox from "@cronocode/react-box/components/textbox";
- Tooltip - this is useful when you need a position absolute and the parent has overflow hidden.
import Tooltip from "@cronocode/react-box/components/tooltip";
It is possible to add your own props to define your custom styles. You need to do a few steps.
- In a project root file you need to define your extends
import Box from "@cronocode/react-box";
export const { extendedProps, extendedPropTypes } = Box.extend(
// css variables
{
dark: '#123123',
light: '#ededed',
cssVarName: 'cssVarValue',
myShadow: '10px 5px 5px red',
myGradient1: 'linear-gradient(#e66465, #9198e5)',
myGradient2: 'linear-gradient(black, white)',
},
// new custom props
{
background: [
{
values: ['myGradient1', 'myGradient2'] as const,
valueFormat: (value: string) => `var(--background${value})`,
},
],
},
// extend values for existing props
{
color: [
{
values: ['dark', 'light'],
valueFormat: (value, getVariableValue) => getVariableValue(value),
},
],
}
);
- Now you have to add typings to the Box in order to have intellisense for you new props and value.
You need to create a
box.d.ts
import '@cronocode/react-box';
import { ExtractBoxStyles } from '@cronocode/react-box/types';
import { extendedProps, extendedPropTypes } from './path-to-your-b0x-extends-declaration';
declare module '@cronocode/react-box/types' {
namespace Augmented {
interface BoxProps extends ExtractBoxStyles<typeof extendedProps> {}
interface BoxPropTypes extends ExtractBoxStyles<typeof extendedPropTypes> {}
}
}
In the project root file (main.tsx) use Theme.setup
import Theme from '@cronocode/react-box/theme';
Theme.setup({
button: {
styles: {
px: 4
},
themes: {
mytheme: {
px: 8
}
}
},
...
})
All styles will be applied to Button component
import Button from '@cronocode/react-box/components/button';
function MyComponent() {
return <Button>Click me</Button>
}
or is possible to use Button with specific theme
import Button from '@cronocode/react-box/components/button';
function MyComponent() {
return <Button theme="mytheme">Click me</Button>
}
In CSS file is possible to override default values for:
--borderColor: black;
--outlineColor: black;
--lineHeight: 1.2;
--fontSize: 14px;
--transitionTime: 0.25s;