@lets-events/react 12.10.3 → 12.10.5

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 (96) hide show
  1. package/.eslintrc.json +2 -2
  2. package/.turbo/turbo-build.log +21 -19
  3. package/CHANGELOG.md +12 -0
  4. package/dist/index.d.mts +8 -3
  5. package/dist/index.d.ts +8 -3
  6. package/dist/index.js +187 -77
  7. package/dist/index.mjs +187 -77
  8. package/package.json +1 -1
  9. package/src/components/Alert.tsx +303 -303
  10. package/src/components/Avatar.tsx +55 -55
  11. package/src/components/Badge.tsx +123 -123
  12. package/src/components/Box.tsx +3 -3
  13. package/src/components/Button/index.tsx +74 -74
  14. package/src/components/Button/styledComponents.ts +361 -361
  15. package/src/components/ButtonGroup.tsx +484 -484
  16. package/src/components/Calendar/index.tsx +168 -168
  17. package/src/components/Calendar/styledComponents.ts +480 -480
  18. package/src/components/Card.tsx +67 -67
  19. package/src/components/CheckboxGroup.tsx +176 -176
  20. package/src/components/Container.tsx +39 -39
  21. package/src/components/Divider.tsx +7 -7
  22. package/src/components/DoubleCalendar/index.tsx +204 -182
  23. package/src/components/Drawer/index.tsx +103 -103
  24. package/src/components/Drawer/styledComponents.ts +97 -97
  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 +98 -98
  37. package/src/components/FormFields/CheckboxGroupFormField.tsx +91 -91
  38. package/src/components/FormFields/DateAndTimeFormField.tsx +217 -217
  39. package/src/components/FormFields/DoubleCalendarFormField.tsx +96 -96
  40. package/src/components/FormFields/EmailFormField.tsx +27 -27
  41. package/src/components/FormFields/Form.tsx +39 -39
  42. package/src/components/FormFields/IdentityDocumentNumberFormField.tsx +32 -32
  43. package/src/components/FormFields/MultiSelectFormField.tsx +64 -64
  44. package/src/components/FormFields/PhoneFormField.tsx +40 -40
  45. package/src/components/FormFields/RadioGroupFormField.tsx +86 -86
  46. package/src/components/FormFields/RichEditorFormField.tsx +105 -103
  47. package/src/components/FormFields/SelectFormField.tsx +113 -113
  48. package/src/components/FormFields/SwitchFormField.tsx +46 -46
  49. package/src/components/FormFields/TextAreaFormField.tsx +61 -61
  50. package/src/components/FormFields/TextFormField.tsx +112 -112
  51. package/src/components/FormFields/TimePickerFormField.tsx +88 -88
  52. package/src/components/FormFields/subComponents/ErrorFormMessage.tsx +36 -36
  53. package/src/components/FormFields/subComponents/FormLabel.tsx +36 -36
  54. package/src/components/FormFields/utils/validation.ts +23 -23
  55. package/src/components/Grid.tsx +137 -137
  56. package/src/components/Icon.tsx +47 -47
  57. package/src/components/MenuDropdown/index.tsx +38 -38
  58. package/src/components/MenuDropdown/styledComponents.ts +31 -31
  59. package/src/components/Modal.tsx +110 -110
  60. package/src/components/MultiSelect/index.tsx +305 -305
  61. package/src/components/MultiSelect/styledComponents.ts +160 -160
  62. package/src/components/RadioGroup.tsx +210 -210
  63. package/src/components/RichEditor/QuillComponent.tsx +415 -468
  64. package/src/components/RichEditor/RichEditor.tsx +53 -49
  65. package/src/components/RichEditor/RichTextPresenter.tsx +18 -18
  66. package/src/components/RichEditor/editorConfig.ts +149 -0
  67. package/src/components/RichEditor/index.ts +3 -3
  68. package/src/components/RichEditor/styledComponents.ts +1175 -1170
  69. package/src/components/RichEditor/types.ts +12 -0
  70. package/src/components/Section.tsx +33 -33
  71. package/src/components/Step.tsx +164 -164
  72. package/src/components/Switch.tsx +108 -108
  73. package/src/components/Text.tsx +38 -38
  74. package/src/components/TextField.tsx +372 -372
  75. package/src/components/TextareaField.tsx +116 -116
  76. package/src/components/TimePicker.tsx +357 -357
  77. package/src/components/Toast/components/ToastItem.tsx +41 -41
  78. package/src/components/Toast/components/ToastProvider.tsx +63 -63
  79. package/src/components/Toast/hooks/useToast.ts +12 -12
  80. package/src/components/Toast/index.tsx +5 -5
  81. package/src/components/Toast/styles/index.ts +135 -135
  82. package/src/components/Toast/types/index.ts +46 -46
  83. package/src/components/ToggleElement/index.tsx +58 -58
  84. package/src/components/Tooltip/index.tsx +73 -73
  85. package/src/components/Tooltip/styles.ts +77 -77
  86. package/src/hooks/useCountries.ts +41 -41
  87. package/src/hooks/useImageUpload.ts +139 -139
  88. package/src/hooks/useOnClickOutside.tsx +42 -42
  89. package/src/index.tsx +72 -72
  90. package/src/styles/index.ts +41 -41
  91. package/src/types/typographyValues.ts +178 -178
  92. package/src/utils/getNestedValue.ts +3 -3
  93. package/src/utils/states.ts +29 -29
  94. package/src/utils/uploadService.ts +180 -180
  95. package/tsconfig.json +3 -3
  96. package/tsup.config.ts +38 -38
@@ -1,168 +1,168 @@
1
- import React, { ComponentProps, useRef, useEffect, useState } from "react";
2
- import { useOnClickOutside } from "../../hooks/useOnClickOutside";
3
- import { DayPicker, Matcher } from "react-day-picker";
4
- import { ptBR } from "date-fns/locale";
5
- import { parse, isValid, format, addYears } from "date-fns";
6
- import { Button } from "../Button";
7
- import { Box } from "../Box";
8
- import { TextField, TextFieldSlot } from "../TextField";
9
- import Icon from "../Icon";
10
- import {
11
- CalendarContentStyled,
12
- CalendarFooterStyled,
13
- CalendarStyled,
14
- DayPickerWrapperStyled,
15
- CalendarButtonStyled,
16
- } from "./styledComponents";
17
-
18
- export type CalendarProps = ComponentProps<typeof CalendarStyled> & {
19
- calendarLayout?: "label" | "dropdown" | "dropdown-months" | "dropdown-years";
20
- selected: Date | undefined;
21
- setSelected: React.Dispatch<React.SetStateAction<Date | undefined>>;
22
- position?: "top" | "bottom" | "top-right" | "bottom-right";
23
- action?: boolean;
24
- actionText?: string;
25
- actionAlign?: "left" | "center" | "right";
26
- hasError?: boolean;
27
- expand?: boolean;
28
- allowPastDates?: boolean;
29
- maxDate?: Date;
30
- maxYearsFromNow?: number;
31
- disabled?: boolean;
32
- };
33
-
34
- function formatToDateMask(value: string): string {
35
- const numeric = value.replace(/\D/g, "").slice(0, 8);
36
- const parts = numeric.match(/^(\d{0,2})(\d{0,2})(\d{0,4})$/);
37
- if (!parts) return "";
38
- const [, day, month, year] = parts;
39
- return [day, month, year].filter(Boolean).join("/");
40
- }
41
-
42
- export function Calendar({
43
- action,
44
- actionText,
45
- actionAlign = "right",
46
- calendarLayout,
47
- selected,
48
- setSelected,
49
- position = "bottom",
50
- hasError,
51
- expand,
52
- allowPastDates = false,
53
- maxDate,
54
- maxYearsFromNow,
55
- disabled = false,
56
- ...props
57
- }: CalendarProps) {
58
- const [inputValue, setInputValue] = useState("");
59
- const [showContainer, setShowCalendar] = useState(false);
60
-
61
- const dropdownRef = useRef<HTMLDivElement>(null);
62
-
63
- useOnClickOutside(dropdownRef, () => {
64
- setShowCalendar(false);
65
- });
66
- const today = new Date();
67
- const resolvedMaxDate =
68
- maxDate ?? (typeof maxYearsFromNow === "number" ? addYears(today, maxYearsFromNow) : undefined);
69
- const disabledDays: Matcher[] = [];
70
-
71
- if (!allowPastDates) {
72
- disabledDays.push({ before: today });
73
- }
74
- if (resolvedMaxDate) {
75
- disabledDays.push({ after: resolvedMaxDate });
76
- }
77
-
78
- useEffect(() => {
79
- if (selected) {
80
- setInputValue(format(selected, "dd/MM/yyyy"));
81
- } else {
82
- setInputValue("");
83
- }
84
- }, [selected]);
85
-
86
- const handleInputChange = (e: React.ChangeEvent<HTMLInputElement>) => {
87
- const masked = formatToDateMask(e.target.value);
88
- setInputValue(masked);
89
-
90
- const parsed = parse(masked, "dd/MM/yyyy", new Date());
91
- if (isValid(parsed)) {
92
- if (!allowPastDates && parsed < today) {
93
- console.warn("Datas passadas não são permitidas:", masked);
94
- return;
95
- }
96
- if (resolvedMaxDate && parsed > resolvedMaxDate) {
97
- console.warn("Data maior que o limite máximo permitido:", masked);
98
- return;
99
- }
100
- setSelected(parsed);
101
- } else {
102
- console.warn("Data inválida inserida no input:", masked);
103
- }
104
- };
105
-
106
- return (
107
- <div>
108
- <CalendarStyled {...props} expand={expand} ref={dropdownRef}>
109
- <CalendarButtonStyled
110
- expand={expand}
111
- type="button"
112
- onClick={() => setShowCalendar((prev) => !prev)}
113
- >
114
- <TextField
115
- placeholder="00/00/0000"
116
- type="text"
117
- value={inputValue}
118
- onChange={handleInputChange}
119
- inputMode="numeric"
120
- textAlign={"right"}
121
- color={hasError ? "error" : "default"}
122
- disabled={disabled}
123
- >
124
- <TextFieldSlot>
125
- <Icon name="calendar" size={"xl"} color="#4C4F54" />
126
- </TextFieldSlot>
127
- </TextField>
128
- </CalendarButtonStyled>
129
- {showContainer && (
130
- <CalendarContentStyled position={position}>
131
- <Box>
132
- <DayPickerWrapperStyled>
133
- <DayPicker
134
- mode="single"
135
- captionLayout={calendarLayout}
136
- selected={selected}
137
- onSelect={setSelected}
138
- required
139
- locale={ptBR}
140
- disabled={disabledDays.length > 0 ? disabledDays : undefined}
141
- startMonth={allowPastDates ? undefined : today}
142
- endMonth={resolvedMaxDate}
143
- />
144
- </DayPickerWrapperStyled>
145
- </Box>
146
-
147
- {action && (
148
- <CalendarFooterStyled actionAlign={actionAlign}>
149
- <Button
150
- variant="text"
151
- color="brand"
152
- type="button"
153
- onClick={() => {
154
- setShowCalendar(false);
155
- }}
156
- size={"medium"}
157
- fontWeight="medium"
158
- >
159
- {actionText ?? "Aplicar"}
160
- </Button>
161
- </CalendarFooterStyled>
162
- )}
163
- </CalendarContentStyled>
164
- )}
165
- </CalendarStyled>
166
- </div>
167
- );
168
- }
1
+ import React, { ComponentProps, useRef, useEffect, useState } from "react";
2
+ import { useOnClickOutside } from "../../hooks/useOnClickOutside";
3
+ import { DayPicker, Matcher } from "react-day-picker";
4
+ import { ptBR } from "date-fns/locale";
5
+ import { parse, isValid, format, addYears } from "date-fns";
6
+ import { Button } from "../Button";
7
+ import { Box } from "../Box";
8
+ import { TextField, TextFieldSlot } from "../TextField";
9
+ import Icon from "../Icon";
10
+ import {
11
+ CalendarContentStyled,
12
+ CalendarFooterStyled,
13
+ CalendarStyled,
14
+ DayPickerWrapperStyled,
15
+ CalendarButtonStyled,
16
+ } from "./styledComponents";
17
+
18
+ export type CalendarProps = ComponentProps<typeof CalendarStyled> & {
19
+ calendarLayout?: "label" | "dropdown" | "dropdown-months" | "dropdown-years";
20
+ selected: Date | undefined;
21
+ setSelected: React.Dispatch<React.SetStateAction<Date | undefined>>;
22
+ position?: "top" | "bottom" | "top-right" | "bottom-right";
23
+ action?: boolean;
24
+ actionText?: string;
25
+ actionAlign?: "left" | "center" | "right";
26
+ hasError?: boolean;
27
+ expand?: boolean;
28
+ allowPastDates?: boolean;
29
+ maxDate?: Date;
30
+ maxYearsFromNow?: number;
31
+ disabled?: boolean;
32
+ };
33
+
34
+ function formatToDateMask(value: string): string {
35
+ const numeric = value.replace(/\D/g, "").slice(0, 8);
36
+ const parts = numeric.match(/^(\d{0,2})(\d{0,2})(\d{0,4})$/);
37
+ if (!parts) return "";
38
+ const [, day, month, year] = parts;
39
+ return [day, month, year].filter(Boolean).join("/");
40
+ }
41
+
42
+ export function Calendar({
43
+ action,
44
+ actionText,
45
+ actionAlign = "right",
46
+ calendarLayout,
47
+ selected,
48
+ setSelected,
49
+ position = "bottom",
50
+ hasError,
51
+ expand,
52
+ allowPastDates = false,
53
+ maxDate,
54
+ maxYearsFromNow,
55
+ disabled = false,
56
+ ...props
57
+ }: CalendarProps) {
58
+ const [inputValue, setInputValue] = useState("");
59
+ const [showContainer, setShowCalendar] = useState(false);
60
+
61
+ const dropdownRef = useRef<HTMLDivElement>(null);
62
+
63
+ useOnClickOutside(dropdownRef, () => {
64
+ setShowCalendar(false);
65
+ });
66
+ const today = new Date();
67
+ const resolvedMaxDate =
68
+ maxDate ?? (typeof maxYearsFromNow === "number" ? addYears(today, maxYearsFromNow) : undefined);
69
+ const disabledDays: Matcher[] = [];
70
+
71
+ if (!allowPastDates) {
72
+ disabledDays.push({ before: today });
73
+ }
74
+ if (resolvedMaxDate) {
75
+ disabledDays.push({ after: resolvedMaxDate });
76
+ }
77
+
78
+ useEffect(() => {
79
+ if (selected) {
80
+ setInputValue(format(selected, "dd/MM/yyyy"));
81
+ } else {
82
+ setInputValue("");
83
+ }
84
+ }, [selected]);
85
+
86
+ const handleInputChange = (e: React.ChangeEvent<HTMLInputElement>) => {
87
+ const masked = formatToDateMask(e.target.value);
88
+ setInputValue(masked);
89
+
90
+ const parsed = parse(masked, "dd/MM/yyyy", new Date());
91
+ if (isValid(parsed)) {
92
+ if (!allowPastDates && parsed < today) {
93
+ console.warn("Datas passadas não são permitidas:", masked);
94
+ return;
95
+ }
96
+ if (resolvedMaxDate && parsed > resolvedMaxDate) {
97
+ console.warn("Data maior que o limite máximo permitido:", masked);
98
+ return;
99
+ }
100
+ setSelected(parsed);
101
+ } else {
102
+ console.warn("Data inválida inserida no input:", masked);
103
+ }
104
+ };
105
+
106
+ return (
107
+ <div>
108
+ <CalendarStyled {...props} expand={expand} ref={dropdownRef}>
109
+ <CalendarButtonStyled
110
+ expand={expand}
111
+ type="button"
112
+ onClick={() => setShowCalendar((prev) => !prev)}
113
+ >
114
+ <TextField
115
+ placeholder="00/00/0000"
116
+ type="text"
117
+ value={inputValue}
118
+ onChange={handleInputChange}
119
+ inputMode="numeric"
120
+ textAlign={"right"}
121
+ color={hasError ? "error" : "default"}
122
+ disabled={disabled}
123
+ >
124
+ <TextFieldSlot>
125
+ <Icon name="calendar" size={"xl"} color="#4C4F54" />
126
+ </TextFieldSlot>
127
+ </TextField>
128
+ </CalendarButtonStyled>
129
+ {showContainer && (
130
+ <CalendarContentStyled position={position}>
131
+ <Box>
132
+ <DayPickerWrapperStyled>
133
+ <DayPicker
134
+ mode="single"
135
+ captionLayout={calendarLayout}
136
+ selected={selected}
137
+ onSelect={setSelected}
138
+ required
139
+ locale={ptBR}
140
+ disabled={disabledDays.length > 0 ? disabledDays : undefined}
141
+ startMonth={allowPastDates ? undefined : today}
142
+ endMonth={resolvedMaxDate}
143
+ />
144
+ </DayPickerWrapperStyled>
145
+ </Box>
146
+
147
+ {action && (
148
+ <CalendarFooterStyled actionAlign={actionAlign}>
149
+ <Button
150
+ variant="text"
151
+ color="brand"
152
+ type="button"
153
+ onClick={() => {
154
+ setShowCalendar(false);
155
+ }}
156
+ size={"medium"}
157
+ fontWeight="medium"
158
+ >
159
+ {actionText ?? "Aplicar"}
160
+ </Button>
161
+ </CalendarFooterStyled>
162
+ )}
163
+ </CalendarContentStyled>
164
+ )}
165
+ </CalendarStyled>
166
+ </div>
167
+ );
168
+ }