@lets-events/react 12.4.1 → 12.5.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 (91) hide show
  1. package/.eslintrc.json +2 -2
  2. package/CHANGELOG.md +6 -0
  3. package/package.json +1 -1
  4. package/src/components/Alert.tsx +303 -303
  5. package/src/components/Avatar.tsx +55 -55
  6. package/src/components/Badge.tsx +125 -125
  7. package/src/components/Box.tsx +3 -3
  8. package/src/components/Button/index.tsx +45 -45
  9. package/src/components/Button/styledComponents.ts +313 -313
  10. package/src/components/ButtonGroup.tsx +484 -484
  11. package/src/components/Calendar/index.tsx +148 -148
  12. package/src/components/Calendar/styledComponents.ts +259 -259
  13. package/src/components/Card.tsx +67 -67
  14. package/src/components/CheckboxGroup.tsx +176 -176
  15. package/src/components/Container.tsx +39 -39
  16. package/src/components/Divider.tsx +7 -7
  17. package/src/components/DoubleCalendar/index.tsx +170 -166
  18. package/src/components/Drawer/index.tsx +100 -98
  19. package/src/components/Drawer/styledComponents.ts +103 -103
  20. package/src/components/Dropdown.tsx +302 -302
  21. package/src/components/Filter.tsx +164 -164
  22. package/src/components/Flex.tsx +118 -118
  23. package/src/components/FormFields/AddressFormFields/CityFormField.tsx +111 -111
  24. package/src/components/FormFields/AddressFormFields/CountryFormField.tsx +33 -33
  25. package/src/components/FormFields/AddressFormFields/PostalCodeFormField.tsx +39 -39
  26. package/src/components/FormFields/AddressFormFields/StateFormField.tsx +32 -32
  27. package/src/components/FormFields/AddressFormFields/index.tsx +141 -141
  28. package/src/components/FormFields/BirthDateFormField.tsx +84 -84
  29. package/src/components/FormFields/CNPJFormField.tsx +87 -87
  30. package/src/components/FormFields/CPFFormField.tsx +78 -78
  31. package/src/components/FormFields/CalendarFormField.tsx +95 -95
  32. package/src/components/FormFields/CheckboxGroupFormField.tsx +91 -91
  33. package/src/components/FormFields/DoubleCalendarFormField.tsx +93 -90
  34. package/src/components/FormFields/EmailFormField.tsx +27 -27
  35. package/src/components/FormFields/Form.tsx +39 -39
  36. package/src/components/FormFields/IdentityDocumentNumberFormField.tsx +32 -32
  37. package/src/components/FormFields/MultiSelectFormField.tsx +64 -64
  38. package/src/components/FormFields/PhoneFormField.tsx +40 -40
  39. package/src/components/FormFields/RadioGroupFormField.tsx +84 -84
  40. package/src/components/FormFields/RichEditorFormField.tsx +103 -103
  41. package/src/components/FormFields/SelectFormField.tsx +93 -93
  42. package/src/components/FormFields/SwitchFormField.tsx +46 -46
  43. package/src/components/FormFields/TextAreaFormField.tsx +59 -59
  44. package/src/components/FormFields/TextFormField.tsx +112 -112
  45. package/src/components/FormFields/TimePickerFormField.tsx +88 -88
  46. package/src/components/FormFields/subComponents/ErrorFormMessage.tsx +36 -36
  47. package/src/components/FormFields/subComponents/FormLabel.tsx +29 -29
  48. package/src/components/FormFields/utils/validation.ts +23 -23
  49. package/src/components/Grid.tsx +137 -137
  50. package/src/components/Icon.tsx +47 -47
  51. package/src/components/MenuDropdown/index.tsx +38 -38
  52. package/src/components/MenuDropdown/styledComponents.ts +31 -31
  53. package/src/components/Modal.tsx +110 -110
  54. package/src/components/MultiSelect/index.tsx +243 -243
  55. package/src/components/MultiSelect/styledComponents.ts +160 -160
  56. package/src/components/RadioGroup.tsx +210 -210
  57. package/src/components/RichEditor/QuillComponent.tsx +457 -457
  58. package/src/components/RichEditor/RichEditor.tsx +49 -49
  59. package/src/components/RichEditor/index.ts +2 -2
  60. package/src/components/RichEditor/styledComponents.ts +1151 -1151
  61. package/src/components/Section.tsx +33 -33
  62. package/src/components/Step.tsx +164 -164
  63. package/src/components/Switch.tsx +108 -108
  64. package/src/components/Text.tsx +38 -38
  65. package/src/components/TextField.tsx +372 -372
  66. package/src/components/TextareaField.tsx +138 -138
  67. package/src/components/TimePicker.tsx +328 -328
  68. package/src/components/Toast/components/ToastItem.tsx +41 -41
  69. package/src/components/Toast/components/ToastProvider.tsx +63 -63
  70. package/src/components/Toast/hooks/useToast.ts +12 -12
  71. package/src/components/Toast/index.tsx +5 -5
  72. package/src/components/Toast/styles/index.ts +135 -135
  73. package/src/components/Toast/types/index.ts +46 -46
  74. package/src/components/Tooltip/index.tsx +66 -66
  75. package/src/components/Tooltip/styles.ts +77 -77
  76. package/src/hooks/useCountries.ts +41 -41
  77. package/src/hooks/useImageUpload.ts +139 -139
  78. package/src/hooks/useOnClickOutside.tsx +42 -42
  79. package/src/index.tsx +71 -71
  80. package/src/styles/index.ts +41 -41
  81. package/src/types/typographyValues.ts +178 -178
  82. package/src/utils/getNestedValue.ts +3 -3
  83. package/src/utils/states.ts +29 -29
  84. package/src/utils/uploadService.ts +180 -180
  85. package/tsconfig.json +3 -3
  86. package/tsup.config.ts +38 -38
  87. package/.turbo/turbo-build.log +0 -19
  88. package/dist/index.d.mts +0 -15398
  89. package/dist/index.d.ts +0 -15398
  90. package/dist/index.js +0 -13390
  91. package/dist/index.mjs +0 -13284
@@ -1,59 +1,59 @@
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
- simpleLayout = false,
24
- ...props
25
- }: TextAreaFormFieldProps) => {
26
- const {
27
- register,
28
- formState: { errors },
29
- } = useFormContext();
30
-
31
- const haveError = !!errors[name];
32
-
33
- const errorMsg = errors[name]?.message;
34
-
35
- const validationRules = {
36
- required: required ? validationErrorMessage : false,
37
- validate: validate,
38
- };
39
-
40
- return (
41
- <Flex direction={"column"}>
42
- <FormLabel
43
- name={name}
44
- label={label}
45
- required={required}
46
- haveError={haveError}
47
- />
48
- <TextareaField
49
- {...props}
50
- {...register(name, validationRules)}
51
- placeholder={placeholder}
52
- color={haveError ? "error" : "default"}
53
- simpleLayout={simpleLayout}
54
- aria-labelledby={`${name}-label`}
55
- />
56
- <ErrorFormMessage message={errorMsg} />
57
- </Flex>
58
- );
59
- };
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
+ simpleLayout = false,
24
+ ...props
25
+ }: TextAreaFormFieldProps) => {
26
+ const {
27
+ register,
28
+ formState: { errors },
29
+ } = useFormContext();
30
+
31
+ const haveError = !!errors[name];
32
+
33
+ const errorMsg = errors[name]?.message;
34
+
35
+ const validationRules = {
36
+ required: required ? validationErrorMessage : false,
37
+ validate: validate,
38
+ };
39
+
40
+ return (
41
+ <Flex direction={"column"}>
42
+ <FormLabel
43
+ name={name}
44
+ label={label}
45
+ required={required}
46
+ haveError={haveError}
47
+ />
48
+ <TextareaField
49
+ {...props}
50
+ {...register(name, validationRules)}
51
+ placeholder={placeholder}
52
+ color={haveError ? "error" : "default"}
53
+ simpleLayout={simpleLayout}
54
+ aria-labelledby={`${name}-label`}
55
+ />
56
+ <ErrorFormMessage message={errorMsg} />
57
+ </Flex>
58
+ );
59
+ };
@@ -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
+ };
@@ -1,88 +1,88 @@
1
- import React from "react";
2
- import { FieldValues, useController, RegisterOptions } from "react-hook-form";
3
- import { Flex } from "../Flex";
4
- import { FormLabel } from "./subComponents/FormLabel";
5
- import { ErrorFormMessage } from "./subComponents/ErrorFormMessage";
6
- import { TimePicker, TimePickerProps } from "../TimePicker";
7
- import { useCallback } from "react";
8
-
9
- export type TimePickerFormFieldProps = Omit<
10
- TimePickerProps,
11
- "selected" | "setSelected"
12
- > & {
13
- name: string;
14
- label?: string;
15
- required?: boolean;
16
- validate?: (value: string | undefined) => boolean | string;
17
- validationErrorMessage?: string;
18
- rules?: Omit<
19
- RegisterOptions<FieldValues, string>,
20
- "valueAsNumber" | "valueAsDate" | "setValueAs" | "disabled"
21
- >;
22
- };
23
-
24
- export const TimePickerFormField = ({
25
- name,
26
- label,
27
- required,
28
- validate,
29
- validationErrorMessage = "Este campo é obrigatório.",
30
- rules,
31
- ...timePickerProps
32
- }: TimePickerFormFieldProps) => {
33
- const handleValidate = useCallback(
34
- (value?: string) => {
35
- if (value === undefined || value === null || value === "") {
36
- if (required) return validationErrorMessage;
37
- return true;
38
- }
39
- return validate?.(value) ?? true;
40
- },
41
- [validate, required, validationErrorMessage]
42
- );
43
-
44
- const { field, fieldState } = useController({
45
- name,
46
- rules: {
47
- required: required ? validationErrorMessage : false,
48
- validate: handleValidate,
49
- ...rules,
50
- },
51
- defaultValue: undefined,
52
- });
53
-
54
- const fieldError = fieldState.error;
55
- const haveError = !!fieldError;
56
- const errorMsg = fieldError?.message;
57
-
58
- const { value: selected, onChange: setSelected } = field;
59
-
60
- const handleTimePickerChange = (time: string | undefined) => {
61
- setSelected(time);
62
- };
63
-
64
- return (
65
- <Flex direction="column" style={{ flex: "1" }}>
66
- {label && (
67
- <FormLabel
68
- name={name}
69
- label={label}
70
- required={required}
71
- haveError={haveError}
72
- />
73
- )}
74
-
75
- <TimePicker
76
- selected={selected}
77
- setSelected={(value) => {
78
- const time = typeof value === "function" ? value(selected) : value;
79
- handleTimePickerChange(time);
80
- }}
81
- hasError={haveError}
82
- {...timePickerProps}
83
- />
84
-
85
- <ErrorFormMessage message={errorMsg} />
86
- </Flex>
87
- );
88
- };
1
+ import React from "react";
2
+ import { FieldValues, useController, RegisterOptions } from "react-hook-form";
3
+ import { Flex } from "../Flex";
4
+ import { FormLabel } from "./subComponents/FormLabel";
5
+ import { ErrorFormMessage } from "./subComponents/ErrorFormMessage";
6
+ import { TimePicker, TimePickerProps } from "../TimePicker";
7
+ import { useCallback } from "react";
8
+
9
+ export type TimePickerFormFieldProps = Omit<
10
+ TimePickerProps,
11
+ "selected" | "setSelected"
12
+ > & {
13
+ name: string;
14
+ label?: string;
15
+ required?: boolean;
16
+ validate?: (value: string | undefined) => boolean | string;
17
+ validationErrorMessage?: string;
18
+ rules?: Omit<
19
+ RegisterOptions<FieldValues, string>,
20
+ "valueAsNumber" | "valueAsDate" | "setValueAs" | "disabled"
21
+ >;
22
+ };
23
+
24
+ export const TimePickerFormField = ({
25
+ name,
26
+ label,
27
+ required,
28
+ validate,
29
+ validationErrorMessage = "Este campo é obrigatório.",
30
+ rules,
31
+ ...timePickerProps
32
+ }: TimePickerFormFieldProps) => {
33
+ const handleValidate = useCallback(
34
+ (value?: string) => {
35
+ if (value === undefined || value === null || value === "") {
36
+ if (required) return validationErrorMessage;
37
+ return true;
38
+ }
39
+ return validate?.(value) ?? true;
40
+ },
41
+ [validate, required, validationErrorMessage]
42
+ );
43
+
44
+ const { field, fieldState } = useController({
45
+ name,
46
+ rules: {
47
+ required: required ? validationErrorMessage : false,
48
+ validate: handleValidate,
49
+ ...rules,
50
+ },
51
+ defaultValue: undefined,
52
+ });
53
+
54
+ const fieldError = fieldState.error;
55
+ const haveError = !!fieldError;
56
+ const errorMsg = fieldError?.message;
57
+
58
+ const { value: selected, onChange: setSelected } = field;
59
+
60
+ const handleTimePickerChange = (time: string | undefined) => {
61
+ setSelected(time);
62
+ };
63
+
64
+ return (
65
+ <Flex direction="column" style={{ flex: "1" }}>
66
+ {label && (
67
+ <FormLabel
68
+ name={name}
69
+ label={label}
70
+ required={required}
71
+ haveError={haveError}
72
+ />
73
+ )}
74
+
75
+ <TimePicker
76
+ selected={selected}
77
+ setSelected={(value) => {
78
+ const time = typeof value === "function" ? value(selected) : value;
79
+ handleTimePickerChange(time);
80
+ }}
81
+ hasError={haveError}
82
+ {...timePickerProps}
83
+ />
84
+
85
+ <ErrorFormMessage message={errorMsg} />
86
+ </Flex>
87
+ );
88
+ };
@@ -1,36 +1,36 @@
1
- import { faXmarkCircle } from "@fortawesome/free-solid-svg-icons";
2
- import { FontAwesomeIcon } from "@fortawesome/react-fontawesome";
3
- import { colors } from "@lets-events/tokens";
4
- import { Flex } from "../../Flex";
5
- import { Text } from "../../Text";
6
- import {
7
- FieldError,
8
- FieldErrorsImpl,
9
- FieldValues,
10
- Merge,
11
- } from "react-hook-form";
12
-
13
- export type ErrorFormMessageProps = {
14
- message?:
15
- | string
16
- | FieldError
17
- | Merge<FieldError, FieldErrorsImpl<any>>
18
- | undefined;
19
- };
20
-
21
- export const ErrorFormMessage = ({ message }: ErrorFormMessageProps) => {
22
- if (!message) return null;
23
-
24
- if (typeof message !== "string") {
25
- return null;
26
- }
27
-
28
- return (
29
- <Flex justify={"start"} align={"center"} gap={6}>
30
- <FontAwesomeIcon icon={faXmarkCircle} color={colors.error600} size="1x" />
31
- <Text typography={"bodyXS"} fontWeight={"medium"} color="error600">
32
- {message}
33
- </Text>
34
- </Flex>
35
- );
36
- };
1
+ import { faXmarkCircle } from "@fortawesome/free-solid-svg-icons";
2
+ import { FontAwesomeIcon } from "@fortawesome/react-fontawesome";
3
+ import { colors } from "@lets-events/tokens";
4
+ import { Flex } from "../../Flex";
5
+ import { Text } from "../../Text";
6
+ import {
7
+ FieldError,
8
+ FieldErrorsImpl,
9
+ FieldValues,
10
+ Merge,
11
+ } from "react-hook-form";
12
+
13
+ export type ErrorFormMessageProps = {
14
+ message?:
15
+ | string
16
+ | FieldError
17
+ | Merge<FieldError, FieldErrorsImpl<any>>
18
+ | undefined;
19
+ };
20
+
21
+ export const ErrorFormMessage = ({ message }: ErrorFormMessageProps) => {
22
+ if (!message) return null;
23
+
24
+ if (typeof message !== "string") {
25
+ return null;
26
+ }
27
+
28
+ return (
29
+ <Flex justify={"start"} align={"center"} gap={6}>
30
+ <FontAwesomeIcon icon={faXmarkCircle} color={colors.error600} size="1x" />
31
+ <Text typography={"bodyXS"} fontWeight={"medium"} color="error600">
32
+ {message}
33
+ </Text>
34
+ </Flex>
35
+ );
36
+ };
@@ -1,29 +1,29 @@
1
- import { Text } from "../../Text";
2
-
3
- export type FormLabelProps = {
4
- name: string;
5
- label?: string;
6
- haveError?: boolean;
7
- required?: boolean;
8
- };
9
-
10
- export const FormLabel = ({
11
- name,
12
- label,
13
- haveError,
14
- required,
15
- }: FormLabelProps) => {
16
- if (!label) return null;
17
-
18
- return (
19
- <Text
20
- typography={"labelMedium"}
21
- fontWeight={"medium"}
22
- color={haveError ? "error600" : "dark700"}
23
- id={`${name}-label`}
24
- >
25
- {label}
26
- {!required && <Text color="dark500"> (opcional)</Text>}
27
- </Text>
28
- );
29
- };
1
+ import { Text } from "../../Text";
2
+
3
+ export type FormLabelProps = {
4
+ name: string;
5
+ label?: string;
6
+ haveError?: boolean;
7
+ required?: boolean;
8
+ };
9
+
10
+ export const FormLabel = ({
11
+ name,
12
+ label,
13
+ haveError,
14
+ required,
15
+ }: FormLabelProps) => {
16
+ if (!label) return null;
17
+
18
+ return (
19
+ <Text
20
+ typography={"labelMedium"}
21
+ fontWeight={"medium"}
22
+ color={haveError ? "error600" : "dark700"}
23
+ id={`${name}-label`}
24
+ >
25
+ {label}
26
+ {!required && <Text color="dark500"> (opcional)</Text>}
27
+ </Text>
28
+ );
29
+ };