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.
Files changed (131) hide show
  1. package/.eslintrc.js +2 -5
  2. package/.tool-versions +1 -0
  3. package/.vscode/settings.json +8 -9
  4. package/README.md +33 -0
  5. package/config/jest/cssTransform.js +14 -0
  6. package/config/jest/fileTransform.js +12 -0
  7. package/config/jest/storageMock.js +40 -0
  8. package/jest.config.js +18 -0
  9. package/lib/alerts/alert.spec.js +133 -0
  10. package/lib/assets/styles/dropdown.scss +28 -2
  11. package/lib/assets/styles/effects.scss +12 -0
  12. package/lib/assets/styles/floatMenu.scss +0 -1
  13. package/lib/assets/styles/multiSelect.scss +105 -0
  14. package/lib/assets/styles/panel.scss +0 -1
  15. package/lib/assets/styles/periodpicker.scss +65 -0
  16. package/lib/assets/styles/popover.scss +9 -11
  17. package/lib/assets/styles/progress.scss +8 -1
  18. package/lib/assets/styles/select.scss +1 -0
  19. package/lib/assets/styles/table.scss +13 -5
  20. package/lib/assets/styles/tabs.scss +79 -44
  21. package/lib/assets/styles/treeview.scss +32 -0
  22. package/lib/avatar/avatar.spec.js +190 -0
  23. package/lib/avatar/index.js +6 -2
  24. package/lib/badge/badge.spec.js +127 -0
  25. package/lib/badge/index.js +3 -5
  26. package/lib/buttons/DefaultButton.js +7 -1
  27. package/lib/buttons/buttons.spec.js +504 -0
  28. package/lib/calendar/calendar.spec.js +171 -0
  29. package/lib/checkbox/Label.js +37 -0
  30. package/lib/checkbox/checkbox.spec.js +215 -0
  31. package/lib/checkbox/index.js +21 -6
  32. package/lib/dialog/Custom.js +7 -1
  33. package/lib/dialog/base/index.js +18 -6
  34. package/lib/dialog/dialog.spec.js +488 -0
  35. package/lib/dialog/form/index.js +23 -4
  36. package/lib/drawer/Drawer.js +3 -0
  37. package/lib/drawer/Drawer.spec.js +258 -0
  38. package/lib/drawer/Header.js +4 -1
  39. package/lib/drawer/index.js +4 -1
  40. package/lib/dropdown/Popup.js +1 -0
  41. package/lib/dropdown/dropdown.spec.js +168 -0
  42. package/lib/dropdown/withDropdown.js +10 -4
  43. package/lib/fieldset/fieldset.spec.js +329 -0
  44. package/lib/form/Field.js +2 -0
  45. package/lib/form/FieldNumber.js +10 -2
  46. package/lib/form/FieldPeriod.js +100 -0
  47. package/lib/form/form.spec.js +285 -0
  48. package/lib/form/helpers.js +9 -1
  49. package/lib/form/index.js +209 -222
  50. package/lib/form/withFieldHOC.js +2 -0
  51. package/lib/form/withFormSecurity.js +106 -0
  52. package/lib/gridlayout/GridRow.js +1 -1
  53. package/lib/gridlayout/gridLayout.spec.js +169 -0
  54. package/lib/icons/helper.js +16 -0
  55. package/lib/icons/icons.spec.js +86 -0
  56. package/lib/icons/index.js +2 -0
  57. package/lib/inputs/base/InputTextBase.js +24 -5
  58. package/lib/inputs/base/base.spec.js +690 -0
  59. package/lib/inputs/base/helpers.js +19 -3
  60. package/lib/inputs/color/color_input.spec.js +174 -0
  61. package/lib/inputs/color/index.js +2 -2
  62. package/lib/inputs/date/Dropdown.js +3 -3
  63. package/lib/inputs/date/date.spec.js +344 -0
  64. package/lib/inputs/date/helpers.js +36 -0
  65. package/lib/inputs/date/index.js +11 -9
  66. package/lib/inputs/mask/Cpf.js +9 -9
  67. package/lib/inputs/mask/input_mask.spec.js +590 -0
  68. package/lib/inputs/multiSelect/ActionButtons.js +68 -0
  69. package/lib/inputs/multiSelect/Dropdown.js +200 -0
  70. package/lib/inputs/multiSelect/helper.js +18 -0
  71. package/lib/inputs/multiSelect/index.js +343 -0
  72. package/lib/inputs/number/BaseNumber.js +1 -1
  73. package/lib/inputs/number/index.js +7 -5
  74. package/lib/inputs/number/numberfield.spec.js +215 -0
  75. package/lib/inputs/period/Dialog.js +38 -0
  76. package/lib/inputs/period/Dropdown.js +90 -0
  77. package/lib/inputs/period/PeriodList.js +79 -0
  78. package/lib/inputs/period/helper.js +118 -0
  79. package/lib/inputs/period/index.js +490 -0
  80. package/lib/inputs/search/search_input.spec.js +209 -0
  81. package/lib/inputs/select/Dropdown.js +4 -4
  82. package/lib/inputs/select/index.js +26 -3
  83. package/lib/inputs/select/multiple/index.js +9 -7
  84. package/lib/inputs/select/select.spec.js +391 -0
  85. package/lib/inputs/select/simple/index.js +30 -18
  86. package/lib/inputs/text/textfield.spec.js +215 -0
  87. package/lib/inputs/textarea/textarea.spec.js +59 -0
  88. package/lib/internals/withTooltip.js +86 -82
  89. package/lib/labelMessages/index.js +3 -2
  90. package/lib/labelMessages/labelMessages.spec.js +176 -0
  91. package/lib/labels/label.spec.js +162 -0
  92. package/lib/list/Item.js +3 -3
  93. package/lib/list/index.js +21 -10
  94. package/lib/list/list.spec.js +611 -0
  95. package/lib/menus/float/MenuItem.js +25 -8
  96. package/lib/menus/float/float-menu.spec.js +221 -0
  97. package/lib/menus/sidenav/index.js +7 -3
  98. package/lib/menus/sidenav/popup_menu_search/index.js +1 -1
  99. package/lib/menus/sidenav/sidenav.spec.js +312 -0
  100. package/lib/noPermission/index.js +2 -1
  101. package/lib/panel/panel.spec.js +216 -0
  102. package/lib/popover/index.js +2 -1
  103. package/lib/popover/popover.spec.js +146 -0
  104. package/lib/progress/Bar.js +40 -9
  105. package/lib/progress/index.js +12 -4
  106. package/lib/progress/progress.spec.js +86 -0
  107. package/lib/radio/radio.spec.js +189 -0
  108. package/lib/spinner/SpinnerLoading.js +14 -24
  109. package/lib/spinner/index.js +6 -1
  110. package/lib/spinner/spinner.spec.js +152 -0
  111. package/lib/split/Split.js +10 -12
  112. package/lib/split/split.spec.js +151 -0
  113. package/lib/table/Header.js +3 -1
  114. package/lib/table/Row.js +2 -5
  115. package/lib/table/index.js +1 -4
  116. package/lib/table/table.spec.js +352 -0
  117. package/lib/tabs/DropdownItems.js +84 -0
  118. package/lib/tabs/Menu.js +18 -5
  119. package/lib/tabs/MenuItems.js +7 -7
  120. package/lib/tabs/Panel.js +1 -3
  121. package/lib/tabs/index.js +151 -20
  122. package/lib/tabs/tabs.spec.js +349 -0
  123. package/lib/toolbar/index.js +8 -4
  124. package/lib/toolbar/toolbar.spec.js +394 -0
  125. package/lib/tooltip/index.js +20 -6
  126. package/lib/tooltip/tooltip.spec.js +203 -0
  127. package/lib/treeview/Node.js +347 -48
  128. package/lib/treeview/index.js +456 -35
  129. package/lib/treeview/treeview.spec.js +261 -0
  130. package/package.json +19 -9
  131. 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)(false),
53
+ var _useState = (0, _react.useState)(props.tooltipPosition),
53
54
  _useState2 = _slicedToArray(_useState, 2),
54
- showTooltip = _useState2[0],
55
- setShowTooltip = _useState2[1];
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
- tooltipDimensions = _useState4[0],
63
- setTooltipDimensions = _useState4[1];
60
+ tooltipStyle = _useState4[0],
61
+ setTooltipStyle = _useState4[1];
64
62
 
65
- var _useState5 = (0, _react.useState)(true),
63
+ var _useState5 = (0, _react.useState)(false),
66
64
  _useState6 = _slicedToArray(_useState5, 2),
67
- findScrollableParent = _useState6[0],
68
- setFindScrollableParent = _useState6[1];
65
+ showTooltip = _useState6[0],
66
+ setShowTooltip = _useState6[1];
69
67
 
70
- var _useState7 = (0, _react.useState)(undefined),
68
+ var _useState7 = (0, _react.useState)({
69
+ width: tooltipWidth,
70
+ height: TOOLTIP_INITIAL_HEIGHT
71
+ }),
71
72
  _useState8 = _slicedToArray(_useState7, 2),
72
- dimensionsTargetElement = _useState8[0],
73
- setDimensionsTargetElement = _useState8[1];
73
+ tooltipDimensions = _useState8[0],
74
+ setTooltipDimensions = _useState8[1];
74
75
 
75
- var scrollableParent = (0, _react.useRef)();
76
- var targetElement = (0, _react.useRef)();
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 === e.target) {
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 onParentScroll = function onParentScroll() {
89
- var currentDimensions = targetElement.current.getBoundingClientRect();
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
- var getStyle = function getStyle() {
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
- return style;
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
- style: getStyle(),
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 /*#__PURE__*/_react["default"].createElement("noscript", null);
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 && handleSelectItem(itemId)) ;
107
+ if (selectable) handleSelectItem(itemId, _onClick);
108
108
  },
109
109
  onKeyDown: null,
110
110
  role: 'button',