indicator-ui 0.1.102 → 0.1.103

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 (36) hide show
  1. package/dist/index.css +195 -75
  2. package/dist/index.css.map +1 -1
  3. package/dist/index.js +1149 -54
  4. package/dist/index.js.map +1 -1
  5. package/dist/scss/styles/mixins/themes.scss +1 -1
  6. package/dist/types/src/assets/icons/index.d.ts +1 -0
  7. package/dist/types/src/hooks/forms/types/scheme.d.ts +2 -1
  8. package/dist/types/src/test/pages/BreadcrumbsPage.d.ts +1 -0
  9. package/dist/types/src/test/pages/SelectFieldPage.d.ts +1 -0
  10. package/dist/types/src/test/pages/index.d.ts +2 -0
  11. package/dist/types/src/types/mixins.d.ts +4 -1
  12. package/dist/types/src/ui/Breadcrumbs/index.d.ts +1 -0
  13. package/dist/types/src/ui/Breadcrumbs/styles/index.d.ts +3 -0
  14. package/dist/types/src/ui/Breadcrumbs/ui/BreadcrumbButton.d.ts +10 -0
  15. package/dist/types/src/ui/Breadcrumbs/ui/Breadcrumbs.d.ts +9 -0
  16. package/dist/types/src/ui/Breadcrumbs/ui/Divider.d.ts +5 -0
  17. package/dist/types/src/ui/Breadcrumbs/ui/index.d.ts +2 -0
  18. package/dist/types/src/ui/Dropdown/types/DropdownTypes.d.ts +1 -0
  19. package/dist/types/src/ui/formFields/FormPaginatedSelectField/hooks/index.d.ts +1 -0
  20. package/dist/types/src/ui/formFields/FormPaginatedSelectField/hooks/useFetch.d.ts +20 -0
  21. package/dist/types/src/ui/formFields/FormPaginatedSelectField/hooks/useFormPaginatedSelectField.d.ts +306 -0
  22. package/dist/types/src/ui/formFields/FormPaginatedSelectField/hooks/useIsLoading.d.ts +5 -0
  23. package/dist/types/src/ui/formFields/FormPaginatedSelectField/hooks/useLocalOptions.d.ts +10 -0
  24. package/dist/types/src/ui/formFields/FormPaginatedSelectField/hooks/useSelectFieldState.d.ts +4 -0
  25. package/dist/types/src/ui/formFields/FormPaginatedSelectField/hooks/useSelectModal.d.ts +11 -0
  26. package/dist/types/src/ui/formFields/FormPaginatedSelectField/hooks/useSelectValue.d.ts +18 -0
  27. package/dist/types/src/ui/formFields/FormPaginatedSelectField/index.d.ts +1 -0
  28. package/dist/types/src/ui/formFields/FormPaginatedSelectField/lib/index.d.ts +8 -0
  29. package/dist/types/src/ui/formFields/FormPaginatedSelectField/styles/index.d.ts +1 -0
  30. package/dist/types/src/ui/formFields/FormPaginatedSelectField/types/index.d.ts +14 -0
  31. package/dist/types/src/ui/formFields/FormPaginatedSelectField/ui/FormPaginatedSelectField.d.ts +8 -0
  32. package/dist/types/src/ui/formFields/FormPaginatedSelectField/ui/FormPaginatedSelectFieldBase.d.ts +4 -0
  33. package/dist/types/src/ui/formFields/FormPaginatedSelectField/ui/index.d.ts +2 -0
  34. package/dist/types/src/ui/formFields/index.d.ts +1 -0
  35. package/dist/types/src/ui/index.d.ts +1 -0
  36. package/package.json +1 -1
@@ -1,5 +1,5 @@
1
1
  @mixin darkTheme() {
2
- [data-theme="dark"] {
2
+ [data-theme="dark"] & {
3
3
  @content;
4
4
  }
5
5
  }
@@ -87,3 +87,4 @@ export { default as CircleSVG } from './circle.svg';
87
87
  export { default as CalendarCheck01SVG } from './calendar-check-01.svg';
88
88
  export { default as HelpCircleSVG } from './help-circle.svg';
89
89
  export { default as AlertCircleSVG } from './alert-circle.svg';
90
+ export { default as SlashDividerSVG } from './slash-divider.svg';
@@ -1,5 +1,6 @@
1
1
  import { Nullable } from "../../../types";
2
2
  import { ExtendFormPath, ExtendFormValue, FormErrorType, FormPath, FormValue } from './formTypes';
3
+ import { FocusEvent } from "react";
3
4
  export type StringFieldValidators = Partial<{
4
5
  /** Минимальная длина строки */
5
6
  minStr: number;
@@ -155,7 +156,7 @@ export type FieldPropsType<V> = {
155
156
  value?: V | null;
156
157
  onChange?: (value?: V | null) => void;
157
158
  error?: FormErrorType;
158
- onBlur?: () => void;
159
+ onBlur?: (event?: FocusEvent) => void;
159
160
  };
160
161
  export type AllValidatorsType = ArrayFieldValidators & FileFieldValidators & StringFieldValidators & DateTimeFieldValidators & NumberFieldValidators;
161
162
  export type ValidatorsConfigType = {
@@ -0,0 +1 @@
1
+ export declare function BreadcrumbsPage(): JSX.Element;
@@ -0,0 +1 @@
1
+ export declare function SelectFieldPage(): JSX.Element;
@@ -24,3 +24,5 @@ export * from './UseSmartScrollPage';
24
24
  export * from './ModalsPage';
25
25
  export * from './UiAnimationsPage';
26
26
  export * from './FormPage';
27
+ export * from './SelectFieldPage';
28
+ export * from './BreadcrumbsPage';
@@ -1,4 +1,4 @@
1
- import { ComponentType, ForwardedRef, LegacyRef } from "react";
1
+ import React, { ComponentType, ElementType, ForwardedRef, LegacyRef } from "react";
2
2
  type RefType<R> = [R] extends [LegacyRef<infer T> | ForwardedRef<infer T> | undefined] ? T : never;
3
3
  export type PropsOf<C> = C extends ComponentType<infer P> ? P : C extends (...args: infer P) => any ? P : never;
4
4
  export type ComponentRefType<R> = [
@@ -18,4 +18,7 @@ export type Nullable<T> = {
18
18
  [K in keyof T]: T[K] | null;
19
19
  } | null;
20
20
  export type Merge<A extends Record<any, any>, B extends Record<any, any>> = Omit<A, keyof B> & B;
21
+ export type AsProps<T extends ElementType> = Merge<React.ComponentPropsWithRef<T>, {
22
+ as?: T;
23
+ }>;
21
24
  export {};
@@ -0,0 +1 @@
1
+ export * from './ui';
@@ -0,0 +1,3 @@
1
+ export { default as BreadcrumbButtonStyle } from './BreadcrumbButton.module.scss';
2
+ export { default as DividerStyle } from './Divider.module.scss';
3
+ export { default as BreadcrumbsStyle } from './Breadcrumbs.module.scss';
@@ -0,0 +1,10 @@
1
+ import React, { ElementType } from "react";
2
+ import { AsProps, Merge } from "../../../../../types";
3
+ type PropsType<T extends ElementType> = Merge<AsProps<T>, {
4
+ current?: boolean;
5
+ className?: string;
6
+ children?: React.ReactNode;
7
+ type?: 'text' | 'button-primary' | 'button-gray';
8
+ }>;
9
+ export declare function BreadcrumbButton<T extends ElementType = 'button'>(props: PropsType<T>): JSX.Element;
10
+ export {};
@@ -0,0 +1,9 @@
1
+ import { AsProps, Merge } from "../../../../../types";
2
+ import React, { ElementType } from "react";
3
+ import { Divider } from "./Divider";
4
+ type PropsType<T extends ElementType> = Merge<AsProps<T>, {
5
+ children?: React.ReactNode;
6
+ type?: React.ComponentProps<typeof Divider>['type'];
7
+ }>;
8
+ export declare function Breadcrumbs<T extends ElementType = 'div'>(props: PropsType<T>): JSX.Element;
9
+ export {};
@@ -0,0 +1,5 @@
1
+ type PropsType = {
2
+ type?: 'slash' | 'arrow';
3
+ };
4
+ export declare function Divider(props: PropsType): JSX.Element;
5
+ export {};
@@ -0,0 +1,2 @@
1
+ export * from './Breadcrumbs';
2
+ export * from './BreadcrumbButton';
@@ -27,6 +27,7 @@ export type DropdownPropsBaseType<T> = {
27
27
  elementAfter?: React.ReactNode;
28
28
  elementBefore?: React.ReactNode;
29
29
  theme?: "light" | "dark";
30
+ isLoading?: boolean;
30
31
  };
31
32
  export type DropdownPropsType<T> = UseSmartScrollCallbacksType & DropdownPropsBaseType<T>;
32
33
  export {};
@@ -0,0 +1 @@
1
+ export * from './useFormPaginatedSelectField';
@@ -0,0 +1,20 @@
1
+ import React from "react";
2
+ import { FetchEventFunType, OptionsExtendItemType, OptionsType } from "../types";
3
+ type PropsType<D> = {
4
+ search?: FetchEventFunType<D>;
5
+ paginate?: FetchEventFunType<D>;
6
+ localOptions: OptionsType<D>;
7
+ setOptions: (opt: OptionsType<D>) => void;
8
+ addOptions: (opt: OptionsType<D>) => void;
9
+ listRef: React.RefObject<HTMLDivElement | null>;
10
+ };
11
+ export declare function useFetch<D>(props: PropsType<D>): {
12
+ optionsCache: React.MutableRefObject<OptionsType<D>>;
13
+ searchValue: string | null | undefined;
14
+ fillOptionsCache: (values: D[], curOptions: OptionsExtendItemType<D>[]) => void;
15
+ handleChangeSearch: (value: string | undefined | null) => void;
16
+ canSearch: boolean;
17
+ canPaginate: boolean;
18
+ isLoading: boolean;
19
+ };
20
+ export {};
@@ -0,0 +1,306 @@
1
+ import React, { FocusEvent } from "react";
2
+ import { FieldPropsType } from "../../../../hooks";
3
+ import { Merge } from "../../../../../../types";
4
+ import { FetchEventPropsType, OptionsType, ValueType } from "../types";
5
+ type BasePropsType<D, M extends boolean> = FieldPropsType<ValueType<D, M>> & {
6
+ options?: OptionsType<D>;
7
+ multiple?: M;
8
+ disabled?: boolean;
9
+ /** Заменяет `options`, которые есть сейчас */
10
+ search?: (props: FetchEventPropsType<D>) => Promise<OptionsType<D>>;
11
+ /** Добавляет `options` к текущим */
12
+ paginate?: (props: FetchEventPropsType<D>) => Promise<OptionsType<D>>;
13
+ };
14
+ type PropsType<D, M extends boolean = false> = Merge<React.ComponentProps<'div'>, BasePropsType<D, M>>;
15
+ export declare function useFormPaginatedSelectField<D, M extends boolean = false>(props: PropsType<D, M>): {
16
+ handleFocus: (event: FocusEvent<HTMLDivElement>) => void;
17
+ handleBlur: (event: FocusEvent<HTMLDivElement>) => void;
18
+ handleClick: (value: D) => void;
19
+ isActive: (value: D) => boolean;
20
+ viewValue: string;
21
+ items: import("../../../../ui").DropdownItemsType<D>;
22
+ readOnly: boolean;
23
+ onChangeSearch: (newSearch: string | null | undefined) => void;
24
+ optionsCache: React.MutableRefObject<OptionsType<D>>;
25
+ searchValue: string | null | undefined;
26
+ fillOptionsCache: (values: D[], curOptions: import("../types").OptionsExtendItemType<D>[]) => void;
27
+ handleChangeSearch: (value: string | undefined | null) => void;
28
+ canSearch: boolean;
29
+ canPaginate: boolean;
30
+ isLoading: boolean;
31
+ fieldState: "view" | "search";
32
+ setIsFocus: React.Dispatch<React.SetStateAction<boolean>>;
33
+ isShow: boolean;
34
+ getIsShow: () => boolean;
35
+ open: () => void;
36
+ close: () => void;
37
+ switching: () => void;
38
+ reinit: () => void;
39
+ getInitStyle: () => React.CSSProperties;
40
+ modalRef: React.MutableRefObject<HTMLDivElement | null>;
41
+ targetRef: React.MutableRefObject<HTMLDivElement | null>;
42
+ otherProps: {
43
+ ref?: React.LegacyRef<HTMLDivElement> | undefined;
44
+ slot?: string | undefined | undefined;
45
+ style?: React.CSSProperties | undefined;
46
+ title?: string | undefined | undefined;
47
+ id?: string | undefined | undefined;
48
+ color?: string | undefined | undefined;
49
+ content?: string | undefined | undefined;
50
+ translate?: "yes" | "no" | undefined | undefined;
51
+ hidden?: boolean | undefined | undefined;
52
+ key?: React.Key | null | undefined;
53
+ onResize?: React.ReactEventHandler<HTMLDivElement> | undefined;
54
+ onSubmit?: React.FormEventHandler<HTMLDivElement> | undefined;
55
+ onReset?: React.FormEventHandler<HTMLDivElement> | undefined;
56
+ defaultChecked?: boolean | undefined | undefined;
57
+ defaultValue?: string | number | readonly string[] | undefined;
58
+ suppressContentEditableWarning?: boolean | undefined | undefined;
59
+ suppressHydrationWarning?: boolean | undefined | undefined;
60
+ accessKey?: string | undefined | undefined;
61
+ autoFocus?: boolean | undefined | undefined;
62
+ contentEditable?: "inherit" | (boolean | "false" | "true") | undefined;
63
+ contextMenu?: string | undefined | undefined;
64
+ dir?: string | undefined | undefined;
65
+ draggable?: (boolean | "false" | "true") | undefined;
66
+ lang?: string | undefined | undefined;
67
+ nonce?: string | undefined | undefined;
68
+ spellCheck?: (boolean | "false" | "true") | undefined;
69
+ tabIndex?: number | undefined | undefined;
70
+ radioGroup?: string | undefined | undefined;
71
+ role?: React.AriaRole | undefined;
72
+ about?: string | undefined | undefined;
73
+ datatype?: string | undefined | undefined;
74
+ inlist?: any;
75
+ prefix?: string | undefined | undefined;
76
+ property?: string | undefined | undefined;
77
+ rel?: string | undefined | undefined;
78
+ resource?: string | undefined | undefined;
79
+ rev?: string | undefined | undefined;
80
+ typeof?: string | undefined | undefined;
81
+ vocab?: string | undefined | undefined;
82
+ autoCapitalize?: string | undefined | undefined;
83
+ autoCorrect?: string | undefined | undefined;
84
+ autoSave?: string | undefined | undefined;
85
+ itemProp?: string | undefined | undefined;
86
+ itemScope?: boolean | undefined | undefined;
87
+ itemType?: string | undefined | undefined;
88
+ itemID?: string | undefined | undefined;
89
+ itemRef?: string | undefined | undefined;
90
+ results?: number | undefined | undefined;
91
+ security?: string | undefined | undefined;
92
+ unselectable?: "on" | "off" | undefined | undefined;
93
+ inputMode?: "none" | "text" | "tel" | "url" | "email" | "numeric" | "decimal" | "search" | undefined | undefined;
94
+ is?: string | undefined | undefined;
95
+ 'aria-activedescendant'?: string | undefined | undefined;
96
+ 'aria-atomic'?: (boolean | "false" | "true") | undefined;
97
+ 'aria-autocomplete'?: "none" | "inline" | "list" | "both" | undefined | undefined;
98
+ 'aria-busy'?: (boolean | "false" | "true") | undefined;
99
+ 'aria-checked'?: boolean | "false" | "mixed" | "true" | undefined | undefined;
100
+ 'aria-colcount'?: number | undefined | undefined;
101
+ 'aria-colindex'?: number | undefined | undefined;
102
+ 'aria-colspan'?: number | undefined | undefined;
103
+ 'aria-controls'?: string | undefined | undefined;
104
+ 'aria-current'?: boolean | "false" | "true" | "page" | "step" | "location" | "date" | "time" | undefined | undefined;
105
+ 'aria-describedby'?: string | undefined | undefined;
106
+ 'aria-details'?: string | undefined | undefined;
107
+ 'aria-disabled'?: (boolean | "false" | "true") | undefined;
108
+ 'aria-dropeffect'?: "none" | "copy" | "execute" | "link" | "move" | "popup" | undefined | undefined;
109
+ 'aria-errormessage'?: string | undefined | undefined;
110
+ 'aria-expanded'?: (boolean | "false" | "true") | undefined;
111
+ 'aria-flowto'?: string | undefined | undefined;
112
+ 'aria-grabbed'?: (boolean | "false" | "true") | undefined;
113
+ 'aria-haspopup'?: boolean | "false" | "true" | "menu" | "listbox" | "tree" | "grid" | "dialog" | undefined | undefined;
114
+ 'aria-hidden'?: (boolean | "false" | "true") | undefined;
115
+ 'aria-invalid'?: boolean | "false" | "true" | "grammar" | "spelling" | undefined | undefined;
116
+ 'aria-keyshortcuts'?: string | undefined | undefined;
117
+ 'aria-label'?: string | undefined | undefined;
118
+ 'aria-labelledby'?: string | undefined | undefined;
119
+ 'aria-level'?: number | undefined | undefined;
120
+ 'aria-live'?: "off" | "assertive" | "polite" | undefined | undefined;
121
+ 'aria-modal'?: (boolean | "false" | "true") | undefined;
122
+ 'aria-multiline'?: (boolean | "false" | "true") | undefined;
123
+ 'aria-multiselectable'?: (boolean | "false" | "true") | undefined;
124
+ 'aria-orientation'?: "horizontal" | "vertical" | undefined | undefined;
125
+ 'aria-owns'?: string | undefined | undefined;
126
+ 'aria-placeholder'?: string | undefined | undefined;
127
+ 'aria-posinset'?: number | undefined | undefined;
128
+ 'aria-pressed'?: boolean | "false" | "mixed" | "true" | undefined | undefined;
129
+ 'aria-readonly'?: (boolean | "false" | "true") | undefined;
130
+ 'aria-relevant'?: "additions" | "additions removals" | "additions text" | "all" | "removals" | "removals additions" | "removals text" | "text" | "text additions" | "text removals" | undefined | undefined;
131
+ 'aria-required'?: (boolean | "false" | "true") | undefined;
132
+ 'aria-roledescription'?: string | undefined | undefined;
133
+ 'aria-rowcount'?: number | undefined | undefined;
134
+ 'aria-rowindex'?: number | undefined | undefined;
135
+ 'aria-rowspan'?: number | undefined | undefined;
136
+ 'aria-selected'?: (boolean | "false" | "true") | undefined;
137
+ 'aria-setsize'?: number | undefined | undefined;
138
+ 'aria-sort'?: "none" | "ascending" | "descending" | "other" | undefined | undefined;
139
+ 'aria-valuemax'?: number | undefined | undefined;
140
+ 'aria-valuemin'?: number | undefined | undefined;
141
+ 'aria-valuenow'?: number | undefined | undefined;
142
+ 'aria-valuetext'?: string | undefined | undefined;
143
+ children?: React.ReactNode;
144
+ dangerouslySetInnerHTML?: {
145
+ __html: string | TrustedHTML;
146
+ } | undefined | undefined;
147
+ onCopy?: React.ClipboardEventHandler<HTMLDivElement> | undefined;
148
+ onCopyCapture?: React.ClipboardEventHandler<HTMLDivElement> | undefined;
149
+ onCut?: React.ClipboardEventHandler<HTMLDivElement> | undefined;
150
+ onCutCapture?: React.ClipboardEventHandler<HTMLDivElement> | undefined;
151
+ onPaste?: React.ClipboardEventHandler<HTMLDivElement> | undefined;
152
+ onPasteCapture?: React.ClipboardEventHandler<HTMLDivElement> | undefined;
153
+ onCompositionEnd?: React.CompositionEventHandler<HTMLDivElement> | undefined;
154
+ onCompositionEndCapture?: React.CompositionEventHandler<HTMLDivElement> | undefined;
155
+ onCompositionStart?: React.CompositionEventHandler<HTMLDivElement> | undefined;
156
+ onCompositionStartCapture?: React.CompositionEventHandler<HTMLDivElement> | undefined;
157
+ onCompositionUpdate?: React.CompositionEventHandler<HTMLDivElement> | undefined;
158
+ onCompositionUpdateCapture?: React.CompositionEventHandler<HTMLDivElement> | undefined;
159
+ onFocusCapture?: React.FocusEventHandler<HTMLDivElement> | undefined;
160
+ onBlurCapture?: React.FocusEventHandler<HTMLDivElement> | undefined;
161
+ onChangeCapture?: React.FormEventHandler<HTMLDivElement> | undefined;
162
+ onBeforeInput?: React.FormEventHandler<HTMLDivElement> | undefined;
163
+ onBeforeInputCapture?: React.FormEventHandler<HTMLDivElement> | undefined;
164
+ onInput?: React.FormEventHandler<HTMLDivElement> | undefined;
165
+ onInputCapture?: React.FormEventHandler<HTMLDivElement> | undefined;
166
+ onResetCapture?: React.FormEventHandler<HTMLDivElement> | undefined;
167
+ onSubmitCapture?: React.FormEventHandler<HTMLDivElement> | undefined;
168
+ onInvalid?: React.FormEventHandler<HTMLDivElement> | undefined;
169
+ onInvalidCapture?: React.FormEventHandler<HTMLDivElement> | undefined;
170
+ onLoad?: React.ReactEventHandler<HTMLDivElement> | undefined;
171
+ onLoadCapture?: React.ReactEventHandler<HTMLDivElement> | undefined;
172
+ onError?: React.ReactEventHandler<HTMLDivElement> | undefined;
173
+ onErrorCapture?: React.ReactEventHandler<HTMLDivElement> | undefined;
174
+ onKeyDown?: React.KeyboardEventHandler<HTMLDivElement> | undefined;
175
+ onKeyDownCapture?: React.KeyboardEventHandler<HTMLDivElement> | undefined;
176
+ onKeyPress?: React.KeyboardEventHandler<HTMLDivElement> | undefined;
177
+ onKeyPressCapture?: React.KeyboardEventHandler<HTMLDivElement> | undefined;
178
+ onKeyUp?: React.KeyboardEventHandler<HTMLDivElement> | undefined;
179
+ onKeyUpCapture?: React.KeyboardEventHandler<HTMLDivElement> | undefined;
180
+ onAbort?: React.ReactEventHandler<HTMLDivElement> | undefined;
181
+ onAbortCapture?: React.ReactEventHandler<HTMLDivElement> | undefined;
182
+ onCanPlay?: React.ReactEventHandler<HTMLDivElement> | undefined;
183
+ onCanPlayCapture?: React.ReactEventHandler<HTMLDivElement> | undefined;
184
+ onCanPlayThrough?: React.ReactEventHandler<HTMLDivElement> | undefined;
185
+ onCanPlayThroughCapture?: React.ReactEventHandler<HTMLDivElement> | undefined;
186
+ onDurationChange?: React.ReactEventHandler<HTMLDivElement> | undefined;
187
+ onDurationChangeCapture?: React.ReactEventHandler<HTMLDivElement> | undefined;
188
+ onEmptied?: React.ReactEventHandler<HTMLDivElement> | undefined;
189
+ onEmptiedCapture?: React.ReactEventHandler<HTMLDivElement> | undefined;
190
+ onEncrypted?: React.ReactEventHandler<HTMLDivElement> | undefined;
191
+ onEncryptedCapture?: React.ReactEventHandler<HTMLDivElement> | undefined;
192
+ onEnded?: React.ReactEventHandler<HTMLDivElement> | undefined;
193
+ onEndedCapture?: React.ReactEventHandler<HTMLDivElement> | undefined;
194
+ onLoadedData?: React.ReactEventHandler<HTMLDivElement> | undefined;
195
+ onLoadedDataCapture?: React.ReactEventHandler<HTMLDivElement> | undefined;
196
+ onLoadedMetadata?: React.ReactEventHandler<HTMLDivElement> | undefined;
197
+ onLoadedMetadataCapture?: React.ReactEventHandler<HTMLDivElement> | undefined;
198
+ onLoadStart?: React.ReactEventHandler<HTMLDivElement> | undefined;
199
+ onLoadStartCapture?: React.ReactEventHandler<HTMLDivElement> | undefined;
200
+ onPause?: React.ReactEventHandler<HTMLDivElement> | undefined;
201
+ onPauseCapture?: React.ReactEventHandler<HTMLDivElement> | undefined;
202
+ onPlay?: React.ReactEventHandler<HTMLDivElement> | undefined;
203
+ onPlayCapture?: React.ReactEventHandler<HTMLDivElement> | undefined;
204
+ onPlaying?: React.ReactEventHandler<HTMLDivElement> | undefined;
205
+ onPlayingCapture?: React.ReactEventHandler<HTMLDivElement> | undefined;
206
+ onProgress?: React.ReactEventHandler<HTMLDivElement> | undefined;
207
+ onProgressCapture?: React.ReactEventHandler<HTMLDivElement> | undefined;
208
+ onRateChange?: React.ReactEventHandler<HTMLDivElement> | undefined;
209
+ onRateChangeCapture?: React.ReactEventHandler<HTMLDivElement> | undefined;
210
+ onResizeCapture?: React.ReactEventHandler<HTMLDivElement> | undefined;
211
+ onSeeked?: React.ReactEventHandler<HTMLDivElement> | undefined;
212
+ onSeekedCapture?: React.ReactEventHandler<HTMLDivElement> | undefined;
213
+ onSeeking?: React.ReactEventHandler<HTMLDivElement> | undefined;
214
+ onSeekingCapture?: React.ReactEventHandler<HTMLDivElement> | undefined;
215
+ onStalled?: React.ReactEventHandler<HTMLDivElement> | undefined;
216
+ onStalledCapture?: React.ReactEventHandler<HTMLDivElement> | undefined;
217
+ onSuspend?: React.ReactEventHandler<HTMLDivElement> | undefined;
218
+ onSuspendCapture?: React.ReactEventHandler<HTMLDivElement> | undefined;
219
+ onTimeUpdate?: React.ReactEventHandler<HTMLDivElement> | undefined;
220
+ onTimeUpdateCapture?: React.ReactEventHandler<HTMLDivElement> | undefined;
221
+ onVolumeChange?: React.ReactEventHandler<HTMLDivElement> | undefined;
222
+ onVolumeChangeCapture?: React.ReactEventHandler<HTMLDivElement> | undefined;
223
+ onWaiting?: React.ReactEventHandler<HTMLDivElement> | undefined;
224
+ onWaitingCapture?: React.ReactEventHandler<HTMLDivElement> | undefined;
225
+ onAuxClick?: React.MouseEventHandler<HTMLDivElement> | undefined;
226
+ onAuxClickCapture?: React.MouseEventHandler<HTMLDivElement> | undefined;
227
+ onClick?: React.MouseEventHandler<HTMLDivElement> | undefined;
228
+ onClickCapture?: React.MouseEventHandler<HTMLDivElement> | undefined;
229
+ onContextMenu?: React.MouseEventHandler<HTMLDivElement> | undefined;
230
+ onContextMenuCapture?: React.MouseEventHandler<HTMLDivElement> | undefined;
231
+ onDoubleClick?: React.MouseEventHandler<HTMLDivElement> | undefined;
232
+ onDoubleClickCapture?: React.MouseEventHandler<HTMLDivElement> | undefined;
233
+ onDrag?: React.DragEventHandler<HTMLDivElement> | undefined;
234
+ onDragCapture?: React.DragEventHandler<HTMLDivElement> | undefined;
235
+ onDragEnd?: React.DragEventHandler<HTMLDivElement> | undefined;
236
+ onDragEndCapture?: React.DragEventHandler<HTMLDivElement> | undefined;
237
+ onDragEnter?: React.DragEventHandler<HTMLDivElement> | undefined;
238
+ onDragEnterCapture?: React.DragEventHandler<HTMLDivElement> | undefined;
239
+ onDragExit?: React.DragEventHandler<HTMLDivElement> | undefined;
240
+ onDragExitCapture?: React.DragEventHandler<HTMLDivElement> | undefined;
241
+ onDragLeave?: React.DragEventHandler<HTMLDivElement> | undefined;
242
+ onDragLeaveCapture?: React.DragEventHandler<HTMLDivElement> | undefined;
243
+ onDragOver?: React.DragEventHandler<HTMLDivElement> | undefined;
244
+ onDragOverCapture?: React.DragEventHandler<HTMLDivElement> | undefined;
245
+ onDragStart?: React.DragEventHandler<HTMLDivElement> | undefined;
246
+ onDragStartCapture?: React.DragEventHandler<HTMLDivElement> | undefined;
247
+ onDrop?: React.DragEventHandler<HTMLDivElement> | undefined;
248
+ onDropCapture?: React.DragEventHandler<HTMLDivElement> | undefined;
249
+ onMouseDown?: React.MouseEventHandler<HTMLDivElement> | undefined;
250
+ onMouseDownCapture?: React.MouseEventHandler<HTMLDivElement> | undefined;
251
+ onMouseEnter?: React.MouseEventHandler<HTMLDivElement> | undefined;
252
+ onMouseLeave?: React.MouseEventHandler<HTMLDivElement> | undefined;
253
+ onMouseMove?: React.MouseEventHandler<HTMLDivElement> | undefined;
254
+ onMouseMoveCapture?: React.MouseEventHandler<HTMLDivElement> | undefined;
255
+ onMouseOut?: React.MouseEventHandler<HTMLDivElement> | undefined;
256
+ onMouseOutCapture?: React.MouseEventHandler<HTMLDivElement> | undefined;
257
+ onMouseOver?: React.MouseEventHandler<HTMLDivElement> | undefined;
258
+ onMouseOverCapture?: React.MouseEventHandler<HTMLDivElement> | undefined;
259
+ onMouseUp?: React.MouseEventHandler<HTMLDivElement> | undefined;
260
+ onMouseUpCapture?: React.MouseEventHandler<HTMLDivElement> | undefined;
261
+ onSelect?: React.ReactEventHandler<HTMLDivElement> | undefined;
262
+ onSelectCapture?: React.ReactEventHandler<HTMLDivElement> | undefined;
263
+ onTouchCancel?: React.TouchEventHandler<HTMLDivElement> | undefined;
264
+ onTouchCancelCapture?: React.TouchEventHandler<HTMLDivElement> | undefined;
265
+ onTouchEnd?: React.TouchEventHandler<HTMLDivElement> | undefined;
266
+ onTouchEndCapture?: React.TouchEventHandler<HTMLDivElement> | undefined;
267
+ onTouchMove?: React.TouchEventHandler<HTMLDivElement> | undefined;
268
+ onTouchMoveCapture?: React.TouchEventHandler<HTMLDivElement> | undefined;
269
+ onTouchStart?: React.TouchEventHandler<HTMLDivElement> | undefined;
270
+ onTouchStartCapture?: React.TouchEventHandler<HTMLDivElement> | undefined;
271
+ onPointerDown?: React.PointerEventHandler<HTMLDivElement> | undefined;
272
+ onPointerDownCapture?: React.PointerEventHandler<HTMLDivElement> | undefined;
273
+ onPointerMove?: React.PointerEventHandler<HTMLDivElement> | undefined;
274
+ onPointerMoveCapture?: React.PointerEventHandler<HTMLDivElement> | undefined;
275
+ onPointerUp?: React.PointerEventHandler<HTMLDivElement> | undefined;
276
+ onPointerUpCapture?: React.PointerEventHandler<HTMLDivElement> | undefined;
277
+ onPointerCancel?: React.PointerEventHandler<HTMLDivElement> | undefined;
278
+ onPointerCancelCapture?: React.PointerEventHandler<HTMLDivElement> | undefined;
279
+ onPointerEnter?: React.PointerEventHandler<HTMLDivElement> | undefined;
280
+ onPointerEnterCapture?: React.PointerEventHandler<HTMLDivElement> | undefined;
281
+ onPointerLeave?: React.PointerEventHandler<HTMLDivElement> | undefined;
282
+ onPointerLeaveCapture?: React.PointerEventHandler<HTMLDivElement> | undefined;
283
+ onPointerOver?: React.PointerEventHandler<HTMLDivElement> | undefined;
284
+ onPointerOverCapture?: React.PointerEventHandler<HTMLDivElement> | undefined;
285
+ onPointerOut?: React.PointerEventHandler<HTMLDivElement> | undefined;
286
+ onPointerOutCapture?: React.PointerEventHandler<HTMLDivElement> | undefined;
287
+ onGotPointerCapture?: React.PointerEventHandler<HTMLDivElement> | undefined;
288
+ onGotPointerCaptureCapture?: React.PointerEventHandler<HTMLDivElement> | undefined;
289
+ onLostPointerCapture?: React.PointerEventHandler<HTMLDivElement> | undefined;
290
+ onLostPointerCaptureCapture?: React.PointerEventHandler<HTMLDivElement> | undefined;
291
+ onScroll?: React.UIEventHandler<HTMLDivElement> | undefined;
292
+ onScrollCapture?: React.UIEventHandler<HTMLDivElement> | undefined;
293
+ onWheel?: React.WheelEventHandler<HTMLDivElement> | undefined;
294
+ onWheelCapture?: React.WheelEventHandler<HTMLDivElement> | undefined;
295
+ onAnimationStart?: React.AnimationEventHandler<HTMLDivElement> | undefined;
296
+ onAnimationStartCapture?: React.AnimationEventHandler<HTMLDivElement> | undefined;
297
+ onAnimationEnd?: React.AnimationEventHandler<HTMLDivElement> | undefined;
298
+ onAnimationEndCapture?: React.AnimationEventHandler<HTMLDivElement> | undefined;
299
+ onAnimationIteration?: React.AnimationEventHandler<HTMLDivElement> | undefined;
300
+ onAnimationIterationCapture?: React.AnimationEventHandler<HTMLDivElement> | undefined;
301
+ onTransitionEnd?: React.TransitionEventHandler<HTMLDivElement> | undefined;
302
+ onTransitionEndCapture?: React.TransitionEventHandler<HTMLDivElement> | undefined;
303
+ error?: import("../../../../hooks").FormErrorType;
304
+ };
305
+ };
306
+ export {};
@@ -0,0 +1,5 @@
1
+ export declare function useIsLoading(): {
2
+ isLoading: boolean;
3
+ startLoading: () => void;
4
+ stopLoading: () => void;
5
+ };
@@ -0,0 +1,10 @@
1
+ import { OptionsType } from "../types";
2
+ type PropsType<D> = {
3
+ options: OptionsType<D>;
4
+ };
5
+ export declare function useLocalOptions<D>(props: PropsType<D>): {
6
+ localOptions: OptionsType<D>;
7
+ addOptions: (opt: OptionsType<D>) => void;
8
+ setOptions: (opt: OptionsType<D>) => void;
9
+ };
10
+ export {};
@@ -0,0 +1,4 @@
1
+ export declare function useSelectFieldState(): {
2
+ fieldState: "view" | "search";
3
+ setIsFocus: import("react").Dispatch<import("react").SetStateAction<boolean>>;
4
+ };
@@ -0,0 +1,11 @@
1
+ export declare function useSelectModal(): {
2
+ isShow: boolean;
3
+ getIsShow: () => boolean;
4
+ open: () => void;
5
+ close: () => void;
6
+ switching: () => void;
7
+ reinit: () => void;
8
+ getInitStyle: () => import("react").CSSProperties;
9
+ modalRef: import("react").MutableRefObject<HTMLDivElement | null>;
10
+ targetRef: import("react").MutableRefObject<HTMLDivElement | null>;
11
+ };
@@ -0,0 +1,18 @@
1
+ import { FocusEvent } from "react";
2
+ import { useSelectModal } from "./useSelectModal";
3
+ import { useSelectFieldState } from "./useSelectFieldState";
4
+ import { useLocalOptions } from "./useLocalOptions";
5
+ import { useFetch } from "./useFetch";
6
+ import { useFormPaginatedSelectField } from "./useFormPaginatedSelectField";
7
+ type PropsType<D, M extends boolean = false> = Pick<Parameters<typeof useFormPaginatedSelectField<D, M>>[number], 'multiple' | 'onFocus' | 'onBlur' | 'onChange' | 'value'> & Pick<ReturnType<typeof useSelectFieldState>, 'fieldState' | 'setIsFocus'> & Pick<ReturnType<typeof useFetch<D>>, 'handleChangeSearch' | 'fillOptionsCache' | 'optionsCache' | 'canSearch' | 'searchValue'> & Pick<ReturnType<typeof useSelectModal>, 'open' | 'close'> & Pick<ReturnType<typeof useLocalOptions<D>>, 'localOptions'>;
8
+ export declare function useSelectValue<D, M extends boolean = false>(props: PropsType<D, M>): {
9
+ handleFocus: (event: FocusEvent<HTMLDivElement>) => void;
10
+ handleBlur: (event: FocusEvent<HTMLDivElement>) => void;
11
+ handleClick: (value: D) => void;
12
+ isActive: (value: D) => boolean;
13
+ viewValue: string;
14
+ items: import("../../../../ui").DropdownItemsType<D>;
15
+ readOnly: boolean;
16
+ onChangeSearch: (newSearch: string | null | undefined) => void;
17
+ };
18
+ export {};
@@ -0,0 +1 @@
1
+ export * from './ui';
@@ -0,0 +1,8 @@
1
+ import { OptionsExtendItemType, OptionsType, ValueType } from "../types";
2
+ export declare function compValue(a: any, b: any): boolean;
3
+ export declare function getExtendOptions<D>(curOptions: OptionsType<D>, cache?: OptionsType<D>): OptionsExtendItemType<D>[];
4
+ export declare function getExtendOptionLabel<D>(curOption: OptionsExtendItemType<D>): string | number | true | import("react").ReactElement<any, string | import("react").JSXElementConstructor<any>> | import("react").ReactFragment;
5
+ export declare function getExtendValue<D, M extends boolean = false>(curValue: ValueType<D, M> | undefined | null, multiple: M): D[];
6
+ export declare function getValueLabels<D>(curValues: D[], curOptions: OptionsExtendItemType<D>[]): string[];
7
+ export declare function getNewMultipleValue<D, M extends boolean = false>(newData: D, curValue: D[]): ValueType<D, M>;
8
+ export declare function getNewValue<D, M extends boolean = false>(newData: D, _curValue: D): ValueType<D, M>;
@@ -0,0 +1 @@
1
+ export { default as SelectFieldStyle } from './SelectField.module.scss';
@@ -0,0 +1,14 @@
1
+ import { DropdownItemPropsType } from "../../../../ui";
2
+ import React from "react";
3
+ export type FetchEventPropsType<D> = {
4
+ search: string;
5
+ curOptions: OptionsType<D>;
6
+ };
7
+ export type FetchEventFunType<D> = (props: FetchEventPropsType<D>) => Promise<OptionsType<D>>;
8
+ export type OptionsExtendItemType<D> = DropdownItemPropsType & {
9
+ value: D;
10
+ label?: React.ReactNode;
11
+ };
12
+ export type OptionsItemType<D> = OptionsExtendItemType<D> | D;
13
+ export type OptionsType<D> = Array<OptionsItemType<Exclude<D, null | undefined>>>;
14
+ export type ValueType<D, M> = M extends true ? Array<D> : D;
@@ -0,0 +1,8 @@
1
+ import React from "react";
2
+ import { ComponentRefType } from "../../../../../../types";
3
+ import { FormPaginatedSelectFieldBase } from './FormPaginatedSelectFieldBase';
4
+ import { FormFieldWrapper } from '../../FormFieldWrapper';
5
+ type RefType = ComponentRefType<typeof FormFieldWrapper>;
6
+ type PropsType<D, M extends boolean> = React.ComponentProps<typeof FormPaginatedSelectFieldBase<D, M>> & React.ComponentProps<typeof FormFieldWrapper>;
7
+ export declare const FormPaginatedSelectField: <D, M extends boolean = false>(props: PropsType<D, M> & React.RefAttributes<RefType>) => React.ReactElement | null;
8
+ export {};
@@ -0,0 +1,4 @@
1
+ import { useFormPaginatedSelectField } from "../hooks";
2
+ type PropsType<D, M extends boolean> = Parameters<typeof useFormPaginatedSelectField<D, M>>[number];
3
+ export declare function FormPaginatedSelectFieldBase<D, M extends boolean = false>(props: PropsType<D, M>): JSX.Element;
4
+ export {};
@@ -0,0 +1,2 @@
1
+ export * from './FormPaginatedSelectFieldBase';
2
+ export * from './FormPaginatedSelectField';
@@ -6,3 +6,4 @@ export * from './FormRadioField';
6
6
  export * from './FormTextareaField';
7
7
  export * from './FormDateField';
8
8
  export * from './FormDateRangeField';
9
+ export * from './FormPaginatedSelectField';
@@ -26,3 +26,4 @@ export * from './DateTimePicker';
26
26
  export * from './Tooltip';
27
27
  export * from './Dropdown';
28
28
  export * from './formFields';
29
+ export * from './Breadcrumbs';
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "indicator-ui",
3
- "version": "0.1.102",
3
+ "version": "0.1.103",
4
4
  "main": "dist/index.js",
5
5
  "types": "dist/types/src/index.d.ts",
6
6
  "style": "dist/index.css",