@pie-lib/config-ui 13.0.4-next.31 → 13.0.4-next.36
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/CHANGELOG.json +32 -0
- package/CHANGELOG.md +2419 -0
- package/LICENSE.md +5 -0
- package/lib/alert-dialog.js +68 -0
- package/lib/alert-dialog.js.map +1 -0
- package/lib/checkbox.js +84 -0
- package/lib/checkbox.js.map +1 -0
- package/lib/choice-configuration/feedback-menu.js +129 -0
- package/lib/choice-configuration/feedback-menu.js.map +1 -0
- package/lib/choice-configuration/index.js +381 -0
- package/lib/choice-configuration/index.js.map +1 -0
- package/lib/choice-utils.js +42 -0
- package/lib/choice-utils.js.map +1 -0
- package/lib/feedback-config/feedback-selector.js +155 -0
- package/lib/feedback-config/feedback-selector.js.map +1 -0
- package/lib/feedback-config/group.js +61 -0
- package/lib/feedback-config/group.js.map +1 -0
- package/lib/feedback-config/index.js +146 -0
- package/lib/feedback-config/index.js.map +1 -0
- package/lib/form-section.js +44 -0
- package/lib/form-section.js.map +1 -0
- package/lib/help.js +106 -0
- package/lib/help.js.map +1 -0
- package/lib/index.js +186 -0
- package/lib/index.js.map +1 -0
- package/lib/input.js +106 -0
- package/lib/input.js.map +1 -0
- package/lib/inputs.js +105 -0
- package/lib/inputs.js.map +1 -0
- package/lib/langs.js +136 -0
- package/lib/langs.js.map +1 -0
- package/lib/layout/config-layout.js +137 -0
- package/lib/layout/config-layout.js.map +1 -0
- package/lib/layout/index.js +21 -0
- package/lib/layout/index.js.map +1 -0
- package/lib/layout/layout-contents.js +160 -0
- package/lib/layout/layout-contents.js.map +1 -0
- package/lib/layout/settings-box.js +57 -0
- package/lib/layout/settings-box.js.map +1 -0
- package/lib/mui-box/index.js +63 -0
- package/lib/mui-box/index.js.map +1 -0
- package/lib/number-text-field-custom.js +376 -0
- package/lib/number-text-field-custom.js.map +1 -0
- package/lib/number-text-field.js +229 -0
- package/lib/number-text-field.js.map +1 -0
- package/lib/radio-with-label.js +48 -0
- package/lib/radio-with-label.js.map +1 -0
- package/lib/settings/display-size.js +61 -0
- package/lib/settings/display-size.js.map +1 -0
- package/lib/settings/index.js +110 -0
- package/lib/settings/index.js.map +1 -0
- package/lib/settings/panel.js +392 -0
- package/lib/settings/panel.js.map +1 -0
- package/lib/settings/settings-radio-label.js +51 -0
- package/lib/settings/settings-radio-label.js.map +1 -0
- package/lib/settings/toggle.js +63 -0
- package/lib/settings/toggle.js.map +1 -0
- package/lib/tabs/index.js +75 -0
- package/lib/tabs/index.js.map +1 -0
- package/lib/tags-input/index.js +149 -0
- package/lib/tags-input/index.js.map +1 -0
- package/lib/two-choice.js +136 -0
- package/lib/two-choice.js.map +1 -0
- package/lib/with-stateful-model.js +61 -0
- package/lib/with-stateful-model.js.map +1 -0
- package/package.json +19 -33
- package/src/__tests__/alert-dialog.test.jsx +183 -0
- package/src/__tests__/checkbox.test.jsx +152 -0
- package/src/__tests__/choice-utils.test.js +12 -0
- package/src/__tests__/form-section.test.jsx +328 -0
- package/src/__tests__/help.test.jsx +184 -0
- package/src/__tests__/input.test.jsx +156 -0
- package/src/__tests__/langs.test.jsx +376 -0
- package/src/__tests__/number-text-field-custom.test.jsx +255 -0
- package/src/__tests__/number-text-field.test.jsx +263 -0
- package/src/__tests__/radio-with-label.test.jsx +155 -0
- package/src/__tests__/settings-panel.test.js +187 -0
- package/src/__tests__/settings.test.jsx +452 -0
- package/src/__tests__/tabs.test.jsx +188 -0
- package/src/__tests__/two-choice.test.js +110 -0
- package/src/__tests__/with-stateful-model.test.jsx +139 -0
- package/src/alert-dialog.jsx +75 -0
- package/src/checkbox.jsx +61 -0
- package/src/choice-configuration/__tests__/feedback-menu.test.jsx +151 -0
- package/src/choice-configuration/__tests__/index.test.jsx +234 -0
- package/src/choice-configuration/feedback-menu.jsx +96 -0
- package/src/choice-configuration/index.jsx +357 -0
- package/src/choice-utils.js +30 -0
- package/src/feedback-config/__tests__/feedback-config.test.jsx +141 -0
- package/src/feedback-config/__tests__/feedback-selector.test.jsx +97 -0
- package/src/feedback-config/feedback-selector.jsx +112 -0
- package/src/feedback-config/group.jsx +51 -0
- package/src/feedback-config/index.jsx +111 -0
- package/src/form-section.jsx +31 -0
- package/src/help.jsx +79 -0
- package/src/index.js +55 -0
- package/src/input.jsx +72 -0
- package/src/inputs.jsx +69 -0
- package/src/langs.jsx +111 -0
- package/src/layout/__tests__/config.layout.test.jsx +59 -0
- package/src/layout/__tests__/layout-content.test.jsx +3 -0
- package/src/layout/config-layout.jsx +103 -0
- package/src/layout/index.js +4 -0
- package/src/layout/layout-contents.jsx +117 -0
- package/src/layout/settings-box.jsx +32 -0
- package/src/mui-box/index.jsx +56 -0
- package/src/number-text-field-custom.jsx +333 -0
- package/src/number-text-field.jsx +215 -0
- package/src/radio-with-label.jsx +30 -0
- package/src/settings/display-size.jsx +53 -0
- package/src/settings/index.js +83 -0
- package/src/settings/panel.jsx +333 -0
- package/src/settings/settings-radio-label.jsx +32 -0
- package/src/settings/toggle.jsx +46 -0
- package/src/tabs/index.jsx +47 -0
- package/src/tags-input/__tests__/index.test.jsx +113 -0
- package/src/tags-input/index.jsx +116 -0
- package/src/two-choice.jsx +90 -0
- package/src/with-stateful-model.jsx +36 -0
- package/dist/_virtual/_rolldown/runtime.js +0 -11
- package/dist/alert-dialog.d.ts +0 -44
- package/dist/alert-dialog.js +0 -47
- package/dist/checkbox.d.ts +0 -34
- package/dist/checkbox.js +0 -57
- package/dist/choice-configuration/feedback-menu.d.ts +0 -32
- package/dist/choice-configuration/feedback-menu.js +0 -85
- package/dist/choice-configuration/index.d.ts +0 -62
- package/dist/choice-configuration/index.js +0 -240
- package/dist/choice-utils.d.ts +0 -21
- package/dist/choice-utils.js +0 -15
- package/dist/feedback-config/feedback-selector.d.ts +0 -33
- package/dist/feedback-config/feedback-selector.js +0 -92
- package/dist/feedback-config/group.d.ts +0 -21
- package/dist/feedback-config/group.js +0 -33
- package/dist/feedback-config/index.d.ts +0 -48
- package/dist/feedback-config/index.js +0 -96
- package/dist/form-section.d.ts +0 -25
- package/dist/form-section.js +0 -25
- package/dist/fraction-to-number.d.ts +0 -7
- package/dist/fraction-to-number.js +0 -9
- package/dist/help.d.ts +0 -41
- package/dist/help.js +0 -61
- package/dist/index.d.ts +0 -31
- package/dist/index.js +0 -34
- package/dist/input.d.ts +0 -29
- package/dist/input.js +0 -65
- package/dist/inputs.d.ts +0 -63
- package/dist/inputs.js +0 -70
- package/dist/langs.d.ts +0 -41
- package/dist/langs.js +0 -76
- package/dist/layout/config-layout.d.ts +0 -10
- package/dist/layout/config-layout.js +0 -75
- package/dist/layout/index.d.ts +0 -11
- package/dist/layout/index.js +0 -10
- package/dist/layout/layout-contents.d.ts +0 -21
- package/dist/layout/layout-contents.js +0 -70
- package/dist/layout/settings-box.d.ts +0 -19
- package/dist/layout/settings-box.js +0 -31
- package/dist/mui-box/index.d.ts +0 -21
- package/dist/mui-box/index.js +0 -47
- package/dist/node_modules/.bun/@babel_runtime@7.28.6/node_modules/@babel/runtime/helpers/esm/extends.js +0 -12
- package/dist/node_modules/.bun/@babel_runtime@7.28.6/node_modules/@babel/runtime/helpers/esm/inheritsLoose.js +0 -7
- package/dist/node_modules/.bun/@babel_runtime@7.28.6/node_modules/@babel/runtime/helpers/esm/objectWithoutPropertiesLoose.js +0 -12
- package/dist/node_modules/.bun/@babel_runtime@7.28.6/node_modules/@babel/runtime/helpers/esm/setPrototypeOf.js +0 -8
- package/dist/node_modules/.bun/react-measure@2.5.2_6dbf9a050bc9aadb/node_modules/react-measure/dist/index.esm.js +0 -122
- package/dist/node_modules/.bun/resize-observer-polyfill@1.5.1/node_modules/resize-observer-polyfill/dist/ResizeObserver.es.js +0 -276
- package/dist/number-text-field-custom.d.ts +0 -51
- package/dist/number-text-field-custom.js +0 -192
- package/dist/number-text-field.d.ts +0 -47
- package/dist/number-text-field.js +0 -122
- package/dist/radio-with-label.d.ts +0 -25
- package/dist/radio-with-label.js +0 -27
- package/dist/settings/display-size.d.ts +0 -26
- package/dist/settings/display-size.js +0 -45
- package/dist/settings/index.d.ts +0 -45
- package/dist/settings/index.js +0 -63
- package/dist/settings/panel.d.ts +0 -27
- package/dist/settings/panel.js +0 -201
- package/dist/settings/settings-radio-label.d.ts +0 -25
- package/dist/settings/settings-radio-label.js +0 -29
- package/dist/settings/toggle.d.ts +0 -25
- package/dist/settings/toggle.js +0 -33
- package/dist/tabs/index.d.ts +0 -22
- package/dist/tabs/index.js +0 -39
- package/dist/tags-input/index.d.ts +0 -21
- package/dist/tags-input/index.js +0 -83
- package/dist/two-choice.d.ts +0 -43
- package/dist/two-choice.js +0 -79
- package/dist/with-stateful-model.d.ts +0 -42
- package/dist/with-stateful-model.js +0 -32
|
@@ -0,0 +1,376 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _typeof = require("@babel/runtime/helpers/typeof");
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports["default"] = exports.NumberTextFieldCustom = void 0;
|
|
9
|
+
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
10
|
+
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
|
|
11
|
+
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
|
|
12
|
+
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
|
|
13
|
+
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
|
|
14
|
+
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
|
|
15
|
+
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
16
|
+
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
17
|
+
var _react = _interopRequireDefault(require("react"));
|
|
18
|
+
var _TextField = _interopRequireDefault(require("@mui/material/TextField"));
|
|
19
|
+
var _styles = require("@mui/material/styles");
|
|
20
|
+
var _lodashEs = require("lodash-es");
|
|
21
|
+
var _IconButton = _interopRequireDefault(require("@mui/material/IconButton"));
|
|
22
|
+
var _InputAdornment = _interopRequireDefault(require("@mui/material/InputAdornment"));
|
|
23
|
+
var _Remove = _interopRequireDefault(require("@mui/icons-material/Remove"));
|
|
24
|
+
var _Add = _interopRequireDefault(require("@mui/icons-material/Add"));
|
|
25
|
+
var math = _interopRequireWildcard(require("mathjs"));
|
|
26
|
+
function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function _interopRequireWildcard(e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, "default": e }; if (null === e || "object" != _typeof(e) && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (var _t in e) "default" !== _t && {}.hasOwnProperty.call(e, _t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, _t)) && (i.get || i.set) ? o(f, _t, i) : f[_t] = e[_t]); return f; })(e, t); }
|
|
27
|
+
function _callSuper(t, o, e) { return o = (0, _getPrototypeOf2["default"])(o), (0, _possibleConstructorReturn2["default"])(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], (0, _getPrototypeOf2["default"])(t).constructor) : o.apply(t, e)); }
|
|
28
|
+
function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); }
|
|
29
|
+
var StyledTextField = (0, _styles.styled)(_TextField["default"])(function () {
|
|
30
|
+
return {
|
|
31
|
+
'& input[type=number]': {
|
|
32
|
+
MozAppearance: 'textfield'
|
|
33
|
+
},
|
|
34
|
+
'& input[type=number]::-webkit-outer-spin-button': {
|
|
35
|
+
WebkitAppearance: 'none',
|
|
36
|
+
margin: 0
|
|
37
|
+
},
|
|
38
|
+
'& input[type=number]::-webkit-inner-spin-button': {
|
|
39
|
+
WebkitAppearance: 'none',
|
|
40
|
+
margin: 0
|
|
41
|
+
}
|
|
42
|
+
};
|
|
43
|
+
});
|
|
44
|
+
var StyledIconButton = (0, _styles.styled)(_IconButton["default"])(function () {
|
|
45
|
+
return {
|
|
46
|
+
padding: '2px'
|
|
47
|
+
};
|
|
48
|
+
});
|
|
49
|
+
var fallbackNumber = function fallbackNumber(min, max) {
|
|
50
|
+
if (!(0, _lodashEs.isFinite)(min) && !(0, _lodashEs.isFinite)(max)) {
|
|
51
|
+
return 0;
|
|
52
|
+
}
|
|
53
|
+
if (!(0, _lodashEs.isFinite)(min) && (0, _lodashEs.isFinite)(max)) {
|
|
54
|
+
return max;
|
|
55
|
+
}
|
|
56
|
+
if ((0, _lodashEs.isFinite)(min)) {
|
|
57
|
+
return min;
|
|
58
|
+
}
|
|
59
|
+
};
|
|
60
|
+
var NumberTextFieldCustom = exports.NumberTextFieldCustom = /*#__PURE__*/function (_React$Component) {
|
|
61
|
+
function NumberTextFieldCustom(props) {
|
|
62
|
+
var _this;
|
|
63
|
+
(0, _classCallCheck2["default"])(this, NumberTextFieldCustom);
|
|
64
|
+
_this = _callSuper(this, NumberTextFieldCustom, [props]);
|
|
65
|
+
(0, _defineProperty2["default"])(_this, "normalizeValueAndIndex", function (customValues, number, min, max) {
|
|
66
|
+
var type = _this.props.type;
|
|
67
|
+
var value = _this.clamp(number, min, max);
|
|
68
|
+
var currentIndex = (customValues || []).findIndex(function (val) {
|
|
69
|
+
return val === value;
|
|
70
|
+
});
|
|
71
|
+
if ((customValues || []).length > 0 && currentIndex === -1) {
|
|
72
|
+
var closestValue = type === 'text' ? _this.getClosestFractionValue(customValues, value) : _this.getClosestValue(customValues, value);
|
|
73
|
+
return {
|
|
74
|
+
value: closestValue.value,
|
|
75
|
+
currentIndex: closestValue.index
|
|
76
|
+
};
|
|
77
|
+
}
|
|
78
|
+
return {
|
|
79
|
+
value: value,
|
|
80
|
+
currentIndex: currentIndex
|
|
81
|
+
};
|
|
82
|
+
});
|
|
83
|
+
(0, _defineProperty2["default"])(_this, "getClosestValue", function (customValues, number) {
|
|
84
|
+
return customValues.reduce(function (closest, value, index) {
|
|
85
|
+
return Math.abs(value - number) < Math.abs(closest.value - number) ? {
|
|
86
|
+
value: value,
|
|
87
|
+
index: index
|
|
88
|
+
} : closest;
|
|
89
|
+
}, {
|
|
90
|
+
value: customValues[0],
|
|
91
|
+
index: 0
|
|
92
|
+
});
|
|
93
|
+
});
|
|
94
|
+
(0, _defineProperty2["default"])(_this, "getClosestFractionValue", function (customValues, number) {
|
|
95
|
+
return customValues.reduce(function (closest, value, index) {
|
|
96
|
+
return Math.abs(math.number(math.fraction(value)) - math.number(math.fraction(number))) < Math.abs(math.number(math.fraction(closest.value)) - math.number(math.fraction(number))) ? {
|
|
97
|
+
value: value,
|
|
98
|
+
index: index
|
|
99
|
+
} : closest;
|
|
100
|
+
}, {
|
|
101
|
+
value: customValues[0],
|
|
102
|
+
index: 0
|
|
103
|
+
});
|
|
104
|
+
});
|
|
105
|
+
(0, _defineProperty2["default"])(_this, "getValidFraction", function (value) {
|
|
106
|
+
if (_this.isPositiveInteger(value.trim())) {
|
|
107
|
+
return value.trim();
|
|
108
|
+
}
|
|
109
|
+
if (value.trim() === '' || value.trim().split('/').length !== 2) {
|
|
110
|
+
return false;
|
|
111
|
+
}
|
|
112
|
+
var _value$trim$split = value.trim().split('/'),
|
|
113
|
+
_value$trim$split2 = (0, _slicedToArray2["default"])(_value$trim$split, 2),
|
|
114
|
+
numerator = _value$trim$split2[0],
|
|
115
|
+
denominator = _value$trim$split2[1];
|
|
116
|
+
if (isNaN(numerator) || isNaN(denominator)) {
|
|
117
|
+
return false;
|
|
118
|
+
}
|
|
119
|
+
numerator = parseFloat(numerator);
|
|
120
|
+
denominator = parseFloat(denominator);
|
|
121
|
+
if (!Number.isInteger(numerator) || !Number.isInteger(denominator)) {
|
|
122
|
+
return false;
|
|
123
|
+
}
|
|
124
|
+
if (numerator < 0 || denominator < 1) {
|
|
125
|
+
return false;
|
|
126
|
+
}
|
|
127
|
+
return numerator + '/' + denominator;
|
|
128
|
+
});
|
|
129
|
+
(0, _defineProperty2["default"])(_this, "isPositiveInteger", function (n) {
|
|
130
|
+
return n >>> 0 === parseFloat(n);
|
|
131
|
+
});
|
|
132
|
+
(0, _defineProperty2["default"])(_this, "onBlur", function (event) {
|
|
133
|
+
var _this$props = _this.props,
|
|
134
|
+
customValues = _this$props.customValues,
|
|
135
|
+
onlyIntegersAllowed = _this$props.onlyIntegersAllowed,
|
|
136
|
+
type = _this$props.type;
|
|
137
|
+
var value = event.target.value;
|
|
138
|
+
if (type === 'text') {
|
|
139
|
+
var tempValue = _this.getValidFraction(value);
|
|
140
|
+
if (tempValue) {
|
|
141
|
+
value = tempValue;
|
|
142
|
+
} else {
|
|
143
|
+
value = _this.props.value;
|
|
144
|
+
}
|
|
145
|
+
}
|
|
146
|
+
var rawNumber = onlyIntegersAllowed ? Math.round(parseFloat(value)) : parseFloat(value);
|
|
147
|
+
if (type === 'text') {
|
|
148
|
+
rawNumber = value.trim();
|
|
149
|
+
}
|
|
150
|
+
var _this$normalizeValueA = _this.normalizeValueAndIndex(customValues, rawNumber),
|
|
151
|
+
number = _this$normalizeValueA.value,
|
|
152
|
+
currentIndex = _this$normalizeValueA.currentIndex;
|
|
153
|
+
_this.setState({
|
|
154
|
+
value: number.toString(),
|
|
155
|
+
currentIndex: currentIndex
|
|
156
|
+
}, function () {
|
|
157
|
+
return _this.props.onChange(event, number);
|
|
158
|
+
});
|
|
159
|
+
});
|
|
160
|
+
var _this$normalizeValueA2 = _this.normalizeValueAndIndex(props.customValues, props.value),
|
|
161
|
+
_value = _this$normalizeValueA2.value,
|
|
162
|
+
_currentIndex = _this$normalizeValueA2.currentIndex;
|
|
163
|
+
_this.state = {
|
|
164
|
+
value: _value,
|
|
165
|
+
currentIndex: _currentIndex
|
|
166
|
+
};
|
|
167
|
+
if (_value !== props.value) {
|
|
168
|
+
_this.props.onChange({}, _value);
|
|
169
|
+
}
|
|
170
|
+
_this.onChange = _this.onChange.bind(_this);
|
|
171
|
+
return _this;
|
|
172
|
+
}
|
|
173
|
+
(0, _inherits2["default"])(NumberTextFieldCustom, _React$Component);
|
|
174
|
+
return (0, _createClass2["default"])(NumberTextFieldCustom, [{
|
|
175
|
+
key: "UNSAFE_componentWillReceiveProps",
|
|
176
|
+
value: function UNSAFE_componentWillReceiveProps(props) {
|
|
177
|
+
var _this$normalizeValueA3 = this.normalizeValueAndIndex(props.customValues, props.value, props.min, props.max),
|
|
178
|
+
value = _this$normalizeValueA3.value,
|
|
179
|
+
currentIndex = _this$normalizeValueA3.currentIndex;
|
|
180
|
+
this.setState({
|
|
181
|
+
value: value,
|
|
182
|
+
currentIndex: currentIndex
|
|
183
|
+
});
|
|
184
|
+
}
|
|
185
|
+
}, {
|
|
186
|
+
key: "clamp",
|
|
187
|
+
value: function clamp(value) {
|
|
188
|
+
var min = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : this.props.min;
|
|
189
|
+
var max = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : this.props.max;
|
|
190
|
+
var customValues = this.props.customValues;
|
|
191
|
+
if ((customValues || []).length > 0) {
|
|
192
|
+
return value;
|
|
193
|
+
}
|
|
194
|
+
if (!(0, _lodashEs.isFinite)(value)) {
|
|
195
|
+
return fallbackNumber(min, max);
|
|
196
|
+
}
|
|
197
|
+
if ((0, _lodashEs.isFinite)(max)) {
|
|
198
|
+
value = Math.min(value, max);
|
|
199
|
+
}
|
|
200
|
+
if ((0, _lodashEs.isFinite)(min)) {
|
|
201
|
+
value = Math.max(value, min);
|
|
202
|
+
}
|
|
203
|
+
return value;
|
|
204
|
+
}
|
|
205
|
+
}, {
|
|
206
|
+
key: "onChange",
|
|
207
|
+
value: function onChange(event) {
|
|
208
|
+
var type = this.props.type;
|
|
209
|
+
var value = event.target.value;
|
|
210
|
+
if (type !== 'text' && typeof value === 'string' && value.trim() === '') {
|
|
211
|
+
return;
|
|
212
|
+
}
|
|
213
|
+
this.setState({
|
|
214
|
+
value: value
|
|
215
|
+
});
|
|
216
|
+
}
|
|
217
|
+
}, {
|
|
218
|
+
key: "changeValue",
|
|
219
|
+
value: function changeValue(event) {
|
|
220
|
+
var sign = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1;
|
|
221
|
+
var shouldUpdate = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;
|
|
222
|
+
event.preventDefault();
|
|
223
|
+
var _this$props2 = this.props,
|
|
224
|
+
customValues = _this$props2.customValues,
|
|
225
|
+
step = _this$props2.step,
|
|
226
|
+
onlyIntegersAllowed = _this$props2.onlyIntegersAllowed,
|
|
227
|
+
onChange = _this$props2.onChange;
|
|
228
|
+
var _this$state = this.state,
|
|
229
|
+
currentIndex = _this$state.currentIndex,
|
|
230
|
+
value = _this$state.value;
|
|
231
|
+
var updatedIndex = currentIndex + sign * 1;
|
|
232
|
+
var number;
|
|
233
|
+
if (customValues.length > 0) {
|
|
234
|
+
if (updatedIndex < 0 || updatedIndex >= customValues.length) {
|
|
235
|
+
return;
|
|
236
|
+
}
|
|
237
|
+
number = customValues[updatedIndex];
|
|
238
|
+
} else {
|
|
239
|
+
var rawNumber = onlyIntegersAllowed ? parseInt(value) : parseFloat(value);
|
|
240
|
+
var updatedValue = (rawNumber * 10000 + step * sign * 10000) / 10000;
|
|
241
|
+
number = this.clamp(updatedValue);
|
|
242
|
+
}
|
|
243
|
+
this.setState({
|
|
244
|
+
value: number.toString(),
|
|
245
|
+
currentIndex: updatedIndex
|
|
246
|
+
}, function () {
|
|
247
|
+
if (shouldUpdate) {
|
|
248
|
+
onChange(event, number);
|
|
249
|
+
}
|
|
250
|
+
});
|
|
251
|
+
}
|
|
252
|
+
}, {
|
|
253
|
+
key: "render",
|
|
254
|
+
value: function render() {
|
|
255
|
+
var _this2 = this;
|
|
256
|
+
var _this$props3 = this.props,
|
|
257
|
+
className = _this$props3.className,
|
|
258
|
+
label = _this$props3.label,
|
|
259
|
+
disabled = _this$props3.disabled,
|
|
260
|
+
error = _this$props3.error,
|
|
261
|
+
min = _this$props3.min,
|
|
262
|
+
max = _this$props3.max,
|
|
263
|
+
customValues = _this$props3.customValues,
|
|
264
|
+
inputClassName = _this$props3.inputClassName,
|
|
265
|
+
disableUnderline = _this$props3.disableUnderline,
|
|
266
|
+
helperText = _this$props3.helperText,
|
|
267
|
+
variant = _this$props3.variant,
|
|
268
|
+
textAlign = _this$props3.textAlign,
|
|
269
|
+
_this$props3$type = _this$props3.type,
|
|
270
|
+
type = _this$props3$type === void 0 ? 'number' : _this$props3$type;
|
|
271
|
+
var value = this.state.value;
|
|
272
|
+
var names = className;
|
|
273
|
+
//Logic to disable the increment and decrement buttons
|
|
274
|
+
var disabledStart = false;
|
|
275
|
+
var disabledEnd = false;
|
|
276
|
+
if (customValues.length > 0) {
|
|
277
|
+
disabledStart = value === customValues[0];
|
|
278
|
+
disabledEnd = value === customValues[customValues.length - 1];
|
|
279
|
+
} else if ((0, _lodashEs.isFinite)(min) && (0, _lodashEs.isFinite)(max)) {
|
|
280
|
+
disabledStart = value === min;
|
|
281
|
+
disabledEnd = value === max;
|
|
282
|
+
}
|
|
283
|
+
return /*#__PURE__*/_react["default"].createElement(StyledTextField, {
|
|
284
|
+
variant: variant,
|
|
285
|
+
inputRef: function inputRef(ref) {
|
|
286
|
+
return _this2.inputRef = ref;
|
|
287
|
+
},
|
|
288
|
+
disabled: disabled,
|
|
289
|
+
label: label,
|
|
290
|
+
value: value,
|
|
291
|
+
error: error,
|
|
292
|
+
helperText: helperText,
|
|
293
|
+
onChange: this.onChange,
|
|
294
|
+
onBlur: this.onBlur,
|
|
295
|
+
onKeyPress: function onKeyPress(e) {
|
|
296
|
+
// once the Enter key is pressed, we force input blur
|
|
297
|
+
if (e.key === 'Enter' && _this2.inputRef) {
|
|
298
|
+
_this2.inputRef.blur();
|
|
299
|
+
}
|
|
300
|
+
},
|
|
301
|
+
onKeyDown: function onKeyDown(e) {
|
|
302
|
+
if (e.key === 'ArrowUp') {
|
|
303
|
+
_this2.changeValue(e);
|
|
304
|
+
}
|
|
305
|
+
if (e.key === 'ArrowDown') {
|
|
306
|
+
_this2.changeValue(e, -1);
|
|
307
|
+
}
|
|
308
|
+
},
|
|
309
|
+
title: '',
|
|
310
|
+
type: type,
|
|
311
|
+
className: names,
|
|
312
|
+
InputProps: {
|
|
313
|
+
className: inputClassName,
|
|
314
|
+
disableUnderline: disableUnderline,
|
|
315
|
+
startAdornment: /*#__PURE__*/_react["default"].createElement(_InputAdornment["default"], {
|
|
316
|
+
position: "start"
|
|
317
|
+
}, /*#__PURE__*/_react["default"].createElement(StyledIconButton, {
|
|
318
|
+
disabled: disabled ? disabled : disabledStart,
|
|
319
|
+
onClick: function onClick(e) {
|
|
320
|
+
return _this2.changeValue(e, -1, true);
|
|
321
|
+
},
|
|
322
|
+
size: "large"
|
|
323
|
+
}, /*#__PURE__*/_react["default"].createElement(_Remove["default"], {
|
|
324
|
+
fontSize: "small"
|
|
325
|
+
}))),
|
|
326
|
+
endAdornment: /*#__PURE__*/_react["default"].createElement(_InputAdornment["default"], {
|
|
327
|
+
position: "end"
|
|
328
|
+
}, /*#__PURE__*/_react["default"].createElement(StyledIconButton, {
|
|
329
|
+
disabled: disabled ? disabled : disabledEnd,
|
|
330
|
+
onClick: function onClick(e) {
|
|
331
|
+
return _this2.changeValue(e, 1, true);
|
|
332
|
+
},
|
|
333
|
+
size: "large"
|
|
334
|
+
}, /*#__PURE__*/_react["default"].createElement(_Add["default"], {
|
|
335
|
+
fontSize: "small"
|
|
336
|
+
})))
|
|
337
|
+
},
|
|
338
|
+
inputProps: {
|
|
339
|
+
style: {
|
|
340
|
+
textAlign: textAlign
|
|
341
|
+
},
|
|
342
|
+
min: min,
|
|
343
|
+
max: max
|
|
344
|
+
}
|
|
345
|
+
});
|
|
346
|
+
}
|
|
347
|
+
}]);
|
|
348
|
+
}(_react["default"].Component);
|
|
349
|
+
(0, _defineProperty2["default"])(NumberTextFieldCustom, "propTypes", {
|
|
350
|
+
className: _propTypes["default"].string,
|
|
351
|
+
customValues: _propTypes["default"].array,
|
|
352
|
+
disabled: _propTypes["default"].bool,
|
|
353
|
+
error: _propTypes["default"].bool,
|
|
354
|
+
inputClassName: _propTypes["default"].string,
|
|
355
|
+
helperText: _propTypes["default"].string,
|
|
356
|
+
onChange: _propTypes["default"].func.isRequired,
|
|
357
|
+
onlyIntegersAllowed: _propTypes["default"].bool,
|
|
358
|
+
value: _propTypes["default"].any,
|
|
359
|
+
min: _propTypes["default"].number,
|
|
360
|
+
max: _propTypes["default"].number,
|
|
361
|
+
step: _propTypes["default"].number,
|
|
362
|
+
label: _propTypes["default"].string,
|
|
363
|
+
disableUnderline: _propTypes["default"].bool,
|
|
364
|
+
textAlign: _propTypes["default"].string,
|
|
365
|
+
variant: _propTypes["default"].string,
|
|
366
|
+
type: _propTypes["default"].string
|
|
367
|
+
});
|
|
368
|
+
(0, _defineProperty2["default"])(NumberTextFieldCustom, "defaultProps", {
|
|
369
|
+
step: 1,
|
|
370
|
+
customValues: [],
|
|
371
|
+
textAlign: 'center',
|
|
372
|
+
variant: 'standard',
|
|
373
|
+
onlyIntegersAllowed: false
|
|
374
|
+
});
|
|
375
|
+
var _default = exports["default"] = NumberTextFieldCustom;
|
|
376
|
+
//# sourceMappingURL=number-text-field-custom.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"number-text-field-custom.js","names":["_propTypes","_interopRequireDefault","require","_react","_TextField","_styles","_lodashEs","_IconButton","_InputAdornment","_Remove","_Add","math","_interopRequireWildcard","e","t","WeakMap","r","n","__esModule","o","i","f","__proto__","_typeof","has","get","set","_t","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","_callSuper","_getPrototypeOf2","_possibleConstructorReturn2","_isNativeReflectConstruct","Reflect","construct","constructor","apply","Boolean","prototype","valueOf","StyledTextField","styled","TextField","MozAppearance","WebkitAppearance","margin","StyledIconButton","IconButton","padding","fallbackNumber","min","max","isFinite","NumberTextFieldCustom","exports","_React$Component","props","_this","_classCallCheck2","_defineProperty2","customValues","number","type","value","clamp","currentIndex","findIndex","val","length","closestValue","getClosestFractionValue","getClosestValue","index","reduce","closest","Math","abs","fraction","isPositiveInteger","trim","split","_value$trim$split","_value$trim$split2","_slicedToArray2","numerator","denominator","isNaN","parseFloat","Number","isInteger","event","_this$props","onlyIntegersAllowed","target","tempValue","getValidFraction","rawNumber","round","_this$normalizeValueA","normalizeValueAndIndex","setState","toString","onChange","_this$normalizeValueA2","state","bind","_inherits2","_createClass2","key","UNSAFE_componentWillReceiveProps","_this$normalizeValueA3","arguments","undefined","changeValue","sign","shouldUpdate","preventDefault","_this$props2","step","_this$state","updatedIndex","parseInt","updatedValue","render","_this2","_this$props3","className","label","disabled","error","inputClassName","disableUnderline","helperText","variant","textAlign","_this$props3$type","names","disabledStart","disabledEnd","createElement","inputRef","ref","onBlur","onKeyPress","blur","onKeyDown","title","InputProps","startAdornment","position","onClick","size","fontSize","endAdornment","inputProps","style","React","Component","PropTypes","string","array","bool","func","isRequired","any","_default"],"sources":["../src/number-text-field-custom.jsx"],"sourcesContent":["import PropTypes from 'prop-types';\nimport React from 'react';\nimport TextField from '@mui/material/TextField';\nimport { styled } from '@mui/material/styles';\nimport { isFinite } from 'lodash-es';\nimport IconButton from '@mui/material/IconButton';\nimport InputAdornment from '@mui/material/InputAdornment';\nimport Remove from '@mui/icons-material/Remove';\nimport Add from '@mui/icons-material/Add';\nimport * as math from 'mathjs';\n\nconst StyledTextField = styled(TextField)(() => ({\n '& input[type=number]': {\n MozAppearance: 'textfield',\n },\n '& input[type=number]::-webkit-outer-spin-button': {\n WebkitAppearance: 'none',\n margin: 0,\n },\n '& input[type=number]::-webkit-inner-spin-button': {\n WebkitAppearance: 'none',\n margin: 0,\n },\n}));\n\nconst StyledIconButton = styled(IconButton)(() => ({\n padding: '2px',\n}));\n\nconst fallbackNumber = (min, max) => {\n if (!isFinite(min) && !isFinite(max)) {\n return 0;\n }\n\n if (!isFinite(min) && isFinite(max)) {\n return max;\n }\n\n if (isFinite(min)) {\n return min;\n }\n};\n\nexport class NumberTextFieldCustom extends React.Component {\n static propTypes = {\n className: PropTypes.string,\n customValues: PropTypes.array,\n disabled: PropTypes.bool,\n error: PropTypes.bool,\n inputClassName: PropTypes.string,\n helperText: PropTypes.string,\n onChange: PropTypes.func.isRequired,\n onlyIntegersAllowed: PropTypes.bool,\n value: PropTypes.any,\n min: PropTypes.number,\n max: PropTypes.number,\n step: PropTypes.number,\n label: PropTypes.string,\n disableUnderline: PropTypes.bool,\n textAlign: PropTypes.string,\n variant: PropTypes.string,\n type: PropTypes.string,\n };\n\n static defaultProps = {\n step: 1,\n customValues: [],\n textAlign: 'center',\n variant: 'standard',\n onlyIntegersAllowed: false,\n };\n\n constructor(props) {\n super(props);\n\n const { value, currentIndex } = this.normalizeValueAndIndex(props.customValues, props.value);\n\n this.state = {\n value,\n currentIndex,\n };\n\n if (value !== props.value) {\n this.props.onChange({}, value);\n }\n\n this.onChange = this.onChange.bind(this);\n }\n\n UNSAFE_componentWillReceiveProps(props) {\n const { value, currentIndex } = this.normalizeValueAndIndex(props.customValues, props.value, props.min, props.max);\n\n this.setState({ value, currentIndex });\n }\n\n clamp(value, min = this.props.min, max = this.props.max) {\n const { customValues } = this.props;\n\n if ((customValues || []).length > 0) {\n return value;\n }\n\n if (!isFinite(value)) {\n return fallbackNumber(min, max);\n }\n\n if (isFinite(max)) {\n value = Math.min(value, max);\n }\n\n if (isFinite(min)) {\n value = Math.max(value, min);\n }\n\n return value;\n }\n\n normalizeValueAndIndex = (customValues, number, min, max) => {\n const { type } = this.props;\n const value = this.clamp(number, min, max);\n const currentIndex = (customValues || []).findIndex((val) => val === value);\n\n if ((customValues || []).length > 0 && currentIndex === -1) {\n const closestValue =\n type === 'text' ? this.getClosestFractionValue(customValues, value) : this.getClosestValue(customValues, value);\n\n return { value: closestValue.value, currentIndex: closestValue.index };\n }\n\n return { value, currentIndex };\n };\n\n getClosestValue = (customValues, number) =>\n customValues.reduce(\n (closest, value, index) =>\n Math.abs(value - number) < Math.abs(closest.value - number) ? { value, index } : closest,\n { value: customValues[0], index: 0 },\n );\n\n getClosestFractionValue = (customValues, number) =>\n customValues.reduce(\n (closest, value, index) =>\n Math.abs(math.number(math.fraction(value)) - math.number(math.fraction(number))) <\n Math.abs(math.number(math.fraction(closest.value)) - math.number(math.fraction(number)))\n ? { value, index }\n : closest,\n { value: customValues[0], index: 0 },\n );\n\n getValidFraction = (value) => {\n if (this.isPositiveInteger(value.trim())) {\n return value.trim();\n }\n if (value.trim() === '' || value.trim().split('/').length !== 2) {\n return false;\n }\n let [numerator, denominator] = value.trim().split('/');\n if (isNaN(numerator) || isNaN(denominator)) {\n return false;\n }\n numerator = parseFloat(numerator);\n denominator = parseFloat(denominator);\n if (!Number.isInteger(numerator) || !Number.isInteger(denominator)) {\n return false;\n }\n if (numerator < 0 || denominator < 1) {\n return false;\n }\n return numerator + '/' + denominator;\n };\n\n isPositiveInteger = (n) => {\n return n >>> 0 === parseFloat(n);\n };\n\n onBlur = (event) => {\n const { customValues, onlyIntegersAllowed, type } = this.props;\n let { value } = event.target;\n if (type === 'text') {\n let tempValue = this.getValidFraction(value);\n if (tempValue) {\n value = tempValue;\n } else {\n value = this.props.value;\n }\n }\n let rawNumber = onlyIntegersAllowed ? Math.round(parseFloat(value)) : parseFloat(value);\n if (type === 'text') {\n rawNumber = value.trim();\n }\n const { value: number, currentIndex } = this.normalizeValueAndIndex(customValues, rawNumber);\n this.setState(\n {\n value: number.toString(),\n currentIndex,\n },\n () => this.props.onChange(event, number),\n );\n };\n\n onChange(event) {\n const { type } = this.props;\n const { value } = event.target;\n if (type !== 'text' && typeof value === 'string' && value.trim() === '') {\n return;\n }\n this.setState({ value });\n }\n\n changeValue(event, sign = 1, shouldUpdate = false) {\n event.preventDefault();\n const { customValues, step, onlyIntegersAllowed, onChange } = this.props;\n const { currentIndex, value } = this.state;\n const updatedIndex = currentIndex + sign * 1;\n let number;\n if (customValues.length > 0) {\n if (updatedIndex < 0 || updatedIndex >= customValues.length) {\n return;\n }\n number = customValues[updatedIndex];\n } else {\n const rawNumber = onlyIntegersAllowed ? parseInt(value) : parseFloat(value);\n const updatedValue = (rawNumber * 10000 + step * sign * 10000) / 10000;\n number = this.clamp(updatedValue);\n }\n this.setState(\n {\n value: number.toString(),\n currentIndex: updatedIndex,\n },\n () => {\n if (shouldUpdate) {\n onChange(event, number);\n }\n },\n );\n }\n\n render() {\n const {\n className,\n label,\n disabled,\n error,\n min,\n max,\n customValues,\n inputClassName,\n disableUnderline,\n helperText,\n variant,\n textAlign,\n type = 'number',\n } = this.props;\n const { value } = this.state;\n const names = className;\n //Logic to disable the increment and decrement buttons\n let disabledStart = false;\n let disabledEnd = false;\n if (customValues.length > 0) {\n disabledStart = value === customValues[0];\n disabledEnd = value === customValues[customValues.length - 1];\n } else if (isFinite(min) && isFinite(max)) {\n disabledStart = value === min;\n disabledEnd = value === max;\n }\n\n return (\n <StyledTextField\n variant={variant}\n inputRef={(ref) => (this.inputRef = ref)}\n disabled={disabled}\n label={label}\n value={value}\n error={error}\n helperText={helperText}\n onChange={this.onChange}\n onBlur={this.onBlur}\n onKeyPress={(e) => {\n // once the Enter key is pressed, we force input blur\n if (e.key === 'Enter' && this.inputRef) {\n this.inputRef.blur();\n }\n }}\n onKeyDown={(e) => {\n if (e.key === 'ArrowUp') {\n this.changeValue(e);\n }\n\n if (e.key === 'ArrowDown') {\n this.changeValue(e, -1);\n }\n }}\n title={''}\n type={type}\n className={names}\n InputProps={{\n className: inputClassName,\n disableUnderline: disableUnderline,\n startAdornment: (\n <InputAdornment position=\"start\">\n <StyledIconButton\n disabled={disabled ? disabled : disabledStart}\n onClick={(e) => this.changeValue(e, -1, true)}\n size=\"large\"\n >\n <Remove fontSize=\"small\" />\n </StyledIconButton>\n </InputAdornment>\n ),\n endAdornment: (\n <InputAdornment position=\"end\">\n <StyledIconButton\n disabled={disabled ? disabled : disabledEnd}\n onClick={(e) => this.changeValue(e, 1, true)}\n size=\"large\"\n >\n <Add fontSize=\"small\" />\n </StyledIconButton>\n </InputAdornment>\n ),\n }}\n inputProps={{\n style: { textAlign },\n min,\n max,\n }}\n />\n );\n }\n}\n\nexport default NumberTextFieldCustom;\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,229 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports["default"] = exports.NumberTextField = void 0;
|
|
8
|
+
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
|
|
9
|
+
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
|
|
10
|
+
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
|
|
11
|
+
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
|
|
12
|
+
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
|
|
13
|
+
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
14
|
+
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
15
|
+
var _react = _interopRequireDefault(require("react"));
|
|
16
|
+
var _TextField = _interopRequireDefault(require("@mui/material/TextField"));
|
|
17
|
+
var _styles = require("@mui/material/styles");
|
|
18
|
+
var _debug = _interopRequireDefault(require("debug"));
|
|
19
|
+
var _lodashEs = require("lodash-es");
|
|
20
|
+
var _InputAdornment = _interopRequireDefault(require("@mui/material/InputAdornment"));
|
|
21
|
+
function _callSuper(t, o, e) { return o = (0, _getPrototypeOf2["default"])(o), (0, _possibleConstructorReturn2["default"])(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], (0, _getPrototypeOf2["default"])(t).constructor) : o.apply(t, e)); }
|
|
22
|
+
function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); }
|
|
23
|
+
var log = (0, _debug["default"])('@pie-lib:config-ui:number-text-field');
|
|
24
|
+
var StyledTextField = (0, _styles.styled)(_TextField["default"])(function (_ref) {
|
|
25
|
+
var theme = _ref.theme;
|
|
26
|
+
return {
|
|
27
|
+
marginRight: theme.spacing(1),
|
|
28
|
+
'& .MuiInputLabel-root': {
|
|
29
|
+
width: 'auto',
|
|
30
|
+
minWidth: 'max-content',
|
|
31
|
+
maxWidth: 'none',
|
|
32
|
+
whiteSpace: 'nowrap',
|
|
33
|
+
overflow: 'visible',
|
|
34
|
+
transform: 'translate(0, 8px) scale(0.75)',
|
|
35
|
+
transformOrigin: 'top left',
|
|
36
|
+
position: 'relative'
|
|
37
|
+
},
|
|
38
|
+
'& .MuiInputBase-root, & .MuiInput-root, & .MuiFilledInput-root, & .MuiOutlinedInput-root': {
|
|
39
|
+
height: 'auto',
|
|
40
|
+
minHeight: 'auto',
|
|
41
|
+
marginTop: 0
|
|
42
|
+
},
|
|
43
|
+
'& .MuiInputBase-input': {
|
|
44
|
+
height: 'auto',
|
|
45
|
+
minHeight: 'auto',
|
|
46
|
+
padding: '6px 0 7px'
|
|
47
|
+
}
|
|
48
|
+
};
|
|
49
|
+
});
|
|
50
|
+
var fallbackNumber = function fallbackNumber(min, max) {
|
|
51
|
+
if (!(0, _lodashEs.isFinite)(min) && !(0, _lodashEs.isFinite)(max)) {
|
|
52
|
+
return 0;
|
|
53
|
+
}
|
|
54
|
+
if (!(0, _lodashEs.isFinite)(min) && (0, _lodashEs.isFinite)(max)) {
|
|
55
|
+
return max;
|
|
56
|
+
}
|
|
57
|
+
if ((0, _lodashEs.isFinite)(min)) {
|
|
58
|
+
return min;
|
|
59
|
+
}
|
|
60
|
+
};
|
|
61
|
+
var NumberTextField = exports.NumberTextField = /*#__PURE__*/function (_React$Component) {
|
|
62
|
+
function NumberTextField(props) {
|
|
63
|
+
var _this;
|
|
64
|
+
(0, _classCallCheck2["default"])(this, NumberTextField);
|
|
65
|
+
_this = _callSuper(this, NumberTextField, [props]);
|
|
66
|
+
/**
|
|
67
|
+
* on Blur (this can be triggered by pressing Enter, see below)
|
|
68
|
+
* we check the entered value and reset it if needed
|
|
69
|
+
*/
|
|
70
|
+
(0, _defineProperty2["default"])(_this, "onBlur", function (event) {
|
|
71
|
+
var value = event.target.value;
|
|
72
|
+
var rawNumber = parseFloat(value);
|
|
73
|
+
log('rawNumber: ', rawNumber);
|
|
74
|
+
var number = _this.clamp(rawNumber);
|
|
75
|
+
log('number: ', number);
|
|
76
|
+
if (number !== _this.state.value) {
|
|
77
|
+
log('trigger update...');
|
|
78
|
+
_this.setState({
|
|
79
|
+
value: number.toString()
|
|
80
|
+
}, function () {
|
|
81
|
+
_this.props.onChange(event, number);
|
|
82
|
+
});
|
|
83
|
+
}
|
|
84
|
+
});
|
|
85
|
+
(0, _defineProperty2["default"])(_this, "errorMessage", function () {
|
|
86
|
+
var _this$props = _this.props,
|
|
87
|
+
min = _this$props.min,
|
|
88
|
+
max = _this$props.max;
|
|
89
|
+
if (min && max) {
|
|
90
|
+
return "The value must be between ".concat(min, " and ").concat(max);
|
|
91
|
+
}
|
|
92
|
+
if (min) {
|
|
93
|
+
return "The value must be greater than ".concat(min);
|
|
94
|
+
}
|
|
95
|
+
if (max) {
|
|
96
|
+
return "The value must be less than ".concat(max);
|
|
97
|
+
}
|
|
98
|
+
});
|
|
99
|
+
/**
|
|
100
|
+
* if the input has to show error when outside range,
|
|
101
|
+
* and the entered value is not matching the requirements
|
|
102
|
+
* we display error message
|
|
103
|
+
*/
|
|
104
|
+
(0, _defineProperty2["default"])(_this, "getError", function () {
|
|
105
|
+
var value = _this.state.value;
|
|
106
|
+
var _float = parseFloat(value);
|
|
107
|
+
var clamped = _this.clamp(_float);
|
|
108
|
+
if (clamped !== _float) {
|
|
109
|
+
return _this.errorMessage();
|
|
110
|
+
}
|
|
111
|
+
});
|
|
112
|
+
var _value = _this.clamp(props.value);
|
|
113
|
+
_this.state = {
|
|
114
|
+
value: _value
|
|
115
|
+
};
|
|
116
|
+
if (_value !== props.value) {
|
|
117
|
+
_this.props.onChange({}, _value);
|
|
118
|
+
}
|
|
119
|
+
_this.onChange = _this.onChange.bind(_this);
|
|
120
|
+
return _this;
|
|
121
|
+
}
|
|
122
|
+
(0, _inherits2["default"])(NumberTextField, _React$Component);
|
|
123
|
+
return (0, _createClass2["default"])(NumberTextField, [{
|
|
124
|
+
key: "UNSAFE_componentWillReceiveProps",
|
|
125
|
+
value: function UNSAFE_componentWillReceiveProps(props) {
|
|
126
|
+
var value = this.clamp(props.value, props.min, props.max);
|
|
127
|
+
this.setState({
|
|
128
|
+
value: value
|
|
129
|
+
});
|
|
130
|
+
}
|
|
131
|
+
}, {
|
|
132
|
+
key: "clamp",
|
|
133
|
+
value: function clamp(value) {
|
|
134
|
+
var min = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : this.props.min;
|
|
135
|
+
var max = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : this.props.max;
|
|
136
|
+
if (!(0, _lodashEs.isFinite)(value)) {
|
|
137
|
+
return fallbackNumber(min, max);
|
|
138
|
+
}
|
|
139
|
+
if ((0, _lodashEs.isFinite)(max)) {
|
|
140
|
+
value = Math.min(value, max);
|
|
141
|
+
}
|
|
142
|
+
if ((0, _lodashEs.isFinite)(min)) {
|
|
143
|
+
value = Math.max(value, min);
|
|
144
|
+
}
|
|
145
|
+
return value;
|
|
146
|
+
}
|
|
147
|
+
}, {
|
|
148
|
+
key: "onChange",
|
|
149
|
+
value: function onChange(event) {
|
|
150
|
+
var value = event.target.value;
|
|
151
|
+
this.setState({
|
|
152
|
+
value: value
|
|
153
|
+
});
|
|
154
|
+
}
|
|
155
|
+
}, {
|
|
156
|
+
key: "render",
|
|
157
|
+
value: function render() {
|
|
158
|
+
var _this2 = this;
|
|
159
|
+
var _this$props2 = this.props,
|
|
160
|
+
className = _this$props2.className,
|
|
161
|
+
label = _this$props2.label,
|
|
162
|
+
disabled = _this$props2.disabled,
|
|
163
|
+
suffix = _this$props2.suffix,
|
|
164
|
+
min = _this$props2.min,
|
|
165
|
+
max = _this$props2.max,
|
|
166
|
+
inputClassName = _this$props2.inputClassName,
|
|
167
|
+
disableUnderline = _this$props2.disableUnderline,
|
|
168
|
+
showErrorWhenOutsideRange = _this$props2.showErrorWhenOutsideRange,
|
|
169
|
+
variant = _this$props2.variant;
|
|
170
|
+
var error = showErrorWhenOutsideRange && this.getError();
|
|
171
|
+
return /*#__PURE__*/_react["default"].createElement(StyledTextField, {
|
|
172
|
+
variant: disableUnderline ? 'filled' : variant || 'standard',
|
|
173
|
+
inputRef: function inputRef(ref) {
|
|
174
|
+
_this2.inputRef = ref;
|
|
175
|
+
},
|
|
176
|
+
disabled: disabled,
|
|
177
|
+
label: label,
|
|
178
|
+
InputLabelProps: {
|
|
179
|
+
shrink: true
|
|
180
|
+
},
|
|
181
|
+
value: this.state.value,
|
|
182
|
+
error: !!error,
|
|
183
|
+
helperText: error,
|
|
184
|
+
onChange: this.onChange,
|
|
185
|
+
onBlur: this.onBlur,
|
|
186
|
+
onKeyDown: function onKeyDown(e) {
|
|
187
|
+
// once the Enter key is pressed, we force input blur
|
|
188
|
+
if (e.key === 'Enter' && _this2.inputRef) {
|
|
189
|
+
_this2.inputRef.blur();
|
|
190
|
+
}
|
|
191
|
+
},
|
|
192
|
+
type: "number",
|
|
193
|
+
className: className,
|
|
194
|
+
slotProps: {
|
|
195
|
+
input: {
|
|
196
|
+
endAdornment: suffix && /*#__PURE__*/_react["default"].createElement(_InputAdornment["default"], {
|
|
197
|
+
position: "end"
|
|
198
|
+
}, suffix),
|
|
199
|
+
className: inputClassName,
|
|
200
|
+
inputProps: {
|
|
201
|
+
min: min,
|
|
202
|
+
max: max
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
},
|
|
206
|
+
margin: "normal"
|
|
207
|
+
});
|
|
208
|
+
}
|
|
209
|
+
}]);
|
|
210
|
+
}(_react["default"].Component);
|
|
211
|
+
(0, _defineProperty2["default"])(NumberTextField, "propTypes", {
|
|
212
|
+
disabled: _propTypes["default"].bool,
|
|
213
|
+
className: _propTypes["default"].string,
|
|
214
|
+
inputClassName: _propTypes["default"].string,
|
|
215
|
+
onChange: _propTypes["default"].func.isRequired,
|
|
216
|
+
value: _propTypes["default"].number,
|
|
217
|
+
min: _propTypes["default"].number,
|
|
218
|
+
max: _propTypes["default"].number,
|
|
219
|
+
label: _propTypes["default"].string,
|
|
220
|
+
suffix: _propTypes["default"].string,
|
|
221
|
+
showErrorWhenOutsideRange: _propTypes["default"].bool,
|
|
222
|
+
disableUnderline: _propTypes["default"].bool,
|
|
223
|
+
variant: _propTypes["default"].string
|
|
224
|
+
});
|
|
225
|
+
(0, _defineProperty2["default"])(NumberTextField, "defaultProps", {
|
|
226
|
+
showErrorWhenOutsideRange: false
|
|
227
|
+
});
|
|
228
|
+
var _default = exports["default"] = NumberTextField;
|
|
229
|
+
//# sourceMappingURL=number-text-field.js.map
|