@ultraviolet/form 2.4.0 → 2.4.1

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.
@@ -0,0 +1,97 @@
1
+ import { TextArea } from '@ultraviolet/ui';
2
+ import { useController } from 'react-hook-form';
3
+ import { jsx } from '@emotion/react/jsx-runtime';
4
+ import { useErrors } from '../../providers/ErrorContext/index.js';
5
+
6
+ /**
7
+ * This component offers a form field based on Ultraviolet UI TextArea component
8
+ */
9
+ const TextAreaField = ({
10
+ autoFocus,
11
+ clearable,
12
+ className,
13
+ tabIndex,
14
+ 'data-testid': dataTestId,
15
+ disabled,
16
+ helper,
17
+ label,
18
+ labelDescription,
19
+ onChange,
20
+ minLength,
21
+ maxLength,
22
+ name,
23
+ onFocus,
24
+ onBlur,
25
+ placeholder,
26
+ readOnly,
27
+ required,
28
+ rows,
29
+ success,
30
+ tooltip,
31
+ validate,
32
+ regex: regexes
33
+ }) => {
34
+ const {
35
+ getError
36
+ } = useErrors();
37
+ const {
38
+ field,
39
+ fieldState: {
40
+ error
41
+ }
42
+ } = useController({
43
+ name,
44
+ rules: {
45
+ required,
46
+ validate: {
47
+ ...(regexes ? {
48
+ pattern: value => regexes.every(regex => value === undefined || value === '' || (Array.isArray(regex) ? regex.some(regexOr => regexOr.test(value)) : regex.test(value)))
49
+ } : {}),
50
+ ...validate
51
+ },
52
+ minLength,
53
+ maxLength
54
+ }
55
+ });
56
+ return jsx(TextArea, {
57
+ autoFocus: autoFocus,
58
+ className: className,
59
+ clearable: clearable,
60
+ "data-testid": dataTestId,
61
+ disabled: disabled,
62
+ error: getError({
63
+ regex: regexes,
64
+ minLength,
65
+ maxLength,
66
+ label,
67
+ value: field.value
68
+ }, error),
69
+ helper: helper,
70
+ label: label,
71
+ labelDescription: labelDescription,
72
+ minLength: minLength,
73
+ maxLength: maxLength,
74
+ name: name,
75
+ onBlur: event => {
76
+ onBlur?.(event);
77
+ field.onBlur();
78
+ },
79
+ onChange: event => {
80
+ field.onChange(event);
81
+ onChange?.(event);
82
+ },
83
+ onFocus: event => {
84
+ onFocus?.(event);
85
+ },
86
+ placeholder: placeholder,
87
+ readOnly: readOnly,
88
+ required: required,
89
+ rows: rows,
90
+ success: success,
91
+ tabIndex: tabIndex,
92
+ tooltip: tooltip,
93
+ value: field.value
94
+ });
95
+ };
96
+
97
+ export { TextAreaField };
package/dist/index.d.ts CHANGED
@@ -1,5 +1,5 @@
1
1
  import * as _emotion_react_jsx_runtime from '@emotion/react/jsx-runtime';
2
- import { Checkbox, CheckboxGroup, DateInput, Radio, SelectInput, SelectableCard, NumberInput, NumberInputV2, TagInput, TextInput, TextInputV2, TimeInput, Toggle, Button, RadioGroup } from '@ultraviolet/ui';
2
+ import { Checkbox, CheckboxGroup, DateInput, Radio, SelectInput, SelectableCard, NumberInput, NumberInputV2, TagInput, TextArea, TextInput, TextInputV2, TimeInput, Toggle, Button, RadioGroup } from '@ultraviolet/ui';
3
3
  import * as react from 'react';
4
4
  import { ComponentProps, ReactNode, FocusEvent, ForwardedRef, FocusEventHandler, Ref, JSX } from 'react';
5
5
  import * as react_hook_form from 'react-hook-form';
@@ -267,6 +267,14 @@ declare const SubmitErrorAlert: ({ className }: {
267
267
  type TagInputFieldProps<TFieldValues extends FieldValues, TName extends FieldPath<TFieldValues>> = BaseFieldProps<TFieldValues, TName> & Partial<Pick<ComponentProps<typeof TagInput>, 'tags' | 'variant' | 'placeholder' | 'disabled' | 'className' | 'id' | 'data-testid'>>;
268
268
  declare const TagInputField: <TFieldValues extends FieldValues, TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>>({ className, disabled, id, name, onChange, placeholder, required, rules, variant, shouldUnregister, "data-testid": dataTestId, }: TagInputFieldProps<TFieldValues, TName>) => _emotion_react_jsx_runtime.JSX.Element;
269
269
 
270
+ type TextAreaFieldProps<TFieldValues extends FieldValues, TName extends FieldPath<TFieldValues>> = BaseFieldProps<TFieldValues, TName> & Omit<ComponentProps<typeof TextArea>, 'value' | 'error' | 'name' | 'onChange'> & {
271
+ regex?: (RegExp | RegExp[])[];
272
+ };
273
+ /**
274
+ * This component offers a form field based on Ultraviolet UI TextArea component
275
+ */
276
+ declare const TextAreaField: <TFieldValues extends FieldValues, TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>>({ autoFocus, clearable, className, tabIndex, "data-testid": dataTestId, disabled, helper, label, labelDescription, onChange, minLength, maxLength, name, onFocus, onBlur, placeholder, readOnly, required, rows, success, tooltip, validate, regex: regexes, }: TextAreaFieldProps<TFieldValues, TName>) => _emotion_react_jsx_runtime.JSX.Element;
277
+
270
278
  type TextInputFieldProps$1<TFieldValues extends FieldValues, TName extends FieldPath<TFieldValues>> = BaseFieldProps<TFieldValues, TName> & Partial<Pick<ComponentProps<typeof TextInput>, 'autoCapitalize' | 'autoComplete' | 'autoCorrect' | 'autoFocus' | 'autoSave' | 'cols' | 'disabled' | 'fillAvailable' | 'generated' | 'id' | 'multiline' | 'notice' | 'onBlur' | 'onFocus' | 'onKeyDown' | 'onKeyUp' | 'placeholder' | 'random' | 'readOnly' | 'resizable' | 'rows' | 'type' | 'noTopLabel' | 'unit' | 'valid' | 'size' | 'maxLength' | 'minLength' | 'min' | 'max' | 'data-testid'>> & {
271
279
  className?: string;
272
280
  regex?: (RegExp | RegExp[])[];
@@ -493,4 +501,4 @@ declare const useFieldArrayDeprecated: <T, TFieldValues extends FieldValues = Fi
493
501
  };
494
502
  };
495
503
 
496
- export { type BaseFieldProps, CheckboxField, CheckboxGroupField, DateField, ErrorProvider, FORM_ERROR, Form, type FormErrors, type FormProps, KeyValueField, NumberInputField, NumberInputFieldV2, RadioField, RadioGroupField, SelectInputField, SelectableCardField, Submit, SubmitErrorAlert, TagInputField, TextInputField$1 as TextInputField, TextInputField as TextInputFieldV2, TimeField, ToggleField, useErrors, useFieldArrayDeprecated, useFieldDeprecated, useFormDeprecated, useFormStateDeprecated, useOnFieldChange };
504
+ export { type BaseFieldProps, CheckboxField, CheckboxGroupField, DateField, ErrorProvider, FORM_ERROR, Form, type FormErrors, type FormProps, KeyValueField, NumberInputField, NumberInputFieldV2, RadioField, RadioGroupField, SelectInputField, SelectableCardField, Submit, SubmitErrorAlert, TagInputField, TextAreaField, TextInputField$1 as TextInputField, TextInputField as TextInputFieldV2, TimeField, ToggleField, useErrors, useFieldArrayDeprecated, useFieldDeprecated, useFormDeprecated, useFormStateDeprecated, useOnFieldChange };
package/dist/index.js CHANGED
@@ -1,26 +1,27 @@
1
1
  export { FORM_ERROR } from './constants.js';
2
2
  export { ErrorProvider, useErrors } from './providers/ErrorContext/index.js';
3
3
  export { useController, useFieldArray, useForm, useFormContext, useFormState, useWatch } from 'react-hook-form';
4
+ export { useFormStateDeprecated } from './hooks/useFormState.js';
5
+ export { useFieldDeprecated } from './hooks/useField.js';
6
+ export { useFormDeprecated } from './hooks/useForm.js';
7
+ export { useFieldArrayDeprecated } from './hooks/useFieldArray.js';
8
+ export { useOnFieldChange } from './hooks/useOnFieldChange.js';
4
9
  export { CheckboxField } from './components/CheckboxField/index.js';
5
10
  export { CheckboxGroupField } from './components/CheckboxGroupField/index.js';
6
11
  export { DateField } from './components/DateField/index.js';
7
12
  export { Form } from './components/Form/index.js';
8
- export { KeyValueField } from './components/KeyValueField/index.js';
9
13
  export { RadioField } from './components/RadioField/index.js';
10
- export { SelectableCardField } from './components/SelectableCardField/index.js';
11
14
  export { SelectInputField } from './components/SelectInputField/index.js';
15
+ export { SelectableCardField } from './components/SelectableCardField/index.js';
12
16
  export { NumberInputField } from './components/NumberInputField/index.js';
13
- export { Submit } from './components/Submit/index.js';
17
+ export { NumberInputFieldV2 } from './components/NumberInputFieldV2/index.js';
14
18
  export { SubmitErrorAlert } from './components/SubmitErrorAlert/index.js';
15
19
  export { TagInputField } from './components/TagInputField/index.js';
20
+ export { TextAreaField } from './components/TextAreaField/index.js';
16
21
  export { TextInputField } from './components/TextInputField/index.js';
22
+ export { TextInputField as TextInputFieldV2 } from './components/TextInputFieldV2/index.js';
17
23
  export { TimeField } from './components/TimeField/index.js';
18
24
  export { ToggleField } from './components/ToggleField/index.js';
25
+ export { Submit } from './components/Submit/index.js';
19
26
  export { RadioGroupField } from './components/RadioGroupField/index.js';
20
- export { NumberInputFieldV2 } from './components/NumberInputFieldV2/index.js';
21
- export { TextInputField as TextInputFieldV2 } from './components/TextInputFieldV2/index.js';
22
- export { useFormStateDeprecated } from './hooks/useFormState.js';
23
- export { useFieldDeprecated } from './hooks/useField.js';
24
- export { useFormDeprecated } from './hooks/useForm.js';
25
- export { useFieldArrayDeprecated } from './hooks/useFieldArray.js';
26
- export { useOnFieldChange } from './hooks/useOnFieldChange.js';
27
+ export { KeyValueField } from './components/KeyValueField/index.js';
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@ultraviolet/form",
3
- "version": "2.4.0",
3
+ "version": "2.4.1",
4
4
  "description": "Ultraviolet Form",
5
5
  "homepage": "https://github.com/scaleway/ultraviolet#readme",
6
6
  "repository": {
@@ -53,7 +53,7 @@
53
53
  "@emotion/styled": "11.11.0",
54
54
  "react-select": "5.8.0",
55
55
  "react-hook-form": "7.49.3",
56
- "@ultraviolet/ui": "1.32.0"
56
+ "@ultraviolet/ui": "1.32.1"
57
57
  },
58
58
  "scripts": {
59
59
  "build": "rollup -c ../../rollup.config.mjs",