@preply/ds-web-core 0.57.1 → 0.58.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.
- package/dist/events/types.d.ts +1 -1
- package/dist/field/hooks/useNumberField.d.ts +13 -0
- package/dist/field/hooks/useNumberField.js +67 -0
- package/dist/field/hooks/useSelectField.d.ts +14 -0
- package/dist/field/hooks/useSelectField.js +74 -0
- package/dist/field/index.d.ts +2 -0
- package/dist/field/index.js +3 -1
- package/dist/field/types.d.ts +8 -1
- package/dist/generated/breakpoints.less +1 -1
- package/dist/generated/options.less +1 -1
- package/dist/generated/tokens.less +1 -1
- package/dist/index.js +3 -1
- package/dist/input/private/types.d.ts +1 -0
- package/dist/input/private/utils.js +13 -7
- package/dist/input/types.d.ts +2 -1
- package/package.json +6 -6
package/dist/events/types.d.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { FocusEvent } from 'react';
|
|
2
2
|
export declare type FocusEventHandler = (event: FocusEvent) => void;
|
|
3
|
-
export declare type ValueChangeEventHandler<T> = (value: T) => void;
|
|
3
|
+
export declare type ValueChangeEventHandler<T> = (value: T | undefined) => void;
|
|
4
4
|
export interface FocusEventHandlers {
|
|
5
5
|
onFocus?: FocusEventHandler;
|
|
6
6
|
onBlur?: FocusEventHandler;
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import type { InputNumberProps } from '../../input';
|
|
3
|
+
import type { FieldLayoutProps } from '../types';
|
|
4
|
+
declare type UseNumberFieldState = {
|
|
5
|
+
layoutProps: Omit<FieldLayoutProps, 'input' | 'className' | 'inputHandle' | 'button'>;
|
|
6
|
+
inputProps: InputNumberProps;
|
|
7
|
+
};
|
|
8
|
+
export declare const useNumberField: (props: import("../types").FieldCommonProps & Pick<InputNumberProps, "required" | "disabled" | "hasError" | "dataset" | "onClick" | "value" | "defaultValue" | "min" | "max" | "placeholder" | "maxLength" | "name" | "onChange" | "onFocus" | "onBlur" | "onKeyDown" | "onKeyUp" | "onValueChange"> & {
|
|
9
|
+
id?: string | undefined;
|
|
10
|
+
} & {
|
|
11
|
+
icon?: import("react").ReactElement<import("../..").IconProps, string | ((props: any) => import("react").ReactElement<any, string | any | (new (props: any) => import("react").Component<any, any, any>)> | null) | (new (props: any) => import("react").Component<any, any, any>)> | undefined;
|
|
12
|
+
} & Pick<InputNumberProps, "required" | "disabled" | "hasError" | "dataset" | "onClick" | "value" | "defaultValue" | "min" | "max" | "aria-describedby" | "aria-disabled" | "aria-invalid" | "aria-required" | "placeholder" | "maxLength" | "name" | "onChange" | "onFocus" | "onBlur" | "onKeyDown" | "onKeyUp" | "onValueChange">) => UseNumberFieldState;
|
|
13
|
+
export {};
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
import { makeTinyId } from '@preply/ds-core';
|
|
2
|
+
import { useState } from 'react';
|
|
3
|
+
import { makeDescId } from '../../accessibility/aria/utils.js';
|
|
4
|
+
|
|
5
|
+
const useNumberField = (props) => {
|
|
6
|
+
const { id, value, label, hideLabel, preserveSpace, required, requiredLabel, additionalText, disabled, hasError, errorMessage, icon, onClick, onFocus, onBlur, onChange, inputDataset, dataset, max, min, onValueChange, ...rest } = props;
|
|
7
|
+
const actualId = id || makeTinyId();
|
|
8
|
+
const [isFocused, setIsFocused] = useState(false);
|
|
9
|
+
const [isTouched, setIsTouched] = useState(false);
|
|
10
|
+
const [isChanged, setIsChanged] = useState(false);
|
|
11
|
+
const handleFocus = ev => {
|
|
12
|
+
setIsFocused(true);
|
|
13
|
+
setIsTouched(true);
|
|
14
|
+
onFocus === null || onFocus === void 0 ? void 0 : onFocus(ev);
|
|
15
|
+
};
|
|
16
|
+
const handleBlur = ev => {
|
|
17
|
+
setIsFocused(false);
|
|
18
|
+
onBlur === null || onBlur === void 0 ? void 0 : onBlur(ev);
|
|
19
|
+
};
|
|
20
|
+
const handleChange = ev => {
|
|
21
|
+
setIsChanged(false);
|
|
22
|
+
onChange === null || onChange === void 0 ? void 0 : onChange(ev);
|
|
23
|
+
};
|
|
24
|
+
const actualHasError = hasError || !!errorMessage;
|
|
25
|
+
const actualAdditionalText = errorMessage || additionalText;
|
|
26
|
+
const describeId = actualHasError || !!additionalText ? makeDescId(actualId) : undefined;
|
|
27
|
+
return {
|
|
28
|
+
layoutProps: {
|
|
29
|
+
id: actualId,
|
|
30
|
+
label,
|
|
31
|
+
hideLabel,
|
|
32
|
+
required,
|
|
33
|
+
requiredLabel,
|
|
34
|
+
additionalText: actualAdditionalText,
|
|
35
|
+
preserveSpace,
|
|
36
|
+
disabled,
|
|
37
|
+
isFocused,
|
|
38
|
+
isTouched,
|
|
39
|
+
isChanged,
|
|
40
|
+
hasValue: typeof value !== undefined,
|
|
41
|
+
hasError: actualHasError,
|
|
42
|
+
onClick,
|
|
43
|
+
icon,
|
|
44
|
+
dataset,
|
|
45
|
+
},
|
|
46
|
+
inputProps: {
|
|
47
|
+
id: actualId,
|
|
48
|
+
value,
|
|
49
|
+
onClick,
|
|
50
|
+
onChange: handleChange,
|
|
51
|
+
onFocus: handleFocus,
|
|
52
|
+
onBlur: handleBlur,
|
|
53
|
+
onValueChange,
|
|
54
|
+
required,
|
|
55
|
+
disabled,
|
|
56
|
+
hasError: actualHasError,
|
|
57
|
+
dataset: inputDataset,
|
|
58
|
+
'aria-describedby': describeId,
|
|
59
|
+
max,
|
|
60
|
+
min,
|
|
61
|
+
...rest,
|
|
62
|
+
},
|
|
63
|
+
};
|
|
64
|
+
};
|
|
65
|
+
|
|
66
|
+
export { useNumberField };
|
|
67
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXNlTnVtYmVyRmllbGQuanMiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9maWVsZC9ob29rcy91c2VOdW1iZXJGaWVsZC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBtYWtlVGlueUlkIH0gZnJvbSAnQHByZXBseS9kcy1jb3JlJztcbmltcG9ydCB7IENoYW5nZUV2ZW50SGFuZGxlciwgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCc7XG5cbmltcG9ydCB7IG1ha2VEZXNjSWQgfSBmcm9tICcuLi8uLi9hY2Nlc3NpYmlsaXR5L2FyaWEvdXRpbHMnO1xuaW1wb3J0IHR5cGUgeyBGb2N1c0V2ZW50SGFuZGxlciB9IGZyb20gJy4uLy4uL2V2ZW50cyc7XG5pbXBvcnQgdHlwZSB7IElucHV0TnVtYmVyUHJvcHMgfSBmcm9tICcuLi8uLi9pbnB1dCc7XG5pbXBvcnQgdHlwZSB7IEZpZWxkTGF5b3V0UHJvcHMsIE51bWJlckZpZWxkUHJvcHMgfSBmcm9tICcuLi90eXBlcyc7XG5cbnR5cGUgVXNlTnVtYmVyRmllbGRTdGF0ZSA9IHtcbiAgICBsYXlvdXRQcm9wczogT21pdDxGaWVsZExheW91dFByb3BzLCAnaW5wdXQnIHwgJ2NsYXNzTmFtZScgfCAnaW5wdXRIYW5kbGUnIHwgJ2J1dHRvbic+O1xuICAgIGlucHV0UHJvcHM6IElucHV0TnVtYmVyUHJvcHM7XG59O1xuXG5leHBvcnQgY29uc3QgdXNlTnVtYmVyRmllbGQgPSAoXG4gICAgcHJvcHM6IE51bWJlckZpZWxkUHJvcHMgJiBPbWl0PElucHV0TnVtYmVyUHJvcHMsICdpZCc+LFxuKTogVXNlTnVtYmVyRmllbGRTdGF0ZSA9PiB7XG4gICAgY29uc3Qge1xuICAgICAgICBpZCxcbiAgICAgICAgdmFsdWUsXG4gICAgICAgIGxhYmVsLFxuICAgICAgICBoaWRlTGFiZWwsXG4gICAgICAgIHByZXNlcnZlU3BhY2UsXG4gICAgICAgIHJlcXVpcmVkLFxuICAgICAgICByZXF1aXJlZExhYmVsLFxuICAgICAgICBhZGRpdGlvbmFsVGV4dCxcbiAgICAgICAgZGlzYWJsZWQsXG4gICAgICAgIGhhc0Vycm9yLFxuICAgICAgICBlcnJvck1lc3NhZ2UsXG4gICAgICAgIGljb24sXG4gICAgICAgIG9uQ2xpY2ssXG4gICAgICAgIG9uRm9jdXMsXG4gICAgICAgIG9uQmx1cixcbiAgICAgICAgb25DaGFuZ2UsXG4gICAgICAgIGlucHV0RGF0YXNldCxcbiAgICAgICAgZGF0YXNldCxcbiAgICAgICAgbWF4LFxuICAgICAgICBtaW4sXG4gICAgICAgIG9uVmFsdWVDaGFuZ2UsXG4gICAgICAgIC4uLnJlc3RcbiAgICB9ID0gcHJvcHM7XG4gICAgY29uc3QgYWN0dWFsSWQgPSBpZCB8fCBtYWtlVGlueUlkKCk7XG4gICAgY29uc3QgW2lzRm9jdXNlZCwgc2V0SXNGb2N1c2VkXSA9IHVzZVN0YXRlPGJvb2xlYW4+KGZhbHNlKTtcbiAgICBjb25zdCBbaXNUb3VjaGVkLCBzZXRJc1RvdWNoZWRdID0gdXNlU3RhdGU8Ym9vbGVhbj4oZmFsc2UpO1xuICAgIGNvbnN0IFtpc0NoYW5nZWQsIHNldElzQ2hhbmdlZF0gPSB1c2VTdGF0ZTxib29sZWFuPihmYWxzZSk7XG5cbiAgICBjb25zdCBoYW5kbGVGb2N1czogRm9jdXNFdmVudEhhbmRsZXIgPSBldiA9PiB7XG4gICAgICAgIHNldElzRm9jdXNlZCh0cnVlKTtcbiAgICAgICAgc2V0SXNUb3VjaGVkKHRydWUpO1xuICAgICAgICBvbkZvY3VzPy4oZXYpO1xuICAgIH07XG4gICAgY29uc3QgaGFuZGxlQmx1cjogRm9jdXNFdmVudEhhbmRsZXIgPSBldiA9PiB7XG4gICAgICAgIHNldElzRm9jdXNlZChmYWxzZSk7XG4gICAgICAgIG9uQmx1cj8uKGV2KTtcbiAgICB9O1xuICAgIGNvbnN0IGhhbmRsZUNoYW5nZTogQ2hhbmdlRXZlbnRIYW5kbGVyID0gZXYgPT4ge1xuICAgICAgICBzZXRJc0NoYW5nZWQoZmFsc2UpO1xuICAgICAgICBvbkNoYW5nZT8uKGV2KTtcbiAgICB9O1xuXG4gICAgY29uc3QgYWN0dWFsSGFzRXJyb3IgPSBoYXNFcnJvciB8fCAhIWVycm9yTWVzc2FnZTtcbiAgICBjb25zdCBhY3R1YWxBZGRpdGlvbmFsVGV4dCA9IGVycm9yTWVzc2FnZSB8fCBhZGRpdGlvbmFsVGV4dDtcbiAgICBjb25zdCBkZXNjcmliZUlkID0gYWN0dWFsSGFzRXJyb3IgfHwgISFhZGRpdGlvbmFsVGV4dCA/IG1ha2VEZXNjSWQoYWN0dWFsSWQpIDogdW5kZWZpbmVkO1xuICAgIHJldHVybiB7XG4gICAgICAgIGxheW91dFByb3BzOiB7XG4gICAgICAgICAgICBpZDogYWN0dWFsSWQsXG4gICAgICAgICAgICBsYWJlbCxcbiAgICAgICAgICAgIGhpZGVMYWJlbCxcbiAgICAgICAgICAgIHJlcXVpcmVkLFxuICAgICAgICAgICAgcmVxdWlyZWRMYWJlbCxcbiAgICAgICAgICAgIGFkZGl0aW9uYWxUZXh0OiBhY3R1YWxBZGRpdGlvbmFsVGV4dCxcbiAgICAgICAgICAgIHByZXNlcnZlU3BhY2UsXG4gICAgICAgICAgICBkaXNhYmxlZCxcbiAgICAgICAgICAgIGlzRm9jdXNlZCxcbiAgICAgICAgICAgIGlzVG91Y2hlZCxcbiAgICAgICAgICAgIGlzQ2hhbmdlZCxcbiAgICAgICAgICAgIGhhc1ZhbHVlOiB0eXBlb2YgdmFsdWUgIT09IHVuZGVmaW5lZCxcbiAgICAgICAgICAgIGhhc0Vycm9yOiBhY3R1YWxIYXNFcnJvcixcbiAgICAgICAgICAgIG9uQ2xpY2ssXG4gICAgICAgICAgICBpY29uLFxuICAgICAgICAgICAgZGF0YXNldCxcbiAgICAgICAgfSxcbiAgICAgICAgaW5wdXRQcm9wczoge1xuICAgICAgICAgICAgaWQ6IGFjdHVhbElkLFxuICAgICAgICAgICAgdmFsdWUsXG4gICAgICAgICAgICBvbkNsaWNrLFxuICAgICAgICAgICAgb25DaGFuZ2U6IGhhbmRsZUNoYW5nZSxcbiAgICAgICAgICAgIG9uRm9jdXM6IGhhbmRsZUZvY3VzLFxuICAgICAgICAgICAgb25CbHVyOiBoYW5kbGVCbHVyLFxuICAgICAgICAgICAgb25WYWx1ZUNoYW5nZSxcbiAgICAgICAgICAgIHJlcXVpcmVkLFxuICAgICAgICAgICAgZGlzYWJsZWQsXG4gICAgICAgICAgICBoYXNFcnJvcjogYWN0dWFsSGFzRXJyb3IsXG4gICAgICAgICAgICBkYXRhc2V0OiBpbnB1dERhdGFzZXQsXG4gICAgICAgICAgICAnYXJpYS1kZXNjcmliZWRieSc6IGRlc2NyaWJlSWQsXG4gICAgICAgICAgICBtYXgsXG4gICAgICAgICAgICBtaW4sXG4gICAgICAgICAgICAuLi5yZXN0LFxuICAgICAgICB9LFxuICAgIH07XG59O1xuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7TUFhYSxjQUFjLEdBQUcsQ0FDMUIsS0FBc0Q7SUFFdEQsTUFBTSxFQUNGLEVBQUUsRUFDRixLQUFLLEVBQ0wsS0FBSyxFQUNMLFNBQVMsRUFDVCxhQUFhLEVBQ2IsUUFBUSxFQUNSLGFBQWEsRUFDYixjQUFjLEVBQ2QsUUFBUSxFQUNSLFFBQVEsRUFDUixZQUFZLEVBQ1osSUFBSSxFQUNKLE9BQU8sRUFDUCxPQUFPLEVBQ1AsTUFBTSxFQUNOLFFBQVEsRUFDUixZQUFZLEVBQ1osT0FBTyxFQUNQLEdBQUcsRUFDSCxHQUFHLEVBQ0gsYUFBYSxFQUNiLEdBQUcsSUFBSSxFQUNWLEdBQUcsS0FBSyxDQUFDO0lBQ1YsTUFBTSxRQUFRLEdBQUcsRUFBRSxJQUFJLFVBQVUsRUFBRSxDQUFDO0lBQ3BDLE1BQU0sQ0FBQyxTQUFTLEVBQUUsWUFBWSxDQUFDLEdBQUcsUUFBUSxDQUFVLEtBQUssQ0FBQyxDQUFDO0lBQzNELE1BQU0sQ0FBQyxTQUFTLEVBQUUsWUFBWSxDQUFDLEdBQUcsUUFBUSxDQUFVLEtBQUssQ0FBQyxDQUFDO0lBQzNELE1BQU0sQ0FBQyxTQUFTLEVBQUUsWUFBWSxDQUFDLEdBQUcsUUFBUSxDQUFVLEtBQUssQ0FBQyxDQUFDO0lBRTNELE1BQU0sV0FBVyxHQUFzQixFQUFFO1FBQ3JDLFlBQVksQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUNuQixZQUFZLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDbkIsT0FBTyxhQUFQLE9BQU8sdUJBQVAsT0FBTyxDQUFHLEVBQUUsRUFBRTtLQUNqQixDQUFDO0lBQ0YsTUFBTSxVQUFVLEdBQXNCLEVBQUU7UUFDcEMsWUFBWSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ3BCLE1BQU0sYUFBTixNQUFNLHVCQUFOLE1BQU0sQ0FBRyxFQUFFLEVBQUU7S0FDaEIsQ0FBQztJQUNGLE1BQU0sWUFBWSxHQUF1QixFQUFFO1FBQ3ZDLFlBQVksQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUNwQixRQUFRLGFBQVIsUUFBUSx1QkFBUixRQUFRLENBQUcsRUFBRSxFQUFFO0tBQ2xCLENBQUM7SUFFRixNQUFNLGNBQWMsR0FBRyxRQUFRLElBQUksQ0FBQyxDQUFDLFlBQVksQ0FBQztJQUNsRCxNQUFNLG9CQUFvQixHQUFHLFlBQVksSUFBSSxjQUFjLENBQUM7SUFDNUQsTUFBTSxVQUFVLEdBQUcsY0FBYyxJQUFJLENBQUMsQ0FBQyxjQUFjLEdBQUcsVUFBVSxDQUFDLFFBQVEsQ0FBQyxHQUFHLFNBQVMsQ0FBQztJQUN6RixPQUFPO1FBQ0gsV0FBVyxFQUFFO1lBQ1QsRUFBRSxFQUFFLFFBQVE7WUFDWixLQUFLO1lBQ0wsU0FBUztZQUNULFFBQVE7WUFDUixhQUFhO1lBQ2IsY0FBYyxFQUFFLG9CQUFvQjtZQUNwQyxhQUFhO1lBQ2IsUUFBUTtZQUNSLFNBQVM7WUFDVCxTQUFTO1lBQ1QsU0FBUztZQUNULFFBQVEsRUFBRSxPQUFPLEtBQUssS0FBSyxTQUFTO1lBQ3BDLFFBQVEsRUFBRSxjQUFjO1lBQ3hCLE9BQU87WUFDUCxJQUFJO1lBQ0osT0FBTztTQUNWO1FBQ0QsVUFBVSxFQUFFO1lBQ1IsRUFBRSxFQUFFLFFBQVE7WUFDWixLQUFLO1lBQ0wsT0FBTztZQUNQLFFBQVEsRUFBRSxZQUFZO1lBQ3RCLE9BQU8sRUFBRSxXQUFXO1lBQ3BCLE1BQU0sRUFBRSxVQUFVO1lBQ2xCLGFBQWE7WUFDYixRQUFRO1lBQ1IsUUFBUTtZQUNSLFFBQVEsRUFBRSxjQUFjO1lBQ3hCLE9BQU8sRUFBRSxZQUFZO1lBQ3JCLGtCQUFrQixFQUFFLFVBQVU7WUFDOUIsR0FBRztZQUNILEdBQUc7WUFDSCxHQUFHLElBQUk7U0FDVjtLQUNKLENBQUM7QUFDTjs7OzsifQ==
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import type { SelectProps } from '../../input';
|
|
3
|
+
import type { FieldLayoutProps } from '../types';
|
|
4
|
+
declare type UseSelectFieldState = {
|
|
5
|
+
layoutProps: Omit<FieldLayoutProps, 'input' | 'className' | 'inputHandle'>;
|
|
6
|
+
inputProps: SelectProps;
|
|
7
|
+
};
|
|
8
|
+
export declare const useSelectField: (props: import("../types").FieldCommonProps & Pick<SelectProps, "children" | "required" | "disabled" | "hasError" | "dataset" | "onClick" | "placeholder" | "name" | "value" | "defaultValue" | "onChange" | "onFocus" | "onBlur" | "onKeyDown" | "onKeyUp" | "onValueChange"> & {
|
|
9
|
+
id?: string | undefined;
|
|
10
|
+
} & {
|
|
11
|
+
icon?: import("react").ReactElement<import("../..").IconProps, string | ((props: any) => import("react").ReactElement<any, string | any | (new (props: any) => import("react").Component<any, any, any>)> | null) | (new (props: any) => import("react").Component<any, any, any>)> | undefined;
|
|
12
|
+
children?: string | number | boolean | {} | import("react").ReactElement<any, string | ((props: any) => import("react").ReactElement<any, string | any | (new (props: any) => import("react").Component<any, any, any>)> | null) | (new (props: any) => import("react").Component<any, any, any>)> | import("react").ReactNodeArray | import("react").ReactPortal | import("react").ReactNode[] | null | undefined;
|
|
13
|
+
} & Pick<SelectProps, "children" | "required" | "disabled" | "hasError" | "dataset" | "onClick" | "aria-describedby" | "aria-disabled" | "aria-invalid" | "aria-required" | "placeholder" | "name" | "value" | "defaultValue" | "onChange" | "onFocus" | "onBlur" | "onKeyDown" | "onKeyUp" | "onValueChange">) => UseSelectFieldState;
|
|
14
|
+
export {};
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
import { makeTinyId } from '@preply/ds-core';
|
|
2
|
+
import { useState, useEffect } from 'react';
|
|
3
|
+
import { makeDescId } from '../../accessibility/aria/utils.js';
|
|
4
|
+
|
|
5
|
+
const useSelectField = (props) => {
|
|
6
|
+
const { id, value, label, hideLabel, preserveSpace, required, requiredLabel, additionalText, disabled, hasError, errorMessage, icon, onClick, onFocus, onBlur, onChange, inputDataset, dataset, placeholder, defaultValue, ...rest } = props;
|
|
7
|
+
const actualId = id || makeTinyId();
|
|
8
|
+
const [isFocused, setIsFocused] = useState(false);
|
|
9
|
+
const [isTouched, setIsTouched] = useState(false);
|
|
10
|
+
const [isChanged, setIsChanged] = useState(false);
|
|
11
|
+
const [hasValue, setHasValue] = useState(!!(value || defaultValue));
|
|
12
|
+
const handleFocus = ev => {
|
|
13
|
+
setIsFocused(true);
|
|
14
|
+
setIsTouched(true);
|
|
15
|
+
onFocus === null || onFocus === void 0 ? void 0 : onFocus(ev);
|
|
16
|
+
};
|
|
17
|
+
const handleBlur = ev => {
|
|
18
|
+
setIsFocused(false);
|
|
19
|
+
onBlur === null || onBlur === void 0 ? void 0 : onBlur(ev);
|
|
20
|
+
};
|
|
21
|
+
const handleChange = (ev) => {
|
|
22
|
+
setIsChanged(true);
|
|
23
|
+
setHasValue(!!ev.target.value);
|
|
24
|
+
onChange === null || onChange === void 0 ? void 0 : onChange(ev);
|
|
25
|
+
};
|
|
26
|
+
const hasControlledValue = !!value;
|
|
27
|
+
useEffect(() => {
|
|
28
|
+
if (defaultValue)
|
|
29
|
+
return;
|
|
30
|
+
setHasValue(hasControlledValue);
|
|
31
|
+
}, [hasControlledValue]);
|
|
32
|
+
const actualHasError = hasError || !!errorMessage;
|
|
33
|
+
const actualAdditionalText = errorMessage || additionalText;
|
|
34
|
+
const describeId = actualHasError || !!additionalText ? makeDescId(actualId) : undefined;
|
|
35
|
+
return {
|
|
36
|
+
layoutProps: {
|
|
37
|
+
id: actualId,
|
|
38
|
+
label,
|
|
39
|
+
hideLabel,
|
|
40
|
+
required,
|
|
41
|
+
requiredLabel,
|
|
42
|
+
additionalText: actualAdditionalText,
|
|
43
|
+
preserveSpace,
|
|
44
|
+
disabled,
|
|
45
|
+
isFocused,
|
|
46
|
+
isTouched,
|
|
47
|
+
isChanged,
|
|
48
|
+
hasValue,
|
|
49
|
+
hasError: actualHasError,
|
|
50
|
+
onClick,
|
|
51
|
+
icon,
|
|
52
|
+
dataset,
|
|
53
|
+
},
|
|
54
|
+
inputProps: {
|
|
55
|
+
id: actualId,
|
|
56
|
+
value,
|
|
57
|
+
onClick,
|
|
58
|
+
onChange: handleChange,
|
|
59
|
+
onFocus: handleFocus,
|
|
60
|
+
onBlur: handleBlur,
|
|
61
|
+
required,
|
|
62
|
+
disabled,
|
|
63
|
+
hasError: actualHasError,
|
|
64
|
+
dataset: inputDataset,
|
|
65
|
+
'aria-describedby': describeId,
|
|
66
|
+
placeholder,
|
|
67
|
+
defaultValue,
|
|
68
|
+
...rest,
|
|
69
|
+
},
|
|
70
|
+
};
|
|
71
|
+
};
|
|
72
|
+
|
|
73
|
+
export { useSelectField };
|
|
74
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXNlU2VsZWN0RmllbGQuanMiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9maWVsZC9ob29rcy91c2VTZWxlY3RGaWVsZC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBtYWtlVGlueUlkIH0gZnJvbSAnQHByZXBseS9kcy1jb3JlJztcbmltcG9ydCB7IHVzZUVmZmVjdCwgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCc7XG5cbmltcG9ydCB7IG1ha2VEZXNjSWQgfSBmcm9tICcuLi8uLi9hY2Nlc3NpYmlsaXR5L2FyaWEvdXRpbHMnO1xuaW1wb3J0IHR5cGUgeyBGb2N1c0V2ZW50SGFuZGxlciB9IGZyb20gJy4uLy4uL2V2ZW50cyc7XG5pbXBvcnQgdHlwZSB7IFNlbGVjdFByb3BzIH0gZnJvbSAnLi4vLi4vaW5wdXQnO1xuaW1wb3J0IHR5cGUgeyBGaWVsZExheW91dFByb3BzLCBTZWxlY3RGaWVsZFByb3BzIH0gZnJvbSAnLi4vdHlwZXMnO1xuXG50eXBlIFVzZVNlbGVjdEZpZWxkU3RhdGUgPSB7XG4gICAgbGF5b3V0UHJvcHM6IE9taXQ8RmllbGRMYXlvdXRQcm9wcywgJ2lucHV0JyB8ICdjbGFzc05hbWUnIHwgJ2lucHV0SGFuZGxlJz47XG4gICAgaW5wdXRQcm9wczogU2VsZWN0UHJvcHM7XG59O1xuXG5leHBvcnQgY29uc3QgdXNlU2VsZWN0RmllbGQgPSAoXG4gICAgcHJvcHM6IFNlbGVjdEZpZWxkUHJvcHMgJiBPbWl0PFNlbGVjdFByb3BzLCAnaWQnPixcbik6IFVzZVNlbGVjdEZpZWxkU3RhdGUgPT4ge1xuICAgIGNvbnN0IHtcbiAgICAgICAgaWQsXG4gICAgICAgIHZhbHVlLFxuICAgICAgICBsYWJlbCxcbiAgICAgICAgaGlkZUxhYmVsLFxuICAgICAgICBwcmVzZXJ2ZVNwYWNlLFxuICAgICAgICByZXF1aXJlZCxcbiAgICAgICAgcmVxdWlyZWRMYWJlbCxcbiAgICAgICAgYWRkaXRpb25hbFRleHQsXG4gICAgICAgIGRpc2FibGVkLFxuICAgICAgICBoYXNFcnJvcixcbiAgICAgICAgZXJyb3JNZXNzYWdlLFxuICAgICAgICBpY29uLFxuICAgICAgICBvbkNsaWNrLFxuICAgICAgICBvbkZvY3VzLFxuICAgICAgICBvbkJsdXIsXG4gICAgICAgIG9uQ2hhbmdlLFxuICAgICAgICBpbnB1dERhdGFzZXQsXG4gICAgICAgIGRhdGFzZXQsXG4gICAgICAgIHBsYWNlaG9sZGVyLFxuICAgICAgICBkZWZhdWx0VmFsdWUsXG4gICAgICAgIC4uLnJlc3RcbiAgICB9ID0gcHJvcHM7XG5cbiAgICBjb25zdCBhY3R1YWxJZCA9IGlkIHx8IG1ha2VUaW55SWQoKTtcbiAgICBjb25zdCBbaXNGb2N1c2VkLCBzZXRJc0ZvY3VzZWRdID0gdXNlU3RhdGU8Ym9vbGVhbj4oZmFsc2UpO1xuICAgIGNvbnN0IFtpc1RvdWNoZWQsIHNldElzVG91Y2hlZF0gPSB1c2VTdGF0ZTxib29sZWFuPihmYWxzZSk7XG4gICAgY29uc3QgW2lzQ2hhbmdlZCwgc2V0SXNDaGFuZ2VkXSA9IHVzZVN0YXRlPGJvb2xlYW4+KGZhbHNlKTtcbiAgICBjb25zdCBbaGFzVmFsdWUsIHNldEhhc1ZhbHVlXSA9IHVzZVN0YXRlPGJvb2xlYW4+KCEhKHZhbHVlIHx8IGRlZmF1bHRWYWx1ZSkpO1xuXG4gICAgY29uc3QgaGFuZGxlRm9jdXM6IEZvY3VzRXZlbnRIYW5kbGVyID0gZXYgPT4ge1xuICAgICAgICBzZXRJc0ZvY3VzZWQodHJ1ZSk7XG4gICAgICAgIHNldElzVG91Y2hlZCh0cnVlKTtcbiAgICAgICAgb25Gb2N1cz8uKGV2KTtcbiAgICB9O1xuICAgIGNvbnN0IGhhbmRsZUJsdXI6IEZvY3VzRXZlbnRIYW5kbGVyID0gZXYgPT4ge1xuICAgICAgICBzZXRJc0ZvY3VzZWQoZmFsc2UpO1xuICAgICAgICBvbkJsdXI/Lihldik7XG4gICAgfTtcbiAgICBjb25zdCBoYW5kbGVDaGFuZ2UgPSAoZXY6IFJlYWN0LkNoYW5nZUV2ZW50PEhUTUxTZWxlY3RFbGVtZW50PikgPT4ge1xuICAgICAgICBzZXRJc0NoYW5nZWQodHJ1ZSk7XG4gICAgICAgIHNldEhhc1ZhbHVlKCEhZXYudGFyZ2V0LnZhbHVlKTtcbiAgICAgICAgb25DaGFuZ2U/Lihldik7XG4gICAgfTtcblxuICAgIGNvbnN0IGhhc0NvbnRyb2xsZWRWYWx1ZSA9ICEhdmFsdWU7XG4gICAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICAgICAgaWYgKGRlZmF1bHRWYWx1ZSkgcmV0dXJuO1xuXG4gICAgICAgIHNldEhhc1ZhbHVlKGhhc0NvbnRyb2xsZWRWYWx1ZSk7XG4gICAgfSwgW2hhc0NvbnRyb2xsZWRWYWx1ZV0pO1xuXG4gICAgY29uc3QgYWN0dWFsSGFzRXJyb3IgPSBoYXNFcnJvciB8fCAhIWVycm9yTWVzc2FnZTtcbiAgICBjb25zdCBhY3R1YWxBZGRpdGlvbmFsVGV4dCA9IGVycm9yTWVzc2FnZSB8fCBhZGRpdGlvbmFsVGV4dDtcbiAgICBjb25zdCBkZXNjcmliZUlkID0gYWN0dWFsSGFzRXJyb3IgfHwgISFhZGRpdGlvbmFsVGV4dCA/IG1ha2VEZXNjSWQoYWN0dWFsSWQpIDogdW5kZWZpbmVkO1xuXG4gICAgcmV0dXJuIHtcbiAgICAgICAgbGF5b3V0UHJvcHM6IHtcbiAgICAgICAgICAgIGlkOiBhY3R1YWxJZCxcbiAgICAgICAgICAgIGxhYmVsLFxuICAgICAgICAgICAgaGlkZUxhYmVsLFxuICAgICAgICAgICAgcmVxdWlyZWQsXG4gICAgICAgICAgICByZXF1aXJlZExhYmVsLFxuICAgICAgICAgICAgYWRkaXRpb25hbFRleHQ6IGFjdHVhbEFkZGl0aW9uYWxUZXh0LFxuICAgICAgICAgICAgcHJlc2VydmVTcGFjZSxcbiAgICAgICAgICAgIGRpc2FibGVkLFxuICAgICAgICAgICAgaXNGb2N1c2VkLFxuICAgICAgICAgICAgaXNUb3VjaGVkLFxuICAgICAgICAgICAgaXNDaGFuZ2VkLFxuICAgICAgICAgICAgaGFzVmFsdWUsXG4gICAgICAgICAgICBoYXNFcnJvcjogYWN0dWFsSGFzRXJyb3IsXG4gICAgICAgICAgICBvbkNsaWNrLFxuICAgICAgICAgICAgaWNvbixcbiAgICAgICAgICAgIGRhdGFzZXQsXG4gICAgICAgIH0sXG4gICAgICAgIGlucHV0UHJvcHM6IHtcbiAgICAgICAgICAgIGlkOiBhY3R1YWxJZCxcbiAgICAgICAgICAgIHZhbHVlLFxuICAgICAgICAgICAgb25DbGljayxcbiAgICAgICAgICAgIG9uQ2hhbmdlOiBoYW5kbGVDaGFuZ2UsXG4gICAgICAgICAgICBvbkZvY3VzOiBoYW5kbGVGb2N1cyxcbiAgICAgICAgICAgIG9uQmx1cjogaGFuZGxlQmx1cixcbiAgICAgICAgICAgIHJlcXVpcmVkLFxuICAgICAgICAgICAgZGlzYWJsZWQsXG4gICAgICAgICAgICBoYXNFcnJvcjogYWN0dWFsSGFzRXJyb3IsXG4gICAgICAgICAgICBkYXRhc2V0OiBpbnB1dERhdGFzZXQsXG4gICAgICAgICAgICAnYXJpYS1kZXNjcmliZWRieSc6IGRlc2NyaWJlSWQsXG4gICAgICAgICAgICBwbGFjZWhvbGRlcixcbiAgICAgICAgICAgIGRlZmF1bHRWYWx1ZSxcbiAgICAgICAgICAgIC4uLnJlc3QsXG4gICAgICAgIH0sXG4gICAgfTtcbn07XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7OztNQWFhLGNBQWMsR0FBRyxDQUMxQixLQUFpRDtJQUVqRCxNQUFNLEVBQ0YsRUFBRSxFQUNGLEtBQUssRUFDTCxLQUFLLEVBQ0wsU0FBUyxFQUNULGFBQWEsRUFDYixRQUFRLEVBQ1IsYUFBYSxFQUNiLGNBQWMsRUFDZCxRQUFRLEVBQ1IsUUFBUSxFQUNSLFlBQVksRUFDWixJQUFJLEVBQ0osT0FBTyxFQUNQLE9BQU8sRUFDUCxNQUFNLEVBQ04sUUFBUSxFQUNSLFlBQVksRUFDWixPQUFPLEVBQ1AsV0FBVyxFQUNYLFlBQVksRUFDWixHQUFHLElBQUksRUFDVixHQUFHLEtBQUssQ0FBQztJQUVWLE1BQU0sUUFBUSxHQUFHLEVBQUUsSUFBSSxVQUFVLEVBQUUsQ0FBQztJQUNwQyxNQUFNLENBQUMs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
|
package/dist/field/index.d.ts
CHANGED
package/dist/field/index.js
CHANGED
|
@@ -1,5 +1,7 @@
|
|
|
1
1
|
export { FIELD_ADDITIONAL_TEXT_VARIANT_DEFAULT, FIELD_TYPE_DEFAULT } from './constants.js';
|
|
2
2
|
export { usePasswordField } from './hooks/usePasswordField.js';
|
|
3
3
|
export { useTextField } from './hooks/useTextField.js';
|
|
4
|
+
export { useNumberField } from './hooks/useNumberField.js';
|
|
5
|
+
export { useSelectField } from './hooks/useSelectField.js';
|
|
4
6
|
export { ADDITIONAL_TEXT_VARIANT_OPTIONS } from './options.js';
|
|
5
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
7
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VzIjpbXSwic291cmNlc0NvbnRlbnQiOltdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OzsifQ==
|
package/dist/field/types.d.ts
CHANGED
|
@@ -3,7 +3,7 @@ import type { MouseEventHandler, ReactNode } from 'react';
|
|
|
3
3
|
import React from 'react';
|
|
4
4
|
import { IconProps } from '../icon/types';
|
|
5
5
|
import type { AutoCompletePasswordOptions, SimpleTextInputType, SingleLineInputType } from '../input/private/types';
|
|
6
|
-
import type { CombinableInputProps, InputPasswordProps, InputTextProps } from '../input/types';
|
|
6
|
+
import type { CombinableInputProps, InputNumberProps, InputPasswordProps, InputTextProps, SelectProps } from '../input/types';
|
|
7
7
|
import { ReactSVGComponentType } from '../svg/types';
|
|
8
8
|
export declare type FieldValue = string | number | boolean;
|
|
9
9
|
/**
|
|
@@ -87,3 +87,10 @@ export declare type PasswordFieldProps = FieldCommonProps & CombinableInputProps
|
|
|
87
87
|
showIcon?: boolean;
|
|
88
88
|
revealValue?: boolean;
|
|
89
89
|
};
|
|
90
|
+
export declare type NumberFieldProps = FieldCommonProps & CombinableInputProps<InputNumberProps> & {
|
|
91
|
+
icon?: React.ReactElement<IconProps>;
|
|
92
|
+
};
|
|
93
|
+
export declare type SelectFieldProps = FieldCommonProps & CombinableInputProps<SelectProps> & {
|
|
94
|
+
icon?: React.ReactElement<IconProps>;
|
|
95
|
+
children?: ReactNode | ReactNode[];
|
|
96
|
+
};
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/* AUTO GENERATED @
|
|
1
|
+
/* AUTO GENERATED @Wed May 03 2023 12:32:26 GMT+0000 (Coordinated Universal Time) */
|
|
2
2
|
|
|
3
3
|
@AVATAR_SIZE_OPTIONS: 2xs, xs, s, m, l, xl;
|
|
4
4
|
@BADGE_COLOR_OPTIONS: gray, teal, green, blue, yellow, red, magenta;
|
package/dist/index.js
CHANGED
|
@@ -13,6 +13,8 @@ export { useFocusEvents } from './events/hooks/useFocusEvents.js';
|
|
|
13
13
|
export { FIELD_ADDITIONAL_TEXT_VARIANT_DEFAULT, FIELD_TYPE_DEFAULT } from './field/constants.js';
|
|
14
14
|
export { usePasswordField } from './field/hooks/usePasswordField.js';
|
|
15
15
|
export { useTextField } from './field/hooks/useTextField.js';
|
|
16
|
+
export { useNumberField } from './field/hooks/useNumberField.js';
|
|
17
|
+
export { useSelectField } from './field/hooks/useSelectField.js';
|
|
16
18
|
export { ADDITIONAL_TEXT_VARIANT_OPTIONS } from './field/options.js';
|
|
17
19
|
export { AUTO_COMPLETE_DATE_DEFAULT, AUTO_COMPLETE_PASSWORD_DEFAULT, AUTO_COMPLETE_TEXT_DEFAULT, INPUT_TYPE_DEFAULT } from './input/constants.js';
|
|
18
20
|
export { AUTO_COMPLETE_DATE_OPTIONS, AUTO_COMPLETE_PASSWORD_OPTIONS, AUTO_COMPLETE_TEXT_OPTIONS, INPUT_TYPE_OPTIONS, INPUT_TYPE_SIMPLE_TEXT_OPTIONS } from './input/options.js';
|
|
@@ -52,4 +54,4 @@ export { useTextCenteredClassnames } from './typography/module-text-centered/hoo
|
|
|
52
54
|
export { useTextWeightClassNames } from './typography/module-text-weight/hooks/useTextWeightClassNames.js';
|
|
53
55
|
export { useVisualModeClassNames } from './visual-mode/module-visual/hooks/useVisualModeClassNames.js';
|
|
54
56
|
export { VisualModeContext } from './visual-mode/module-visual/providers/VisualModeContext.js';
|
|
55
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
57
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VzIjpbXSwic291cmNlc0NvbnRlbnQiOltdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OyJ9
|
|
@@ -91,6 +91,7 @@ export interface InputTypeTextareaProps extends InputStringProps {
|
|
|
91
91
|
}
|
|
92
92
|
export interface InputTypeSelectProps extends InputCommonProps {
|
|
93
93
|
type: 'select';
|
|
94
|
+
placeholder?: string;
|
|
94
95
|
children?: ReactNode;
|
|
95
96
|
}
|
|
96
97
|
export declare type InputGenericTextProps = InputTypeTextProps | InputTypeSearchProps | InputTypeEmailProps | InputTypeTelProps | InputTypeUrlProps;
|
|
@@ -35,15 +35,19 @@ const isSelect = (props) => {
|
|
|
35
35
|
};
|
|
36
36
|
const getTextProps = (props) => {
|
|
37
37
|
if (isText(props)) {
|
|
38
|
-
const { value, placeholder, maxLength, autoComplete } = props;
|
|
39
|
-
|
|
38
|
+
const { value, defaultValue, placeholder, maxLength, autoComplete } = props;
|
|
39
|
+
const forcedValue = defaultValue === undefined ? '' : undefined;
|
|
40
|
+
const actualValue = value !== undefined ? value : forcedValue;
|
|
41
|
+
return { value: actualValue, defaultValue, placeholder, maxLength, autoComplete };
|
|
40
42
|
}
|
|
41
43
|
return {};
|
|
42
44
|
};
|
|
43
45
|
const getDateTimeProps = (props) => {
|
|
44
46
|
if (isDateTime(props)) {
|
|
45
|
-
const { defaultValue, placeholder, maxLength, autoComplete } = props;
|
|
46
|
-
|
|
47
|
+
const { value, defaultValue, placeholder, maxLength, autoComplete } = props;
|
|
48
|
+
const forcedValue = defaultValue === undefined ? '' : undefined;
|
|
49
|
+
const actualValue = value !== undefined ? value : forcedValue;
|
|
50
|
+
return { value: actualValue, defaultValue, placeholder, maxLength, autoComplete };
|
|
47
51
|
}
|
|
48
52
|
return {};
|
|
49
53
|
};
|
|
@@ -77,11 +81,13 @@ const getRadioProps = (props) => {
|
|
|
77
81
|
};
|
|
78
82
|
const getSelectProps = (props) => {
|
|
79
83
|
if (isSelect(props)) {
|
|
80
|
-
const { value, children } = props;
|
|
81
|
-
|
|
84
|
+
const { value, defaultValue, children } = props;
|
|
85
|
+
const forcedValue = defaultValue === undefined ? '' : undefined;
|
|
86
|
+
const actualValue = value !== undefined ? value : forcedValue;
|
|
87
|
+
return { value: actualValue, defaultValue, children };
|
|
82
88
|
}
|
|
83
89
|
return {};
|
|
84
90
|
};
|
|
85
91
|
|
|
86
92
|
export { getBoundedProps, getCheckableProps, getDateTimeProps, getRadioProps, getSelectProps, getTextProps, getTextareaProps };
|
|
87
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9pbnB1dC9wcml2YXRlL3V0aWxzLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IElucHV0SFRNTEF0dHJpYnV0ZXMsIFNlbGVjdEhUTUxBdHRyaWJ1dGVzLCBUZXh0YXJlYUhUTUxBdHRyaWJ1dGVzIH0gZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgdHlwZSB7IElucHV0QmFzZVByb3BzIH0gZnJvbSAnLi4vdHlwZXMnO1xuXG5pbXBvcnQgdHlwZSB7XG4gICAgSW5wdXRCb3VuZGVkUHJvcHMsXG4gICAgSW5wdXRDaGVja2FibGVQcm9wcyxcbiAgICBJbnB1dENvbW1vblByb3BzLFxuICAgIElucHV0VHlwZVNlbGVjdFByb3BzLFxuICAgIElucHV0VHlwZVRleHRQcm9wcyxcbiAgICBJbnB1dFR5cGVUZXh0YXJlYVByb3BzLFxufSBmcm9tICcuL3R5cGVzJztcblxuY29uc3QgaXNUZXh0ID0gKHByb3BzOiBJbnB1dENvbW1vblByb3BzKTogcHJvcHMgaXMgSW5wdXRUeXBlVGV4dFByb3BzID0+IHtcbiAgICBjb25zdCB7IHR5cGUgfSA9IHByb3BzO1xuICAgIHJldHVybiAoXG4gICAgICAgIHR5cGUgPT09ICd0ZXh0JyB8fFxuICAgICAgICB0eXBlID09PSAnc2VhcmNoJyB8fFxuICAgICAgICB0eXBlID09PSAncGFzc3dvcmQnIHx8XG4gICAgICAgIHR5cGUgPT09ICdlbWFpbCcgfHxcbiAgICAgICAgdHlwZSA9PT0gJ3RlbCcgfHxcbiAgICAgICAgdHlwZSA9PT0gJ3VybCcgfHxcbiAgICAgICAgdHlwZSA9PT0gJ251bWJlcicgfHxcbiAgICAgICAgdHlwZSA9PT0gJ3RleHRhcmVhJ1xuICAgICk7XG59O1xuXG5jb25zdCBpc0RhdGVUaW1lID0gKHByb3BzOiBJbnB1dENvbW1vblByb3BzKTogcHJvcHMgaXMgSW5wdXRUeXBlVGV4dFByb3BzID0+IHtcbiAgICBjb25zdCB7IHR5cGUgfSA9IHByb3BzO1xuICAgIHJldHVybiB0eXBlID09PSAnZGF0ZScgfHwgdHlwZSA9PT0gJ3RpbWUnO1xufTtcblxuY29uc3QgaXNCb3VuZGVkID0gKHByb3BzOiBJbnB1dENvbW1vblByb3BzKTogcHJvcHMgaXMgSW5wdXRCb3VuZGVkUHJvcHMgPT4ge1xuICAgIGNvbnN0IHsgdHlwZSB9ID0gcHJvcHM7XG4gICAgcmV0dXJuIHR5cGUgPT09ICdudW1iZXInIHx8IHR5cGUgPT09ICdkYXRlJyB8fCB0eXBlID09PSAndGltZSc7XG59O1xuXG5jb25zdCBpc0NoZWNrYWJsZSA9IChwcm9wczogSW5wdXRDb21tb25Qcm9wcyk6IHByb3BzIGlzIElucHV0Q2hlY2thYmxlUHJvcHMgPT4ge1xuICAgIGNvbnN0IHsgdHlwZSB9ID0gcHJvcHM7XG4gICAgcmV0dXJuIHR5cGUgPT09ICdjaGVja2JveCc7XG59O1xuXG5jb25zdCBpc1JhZGlvID0gKHByb3BzOiBJbnB1dENvbW1vblByb3BzKTogcHJvcHMgaXMgSW5wdXRDaGVja2FibGVQcm9wcyA9PiB7XG4gICAgY29uc3QgeyB0eXBlIH0gPSBwcm9wcztcbiAgICByZXR1cm4gdHlwZSA9PT0gJ3JhZGlvJztcbn07XG5cbmNvbnN0IGlzVGV4dGFyZWEgPSAocHJvcHM6IElucHV0Q29tbW9uUHJvcHMpOiBwcm9wcyBpcyBJbnB1dFR5cGVUZXh0YXJlYVByb3BzID0+
|
|
93
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"utils.js","sources":["../../../src/input/private/utils.ts"],"sourcesContent":["import { InputHTMLAttributes, SelectHTMLAttributes, TextareaHTMLAttributes } from 'react';\n\nimport type { InputBaseProps } from '../types';\n\nimport type {\n    InputBoundedProps,\n    InputCheckableProps,\n    InputCommonProps,\n    InputTypeSelectProps,\n    InputTypeTextProps,\n    InputTypeTextareaProps,\n} from './types';\n\nconst isText = (props: InputCommonProps): props is InputTypeTextProps => {\n    const { type } = props;\n    return (\n        type === 'text' ||\n        type === 'search' ||\n        type === 'password' ||\n        type === 'email' ||\n        type === 'tel' ||\n        type === 'url' ||\n        type === 'number' ||\n        type === 'textarea'\n    );\n};\n\nconst isDateTime = (props: InputCommonProps): props is InputTypeTextProps => {\n    const { type } = props;\n    return type === 'date' || type === 'time';\n};\n\nconst isBounded = (props: InputCommonProps): props is InputBoundedProps => {\n    const { type } = props;\n    return type === 'number' || type === 'date' || type === 'time';\n};\n\nconst isCheckable = (props: InputCommonProps): props is InputCheckableProps => {\n    const { type } = props;\n    return type === 'checkbox';\n};\n\nconst isRadio = (props: InputCommonProps): props is InputCheckableProps => {\n    const { type } = props;\n    return type === 'radio';\n};\n\nconst isTextarea = (props: InputCommonProps): props is InputTypeTextareaProps => {\n    const { type } = props;\n    return type === 'number' || type === 'date' || type === 'time';\n};\n\nconst isSelect = (props: InputCommonProps): props is InputTypeSelectProps => {\n    const { type } = props;\n    return type === 'select';\n};\n\nexport const getTextProps = (props: InputBaseProps): InputHTMLAttributes<HTMLInputElement> => {\n    if (isText(props)) {\n        const { value, defaultValue, placeholder, maxLength, autoComplete } = props;\n        const forcedValue = defaultValue === undefined ? '' : undefined;\n        const actualValue = value !== undefined ? value : forcedValue;\n        return { value: actualValue, defaultValue, placeholder, maxLength, autoComplete };\n    }\n    return {};\n};\n\nexport const getDateTimeProps = (props: InputBaseProps): InputHTMLAttributes<HTMLInputElement> => {\n    if (isDateTime(props)) {\n        const { value, defaultValue, placeholder, maxLength, autoComplete } = props;\n        const forcedValue = defaultValue === undefined ? '' : undefined;\n        const actualValue = value !== undefined ? value : forcedValue;\n        return { value: actualValue, defaultValue, placeholder, maxLength, autoComplete };\n    }\n    return {};\n};\n\nexport const getBoundedProps = (props: InputBaseProps): InputHTMLAttributes<HTMLInputElement> => {\n    if (isBounded(props)) {\n        const { min, max } = props;\n        return { min, max };\n    }\n    return {};\n};\n\nexport const getTextareaProps = (\n    props: InputBaseProps,\n): TextareaHTMLAttributes<HTMLTextAreaElement> => {\n    if (isTextarea(props)) {\n        const { rows } = props;\n        return { rows };\n    }\n    return {};\n};\n\nexport const getCheckableProps = (props: InputBaseProps): InputHTMLAttributes<HTMLInputElement> => {\n    if (isCheckable(props)) {\n        const { checked } = props;\n        return { checked };\n    }\n    return {};\n};\n\nexport const getRadioProps = (props: InputBaseProps): InputHTMLAttributes<HTMLInputElement> => {\n    if (isRadio(props)) {\n        const { checked, name } = props;\n        return { defaultChecked: checked, name };\n    }\n    return {};\n};\n\nexport const getSelectProps = (props: InputBaseProps): SelectHTMLAttributes<HTMLSelectElement> => {\n    if (isSelect(props)) {\n        const { value, defaultValue, children } = props;\n        const forcedValue = defaultValue === undefined ? '' : undefined;\n        const actualValue = value !== undefined ? value : forcedValue;\n        return { value: actualValue, defaultValue, children };\n    }\n    return {};\n};\n"],"names":[],"mappings":"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"}
|
package/dist/input/types.d.ts
CHANGED
|
@@ -34,10 +34,11 @@ export declare type InputDateProps = Omit<InputTypeDateProps, 'type' | 'value' |
|
|
|
34
34
|
defaultValue?: Date;
|
|
35
35
|
onValueChange?: ValueChangeEventHandler<Date>;
|
|
36
36
|
};
|
|
37
|
-
export declare type InputNumberProps = Omit<InputTypeNumberProps, 'type' | 'value' | 'min' | 'max'> & {
|
|
37
|
+
export declare type InputNumberProps = Omit<InputTypeNumberProps, 'type' | 'value' | 'defaultValue' | 'min' | 'max'> & {
|
|
38
38
|
value?: number;
|
|
39
39
|
min?: number;
|
|
40
40
|
max?: number;
|
|
41
|
+
defaultValue?: number;
|
|
41
42
|
onValueChange?: ValueChangeEventHandler<number>;
|
|
42
43
|
};
|
|
43
44
|
export declare type InputPasswordProps = Omit<InputTypePasswordProps, 'type'> & {
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@preply/ds-web-core",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.58.0",
|
|
4
4
|
"publishConfig": {
|
|
5
5
|
"access": "public"
|
|
6
6
|
},
|
|
@@ -19,14 +19,14 @@
|
|
|
19
19
|
"dev": "run build:rollup -w"
|
|
20
20
|
},
|
|
21
21
|
"dependencies": {
|
|
22
|
-
"@preply/ds-core": "0.
|
|
23
|
-
"@preply/ds-core-types": "0.
|
|
22
|
+
"@preply/ds-core": "0.58.0",
|
|
23
|
+
"@preply/ds-core-types": "0.58.0"
|
|
24
24
|
},
|
|
25
25
|
"peerDependencies": {
|
|
26
|
-
"@preply/ds-core": "0.
|
|
27
|
-
"@preply/ds-core-types": "0.
|
|
26
|
+
"@preply/ds-core": "0.58.0",
|
|
27
|
+
"@preply/ds-core-types": "0.58.0",
|
|
28
28
|
"react": "^16.8.3",
|
|
29
29
|
"react-dom": "^16.8.3"
|
|
30
30
|
},
|
|
31
|
-
"gitHead": "
|
|
31
|
+
"gitHead": "35113324a4808a63eb480e92621dffc5f37ee966"
|
|
32
32
|
}
|