@pie-lib/config-ui 13.0.4-next.29 → 13.0.4-next.30
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/dist/_virtual/_rolldown/runtime.js +11 -0
- package/dist/alert-dialog.d.ts +44 -0
- package/dist/alert-dialog.js +47 -0
- package/dist/checkbox.d.ts +34 -0
- package/dist/checkbox.js +57 -0
- package/dist/choice-configuration/feedback-menu.d.ts +32 -0
- package/dist/choice-configuration/feedback-menu.js +85 -0
- package/dist/choice-configuration/index.d.ts +62 -0
- package/dist/choice-configuration/index.js +240 -0
- package/dist/choice-utils.d.ts +21 -0
- package/dist/choice-utils.js +15 -0
- package/dist/feedback-config/feedback-selector.d.ts +33 -0
- package/dist/feedback-config/feedback-selector.js +92 -0
- package/dist/feedback-config/group.d.ts +21 -0
- package/dist/feedback-config/group.js +33 -0
- package/dist/feedback-config/index.d.ts +48 -0
- package/dist/feedback-config/index.js +96 -0
- package/dist/form-section.d.ts +25 -0
- package/dist/form-section.js +25 -0
- package/dist/fraction-to-number.d.ts +7 -0
- package/dist/fraction-to-number.js +9 -0
- package/dist/help.d.ts +41 -0
- package/dist/help.js +61 -0
- package/dist/index.d.ts +31 -0
- package/dist/index.js +34 -0
- package/dist/input.d.ts +29 -0
- package/dist/input.js +65 -0
- package/dist/inputs.d.ts +63 -0
- package/dist/inputs.js +70 -0
- package/dist/langs.d.ts +41 -0
- package/dist/langs.js +76 -0
- package/dist/layout/config-layout.d.ts +10 -0
- package/dist/layout/config-layout.js +75 -0
- package/dist/layout/index.d.ts +11 -0
- package/dist/layout/index.js +10 -0
- package/dist/layout/layout-contents.d.ts +21 -0
- package/dist/layout/layout-contents.js +70 -0
- package/dist/layout/settings-box.d.ts +19 -0
- package/dist/layout/settings-box.js +31 -0
- package/dist/mui-box/index.d.ts +21 -0
- package/dist/mui-box/index.js +47 -0
- package/dist/node_modules/.bun/@babel_runtime@7.29.7/node_modules/@babel/runtime/helpers/esm/extends.js +12 -0
- package/dist/node_modules/.bun/@babel_runtime@7.29.7/node_modules/@babel/runtime/helpers/esm/inheritsLoose.js +7 -0
- package/dist/node_modules/.bun/@babel_runtime@7.29.7/node_modules/@babel/runtime/helpers/esm/objectWithoutPropertiesLoose.js +12 -0
- package/dist/node_modules/.bun/@babel_runtime@7.29.7/node_modules/@babel/runtime/helpers/esm/setPrototypeOf.js +8 -0
- package/dist/node_modules/.bun/react-measure@2.5.2_6dbf9a050bc9aadb/node_modules/react-measure/dist/index.esm.js +122 -0
- package/dist/node_modules/.bun/resize-observer-polyfill@1.5.1/node_modules/resize-observer-polyfill/dist/ResizeObserver.es.js +276 -0
- package/dist/number-text-field-custom.d.ts +51 -0
- package/dist/number-text-field-custom.js +192 -0
- package/dist/number-text-field.d.ts +47 -0
- package/dist/number-text-field.js +122 -0
- package/dist/radio-with-label.d.ts +25 -0
- package/dist/radio-with-label.js +27 -0
- package/dist/settings/display-size.d.ts +26 -0
- package/dist/settings/display-size.js +45 -0
- package/dist/settings/index.d.ts +45 -0
- package/dist/settings/index.js +63 -0
- package/dist/settings/panel.d.ts +27 -0
- package/dist/settings/panel.js +201 -0
- package/dist/settings/settings-radio-label.d.ts +25 -0
- package/dist/settings/settings-radio-label.js +29 -0
- package/dist/settings/toggle.d.ts +25 -0
- package/dist/settings/toggle.js +33 -0
- package/dist/tabs/index.d.ts +22 -0
- package/dist/tabs/index.js +39 -0
- package/dist/tags-input/index.d.ts +21 -0
- package/dist/tags-input/index.js +83 -0
- package/dist/two-choice.d.ts +43 -0
- package/dist/two-choice.js +79 -0
- package/dist/with-stateful-model.d.ts +42 -0
- package/dist/with-stateful-model.js +32 -0
- package/package.json +33 -19
- package/CHANGELOG.json +0 -32
- package/CHANGELOG.md +0 -2419
- package/LICENSE.md +0 -5
- package/lib/alert-dialog.js +0 -68
- package/lib/alert-dialog.js.map +0 -1
- package/lib/checkbox.js +0 -84
- package/lib/checkbox.js.map +0 -1
- package/lib/choice-configuration/feedback-menu.js +0 -129
- package/lib/choice-configuration/feedback-menu.js.map +0 -1
- package/lib/choice-configuration/index.js +0 -381
- package/lib/choice-configuration/index.js.map +0 -1
- package/lib/choice-utils.js +0 -42
- package/lib/choice-utils.js.map +0 -1
- package/lib/feedback-config/feedback-selector.js +0 -155
- package/lib/feedback-config/feedback-selector.js.map +0 -1
- package/lib/feedback-config/group.js +0 -61
- package/lib/feedback-config/group.js.map +0 -1
- package/lib/feedback-config/index.js +0 -146
- package/lib/feedback-config/index.js.map +0 -1
- package/lib/form-section.js +0 -44
- package/lib/form-section.js.map +0 -1
- package/lib/help.js +0 -106
- package/lib/help.js.map +0 -1
- package/lib/index.js +0 -186
- package/lib/index.js.map +0 -1
- package/lib/input.js +0 -106
- package/lib/input.js.map +0 -1
- package/lib/inputs.js +0 -105
- package/lib/inputs.js.map +0 -1
- package/lib/langs.js +0 -136
- package/lib/langs.js.map +0 -1
- package/lib/layout/config-layout.js +0 -137
- package/lib/layout/config-layout.js.map +0 -1
- package/lib/layout/index.js +0 -21
- package/lib/layout/index.js.map +0 -1
- package/lib/layout/layout-contents.js +0 -160
- package/lib/layout/layout-contents.js.map +0 -1
- package/lib/layout/settings-box.js +0 -57
- package/lib/layout/settings-box.js.map +0 -1
- package/lib/mui-box/index.js +0 -63
- package/lib/mui-box/index.js.map +0 -1
- package/lib/number-text-field-custom.js +0 -376
- package/lib/number-text-field-custom.js.map +0 -1
- package/lib/number-text-field.js +0 -229
- package/lib/number-text-field.js.map +0 -1
- package/lib/radio-with-label.js +0 -48
- package/lib/radio-with-label.js.map +0 -1
- package/lib/settings/display-size.js +0 -61
- package/lib/settings/display-size.js.map +0 -1
- package/lib/settings/index.js +0 -110
- package/lib/settings/index.js.map +0 -1
- package/lib/settings/panel.js +0 -392
- package/lib/settings/panel.js.map +0 -1
- package/lib/settings/settings-radio-label.js +0 -51
- package/lib/settings/settings-radio-label.js.map +0 -1
- package/lib/settings/toggle.js +0 -63
- package/lib/settings/toggle.js.map +0 -1
- package/lib/tabs/index.js +0 -75
- package/lib/tabs/index.js.map +0 -1
- package/lib/tags-input/index.js +0 -149
- package/lib/tags-input/index.js.map +0 -1
- package/lib/two-choice.js +0 -136
- package/lib/two-choice.js.map +0 -1
- package/lib/with-stateful-model.js +0 -61
- package/lib/with-stateful-model.js.map +0 -1
- package/src/__tests__/alert-dialog.test.jsx +0 -183
- package/src/__tests__/checkbox.test.jsx +0 -152
- package/src/__tests__/choice-utils.test.js +0 -12
- package/src/__tests__/form-section.test.jsx +0 -328
- package/src/__tests__/help.test.jsx +0 -184
- package/src/__tests__/input.test.jsx +0 -156
- package/src/__tests__/langs.test.jsx +0 -376
- package/src/__tests__/number-text-field-custom.test.jsx +0 -255
- package/src/__tests__/number-text-field.test.jsx +0 -263
- package/src/__tests__/radio-with-label.test.jsx +0 -155
- package/src/__tests__/settings-panel.test.js +0 -187
- package/src/__tests__/settings.test.jsx +0 -452
- package/src/__tests__/tabs.test.jsx +0 -188
- package/src/__tests__/two-choice.test.js +0 -110
- package/src/__tests__/with-stateful-model.test.jsx +0 -139
- package/src/alert-dialog.jsx +0 -75
- package/src/checkbox.jsx +0 -61
- package/src/choice-configuration/__tests__/feedback-menu.test.jsx +0 -151
- package/src/choice-configuration/__tests__/index.test.jsx +0 -234
- package/src/choice-configuration/feedback-menu.jsx +0 -96
- package/src/choice-configuration/index.jsx +0 -357
- package/src/choice-utils.js +0 -30
- package/src/feedback-config/__tests__/feedback-config.test.jsx +0 -141
- package/src/feedback-config/__tests__/feedback-selector.test.jsx +0 -97
- package/src/feedback-config/feedback-selector.jsx +0 -112
- package/src/feedback-config/group.jsx +0 -51
- package/src/feedback-config/index.jsx +0 -111
- package/src/form-section.jsx +0 -31
- package/src/help.jsx +0 -79
- package/src/index.js +0 -55
- package/src/input.jsx +0 -72
- package/src/inputs.jsx +0 -69
- package/src/langs.jsx +0 -111
- package/src/layout/__tests__/config.layout.test.jsx +0 -59
- package/src/layout/__tests__/layout-content.test.jsx +0 -3
- package/src/layout/config-layout.jsx +0 -103
- package/src/layout/index.js +0 -4
- package/src/layout/layout-contents.jsx +0 -117
- package/src/layout/settings-box.jsx +0 -32
- package/src/mui-box/index.jsx +0 -56
- package/src/number-text-field-custom.jsx +0 -333
- package/src/number-text-field.jsx +0 -215
- package/src/radio-with-label.jsx +0 -30
- package/src/settings/display-size.jsx +0 -53
- package/src/settings/index.js +0 -83
- package/src/settings/panel.jsx +0 -333
- package/src/settings/settings-radio-label.jsx +0 -32
- package/src/settings/toggle.jsx +0 -46
- package/src/tabs/index.jsx +0 -47
- package/src/tags-input/__tests__/index.test.jsx +0 -113
- package/src/tags-input/index.jsx +0 -116
- package/src/two-choice.jsx +0 -90
- package/src/with-stateful-model.jsx +0 -36
|
@@ -1,376 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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":[]}
|
package/lib/number-text-field.js
DELETED
|
@@ -1,229 +0,0 @@
|
|
|
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
|