linear-react-components-ui 0.4.75 → 0.4.76-beta.11
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/.eslintrc.js +2 -5
- package/.tool-versions +1 -0
- package/.vscode/settings.json +8 -9
- package/README.md +33 -0
- package/config/jest/cssTransform.js +14 -0
- package/config/jest/fileTransform.js +12 -0
- package/config/jest/storageMock.js +40 -0
- package/jest.config.js +18 -0
- package/lib/alerts/alert.spec.js +133 -0
- package/lib/assets/styles/dropdown.scss +28 -2
- package/lib/assets/styles/effects.scss +12 -0
- package/lib/assets/styles/floatMenu.scss +0 -1
- package/lib/assets/styles/multiSelect.scss +105 -0
- package/lib/assets/styles/panel.scss +0 -1
- package/lib/assets/styles/periodpicker.scss +65 -0
- package/lib/assets/styles/popover.scss +9 -11
- package/lib/assets/styles/progress.scss +8 -1
- package/lib/assets/styles/select.scss +1 -0
- package/lib/assets/styles/table.scss +13 -5
- package/lib/assets/styles/tabs.scss +79 -44
- package/lib/assets/styles/treeview.scss +32 -0
- package/lib/avatar/avatar.spec.js +190 -0
- package/lib/avatar/index.js +6 -2
- package/lib/badge/badge.spec.js +127 -0
- package/lib/badge/index.js +3 -5
- package/lib/buttons/DefaultButton.js +7 -1
- package/lib/buttons/buttons.spec.js +504 -0
- package/lib/calendar/calendar.spec.js +171 -0
- package/lib/checkbox/Label.js +37 -0
- package/lib/checkbox/checkbox.spec.js +215 -0
- package/lib/checkbox/index.js +21 -6
- package/lib/dialog/Custom.js +7 -1
- package/lib/dialog/base/index.js +18 -6
- package/lib/dialog/dialog.spec.js +488 -0
- package/lib/dialog/form/index.js +23 -4
- package/lib/drawer/Drawer.js +3 -0
- package/lib/drawer/Drawer.spec.js +258 -0
- package/lib/drawer/Header.js +4 -1
- package/lib/drawer/index.js +4 -1
- package/lib/dropdown/Popup.js +1 -0
- package/lib/dropdown/dropdown.spec.js +168 -0
- package/lib/dropdown/withDropdown.js +10 -4
- package/lib/fieldset/fieldset.spec.js +329 -0
- package/lib/form/Field.js +2 -0
- package/lib/form/FieldNumber.js +10 -2
- package/lib/form/FieldPeriod.js +100 -0
- package/lib/form/form.spec.js +285 -0
- package/lib/form/helpers.js +9 -1
- package/lib/form/index.js +209 -222
- package/lib/form/withFieldHOC.js +2 -0
- package/lib/form/withFormSecurity.js +106 -0
- package/lib/gridlayout/GridRow.js +1 -1
- package/lib/gridlayout/gridLayout.spec.js +169 -0
- package/lib/icons/helper.js +16 -0
- package/lib/icons/icons.spec.js +86 -0
- package/lib/icons/index.js +2 -0
- package/lib/inputs/base/InputTextBase.js +24 -5
- package/lib/inputs/base/base.spec.js +690 -0
- package/lib/inputs/base/helpers.js +19 -3
- package/lib/inputs/color/color_input.spec.js +174 -0
- package/lib/inputs/color/index.js +2 -2
- package/lib/inputs/date/Dropdown.js +3 -3
- package/lib/inputs/date/date.spec.js +344 -0
- package/lib/inputs/date/helpers.js +36 -0
- package/lib/inputs/date/index.js +11 -9
- package/lib/inputs/mask/Cpf.js +9 -9
- package/lib/inputs/mask/input_mask.spec.js +590 -0
- package/lib/inputs/multiSelect/ActionButtons.js +68 -0
- package/lib/inputs/multiSelect/Dropdown.js +200 -0
- package/lib/inputs/multiSelect/helper.js +18 -0
- package/lib/inputs/multiSelect/index.js +343 -0
- package/lib/inputs/number/BaseNumber.js +1 -1
- package/lib/inputs/number/index.js +7 -5
- package/lib/inputs/number/numberfield.spec.js +215 -0
- package/lib/inputs/period/Dialog.js +38 -0
- package/lib/inputs/period/Dropdown.js +90 -0
- package/lib/inputs/period/PeriodList.js +79 -0
- package/lib/inputs/period/helper.js +118 -0
- package/lib/inputs/period/index.js +490 -0
- package/lib/inputs/search/search_input.spec.js +209 -0
- package/lib/inputs/select/Dropdown.js +4 -4
- package/lib/inputs/select/index.js +26 -3
- package/lib/inputs/select/multiple/index.js +9 -7
- package/lib/inputs/select/select.spec.js +391 -0
- package/lib/inputs/select/simple/index.js +30 -18
- package/lib/inputs/text/textfield.spec.js +215 -0
- package/lib/inputs/textarea/textarea.spec.js +59 -0
- package/lib/internals/withTooltip.js +86 -82
- package/lib/labelMessages/index.js +3 -2
- package/lib/labelMessages/labelMessages.spec.js +176 -0
- package/lib/labels/label.spec.js +162 -0
- package/lib/list/Item.js +3 -3
- package/lib/list/index.js +21 -10
- package/lib/list/list.spec.js +611 -0
- package/lib/menus/float/MenuItem.js +25 -8
- package/lib/menus/float/float-menu.spec.js +221 -0
- package/lib/menus/sidenav/index.js +7 -3
- package/lib/menus/sidenav/popup_menu_search/index.js +1 -1
- package/lib/menus/sidenav/sidenav.spec.js +312 -0
- package/lib/noPermission/index.js +2 -1
- package/lib/panel/panel.spec.js +216 -0
- package/lib/popover/index.js +2 -1
- package/lib/popover/popover.spec.js +146 -0
- package/lib/progress/Bar.js +40 -9
- package/lib/progress/index.js +12 -4
- package/lib/progress/progress.spec.js +86 -0
- package/lib/radio/radio.spec.js +189 -0
- package/lib/spinner/SpinnerLoading.js +14 -24
- package/lib/spinner/index.js +6 -1
- package/lib/spinner/spinner.spec.js +152 -0
- package/lib/split/Split.js +10 -12
- package/lib/split/split.spec.js +151 -0
- package/lib/table/Header.js +3 -1
- package/lib/table/Row.js +2 -5
- package/lib/table/index.js +1 -4
- package/lib/table/table.spec.js +352 -0
- package/lib/tabs/DropdownItems.js +84 -0
- package/lib/tabs/Menu.js +18 -5
- package/lib/tabs/MenuItems.js +7 -7
- package/lib/tabs/Panel.js +1 -3
- package/lib/tabs/index.js +151 -20
- package/lib/tabs/tabs.spec.js +349 -0
- package/lib/toolbar/index.js +8 -4
- package/lib/toolbar/toolbar.spec.js +394 -0
- package/lib/tooltip/index.js +20 -6
- package/lib/tooltip/tooltip.spec.js +203 -0
- package/lib/treeview/Node.js +347 -48
- package/lib/treeview/index.js +456 -35
- package/lib/treeview/treeview.spec.js +261 -0
- package/package.json +19 -9
- package/.DS_Store +0 -0
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _react = _interopRequireDefault(require("react"));
|
|
4
|
+
|
|
5
|
+
var _react2 = require("@testing-library/react");
|
|
6
|
+
|
|
7
|
+
require("@testing-library/jest-dom/extend-expect");
|
|
8
|
+
|
|
9
|
+
var _index = _interopRequireDefault(require("./index"));
|
|
10
|
+
|
|
11
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
12
|
+
|
|
13
|
+
describe('TextArea', function () {
|
|
14
|
+
var textArea = function textArea(textAreaProps) {
|
|
15
|
+
return /*#__PURE__*/_react["default"].createElement(_index["default"], textAreaProps);
|
|
16
|
+
};
|
|
17
|
+
|
|
18
|
+
it('should render correctly', function () {
|
|
19
|
+
var _render = (0, _react2.render)(textArea()),
|
|
20
|
+
container = _render.container;
|
|
21
|
+
|
|
22
|
+
var textAreaHTML = container.querySelector('textarea.textinput');
|
|
23
|
+
expect(container.firstChild).toHaveClass('textarea-container');
|
|
24
|
+
expect(textAreaHTML).toBeInTheDocument();
|
|
25
|
+
expect(textAreaHTML.type).toBe('textarea');
|
|
26
|
+
});
|
|
27
|
+
it('should apply customClass', function () {
|
|
28
|
+
var customClass = 'teste-textarea';
|
|
29
|
+
|
|
30
|
+
var _render2 = (0, _react2.render)(textArea({
|
|
31
|
+
customClass: customClass
|
|
32
|
+
})),
|
|
33
|
+
container = _render2.container;
|
|
34
|
+
|
|
35
|
+
expect(container.firstChild).toHaveClass(customClass);
|
|
36
|
+
});
|
|
37
|
+
it('should apply rows', function () {
|
|
38
|
+
var rows = '12';
|
|
39
|
+
|
|
40
|
+
var _render3 = (0, _react2.render)(textArea({
|
|
41
|
+
rows: rows
|
|
42
|
+
})),
|
|
43
|
+
container = _render3.container;
|
|
44
|
+
|
|
45
|
+
var textAreaHTML = container.querySelector('textarea.textinput');
|
|
46
|
+
expect(textAreaHTML.rows).toBe(parseInt(rows, 10));
|
|
47
|
+
});
|
|
48
|
+
it('should apply cols', function () {
|
|
49
|
+
var cols = '12';
|
|
50
|
+
|
|
51
|
+
var _render4 = (0, _react2.render)(textArea({
|
|
52
|
+
cols: cols
|
|
53
|
+
})),
|
|
54
|
+
container = _render4.container;
|
|
55
|
+
|
|
56
|
+
var textAreaHTML = container.querySelector('textarea.textinput');
|
|
57
|
+
expect(textAreaHTML.cols).toBe(parseInt(cols, 10));
|
|
58
|
+
});
|
|
59
|
+
});
|
|
@@ -33,6 +33,8 @@ function _iterableToArrayLimit(arr, i) { var _i = arr && (typeof Symbol !== "und
|
|
|
33
33
|
|
|
34
34
|
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
|
|
35
35
|
|
|
36
|
+
var TOOLTIP_INITIAL_HEIGHT = 40;
|
|
37
|
+
|
|
36
38
|
var hasTooltip = function hasTooltip(_ref) {
|
|
37
39
|
var tooltip = _ref.tooltip;
|
|
38
40
|
return tooltip;
|
|
@@ -45,38 +47,37 @@ var getDisplayName = function getDisplayName(WrappedComponent) {
|
|
|
45
47
|
var withTooltip = function withTooltip(WrappedComponent) {
|
|
46
48
|
var EnhancedComponent = function EnhancedComponent(props) {
|
|
47
49
|
var tooltip = props.tooltip,
|
|
48
|
-
tooltipPosition = props.tooltipPosition,
|
|
49
50
|
tooltipWidth = props.tooltipWidth,
|
|
50
51
|
space = props.space;
|
|
51
52
|
|
|
52
|
-
var _useState = (0, _react.useState)(
|
|
53
|
+
var _useState = (0, _react.useState)(props.tooltipPosition),
|
|
53
54
|
_useState2 = _slicedToArray(_useState, 2),
|
|
54
|
-
|
|
55
|
-
|
|
55
|
+
tooltipPosition = _useState2[0],
|
|
56
|
+
setTooltipPosition = _useState2[1];
|
|
56
57
|
|
|
57
|
-
var _useState3 = (0, _react.useState)(
|
|
58
|
-
width: tooltipWidth,
|
|
59
|
-
height: undefined
|
|
60
|
-
}),
|
|
58
|
+
var _useState3 = (0, _react.useState)(''),
|
|
61
59
|
_useState4 = _slicedToArray(_useState3, 2),
|
|
62
|
-
|
|
63
|
-
|
|
60
|
+
tooltipStyle = _useState4[0],
|
|
61
|
+
setTooltipStyle = _useState4[1];
|
|
64
62
|
|
|
65
|
-
var _useState5 = (0, _react.useState)(
|
|
63
|
+
var _useState5 = (0, _react.useState)(false),
|
|
66
64
|
_useState6 = _slicedToArray(_useState5, 2),
|
|
67
|
-
|
|
68
|
-
|
|
65
|
+
showTooltip = _useState6[0],
|
|
66
|
+
setShowTooltip = _useState6[1];
|
|
69
67
|
|
|
70
|
-
var _useState7 = (0, _react.useState)(
|
|
68
|
+
var _useState7 = (0, _react.useState)({
|
|
69
|
+
width: tooltipWidth,
|
|
70
|
+
height: TOOLTIP_INITIAL_HEIGHT
|
|
71
|
+
}),
|
|
71
72
|
_useState8 = _slicedToArray(_useState7, 2),
|
|
72
|
-
|
|
73
|
-
|
|
73
|
+
tooltipDimensions = _useState8[0],
|
|
74
|
+
setTooltipDimensions = _useState8[1];
|
|
74
75
|
|
|
75
|
-
var
|
|
76
|
-
var
|
|
76
|
+
var targetElement = (0, _react.useRef)(null);
|
|
77
|
+
var tooltipElement = (0, _react.useRef)(null);
|
|
77
78
|
|
|
78
79
|
var onMouseOver = function onMouseOver(e) {
|
|
79
|
-
if (targetElement.current
|
|
80
|
+
if (targetElement && targetElement.current && targetElement.current.contains(e.target)) {
|
|
80
81
|
setShowTooltip(true);
|
|
81
82
|
} else setShowTooltip(false);
|
|
82
83
|
};
|
|
@@ -85,58 +86,24 @@ var withTooltip = function withTooltip(WrappedComponent) {
|
|
|
85
86
|
setShowTooltip(false);
|
|
86
87
|
};
|
|
87
88
|
|
|
88
|
-
var
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
if (targetElement.current && dimensionsTargetElement !== currentDimensions) {
|
|
92
|
-
return setDimensionsTargetElement(currentDimensions);
|
|
93
|
-
}
|
|
94
|
-
|
|
95
|
-
return null;
|
|
96
|
-
};
|
|
97
|
-
|
|
98
|
-
var getScrollableParent = function getScrollableParent(node) {
|
|
99
|
-
if (node === null || node.nodeName === '#document') {
|
|
100
|
-
return setFindScrollableParent(false);
|
|
101
|
-
}
|
|
102
|
-
|
|
103
|
-
var _window$getComputedSt = window.getComputedStyle(node),
|
|
104
|
-
overflowY = _window$getComputedSt.overflowY;
|
|
105
|
-
|
|
106
|
-
var isScrollable = overflowY !== 'visible' && overflowY !== 'hidden';
|
|
107
|
-
|
|
108
|
-
if (isScrollable && node.scrollHeight > node.clientHeight) {
|
|
109
|
-
scrollableParent.current = node;
|
|
110
|
-
return setFindScrollableParent(false);
|
|
111
|
-
}
|
|
112
|
-
|
|
113
|
-
return getScrollableParent(node.parentNode);
|
|
89
|
+
var onAnyScroll = function onAnyScroll() {
|
|
90
|
+
setShowTooltip(false);
|
|
114
91
|
};
|
|
115
92
|
|
|
116
93
|
(0, _react.useEffect)(function () {
|
|
117
94
|
if (hasTooltip(props)) {
|
|
118
95
|
document.addEventListener('mouseover', onMouseOver);
|
|
96
|
+
document.addEventListener('scroll', onAnyScroll, true);
|
|
119
97
|
|
|
120
98
|
if (targetElement && targetElement.current) {
|
|
121
99
|
targetElement.current.addEventListener('mouseout', onMouseOut);
|
|
122
100
|
}
|
|
123
|
-
|
|
124
|
-
if (targetElement && targetElement.current && findScrollableParent) {
|
|
125
|
-
getScrollableParent(targetElement.current);
|
|
126
|
-
}
|
|
127
|
-
|
|
128
|
-
if (scrollableParent && scrollableParent.current) {
|
|
129
|
-
scrollableParent.current.addEventListener('scroll', onParentScroll);
|
|
130
|
-
}
|
|
131
101
|
}
|
|
132
102
|
|
|
133
103
|
return function () {
|
|
134
104
|
if (hasTooltip(props)) {
|
|
135
105
|
document.removeEventListener('mouseover', onMouseOver);
|
|
136
|
-
|
|
137
|
-
if (scrollableParent && scrollableParent.current) {
|
|
138
|
-
scrollableParent.current.removeEventListener('scroll', onParentScroll);
|
|
139
|
-
}
|
|
106
|
+
document.removeEventListener('scroll', onAnyScroll, true);
|
|
140
107
|
|
|
141
108
|
if (targetElement && targetElement.current) {
|
|
142
109
|
targetElement.current.removeEventListener('mouseout', onMouseOut);
|
|
@@ -144,39 +111,76 @@ var withTooltip = function withTooltip(WrappedComponent) {
|
|
|
144
111
|
}
|
|
145
112
|
};
|
|
146
113
|
}, []);
|
|
114
|
+
(0, _react.useEffect)(function () {
|
|
115
|
+
if (targetElement.current) {
|
|
116
|
+
var width = tooltipDimensions.width,
|
|
117
|
+
height = tooltipDimensions.height;
|
|
118
|
+
var targetDimensions = targetElement.current.getBoundingClientRect();
|
|
119
|
+
var targetVerticalCenter = (targetDimensions.top + targetDimensions.bottom) / 2;
|
|
120
|
+
var tooltipClientWidth = tooltipElement.current && tooltipElement.current.clientWidth;
|
|
121
|
+
var style = "width: ".concat(typeof width === 'string' ? width : "".concat(width, "px"));
|
|
122
|
+
var left = targetDimensions.left + targetDimensions.width / 2 - tooltipClientWidth / 2;
|
|
123
|
+
left = Math.min(left, document.body.clientWidth - tooltipClientWidth - space);
|
|
124
|
+
style += "; left: ".concat(Math.max(space, left), "px");
|
|
125
|
+
|
|
126
|
+
switch (tooltipPosition) {
|
|
127
|
+
case 'top':
|
|
128
|
+
if (targetDimensions.top < height) {
|
|
129
|
+
setTooltipPosition('bottom');
|
|
130
|
+
} else {
|
|
131
|
+
style += "; top: ".concat(targetDimensions.top + window.scrollY - height - 5, "px");
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
break;
|
|
135
|
+
|
|
136
|
+
case 'bottom':
|
|
137
|
+
if (window.innerHeight - targetDimensions.bottom < height) {
|
|
138
|
+
setTooltipPosition('top');
|
|
139
|
+
} else {
|
|
140
|
+
style += "; top: ".concat(targetDimensions.top + window.scrollY + targetDimensions.height + 5, "px");
|
|
141
|
+
}
|
|
142
|
+
|
|
143
|
+
break;
|
|
144
|
+
|
|
145
|
+
case 'left':
|
|
146
|
+
if (targetDimensions.left < tooltipClientWidth) {
|
|
147
|
+
setTooltipPosition('right');
|
|
148
|
+
} else {
|
|
149
|
+
style += "; top: ".concat(targetVerticalCenter + window.scrollY - height / 2, "px");
|
|
150
|
+
style += "; left: ".concat(targetDimensions.left - tooltipClientWidth - 6, "px");
|
|
151
|
+
}
|
|
152
|
+
|
|
153
|
+
break;
|
|
154
|
+
|
|
155
|
+
case 'right':
|
|
156
|
+
if (window.innerWidth - targetDimensions.right < tooltipClientWidth) {
|
|
157
|
+
setTooltipPosition('left');
|
|
158
|
+
} else {
|
|
159
|
+
style += "; top: ".concat(targetVerticalCenter + window.scrollY - height / 2, "px");
|
|
160
|
+
style += "; left: ".concat(targetDimensions.left + targetDimensions.width + 5, "px");
|
|
161
|
+
}
|
|
162
|
+
|
|
163
|
+
break;
|
|
164
|
+
|
|
165
|
+
default:
|
|
166
|
+
style += '';
|
|
167
|
+
}
|
|
147
168
|
|
|
148
|
-
|
|
149
|
-
// where on the screen is the target
|
|
150
|
-
var width = tooltipDimensions.width,
|
|
151
|
-
height = tooltipDimensions.height;
|
|
152
|
-
var targetDimensions = dimensionsTargetElement || targetElement.current.getBoundingClientRect();
|
|
153
|
-
var targetVerticalCenter = (targetDimensions.top + targetDimensions.bottom) / 2;
|
|
154
|
-
var style = "width: ".concat(width + 2, "px");
|
|
155
|
-
var left = targetDimensions.left + targetDimensions.width / 2 - width / 2;
|
|
156
|
-
left = Math.min(left, document.body.clientWidth - width - space);
|
|
157
|
-
style += "; left: ".concat(Math.max(space, left), "px"); // when the position is informed
|
|
158
|
-
|
|
159
|
-
if (tooltipPosition === 'top') {
|
|
160
|
-
style += "; top: ".concat(targetDimensions.top + window.scrollY - height - 5, "px");
|
|
161
|
-
} else if (tooltipPosition === 'bottom') {
|
|
162
|
-
style += "; top: ".concat(targetDimensions.top + window.scrollY + targetDimensions.height + 5, "px");
|
|
163
|
-
} else if (tooltipPosition === 'left') {
|
|
164
|
-
style += "; top: ".concat(targetVerticalCenter + window.scrollY - height / 2, "px");
|
|
165
|
-
style += "; left: ".concat(targetDimensions.left - width - 6, "px");
|
|
166
|
-
} else if (tooltipPosition === 'right') {
|
|
167
|
-
style += "; top: ".concat(targetVerticalCenter + window.scrollY - height / 2, "px");
|
|
168
|
-
style += "; left: ".concat(targetDimensions.left + targetDimensions.width + 5, "px");
|
|
169
|
+
setTooltipStyle(style);
|
|
169
170
|
}
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
171
|
+
}, [tooltipDimensions, tooltipElement.current, targetElement.current, tooltipPosition]);
|
|
172
|
+
(0, _react.useEffect)(function () {
|
|
173
|
+
setTooltipPosition(props.tooltipPosition);
|
|
174
|
+
}, [window.scrollY, window.scrollX, window.innerWidth]);
|
|
173
175
|
|
|
174
176
|
var getTooltip = function getTooltip() {
|
|
175
177
|
if (tooltip) {
|
|
176
178
|
return /*#__PURE__*/_react["default"].createElement(_tooltip["default"], {
|
|
177
179
|
text: tooltip,
|
|
178
|
-
|
|
180
|
+
tooltipRef: tooltipElement,
|
|
181
|
+
style: tooltipStyle,
|
|
179
182
|
className: tooltipPosition,
|
|
183
|
+
tooltipDimensions: tooltipDimensions,
|
|
180
184
|
handlerSetDimensions: setTooltipDimensions
|
|
181
185
|
});
|
|
182
186
|
}
|
|
@@ -48,7 +48,8 @@ var LabelMessages = function LabelMessages(props) {
|
|
|
48
48
|
showCloseButton = props.showCloseButton,
|
|
49
49
|
type = props.type,
|
|
50
50
|
flat = props.flat,
|
|
51
|
-
square = props.square
|
|
51
|
+
square = props.square,
|
|
52
|
+
visible = props.visible;
|
|
52
53
|
|
|
53
54
|
var getClass = function getClass() {
|
|
54
55
|
return "labelmessages-component -".concat(type, " ").concat(customClass, "\n ").concat(square && '-square', " ").concat(flat && '-flat');
|
|
@@ -69,7 +70,7 @@ var LabelMessages = function LabelMessages(props) {
|
|
|
69
70
|
return null;
|
|
70
71
|
};
|
|
71
72
|
|
|
72
|
-
if (closed) return
|
|
73
|
+
if (closed || !visible) return null;
|
|
73
74
|
return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement("div", {
|
|
74
75
|
className: "".concat(getClass(), " ").concat(customClass),
|
|
75
76
|
style: style
|
|
@@ -0,0 +1,176 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _react = _interopRequireDefault(require("react"));
|
|
4
|
+
|
|
5
|
+
var _react2 = require("@testing-library/react");
|
|
6
|
+
|
|
7
|
+
require("@testing-library/jest-dom/extend-expect");
|
|
8
|
+
|
|
9
|
+
require("babel-polyfill");
|
|
10
|
+
|
|
11
|
+
var _index = _interopRequireDefault(require("./index"));
|
|
12
|
+
|
|
13
|
+
var _icons = _interopRequireDefault(require("../icons"));
|
|
14
|
+
|
|
15
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
16
|
+
|
|
17
|
+
describe('LabelMessages', function () {
|
|
18
|
+
describe('Default', function () {
|
|
19
|
+
var Default = /*#__PURE__*/_react["default"].createElement(_index["default"], {
|
|
20
|
+
icon: /*#__PURE__*/_react["default"].createElement(_icons["default"], {
|
|
21
|
+
name: "user"
|
|
22
|
+
})
|
|
23
|
+
}, "Teste");
|
|
24
|
+
|
|
25
|
+
it('should render correctly', function () {
|
|
26
|
+
var _render = (0, _react2.render)(Default),
|
|
27
|
+
container = _render.container;
|
|
28
|
+
|
|
29
|
+
expect(container.firstChild).toHaveTextContent('Teste');
|
|
30
|
+
});
|
|
31
|
+
it('should render icon', function () {
|
|
32
|
+
var _render2 = (0, _react2.render)(Default),
|
|
33
|
+
getByTestId = _render2.getByTestId;
|
|
34
|
+
|
|
35
|
+
expect(getByTestId('icon')).toBeTruthy();
|
|
36
|
+
});
|
|
37
|
+
it('should render icon when use iconName', function () {
|
|
38
|
+
var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_index["default"], {
|
|
39
|
+
iconName: "user"
|
|
40
|
+
}, "Teste")),
|
|
41
|
+
getByTestId = _render3.getByTestId;
|
|
42
|
+
|
|
43
|
+
expect(getByTestId('icon')).toBeTruthy();
|
|
44
|
+
});
|
|
45
|
+
it('should render close button', function () {
|
|
46
|
+
var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_index["default"], {
|
|
47
|
+
showCloseButton: true
|
|
48
|
+
}, "Teste")),
|
|
49
|
+
getByRole = _render4.getByRole;
|
|
50
|
+
|
|
51
|
+
expect(getByRole('presentation')).toBeTruthy();
|
|
52
|
+
});
|
|
53
|
+
it('should execute function when clicking the close button', function () {
|
|
54
|
+
var mockHandlerClosed = jest.fn();
|
|
55
|
+
|
|
56
|
+
var mockLabelMessage = /*#__PURE__*/_react["default"].createElement(_index["default"], {
|
|
57
|
+
showCloseButton: true,
|
|
58
|
+
handlerClosed: mockHandlerClosed
|
|
59
|
+
}, "Teste");
|
|
60
|
+
|
|
61
|
+
(0, _react2.render)(mockLabelMessage);
|
|
62
|
+
|
|
63
|
+
_react2.fireEvent.click(_react2.screen.getByRole('presentation'));
|
|
64
|
+
|
|
65
|
+
expect(mockHandlerClosed).toHaveBeenCalled();
|
|
66
|
+
});
|
|
67
|
+
it('should close labelMessage', function () {
|
|
68
|
+
var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_index["default"], {
|
|
69
|
+
showCloseButton: true
|
|
70
|
+
}, "Teste")),
|
|
71
|
+
container = _render5.container;
|
|
72
|
+
|
|
73
|
+
_react2.fireEvent.click(_react2.screen.getByRole('presentation'));
|
|
74
|
+
|
|
75
|
+
expect(container.firstChild).not.toBeInTheDocument();
|
|
76
|
+
});
|
|
77
|
+
it('should apply customClass', function () {
|
|
78
|
+
var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_index["default"], {
|
|
79
|
+
customClass: "customClass"
|
|
80
|
+
}, "Teste")),
|
|
81
|
+
container = _render6.container;
|
|
82
|
+
|
|
83
|
+
expect(container.firstChild).toHaveClass('customClass');
|
|
84
|
+
});
|
|
85
|
+
it('should apply inline style', function () {
|
|
86
|
+
var _render7 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_index["default"], {
|
|
87
|
+
style: {
|
|
88
|
+
borderWidth: 10
|
|
89
|
+
}
|
|
90
|
+
}, "Teste")),
|
|
91
|
+
container = _render7.container;
|
|
92
|
+
|
|
93
|
+
expect(container.firstChild).toHaveStyle('border-width: 10px');
|
|
94
|
+
});
|
|
95
|
+
it('should hide labelMessage when visible is false', function () {
|
|
96
|
+
var _render8 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_index["default"], {
|
|
97
|
+
visible: false
|
|
98
|
+
}, "Teste")),
|
|
99
|
+
container = _render8.container;
|
|
100
|
+
|
|
101
|
+
expect(container.firstChild).not.toBeTruthy();
|
|
102
|
+
});
|
|
103
|
+
});
|
|
104
|
+
describe('Danger', function () {
|
|
105
|
+
var dangerLabelMessages = /*#__PURE__*/_react["default"].createElement(_index["default"], {
|
|
106
|
+
type: "danger"
|
|
107
|
+
}, "Teste");
|
|
108
|
+
|
|
109
|
+
it('should apply type danger', function () {
|
|
110
|
+
var _render9 = (0, _react2.render)(dangerLabelMessages),
|
|
111
|
+
container = _render9.container;
|
|
112
|
+
|
|
113
|
+
expect(container.firstChild).toHaveClass('-danger');
|
|
114
|
+
});
|
|
115
|
+
});
|
|
116
|
+
describe('Info', function () {
|
|
117
|
+
var infoLabelMessages = /*#__PURE__*/_react["default"].createElement(_index["default"], {
|
|
118
|
+
type: "info"
|
|
119
|
+
}, "Teste");
|
|
120
|
+
|
|
121
|
+
it('should apply type info', function () {
|
|
122
|
+
var _render10 = (0, _react2.render)(infoLabelMessages),
|
|
123
|
+
container = _render10.container;
|
|
124
|
+
|
|
125
|
+
expect(container.firstChild).toHaveClass('-info');
|
|
126
|
+
});
|
|
127
|
+
});
|
|
128
|
+
describe('Warning', function () {
|
|
129
|
+
var warningLabelMessages = /*#__PURE__*/_react["default"].createElement(_index["default"], {
|
|
130
|
+
type: "warning"
|
|
131
|
+
}, "Teste");
|
|
132
|
+
|
|
133
|
+
it('should apply type warning', function () {
|
|
134
|
+
var _render11 = (0, _react2.render)(warningLabelMessages),
|
|
135
|
+
container = _render11.container;
|
|
136
|
+
|
|
137
|
+
expect(container.firstChild).toHaveClass('-warning');
|
|
138
|
+
});
|
|
139
|
+
});
|
|
140
|
+
describe('Success', function () {
|
|
141
|
+
var successLabelMessages = /*#__PURE__*/_react["default"].createElement(_index["default"], {
|
|
142
|
+
type: "success"
|
|
143
|
+
}, "Teste");
|
|
144
|
+
|
|
145
|
+
it('should apply type success', function () {
|
|
146
|
+
var _render12 = (0, _react2.render)(successLabelMessages),
|
|
147
|
+
container = _render12.container;
|
|
148
|
+
|
|
149
|
+
expect(container.firstChild).toHaveClass('-success');
|
|
150
|
+
});
|
|
151
|
+
});
|
|
152
|
+
describe('Flat', function () {
|
|
153
|
+
var flatLabelMessages = /*#__PURE__*/_react["default"].createElement(_index["default"], {
|
|
154
|
+
flat: true
|
|
155
|
+
}, "Teste");
|
|
156
|
+
|
|
157
|
+
it('should apply rounded border', function () {
|
|
158
|
+
var _render13 = (0, _react2.render)(flatLabelMessages),
|
|
159
|
+
container = _render13.container;
|
|
160
|
+
|
|
161
|
+
expect(container.firstChild).toHaveClass('-flat');
|
|
162
|
+
});
|
|
163
|
+
});
|
|
164
|
+
describe('Square', function () {
|
|
165
|
+
var squareLabelMessages = /*#__PURE__*/_react["default"].createElement(_index["default"], {
|
|
166
|
+
square: true
|
|
167
|
+
}, "Teste");
|
|
168
|
+
|
|
169
|
+
it('should apply rounded borderless', function () {
|
|
170
|
+
var _render14 = (0, _react2.render)(squareLabelMessages),
|
|
171
|
+
container = _render14.container;
|
|
172
|
+
|
|
173
|
+
expect(container.firstChild).toHaveClass('-square');
|
|
174
|
+
});
|
|
175
|
+
});
|
|
176
|
+
});
|
|
@@ -0,0 +1,162 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
|
|
4
|
+
|
|
5
|
+
var _react = _interopRequireDefault(require("react"));
|
|
6
|
+
|
|
7
|
+
var _react2 = require("@testing-library/react");
|
|
8
|
+
|
|
9
|
+
require("@testing-library/jest-dom/extend-expect");
|
|
10
|
+
|
|
11
|
+
var _index = _interopRequireWildcard(require("./index"));
|
|
12
|
+
|
|
13
|
+
var _icons = _interopRequireDefault(require("../icons"));
|
|
14
|
+
|
|
15
|
+
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
16
|
+
|
|
17
|
+
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
18
|
+
|
|
19
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
20
|
+
|
|
21
|
+
describe('Labels', function () {
|
|
22
|
+
describe('Default', function () {
|
|
23
|
+
var Default = /*#__PURE__*/_react["default"].createElement(_index["default"], {
|
|
24
|
+
icon: /*#__PURE__*/_react["default"].createElement(_icons["default"], {
|
|
25
|
+
name: "user"
|
|
26
|
+
})
|
|
27
|
+
}, "TESTE");
|
|
28
|
+
|
|
29
|
+
it('should have text content iguals children', function () {
|
|
30
|
+
var _render = (0, _react2.render)(Default),
|
|
31
|
+
container = _render.container;
|
|
32
|
+
|
|
33
|
+
expect(container.firstChild).toHaveTextContent('TESTE');
|
|
34
|
+
});
|
|
35
|
+
it('should be rendering icon from icon prop', function () {
|
|
36
|
+
var _render2 = (0, _react2.render)(Default),
|
|
37
|
+
getByTestId = _render2.getByTestId;
|
|
38
|
+
|
|
39
|
+
expect(getByTestId('icon')).toBeTruthy();
|
|
40
|
+
});
|
|
41
|
+
it('should be rendering icon from iconName prop', function () {
|
|
42
|
+
var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_index["default"], {
|
|
43
|
+
iconName: "user"
|
|
44
|
+
}, "TESTE")),
|
|
45
|
+
getByTestId = _render3.getByTestId;
|
|
46
|
+
|
|
47
|
+
expect(getByTestId('icon')).toBeTruthy();
|
|
48
|
+
});
|
|
49
|
+
it('should have class mini', function () {
|
|
50
|
+
var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_index["default"], {
|
|
51
|
+
iconName: "user",
|
|
52
|
+
size: "mini"
|
|
53
|
+
}, "TESTE")),
|
|
54
|
+
container = _render4.container;
|
|
55
|
+
|
|
56
|
+
expect(container.firstChild).toHaveClass('-mini');
|
|
57
|
+
});
|
|
58
|
+
it('should have class small', function () {
|
|
59
|
+
var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_index["default"], {
|
|
60
|
+
iconName: "user",
|
|
61
|
+
size: "small"
|
|
62
|
+
}, "TESTE")),
|
|
63
|
+
container = _render5.container;
|
|
64
|
+
|
|
65
|
+
expect(container.firstChild).toHaveClass('-small');
|
|
66
|
+
});
|
|
67
|
+
it('should have class large', function () {
|
|
68
|
+
var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_index["default"], {
|
|
69
|
+
iconName: "user",
|
|
70
|
+
size: "large"
|
|
71
|
+
}, "TESTE")),
|
|
72
|
+
container = _render6.container;
|
|
73
|
+
|
|
74
|
+
expect(container.firstChild).toHaveClass('-large');
|
|
75
|
+
});
|
|
76
|
+
it('should apply customClass', function () {
|
|
77
|
+
var _render7 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_index["default"], {
|
|
78
|
+
customClass: "customClass"
|
|
79
|
+
}, "TESTE")),
|
|
80
|
+
container = _render7.container;
|
|
81
|
+
|
|
82
|
+
expect(container.firstChild).toHaveClass('customClass');
|
|
83
|
+
});
|
|
84
|
+
it('should apply border', function () {
|
|
85
|
+
var _render8 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_index["default"], {
|
|
86
|
+
bordered: true
|
|
87
|
+
}, "TESTE")),
|
|
88
|
+
container = _render8.container;
|
|
89
|
+
|
|
90
|
+
expect(container.firstChild).toHaveClass('-bordered');
|
|
91
|
+
});
|
|
92
|
+
it('should apply style prop', function () {
|
|
93
|
+
var _render9 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_index["default"], {
|
|
94
|
+
style: {
|
|
95
|
+
borderWidth: 10
|
|
96
|
+
}
|
|
97
|
+
}, "TESTE")),
|
|
98
|
+
container = _render9.container;
|
|
99
|
+
|
|
100
|
+
expect(container.firstChild).toHaveStyle('border-width: 10px');
|
|
101
|
+
});
|
|
102
|
+
it('should apply invisible prop', function () {
|
|
103
|
+
var _render10 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_index["default"], {
|
|
104
|
+
visible: false
|
|
105
|
+
}, "TESTE")),
|
|
106
|
+
container = _render10.container;
|
|
107
|
+
|
|
108
|
+
expect(container.firstChild).not.toBeTruthy();
|
|
109
|
+
});
|
|
110
|
+
it('should apply right icon align', function () {
|
|
111
|
+
var _render11 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_index["default"], {
|
|
112
|
+
iconName: "user",
|
|
113
|
+
iconAlign: "right"
|
|
114
|
+
}, "TESTE")),
|
|
115
|
+
container = _render11.container;
|
|
116
|
+
|
|
117
|
+
expect(container.firstChild).toHaveClass('icon-right');
|
|
118
|
+
});
|
|
119
|
+
});
|
|
120
|
+
describe('Danger', function () {
|
|
121
|
+
var dangerLabel = /*#__PURE__*/_react["default"].createElement(_index.DangerLabel, null, "TESTE");
|
|
122
|
+
|
|
123
|
+
it('should have class -danger', function () {
|
|
124
|
+
var _render12 = (0, _react2.render)(dangerLabel),
|
|
125
|
+
container = _render12.container;
|
|
126
|
+
|
|
127
|
+
expect(container.firstChild).toHaveClass('-danger');
|
|
128
|
+
});
|
|
129
|
+
});
|
|
130
|
+
describe('Info', function () {
|
|
131
|
+
it('should have class -info', function () {
|
|
132
|
+
var _render13 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_index.InfoLabel, null, "TESTE")),
|
|
133
|
+
container = _render13.container;
|
|
134
|
+
|
|
135
|
+
expect(container.firstChild).toHaveClass('-info');
|
|
136
|
+
});
|
|
137
|
+
});
|
|
138
|
+
describe('Primary', function () {
|
|
139
|
+
it('should have class -primary', function () {
|
|
140
|
+
var _render14 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_index.PrimaryLabel, null, "TESTE")),
|
|
141
|
+
container = _render14.container;
|
|
142
|
+
|
|
143
|
+
expect(container.firstChild).toHaveClass('-primary');
|
|
144
|
+
});
|
|
145
|
+
});
|
|
146
|
+
describe('Success', function () {
|
|
147
|
+
it('should have class -success', function () {
|
|
148
|
+
var _render15 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_index.SuccessLabel, null, "TESTE")),
|
|
149
|
+
container = _render15.container;
|
|
150
|
+
|
|
151
|
+
expect(container.firstChild).toHaveClass('-success');
|
|
152
|
+
});
|
|
153
|
+
});
|
|
154
|
+
describe('Warning', function () {
|
|
155
|
+
it('should have class -warning', function () {
|
|
156
|
+
var _render16 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_index.WarningLabel, null, "TESTE")),
|
|
157
|
+
container = _render16.container;
|
|
158
|
+
|
|
159
|
+
expect(container.firstChild).toHaveClass('-warning');
|
|
160
|
+
});
|
|
161
|
+
});
|
|
162
|
+
});
|
package/lib/list/Item.js
CHANGED
|
@@ -99,12 +99,12 @@ var Item = function Item(props) {
|
|
|
99
99
|
|
|
100
100
|
var getProps = function getProps() {
|
|
101
101
|
if (shouldDisable()) return undefined;
|
|
102
|
-
if (_onClick === undefined && dropdownContext === undefined) return null;
|
|
102
|
+
if (_onClick === undefined && dropdownContext === undefined && !selectable) return null;
|
|
103
103
|
return {
|
|
104
104
|
onClick: function onClick(e) {
|
|
105
|
-
if (_onClick !== undefined) _onClick(e);
|
|
105
|
+
if (_onClick !== undefined) _onClick(e, itemId);
|
|
106
106
|
if (dropdownContext) dropdownContext.handleDropdownClose();
|
|
107
|
-
if (selectable
|
|
107
|
+
if (selectable) handleSelectItem(itemId, _onClick);
|
|
108
108
|
},
|
|
109
109
|
onKeyDown: null,
|
|
110
110
|
role: 'button',
|