linear-react-components-ui 1.1.20-beta.15 → 1.1.20-beta.16
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/lib/alerts/BaseAlert.js +1 -1
- package/lib/alerts/Message.js +1 -1
- package/lib/assets/styles/input.scss +2 -2
- package/lib/assets/styles/popover.scss +3 -0
- package/lib/assets/styles/wizard.scss +1 -3
- package/lib/avatar/index.js +9 -8
- package/lib/badge/index.js +4 -4
- package/lib/buttons/DangerButton.js +1 -1
- package/lib/buttons/DefaultButton.js +11 -2
- package/lib/buttons/InfoButton.js +1 -1
- package/lib/buttons/PrimaryButton.js +1 -1
- package/lib/buttons/SuccessButton.js +1 -1
- package/lib/buttons/WarningButton.js +1 -1
- package/lib/buttons/button_container/index.js +1 -1
- package/lib/buttons/split_button/index.js +1 -1
- package/lib/calendar/base/Day.js +1 -1
- package/lib/calendar/base/Month.js +1 -1
- package/lib/calendar/base/helpers.js +2 -2
- package/lib/calendar/base/index.js +1 -1
- package/lib/checkbox/index.js +46 -19
- package/lib/checkbox/types.d.ts +4 -0
- package/lib/dialog/Custom.js +1 -1
- package/lib/dialog/base/Content.js +1 -1
- package/lib/dialog/base/Header.js +2 -2
- package/lib/dialog/base/index.js +3 -4
- package/lib/dialog/form/index.js +1 -1
- package/lib/dialog/types.d.ts +0 -2
- package/lib/dialog/wizard/index.d.ts +1 -1
- package/lib/dialog/wizard/index.js +4 -8
- package/lib/dialog/wizard/progressbar.js +1 -1
- package/lib/dialog/wizard/step.js +1 -1
- package/lib/drawer/Drawer.js +3 -3
- package/lib/drawer/Header.js +1 -1
- package/lib/dropdown/Popup.js +6 -6
- package/lib/dropdown/helper.js +1 -1
- package/lib/dropdown/withDropdown.js +2 -2
- package/lib/fieldset/index.js +7 -7
- package/lib/form/FieldArray.js +1 -1
- package/lib/form/FieldNumber.js +3 -3
- package/lib/form/FieldPeriod.js +2 -2
- package/lib/form/index.js +2 -2
- package/lib/form/types.d.ts +14 -1
- package/lib/gridlayout/GridCol.js +5 -5
- package/lib/gridlayout/GridRow.js +4 -1
- package/lib/hint/index.js +7 -1
- package/lib/icons/index.js +24 -27
- package/lib/inputs/base/InputTextBase.js +39 -15
- package/lib/inputs/base/Label.js +1 -1
- package/lib/inputs/base/helpers.js +7 -3
- package/lib/inputs/base/types.d.ts +3 -0
- package/lib/inputs/color/types.d.ts +5 -0
- package/lib/inputs/date/helpers.js +4 -1
- package/lib/inputs/date/index.js +9 -15
- package/lib/inputs/date/types.d.ts +4 -0
- package/lib/inputs/errorMessage/index.js +1 -1
- package/lib/inputs/file/DefaultFile.js +5 -6
- package/lib/inputs/file/DragDropFile.js +17 -18
- package/lib/inputs/file/File.js +3 -4
- package/lib/inputs/file/types.d.ts +3 -0
- package/lib/inputs/mask/BaseMask.js +1 -1
- package/lib/inputs/mask/helpers.d.ts +4 -0
- package/lib/inputs/mask/types.d.ts +4 -0
- package/lib/inputs/multiSelect/Dropdown.js +9 -10
- package/lib/inputs/multiSelect/helper.js +1 -2
- package/lib/inputs/multiSelect/index.js +7 -9
- package/lib/inputs/multiSelect/types.d.ts +4 -0
- package/lib/inputs/number/BaseNumber.d.ts +1 -1
- package/lib/inputs/number/Currency.d.ts +1 -1
- package/lib/inputs/number/Decimal.d.ts +1 -1
- package/lib/inputs/number/index.d.ts +1 -1
- package/lib/inputs/number/index.js +7 -3
- package/lib/inputs/number/types.d.ts +14 -2
- package/lib/inputs/period/PeriodList.js +1 -1
- package/lib/inputs/period/helper.js +3 -1
- package/lib/inputs/period/index.js +40 -18
- package/lib/inputs/period/types.d.ts +3 -0
- package/lib/inputs/search/index.js +1 -1
- package/lib/inputs/select/Dropdown.js +1 -1
- package/lib/inputs/select/helper.js +10 -13
- package/lib/inputs/select/multiple/Selecteds.js +1 -1
- package/lib/inputs/select/multiple/index.js +18 -16
- package/lib/inputs/select/simple/index.js +10 -17
- package/lib/inputs/select/types.d.ts +6 -0
- package/lib/inputs/textarea/index.js +1 -1
- package/lib/internals/withTooltip.js +9 -9
- package/lib/labelMessages/index.js +4 -3
- package/lib/labels/DefaultLabel.js +4 -1
- package/lib/labels/label_container/index.js +1 -1
- package/lib/list/Header.js +1 -1
- package/lib/list/Item.js +9 -7
- package/lib/list/index.js +3 -2
- package/lib/menus/float/MenuItem.js +2 -2
- package/lib/menus/float/SubMenuContainer.js +1 -1
- package/lib/menus/float/index.js +1 -1
- package/lib/menus/sidenav/ExpandMenu.js +1 -1
- package/lib/menus/sidenav/NavMenuGroup.js +1 -1
- package/lib/menus/sidenav/NavMenuItem.js +7 -9
- package/lib/menus/sidenav/NavSubMenuItem.js +1 -1
- package/lib/menus/sidenav/helpers.js +1 -1
- package/lib/menus/sidenav/index.js +5 -5
- package/lib/panel/Content.js +5 -7
- package/lib/panel/Default.js +2 -2
- package/lib/panel/Header.js +3 -3
- package/lib/permissionValidations.js +1 -1
- package/lib/popover/index.js +4 -6
- package/lib/popover/types.d.ts +2 -1
- package/lib/progress/Bar.js +6 -6
- package/lib/radio/index.d.ts +1 -1
- package/lib/radio/index.js +34 -3
- package/lib/radio/types.d.ts +6 -0
- package/lib/shortcuts/index.js +1 -1
- package/lib/skeleton/SkeletonContainer.js +2 -1
- package/lib/skeleton/index.js +4 -1
- package/lib/spinner/index.js +2 -2
- package/lib/split/Split.js +1 -1
- package/lib/split/SplitSide.js +3 -3
- package/lib/table/Body.js +3 -3
- package/lib/table/Header.js +8 -11
- package/lib/table/HeaderColumn.js +1 -1
- package/lib/table/Row.js +3 -3
- package/lib/table/RowColumn.js +1 -1
- package/lib/table/index.js +6 -1
- package/lib/tabs/DropdownTabs.js +1 -1
- package/lib/tabs/Menu.js +1 -1
- package/lib/tabs/MenuTabs.js +2 -2
- package/lib/tabs/Panel.js +5 -7
- package/lib/tabs/context.js +3 -6
- package/lib/textContent/index.d.ts +18 -4
- package/lib/textContent/index.js +15 -5
- package/lib/toolbar/ButtonBar.js +1 -1
- package/lib/toolbar/index.js +1 -1
- package/lib/tooltip/index.js +7 -7
- package/lib/treetable/Body.js +1 -1
- package/lib/treetable/Header.js +2 -2
- package/lib/treetable/Row.js +8 -8
- package/lib/treeview/Header.js +1 -1
- package/lib/treeview/Node.js +5 -5
- package/lib/treeview/index.js +4 -4
- package/lib/uitour/index.js +6 -8
- package/package.json +1 -1
- package/lib/checkbox/Label.d.ts +0 -11
- package/lib/checkbox/Label.js +0 -31
|
@@ -38,7 +38,7 @@ const withDropdown = WrappedComponent => {
|
|
|
38
38
|
const {
|
|
39
39
|
target
|
|
40
40
|
} = event;
|
|
41
|
-
if (popupRef
|
|
41
|
+
if (popupRef?.current && target !== popupRef?.current && !event.composedPath().includes(popupRef.current) && wrappedComponentRef.current !== target) {
|
|
42
42
|
setOpened(false);
|
|
43
43
|
}
|
|
44
44
|
};
|
|
@@ -86,7 +86,7 @@ const withDropdown = WrappedComponent => {
|
|
|
86
86
|
value: contextValues
|
|
87
87
|
}, /*#__PURE__*/_react.default.createElement(WrappedComponent, _extends({}, props, newProps)));
|
|
88
88
|
};
|
|
89
|
-
EnhancedComponent.displayName =
|
|
89
|
+
EnhancedComponent.displayName = `withDropdown(${getDisplayName(WrappedComponent)})`;
|
|
90
90
|
return EnhancedComponent;
|
|
91
91
|
};
|
|
92
92
|
var _default = exports.default = withDropdown;
|
package/lib/fieldset/index.js
CHANGED
|
@@ -43,9 +43,9 @@ const Fieldset = props => {
|
|
|
43
43
|
customClass,
|
|
44
44
|
hasError
|
|
45
45
|
} = _ref;
|
|
46
|
-
let cssClass =
|
|
47
|
-
if (type) cssClass =
|
|
48
|
-
if (hasError) cssClass =
|
|
46
|
+
let cssClass = `fieldset-component ${customClass}`;
|
|
47
|
+
if (type) cssClass = `${cssClass} -${type}`;
|
|
48
|
+
if (hasError) cssClass = `${cssClass} -witherror`;
|
|
49
49
|
return cssClass;
|
|
50
50
|
};
|
|
51
51
|
const getContentStyle = _ref2 => {
|
|
@@ -55,11 +55,11 @@ const Fieldset = props => {
|
|
|
55
55
|
} = _ref2;
|
|
56
56
|
if (template === 'rows') {
|
|
57
57
|
return {
|
|
58
|
-
gridTemplateRows:
|
|
58
|
+
gridTemplateRows: `repeat(${rowsCount}, 1fr)`
|
|
59
59
|
};
|
|
60
60
|
} else if (template === 'columns') {
|
|
61
61
|
return {
|
|
62
|
-
gridTemplateColumns:
|
|
62
|
+
gridTemplateColumns: `repeat(${colsCount}, 1fr)`
|
|
63
63
|
};
|
|
64
64
|
}
|
|
65
65
|
return {};
|
|
@@ -70,9 +70,9 @@ const Fieldset = props => {
|
|
|
70
70
|
}, onDenied.hideContent ? /*#__PURE__*/_react.default.createElement(_noPermission.default, null) : /*#__PURE__*/_react.default.createElement(_react.Fragment, null, title && /*#__PURE__*/_react.default.createElement("legend", {
|
|
71
71
|
style: styleTitle,
|
|
72
72
|
align: titleAlign,
|
|
73
|
-
className:
|
|
73
|
+
className: `legend ${titleCustomClass}`
|
|
74
74
|
}, leftElements, title, rightElements), /*#__PURE__*/_react.default.createElement("div", {
|
|
75
|
-
className:
|
|
75
|
+
className: `contentfieldset -template${template} `,
|
|
76
76
|
style: Object.assign(getContentStyle(props), styleContent)
|
|
77
77
|
}, children)));
|
|
78
78
|
if (onDenied.unvisible) return null;
|
package/lib/form/FieldArray.js
CHANGED
|
@@ -77,7 +77,7 @@ const FieldArray = props => {
|
|
|
77
77
|
if (!skipLabel && label) {
|
|
78
78
|
content = /*#__PURE__*/_react.default.createElement(_fieldset.default, {
|
|
79
79
|
title: label,
|
|
80
|
-
customClass:
|
|
80
|
+
customClass: `arraycontainer ${bordered && '-bordered'}`,
|
|
81
81
|
style: labelContainerStyle,
|
|
82
82
|
titleCustomClass: "label"
|
|
83
83
|
}, /*#__PURE__*/_react.default.createElement(Component, _extends({}, rest, getDefaultProps(props), {
|
package/lib/form/FieldNumber.js
CHANGED
|
@@ -31,18 +31,18 @@ const getEventProps = _ref => {
|
|
|
31
31
|
} = _ref;
|
|
32
32
|
return {
|
|
33
33
|
onBlur: e => {
|
|
34
|
-
if (
|
|
34
|
+
if (component?.name !== 'NumberField' && handlerFieldChange) handlerFieldChange(e);
|
|
35
35
|
if (validators && handlerFieldValidate) handlerFieldValidate(name, e.target.value, validators);
|
|
36
36
|
if (onBlur) onBlur(e);
|
|
37
37
|
},
|
|
38
38
|
onKeyDown: e => {
|
|
39
39
|
if ([constants.keyCodes.ENTER].includes(e.keyCode)) {
|
|
40
|
-
if (validators) handlerFieldValidate
|
|
40
|
+
if (validators) handlerFieldValidate?.(name, e.target.value, validators);
|
|
41
41
|
if (onKeyDown) onKeyDown(e);
|
|
42
42
|
}
|
|
43
43
|
},
|
|
44
44
|
onChange: e => {
|
|
45
|
-
if (
|
|
45
|
+
if (component?.name === 'NumberField') {
|
|
46
46
|
if (validators && e.target && handlerFieldValidate) {
|
|
47
47
|
handlerFieldValidate(name, e.target.value, validators);
|
|
48
48
|
}
|
package/lib/form/FieldPeriod.js
CHANGED
|
@@ -79,8 +79,8 @@ const FieldPeriod = props => {
|
|
|
79
79
|
});
|
|
80
80
|
},
|
|
81
81
|
value: {
|
|
82
|
-
initial: _lodash.default.get(data,
|
|
83
|
-
final: _lodash.default.get(data,
|
|
82
|
+
initial: _lodash.default.get(data, `${name}.${nameDateInitial}`),
|
|
83
|
+
final: _lodash.default.get(data, `${name}.${nameDateFinal}`)
|
|
84
84
|
}
|
|
85
85
|
}));
|
|
86
86
|
}
|
package/lib/form/index.js
CHANGED
|
@@ -237,7 +237,7 @@ const Form = _ref => {
|
|
|
237
237
|
}
|
|
238
238
|
}, [submitOnPressEnterKey]);
|
|
239
239
|
(0, _react.useEffect)(() => {
|
|
240
|
-
const validatorsQuantity = Object.values(fieldsValidators.current).reduce((acc, currentValue) => acc + (
|
|
240
|
+
const validatorsQuantity = Object.values(fieldsValidators.current).reduce((acc, currentValue) => acc + (currentValue?.length || 0), 0);
|
|
241
241
|
if (fieldsValidators.current && onValidateForm && oldFieldsValidatorsQuantity !== validatorsQuantity) {
|
|
242
242
|
setOldFieldsValidatorsQuantity(validatorsQuantity);
|
|
243
243
|
onValidateForm(checkIsValid(usedData, true, fieldsValidators.current));
|
|
@@ -265,7 +265,7 @@ const Form = _ref => {
|
|
|
265
265
|
style: style
|
|
266
266
|
}, formProps(), {
|
|
267
267
|
role: "presentation",
|
|
268
|
-
className:
|
|
268
|
+
className: `form-component ${customClass}`
|
|
269
269
|
}), children)), /*#__PURE__*/_react.default.createElement(_dialog.DialogQuestion, {
|
|
270
270
|
zIndex: "99999999",
|
|
271
271
|
title: securityTitle || 'Dados Alterados',
|
package/lib/form/types.d.ts
CHANGED
|
@@ -85,11 +85,16 @@ interface IFieldProps extends WithFieldProps {
|
|
|
85
85
|
autoFocus?: boolean;
|
|
86
86
|
autoCompleteMask?: 'left' | 'right';
|
|
87
87
|
mask?: string;
|
|
88
|
+
hint?: string | string[];
|
|
89
|
+
hintPosition?: 'below' | 'onLabelRight';
|
|
90
|
+
themePopover?: 'light' | 'dark';
|
|
91
|
+
popoverAlign?: 'right' | 'left';
|
|
92
|
+
displayCurrencySymbol?: boolean;
|
|
88
93
|
removeZeroLeft?: boolean;
|
|
89
94
|
textAlign?: 'left' | 'right';
|
|
90
95
|
disabled?: boolean;
|
|
91
|
-
displayCurrencySymbol?: boolean;
|
|
92
96
|
currencySymbol?: string;
|
|
97
|
+
checked?: boolean;
|
|
93
98
|
}
|
|
94
99
|
interface CustomEvent {
|
|
95
100
|
target: {
|
|
@@ -126,6 +131,10 @@ interface IFieldArrayProps extends WithFieldProps {
|
|
|
126
131
|
onBlur?: (event: ChangeEvent<HTMLInputElement>) => void;
|
|
127
132
|
handlerFieldValidate?: (name: string, value: string, validatorsArray: Validator[] | Validator) => void;
|
|
128
133
|
required?: boolean;
|
|
134
|
+
hint?: string | string[];
|
|
135
|
+
hintPosition?: 'below' | 'onLabelRight';
|
|
136
|
+
themePopover?: 'light' | 'dark';
|
|
137
|
+
popoverAlign?: 'right' | 'left';
|
|
129
138
|
}
|
|
130
139
|
type PeriodChangeEvent = {
|
|
131
140
|
initial: string;
|
|
@@ -159,6 +168,10 @@ interface IFieldPeriodProps extends WithFieldProps {
|
|
|
159
168
|
handlerFieldValidate?: (name: string, value: object, validatorsArray: PeriodValidator[] | PeriodValidator) => void;
|
|
160
169
|
onChange?: (event: PeriodChangeEvent) => PeriodChangeEvent;
|
|
161
170
|
gridLayout?: string;
|
|
171
|
+
hint?: string | string[];
|
|
172
|
+
hintPosition?: 'below' | 'onLabelRight';
|
|
173
|
+
themePopover?: 'light' | 'dark';
|
|
174
|
+
popoverAlign?: 'right' | 'left';
|
|
162
175
|
}
|
|
163
176
|
interface FormContextProps {
|
|
164
177
|
skeletonize?: boolean;
|
|
@@ -10,10 +10,10 @@ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e
|
|
|
10
10
|
const getClass = col => {
|
|
11
11
|
const cols = col ? col.split(' ') : [];
|
|
12
12
|
let classes = 'grid-container ';
|
|
13
|
-
if (cols[0]) classes +=
|
|
14
|
-
if (cols[1]) classes +=
|
|
15
|
-
if (cols[2]) classes +=
|
|
16
|
-
if (cols[3]) classes +=
|
|
13
|
+
if (cols[0]) classes += `col-xs-${cols[0]}`;
|
|
14
|
+
if (cols[1]) classes += ` col-sm-${cols[1]}`;
|
|
15
|
+
if (cols[2]) classes += ` col-md-${cols[2]}`;
|
|
16
|
+
if (cols[3]) classes += ` col-lg-${cols[3]}`;
|
|
17
17
|
return classes;
|
|
18
18
|
};
|
|
19
19
|
const GridCol = props => {
|
|
@@ -27,7 +27,7 @@ const GridCol = props => {
|
|
|
27
27
|
const gridClasses = getClass(cols || '');
|
|
28
28
|
if (!visible) return null;
|
|
29
29
|
return /*#__PURE__*/_react.default.createElement("div", {
|
|
30
|
-
className:
|
|
30
|
+
className: `${customClass} ${gridClasses}`,
|
|
31
31
|
style: style
|
|
32
32
|
}, children);
|
|
33
33
|
};
|
|
@@ -12,7 +12,10 @@ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t =
|
|
|
12
12
|
function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
|
|
13
13
|
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : i + ""; }
|
|
14
14
|
function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
|
|
15
|
-
const getClass = props =>
|
|
15
|
+
const getClass = props => `row ${props.customClass}
|
|
16
|
+
${props.withTrim && ' -withtrim'}
|
|
17
|
+
${props.verticalAlign && ` align-items-${props.verticalAlign}`}
|
|
18
|
+
${props.horizontalAlign && ` justify-content-${props.horizontalAlign}`}`;
|
|
16
19
|
const GridRow = props => {
|
|
17
20
|
const {
|
|
18
21
|
style,
|
package/lib/hint/index.js
CHANGED
|
@@ -22,7 +22,13 @@ const Hint = _ref => {
|
|
|
22
22
|
return /*#__PURE__*/_react.default.createElement("div", {
|
|
23
23
|
"aria-disabled": disabled,
|
|
24
24
|
style: style,
|
|
25
|
-
className:
|
|
25
|
+
className: `
|
|
26
|
+
hint-component
|
|
27
|
+
${customClass}
|
|
28
|
+
${skeletonize ? '-skeletonized' : ''}
|
|
29
|
+
${disabled ? '-disabled' : ''}
|
|
30
|
+
-${color}
|
|
31
|
+
`
|
|
26
32
|
}, Array.isArray(description) ? (0, _helpers.showHintList)(description) : /*#__PURE__*/_react.default.createElement("span", {
|
|
27
33
|
"aria-disabled": disabled
|
|
28
34
|
}, description));
|
package/lib/icons/index.js
CHANGED
|
@@ -34,38 +34,35 @@ const Icon = _ref => {
|
|
|
34
34
|
const isUsingColorStyle = colorStyle !== 'default';
|
|
35
35
|
const colorFromProp = isUsingColorStyle || !color ? undefined : color;
|
|
36
36
|
const refSvg = (0, _react.useRef)(null);
|
|
37
|
-
const viewBoxFromIconOrSvgStrcut = name ? listIcon[name].viewbox : svgStruct
|
|
38
|
-
const getPaths = () => name ? listIcon[name].paths : svgStruct
|
|
39
|
-
const getSvg = () => {
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
key: value
|
|
61
|
-
})));
|
|
62
|
-
};
|
|
37
|
+
const viewBoxFromIconOrSvgStrcut = name ? listIcon[name].viewbox : svgStruct?.viewbox;
|
|
38
|
+
const getPaths = () => name ? listIcon[name].paths : svgStruct?.paths;
|
|
39
|
+
const getSvg = () => /*#__PURE__*/_react.default.createElement("svg", {
|
|
40
|
+
"data-testid": "icon",
|
|
41
|
+
"data-color-style": colorStyle,
|
|
42
|
+
onClick: () => {
|
|
43
|
+
if (onClick && !disabled) onClick();
|
|
44
|
+
},
|
|
45
|
+
ref: r => {
|
|
46
|
+
refSvg.current = r;
|
|
47
|
+
},
|
|
48
|
+
width: `${size}px`,
|
|
49
|
+
height: `${size}px`,
|
|
50
|
+
fill: disabled ? disabledIconColor : colorFromProp,
|
|
51
|
+
viewBox: viewBox || viewBoxFromIconOrSvgStrcut,
|
|
52
|
+
className: `icon-component ${customClass}`,
|
|
53
|
+
pointerEvents: pointerEvents,
|
|
54
|
+
style: style
|
|
55
|
+
}, getPaths()?.map(value => /*#__PURE__*/_react.default.createElement("path", {
|
|
56
|
+
"data-testid": "icon-path",
|
|
57
|
+
d: value,
|
|
58
|
+
key: value
|
|
59
|
+
})));
|
|
63
60
|
if (color && colorStyle !== 'default') throw new Error('Expected only one of the two properties: colorStyle or color');
|
|
64
61
|
if (!name && !svgStruct) throw new Error('One of the "name" and "svgStruct" props must be filled');
|
|
65
62
|
if (!visible) return null;
|
|
66
63
|
if (!tooltip) return getSvg();
|
|
67
64
|
return /*#__PURE__*/_react.default.createElement("div", {
|
|
68
|
-
className:
|
|
65
|
+
className: `icon-component-container ${customClassForContainer}`,
|
|
69
66
|
ref: r => {
|
|
70
67
|
if (targetRef && r) targetRef(r);
|
|
71
68
|
}
|
|
@@ -13,7 +13,8 @@ var _withTooltip = _interopRequireDefault(require("../../internals/withTooltip")
|
|
|
13
13
|
var _permissionValidations = require("../../permissionValidations");
|
|
14
14
|
var _hint = _interopRequireDefault(require("../../hint"));
|
|
15
15
|
var _errorMessage = require("../errorMessage");
|
|
16
|
-
var
|
|
16
|
+
var _textContent = _interopRequireDefault(require("../../textContent"));
|
|
17
|
+
var _popover = _interopRequireDefault(require("../../popover"));
|
|
17
18
|
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
18
19
|
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
|
|
19
20
|
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
|
|
@@ -43,6 +44,7 @@ const InputTextBase = props => {
|
|
|
43
44
|
label,
|
|
44
45
|
labelUppercase,
|
|
45
46
|
hint,
|
|
47
|
+
hintPosition = 'below',
|
|
46
48
|
errorMessages,
|
|
47
49
|
visible = true,
|
|
48
50
|
permissionAttr,
|
|
@@ -68,7 +70,9 @@ const InputTextBase = props => {
|
|
|
68
70
|
onDragLeave,
|
|
69
71
|
onClick,
|
|
70
72
|
readOnlyClass,
|
|
71
|
-
autoComplete = 'on'
|
|
73
|
+
autoComplete = 'on',
|
|
74
|
+
themePopover = 'light',
|
|
75
|
+
popoverAlign = 'left'
|
|
72
76
|
} = props;
|
|
73
77
|
let propsInput;
|
|
74
78
|
const options = [_permissionValidations.OPTIONS_ON_DENIED.disabled, _permissionValidations.OPTIONS_ON_DENIED.unvisible, _permissionValidations.OPTIONS_ON_DENIED.readOnly, _permissionValidations.OPTIONS_ON_DENIED.hideContent];
|
|
@@ -118,13 +122,11 @@ const InputTextBase = props => {
|
|
|
118
122
|
if (!disableCallbacks) {
|
|
119
123
|
propsInput = _objectSpread(_objectSpread({}, propsInput), {}, {
|
|
120
124
|
onFocus: e => {
|
|
121
|
-
|
|
122
|
-
(_props$onInputReceive = props.onInputReceiveFocus) === null || _props$onInputReceive === void 0 ? void 0 : _props$onInputReceive.call(props);
|
|
125
|
+
props.onInputReceiveFocus?.();
|
|
123
126
|
if (props.onFocus) props.onFocus(e);
|
|
124
127
|
},
|
|
125
128
|
onBlur: e => {
|
|
126
|
-
|
|
127
|
-
(_props$onInputLostFoc = props.onInputLostFocus) === null || _props$onInputLostFoc === void 0 ? void 0 : _props$onInputLostFoc.call(props);
|
|
129
|
+
props.onInputLostFocus?.();
|
|
128
130
|
if (props.onBlur) props.onBlur(e);
|
|
129
131
|
},
|
|
130
132
|
onKeyDown: e => {
|
|
@@ -188,23 +190,45 @@ const InputTextBase = props => {
|
|
|
188
190
|
if (!visible || unvisible) return null;
|
|
189
191
|
return /*#__PURE__*/_react.default.createElement("div", {
|
|
190
192
|
style: style,
|
|
191
|
-
className:
|
|
193
|
+
className: `input-base-component ${skeletonize ? '-skeletonized' : ''} ${customClass}`,
|
|
192
194
|
ref: inputBaseRef
|
|
193
195
|
}, label && /*#__PURE__*/_react.default.createElement("div", {
|
|
194
196
|
className: "labelcontainer",
|
|
195
197
|
style: {
|
|
196
198
|
textAlign: textAlign === 'center' ? 'left' : textAlign
|
|
197
199
|
}
|
|
198
|
-
}, /*#__PURE__*/_react.default.createElement(
|
|
200
|
+
}, /*#__PURE__*/_react.default.createElement(_textContent.default, {
|
|
199
201
|
labelRef: labelRef,
|
|
200
|
-
label: label,
|
|
201
202
|
required: required,
|
|
203
|
+
label: label,
|
|
202
204
|
onHoverLabel: onHoverLabel,
|
|
203
|
-
|
|
205
|
+
className: customClassForLabel,
|
|
204
206
|
labelUppercase: labelUppercase,
|
|
205
|
-
tooltip:
|
|
207
|
+
tooltip: label.toString(),
|
|
206
208
|
tooltipPosition: "top"
|
|
207
|
-
})
|
|
209
|
+
}), /*#__PURE__*/_react.default.createElement("div", {
|
|
210
|
+
className: "text-content",
|
|
211
|
+
style: {
|
|
212
|
+
display: 'flex'
|
|
213
|
+
}
|
|
214
|
+
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
215
|
+
className: `label ${customClassForLabel} ${labelUppercase && ' -uppercase'}`,
|
|
216
|
+
style: {
|
|
217
|
+
alignSelf: 'center'
|
|
218
|
+
}
|
|
219
|
+
}, label, required && /*#__PURE__*/_react.default.createElement("span", {
|
|
220
|
+
className: "-requiredlabel"
|
|
221
|
+
}, "*"), !!hint && hintPosition === 'onLabelRight' && !skeletonize && /*#__PURE__*/_react.default.createElement(_popover.default, {
|
|
222
|
+
theme: themePopover,
|
|
223
|
+
align: popoverAlign,
|
|
224
|
+
customClass: "-hint",
|
|
225
|
+
iconColor: "#03bde2",
|
|
226
|
+
style: {
|
|
227
|
+
margin: '0px 5px',
|
|
228
|
+
height: 'auto',
|
|
229
|
+
width: 20
|
|
230
|
+
}
|
|
231
|
+
}, hint))), /*#__PURE__*/_react.default.createElement(_textContent.default, null)), /*#__PURE__*/_react.default.createElement("div", {
|
|
208
232
|
"data-testid": "testInputWrapper",
|
|
209
233
|
style: styleForWrapper,
|
|
210
234
|
className: helpers.getInputWrapperClass(_objectSpread(_objectSpread({}, props), {}, {
|
|
@@ -212,11 +236,11 @@ const InputTextBase = props => {
|
|
|
212
236
|
}))
|
|
213
237
|
}, leftElements && /*#__PURE__*/_react.default.createElement("div", {
|
|
214
238
|
style: styleForSideButtons,
|
|
215
|
-
className:
|
|
239
|
+
className: `sidebuttons ${customClassForSideButtons}`
|
|
216
240
|
}, leftElements), /*#__PURE__*/_react.default.createElement("div", {
|
|
217
241
|
"data-testid": "testInputContent",
|
|
218
242
|
style: styleForInputContent,
|
|
219
|
-
className:
|
|
243
|
+
className: `inputcontent ${customClassForInputContent}`
|
|
220
244
|
}, type === 'textarea' ? /*#__PURE__*/_react.default.createElement("textarea", _extends({
|
|
221
245
|
rows: props.rows,
|
|
222
246
|
cols: props.cols,
|
|
@@ -227,7 +251,7 @@ const InputTextBase = props => {
|
|
|
227
251
|
"data-testid": "teste-123"
|
|
228
252
|
}, inputProps())), children), helpers.getRightElements(errorMessages || [], skeletonize, rightElements)), /*#__PURE__*/_react.default.createElement(_hint.default, {
|
|
229
253
|
disabled: disabled,
|
|
230
|
-
visible: !!hint,
|
|
254
|
+
visible: !!hint && hintPosition === 'below',
|
|
231
255
|
customClass: "hint",
|
|
232
256
|
description: hint
|
|
233
257
|
}), /*#__PURE__*/_react.default.createElement(_errorMessage.ErrorMessage, {
|
package/lib/inputs/base/Label.js
CHANGED
|
@@ -27,7 +27,7 @@ const Label = props => {
|
|
|
27
27
|
}
|
|
28
28
|
},
|
|
29
29
|
onMouseEnter: onHoverLabel,
|
|
30
|
-
className:
|
|
30
|
+
className: `label ${customClassForLabel} ${labelUppercase && ' -uppercase'}`
|
|
31
31
|
}, label, required && /*#__PURE__*/_react.default.createElement("span", {
|
|
32
32
|
className: "-requiredlabel"
|
|
33
33
|
}, "*"));
|
|
@@ -13,7 +13,7 @@ const getInputClass = _ref => {
|
|
|
13
13
|
readOnly,
|
|
14
14
|
readOnlyClass
|
|
15
15
|
} = _ref;
|
|
16
|
-
return
|
|
16
|
+
return `textinput text-align-${textAlign} ${readOnlyClass} ${readOnly ? ' -readonly' : ''}`;
|
|
17
17
|
};
|
|
18
18
|
exports.getInputClass = getInputClass;
|
|
19
19
|
const getInputWrapperClass = props => {
|
|
@@ -24,7 +24,11 @@ const getInputWrapperClass = props => {
|
|
|
24
24
|
errorMessages,
|
|
25
25
|
disabled
|
|
26
26
|
} = props;
|
|
27
|
-
return
|
|
27
|
+
return `inputwrapper ${inputHasFocus && ' -focusable'}
|
|
28
|
+
${customClassForWrapper}
|
|
29
|
+
${errorMessages && errorMessages.length > 0 && ' -requirederror'}
|
|
30
|
+
${rounded && ' -roundedborders'}
|
|
31
|
+
${disabled && ' -disabled'}`;
|
|
28
32
|
};
|
|
29
33
|
exports.getInputWrapperClass = getInputWrapperClass;
|
|
30
34
|
const getRightElements = (errorMessages, skeletonize, rightElements) => {
|
|
@@ -34,7 +38,7 @@ const getRightElements = (errorMessages, skeletonize, rightElements) => {
|
|
|
34
38
|
elements = [elements];
|
|
35
39
|
}
|
|
36
40
|
elements = elements.map((element, index) => element && /*#__PURE__*/_react.default.cloneElement(element, {
|
|
37
|
-
key:
|
|
41
|
+
key: `rightelement-${index + 1}`
|
|
38
42
|
}));
|
|
39
43
|
if (errorMessages) return elements;
|
|
40
44
|
return elements;
|
|
@@ -73,6 +73,7 @@ interface IBaseProps {
|
|
|
73
73
|
inputRef?: MutableRefObject<HTMLInputElement | HTMLTextAreaElement | null> | ((ref: HTMLInputElement | HTMLTextAreaElement | null) => void);
|
|
74
74
|
inputBaseRef?: RefObject<HTMLDivElement> | ((ref: HTMLDivElement) => void);
|
|
75
75
|
hint?: string | string[];
|
|
76
|
+
hintPosition?: 'below' | 'onLabelRight';
|
|
76
77
|
textAlign?: TextAlign;
|
|
77
78
|
rounded?: boolean;
|
|
78
79
|
errorMessages?: string[] | undefined;
|
|
@@ -92,6 +93,8 @@ interface IBaseProps {
|
|
|
92
93
|
multiple?: boolean;
|
|
93
94
|
readOnlyClass?: string;
|
|
94
95
|
autoComplete?: 'on' | 'off';
|
|
96
|
+
themePopover?: 'light' | 'dark';
|
|
97
|
+
popoverAlign?: 'right' | 'left';
|
|
95
98
|
}
|
|
96
99
|
|
|
97
100
|
export { CustomInputEvent, IBaseProps, InputLabelProps };
|
|
@@ -9,6 +9,11 @@ interface IColorProps {
|
|
|
9
9
|
name?: string;
|
|
10
10
|
permissionAttr?: PermissionAttr;
|
|
11
11
|
visible?: boolean;
|
|
12
|
+
label?: string;
|
|
13
|
+
hint?: string | string[];
|
|
14
|
+
hintPosition?: 'below' | 'onLabelRight';
|
|
15
|
+
themePopover?: 'light' | 'dark';
|
|
16
|
+
popoverAlign?: 'right' | 'left';
|
|
12
17
|
}
|
|
13
18
|
|
|
14
19
|
export { IColorProps };
|
|
@@ -15,7 +15,10 @@ const getCalendarDropdownStyle = _ref => {
|
|
|
15
15
|
width,
|
|
16
16
|
minWidth
|
|
17
17
|
} = _ref;
|
|
18
|
-
return
|
|
18
|
+
return `top: ${topPosition}px;
|
|
19
|
+
left: ${leftPosition}px;
|
|
20
|
+
width: ${width}px;
|
|
21
|
+
min-width: ${minWidth}px;`;
|
|
19
22
|
};
|
|
20
23
|
exports.getCalendarDropdownStyle = getCalendarDropdownStyle;
|
|
21
24
|
const getMomentValue = value => {
|
package/lib/inputs/date/index.js
CHANGED
|
@@ -22,7 +22,6 @@ function _extends() { return _extends = Object.assign ? Object.assign.bind() : f
|
|
|
22
22
|
const CALENDAR_BUTTON_WIDTH = 24;
|
|
23
23
|
const CALENDAR_MIN_WIDTH = 250;
|
|
24
24
|
const DatePicker = props => {
|
|
25
|
-
var _window;
|
|
26
25
|
const {
|
|
27
26
|
showButtonOpen = true,
|
|
28
27
|
openOnFocus = true,
|
|
@@ -54,16 +53,14 @@ const DatePicker = props => {
|
|
|
54
53
|
const dropdownContainer = (0, _react.useRef)();
|
|
55
54
|
const [insideDropdown, setInsideDropdown] = (0, _react.useState)(false);
|
|
56
55
|
const onScreenResize = () => {
|
|
57
|
-
|
|
58
|
-
setInputDimensions(inputRef === null || inputRef === void 0 ? void 0 : (_inputRef$current = inputRef.current) === null || _inputRef$current === void 0 ? void 0 : _inputRef$current.getBoundingClientRect());
|
|
56
|
+
setInputDimensions(inputRef?.current?.getBoundingClientRect());
|
|
59
57
|
};
|
|
60
58
|
const onClickOutside = event => {
|
|
61
|
-
var _buttonOpenRef$curren;
|
|
62
59
|
const {
|
|
63
60
|
target
|
|
64
61
|
} = event;
|
|
65
62
|
if (!dropdownContainer || target === inputRef.current || target === buttonOpenRef.current) return;
|
|
66
|
-
if (target !== dropdownContainer.current && dropdownContainer && dropdownContainer.current && !dropdownContainer.current.contains(target) && buttonOpenRef && !
|
|
63
|
+
if (target !== dropdownContainer.current && dropdownContainer && dropdownContainer.current && !dropdownContainer.current.contains(target) && buttonOpenRef && !buttonOpenRef?.current?.contains(target)) {
|
|
67
64
|
setShowCalendar(false);
|
|
68
65
|
}
|
|
69
66
|
};
|
|
@@ -109,8 +106,7 @@ const DatePicker = props => {
|
|
|
109
106
|
const onInputChange = function (event) {
|
|
110
107
|
let valueInput = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '';
|
|
111
108
|
if (typeof valueInput === 'string') {
|
|
112
|
-
|
|
113
|
-
const date = (_event$target$value = event.target.value) !== null && _event$target$value !== void 0 ? _event$target$value : '';
|
|
109
|
+
const date = event.target.value ?? '';
|
|
114
110
|
if (props.onChange) {
|
|
115
111
|
if (isValidDate(date)) {
|
|
116
112
|
const newValue = (0, _moment.default)(date, _helpers.PT_BR_FORMAT).format(_helpers.EN_US_FORMAT);
|
|
@@ -136,10 +132,9 @@ const DatePicker = props => {
|
|
|
136
132
|
}
|
|
137
133
|
};
|
|
138
134
|
const setValue = function () {
|
|
139
|
-
var _inputRef$current2;
|
|
140
135
|
let valueParam = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
|
|
141
136
|
let e = arguments.length > 1 ? arguments[1] : undefined;
|
|
142
|
-
if (showCalendar && setFocusOnSelect)
|
|
137
|
+
if (showCalendar && setFocusOnSelect) inputRef.current?.focus();
|
|
143
138
|
if (props.onComplete) props.onComplete(e, valueParam);
|
|
144
139
|
if (props.onChange) onInputChange({
|
|
145
140
|
target: {
|
|
@@ -184,7 +179,7 @@ const DatePicker = props => {
|
|
|
184
179
|
return /*#__PURE__*/_react.default.createElement(_Dialog.default, {
|
|
185
180
|
dialogSize: dialogSize,
|
|
186
181
|
handlerClose: setShowCalendar
|
|
187
|
-
}, getCalendar(valueState, props
|
|
182
|
+
}, getCalendar(valueState, props?.calendarColorStyle));
|
|
188
183
|
}
|
|
189
184
|
return /*#__PURE__*/_react.default.createElement(_Dropdown.default, {
|
|
190
185
|
topPosition: inputDimensions ? inputDimensions.top + inputDimensions.height + 5 : '',
|
|
@@ -194,16 +189,16 @@ const DatePicker = props => {
|
|
|
194
189
|
dropdownRef: el => {
|
|
195
190
|
dropdownContainer.current = el;
|
|
196
191
|
}
|
|
197
|
-
}, getCalendar(valueState, props
|
|
192
|
+
}, getCalendar(valueState, props?.calendarColorStyle));
|
|
198
193
|
};
|
|
199
194
|
(0, _react.useEffect)(() => {
|
|
200
195
|
const screenWidth = window.innerWidth;
|
|
201
196
|
if (inputDimensions && screenWidth < inputDimensions.left + CALENDAR_MIN_WIDTH) {
|
|
202
197
|
setFormatedLeftPosition(inputDimensions.left - (CALENDAR_MIN_WIDTH - inputDimensions.width - CALENDAR_BUTTON_WIDTH));
|
|
203
198
|
} else {
|
|
204
|
-
setFormatedLeftPosition(inputDimensions
|
|
199
|
+
setFormatedLeftPosition(inputDimensions?.left);
|
|
205
200
|
}
|
|
206
|
-
}, [
|
|
201
|
+
}, [window?.innerWidth, inputDimensions]);
|
|
207
202
|
(0, _react.useEffect)(() => {
|
|
208
203
|
window.addEventListener('resize', onScreenResize);
|
|
209
204
|
document.addEventListener('click', onClickOutside);
|
|
@@ -233,8 +228,7 @@ const DatePicker = props => {
|
|
|
233
228
|
mask: "00/00/0000",
|
|
234
229
|
onComplete: e => {
|
|
235
230
|
if (e) {
|
|
236
|
-
|
|
237
|
-
setValue((_e$target = e.target) === null || _e$target === void 0 ? void 0 : _e$target.maskedValue, e);
|
|
231
|
+
setValue(e.target?.maskedValue, e);
|
|
238
232
|
}
|
|
239
233
|
},
|
|
240
234
|
onBlur: onInputBlur,
|
|
@@ -37,6 +37,10 @@ interface IDatePickerProps {
|
|
|
37
37
|
disabled?: boolean;
|
|
38
38
|
permissionAttr?: PermissionAttr;
|
|
39
39
|
label?: string;
|
|
40
|
+
hint?: string | string[];
|
|
41
|
+
hintPosition?: 'below' | 'onLabelRight';
|
|
42
|
+
themePopover?: 'light' | 'dark';
|
|
43
|
+
popoverAlign?: 'right' | 'left';
|
|
40
44
|
}
|
|
41
45
|
interface IDateDropdownProps {
|
|
42
46
|
children: ReactNode | ReactNode[];
|
|
@@ -19,7 +19,7 @@ const ErrorMessage = exports.ErrorMessage = /*#__PURE__*/(0, _react.forwardRef)(
|
|
|
19
19
|
return /*#__PURE__*/_react.default.createElement("p", {
|
|
20
20
|
ref: ref,
|
|
21
21
|
style: style,
|
|
22
|
-
className:
|
|
22
|
+
className: `errormessages-component ${customClass}`
|
|
23
23
|
}, messages.join(', '));
|
|
24
24
|
});
|
|
25
25
|
ErrorMessage.displayName = 'ErrorMessage';
|
|
@@ -27,16 +27,16 @@ const DefaultFile = props => {
|
|
|
27
27
|
hint = [],
|
|
28
28
|
onChange
|
|
29
29
|
} = props;
|
|
30
|
-
const getFilesList = files => !
|
|
30
|
+
const getFilesList = files => !files?.length ? [] : _lodash.default.map(files, file => file);
|
|
31
31
|
const [fileList, setFileList] = (0, _react.useState)(defaultFiles);
|
|
32
32
|
const ifExistFiles = fileList instanceof Array && fileList.length > 0;
|
|
33
33
|
const popUpDescription = () => /*#__PURE__*/_react.default.createElement("div", {
|
|
34
|
-
className:
|
|
34
|
+
className: `size-position-icon ${!ifExistFiles ? '-disabled-popover' : ''}`
|
|
35
35
|
}, /*#__PURE__*/_react.default.createElement(_popover.default, {
|
|
36
36
|
iconSize: 16
|
|
37
37
|
}, /*#__PURE__*/_react.default.createElement(_popover.PopoverText, null, /*#__PURE__*/_react.default.createElement("strong", null, "Arquivos"), /*#__PURE__*/_react.default.createElement("br", null), ifExistFiles && fileList.map(file => /*#__PURE__*/_react.default.createElement("div", {
|
|
38
38
|
className: "list-simple-file",
|
|
39
|
-
key:
|
|
39
|
+
key: `${file.name}${file.size}`
|
|
40
40
|
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
41
41
|
className: "file-name"
|
|
42
42
|
}, /*#__PURE__*/_react.default.createElement("span", null, file.name)))))));
|
|
@@ -55,11 +55,10 @@ const DefaultFile = props => {
|
|
|
55
55
|
})
|
|
56
56
|
});
|
|
57
57
|
const handleChange = e => {
|
|
58
|
-
|
|
59
|
-
(_e$preventDefault = e.preventDefault) === null || _e$preventDefault === void 0 ? void 0 : _e$preventDefault.call(e);
|
|
58
|
+
e.preventDefault?.();
|
|
60
59
|
const files = getFilesList(e.target.files);
|
|
61
60
|
setFileList(files);
|
|
62
|
-
onChange
|
|
61
|
+
onChange?.(files, e);
|
|
63
62
|
};
|
|
64
63
|
return /*#__PURE__*/_react.default.createElement("div", {
|
|
65
64
|
className: "input-simple-file-container"
|