linear-react-components-ui 0.4.76-beta.10 → 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/lib/inputs/base/InputTextBase.js +10 -1
- package/lib/inputs/base/helpers.js +19 -3
- package/lib/inputs/date/Dropdown.js +3 -3
- package/lib/inputs/date/helpers.js +36 -0
- package/lib/inputs/date/index.js +10 -9
- package/lib/internals/withTooltip.js +1 -1
- package/lib/tooltip/index.js +2 -5
- package/lib/treeview/Node.js +35 -17
- package/lib/treeview/index.js +3 -1
- package/package.json +1 -1
|
@@ -11,6 +11,8 @@ var _react = _interopRequireWildcard(require("react"));
|
|
|
11
11
|
|
|
12
12
|
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
13
13
|
|
|
14
|
+
var _lodash = _interopRequireDefault(require("lodash"));
|
|
15
|
+
|
|
14
16
|
var _inputHOC = _interopRequireDefault(require("../inputHOC"));
|
|
15
17
|
|
|
16
18
|
require("../../assets/styles/input.scss");
|
|
@@ -111,7 +113,14 @@ var InputTextBase = function InputTextBase(props) {
|
|
|
111
113
|
id: id,
|
|
112
114
|
className: helpers.getInputClass(props),
|
|
113
115
|
ref: function ref(r) {
|
|
114
|
-
if (inputRef)
|
|
116
|
+
if (inputRef) {
|
|
117
|
+
if (!_lodash["default"].isFunction(inputRef)) {
|
|
118
|
+
inputRef.current = r;
|
|
119
|
+
} else {
|
|
120
|
+
inputRef(r);
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
|
|
115
124
|
if (targetRef) targetRef(r);
|
|
116
125
|
}
|
|
117
126
|
};
|
|
@@ -7,9 +7,14 @@ exports.getRightElements = exports.getErrorMessages = exports.getInputWrapperCla
|
|
|
7
7
|
|
|
8
8
|
var _react = _interopRequireDefault(require("react"));
|
|
9
9
|
|
|
10
|
+
var _lodash = _interopRequireDefault(require("lodash"));
|
|
11
|
+
|
|
12
|
+
var _uuid = _interopRequireDefault(require("uuid"));
|
|
13
|
+
|
|
10
14
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
11
15
|
|
|
12
|
-
|
|
16
|
+
function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
|
|
17
|
+
|
|
13
18
|
var getInputClass = function getInputClass(_ref) {
|
|
14
19
|
var textAlign = _ref.textAlign,
|
|
15
20
|
readOnly = _ref.readOnly;
|
|
@@ -39,11 +44,22 @@ var getErrorMessages = function getErrorMessages(messages) {
|
|
|
39
44
|
exports.getErrorMessages = getErrorMessages;
|
|
40
45
|
|
|
41
46
|
var getRightElements = function getRightElements(rightElements, errorMessages) {
|
|
42
|
-
if (errorMessages.length === 0) return rightElements;
|
|
43
47
|
var elements = rightElements || [];
|
|
48
|
+
var newElements = _lodash["default"].isArray(elements) ? elements : [elements];
|
|
49
|
+
|
|
50
|
+
var elementsMap = function elementsMap() {
|
|
51
|
+
return newElements.map(function (element) {
|
|
52
|
+
return _extends({}, element, {
|
|
53
|
+
key: "rightelement-".concat(_uuid["default"].v1())
|
|
54
|
+
});
|
|
55
|
+
});
|
|
56
|
+
};
|
|
57
|
+
|
|
58
|
+
newElements = elementsMap();
|
|
59
|
+
if (errorMessages.length === 0) return newElements;
|
|
44
60
|
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
45
61
|
className: "sidebuttons"
|
|
46
|
-
},
|
|
62
|
+
}, newElements);
|
|
47
63
|
};
|
|
48
64
|
|
|
49
65
|
exports.getRightElements = getRightElements;
|
|
@@ -13,7 +13,7 @@ var _reactDom = _interopRequireDefault(require("react-dom"));
|
|
|
13
13
|
|
|
14
14
|
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
15
15
|
|
|
16
|
-
var
|
|
16
|
+
var _helpers = require("./helpers");
|
|
17
17
|
|
|
18
18
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
19
19
|
|
|
@@ -52,7 +52,7 @@ var Dropdown = /*#__PURE__*/function (_Component) {
|
|
|
52
52
|
_this = _super.call(this, props);
|
|
53
53
|
_this.el = document.createElement('div');
|
|
54
54
|
_this.el.className = 'datepicker-component';
|
|
55
|
-
_this.el.style = (0,
|
|
55
|
+
_this.el.style = (0, _helpers.getCalendarDropdownStyle)(props);
|
|
56
56
|
return _this;
|
|
57
57
|
}
|
|
58
58
|
|
|
@@ -65,7 +65,7 @@ var Dropdown = /*#__PURE__*/function (_Component) {
|
|
|
65
65
|
}, {
|
|
66
66
|
key: "componentDidUpdate",
|
|
67
67
|
value: function componentDidUpdate() {
|
|
68
|
-
this.el.style = (0,
|
|
68
|
+
this.el.style = (0, _helpers.getCalendarDropdownStyle)(this.props);
|
|
69
69
|
}
|
|
70
70
|
}, {
|
|
71
71
|
key: "componentWillUnmount",
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.EN_US_FORMAT = exports.PT_BR_FORMAT = exports.getValue = exports.getCalendarDropdownStyle = void 0;
|
|
7
|
+
|
|
8
|
+
var _moment = _interopRequireDefault(require("moment"));
|
|
9
|
+
|
|
10
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
11
|
+
|
|
12
|
+
var PT_BR_FORMAT = 'DD/MM/YYYY';
|
|
13
|
+
exports.PT_BR_FORMAT = PT_BR_FORMAT;
|
|
14
|
+
var EN_US_FORMAT = 'YYYY-MM-DD';
|
|
15
|
+
exports.EN_US_FORMAT = EN_US_FORMAT;
|
|
16
|
+
|
|
17
|
+
var getCalendarDropdownStyle = function getCalendarDropdownStyle(_ref) {
|
|
18
|
+
var topPosition = _ref.topPosition,
|
|
19
|
+
leftPosition = _ref.leftPosition,
|
|
20
|
+
width = _ref.width;
|
|
21
|
+
return "top: ".concat(topPosition, "px;\n left: ").concat(leftPosition, "px;\n width:").concat(width, "px");
|
|
22
|
+
};
|
|
23
|
+
|
|
24
|
+
exports.getCalendarDropdownStyle = getCalendarDropdownStyle;
|
|
25
|
+
|
|
26
|
+
var getValue = function getValue(value) {
|
|
27
|
+
var stringDataToEnUs = value;
|
|
28
|
+
|
|
29
|
+
if ((0, _moment["default"])(value, PT_BR_FORMAT).isValid()) {
|
|
30
|
+
stringDataToEnUs = (0, _moment["default"])(value, PT_BR_FORMAT).format(EN_US_FORMAT);
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
return typeof value === 'string' ? (0, _moment["default"])(stringDataToEnUs, EN_US_FORMAT) : value;
|
|
34
|
+
};
|
|
35
|
+
|
|
36
|
+
exports.getValue = getValue;
|
package/lib/inputs/date/index.js
CHANGED
|
@@ -31,6 +31,8 @@ var _Dialog = _interopRequireDefault(require("./Dialog"));
|
|
|
31
31
|
|
|
32
32
|
var _colorStyles = _interopRequireDefault(require("../../internals/colorStyles"));
|
|
33
33
|
|
|
34
|
+
var _helpers = require("./helpers");
|
|
35
|
+
|
|
34
36
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
35
37
|
|
|
36
38
|
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); }
|
|
@@ -60,7 +62,6 @@ function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Re
|
|
|
60
62
|
function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
|
|
61
63
|
|
|
62
64
|
var CALENDAR_BUTTON_WIDTH = 24;
|
|
63
|
-
var dateFormat = 'DD/MM/YYYY';
|
|
64
65
|
|
|
65
66
|
var DatePicker = /*#__PURE__*/function (_Component) {
|
|
66
67
|
_inherits(DatePicker, _Component);
|
|
@@ -78,7 +79,7 @@ var DatePicker = /*#__PURE__*/function (_Component) {
|
|
|
78
79
|
|
|
79
80
|
var propsValue = props.value;
|
|
80
81
|
_this.state = {
|
|
81
|
-
value: propsValue ? (0,
|
|
82
|
+
value: propsValue ? (0, _helpers.getValue)(propsValue) : undefined,
|
|
82
83
|
// eslint-disable-next-line react/no-unused-state
|
|
83
84
|
propsValue: propsValue,
|
|
84
85
|
showCalendar: false,
|
|
@@ -116,7 +117,7 @@ var DatePicker = /*#__PURE__*/function (_Component) {
|
|
|
116
117
|
var required = this.props.required;
|
|
117
118
|
if (onDenied && onDenied.unvisible) return null;
|
|
118
119
|
return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement(_BaseMask["default"], _extends({}, this.props, {
|
|
119
|
-
value: !value ? ' ' : value.format(
|
|
120
|
+
value: !value ? ' ' : value.format(_helpers.PT_BR_FORMAT),
|
|
120
121
|
mask: "00/00/0000",
|
|
121
122
|
onComplete: function onComplete(e, date) {
|
|
122
123
|
_this2.setValue(e, date);
|
|
@@ -136,7 +137,7 @@ var DatePicker = /*#__PURE__*/function (_Component) {
|
|
|
136
137
|
inputRef: function inputRef(el) {
|
|
137
138
|
_this2.inputRef = el;
|
|
138
139
|
},
|
|
139
|
-
rightElements:
|
|
140
|
+
rightElements: this.getButtonOpen(),
|
|
140
141
|
required: required,
|
|
141
142
|
handlerSetOnDenied: this.setOnDenied
|
|
142
143
|
})), showCalendar && this.getWrapperComponent());
|
|
@@ -154,9 +155,9 @@ Object.defineProperty(DatePicker, "getDerivedStateFromProps", {
|
|
|
154
155
|
var value = props.value;
|
|
155
156
|
var propsValue = state.propsValue;
|
|
156
157
|
|
|
157
|
-
if (value && (0, _moment["default"])(value,
|
|
158
|
+
if (value && (0, _moment["default"])(value, _helpers.EN_US_FORMAT).format() !== 'Invalid date' && (0, _moment["default"])(propsValue, _helpers.EN_US_FORMAT).format() !== (0, _moment["default"])(value, _helpers.EN_US_FORMAT).format()) {
|
|
158
159
|
return {
|
|
159
|
-
value: (0, _moment["default"])(value),
|
|
160
|
+
value: (0, _moment["default"])(value, _helpers.EN_US_FORMAT),
|
|
160
161
|
propsValue: value
|
|
161
162
|
};
|
|
162
163
|
} else if (!value && value !== propsValue) {
|
|
@@ -262,8 +263,8 @@ var _initialiseProps = function _initialiseProps() {
|
|
|
262
263
|
var onChange = _this3.props.onChange;
|
|
263
264
|
|
|
264
265
|
if (onChange) {
|
|
265
|
-
if ((0, _moment["default"])(_value,
|
|
266
|
-
var newValue = (0, _moment["default"])(_value,
|
|
266
|
+
if ((0, _moment["default"])(_value, _helpers.PT_BR_FORMAT, true).isValid()) {
|
|
267
|
+
var newValue = (0, _moment["default"])(_value, _helpers.PT_BR_FORMAT).format(_helpers.EN_US_FORMAT);
|
|
267
268
|
var obj = {
|
|
268
269
|
target: {
|
|
269
270
|
value: newValue,
|
|
@@ -309,7 +310,7 @@ var _initialiseProps = function _initialiseProps() {
|
|
|
309
310
|
if (_this3.props.shouldCloseOnSelect) showCalendar = false;
|
|
310
311
|
|
|
311
312
|
_this3.setState({
|
|
312
|
-
value: (0, _moment["default"])(_value2,
|
|
313
|
+
value: (0, _moment["default"])(_value2, _helpers.PT_BR_FORMAT),
|
|
313
314
|
showCalendar: showCalendar
|
|
314
315
|
});
|
|
315
316
|
}
|
|
@@ -205,7 +205,7 @@ var withTooltip = function withTooltip(WrappedComponent) {
|
|
|
205
205
|
tooltipPosition: _propTypes["default"].string
|
|
206
206
|
};
|
|
207
207
|
EnhancedComponent.defaultProps = {
|
|
208
|
-
tooltipWidth:
|
|
208
|
+
tooltipWidth: 'auto',
|
|
209
209
|
space: 20,
|
|
210
210
|
tooltip: '',
|
|
211
211
|
tooltipPosition: 'bottom'
|
package/lib/tooltip/index.js
CHANGED
|
@@ -31,19 +31,16 @@ var Tooltip = function Tooltip(props) {
|
|
|
31
31
|
text = props.text,
|
|
32
32
|
tooltipRef = props.tooltipRef;
|
|
33
33
|
var tooltipComponent = (0, _react.useRef)(document.createElement('div'));
|
|
34
|
-
tooltipComponent.current.id = "tooltip-".concat(_uuid["default"].v1());
|
|
35
|
-
tooltipComponent.current.className = "tooltip-component ".concat(className, " ");
|
|
36
|
-
tooltipComponent.current.dataset.testid = 'tooltip-component';
|
|
37
|
-
tooltipComponent.current.style = style;
|
|
38
34
|
(0, _react.useEffect)(function () {
|
|
39
35
|
tooltipComponent.current.id = "tooltip-".concat(_uuid["default"].v1());
|
|
40
36
|
tooltipComponent.current.className = "tooltip-component ".concat(className, " ");
|
|
37
|
+
tooltipComponent.current.dataset.testid = 'tooltip-component';
|
|
41
38
|
tooltipComponent.current.style = style;
|
|
42
39
|
document.body.appendChild(tooltipComponent.current);
|
|
43
40
|
var tooltipEl = document.querySelector("div#".concat(tooltipComponent.current.id));
|
|
44
41
|
var width = tooltipEl.offsetWidth;
|
|
45
42
|
|
|
46
|
-
if (tooltipDimensions.width
|
|
43
|
+
if (tooltipDimensions.width) {
|
|
47
44
|
width = tooltipDimensions.width;
|
|
48
45
|
}
|
|
49
46
|
|
package/lib/treeview/Node.js
CHANGED
|
@@ -67,12 +67,16 @@ function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Re
|
|
|
67
67
|
|
|
68
68
|
function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
|
|
69
69
|
|
|
70
|
+
var nodeHasItens = function nodeHasItens(node) {
|
|
71
|
+
return node.itens && node.itens.length > 0;
|
|
72
|
+
};
|
|
73
|
+
|
|
70
74
|
var TreeNode = /*#__PURE__*/function (_Component) {
|
|
71
75
|
_inherits(TreeNode, _Component);
|
|
72
76
|
|
|
73
77
|
var _super = _createSuper(TreeNode);
|
|
74
78
|
|
|
75
|
-
function TreeNode(props
|
|
79
|
+
function TreeNode(props) {
|
|
76
80
|
var _this;
|
|
77
81
|
|
|
78
82
|
_classCallCheck(this, TreeNode);
|
|
@@ -82,12 +86,12 @@ var TreeNode = /*#__PURE__*/function (_Component) {
|
|
|
82
86
|
_initialiseProps.call(_assertThisInitialized(_this));
|
|
83
87
|
|
|
84
88
|
_this.labelRef = /*#__PURE__*/_react["default"].createRef();
|
|
85
|
-
var node = props.node
|
|
86
|
-
|
|
87
|
-
var nodeHasItens = node.itens && node.itens.length > 0;
|
|
89
|
+
var node = props.node,
|
|
90
|
+
startNodesOpened = props.startNodesOpened;
|
|
88
91
|
_this.state = {
|
|
89
|
-
|
|
90
|
-
|
|
92
|
+
node: node,
|
|
93
|
+
isVisible: startNodesOpened && nodeHasItens(node),
|
|
94
|
+
wasOpened: startNodesOpened && nodeHasItens(node),
|
|
91
95
|
showNodeElements: false,
|
|
92
96
|
keepMenuOpened: false
|
|
93
97
|
};
|
|
@@ -126,11 +130,11 @@ var TreeNode = /*#__PURE__*/function (_Component) {
|
|
|
126
130
|
var _this2 = this;
|
|
127
131
|
|
|
128
132
|
var _this$props3 = this.props,
|
|
129
|
-
node = _this$props3.node,
|
|
130
133
|
children = _this$props3.children,
|
|
131
134
|
isParent = _this$props3.isParent,
|
|
132
135
|
onNodeClick = _this$props3.onNodeClick,
|
|
133
136
|
nodeMenuButtonSize = _this$props3.nodeMenuButtonSize;
|
|
137
|
+
var node = this.state.node;
|
|
134
138
|
var showNodeElements = this.state.showNodeElements;
|
|
135
139
|
return /*#__PURE__*/_react["default"].createElement(_constants.TreeviewContext.Consumer, null, function (_ref) {
|
|
136
140
|
var valuePropName = _ref.valuePropName,
|
|
@@ -207,6 +211,22 @@ var TreeNode = /*#__PURE__*/function (_Component) {
|
|
|
207
211
|
}, _this2.state.isVisible && children));
|
|
208
212
|
});
|
|
209
213
|
}
|
|
214
|
+
}], [{
|
|
215
|
+
key: "getDerivedStateFromProps",
|
|
216
|
+
value: function getDerivedStateFromProps(props, state) {
|
|
217
|
+
var node = props.node,
|
|
218
|
+
startNodesOpened = props.startNodesOpened;
|
|
219
|
+
|
|
220
|
+
if (node !== state.node) {
|
|
221
|
+
return {
|
|
222
|
+
node: node,
|
|
223
|
+
isVisible: startNodesOpened && nodeHasItens(node),
|
|
224
|
+
wasOpened: startNodesOpened && nodeHasItens(node)
|
|
225
|
+
};
|
|
226
|
+
}
|
|
227
|
+
|
|
228
|
+
return null;
|
|
229
|
+
}
|
|
210
230
|
}]);
|
|
211
231
|
|
|
212
232
|
return TreeNode;
|
|
@@ -220,9 +240,8 @@ var _initialiseProps = function _initialiseProps() {
|
|
|
220
240
|
enumerable: true,
|
|
221
241
|
writable: true,
|
|
222
242
|
value: function value() {
|
|
223
|
-
var
|
|
224
|
-
|
|
225
|
-
alwaysShowArrow = _this3$props.alwaysShowArrow;
|
|
243
|
+
var alwaysShowArrow = _this3.props.alwaysShowArrow;
|
|
244
|
+
var node = _this3.state.node;
|
|
226
245
|
|
|
227
246
|
var span = /*#__PURE__*/_react["default"].createElement("noscript", null);
|
|
228
247
|
|
|
@@ -289,9 +308,8 @@ var _initialiseProps = function _initialiseProps() {
|
|
|
289
308
|
enumerable: true,
|
|
290
309
|
writable: true,
|
|
291
310
|
value: function value(elements) {
|
|
292
|
-
var
|
|
293
|
-
|
|
294
|
-
nodeElementsValidations = _this3$props2.nodeElementsValidations;
|
|
311
|
+
var nodeElementsValidations = _this3.props.nodeElementsValidations;
|
|
312
|
+
var node = _this3.state.node;
|
|
295
313
|
var updatedElements = [];
|
|
296
314
|
|
|
297
315
|
if (elements) {
|
|
@@ -370,9 +388,8 @@ var _initialiseProps = function _initialiseProps() {
|
|
|
370
388
|
enumerable: true,
|
|
371
389
|
writable: true,
|
|
372
390
|
value: function value(validationKey) {
|
|
373
|
-
var
|
|
374
|
-
|
|
375
|
-
node = _this3$props3.node;
|
|
391
|
+
var nodeElementsValidations = _this3.props.nodeElementsValidations;
|
|
392
|
+
var node = _this3.state.node;
|
|
376
393
|
var validations = nodeElementsValidations[validationKey];
|
|
377
394
|
var options = {
|
|
378
395
|
disabled: {
|
|
@@ -413,7 +430,8 @@ TreeNode.propTypes = {
|
|
|
413
430
|
nodeMenuButtonSize: _propTypes["default"].oneOf(['mini', 'small', 'medium', 'large', 'default']),
|
|
414
431
|
onNodeClick: _propTypes["default"].func,
|
|
415
432
|
handlerOnNodeOpen: _propTypes["default"].func,
|
|
416
|
-
nodeElementsValidations: _propTypes["default"].object
|
|
433
|
+
nodeElementsValidations: _propTypes["default"].object,
|
|
434
|
+
startNodesOpened: _propTypes["default"].bool.isRequired
|
|
417
435
|
};
|
|
418
436
|
TreeNode.defaultProps = {
|
|
419
437
|
childrenIds: [],
|
package/lib/treeview/index.js
CHANGED
|
@@ -462,7 +462,8 @@ var TreeView = /*#__PURE__*/function (_Component) {
|
|
|
462
462
|
nodeElementsValidations = _this$props3.nodeElementsValidations,
|
|
463
463
|
nodeToolbarElements = _this$props3.nodeToolbarElements,
|
|
464
464
|
nodeMenuButtonSize = _this$props3.nodeMenuButtonSize,
|
|
465
|
-
alwaysShowArrow = _this$props3.alwaysShowArrow
|
|
465
|
+
alwaysShowArrow = _this$props3.alwaysShowArrow,
|
|
466
|
+
startNodesOpened = _this$props3.startNodesOpened;
|
|
466
467
|
var childrenIds = [];
|
|
467
468
|
|
|
468
469
|
if (node.itens && node.itens.length > 0) {
|
|
@@ -480,6 +481,7 @@ var TreeView = /*#__PURE__*/function (_Component) {
|
|
|
480
481
|
return /*#__PURE__*/_react["default"].createElement(_Node["default"], {
|
|
481
482
|
key: "node-".concat(node.id),
|
|
482
483
|
node: node,
|
|
484
|
+
startNodesOpened: startNodesOpened,
|
|
483
485
|
alwaysShowArrow: alwaysShowArrow,
|
|
484
486
|
childrenIds: childrenIds,
|
|
485
487
|
isParent: node.itens && node.itens.length > 0,
|