indicator-ui 1.1.0 → 1.1.2
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/index.cjs +16 -16
- package/dist/index.js +9028 -8699
- package/dist/indicator-ui.css +1 -1
- package/dist/types/src/hooks/forms/useForm.d.ts +1 -1
- package/dist/types/src/types/mixins.d.ts +1 -1
- package/dist/types/src/ui/InputFields/DateTimeField/ui/TimeField.d.ts +1 -1
- package/dist/types/src/ui/datePickersV2/hooks/dateManagers/index.d.ts +1 -0
- package/dist/types/src/ui/datePickersV2/hooks/dateManagers/useTimeManager.d.ts +14 -0
- package/dist/types/src/ui/datePickersV2/hooks/pickers/time/index.d.ts +1 -0
- package/dist/types/src/ui/datePickersV2/hooks/pickers/time/useTimePickerV2Provider.d.ts +31 -0
- package/dist/types/src/ui/datePickersV2/ui/pickers/TimePickerV2.d.ts +4 -0
- package/dist/types/src/ui/datePickersV2/ui/pickers/index.d.ts +1 -0
- package/dist/types/src/ui/formFields/dates/FormDateField/hooks/useDatePickerController.d.ts +4 -3
- package/dist/types/src/ui/formFields/dates/FormDateField/hooks/useFormDateFieldProvider.d.ts +1 -0
- package/dist/types/src/ui/formFields/dates/FormDateField/hooks/useSyncDateValues.d.ts +2 -1
- package/dist/types/src/ui/formFields/dates/FormDateRangeField/hooks/useDateTimePickerController.d.ts +3 -1
- package/dist/types/src/ui/formFields/dates/FormDateRangeField/hooks/useFormDateRangeFieldProvider.d.ts +1 -0
- package/dist/types/src/ui/formFields/dates/FormDateRangeField/hooks/useSyncDateTimeValues.d.ts +2 -1
- package/dist/types/src/ui/formFields/dates/FormDateTimeField/hooks/useDateTimePickerController.d.ts +3 -1
- package/dist/types/src/ui/formFields/dates/FormDateTimeField/hooks/useFormDateTimeFieldProvider.d.ts +1 -0
- package/dist/types/src/ui/formFields/dates/FormDateTimeField/hooks/useSyncDateTimeValues.d.ts +2 -1
- package/dist/types/src/ui/formFields/dates/FormTimeField/hooks/index.d.ts +1 -0
- package/dist/types/src/ui/formFields/dates/FormTimeField/hooks/useFormTimeFieldProvider.d.ts +109 -0
- package/dist/types/src/ui/formFields/dates/FormTimeField/hooks/useInputFieldController.d.ts +4 -0
- package/dist/types/src/ui/formFields/dates/FormTimeField/hooks/useInputFieldProps.d.ts +63 -0
- package/dist/types/src/ui/formFields/dates/FormTimeField/hooks/useSyncTimeValues.d.ts +7 -0
- package/dist/types/src/ui/formFields/dates/FormTimeField/hooks/useTimeDraft.d.ts +13 -0
- package/dist/types/src/ui/formFields/dates/FormTimeField/hooks/useTimeFormats.d.ts +14 -0
- package/dist/types/src/ui/formFields/dates/FormTimeField/hooks/useTimePickerController.d.ts +33 -0
- package/dist/types/src/ui/formFields/dates/FormTimeField/hooks/useTimePickerProps.d.ts +10 -0
- package/dist/types/src/ui/formFields/dates/FormTimeField/index.d.ts +1 -0
- package/dist/types/src/ui/formFields/dates/FormTimeField/ui/FormTimeField.d.ts +6 -0
- package/dist/types/src/ui/formFields/dates/FormTimeField/ui/FormTimeFieldBase.d.ts +4 -0
- package/dist/types/src/ui/formFields/dates/FormTimeField/ui/index.d.ts +2 -0
- package/dist/types/src/ui/formFields/dates/index.d.ts +1 -0
- package/package.json +7 -7
|
@@ -236,7 +236,7 @@ export declare function useForm<Form, T extends Nullable<Undefinable<Form>> = Nu
|
|
|
236
236
|
(): FieldPropsType<FormValue<T, "">, "update">;
|
|
237
237
|
<P extends FormPath<T>>(path: P, config?: FormSchemeType<T>[P]): FieldPropsType<FormValue<T, P>, "update">;
|
|
238
238
|
};
|
|
239
|
-
registerForm: (refsInstance?: FormInstance) => Pick<React.
|
|
239
|
+
registerForm: (refsInstance?: FormInstance) => Pick<React.DetailedHTMLProps<React.FormHTMLAttributes<HTMLFormElement>, HTMLFormElement>, "ref" | "onReset" | "onSubmit" | "noValidate"> & Pick<InstanceRefAttributes<HTMLFormElement>, "instanceRef">;
|
|
240
240
|
getValidForm: () => Promise<Form | null>;
|
|
241
241
|
submitForm: () => void;
|
|
242
242
|
resetForm: () => void;
|
|
@@ -28,7 +28,7 @@ export type AsProps<T extends ElementType, P extends ComponentAttributes = {}, I
|
|
|
28
28
|
} & (IR extends never ? {} : InstanceRefAttributes<IR>) & P>;
|
|
29
29
|
export type ComponentPropsWithoutInstanceRef<T extends ElementType> = Omit<React.ComponentProps<T>, keyof InstanceRefAttributes<T>>;
|
|
30
30
|
export type InstanceRefAttributes<T> = {
|
|
31
|
-
instanceRef?: React.
|
|
31
|
+
instanceRef?: React.Ref<T>;
|
|
32
32
|
};
|
|
33
33
|
export type ComponentInstanceRef<T extends ElementType> = React.ComponentProps<T> extends InstanceRefAttributes<infer Method> ? Method : never;
|
|
34
34
|
export type AcceptsComponentProps<T extends ElementType, P extends ComponentAttributes> = React.ComponentPropsWithoutRef<T> extends P ? T : never;
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
import { TimeFieldPropsType } from '../../..';
|
|
2
|
-
export declare function TimeField({ value, onChange, timeFormat, outFormat,
|
|
2
|
+
export declare function TimeField({ value, onChange, timeFormat, outFormat, timePlaceholder, iconTime, textTime, isError, disabled, onBlur, }: TimeFieldPropsType): import("react/jsx-runtime").JSX.Element;
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
type CommitedDate = string | undefined;
|
|
2
|
+
export declare function useTimeManager(): {
|
|
3
|
+
setInput: <K extends "hours" | "minutes">(key: K, instance: Partial<Partial<{
|
|
4
|
+
hours: number;
|
|
5
|
+
minutes: number;
|
|
6
|
+
}>>[K]) => void;
|
|
7
|
+
clearDateInput: () => void;
|
|
8
|
+
initViewHours: number | undefined;
|
|
9
|
+
initViewMinutes: number | undefined;
|
|
10
|
+
createCommitTime: (prev: CommitedDate) => NonNullable<CommitedDate>;
|
|
11
|
+
createCommitTimeWithoutClearing: (prev: CommitedDate) => NonNullable<CommitedDate>;
|
|
12
|
+
getPreviewTime: (instance: CommitedDate) => string | undefined;
|
|
13
|
+
};
|
|
14
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './useTimePickerV2Provider';
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { default as React } from 'react';
|
|
2
|
+
import { ComponentInstanceRef, InstanceRefAttributes } from '../../../../../types';
|
|
3
|
+
import { Footer, Header, Wrapper } from '../../../ui/pickers/components';
|
|
4
|
+
import { TimeFeed } from '../../../ui/feeds/time';
|
|
5
|
+
import { useTimeManager } from '../../dateManagers';
|
|
6
|
+
type WrapperRef = ComponentInstanceRef<typeof Wrapper>;
|
|
7
|
+
type TimeFeedRef = ComponentInstanceRef<typeof TimeFeed>;
|
|
8
|
+
type TimeValue = string;
|
|
9
|
+
type RefType = Pick<ReturnType<typeof useTimeManager>, 'createCommitTimeWithoutClearing' | 'createCommitTime' | 'clearDateInput' | 'setInput'> & {
|
|
10
|
+
timeFeedRef: React.RefObject<TimeFeedRef>;
|
|
11
|
+
};
|
|
12
|
+
type PropsType = Pick<React.ComponentProps<typeof Wrapper>, 'style'> & Pick<React.ComponentProps<typeof Header>, 'title' | 'subtitle'> & Pick<React.ComponentProps<typeof Footer>, 'isShowFooter' | 'onClose'> & InstanceRefAttributes<RefType> & {
|
|
13
|
+
wrapperRef?: React.RefObject<WrapperRef>;
|
|
14
|
+
time?: TimeValue;
|
|
15
|
+
onSubmitTime?: (dateTime: TimeValue) => void;
|
|
16
|
+
};
|
|
17
|
+
export declare function useTimePickerV2Provider(props: PropsType): {
|
|
18
|
+
time: string | undefined;
|
|
19
|
+
onChangeHours: (instance: number) => void;
|
|
20
|
+
onChangeMinutes: (instance: number) => void;
|
|
21
|
+
onChooseTime: (instance: string) => void;
|
|
22
|
+
onSubmit: () => void;
|
|
23
|
+
viewHoursValue: number | undefined;
|
|
24
|
+
viewMinutesValue: number | undefined;
|
|
25
|
+
timeFeedRef: React.RefObject<{
|
|
26
|
+
scrollToHour: (item: import('../../feeds/time/feed/utils').ElementItem, behavior?: ScrollBehavior) => Promise<void>;
|
|
27
|
+
scrollToMinute: (item: import('../../feeds/time/feed/utils').ElementItem, behavior?: ScrollBehavior) => Promise<void>;
|
|
28
|
+
}>;
|
|
29
|
+
previewTime: string | undefined;
|
|
30
|
+
};
|
|
31
|
+
export {};
|
|
@@ -2,7 +2,9 @@ import { default as React } from 'react';
|
|
|
2
2
|
import { InputDateValue } from './useDateDraft';
|
|
3
3
|
import { useInputFieldController } from './useInputFieldController';
|
|
4
4
|
import { useDateFormats } from './useDateFormats';
|
|
5
|
-
type PropsType = Pick<ReturnType<typeof useDateFormats>, 'parseDateInput'> & Pick<ReturnType<typeof useInputFieldController>, 'doubleInputRef'
|
|
5
|
+
type PropsType = Pick<ReturnType<typeof useDateFormats>, 'parseDateInput'> & Pick<ReturnType<typeof useInputFieldController>, 'doubleInputRef'> & {
|
|
6
|
+
disablePicker?: boolean;
|
|
7
|
+
};
|
|
6
8
|
export declare function useDatePickerController(props: PropsType): {
|
|
7
9
|
datePickerRef: React.RefObject<Pick<{
|
|
8
10
|
dateInput: Partial<Partial<Partial<{
|
|
@@ -39,9 +41,8 @@ export declare function useDatePickerController(props: PropsType): {
|
|
|
39
41
|
datePickerWrapperRef: React.RefObject<never>;
|
|
40
42
|
moveToInputtedDateInPicker: (instance: InputDateValue) => Promise<(void | undefined)[]>;
|
|
41
43
|
clearDateInputInPicker: () => void;
|
|
42
|
-
closePicker: () => void;
|
|
43
|
-
openPicker: () => void;
|
|
44
44
|
switchingPicker: () => void;
|
|
45
|
+
closePicker: () => void;
|
|
45
46
|
getPickerInitStyle: () => React.CSSProperties;
|
|
46
47
|
};
|
|
47
48
|
export {};
|
package/dist/types/src/ui/formFields/dates/FormDateField/hooks/useFormDateFieldProvider.d.ts
CHANGED
|
@@ -25,6 +25,7 @@ type PropsType = FieldProps & Pick<DatePickerV2Props, 'requestDaysData' | 'reque
|
|
|
25
25
|
datePlaceholder?: DoubleInputItemProps['placeholder'];
|
|
26
26
|
disabled?: DoubleInputItemProps['disabled'];
|
|
27
27
|
pickerSubtitle?: DatePickerV2Props['subtitle'];
|
|
28
|
+
disablePicker?: boolean;
|
|
28
29
|
};
|
|
29
30
|
export declare function useFormDateFieldProvider(props: PropsType): {
|
|
30
31
|
dateInputValue: string | undefined;
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { useDateDraft } from './useDateDraft';
|
|
2
2
|
import { useDateFormats } from './useDateFormats';
|
|
3
3
|
import { useFormDateFieldProvider } from './useFormDateFieldProvider';
|
|
4
|
-
|
|
4
|
+
import { useDatePickerController } from './useDatePickerController';
|
|
5
|
+
type PropsType = Pick<Parameters<typeof useFormDateFieldProvider>[number], 'onChange' | 'value'> & Pick<ReturnType<typeof useDateDraft>, 'setDateInputValue' | 'dateInputValue'> & Pick<ReturnType<typeof useDateFormats>, 'formatDateInputToValue' | 'formatValueToDateInput'> & Pick<ReturnType<typeof useDatePickerController>, 'moveToInputtedDateInPicker'>;
|
|
5
6
|
export declare function useSyncDateValues(props: PropsType): void;
|
|
6
7
|
export {};
|
package/dist/types/src/ui/formFields/dates/FormDateRangeField/hooks/useDateTimePickerController.d.ts
CHANGED
|
@@ -2,7 +2,9 @@ import { default as React } from 'react';
|
|
|
2
2
|
import { InputDateValue } from './useDateRangeDraft';
|
|
3
3
|
import { useInputFieldController } from './useInputFieldController';
|
|
4
4
|
import { useDateRangeFormats } from './useDateRangeFormats';
|
|
5
|
-
type PropsType = Pick<ReturnType<typeof useDateRangeFormats>, 'parseInputDate'> & Pick<ReturnType<typeof useInputFieldController>, 'doubleInputRef'
|
|
5
|
+
type PropsType = Pick<ReturnType<typeof useDateRangeFormats>, 'parseInputDate'> & Pick<ReturnType<typeof useInputFieldController>, 'doubleInputRef'> & {
|
|
6
|
+
disablePicker?: boolean;
|
|
7
|
+
};
|
|
6
8
|
export declare function useDateTimePickerController(props: PropsType): {
|
|
7
9
|
dateTimePickerRef: React.RefObject<Pick<{
|
|
8
10
|
setInput: <K extends "year" | "monthYear" | "dayMonthYear">(key: K, instance: Partial<Partial<{
|
|
@@ -29,6 +29,7 @@ type PropsType = FieldProps & Pick<DateRangePickerV2Props, 'requestedDaysData' |
|
|
|
29
29
|
toIcon?: DoubleInputItemProps['icon'];
|
|
30
30
|
disabled?: DoubleInputItemProps['disabled'];
|
|
31
31
|
pickerSubtitle?: DateRangePickerV2Props['subtitle'];
|
|
32
|
+
disablePicker?: boolean;
|
|
32
33
|
};
|
|
33
34
|
export declare function useFormDateRangeFieldProvider(props: PropsType): {
|
|
34
35
|
fromDateValue: string | undefined;
|
package/dist/types/src/ui/formFields/dates/FormDateRangeField/hooks/useSyncDateTimeValues.d.ts
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { useDateRangeDraft } from './useDateRangeDraft';
|
|
2
2
|
import { useDateRangeFormats } from './useDateRangeFormats';
|
|
3
3
|
import { useFormDateRangeFieldProvider } from './useFormDateRangeFieldProvider';
|
|
4
|
-
|
|
4
|
+
import { useDateTimePickerController } from './useDateTimePickerController';
|
|
5
|
+
type PropsType = Pick<Parameters<typeof useFormDateRangeFieldProvider>[number], 'onChange' | 'value'> & Pick<ReturnType<typeof useDateRangeDraft>, 'setFromDateValue' | 'setToDateValue' | 'fromDateValue' | 'toDateValue'> & Pick<ReturnType<typeof useDateRangeFormats>, 'formatDateInputToValue' | 'formatValueItemToDateInput'> & Pick<ReturnType<typeof useDateTimePickerController>, 'moveToInputtedDateInPicker'>;
|
|
5
6
|
export declare function useSyncDateTimeValues(props: PropsType): void;
|
|
6
7
|
export {};
|
package/dist/types/src/ui/formFields/dates/FormDateTimeField/hooks/useDateTimePickerController.d.ts
CHANGED
|
@@ -2,7 +2,9 @@ import { default as React } from 'react';
|
|
|
2
2
|
import { DateValue, TimeValue } from './useDateTimeDraft';
|
|
3
3
|
import { useInputFieldController } from './useInputFieldController';
|
|
4
4
|
import { useDateTimeFormats } from './useDateTimeFormats';
|
|
5
|
-
type PropsType = Pick<ReturnType<typeof useDateTimeFormats>, 'parseTimeInput' | 'parseDateInput'> & Pick<ReturnType<typeof useInputFieldController>, 'doubleInputRef'
|
|
5
|
+
type PropsType = Pick<ReturnType<typeof useDateTimeFormats>, 'parseTimeInput' | 'parseDateInput'> & Pick<ReturnType<typeof useInputFieldController>, 'doubleInputRef'> & {
|
|
6
|
+
disablePicker?: boolean;
|
|
7
|
+
};
|
|
6
8
|
export declare function useDateTimePickerController(props: PropsType): {
|
|
7
9
|
dateTimePickerRef: React.RefObject<Pick<{
|
|
8
10
|
pickerState: "time" | "date-main";
|
package/dist/types/src/ui/formFields/dates/FormDateTimeField/hooks/useFormDateTimeFieldProvider.d.ts
CHANGED
|
@@ -35,6 +35,7 @@ type PropsType = FieldProps & Pick<DateTimePickerV2Props, 'requestDaysData' | 'r
|
|
|
35
35
|
timeIcon?: DoubleInputItemProps['icon'];
|
|
36
36
|
disabled?: DoubleInputItemProps['disabled'];
|
|
37
37
|
pickerSubtitle?: DateTimePickerV2Props['subtitle'];
|
|
38
|
+
disablePicker?: boolean;
|
|
38
39
|
};
|
|
39
40
|
export declare function useFormDateTimeFieldProvider(props: PropsType): {
|
|
40
41
|
dateValue: string | undefined;
|
package/dist/types/src/ui/formFields/dates/FormDateTimeField/hooks/useSyncDateTimeValues.d.ts
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { useDateTimeDraft } from './useDateTimeDraft';
|
|
2
2
|
import { useDateTimeFormats } from './useDateTimeFormats';
|
|
3
3
|
import { useFormDateTimeFieldProvider } from './useFormDateTimeFieldProvider';
|
|
4
|
-
|
|
4
|
+
import { useDateTimePickerController } from './useDateTimePickerController';
|
|
5
|
+
type PropsType = Pick<Parameters<typeof useFormDateTimeFieldProvider>[number], 'onChange' | 'value'> & Pick<ReturnType<typeof useDateTimeDraft>, 'setDateInputValue' | 'setTimeInputValue' | 'timeInputValue' | 'dateInputValue'> & Pick<ReturnType<typeof useDateTimeFormats>, 'formatDateTimeInputToValue' | 'formatValueToDateInput' | 'formatValueToTimeInput'> & Pick<ReturnType<typeof useDateTimePickerController>, 'moveToInputtedDateInPicker' | 'moveToInputtedTimeInPicker'>;
|
|
5
6
|
export declare function useSyncDateTimeValues(props: PropsType): void;
|
|
6
7
|
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './useFormTimeFieldProvider';
|
|
@@ -0,0 +1,109 @@
|
|
|
1
|
+
import { default as React } from 'react';
|
|
2
|
+
import { FieldPropsType } from '../../../../../hooks';
|
|
3
|
+
import { TimePickerV2 } from '../../../..';
|
|
4
|
+
import { DoubleInputItemProps } from './useInputFieldProps';
|
|
5
|
+
type TimePickerV2Props = React.ComponentProps<typeof TimePickerV2>;
|
|
6
|
+
type ValueBaseType = string;
|
|
7
|
+
type FieldProps = FieldPropsType<ValueBaseType>;
|
|
8
|
+
export type ValueType = FieldProps['value'];
|
|
9
|
+
type PropsType = FieldProps & {
|
|
10
|
+
/**
|
|
11
|
+
* Формат даты ввода пользователя.
|
|
12
|
+
*
|
|
13
|
+
* ---
|
|
14
|
+
* Для ознакомления с обозначениями {@link DATE_IMASK_BLOCKS}
|
|
15
|
+
* */
|
|
16
|
+
inputTimeFormat?: string;
|
|
17
|
+
/**
|
|
18
|
+
* Формат даты (понимаемый `date-fns`), которая будет хранится в `value`.
|
|
19
|
+
*
|
|
20
|
+
* Пример: `"HH:mm:ssXXX"`.
|
|
21
|
+
* */
|
|
22
|
+
outFormat?: string | 'iso';
|
|
23
|
+
timePlaceholder?: DoubleInputItemProps['placeholder'];
|
|
24
|
+
timeHintText?: DoubleInputItemProps['hintText'];
|
|
25
|
+
timeIcon?: DoubleInputItemProps['icon'];
|
|
26
|
+
disabled?: DoubleInputItemProps['disabled'];
|
|
27
|
+
pickerSubtitle?: TimePickerV2Props['subtitle'];
|
|
28
|
+
disablePicker?: boolean;
|
|
29
|
+
};
|
|
30
|
+
export declare function useFormTimeFieldProvider(props: PropsType): {
|
|
31
|
+
timeInputValue: string | undefined;
|
|
32
|
+
onCompleteTime: NonNullable<((value: string, maskRef: import('imask').InputMask<{
|
|
33
|
+
[x: string]: unknown;
|
|
34
|
+
}>, e?: InputEvent) => void) | ((value: string, maskRef: import('imask').InputMask<{
|
|
35
|
+
[x: string]: unknown;
|
|
36
|
+
}>, e?: InputEvent) => void) | ((value: string, maskRef: import('imask').InputMask<{
|
|
37
|
+
[x: string]: unknown;
|
|
38
|
+
}>, e?: InputEvent) => void) | ((value: string, maskRef: import('imask').InputMask<{
|
|
39
|
+
[x: string]: unknown;
|
|
40
|
+
}>, e?: InputEvent) => void) | ((value: string, maskRef: import('imask').InputMask<{
|
|
41
|
+
[x: string]: unknown;
|
|
42
|
+
}>, e?: InputEvent) => void) | ((value: string, maskRef: import('imask').InputMask<{
|
|
43
|
+
[x: string]: unknown;
|
|
44
|
+
}>, e?: InputEvent) => void) | ((value: string, maskRef: import('imask').InputMask<{
|
|
45
|
+
[x: string]: unknown;
|
|
46
|
+
}>, e?: InputEvent) => void) | ((value: string, maskRef: import('imask').InputMask<{
|
|
47
|
+
[x: string]: unknown;
|
|
48
|
+
}>, e?: InputEvent) => void) | ((value: string, maskRef: import('imask').InputMask<{
|
|
49
|
+
[x: string]: unknown;
|
|
50
|
+
}>, e?: InputEvent) => void) | ((value: string, maskRef: import('imask').InputMask<{
|
|
51
|
+
[x: string]: unknown;
|
|
52
|
+
}>, e?: InputEvent) => void) | ((value: string, maskRef: import('imask').InputMask<{
|
|
53
|
+
[x: string]: unknown;
|
|
54
|
+
}>, e?: InputEvent) => void) | ((value: string, maskRef: import('imask').InputMask<{
|
|
55
|
+
[x: string]: unknown;
|
|
56
|
+
}>, e?: InputEvent) => void) | ((value: string, maskRef: import('imask').InputMask<{
|
|
57
|
+
[x: string]: unknown;
|
|
58
|
+
}>, e?: InputEvent) => void) | ((value: string, maskRef: import('imask').InputMask<{
|
|
59
|
+
[x: string]: unknown;
|
|
60
|
+
}>, e?: InputEvent) => void) | ((value: string, maskRef: import('imask').InputMask<{
|
|
61
|
+
[x: string]: unknown;
|
|
62
|
+
}>, e?: InputEvent) => void) | ((value: string, maskRef: import('imask').InputMask<{
|
|
63
|
+
[x: string]: unknown;
|
|
64
|
+
}>, e?: InputEvent) => void) | ((value: string, maskRef: import('imask').InputMask<{
|
|
65
|
+
[x: string]: unknown;
|
|
66
|
+
}>, e?: InputEvent) => void) | ((value: string, maskRef: import('imask').InputMask<{
|
|
67
|
+
[x: string]: unknown;
|
|
68
|
+
}>, e?: InputEvent) => void) | ((value: string, maskRef: import('imask').InputMask<{
|
|
69
|
+
[x: string]: unknown;
|
|
70
|
+
}>, e?: InputEvent) => void) | ((value: string, maskRef: import('imask').InputMask<{
|
|
71
|
+
[x: string]: unknown;
|
|
72
|
+
}>, e?: InputEvent) => void) | ((value: string, maskRef: import('imask').InputMask<{
|
|
73
|
+
[x: string]: unknown;
|
|
74
|
+
}>, e?: InputEvent) => void) | ((value: string, maskRef: import('imask').InputMask<{
|
|
75
|
+
[x: string]: unknown;
|
|
76
|
+
}>, e?: InputEvent) => void) | ((value: string, maskRef: import('imask').InputMask<{
|
|
77
|
+
[x: string]: unknown;
|
|
78
|
+
}>, e?: InputEvent) => void) | ((value: string, maskRef: import('imask').InputMask<{
|
|
79
|
+
[x: string]: unknown;
|
|
80
|
+
}>, e?: InputEvent) => void) | undefined>;
|
|
81
|
+
timePickerRef: React.RefObject<Pick<{
|
|
82
|
+
setInput: <K extends "hours" | "minutes">(key: K, instance: Partial<Partial<{
|
|
83
|
+
hours: number;
|
|
84
|
+
minutes: number;
|
|
85
|
+
}>>[K]) => void;
|
|
86
|
+
clearDateInput: () => void;
|
|
87
|
+
initViewHours: number | undefined;
|
|
88
|
+
initViewMinutes: number | undefined;
|
|
89
|
+
createCommitTime: (prev: string | undefined) => NonNullable<string | undefined>;
|
|
90
|
+
createCommitTimeWithoutClearing: (prev: string | undefined) => NonNullable<string | undefined>;
|
|
91
|
+
getPreviewTime: (instance: string | undefined) => string | undefined;
|
|
92
|
+
}, "clearDateInput" | "setInput" | "createCommitTimeWithoutClearing" | "createCommitTime"> & {
|
|
93
|
+
timeFeedRef: React.RefObject<{
|
|
94
|
+
scrollToHour: (item: import('../../../../datePickersV2/hooks/feeds/time/feed/utils').ElementItem, behavior?: ScrollBehavior) => Promise<void>;
|
|
95
|
+
scrollToMinute: (item: import('../../../../datePickersV2/hooks/feeds/time/feed/utils').ElementItem, behavior?: ScrollBehavior) => Promise<void>;
|
|
96
|
+
}>;
|
|
97
|
+
}>;
|
|
98
|
+
timePickerWrapperRef: React.RefObject<never>;
|
|
99
|
+
doubleInputRef: React.RefObject<HTMLDivElement>;
|
|
100
|
+
inputTimeFormat: string;
|
|
101
|
+
time: string | undefined;
|
|
102
|
+
onSubmitTime: (dateTime: string) => void;
|
|
103
|
+
onClickTimeField: React.MouseEventHandler<HTMLInputElement>;
|
|
104
|
+
clearTime: () => void;
|
|
105
|
+
isErrorInputFields: boolean | undefined;
|
|
106
|
+
isDisabledInputFields: boolean | undefined;
|
|
107
|
+
getPickerInitStyle: () => React.CSSProperties;
|
|
108
|
+
};
|
|
109
|
+
export {};
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
import { default as React } from 'react';
|
|
2
|
+
import { DoubleInputItem } from '../../../components';
|
|
3
|
+
import { useTimePickerController } from './useTimePickerController';
|
|
4
|
+
import { useTimeDraft } from './useTimeDraft';
|
|
5
|
+
import { useFormTimeFieldProvider } from './useFormTimeFieldProvider';
|
|
6
|
+
export type DoubleInputItemProps = React.ComponentProps<typeof DoubleInputItem>;
|
|
7
|
+
type PropsType = Pick<Parameters<typeof useFormTimeFieldProvider>[number], 'error' | 'disabled'> & Pick<ReturnType<typeof useTimePickerController>, 'moveToInputtedTimeInPicker' | 'clearTimeInputInPicker' | 'closePicker' | 'switchingPicker'> & Pick<ReturnType<typeof useTimeDraft>, 'setTimeInputValue' | 'clearTimeValue' | 'isFullDateInput'>;
|
|
8
|
+
export declare function useInputFieldProps(props: PropsType): {
|
|
9
|
+
onCompleteTime: NonNullable<((value: string, maskRef: import('imask').InputMask<{
|
|
10
|
+
[x: string]: unknown;
|
|
11
|
+
}>, e?: InputEvent) => void) | ((value: string, maskRef: import('imask').InputMask<{
|
|
12
|
+
[x: string]: unknown;
|
|
13
|
+
}>, e?: InputEvent) => void) | ((value: string, maskRef: import('imask').InputMask<{
|
|
14
|
+
[x: string]: unknown;
|
|
15
|
+
}>, e?: InputEvent) => void) | ((value: string, maskRef: import('imask').InputMask<{
|
|
16
|
+
[x: string]: unknown;
|
|
17
|
+
}>, e?: InputEvent) => void) | ((value: string, maskRef: import('imask').InputMask<{
|
|
18
|
+
[x: string]: unknown;
|
|
19
|
+
}>, e?: InputEvent) => void) | ((value: string, maskRef: import('imask').InputMask<{
|
|
20
|
+
[x: string]: unknown;
|
|
21
|
+
}>, e?: InputEvent) => void) | ((value: string, maskRef: import('imask').InputMask<{
|
|
22
|
+
[x: string]: unknown;
|
|
23
|
+
}>, e?: InputEvent) => void) | ((value: string, maskRef: import('imask').InputMask<{
|
|
24
|
+
[x: string]: unknown;
|
|
25
|
+
}>, e?: InputEvent) => void) | ((value: string, maskRef: import('imask').InputMask<{
|
|
26
|
+
[x: string]: unknown;
|
|
27
|
+
}>, e?: InputEvent) => void) | ((value: string, maskRef: import('imask').InputMask<{
|
|
28
|
+
[x: string]: unknown;
|
|
29
|
+
}>, e?: InputEvent) => void) | ((value: string, maskRef: import('imask').InputMask<{
|
|
30
|
+
[x: string]: unknown;
|
|
31
|
+
}>, e?: InputEvent) => void) | ((value: string, maskRef: import('imask').InputMask<{
|
|
32
|
+
[x: string]: unknown;
|
|
33
|
+
}>, e?: InputEvent) => void) | ((value: string, maskRef: import('imask').InputMask<{
|
|
34
|
+
[x: string]: unknown;
|
|
35
|
+
}>, e?: InputEvent) => void) | ((value: string, maskRef: import('imask').InputMask<{
|
|
36
|
+
[x: string]: unknown;
|
|
37
|
+
}>, e?: InputEvent) => void) | ((value: string, maskRef: import('imask').InputMask<{
|
|
38
|
+
[x: string]: unknown;
|
|
39
|
+
}>, e?: InputEvent) => void) | ((value: string, maskRef: import('imask').InputMask<{
|
|
40
|
+
[x: string]: unknown;
|
|
41
|
+
}>, e?: InputEvent) => void) | ((value: string, maskRef: import('imask').InputMask<{
|
|
42
|
+
[x: string]: unknown;
|
|
43
|
+
}>, e?: InputEvent) => void) | ((value: string, maskRef: import('imask').InputMask<{
|
|
44
|
+
[x: string]: unknown;
|
|
45
|
+
}>, e?: InputEvent) => void) | ((value: string, maskRef: import('imask').InputMask<{
|
|
46
|
+
[x: string]: unknown;
|
|
47
|
+
}>, e?: InputEvent) => void) | ((value: string, maskRef: import('imask').InputMask<{
|
|
48
|
+
[x: string]: unknown;
|
|
49
|
+
}>, e?: InputEvent) => void) | ((value: string, maskRef: import('imask').InputMask<{
|
|
50
|
+
[x: string]: unknown;
|
|
51
|
+
}>, e?: InputEvent) => void) | ((value: string, maskRef: import('imask').InputMask<{
|
|
52
|
+
[x: string]: unknown;
|
|
53
|
+
}>, e?: InputEvent) => void) | ((value: string, maskRef: import('imask').InputMask<{
|
|
54
|
+
[x: string]: unknown;
|
|
55
|
+
}>, e?: InputEvent) => void) | ((value: string, maskRef: import('imask').InputMask<{
|
|
56
|
+
[x: string]: unknown;
|
|
57
|
+
}>, e?: InputEvent) => void) | undefined>;
|
|
58
|
+
onClickTimeField: React.MouseEventHandler<HTMLInputElement>;
|
|
59
|
+
clearTime: () => void;
|
|
60
|
+
isErrorInputFields: boolean | undefined;
|
|
61
|
+
isDisabledInputFields: boolean | undefined;
|
|
62
|
+
};
|
|
63
|
+
export {};
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { useTimeDraft } from './useTimeDraft';
|
|
2
|
+
import { useTimeFormats } from './useTimeFormats';
|
|
3
|
+
import { useFormTimeFieldProvider } from './useFormTimeFieldProvider';
|
|
4
|
+
import { useTimePickerController } from './useTimePickerController';
|
|
5
|
+
type PropsType = Pick<Parameters<typeof useFormTimeFieldProvider>[number], 'onChange' | 'value'> & Pick<ReturnType<typeof useTimeDraft>, 'setTimeInputValue' | 'timeInputValue'> & Pick<ReturnType<typeof useTimeFormats>, 'formatDateTimeInputToValue' | 'formatValueToTimeInput'> & Pick<ReturnType<typeof useTimePickerController>, 'moveToInputtedTimeInPicker'>;
|
|
6
|
+
export declare function useSyncTimeValues(props: PropsType): void;
|
|
7
|
+
export {};
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { useFormTimeFieldProvider } from './useFormTimeFieldProvider';
|
|
2
|
+
import { useTimeFormats } from './useTimeFormats';
|
|
3
|
+
type UseFormDateTimeFieldProps = Parameters<typeof useFormTimeFieldProvider>[number];
|
|
4
|
+
export type DateValue = string;
|
|
5
|
+
export type TimeValue = string;
|
|
6
|
+
type PropsType = Pick<UseFormDateTimeFieldProps, 'value'> & Pick<ReturnType<typeof useTimeFormats>, 'formatValueToTimeInput'>;
|
|
7
|
+
export declare function useTimeDraft(props: PropsType): {
|
|
8
|
+
timeInputValue: string | undefined;
|
|
9
|
+
setTimeInputValue: import('react').Dispatch<import('react').SetStateAction<string | undefined>>;
|
|
10
|
+
clearTimeValue: () => void;
|
|
11
|
+
isFullDateInput: () => boolean;
|
|
12
|
+
};
|
|
13
|
+
export {};
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { default as React } from 'react';
|
|
2
|
+
import { TimePickerV2 } from '../../../..';
|
|
3
|
+
import { useFormTimeFieldProvider, ValueType } from './useFormTimeFieldProvider';
|
|
4
|
+
import { TimeValue } from './useTimeDraft';
|
|
5
|
+
type TimePickerV2Props = React.ComponentProps<typeof TimePickerV2>;
|
|
6
|
+
type DateTimePickerValue = Parameters<NonNullable<TimePickerV2Props['onSubmitTime']>>[0];
|
|
7
|
+
type PropsType = Required<Pick<Parameters<typeof useFormTimeFieldProvider>[number], 'outFormat' | 'inputTimeFormat'>>;
|
|
8
|
+
export declare function useTimeFormats(props: PropsType): {
|
|
9
|
+
formatDateTimeInputToValue: (timeValue: TimeValue) => ValueType;
|
|
10
|
+
parseTimeInput: (instance: TimeValue) => Date;
|
|
11
|
+
formatPickerValueToTimeInput: (instance: DateTimePickerValue) => TimeValue | undefined;
|
|
12
|
+
formatValueToTimeInput: (instance: ValueType) => TimeValue | undefined;
|
|
13
|
+
};
|
|
14
|
+
export {};
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { default as React } from 'react';
|
|
2
|
+
import { TimeValue } from './useTimeDraft';
|
|
3
|
+
import { useInputFieldController } from './useInputFieldController';
|
|
4
|
+
import { useTimeFormats } from './useTimeFormats';
|
|
5
|
+
type PropsType = Pick<ReturnType<typeof useTimeFormats>, 'parseTimeInput'> & Pick<ReturnType<typeof useInputFieldController>, 'doubleInputRef'> & {
|
|
6
|
+
disablePicker?: boolean;
|
|
7
|
+
};
|
|
8
|
+
export declare function useTimePickerController(props: PropsType): {
|
|
9
|
+
timePickerRef: React.RefObject<Pick<{
|
|
10
|
+
setInput: <K extends "hours" | "minutes">(key: K, instance: Partial<Partial<{
|
|
11
|
+
hours: number;
|
|
12
|
+
minutes: number;
|
|
13
|
+
}>>[K]) => void;
|
|
14
|
+
clearDateInput: () => void;
|
|
15
|
+
initViewHours: number | undefined;
|
|
16
|
+
initViewMinutes: number | undefined;
|
|
17
|
+
createCommitTime: (prev: string | undefined) => NonNullable<string | undefined>;
|
|
18
|
+
createCommitTimeWithoutClearing: (prev: string | undefined) => NonNullable<string | undefined>;
|
|
19
|
+
getPreviewTime: (instance: string | undefined) => string | undefined;
|
|
20
|
+
}, "clearDateInput" | "setInput" | "createCommitTimeWithoutClearing" | "createCommitTime"> & {
|
|
21
|
+
timeFeedRef: React.RefObject<{
|
|
22
|
+
scrollToHour: (item: import('../../../../datePickersV2/hooks/feeds/time/feed/utils').ElementItem, behavior?: ScrollBehavior) => Promise<void>;
|
|
23
|
+
scrollToMinute: (item: import('../../../../datePickersV2/hooks/feeds/time/feed/utils').ElementItem, behavior?: ScrollBehavior) => Promise<void>;
|
|
24
|
+
}>;
|
|
25
|
+
}>;
|
|
26
|
+
timePickerWrapperRef: React.RefObject<never>;
|
|
27
|
+
moveToInputtedTimeInPicker: (instance: TimeValue) => Promise<(void | undefined)[]>;
|
|
28
|
+
clearTimeInputInPicker: () => void;
|
|
29
|
+
closePicker: () => void;
|
|
30
|
+
switchingPicker: () => void;
|
|
31
|
+
getPickerInitStyle: () => React.CSSProperties;
|
|
32
|
+
};
|
|
33
|
+
export {};
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { useTimeDraft } from './useTimeDraft';
|
|
2
|
+
import { useFormTimeFieldProvider } from './useFormTimeFieldProvider';
|
|
3
|
+
import { useTimePickerController } from './useTimePickerController';
|
|
4
|
+
import { useTimeFormats } from './useTimeFormats';
|
|
5
|
+
type PropsType = Pick<Parameters<typeof useFormTimeFieldProvider>[number], 'value'> & Pick<ReturnType<typeof useTimePickerController>, 'closePicker'> & Pick<ReturnType<typeof useTimeDraft>, 'setTimeInputValue'> & Pick<ReturnType<typeof useTimeFormats>, 'formatPickerValueToTimeInput'>;
|
|
6
|
+
export declare function useTimePickerProps(props: PropsType): {
|
|
7
|
+
time: string | undefined;
|
|
8
|
+
onSubmitTime: (dateTime: string) => void;
|
|
9
|
+
};
|
|
10
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './ui';
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { default as React } from 'react';
|
|
2
|
+
import { FormFieldWrapper } from '../../../FormFieldWrapper';
|
|
3
|
+
import { FormTimeFieldBase } from './FormTimeFieldBase';
|
|
4
|
+
type PropsType = Omit<React.ComponentProps<typeof FormTimeFieldBase>, 'pickerSubtitle'> & Pick<React.ComponentProps<typeof FormFieldWrapper>, 'error' | 'hint' | 'helperLink' | 'label' | 'required' | 'typeDisplay'>;
|
|
5
|
+
export declare function FormTimeField(props: PropsType): import("react/jsx-runtime").JSX.Element;
|
|
6
|
+
export {};
|
package/package.json
CHANGED
|
@@ -11,7 +11,7 @@
|
|
|
11
11
|
"react-components",
|
|
12
12
|
"ui-kit"
|
|
13
13
|
],
|
|
14
|
-
"version": "1.1.
|
|
14
|
+
"version": "1.1.2",
|
|
15
15
|
"exports": {
|
|
16
16
|
".": {
|
|
17
17
|
"types": "./dist/types/index.d.ts",
|
|
@@ -46,8 +46,8 @@
|
|
|
46
46
|
"@types/mathjs": "^9.4.1",
|
|
47
47
|
"@types/node": "^22.13.13",
|
|
48
48
|
"@types/object-hash": "^3.0.6",
|
|
49
|
-
"@types/react": "
|
|
50
|
-
"@types/react-dom": "
|
|
49
|
+
"@types/react": ">=18.0.0",
|
|
50
|
+
"@types/react-dom": ">=18.0.0",
|
|
51
51
|
"@vitejs/plugin-react": "^5.1.2",
|
|
52
52
|
"ajv": "^8.17.1",
|
|
53
53
|
"clsx": "^2.1.1",
|
|
@@ -70,13 +70,13 @@
|
|
|
70
70
|
"vite-plugin-dts": "^4.5.4",
|
|
71
71
|
"vite-plugin-static-copy": "^3.1.4",
|
|
72
72
|
"vite-plugin-svgr": "^4.5.0",
|
|
73
|
-
"vite-plugin-virtual-html": "^1.2.7"
|
|
73
|
+
"vite-plugin-virtual-html": "^1.2.7",
|
|
74
|
+
"gl-matrix": "^3.4.4",
|
|
75
|
+
"uuid": "^13.0.0"
|
|
74
76
|
},
|
|
75
77
|
"peerDependencies": {
|
|
76
78
|
"react": ">=18.0.0",
|
|
77
|
-
"react-dom": ">=18.0.0"
|
|
78
|
-
"gl-matrix": "^3.4.4",
|
|
79
|
-
"uuid": "^13.0.0"
|
|
79
|
+
"react-dom": ">=18.0.0"
|
|
80
80
|
},
|
|
81
81
|
"dependencies": {}
|
|
82
82
|
}
|