@lets-events/react 12.2.9 → 12.2.11

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 (90) hide show
  1. package/.eslintrc.json +2 -2
  2. package/.turbo/turbo-build.log +19 -21
  3. package/CHANGELOG.md +12 -0
  4. package/dist/index.css +171 -0
  5. package/dist/index.d.mts +375 -3
  6. package/dist/index.d.ts +375 -3
  7. package/dist/index.js +43 -22
  8. package/dist/index.mjs +42 -22
  9. package/package.json +1 -1
  10. package/src/components/Alert.tsx +303 -303
  11. package/src/components/Avatar.tsx +55 -55
  12. package/src/components/Badge.tsx +125 -125
  13. package/src/components/Box.tsx +3 -3
  14. package/src/components/Button/index.tsx +16 -16
  15. package/src/components/Button/styledComponents.ts +300 -300
  16. package/src/components/ButtonGroup.tsx +484 -484
  17. package/src/components/Calendar/index.tsx +148 -148
  18. package/src/components/Calendar/styledComponents.ts +250 -250
  19. package/src/components/Card.tsx +48 -48
  20. package/src/components/CheckboxGroup.tsx +176 -176
  21. package/src/components/Container.tsx +39 -39
  22. package/src/components/Divider.tsx +7 -0
  23. package/src/components/Drawer/index.tsx +148 -138
  24. package/src/components/Drawer/styledComponents.ts +52 -52
  25. package/src/components/Dropdown.tsx +302 -302
  26. package/src/components/Filter.tsx +164 -164
  27. package/src/components/Flex.tsx +118 -118
  28. package/src/components/FormFields/AddressFormFields/CityFormField.tsx +111 -111
  29. package/src/components/FormFields/AddressFormFields/CountryFormField.tsx +33 -33
  30. package/src/components/FormFields/AddressFormFields/PostalCodeFormField.tsx +39 -39
  31. package/src/components/FormFields/AddressFormFields/StateFormField.tsx +32 -32
  32. package/src/components/FormFields/AddressFormFields/index.tsx +141 -141
  33. package/src/components/FormFields/BirthDateFormField.tsx +84 -84
  34. package/src/components/FormFields/CNPJFormField.tsx +87 -87
  35. package/src/components/FormFields/CPFFormField.tsx +78 -78
  36. package/src/components/FormFields/CalendarFormField.tsx +95 -95
  37. package/src/components/FormFields/CheckboxGroupFormField.tsx +91 -91
  38. package/src/components/FormFields/EmailFormField.tsx +27 -27
  39. package/src/components/FormFields/Form.tsx +39 -39
  40. package/src/components/FormFields/IdentityDocumentNumberFormField.tsx +32 -32
  41. package/src/components/FormFields/MultiSelectFormField.tsx +64 -64
  42. package/src/components/FormFields/PhoneFormField.tsx +40 -40
  43. package/src/components/FormFields/RadioGroupFormField.tsx +84 -84
  44. package/src/components/FormFields/RichEditorFormField.tsx +103 -102
  45. package/src/components/FormFields/SelectFormField.tsx +93 -93
  46. package/src/components/FormFields/SwitchFormField.tsx +46 -46
  47. package/src/components/FormFields/TextAreaFormField.tsx +57 -57
  48. package/src/components/FormFields/TextFormField.tsx +112 -112
  49. package/src/components/FormFields/TimePickerFormField.tsx +88 -88
  50. package/src/components/FormFields/subComponents/ErrorFormMessage.tsx +36 -36
  51. package/src/components/FormFields/subComponents/FormLabel.tsx +29 -29
  52. package/src/components/FormFields/utils/validation.ts +23 -23
  53. package/src/components/Grid.tsx +137 -137
  54. package/src/components/Icon.tsx +47 -47
  55. package/src/components/MenuDropdown/index.tsx +38 -38
  56. package/src/components/MenuDropdown/styledComponents.ts +31 -31
  57. package/src/components/Modal.tsx +90 -90
  58. package/src/components/MultiSelect/index.tsx +243 -243
  59. package/src/components/MultiSelect/styledComponents.ts +160 -160
  60. package/src/components/RadioGroup.tsx +210 -210
  61. package/src/components/RichEditor/QuillComponent.tsx +457 -455
  62. package/src/components/RichEditor/RichEditor.tsx +49 -49
  63. package/src/components/RichEditor/index.ts +2 -2
  64. package/src/components/RichEditor/styledComponents.ts +1151 -1151
  65. package/src/components/Section.tsx +33 -33
  66. package/src/components/Step.tsx +164 -164
  67. package/src/components/Switch.tsx +108 -108
  68. package/src/components/Text.tsx +38 -38
  69. package/src/components/TextField.tsx +372 -372
  70. package/src/components/TextareaField.tsx +127 -127
  71. package/src/components/TimePicker.tsx +328 -328
  72. package/src/components/Toast/components/ToastItem.tsx +41 -41
  73. package/src/components/Toast/components/ToastProvider.tsx +63 -63
  74. package/src/components/Toast/hooks/useToast.ts +12 -12
  75. package/src/components/Toast/index.tsx +5 -5
  76. package/src/components/Toast/styles/index.ts +135 -135
  77. package/src/components/Toast/types/index.ts +46 -46
  78. package/src/components/Tooltip/index.tsx +66 -66
  79. package/src/components/Tooltip/styles.ts +77 -77
  80. package/src/hooks/useCountries.ts +41 -41
  81. package/src/hooks/useImageUpload.ts +139 -139
  82. package/src/hooks/useOnClickOutside.tsx +42 -42
  83. package/src/index.tsx +69 -68
  84. package/src/styles/index.ts +38 -38
  85. package/src/types/typographyValues.ts +178 -178
  86. package/src/utils/getNestedValue.ts +3 -3
  87. package/src/utils/states.ts +29 -29
  88. package/src/utils/uploadService.ts +180 -180
  89. package/tsconfig.json +3 -3
  90. package/tsup.config.ts +38 -38
@@ -1,93 +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 "./subComponents/FormLabel";
5
- import { ErrorFormMessage } from "./subComponents/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
+ import { useFormContext, Controller } from "react-hook-form";
2
+ import { DropdownMenu, DropdownMenuItem } from "../Dropdown";
3
+ import { Flex } from "../Flex";
4
+ import { FormLabel } from "./subComponents/FormLabel";
5
+ import { ErrorFormMessage } from "./subComponents/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,46 +1,46 @@
1
- import { useFormContext, Controller } from "react-hook-form";
2
- import { Flex } from "../Flex";
3
- import { Switch } from "../Switch";
4
- import { Text } from "../Text";
5
-
6
-
7
- export type SwitchFormFieldProps = {
8
- name: string;
9
- label: string;
10
- defaultValue?: boolean;
11
- watch?: boolean;
12
- };
13
-
14
- export const SwitchFormField = ({
15
- name,
16
- label,
17
- defaultValue = false,
18
- watch = false,
19
- }: SwitchFormFieldProps) => {
20
- const {
21
- control,
22
- watch: watchForm,
23
- } = useFormContext();
24
-
25
- if (watch) {
26
- watchForm(name);
27
- }
28
- return (
29
- <Flex justify="between" style={{ margin: '1rem 0' }}>
30
- <Text typography="labelMedium" fontWeight="regular">
31
- {label}
32
- </Text>
33
- <Controller
34
- control={control}
35
- name={name}
36
- defaultValue={defaultValue}
37
- render={({ field }) => (
38
- <Switch
39
- checked={field.value}
40
- onCheckedChange={field.onChange}
41
- />
42
- )}
43
- />
44
- </Flex>
45
- );
46
- };
1
+ import { useFormContext, Controller } from "react-hook-form";
2
+ import { Flex } from "../Flex";
3
+ import { Switch } from "../Switch";
4
+ import { Text } from "../Text";
5
+
6
+
7
+ export type SwitchFormFieldProps = {
8
+ name: string;
9
+ label: string;
10
+ defaultValue?: boolean;
11
+ watch?: boolean;
12
+ };
13
+
14
+ export const SwitchFormField = ({
15
+ name,
16
+ label,
17
+ defaultValue = false,
18
+ watch = false,
19
+ }: SwitchFormFieldProps) => {
20
+ const {
21
+ control,
22
+ watch: watchForm,
23
+ } = useFormContext();
24
+
25
+ if (watch) {
26
+ watchForm(name);
27
+ }
28
+ return (
29
+ <Flex justify="between" style={{ margin: '1rem 0' }}>
30
+ <Text typography="labelMedium" fontWeight="regular">
31
+ {label}
32
+ </Text>
33
+ <Controller
34
+ control={control}
35
+ name={name}
36
+ defaultValue={defaultValue}
37
+ render={({ field }) => (
38
+ <Switch
39
+ checked={field.value}
40
+ onCheckedChange={field.onChange}
41
+ />
42
+ )}
43
+ />
44
+ </Flex>
45
+ );
46
+ };
@@ -1,57 +1,57 @@
1
- import { useFormContext } from "react-hook-form";
2
- import { Flex } from "../Flex";
3
- import { FormLabel } from "./subComponents/FormLabel";
4
- import { ErrorFormMessage } from "./subComponents/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
- validate?: (value: string) => boolean | string;
13
- validationErrorMessage?: string;
14
- };
15
-
16
- export const TextAreaFormField = ({
17
- name,
18
- label,
19
- required,
20
- placeholder,
21
- validate,
22
- validationErrorMessage = "Este campo é obrigatório.",
23
- ...props
24
- }: TextAreaFormFieldProps) => {
25
- const {
26
- register,
27
- formState: { errors },
28
- } = useFormContext();
29
-
30
- const haveError = !!errors[name];
31
-
32
- const errorMsg = errors[name]?.message;
33
-
34
- const validationRules = {
35
- required: required ? validationErrorMessage : false,
36
- validate: validate,
37
- };
38
-
39
- return (
40
- <Flex direction={"column"}>
41
- <FormLabel
42
- name={name}
43
- label={label}
44
- required={required}
45
- haveError={haveError}
46
- />
47
- <TextareaField
48
- {...props}
49
- {...register(name, validationRules)}
50
- placeholder={placeholder}
51
- color={haveError ? "error" : "default"}
52
- aria-labelledby={`${name}-label`}
53
- />
54
- <ErrorFormMessage message={errorMsg} />
55
- </Flex>
56
- );
57
- };
1
+ import { useFormContext } from "react-hook-form";
2
+ import { Flex } from "../Flex";
3
+ import { FormLabel } from "./subComponents/FormLabel";
4
+ import { ErrorFormMessage } from "./subComponents/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
+ validate?: (value: string) => boolean | string;
13
+ validationErrorMessage?: string;
14
+ };
15
+
16
+ export const TextAreaFormField = ({
17
+ name,
18
+ label,
19
+ required,
20
+ placeholder,
21
+ validate,
22
+ validationErrorMessage = "Este campo é obrigatório.",
23
+ ...props
24
+ }: TextAreaFormFieldProps) => {
25
+ const {
26
+ register,
27
+ formState: { errors },
28
+ } = useFormContext();
29
+
30
+ const haveError = !!errors[name];
31
+
32
+ const errorMsg = errors[name]?.message;
33
+
34
+ const validationRules = {
35
+ required: required ? validationErrorMessage : false,
36
+ validate: validate,
37
+ };
38
+
39
+ return (
40
+ <Flex direction={"column"}>
41
+ <FormLabel
42
+ name={name}
43
+ label={label}
44
+ required={required}
45
+ haveError={haveError}
46
+ />
47
+ <TextareaField
48
+ {...props}
49
+ {...register(name, validationRules)}
50
+ placeholder={placeholder}
51
+ color={haveError ? "error" : "default"}
52
+ aria-labelledby={`${name}-label`}
53
+ />
54
+ <ErrorFormMessage message={errorMsg} />
55
+ </Flex>
56
+ );
57
+ };
@@ -1,112 +1,112 @@
1
- import {
2
- FieldValues,
3
- RegisterOptions,
4
- useFormContext,
5
- Validate,
6
- useController,
7
- } from "react-hook-form";
8
- import { Flex } from "../Flex";
9
- import { FormLabel } from "./subComponents/FormLabel";
10
- import { TextField, TextFieldProps } from "../TextField";
11
- import { ErrorFormMessage } from "./subComponents/ErrorFormMessage";
12
- import { MaskOptions } from "@react-input/mask";
13
- import { getNestedValue } from "../../utils/getNestedValue";
14
- import { useCallback, useMemo } from "react";
15
- import { format, unformat } from "@react-input/mask";
16
-
17
- export type TextFormFieldProps = TextFieldProps & {
18
- name: string;
19
- label?: string;
20
- required?: boolean;
21
- mask?: MaskOptions;
22
- validate?: (value: string) => boolean | string;
23
- validationErrorMessage?: string;
24
- valueFormatter?: {
25
- format: (v: string) => string;
26
- unformat: (v: string) => string;
27
- };
28
- };
29
-
30
- export const TextFormField = ({
31
- name,
32
- label,
33
- required,
34
- mask,
35
- validate,
36
- validationErrorMessage = "Este campo é obrigatório.",
37
- onChange,
38
- valueFormatter,
39
- ...inputProps
40
- }: TextFormFieldProps) => {
41
- const handleValidate = useCallback(
42
- (value?: string) => {
43
- if (
44
- value === undefined ||
45
- value === null ||
46
- (!required && value.trim() === "")
47
- )
48
- return true;
49
- return validate?.(value) ?? true;
50
- },
51
- [validate, required]
52
- );
53
-
54
- const { field, fieldState } = useController({
55
- name,
56
- rules: {
57
- required: required ? validationErrorMessage : false,
58
- validate: handleValidate,
59
- onChange,
60
- },
61
- defaultValue: "",
62
- });
63
-
64
- const fieldError = fieldState.error;
65
- const haveError = !!fieldError;
66
- const errorMsg = fieldError?.message;
67
-
68
- const { value: formValue, onChange: formChange } = field;
69
-
70
- const formattedValue = useMemo(() => {
71
- let value = formValue;
72
-
73
- if (valueFormatter) value = valueFormatter.format(value);
74
- if (mask) value = format(value ?? "", mask as any);
75
-
76
- return value;
77
- }, [formValue, valueFormatter, mask]);
78
-
79
- const handleChange = (e: any) => {
80
- let value = e.target.value;
81
-
82
- if (mask) value = unformat(value, mask as any);
83
- if (valueFormatter) value = valueFormatter.unformat(value);
84
-
85
- formChange(value);
86
- };
87
-
88
- return (
89
- <Flex direction="column">
90
- {label && (
91
- <FormLabel
92
- name={name}
93
- label={label}
94
- required={required}
95
- haveError={haveError}
96
- />
97
- )}
98
-
99
- <TextField
100
- mask={mask}
101
- color={haveError ? "error" : "default"}
102
- aria-labelledby={`${name}-label`}
103
- {...inputProps}
104
- {...field}
105
- onChange={handleChange}
106
- value={formattedValue}
107
- />
108
-
109
- <ErrorFormMessage message={errorMsg} />
110
- </Flex>
111
- );
112
- };
1
+ import {
2
+ FieldValues,
3
+ RegisterOptions,
4
+ useFormContext,
5
+ Validate,
6
+ useController,
7
+ } from "react-hook-form";
8
+ import { Flex } from "../Flex";
9
+ import { FormLabel } from "./subComponents/FormLabel";
10
+ import { TextField, TextFieldProps } from "../TextField";
11
+ import { ErrorFormMessage } from "./subComponents/ErrorFormMessage";
12
+ import { MaskOptions } from "@react-input/mask";
13
+ import { getNestedValue } from "../../utils/getNestedValue";
14
+ import { useCallback, useMemo } from "react";
15
+ import { format, unformat } from "@react-input/mask";
16
+
17
+ export type TextFormFieldProps = TextFieldProps & {
18
+ name: string;
19
+ label?: string;
20
+ required?: boolean;
21
+ mask?: MaskOptions;
22
+ validate?: (value: string) => boolean | string;
23
+ validationErrorMessage?: string;
24
+ valueFormatter?: {
25
+ format: (v: string) => string;
26
+ unformat: (v: string) => string;
27
+ };
28
+ };
29
+
30
+ export const TextFormField = ({
31
+ name,
32
+ label,
33
+ required,
34
+ mask,
35
+ validate,
36
+ validationErrorMessage = "Este campo é obrigatório.",
37
+ onChange,
38
+ valueFormatter,
39
+ ...inputProps
40
+ }: TextFormFieldProps) => {
41
+ const handleValidate = useCallback(
42
+ (value?: string) => {
43
+ if (
44
+ value === undefined ||
45
+ value === null ||
46
+ (!required && value.trim() === "")
47
+ )
48
+ return true;
49
+ return validate?.(value) ?? true;
50
+ },
51
+ [validate, required]
52
+ );
53
+
54
+ const { field, fieldState } = useController({
55
+ name,
56
+ rules: {
57
+ required: required ? validationErrorMessage : false,
58
+ validate: handleValidate,
59
+ onChange,
60
+ },
61
+ defaultValue: "",
62
+ });
63
+
64
+ const fieldError = fieldState.error;
65
+ const haveError = !!fieldError;
66
+ const errorMsg = fieldError?.message;
67
+
68
+ const { value: formValue, onChange: formChange } = field;
69
+
70
+ const formattedValue = useMemo(() => {
71
+ let value = formValue;
72
+
73
+ if (valueFormatter) value = valueFormatter.format(value);
74
+ if (mask) value = format(value ?? "", mask as any);
75
+
76
+ return value;
77
+ }, [formValue, valueFormatter, mask]);
78
+
79
+ const handleChange = (e: any) => {
80
+ let value = e.target.value;
81
+
82
+ if (mask) value = unformat(value, mask as any);
83
+ if (valueFormatter) value = valueFormatter.unformat(value);
84
+
85
+ formChange(value);
86
+ };
87
+
88
+ return (
89
+ <Flex direction="column">
90
+ {label && (
91
+ <FormLabel
92
+ name={name}
93
+ label={label}
94
+ required={required}
95
+ haveError={haveError}
96
+ />
97
+ )}
98
+
99
+ <TextField
100
+ mask={mask}
101
+ color={haveError ? "error" : "default"}
102
+ aria-labelledby={`${name}-label`}
103
+ {...inputProps}
104
+ {...field}
105
+ onChange={handleChange}
106
+ value={formattedValue}
107
+ />
108
+
109
+ <ErrorFormMessage message={errorMsg} />
110
+ </Flex>
111
+ );
112
+ };