@rolster/react-components 18.9.0 → 18.10.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/cjs/index.js +141 -58
- package/dist/cjs/index.js.map +1 -1
- package/dist/es/index.js +139 -58
- package/dist/es/index.js.map +1 -1
- package/dist/esm/components/organisms/AutocompleteField/AutocompleteField.d.ts +11 -6
- package/dist/esm/components/organisms/AutocompleteField/AutocompleteField.js +21 -157
- package/dist/esm/components/organisms/AutocompleteField/AutocompleteField.js.map +1 -1
- package/dist/esm/components/organisms/AutocompleteField/autocomplete-field.hook.d.ts +27 -0
- package/dist/esm/components/organisms/AutocompleteField/autocomplete-field.hook.js +170 -0
- package/dist/esm/components/organisms/AutocompleteField/autocomplete-field.hook.js.map +1 -0
- package/dist/esm/components/organisms/Confirmation/Confirmation.js +2 -1
- package/dist/esm/components/organisms/Confirmation/Confirmation.js.map +1 -1
- package/dist/esm/components/organisms/DatePicker/DatePicker.js +2 -1
- package/dist/esm/components/organisms/DatePicker/DatePicker.js.map +1 -1
- package/dist/esm/components/organisms/DateRangePicker/DateRangePicker.js +2 -1
- package/dist/esm/components/organisms/DateRangePicker/DateRangePicker.js.map +1 -1
- package/dist/esm/components/organisms/SelectField/SelectField.d.ts +11 -7
- package/dist/esm/components/organisms/SelectField/SelectField.js +20 -95
- package/dist/esm/components/organisms/SelectField/SelectField.js.map +1 -1
- package/dist/esm/components/organisms/SelectField/select-field.hook.d.ts +24 -0
- package/dist/esm/components/organisms/SelectField/select-field.hook.js +104 -0
- package/dist/esm/components/organisms/SelectField/select-field.hook.js.map +1 -0
- package/dist/esm/hooks/list-control.hook.d.ts +10 -10
- package/dist/esm/hooks/list-control.hook.js +15 -15
- package/dist/esm/hooks/list-control.hook.js.map +1 -1
- package/dist/esm/i18n.d.ts +18 -0
- package/dist/esm/i18n.js +23 -0
- package/dist/esm/i18n.js.map +1 -0
- package/dist/esm/models.d.ts +19 -8
- package/dist/esm/models.js +6 -6
- package/dist/esm/models.js.map +1 -1
- package/package.json +2 -1
|
@@ -1,102 +1,27 @@
|
|
|
1
1
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
-
import
|
|
3
|
-
import { useListControl } from '../../../hooks';
|
|
2
|
+
import reactI18n from '../../../i18n';
|
|
4
3
|
import { renderClassStatus } from '../../../utils/css';
|
|
5
4
|
import { RlsMessageIcon, RlsIcon } from '../../atoms';
|
|
6
5
|
import { RlsBallot } from '../../molecules';
|
|
6
|
+
import { useSelectField } from './select-field.hook';
|
|
7
7
|
import './SelectField.css';
|
|
8
|
-
export function
|
|
9
|
-
const {
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
}, [
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
}
|
|
27
|
-
function onBlurInput() {
|
|
28
|
-
setActive(false);
|
|
29
|
-
}
|
|
30
|
-
function onClickInput() {
|
|
31
|
-
setVisible(true);
|
|
32
|
-
}
|
|
33
|
-
function onKeydownInput(event) {
|
|
34
|
-
switch (event.code) {
|
|
35
|
-
case 'Space':
|
|
36
|
-
setVisible(true);
|
|
37
|
-
break;
|
|
38
|
-
case 'Enter':
|
|
39
|
-
setVisible(true);
|
|
40
|
-
break;
|
|
41
|
-
case 'Escape':
|
|
42
|
-
setVisible(false);
|
|
43
|
-
break;
|
|
44
|
-
case 'Tab':
|
|
45
|
-
setVisible(false);
|
|
46
|
-
break;
|
|
47
|
-
default:
|
|
48
|
-
navigationInput(event);
|
|
49
|
-
break;
|
|
50
|
-
}
|
|
51
|
-
}
|
|
52
|
-
function onClickAction() {
|
|
53
|
-
const newVisible = !visible;
|
|
54
|
-
setVisible(newVisible);
|
|
55
|
-
if (newVisible) {
|
|
56
|
-
inputRef?.current?.focus();
|
|
57
|
-
}
|
|
58
|
-
}
|
|
59
|
-
function onClickBackdrop() {
|
|
60
|
-
setVisible(false);
|
|
61
|
-
}
|
|
62
|
-
function onClickItem(element) {
|
|
63
|
-
return () => {
|
|
64
|
-
onChange(element);
|
|
65
|
-
};
|
|
66
|
-
}
|
|
67
|
-
function onKeydownItem(element) {
|
|
68
|
-
return (event) => {
|
|
69
|
-
switch (event.code) {
|
|
70
|
-
case 'Enter':
|
|
71
|
-
onChange(element);
|
|
72
|
-
break;
|
|
73
|
-
default:
|
|
74
|
-
navigationElement(event);
|
|
75
|
-
break;
|
|
76
|
-
}
|
|
77
|
-
};
|
|
78
|
-
}
|
|
79
|
-
function onChange({ description, value }) {
|
|
80
|
-
inputRef?.current?.focus();
|
|
81
|
-
setVisible(false);
|
|
82
|
-
if (onSelect) {
|
|
83
|
-
onSelect(value);
|
|
84
|
-
}
|
|
85
|
-
else {
|
|
86
|
-
if (formControl) {
|
|
87
|
-
setChangeInternal(true);
|
|
88
|
-
formControl.setState(value);
|
|
89
|
-
}
|
|
90
|
-
setValue(description);
|
|
91
|
-
}
|
|
92
|
-
if (onValue) {
|
|
93
|
-
onValue(value);
|
|
94
|
-
}
|
|
95
|
-
}
|
|
96
|
-
return (_jsxs("div", { ref: boxContentRef, className: renderClassStatus('rls-box-field', { active, disabled }, 'rls-select-field rls-list-field'), "rls-theme": rlsTheme, children: [children && _jsx("label", { className: "rls-box-field__label", children: children }), _jsx("div", { className: "rls-box-field__component", children: _jsxs("div", { className: "rls-box-field__body", children: [_jsx("input", { ref: inputRef, className: "rls-list-field__control", readOnly: true, disabled: disabled, placeholder: placeholder, value: value, onFocus: onFocusInput, onBlur: onBlurInput, onClick: onClickInput, onKeyDown: onKeydownInput }), _jsx("button", { className: renderClassStatus('rls-list-field__action', { visible }), disabled: disabled, onClick: onClickAction, children: _jsx(RlsIcon, { value: "arrow-ios-down" }) })] }) }), formControl?.touched && formControl?.error && (_jsx("div", { className: "rls-box-field__error", children: _jsx(RlsMessageIcon, { icon: "alert-triangle", rlsTheme: "danger", children: formControl.error.message }) })), _jsxs("div", { className: renderClassStatus('rls-list-field__suggestions', {
|
|
97
|
-
visible,
|
|
98
|
-
hide: !visible,
|
|
99
|
-
higher
|
|
100
|
-
}), children: [_jsx("div", { className: "rls-list-field__suggestions__body", children: _jsxs("ul", { ref: listRef, className: "rls-list-field__ul", children: [suggestions.map((element, index) => (_jsx("li", { className: "rls-list-field__element", tabIndex: -1, onClick: onClickItem(element), onKeyDown: onKeydownItem(element), children: _jsx(RlsBallot, { subtitle: element.subtitle, img: element.img, initials: element.initials, children: element.title }) }, index))), !suggestions.length && (_jsx("li", { className: "rls-list-field__empty", children: _jsxs("div", { className: "rls-list-field__empty__description", children: [_jsx("label", { className: "label-bold truncate", children: "Selecci\u00F3n no disponible" }), _jsx("p", { className: "caption-regular", children: "Lo sentimos, en el momento no hay elementos en el listado" })] }) }))] }) }), _jsx("div", { className: "rls-list-field__backdrop", onClick: onClickBackdrop })] })] }));
|
|
8
|
+
export function RlsSelectFieldTemplate({ suggestions, children, disabled, formControl, placeholder, rlsTheme, onSelect, onValue, render }) {
|
|
9
|
+
const { listControl, onBlurInput, onClickAction, onClickBackdrop, onClickElement, onClickInput, onFocusInput, onKeydownElement, onKeydownInput } = useSelectField({
|
|
10
|
+
suggestions,
|
|
11
|
+
disabled,
|
|
12
|
+
formControl,
|
|
13
|
+
onSelect,
|
|
14
|
+
onValue
|
|
15
|
+
});
|
|
16
|
+
return (_jsxs("div", { ref: listControl.boxContentRef, className: renderClassStatus('rls-box-field', { focused: listControl.focused, disabled }, 'rls-select-field rls-list-field'), "rls-theme": rlsTheme, children: [children && _jsx("label", { className: "rls-box-field__label", children: children }), _jsx("div", { className: "rls-box-field__component", children: _jsxs("div", { className: "rls-box-field__body", children: [_jsx("input", { ref: listControl.inputRef, className: "rls-list-field__control", readOnly: true, disabled: disabled, placeholder: placeholder, value: listControl.value, onFocus: onFocusInput, onBlur: onBlurInput, onClick: onClickInput, onKeyDown: onKeydownInput }), _jsx("button", { className: renderClassStatus('rls-list-field__action', {
|
|
17
|
+
visible: listControl.visible
|
|
18
|
+
}), disabled: disabled, onClick: onClickAction, children: _jsx(RlsIcon, { value: "arrow-ios-down" }) })] }) }), formControl?.touched && formControl?.error && (_jsx("div", { className: "rls-box-field__error", children: _jsx(RlsMessageIcon, { icon: "alert-triangle", rlsTheme: "danger", children: formControl.error.message }) })), _jsxs("div", { className: renderClassStatus('rls-list-field__suggestions', {
|
|
19
|
+
visible: listControl.visible,
|
|
20
|
+
hide: !listControl.visible,
|
|
21
|
+
higher: listControl.higher
|
|
22
|
+
}), children: [_jsx("div", { className: "rls-list-field__suggestions__body", children: _jsxs("ul", { ref: listControl.listRef, className: "rls-list-field__ul", children: [suggestions.map((element, index) => (_jsx("li", { className: "rls-list-field__element", tabIndex: -1, onClick: onClickElement(element), onKeyDown: onKeydownElement(element), children: render(element) }, index))), !suggestions.length && (_jsx("li", { className: "rls-list-field__empty", children: _jsxs("div", { className: "rls-list-field__empty__description", children: [_jsx("label", { className: "label-bold truncate", children: reactI18n('listEmptyTitle') }), _jsx("p", { className: "caption-regular", children: reactI18n('listEmptyDescription') })] }) }))] }) }), _jsx("div", { className: "rls-list-field__backdrop", onClick: onClickBackdrop })] })] }));
|
|
23
|
+
}
|
|
24
|
+
export function RlsSelectField(props) {
|
|
25
|
+
return (_jsx(RlsSelectFieldTemplate, { ...props, render: (element) => (_jsx(RlsBallot, { subtitle: element.subtitle, img: element.img, initials: element.initials, children: element.title })) }));
|
|
101
26
|
}
|
|
102
27
|
//# sourceMappingURL=SelectField.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SelectField.js","sourceRoot":"","sources":["../../../../../src/components/organisms/SelectField/SelectField.tsx"],"names":[],"mappings":";
|
|
1
|
+
{"version":3,"file":"SelectField.js","sourceRoot":"","sources":["../../../../../src/components/organisms/SelectField/SelectField.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { ReactControl } from '@rolster/react-forms';
|
|
2
|
+
import { KeyboardEvent, KeyboardEventHandler, MouseEventHandler } from 'react';
|
|
3
|
+
import { ListControl } from '../../../hooks';
|
|
4
|
+
import { AbstractListElement as Element } from '../../../models';
|
|
5
|
+
export interface SelectControl<T = unknown, E extends Element<T> = Element<T>> {
|
|
6
|
+
listControl: ListControl<T>;
|
|
7
|
+
onBlurInput: () => void;
|
|
8
|
+
onClickAction: () => void;
|
|
9
|
+
onClickBackdrop: () => void;
|
|
10
|
+
onClickElement: (element: E) => MouseEventHandler;
|
|
11
|
+
onClickInput: () => void;
|
|
12
|
+
onFocusInput: () => void;
|
|
13
|
+
onKeydownElement: (element: E) => KeyboardEventHandler;
|
|
14
|
+
onKeydownInput: (event: KeyboardEvent) => void;
|
|
15
|
+
}
|
|
16
|
+
interface SelectProps<T = unknown, E extends Element<T> = Element<T>> {
|
|
17
|
+
suggestions: E[];
|
|
18
|
+
disabled?: boolean;
|
|
19
|
+
formControl?: ReactControl<HTMLElement, T>;
|
|
20
|
+
onSelect?: (value: T) => void;
|
|
21
|
+
onValue?: (value?: T) => void;
|
|
22
|
+
}
|
|
23
|
+
export declare function useSelectField<T = unknown, E extends Element<T> = Element<T>>({ suggestions, formControl, onSelect, onValue }: SelectProps<T, E>): SelectControl<T, E>;
|
|
24
|
+
export {};
|
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
import { useEffect, useState } from 'react';
|
|
2
|
+
import { useListControl } from '../../../hooks';
|
|
3
|
+
export function useSelectField({ suggestions, formControl, onSelect, onValue }) {
|
|
4
|
+
const listControl = useListControl({ suggestions, formControl });
|
|
5
|
+
const { collection, inputRef, visible, setFocused, setValue, setVisible, navigationElement, navigationInput } = listControl;
|
|
6
|
+
const [changeInternal, setChangeInternal] = useState(false);
|
|
7
|
+
useEffect(() => {
|
|
8
|
+
if (!changeInternal) {
|
|
9
|
+
redefineDescription();
|
|
10
|
+
}
|
|
11
|
+
setChangeInternal(false);
|
|
12
|
+
}, [formControl?.state]);
|
|
13
|
+
useEffect(() => {
|
|
14
|
+
redefineDescription();
|
|
15
|
+
}, [collection]);
|
|
16
|
+
function redefineDescription() {
|
|
17
|
+
const element = formControl?.state && collection.find(formControl?.state);
|
|
18
|
+
setValue(element?.description || '');
|
|
19
|
+
}
|
|
20
|
+
function onFocusInput() {
|
|
21
|
+
setFocused(true);
|
|
22
|
+
}
|
|
23
|
+
function onBlurInput() {
|
|
24
|
+
setFocused(false);
|
|
25
|
+
}
|
|
26
|
+
function onClickControl() {
|
|
27
|
+
setVisible(true);
|
|
28
|
+
}
|
|
29
|
+
function onKeydownInput(event) {
|
|
30
|
+
switch (event.code) {
|
|
31
|
+
case 'Space':
|
|
32
|
+
setVisible(true);
|
|
33
|
+
break;
|
|
34
|
+
case 'Enter':
|
|
35
|
+
setVisible(true);
|
|
36
|
+
break;
|
|
37
|
+
case 'Escape':
|
|
38
|
+
setVisible(false);
|
|
39
|
+
break;
|
|
40
|
+
case 'Tab':
|
|
41
|
+
setVisible(false);
|
|
42
|
+
break;
|
|
43
|
+
default:
|
|
44
|
+
navigationInput(event);
|
|
45
|
+
break;
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
function onClickAction() {
|
|
49
|
+
const newVisible = !visible;
|
|
50
|
+
setVisible(newVisible);
|
|
51
|
+
if (newVisible) {
|
|
52
|
+
inputRef?.current?.focus();
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
function onClickBackdrop() {
|
|
56
|
+
setVisible(false);
|
|
57
|
+
}
|
|
58
|
+
function onClickElement(element) {
|
|
59
|
+
return () => {
|
|
60
|
+
onChange(element);
|
|
61
|
+
};
|
|
62
|
+
}
|
|
63
|
+
function onKeydownElement(element) {
|
|
64
|
+
return (event) => {
|
|
65
|
+
switch (event.code) {
|
|
66
|
+
case 'Enter':
|
|
67
|
+
onChange(element);
|
|
68
|
+
break;
|
|
69
|
+
default:
|
|
70
|
+
navigationElement(event);
|
|
71
|
+
break;
|
|
72
|
+
}
|
|
73
|
+
};
|
|
74
|
+
}
|
|
75
|
+
function onChange({ description, value }) {
|
|
76
|
+
inputRef?.current?.focus();
|
|
77
|
+
setVisible(false);
|
|
78
|
+
if (onSelect) {
|
|
79
|
+
onSelect(value);
|
|
80
|
+
}
|
|
81
|
+
else {
|
|
82
|
+
if (formControl) {
|
|
83
|
+
setChangeInternal(true);
|
|
84
|
+
formControl.setState(value);
|
|
85
|
+
}
|
|
86
|
+
setValue(description);
|
|
87
|
+
}
|
|
88
|
+
if (onValue) {
|
|
89
|
+
onValue(value);
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
return {
|
|
93
|
+
listControl,
|
|
94
|
+
onBlurInput,
|
|
95
|
+
onClickAction,
|
|
96
|
+
onClickBackdrop,
|
|
97
|
+
onClickInput: onClickControl,
|
|
98
|
+
onClickElement,
|
|
99
|
+
onFocusInput,
|
|
100
|
+
onKeydownElement,
|
|
101
|
+
onKeydownInput
|
|
102
|
+
};
|
|
103
|
+
}
|
|
104
|
+
//# sourceMappingURL=select-field.hook.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"select-field.hook.js","sourceRoot":"","sources":["../../../../../src/components/organisms/SelectField/select-field.hook.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,25 +1,25 @@
|
|
|
1
1
|
import { ReactControl } from '@rolster/react-forms';
|
|
2
2
|
import { Dispatch, KeyboardEvent, RefObject, SetStateAction } from 'react';
|
|
3
|
-
import {
|
|
4
|
-
interface ListControl<T = unknown> {
|
|
5
|
-
active: boolean;
|
|
3
|
+
import { AbstractListElement, ListCollection } from '../models';
|
|
4
|
+
export interface ListControl<T = unknown> {
|
|
6
5
|
boxContentRef: RefObject<HTMLDivElement>;
|
|
7
|
-
collection:
|
|
6
|
+
collection: ListCollection<T>;
|
|
7
|
+
focused: boolean;
|
|
8
8
|
higher: boolean;
|
|
9
9
|
inputRef: RefObject<HTMLInputElement>;
|
|
10
10
|
listRef: RefObject<HTMLUListElement>;
|
|
11
|
+
value: string;
|
|
12
|
+
visible: boolean;
|
|
11
13
|
navigationElement: (event: KeyboardEvent) => void;
|
|
12
14
|
navigationInput: (event: KeyboardEvent) => void;
|
|
13
|
-
|
|
15
|
+
setFocused: Dispatch<SetStateAction<boolean>>;
|
|
14
16
|
setValue: Dispatch<SetStateAction<string>>;
|
|
15
17
|
setVisible: Dispatch<SetStateAction<boolean>>;
|
|
16
|
-
value: string;
|
|
17
|
-
visible: boolean;
|
|
18
18
|
}
|
|
19
19
|
interface ListControlProps<T = unknown> {
|
|
20
|
-
suggestions:
|
|
20
|
+
suggestions: AbstractListElement<T>[];
|
|
21
21
|
formControl?: ReactControl<HTMLElement, T>;
|
|
22
|
-
|
|
22
|
+
withHigher?: boolean;
|
|
23
23
|
}
|
|
24
|
-
export declare function useListControl<T = unknown>({ suggestions, formControl,
|
|
24
|
+
export declare function useListControl<T = unknown>({ suggestions, formControl, withHigher }: ListControlProps<T>): ListControl<T>;
|
|
25
25
|
export {};
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { useEffect, useRef, useState } from 'react';
|
|
2
|
-
import {
|
|
2
|
+
import { ListCollection } from '../models';
|
|
3
3
|
const classElement = '.rls-list-field__element';
|
|
4
4
|
const MAX_POSITION_VISIBLE = 4;
|
|
5
5
|
const LIST_SIZE_REM = 16;
|
|
@@ -7,16 +7,16 @@ const ELEMENT_SIZE_REM = 4;
|
|
|
7
7
|
const BASE_SIZE_PX = 16;
|
|
8
8
|
const ELEMENT_SIZE_PX = BASE_SIZE_PX * ELEMENT_SIZE_REM;
|
|
9
9
|
const MAZ_LIST_SIZE_PX = BASE_SIZE_PX * LIST_SIZE_REM;
|
|
10
|
-
export function useListControl({ suggestions, formControl,
|
|
10
|
+
export function useListControl({ suggestions, formControl, withHigher = false }) {
|
|
11
11
|
const boxContentRef = useRef(null);
|
|
12
12
|
const listRef = useRef(null);
|
|
13
13
|
const inputRef = useRef(null);
|
|
14
|
-
const [collection, setCollection] = useState(new
|
|
15
|
-
const [active, setActive] = useState(false);
|
|
16
|
-
const [visible, setVisible] = useState(false);
|
|
17
|
-
const [opened, setOpened] = useState(false);
|
|
14
|
+
const [collection, setCollection] = useState(new ListCollection([]));
|
|
18
15
|
const [value, setValue] = useState('');
|
|
16
|
+
const [opened, setOpened] = useState(false);
|
|
17
|
+
const [visible, setVisible] = useState(false);
|
|
19
18
|
const [higher, setHigher] = useState(false);
|
|
19
|
+
const [focused, setFocused] = useState(false);
|
|
20
20
|
const [positionElement, setPositionElement] = useState(0);
|
|
21
21
|
const [listElements, setListElements] = useState(undefined);
|
|
22
22
|
useEffect(() => {
|
|
@@ -40,7 +40,7 @@ export function useListControl({ suggestions, formControl, ignoreHigher = false
|
|
|
40
40
|
setLocationList();
|
|
41
41
|
}, [visible]);
|
|
42
42
|
useEffect(() => {
|
|
43
|
-
setCollection(new
|
|
43
|
+
setCollection(new ListCollection(suggestions));
|
|
44
44
|
}, [suggestions]);
|
|
45
45
|
function setLocationList() {
|
|
46
46
|
if (boxContentRef?.current) {
|
|
@@ -58,7 +58,7 @@ export function useListControl({ suggestions, formControl, ignoreHigher = false
|
|
|
58
58
|
}
|
|
59
59
|
break;
|
|
60
60
|
case 'ArrowDown':
|
|
61
|
-
if (visible && (
|
|
61
|
+
if (visible && (withHigher || !higher)) {
|
|
62
62
|
navigationInputDown();
|
|
63
63
|
}
|
|
64
64
|
break;
|
|
@@ -112,7 +112,7 @@ export function useListControl({ suggestions, formControl, ignoreHigher = false
|
|
|
112
112
|
setPositionElement(newPosition);
|
|
113
113
|
listElements?.item(newPosition).focus();
|
|
114
114
|
}
|
|
115
|
-
else if (
|
|
115
|
+
else if (withHigher || !higher) {
|
|
116
116
|
inputRef?.current?.focus();
|
|
117
117
|
}
|
|
118
118
|
}
|
|
@@ -123,24 +123,24 @@ export function useListControl({ suggestions, formControl, ignoreHigher = false
|
|
|
123
123
|
setPositionElement(newPosition);
|
|
124
124
|
listElements?.item(newPosition).focus();
|
|
125
125
|
}
|
|
126
|
-
else if (higher && !
|
|
126
|
+
else if (higher && !withHigher) {
|
|
127
127
|
inputRef?.current?.focus();
|
|
128
128
|
}
|
|
129
129
|
}
|
|
130
130
|
return {
|
|
131
|
-
active,
|
|
132
131
|
boxContentRef,
|
|
133
132
|
collection,
|
|
133
|
+
focused,
|
|
134
134
|
higher,
|
|
135
135
|
inputRef,
|
|
136
136
|
listRef,
|
|
137
|
+
value,
|
|
138
|
+
visible,
|
|
137
139
|
navigationElement,
|
|
138
140
|
navigationInput,
|
|
139
|
-
|
|
141
|
+
setFocused,
|
|
140
142
|
setValue,
|
|
141
|
-
setVisible
|
|
142
|
-
value,
|
|
143
|
-
visible
|
|
143
|
+
setVisible
|
|
144
144
|
};
|
|
145
145
|
}
|
|
146
146
|
//# sourceMappingURL=list-control.hook.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"list-control.hook.js","sourceRoot":"","sources":["../../../src/hooks/list-control.hook.ts"],"names":[],"mappings":"AACA,OAAO,EAKL,SAAS,EACT,MAAM,EACN,QAAQ,EACT,MAAM,OAAO,CAAC;AACf,OAAO,
|
|
1
|
+
{"version":3,"file":"list-control.hook.js","sourceRoot":"","sources":["../../../src/hooks/list-control.hook.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
declare const reactI18n: import("@rolster/i18n").I18nTranslate<{
|
|
2
|
+
confirmationActionApproved: string;
|
|
3
|
+
dateActionCancel: string;
|
|
4
|
+
dateActionSelect: string;
|
|
5
|
+
dateActionToday: string;
|
|
6
|
+
listEmptyDescription: string;
|
|
7
|
+
listEmptyTitle: string;
|
|
8
|
+
listInputPlaceholder: string;
|
|
9
|
+
} | {
|
|
10
|
+
confirmationActionApproved: string;
|
|
11
|
+
dateActionCancel: string;
|
|
12
|
+
dateActionSelect: string;
|
|
13
|
+
dateActionToday: string;
|
|
14
|
+
listEmptyDescription: string;
|
|
15
|
+
listEmptyTitle: string;
|
|
16
|
+
listInputPlaceholder: string;
|
|
17
|
+
}>;
|
|
18
|
+
export default reactI18n;
|
package/dist/esm/i18n.js
ADDED
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { i18n } from '@rolster/i18n';
|
|
2
|
+
const reactI18n = i18n({
|
|
3
|
+
es: {
|
|
4
|
+
confirmationActionApproved: 'Aceptar',
|
|
5
|
+
dateActionCancel: 'Cancelar',
|
|
6
|
+
dateActionSelect: 'Establecer',
|
|
7
|
+
dateActionToday: 'Hoy',
|
|
8
|
+
listEmptyDescription: 'Lo sentimos, en el momento no hay elementos en el listado',
|
|
9
|
+
listEmptyTitle: 'Selección no disponible',
|
|
10
|
+
listInputPlaceholder: 'Buscar...'
|
|
11
|
+
},
|
|
12
|
+
en: {
|
|
13
|
+
confirmationActionApproved: 'Approved',
|
|
14
|
+
dateActionCancel: 'Cancel',
|
|
15
|
+
dateActionSelect: 'Select',
|
|
16
|
+
dateActionToday: 'Today',
|
|
17
|
+
listEmptyDescription: 'Sorry, there are currently no items in the list',
|
|
18
|
+
listEmptyTitle: 'Selection not available',
|
|
19
|
+
listInputPlaceholder: 'Search...'
|
|
20
|
+
}
|
|
21
|
+
});
|
|
22
|
+
export default reactI18n;
|
|
23
|
+
//# sourceMappingURL=i18n.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"i18n.js","sourceRoot":"","sources":["../../src/i18n.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAErC,MAAM,SAAS,GAAG,IAAI,CAAC;IACrB,EAAE,EAAE;QACF,0BAA0B,EAAE,SAAS;QACrC,gBAAgB,EAAE,UAAU;QAC5B,gBAAgB,EAAE,YAAY;QAC9B,eAAe,EAAE,KAAK;QACtB,oBAAoB,EAClB,2DAA2D;QAC7D,cAAc,EAAE,yBAAyB;QACzC,oBAAoB,EAAE,WAAW;KAClC;IACD,EAAE,EAAE;QACF,0BAA0B,EAAE,UAAU;QACtC,gBAAgB,EAAE,QAAQ;QAC1B,gBAAgB,EAAE,QAAQ;QAC1B,eAAe,EAAE,OAAO;QACxB,oBAAoB,EAAE,iDAAiD;QACvE,cAAc,EAAE,yBAAyB;QACzC,oBAAoB,EAAE,WAAW;KAClC;CACF,CAAC,CAAC;AAEH,eAAe,SAAS,CAAC"}
|
package/dist/esm/models.d.ts
CHANGED
|
@@ -1,18 +1,29 @@
|
|
|
1
|
-
export interface
|
|
1
|
+
export interface AbstractListElement<T = unknown> {
|
|
2
2
|
description: string;
|
|
3
|
-
title: string;
|
|
4
3
|
value: T;
|
|
4
|
+
compareTo(value: T): boolean;
|
|
5
|
+
}
|
|
6
|
+
export interface AbstractAutocompleteElement<T = unknown> extends AbstractListElement<T> {
|
|
7
|
+
hasCoincidence(pattern: string): boolean;
|
|
8
|
+
}
|
|
9
|
+
export interface ListElement<T = unknown> extends AbstractListElement<T> {
|
|
10
|
+
title: string;
|
|
11
|
+
code?: string;
|
|
12
|
+
img?: string;
|
|
13
|
+
initials?: string;
|
|
14
|
+
subtitle?: string;
|
|
15
|
+
}
|
|
16
|
+
export interface AutocompleteElement<T = unknown> extends AbstractAutocompleteElement<T> {
|
|
17
|
+
title: string;
|
|
5
18
|
code?: string;
|
|
6
19
|
img?: string;
|
|
7
20
|
initials?: string;
|
|
8
21
|
subtitle?: string;
|
|
9
|
-
compareTo(value: T): boolean;
|
|
10
|
-
hasCoincidence(pattern: string): boolean;
|
|
11
22
|
}
|
|
12
|
-
export declare class
|
|
13
|
-
readonly value:
|
|
14
|
-
constructor(value:
|
|
15
|
-
|
|
23
|
+
export declare class ListCollection<T = unknown> {
|
|
24
|
+
readonly value: AbstractListElement<T>[];
|
|
25
|
+
constructor(value: AbstractListElement<T>[]);
|
|
26
|
+
find(element: T): Undefined<AbstractListElement<T>>;
|
|
16
27
|
}
|
|
17
28
|
export interface DayState {
|
|
18
29
|
value?: number;
|
package/dist/esm/models.js
CHANGED
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
import { formatDate, isAfter, isBefore, normalizeMinTime, timeDifference } from '@rolster/helpers-date';
|
|
2
|
-
const
|
|
3
|
-
export class
|
|
2
|
+
const DATE_FORMAT = '{dd}/{mm}/{aa}';
|
|
3
|
+
export class ListCollection {
|
|
4
4
|
constructor(value) {
|
|
5
5
|
this.value = value;
|
|
6
6
|
}
|
|
7
|
-
|
|
8
|
-
return this.value.find((
|
|
7
|
+
find(element) {
|
|
8
|
+
return this.value.find((current) => current.compareTo(element));
|
|
9
9
|
}
|
|
10
10
|
}
|
|
11
11
|
export class DateRange {
|
|
@@ -17,8 +17,8 @@ export class DateRange {
|
|
|
17
17
|
else {
|
|
18
18
|
this.maxDate = normalizeMinTime(minDate);
|
|
19
19
|
}
|
|
20
|
-
const minFormat = formatDate(this.minDate,
|
|
21
|
-
const maxFormat = formatDate(this.maxDate,
|
|
20
|
+
const minFormat = formatDate(this.minDate, DATE_FORMAT);
|
|
21
|
+
const maxFormat = formatDate(this.maxDate, DATE_FORMAT);
|
|
22
22
|
this.description = `${minFormat} - ${maxFormat}`;
|
|
23
23
|
}
|
|
24
24
|
recalculate(date) {
|
package/dist/esm/models.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"models.js","sourceRoot":"","sources":["../../src/models.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,UAAU,EACV,OAAO,EACP,QAAQ,EACR,gBAAgB,EAChB,cAAc,EACf,MAAM,uBAAuB,CAAC;AAE/B,MAAM,
|
|
1
|
+
{"version":3,"file":"models.js","sourceRoot":"","sources":["../../src/models.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,UAAU,EACV,OAAO,EACP,QAAQ,EACR,gBAAgB,EAChB,cAAc,EACf,MAAM,uBAAuB,CAAC;AAE/B,MAAM,WAAW,GAAG,gBAAgB,CAAC;AA8BrC,MAAM,OAAO,cAAc;IACzB,YAA4B,KAA+B;QAA/B,UAAK,GAAL,KAAK,CAA0B;IAAG,CAAC;IAExD,IAAI,CAAC,OAAU;QACpB,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC;IAClE,CAAC;CACF;AAsCD,MAAM,OAAO,SAAS;IAOpB,YAAY,OAAa,EAAE,OAAc;QACvC,IAAI,CAAC,OAAO,GAAG,gBAAgB,CAAC,OAAO,CAAC,CAAC;QAEzC,IAAI,OAAO,IAAI,QAAQ,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC;YAC1C,IAAI,CAAC,OAAO,GAAG,gBAAgB,CAAC,OAAO,CAAC,CAAC;QAC3C,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,OAAO,GAAG,gBAAgB,CAAC,OAAO,CAAC,CAAC;QAC3C,CAAC;QAED,MAAM,SAAS,GAAG,UAAU,CAAC,IAAI,CAAC,OAAO,EAAE,WAAW,CAAC,CAAC;QACxD,MAAM,SAAS,GAAG,UAAU,CAAC,IAAI,CAAC,OAAO,EAAE,WAAW,CAAC,CAAC;QAExD,IAAI,CAAC,WAAW,GAAG,GAAG,SAAS,MAAM,SAAS,EAAE,CAAC;IACnD,CAAC;IAEM,WAAW,CAAC,IAAU;QAC3B,IAAI,QAAQ,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,EAAE,CAAC;YACjC,OAAO,IAAI,SAAS,CAAC,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;QAC3C,CAAC;QAED,IAAI,OAAO,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,EAAE,CAAC;YAChC,OAAO,IAAI,SAAS,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;QAC3C,CAAC;QAED,MAAM,aAAa,GAAG,cAAc,CAAC,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;QACzD,MAAM,aAAa,GAAG,cAAc,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;QAEzD,OAAO,aAAa,GAAG,aAAa;YAClC,CAAC,CAAC,IAAI,SAAS,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC;YACnC,CAAC,CAAC,IAAI,SAAS,CAAC,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;IACxC,CAAC;IAEM,MAAM,CAAC,GAAG;QACf,OAAO,IAAI,SAAS,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC;IACnC,CAAC;CACF"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@rolster/react-components",
|
|
3
|
-
"version": "18.
|
|
3
|
+
"version": "18.10.0",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"description": "Package containing UI components for React Project.",
|
|
6
6
|
"module": "dist/esm/index.js",
|
|
@@ -38,6 +38,7 @@
|
|
|
38
38
|
"@rolster/helpers-date": "^1.2.0",
|
|
39
39
|
"@rolster/helpers-forms": "^1.9.0",
|
|
40
40
|
"@rolster/helpers-string": "^1.1.1",
|
|
41
|
+
"@rolster/i18n": "^1.3.2",
|
|
41
42
|
"@rolster/react-forms": "^18.0.2",
|
|
42
43
|
"@rolster/validators": "^1.0.3",
|
|
43
44
|
"lottie-react": "^2.4.0",
|