@lets-events/react 11.5.3 → 11.6.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (74) hide show
  1. package/.eslintrc.json +2 -2
  2. package/.turbo/turbo-build.log +20 -18
  3. package/CHANGELOG.md +12 -0
  4. package/dist/index.d.mts +105 -14
  5. package/dist/index.d.ts +105 -14
  6. package/dist/index.js +1005 -143
  7. package/dist/index.mjs +966 -112
  8. package/package.json +2 -1
  9. package/src/components/Alert.tsx +303 -303
  10. package/src/components/Avatar.tsx +55 -55
  11. package/src/components/Badge.tsx +125 -125
  12. package/src/components/Box.tsx +3 -3
  13. package/src/components/Button/index.tsx +16 -16
  14. package/src/components/Button/styledComponents.ts +287 -287
  15. package/src/components/ButtonGroup.tsx +484 -484
  16. package/src/components/Calendar/index.tsx +136 -136
  17. package/src/components/Calendar/styledComponents.ts +209 -209
  18. package/src/components/Card.tsx +48 -48
  19. package/src/components/CheckboxGroup.tsx +176 -196
  20. package/src/components/Container.tsx +39 -39
  21. package/src/components/Drawer/index.tsx +48 -48
  22. package/src/components/Drawer/styledComponents.ts +46 -46
  23. package/src/components/Dropdown.tsx +192 -167
  24. package/src/components/Filter.tsx +164 -164
  25. package/src/components/Flex.tsx +118 -118
  26. package/src/components/FormFields/AddressFormFields/CityFormField.tsx +111 -0
  27. package/src/components/FormFields/AddressFormFields/CountryFormField.tsx +33 -0
  28. package/src/components/FormFields/AddressFormFields/PostalCodeFormField.tsx +45 -0
  29. package/src/components/FormFields/AddressFormFields/StateFormField.tsx +32 -0
  30. package/src/components/FormFields/AddressFormFields/index.tsx +139 -0
  31. package/src/components/FormFields/BirthDateFormField.tsx +87 -0
  32. package/src/components/FormFields/CNPJFormField.tsx +89 -0
  33. package/src/components/FormFields/CPFFormField.tsx +79 -0
  34. package/src/components/FormFields/CheckboxGroupFormField.tsx +90 -0
  35. package/src/components/FormFields/ErrorFormMessage.tsx +36 -36
  36. package/src/components/FormFields/Form.tsx +29 -25
  37. package/src/components/FormFields/FormLabel.tsx +29 -29
  38. package/src/components/FormFields/IdentityDocumentNumberFormField.tsx +42 -0
  39. package/src/components/FormFields/MultiSelectFormField.tsx +59 -59
  40. package/src/components/FormFields/PhoneFormField.tsx +130 -130
  41. package/src/components/FormFields/RadioGroupFormField.tsx +84 -0
  42. package/src/components/FormFields/SelectFormField.tsx +93 -0
  43. package/src/components/FormFields/TextAreaFormField.tsx +48 -49
  44. package/src/components/FormFields/TextFormField.tsx +76 -46
  45. package/src/components/Grid.tsx +137 -137
  46. package/src/components/Icon.tsx +47 -47
  47. package/src/components/MenuDropdown/index.tsx +30 -30
  48. package/src/components/MenuDropdown/styledComponents.ts +31 -31
  49. package/src/components/Modal.tsx +90 -90
  50. package/src/components/MultiSelect.tsx +218 -218
  51. package/src/components/RadioGroup.tsx +210 -210
  52. package/src/components/Section.tsx +33 -33
  53. package/src/components/Step.tsx +164 -164
  54. package/src/components/Switch.tsx +108 -108
  55. package/src/components/Text.tsx +38 -38
  56. package/src/components/TextField.tsx +312 -315
  57. package/src/components/TextareaField.tsx +128 -128
  58. package/src/components/TimePicker.tsx +298 -298
  59. package/src/components/Toast/components/ToastItem.tsx +41 -41
  60. package/src/components/Toast/components/ToastProvider.tsx +63 -63
  61. package/src/components/Toast/hooks/useToast.ts +12 -12
  62. package/src/components/Toast/index.tsx +5 -5
  63. package/src/components/Toast/styles/index.ts +135 -135
  64. package/src/components/Toast/types/index.ts +46 -46
  65. package/src/components/Tooltip/index.tsx +66 -66
  66. package/src/components/Tooltip/styles.ts +77 -77
  67. package/src/hooks/useCountries.ts +41 -0
  68. package/src/hooks/useOnClickOutside.tsx +20 -20
  69. package/src/index.tsx +52 -45
  70. package/src/styles/index.ts +38 -38
  71. package/src/types/typographyValues.ts +178 -178
  72. package/src/utils/getNestedValue.ts +3 -0
  73. package/src/utils/states.ts +29 -0
  74. package/tsconfig.json +3 -3
@@ -0,0 +1,93 @@
1
+ import { useFormContext, Controller } from "react-hook-form";
2
+ import { DropdownMenu, DropdownMenuItem } from "../Dropdown";
3
+ import { Flex } from "../Flex";
4
+ import { FormLabel } from "./FormLabel";
5
+ import { ErrorFormMessage } from "./ErrorFormMessage";
6
+ import { getNestedValue } from "../../utils/getNestedValue";
7
+
8
+ type Option = {
9
+ label: string;
10
+ value: string;
11
+ };
12
+
13
+ export type SelectFormFieldProps = {
14
+ name: string;
15
+ label: string;
16
+ required?: boolean;
17
+ placeholder?: string;
18
+ options: Option[];
19
+ validation?: {
20
+ validate?: (value: string) => boolean | string;
21
+ };
22
+ validationErrorMessage?: string;
23
+ defaultValue?: string;
24
+ };
25
+
26
+ export const SelectFormField = ({
27
+ name,
28
+ label,
29
+ required,
30
+ placeholder = "Selecione",
31
+ options,
32
+ validation,
33
+ validationErrorMessage = "Este campo é obrigatório.",
34
+ defaultValue,
35
+ }: SelectFormFieldProps) => {
36
+ const {
37
+ control,
38
+ formState: { errors },
39
+ } = useFormContext();
40
+
41
+ const fieldError = getNestedValue(errors, name);
42
+ const haveError = !!fieldError;
43
+ const errorMsg = fieldError?.message;
44
+
45
+ const validationRules = {
46
+ required: required ? validationErrorMessage : false,
47
+ ...validation,
48
+ };
49
+
50
+ return (
51
+ <Flex direction="column">
52
+ <FormLabel
53
+ name={name}
54
+ label={label}
55
+ required={required}
56
+ haveError={haveError}
57
+ />
58
+
59
+ <Controller
60
+ control={control}
61
+ name={name}
62
+ rules={validationRules}
63
+ defaultValue={defaultValue || ""}
64
+ render={({ field: { value, onChange } }) => {
65
+ const selectedOption = options.find((opt) => opt.value === value);
66
+
67
+ return (
68
+ <DropdownMenu
69
+ placeholder={selectedOption?.label || placeholder}
70
+ fontWeight="regular"
71
+ typography="labelLarge"
72
+ color={haveError ? "error" : "default"}
73
+ >
74
+ {options.map((option, index) => (
75
+ <DropdownMenuItem
76
+ key={`${option.value}${index}`}
77
+ value={option.value}
78
+ onSelect={() => onChange(option.value)}
79
+ fontWeight="regular"
80
+ typography="labelLarge"
81
+ >
82
+ {option.label}
83
+ </DropdownMenuItem>
84
+ ))}
85
+ </DropdownMenu>
86
+ );
87
+ }}
88
+ />
89
+
90
+ <ErrorFormMessage message={errorMsg} />
91
+ </Flex>
92
+ );
93
+ };
@@ -1,49 +1,48 @@
1
- import { useFormContext } from "react-hook-form";
2
- import { Flex } from "../Flex";
3
- import { FormLabel } from "./FormLabel";
4
- import { ErrorFormMessage } from "./ErrorFormMessage";
5
- import { TextareaField, TextareaFieldProps } from "../TextareaField";
6
-
7
- export type TextAreaFormFieldProps = {
8
- name: string;
9
- label?: string;
10
- required?: boolean;
11
- placeholder?: string;
12
- fieldProps?: TextareaFieldProps;
13
- };
14
-
15
- export const TextAreaFormField = ({
16
- name,
17
- label,
18
- required,
19
- placeholder,
20
- fieldProps,
21
- }: TextAreaFormFieldProps) => {
22
- const {
23
- register,
24
- formState: { errors },
25
- } = useFormContext();
26
-
27
- const haveError = !!errors[name];
28
-
29
- const errorMsg = errors[name]?.message;
30
-
31
- return (
32
- <Flex direction={"column"}>
33
- <FormLabel
34
- name={name}
35
- label={label}
36
- required={required}
37
- haveError={haveError}
38
- />
39
- <TextareaField
40
- {...fieldProps}
41
- {...register(name, { required })}
42
- placeholder={placeholder}
43
- color={haveError ? "error" : "default"}
44
- aria-labelledby={`${name}-label`}
45
- />
46
- <ErrorFormMessage message={errorMsg} />
47
- </Flex>
48
- );
49
- };
1
+ import { useFormContext } from "react-hook-form";
2
+ import { Flex } from "../Flex";
3
+ import { FormLabel } from "./FormLabel";
4
+ import { ErrorFormMessage } from "./ErrorFormMessage";
5
+ import { TextareaField, TextareaFieldProps } from "../TextareaField";
6
+
7
+ export type TextAreaFormFieldProps = TextareaFieldProps & {
8
+ name: string;
9
+ label?: string;
10
+ required?: boolean;
11
+ placeholder?: string;
12
+ };
13
+
14
+ export const TextAreaFormField = ({
15
+ name,
16
+ label,
17
+ required,
18
+ placeholder,
19
+ ...props
20
+ }: TextAreaFormFieldProps) => {
21
+ const {
22
+ register,
23
+ formState: { errors },
24
+ } = useFormContext();
25
+
26
+ const haveError = !!errors[name];
27
+
28
+ const errorMsg = errors[name]?.message;
29
+
30
+ return (
31
+ <Flex direction={"column"}>
32
+ <FormLabel
33
+ name={name}
34
+ label={label}
35
+ required={required}
36
+ haveError={haveError}
37
+ />
38
+ <TextareaField
39
+ {...props}
40
+ {...register(name, { required })}
41
+ placeholder={placeholder}
42
+ color={haveError ? "error" : "default"}
43
+ aria-labelledby={`${name}-label`}
44
+ />
45
+ <ErrorFormMessage message={errorMsg} />
46
+ </Flex>
47
+ );
48
+ };
@@ -1,46 +1,76 @@
1
- import { useFormContext } from "react-hook-form";
2
- import { Flex } from "../Flex";
3
- import { FormLabel } from "./FormLabel";
4
- import { TextField } from "../TextField";
5
- import { ErrorFormMessage } from "./ErrorFormMessage";
6
-
7
- export type TextFormFieldProps = {
8
- name: string;
9
- label?: string;
10
- required?: boolean;
11
- placeholder?: string;
12
- };
13
-
14
- export const TextFormField = ({
15
- name,
16
- label,
17
- required,
18
- placeholder,
19
- }: TextFormFieldProps) => {
20
- const {
21
- register,
22
- formState: { errors },
23
- } = useFormContext();
24
-
25
- const haveError = !!errors[name];
26
-
27
- const errorMsg = errors[name]?.message;
28
-
29
- return (
30
- <Flex direction={"column"}>
31
- <FormLabel
32
- name={name}
33
- label={label}
34
- required={required}
35
- haveError={haveError}
36
- />
37
- <TextField
38
- {...register(name, { required })}
39
- placeholder={placeholder}
40
- color={haveError ? "error" : "default"}
41
- aria-labelledby={`${name}-label`}
42
- />
43
- <ErrorFormMessage message={errorMsg} />
44
- </Flex>
45
- );
46
- };
1
+ import { useFormContext } from "react-hook-form";
2
+ import { Flex } from "../Flex";
3
+ import { FormLabel } from "./FormLabel";
4
+ import { TextField } from "../TextField";
5
+ import { ErrorFormMessage } from "./ErrorFormMessage";
6
+ import { MaskOptions } from "@react-input/mask";
7
+ import { getNestedValue } from "../../utils/getNestedValue";
8
+
9
+ export type TextFormFieldProps = {
10
+ name: string;
11
+ label?: string;
12
+ required?: boolean;
13
+ placeholder?: string;
14
+ mask?: MaskOptions;
15
+ validation?: {
16
+ validate?: (value: string) => boolean | string;
17
+ };
18
+ validationErrorMessage?: string;
19
+ disabled?: boolean;
20
+ onChange?: (e: React.ChangeEvent<HTMLInputElement>) => void;
21
+ value?: string;
22
+ };
23
+
24
+ export const TextFormField = ({
25
+ name,
26
+ label,
27
+ required,
28
+ placeholder,
29
+ mask,
30
+ validation,
31
+ validationErrorMessage = "Este campo é obrigatório.",
32
+ disabled = false,
33
+ value,
34
+ onChange,
35
+ }: TextFormFieldProps) => {
36
+ const {
37
+ register,
38
+ formState: { errors },
39
+ } = useFormContext();
40
+
41
+ const validationRules = {
42
+ required: required ? validationErrorMessage : false,
43
+ ...validation,
44
+ };
45
+
46
+ const { ref, ...restFieldProps } = register(name, validationRules);
47
+ const fieldError = getNestedValue(errors, name);
48
+ const haveError = !!fieldError;
49
+ const errorMsg = fieldError?.message;
50
+ return (
51
+ <Flex direction="column">
52
+ {label && (
53
+ <FormLabel
54
+ name={name}
55
+ label={label}
56
+ required={required}
57
+ haveError={haveError}
58
+ />
59
+ )}
60
+
61
+ <TextField
62
+ mask={mask}
63
+ placeholder={placeholder}
64
+ disabled={disabled}
65
+ color={haveError ? "error" : "default"}
66
+ aria-labelledby={`${name}-label`}
67
+ {...restFieldProps}
68
+ ref={ref}
69
+ onChange={onChange}
70
+ value={value}
71
+ />
72
+
73
+ <ErrorFormMessage message={errorMsg} />
74
+ </Flex>
75
+ );
76
+ };
@@ -1,138 +1,138 @@
1
- import { ComponentProps, ElementType } from 'react';
2
- import { styled } from '../styles'
3
- import { Grid as GridRadix } from "@radix-ui/themes";
4
- export const GridStyled = styled(GridRadix, {
5
- display: 'grid',
6
- variants: {
7
- display: {
8
- 'grid': { display: 'grid' },
9
- 'inline-grid': { display: 'inline-grid' },
10
- },
11
- align: {
12
- start: { alignItems: 'start' },
13
- center: { alignItems: 'center' },
14
- end: { alignItems: 'end' },
15
- stretch: { alignItems: 'stretch' },
16
- },
17
- justify: {
18
- start: { justifyContent: 'start' },
19
- center: { justifyContent: 'center' },
20
- end: { justifyContent: 'end' },
21
- between: { justifyContent: 'space-between' },
22
- },
23
- flow: {
24
- row: { gridAutoFlow: 'row' },
25
- column: { gridAutoFlow: 'column' },
26
- 'row-dense': { gridAutoFlow: 'row dense' },
27
- 'column-dense': { gridAutoFlow: 'column dense' },
28
- },
29
- columns: {
30
- 1: { gridTemplateColumns: 'repeat(1, 1fr)' },
31
- 2: { gridTemplateColumns: 'repeat(2, 1fr)' },
32
- 3: { gridTemplateColumns: 'repeat(3, 1fr)' },
33
- 4: { gridTemplateColumns: 'repeat(4, 1fr)' },
34
- 6: { gridTemplateColumns: 'repeat(6, 1fr)' },
35
- 12: { gridTemplateColumns: 'repeat(12, 1fr)' },
36
- },
37
- rows: {
38
- 1: { gridTemplateRows: 'repeat(1, 1fr)' },
39
- 2: { gridTemplateRows: 'repeat(2, 1fr)' },
40
- 3: { gridTemplateRows: 'repeat(3, 1fr)' },
41
- 4: { gridTemplateRows: 'repeat(4, 1fr)' },
42
- 5: { gridTemplateRows: 'repeat(5, 1fr)' },
43
- 6: { gridTemplateRows: 'repeat(6, 1fr)' },
44
- 7: { gridTemplateRows: 'repeat(7, 1fr)' },
45
- 8: { gridTemplateRows: 'repeat(8, 1fr)' },
46
- 9: { gridTemplateRows: 'repeat(9, 1fr)' },
47
- 10: { gridTemplateRows: 'repeat(10, 1fr)' },
48
- 11: { gridTemplateRows: 'repeat(11, 1fr)' },
49
- 12: { gridTemplateRows: 'repeat(12, 1fr)' },
50
- auto: { gridTemplateRows: 'auto' },
51
- },
52
- gap: {
53
- 2: { gap: '$2' },
54
- 4: { gap: '$4' },
55
- 6: { gap: '$6' },
56
- 8: { gap: '$8' },
57
- 10: { gap: '$10' },
58
- 12: { gap: '$12' },
59
- 14: { gap: '$14' },
60
- 16: { gap: '$16' },
61
- 20: { gap: '$20' },
62
- 22: { gap: '$22' },
63
- 24: { gap: '$24' },
64
- 32: { gap: '$32' },
65
- 36: { gap: '$36' },
66
- 40: { gap: '$40' },
67
- 48: { gap: '$48' },
68
- 56: { gap: '$56' },
69
- 64: { gap: '$64' },
70
- 72: { gap: '$72' },
71
- 80: { gap: '$80' },
72
- full: { gap: '$full' },
73
- },
74
- gapX: {
75
- 2: { gap: '$2' },
76
- 4: { gap: '$4' },
77
- 6: { gap: '$6' },
78
- 8: { gap: '$8' },
79
- 10: { gap: '$10' },
80
- 12: { gap: '$12' },
81
- 14: { gap: '$14' },
82
- 16: { gap: '$16' },
83
- 20: { gap: '$20' },
84
- 22: { gap: '$22' },
85
- 24: { gap: '$24' },
86
- 32: { gap: '$32' },
87
- 36: { gap: '$36' },
88
- 40: { gap: '$40' },
89
- 48: { gap: '$48' },
90
- 56: { gap: '$56' },
91
- 64: { gap: '$64' },
92
- 72: { gap: '$72' },
93
- 80: { gap: '$80' },
94
- full: { gap: '$full' },
95
- },
96
- gapY: {
97
- 2: { gap: '$2' },
98
- 4: { gap: '$4' },
99
- 6: { gap: '$6' },
100
- 8: { gap: '$8' },
101
- 10: { gap: '$10' },
102
- 12: { gap: '$12' },
103
- 14: { gap: '$14' },
104
- 16: { gap: '$16' },
105
- 20: { gap: '$20' },
106
- 22: { gap: '$22' },
107
- 24: { gap: '$24' },
108
- 32: { gap: '$32' },
109
- 36: { gap: '$36' },
110
- 40: { gap: '$40' },
111
- 48: { gap: '$48' },
112
- 56: { gap: '$56' },
113
- 64: { gap: '$64' },
114
- 72: { gap: '$72' },
115
- 80: { gap: '$80' },
116
- full: { gap: '$full' },
117
- },
118
- },
119
- defaultVariants: {
120
- gap: 10,
121
- }
122
-
123
- })
124
-
125
- export type GridProps = ComponentProps<typeof GridStyled> & {
126
- as?: ElementType
127
- children: React.ReactNode,
128
- areas?: string
129
- }
130
-
131
-
132
- export function Grid({ children, ...props }: GridProps) {
133
- return (
134
- <GridStyled {...props}>
135
- {children}
136
- </GridStyled>
137
- )
1
+ import { ComponentProps, ElementType } from 'react';
2
+ import { styled } from '../styles'
3
+ import { Grid as GridRadix } from "@radix-ui/themes";
4
+ export const GridStyled = styled(GridRadix, {
5
+ display: 'grid',
6
+ variants: {
7
+ display: {
8
+ 'grid': { display: 'grid' },
9
+ 'inline-grid': { display: 'inline-grid' },
10
+ },
11
+ align: {
12
+ start: { alignItems: 'start' },
13
+ center: { alignItems: 'center' },
14
+ end: { alignItems: 'end' },
15
+ stretch: { alignItems: 'stretch' },
16
+ },
17
+ justify: {
18
+ start: { justifyContent: 'start' },
19
+ center: { justifyContent: 'center' },
20
+ end: { justifyContent: 'end' },
21
+ between: { justifyContent: 'space-between' },
22
+ },
23
+ flow: {
24
+ row: { gridAutoFlow: 'row' },
25
+ column: { gridAutoFlow: 'column' },
26
+ 'row-dense': { gridAutoFlow: 'row dense' },
27
+ 'column-dense': { gridAutoFlow: 'column dense' },
28
+ },
29
+ columns: {
30
+ 1: { gridTemplateColumns: 'repeat(1, 1fr)' },
31
+ 2: { gridTemplateColumns: 'repeat(2, 1fr)' },
32
+ 3: { gridTemplateColumns: 'repeat(3, 1fr)' },
33
+ 4: { gridTemplateColumns: 'repeat(4, 1fr)' },
34
+ 6: { gridTemplateColumns: 'repeat(6, 1fr)' },
35
+ 12: { gridTemplateColumns: 'repeat(12, 1fr)' },
36
+ },
37
+ rows: {
38
+ 1: { gridTemplateRows: 'repeat(1, 1fr)' },
39
+ 2: { gridTemplateRows: 'repeat(2, 1fr)' },
40
+ 3: { gridTemplateRows: 'repeat(3, 1fr)' },
41
+ 4: { gridTemplateRows: 'repeat(4, 1fr)' },
42
+ 5: { gridTemplateRows: 'repeat(5, 1fr)' },
43
+ 6: { gridTemplateRows: 'repeat(6, 1fr)' },
44
+ 7: { gridTemplateRows: 'repeat(7, 1fr)' },
45
+ 8: { gridTemplateRows: 'repeat(8, 1fr)' },
46
+ 9: { gridTemplateRows: 'repeat(9, 1fr)' },
47
+ 10: { gridTemplateRows: 'repeat(10, 1fr)' },
48
+ 11: { gridTemplateRows: 'repeat(11, 1fr)' },
49
+ 12: { gridTemplateRows: 'repeat(12, 1fr)' },
50
+ auto: { gridTemplateRows: 'auto' },
51
+ },
52
+ gap: {
53
+ 2: { gap: '$2' },
54
+ 4: { gap: '$4' },
55
+ 6: { gap: '$6' },
56
+ 8: { gap: '$8' },
57
+ 10: { gap: '$10' },
58
+ 12: { gap: '$12' },
59
+ 14: { gap: '$14' },
60
+ 16: { gap: '$16' },
61
+ 20: { gap: '$20' },
62
+ 22: { gap: '$22' },
63
+ 24: { gap: '$24' },
64
+ 32: { gap: '$32' },
65
+ 36: { gap: '$36' },
66
+ 40: { gap: '$40' },
67
+ 48: { gap: '$48' },
68
+ 56: { gap: '$56' },
69
+ 64: { gap: '$64' },
70
+ 72: { gap: '$72' },
71
+ 80: { gap: '$80' },
72
+ full: { gap: '$full' },
73
+ },
74
+ gapX: {
75
+ 2: { gap: '$2' },
76
+ 4: { gap: '$4' },
77
+ 6: { gap: '$6' },
78
+ 8: { gap: '$8' },
79
+ 10: { gap: '$10' },
80
+ 12: { gap: '$12' },
81
+ 14: { gap: '$14' },
82
+ 16: { gap: '$16' },
83
+ 20: { gap: '$20' },
84
+ 22: { gap: '$22' },
85
+ 24: { gap: '$24' },
86
+ 32: { gap: '$32' },
87
+ 36: { gap: '$36' },
88
+ 40: { gap: '$40' },
89
+ 48: { gap: '$48' },
90
+ 56: { gap: '$56' },
91
+ 64: { gap: '$64' },
92
+ 72: { gap: '$72' },
93
+ 80: { gap: '$80' },
94
+ full: { gap: '$full' },
95
+ },
96
+ gapY: {
97
+ 2: { gap: '$2' },
98
+ 4: { gap: '$4' },
99
+ 6: { gap: '$6' },
100
+ 8: { gap: '$8' },
101
+ 10: { gap: '$10' },
102
+ 12: { gap: '$12' },
103
+ 14: { gap: '$14' },
104
+ 16: { gap: '$16' },
105
+ 20: { gap: '$20' },
106
+ 22: { gap: '$22' },
107
+ 24: { gap: '$24' },
108
+ 32: { gap: '$32' },
109
+ 36: { gap: '$36' },
110
+ 40: { gap: '$40' },
111
+ 48: { gap: '$48' },
112
+ 56: { gap: '$56' },
113
+ 64: { gap: '$64' },
114
+ 72: { gap: '$72' },
115
+ 80: { gap: '$80' },
116
+ full: { gap: '$full' },
117
+ },
118
+ },
119
+ defaultVariants: {
120
+ gap: 10,
121
+ }
122
+
123
+ })
124
+
125
+ export type GridProps = ComponentProps<typeof GridStyled> & {
126
+ as?: ElementType
127
+ children: React.ReactNode,
128
+ areas?: string
129
+ }
130
+
131
+
132
+ export function Grid({ children, ...props }: GridProps) {
133
+ return (
134
+ <GridStyled {...props}>
135
+ {children}
136
+ </GridStyled>
137
+ )
138
138
  }