@pie-lib/config-ui 13.0.4-next.30 → 13.0.4-next.34

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (190) hide show
  1. package/CHANGELOG.json +32 -0
  2. package/CHANGELOG.md +2419 -0
  3. package/LICENSE.md +5 -0
  4. package/lib/alert-dialog.js +68 -0
  5. package/lib/alert-dialog.js.map +1 -0
  6. package/lib/checkbox.js +84 -0
  7. package/lib/checkbox.js.map +1 -0
  8. package/lib/choice-configuration/feedback-menu.js +129 -0
  9. package/lib/choice-configuration/feedback-menu.js.map +1 -0
  10. package/lib/choice-configuration/index.js +381 -0
  11. package/lib/choice-configuration/index.js.map +1 -0
  12. package/lib/choice-utils.js +42 -0
  13. package/lib/choice-utils.js.map +1 -0
  14. package/lib/feedback-config/feedback-selector.js +155 -0
  15. package/lib/feedback-config/feedback-selector.js.map +1 -0
  16. package/lib/feedback-config/group.js +61 -0
  17. package/lib/feedback-config/group.js.map +1 -0
  18. package/lib/feedback-config/index.js +146 -0
  19. package/lib/feedback-config/index.js.map +1 -0
  20. package/lib/form-section.js +44 -0
  21. package/lib/form-section.js.map +1 -0
  22. package/lib/help.js +106 -0
  23. package/lib/help.js.map +1 -0
  24. package/lib/index.js +186 -0
  25. package/lib/index.js.map +1 -0
  26. package/lib/input.js +106 -0
  27. package/lib/input.js.map +1 -0
  28. package/lib/inputs.js +105 -0
  29. package/lib/inputs.js.map +1 -0
  30. package/lib/langs.js +136 -0
  31. package/lib/langs.js.map +1 -0
  32. package/lib/layout/config-layout.js +137 -0
  33. package/lib/layout/config-layout.js.map +1 -0
  34. package/lib/layout/index.js +21 -0
  35. package/lib/layout/index.js.map +1 -0
  36. package/lib/layout/layout-contents.js +160 -0
  37. package/lib/layout/layout-contents.js.map +1 -0
  38. package/lib/layout/settings-box.js +57 -0
  39. package/lib/layout/settings-box.js.map +1 -0
  40. package/lib/mui-box/index.js +63 -0
  41. package/lib/mui-box/index.js.map +1 -0
  42. package/lib/number-text-field-custom.js +376 -0
  43. package/lib/number-text-field-custom.js.map +1 -0
  44. package/lib/number-text-field.js +229 -0
  45. package/lib/number-text-field.js.map +1 -0
  46. package/lib/radio-with-label.js +48 -0
  47. package/lib/radio-with-label.js.map +1 -0
  48. package/lib/settings/display-size.js +61 -0
  49. package/lib/settings/display-size.js.map +1 -0
  50. package/lib/settings/index.js +110 -0
  51. package/lib/settings/index.js.map +1 -0
  52. package/lib/settings/panel.js +392 -0
  53. package/lib/settings/panel.js.map +1 -0
  54. package/lib/settings/settings-radio-label.js +51 -0
  55. package/lib/settings/settings-radio-label.js.map +1 -0
  56. package/lib/settings/toggle.js +63 -0
  57. package/lib/settings/toggle.js.map +1 -0
  58. package/lib/tabs/index.js +75 -0
  59. package/lib/tabs/index.js.map +1 -0
  60. package/lib/tags-input/index.js +149 -0
  61. package/lib/tags-input/index.js.map +1 -0
  62. package/lib/two-choice.js +136 -0
  63. package/lib/two-choice.js.map +1 -0
  64. package/lib/with-stateful-model.js +61 -0
  65. package/lib/with-stateful-model.js.map +1 -0
  66. package/package.json +19 -33
  67. package/src/__tests__/alert-dialog.test.jsx +183 -0
  68. package/src/__tests__/checkbox.test.jsx +152 -0
  69. package/src/__tests__/choice-utils.test.js +12 -0
  70. package/src/__tests__/form-section.test.jsx +328 -0
  71. package/src/__tests__/help.test.jsx +184 -0
  72. package/src/__tests__/input.test.jsx +156 -0
  73. package/src/__tests__/langs.test.jsx +376 -0
  74. package/src/__tests__/number-text-field-custom.test.jsx +255 -0
  75. package/src/__tests__/number-text-field.test.jsx +263 -0
  76. package/src/__tests__/radio-with-label.test.jsx +155 -0
  77. package/src/__tests__/settings-panel.test.js +187 -0
  78. package/src/__tests__/settings.test.jsx +452 -0
  79. package/src/__tests__/tabs.test.jsx +188 -0
  80. package/src/__tests__/two-choice.test.js +110 -0
  81. package/src/__tests__/with-stateful-model.test.jsx +139 -0
  82. package/src/alert-dialog.jsx +75 -0
  83. package/src/checkbox.jsx +61 -0
  84. package/src/choice-configuration/__tests__/feedback-menu.test.jsx +151 -0
  85. package/src/choice-configuration/__tests__/index.test.jsx +234 -0
  86. package/src/choice-configuration/feedback-menu.jsx +96 -0
  87. package/src/choice-configuration/index.jsx +357 -0
  88. package/src/choice-utils.js +30 -0
  89. package/src/feedback-config/__tests__/feedback-config.test.jsx +141 -0
  90. package/src/feedback-config/__tests__/feedback-selector.test.jsx +97 -0
  91. package/src/feedback-config/feedback-selector.jsx +112 -0
  92. package/src/feedback-config/group.jsx +51 -0
  93. package/src/feedback-config/index.jsx +111 -0
  94. package/src/form-section.jsx +31 -0
  95. package/src/help.jsx +79 -0
  96. package/src/index.js +55 -0
  97. package/src/input.jsx +72 -0
  98. package/src/inputs.jsx +69 -0
  99. package/src/langs.jsx +111 -0
  100. package/src/layout/__tests__/config.layout.test.jsx +59 -0
  101. package/src/layout/__tests__/layout-content.test.jsx +3 -0
  102. package/src/layout/config-layout.jsx +103 -0
  103. package/src/layout/index.js +4 -0
  104. package/src/layout/layout-contents.jsx +117 -0
  105. package/src/layout/settings-box.jsx +32 -0
  106. package/src/mui-box/index.jsx +56 -0
  107. package/src/number-text-field-custom.jsx +333 -0
  108. package/src/number-text-field.jsx +215 -0
  109. package/src/radio-with-label.jsx +30 -0
  110. package/src/settings/display-size.jsx +53 -0
  111. package/src/settings/index.js +83 -0
  112. package/src/settings/panel.jsx +333 -0
  113. package/src/settings/settings-radio-label.jsx +32 -0
  114. package/src/settings/toggle.jsx +46 -0
  115. package/src/tabs/index.jsx +47 -0
  116. package/src/tags-input/__tests__/index.test.jsx +113 -0
  117. package/src/tags-input/index.jsx +116 -0
  118. package/src/two-choice.jsx +90 -0
  119. package/src/with-stateful-model.jsx +36 -0
  120. package/dist/_virtual/_rolldown/runtime.js +0 -11
  121. package/dist/alert-dialog.d.ts +0 -44
  122. package/dist/alert-dialog.js +0 -47
  123. package/dist/checkbox.d.ts +0 -34
  124. package/dist/checkbox.js +0 -57
  125. package/dist/choice-configuration/feedback-menu.d.ts +0 -32
  126. package/dist/choice-configuration/feedback-menu.js +0 -85
  127. package/dist/choice-configuration/index.d.ts +0 -62
  128. package/dist/choice-configuration/index.js +0 -240
  129. package/dist/choice-utils.d.ts +0 -21
  130. package/dist/choice-utils.js +0 -15
  131. package/dist/feedback-config/feedback-selector.d.ts +0 -33
  132. package/dist/feedback-config/feedback-selector.js +0 -92
  133. package/dist/feedback-config/group.d.ts +0 -21
  134. package/dist/feedback-config/group.js +0 -33
  135. package/dist/feedback-config/index.d.ts +0 -48
  136. package/dist/feedback-config/index.js +0 -96
  137. package/dist/form-section.d.ts +0 -25
  138. package/dist/form-section.js +0 -25
  139. package/dist/fraction-to-number.d.ts +0 -7
  140. package/dist/fraction-to-number.js +0 -9
  141. package/dist/help.d.ts +0 -41
  142. package/dist/help.js +0 -61
  143. package/dist/index.d.ts +0 -31
  144. package/dist/index.js +0 -34
  145. package/dist/input.d.ts +0 -29
  146. package/dist/input.js +0 -65
  147. package/dist/inputs.d.ts +0 -63
  148. package/dist/inputs.js +0 -70
  149. package/dist/langs.d.ts +0 -41
  150. package/dist/langs.js +0 -76
  151. package/dist/layout/config-layout.d.ts +0 -10
  152. package/dist/layout/config-layout.js +0 -75
  153. package/dist/layout/index.d.ts +0 -11
  154. package/dist/layout/index.js +0 -10
  155. package/dist/layout/layout-contents.d.ts +0 -21
  156. package/dist/layout/layout-contents.js +0 -70
  157. package/dist/layout/settings-box.d.ts +0 -19
  158. package/dist/layout/settings-box.js +0 -31
  159. package/dist/mui-box/index.d.ts +0 -21
  160. package/dist/mui-box/index.js +0 -47
  161. package/dist/node_modules/.bun/@babel_runtime@7.29.7/node_modules/@babel/runtime/helpers/esm/extends.js +0 -12
  162. package/dist/node_modules/.bun/@babel_runtime@7.29.7/node_modules/@babel/runtime/helpers/esm/inheritsLoose.js +0 -7
  163. package/dist/node_modules/.bun/@babel_runtime@7.29.7/node_modules/@babel/runtime/helpers/esm/objectWithoutPropertiesLoose.js +0 -12
  164. package/dist/node_modules/.bun/@babel_runtime@7.29.7/node_modules/@babel/runtime/helpers/esm/setPrototypeOf.js +0 -8
  165. package/dist/node_modules/.bun/react-measure@2.5.2_6dbf9a050bc9aadb/node_modules/react-measure/dist/index.esm.js +0 -122
  166. package/dist/node_modules/.bun/resize-observer-polyfill@1.5.1/node_modules/resize-observer-polyfill/dist/ResizeObserver.es.js +0 -276
  167. package/dist/number-text-field-custom.d.ts +0 -51
  168. package/dist/number-text-field-custom.js +0 -192
  169. package/dist/number-text-field.d.ts +0 -47
  170. package/dist/number-text-field.js +0 -122
  171. package/dist/radio-with-label.d.ts +0 -25
  172. package/dist/radio-with-label.js +0 -27
  173. package/dist/settings/display-size.d.ts +0 -26
  174. package/dist/settings/display-size.js +0 -45
  175. package/dist/settings/index.d.ts +0 -45
  176. package/dist/settings/index.js +0 -63
  177. package/dist/settings/panel.d.ts +0 -27
  178. package/dist/settings/panel.js +0 -201
  179. package/dist/settings/settings-radio-label.d.ts +0 -25
  180. package/dist/settings/settings-radio-label.js +0 -29
  181. package/dist/settings/toggle.d.ts +0 -25
  182. package/dist/settings/toggle.js +0 -33
  183. package/dist/tabs/index.d.ts +0 -22
  184. package/dist/tabs/index.js +0 -39
  185. package/dist/tags-input/index.d.ts +0 -21
  186. package/dist/tags-input/index.js +0 -83
  187. package/dist/two-choice.d.ts +0 -43
  188. package/dist/two-choice.js +0 -79
  189. package/dist/with-stateful-model.d.ts +0 -42
  190. 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":";;;;;;;;;;;;;;;AAAA,IAAAA,UAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,MAAA,GAAAF,sBAAA,CAAAC,OAAA;AACA,IAAAE,UAAA,GAAAH,sBAAA,CAAAC,OAAA;AACA,IAAAG,OAAA,GAAAH,OAAA;AACA,IAAAI,SAAA,GAAAJ,OAAA;AACA,IAAAK,WAAA,GAAAN,sBAAA,CAAAC,OAAA;AACA,IAAAM,eAAA,GAAAP,sBAAA,CAAAC,OAAA;AACA,IAAAO,OAAA,GAAAR,sBAAA,CAAAC,OAAA;AACA,IAAAQ,IAAA,GAAAT,sBAAA,CAAAC,OAAA;AACA,IAAAS,IAAA,GAAAC,uBAAA,CAAAV,OAAA;AAA+B,SAAAU,wBAAAC,CAAA,EAAAC,CAAA,6BAAAC,OAAA,MAAAC,CAAA,OAAAD,OAAA,IAAAE,CAAA,OAAAF,OAAA,YAAAH,uBAAA,YAAAA,wBAAAC,CAAA,EAAAC,CAAA,SAAAA,CAAA,IAAAD,CAAA,IAAAA,CAAA,CAAAK,UAAA,SAAAL,CAAA,MAAAM,CAAA,EAAAC,CAAA,EAAAC,CAAA,KAAAC,SAAA,mBAAAT,CAAA,iBAAAA,CAAA,gBAAAU,OAAA,CAAAV,CAAA,0BAAAA,CAAA,SAAAQ,CAAA,MAAAF,CAAA,GAAAL,CAAA,GAAAG,CAAA,GAAAD,CAAA,QAAAG,CAAA,CAAAK,GAAA,CAAAX,CAAA,UAAAM,CAAA,CAAAM,GAAA,CAAAZ,CAAA,GAAAM,CAAA,CAAAO,GAAA,CAAAb,CAAA,EAAAQ,CAAA,cAAAM,EAAA,IAAAd,CAAA,gBAAAc,EAAA,OAAAC,cAAA,CAAAC,IAAA,CAAAhB,CAAA,EAAAc,EAAA,OAAAP,CAAA,IAAAD,CAAA,GAAAW,MAAA,CAAAC,cAAA,KAAAD,MAAA,CAAAE,wBAAA,CAAAnB,CAAA,EAAAc,EAAA,OAAAP,CAAA,CAAAK,GAAA,IAAAL,CAAA,CAAAM,GAAA,IAAAP,CAAA,CAAAE,CAAA,EAAAM,EAAA,EAAAP,CAAA,IAAAC,CAAA,CAAAM,EAAA,IAAAd,CAAA,CAAAc,EAAA,WAAAN,CAAA,KAAAR,CAAA,EAAAC,CAAA;AAAA,SAAAmB,WAAAnB,CAAA,EAAAK,CAAA,EAAAN,CAAA,WAAAM,CAAA,OAAAe,gBAAA,aAAAf,CAAA,OAAAgB,2BAAA,aAAArB,CAAA,EAAAsB,yBAAA,KAAAC,OAAA,CAAAC,SAAA,CAAAnB,CAAA,EAAAN,CAAA,YAAAqB,gBAAA,aAAApB,CAAA,EAAAyB,WAAA,IAAApB,CAAA,CAAAqB,KAAA,CAAA1B,CAAA,EAAAD,CAAA;AAAA,SAAAuB,0BAAA,cAAAtB,CAAA,IAAA2B,OAAA,CAAAC,SAAA,CAAAC,OAAA,CAAAd,IAAA,CAAAQ,OAAA,CAAAC,SAAA,CAAAG,OAAA,iCAAA3B,CAAA,aAAAsB,yBAAA,YAAAA,0BAAA,aAAAtB,CAAA;AAE/B,IAAM8B,eAAe,GAAG,IAAAC,cAAM,EAACC,qBAAS,CAAC,CAAC;EAAA,OAAO;IAC/C,sBAAsB,EAAE;MACtBC,aAAa,EAAE;IACjB,CAAC;IACD,iDAAiD,EAAE;MACjDC,gBAAgB,EAAE,MAAM;MACxBC,MAAM,EAAE;IACV,CAAC;IACD,iDAAiD,EAAE;MACjDD,gBAAgB,EAAE,MAAM;MACxBC,MAAM,EAAE;IACV;EACF,CAAC;AAAA,CAAC,CAAC;AAEH,IAAMC,gBAAgB,GAAG,IAAAL,cAAM,EAACM,sBAAU,CAAC,CAAC;EAAA,OAAO;IACjDC,OAAO,EAAE;EACX,CAAC;AAAA,CAAC,CAAC;AAEH,IAAMC,cAAc,GAAG,SAAjBA,cAAcA,CAAIC,GAAG,EAAEC,GAAG,EAAK;EACnC,IAAI,CAAC,IAAAC,kBAAQ,EAACF,GAAG,CAAC,IAAI,CAAC,IAAAE,kBAAQ,EAACD,GAAG,CAAC,EAAE;IACpC,OAAO,CAAC;EACV;EAEA,IAAI,CAAC,IAAAC,kBAAQ,EAACF,GAAG,CAAC,IAAI,IAAAE,kBAAQ,EAACD,GAAG,CAAC,EAAE;IACnC,OAAOA,GAAG;EACZ;EAEA,IAAI,IAAAC,kBAAQ,EAACF,GAAG,CAAC,EAAE;IACjB,OAAOA,GAAG;EACZ;AACF,CAAC;AAAC,IAEWG,qBAAqB,GAAAC,OAAA,CAAAD,qBAAA,0BAAAE,gBAAA;EA6BhC,SAAAF,sBAAYG,KAAK,EAAE;IAAA,IAAAC,KAAA;IAAA,IAAAC,gBAAA,mBAAAL,qBAAA;IACjBI,KAAA,GAAA5B,UAAA,OAAAwB,qBAAA,GAAMG,KAAK;IAAE,IAAAG,gBAAA,aAAAF,KAAA,4BA4CU,UAACG,YAAY,EAAEC,MAAM,EAAEX,GAAG,EAAEC,GAAG,EAAK;MAC3D,IAAQW,IAAI,GAAKL,KAAA,CAAKD,KAAK,CAAnBM,IAAI;MACZ,IAAMC,KAAK,GAAGN,KAAA,CAAKO,KAAK,CAACH,MAAM,EAAEX,GAAG,EAAEC,GAAG,CAAC;MAC1C,IAAMc,YAAY,GAAG,CAACL,YAAY,IAAI,EAAE,EAAEM,SAAS,CAAC,UAACC,GAAG;QAAA,OAAKA,GAAG,KAAKJ,KAAK;MAAA,EAAC;MAE3E,IAAI,CAACH,YAAY,IAAI,EAAE,EAAEQ,MAAM,GAAG,CAAC,IAAIH,YAAY,KAAK,CAAC,CAAC,EAAE;QAC1D,IAAMI,YAAY,GAChBP,IAAI,KAAK,MAAM,GAAGL,KAAA,CAAKa,uBAAuB,CAACV,YAAY,EAAEG,KAAK,CAAC,GAAGN,KAAA,CAAKc,eAAe,CAACX,YAAY,EAAEG,KAAK,CAAC;QAEjH,OAAO;UAAEA,KAAK,EAAEM,YAAY,CAACN,KAAK;UAAEE,YAAY,EAAEI,YAAY,CAACG;QAAM,CAAC;MACxE;MAEA,OAAO;QAAET,KAAK,EAALA,KAAK;QAAEE,YAAY,EAAZA;MAAa,CAAC;IAChC,CAAC;IAAA,IAAAN,gBAAA,aAAAF,KAAA,qBAEiB,UAACG,YAAY,EAAEC,MAAM;MAAA,OACrCD,YAAY,CAACa,MAAM,CACjB,UAACC,OAAO,EAAEX,KAAK,EAAES,KAAK;QAAA,OACpBG,IAAI,CAACC,GAAG,CAACb,KAAK,GAAGF,MAAM,CAAC,GAAGc,IAAI,CAACC,GAAG,CAACF,OAAO,CAACX,KAAK,GAAGF,MAAM,CAAC,GAAG;UAAEE,KAAK,EAALA,KAAK;UAAES,KAAK,EAALA;QAAM,CAAC,GAAGE,OAAO;MAAA,GAC1F;QAAEX,KAAK,EAAEH,YAAY,CAAC,CAAC,CAAC;QAAEY,KAAK,EAAE;MAAE,CACrC,CAAC;IAAA;IAAA,IAAAb,gBAAA,aAAAF,KAAA,6BAEuB,UAACG,YAAY,EAAEC,MAAM;MAAA,OAC7CD,YAAY,CAACa,MAAM,CACjB,UAACC,OAAO,EAAEX,KAAK,EAAES,KAAK;QAAA,OACpBG,IAAI,CAACC,GAAG,CAACrE,IAAI,CAACsD,MAAM,CAACtD,IAAI,CAACsE,QAAQ,CAACd,KAAK,CAAC,CAAC,GAAGxD,IAAI,CAACsD,MAAM,CAACtD,IAAI,CAACsE,QAAQ,CAAChB,MAAM,CAAC,CAAC,CAAC,GAChFc,IAAI,CAACC,GAAG,CAACrE,IAAI,CAACsD,MAAM,CAACtD,IAAI,CAACsE,QAAQ,CAACH,OAAO,CAACX,KAAK,CAAC,CAAC,GAAGxD,IAAI,CAACsD,MAAM,CAACtD,IAAI,CAACsE,QAAQ,CAAChB,MAAM,CAAC,CAAC,CAAC,GACpF;UAAEE,KAAK,EAALA,KAAK;UAAES,KAAK,EAALA;QAAM,CAAC,GAChBE,OAAO;MAAA,GACb;QAAEX,KAAK,EAAEH,YAAY,CAAC,CAAC,CAAC;QAAEY,KAAK,EAAE;MAAE,CACrC,CAAC;IAAA;IAAA,IAAAb,gBAAA,aAAAF,KAAA,sBAEgB,UAACM,KAAK,EAAK;MAC5B,IAAIN,KAAA,CAAKqB,iBAAiB,CAACf,KAAK,CAACgB,IAAI,CAAC,CAAC,CAAC,EAAE;QACxC,OAAOhB,KAAK,CAACgB,IAAI,CAAC,CAAC;MACrB;MACA,IAAIhB,KAAK,CAACgB,IAAI,CAAC,CAAC,KAAK,EAAE,IAAIhB,KAAK,CAACgB,IAAI,CAAC,CAAC,CAACC,KAAK,CAAC,GAAG,CAAC,CAACZ,MAAM,KAAK,CAAC,EAAE;QAC/D,OAAO,KAAK;MACd;MACA,IAAAa,iBAAA,GAA+BlB,KAAK,CAACgB,IAAI,CAAC,CAAC,CAACC,KAAK,CAAC,GAAG,CAAC;QAAAE,kBAAA,OAAAC,eAAA,aAAAF,iBAAA;QAAjDG,SAAS,GAAAF,kBAAA;QAAEG,WAAW,GAAAH,kBAAA;MAC3B,IAAII,KAAK,CAACF,SAAS,CAAC,IAAIE,KAAK,CAACD,WAAW,CAAC,EAAE;QAC1C,OAAO,KAAK;MACd;MACAD,SAAS,GAAGG,UAAU,CAACH,SAAS,CAAC;MACjCC,WAAW,GAAGE,UAAU,CAACF,WAAW,CAAC;MACrC,IAAI,CAACG,MAAM,CAACC,SAAS,CAACL,SAAS,CAAC,IAAI,CAACI,MAAM,CAACC,SAAS,CAACJ,WAAW,CAAC,EAAE;QAClE,OAAO,KAAK;MACd;MACA,IAAID,SAAS,GAAG,CAAC,IAAIC,WAAW,GAAG,CAAC,EAAE;QACpC,OAAO,KAAK;MACd;MACA,OAAOD,SAAS,GAAG,GAAG,GAAGC,WAAW;IACtC,CAAC;IAAA,IAAA1B,gBAAA,aAAAF,KAAA,uBAEmB,UAAC5C,CAAC,EAAK;MACzB,OAAOA,CAAC,KAAK,CAAC,KAAK0E,UAAU,CAAC1E,CAAC,CAAC;IAClC,CAAC;IAAA,IAAA8C,gBAAA,aAAAF,KAAA,YAEQ,UAACiC,KAAK,EAAK;MAClB,IAAAC,WAAA,GAAoDlC,KAAA,CAAKD,KAAK;QAAtDI,YAAY,GAAA+B,WAAA,CAAZ/B,YAAY;QAAEgC,mBAAmB,GAAAD,WAAA,CAAnBC,mBAAmB;QAAE9B,IAAI,GAAA6B,WAAA,CAAJ7B,IAAI;MAC/C,IAAMC,KAAK,GAAK2B,KAAK,CAACG,MAAM,CAAtB9B,KAAK;MACX,IAAID,IAAI,KAAK,MAAM,EAAE;QACnB,IAAIgC,SAAS,GAAGrC,KAAA,CAAKsC,gBAAgB,CAAChC,KAAK,CAAC;QAC5C,IAAI+B,SAAS,EAAE;UACb/B,KAAK,GAAG+B,SAAS;QACnB,CAAC,MAAM;UACL/B,KAAK,GAAGN,KAAA,CAAKD,KAAK,CAACO,KAAK;QAC1B;MACF;MACA,IAAIiC,SAAS,GAAGJ,mBAAmB,GAAGjB,IAAI,CAACsB,KAAK,CAACV,UAAU,CAACxB,KAAK,CAAC,CAAC,GAAGwB,UAAU,CAACxB,KAAK,CAAC;MACvF,IAAID,IAAI,KAAK,MAAM,EAAE;QACnBkC,SAAS,GAAGjC,KAAK,CAACgB,IAAI,CAAC,CAAC;MAC1B;MACA,IAAAmB,qBAAA,GAAwCzC,KAAA,CAAK0C,sBAAsB,CAACvC,YAAY,EAAEoC,SAAS,CAAC;QAA7EnC,MAAM,GAAAqC,qBAAA,CAAbnC,KAAK;QAAUE,YAAY,GAAAiC,qBAAA,CAAZjC,YAAY;MACnCR,KAAA,CAAK2C,QAAQ,CACX;QACErC,KAAK,EAAEF,MAAM,CAACwC,QAAQ,CAAC,CAAC;QACxBpC,YAAY,EAAZA;MACF,CAAC,EACD;QAAA,OAAMR,KAAA,CAAKD,KAAK,CAAC8C,QAAQ,CAACZ,KAAK,EAAE7B,MAAM,CAAC;MAAA,CAC1C,CAAC;IACH,CAAC;IA3HC,IAAA0C,sBAAA,GAAgC9C,KAAA,CAAK0C,sBAAsB,CAAC3C,KAAK,CAACI,YAAY,EAAEJ,KAAK,CAACO,KAAK,CAAC;MAApFA,MAAK,GAAAwC,sBAAA,CAALxC,KAAK;MAAEE,aAAY,GAAAsC,sBAAA,CAAZtC,YAAY;IAE3BR,KAAA,CAAK+C,KAAK,GAAG;MACXzC,KAAK,EAALA,MAAK;MACLE,YAAY,EAAZA;IACF,CAAC;IAED,IAAIF,MAAK,KAAKP,KAAK,CAACO,KAAK,EAAE;MACzBN,KAAA,CAAKD,KAAK,CAAC8C,QAAQ,CAAC,CAAC,CAAC,EAAEvC,MAAK,CAAC;IAChC;IAEAN,KAAA,CAAK6C,QAAQ,GAAG7C,KAAA,CAAK6C,QAAQ,CAACG,IAAI,CAAAhD,KAAK,CAAC;IAAC,OAAAA,KAAA;EAC3C;EAAC,IAAAiD,UAAA,aAAArD,qBAAA,EAAAE,gBAAA;EAAA,WAAAoD,aAAA,aAAAtD,qBAAA;IAAAuD,GAAA;IAAA7C,KAAA,EAED,SAAA8C,gCAAgCA,CAACrD,KAAK,EAAE;MACtC,IAAAsD,sBAAA,GAAgC,IAAI,CAACX,sBAAsB,CAAC3C,KAAK,CAACI,YAAY,EAAEJ,KAAK,CAACO,KAAK,EAAEP,KAAK,CAACN,GAAG,EAAEM,KAAK,CAACL,GAAG,CAAC;QAA1GY,KAAK,GAAA+C,sBAAA,CAAL/C,KAAK;QAAEE,YAAY,GAAA6C,sBAAA,CAAZ7C,YAAY;MAE3B,IAAI,CAACmC,QAAQ,CAAC;QAAErC,KAAK,EAALA,KAAK;QAAEE,YAAY,EAAZA;MAAa,CAAC,CAAC;IACxC;EAAC;IAAA2C,GAAA;IAAA7C,KAAA,EAED,SAAAC,KAAKA,CAACD,KAAK,EAA8C;MAAA,IAA5Cb,GAAG,GAAA6D,SAAA,CAAA3C,MAAA,QAAA2C,SAAA,QAAAC,SAAA,GAAAD,SAAA,MAAG,IAAI,CAACvD,KAAK,CAACN,GAAG;MAAA,IAAEC,GAAG,GAAA4D,SAAA,CAAA3C,MAAA,QAAA2C,SAAA,QAAAC,SAAA,GAAAD,SAAA,MAAG,IAAI,CAACvD,KAAK,CAACL,GAAG;MACrD,IAAQS,YAAY,GAAK,IAAI,CAACJ,KAAK,CAA3BI,YAAY;MAEpB,IAAI,CAACA,YAAY,IAAI,EAAE,EAAEQ,MAAM,GAAG,CAAC,EAAE;QACnC,OAAOL,KAAK;MACd;MAEA,IAAI,CAAC,IAAAX,kBAAQ,EAACW,KAAK,CAAC,EAAE;QACpB,OAAOd,cAAc,CAACC,GAAG,EAAEC,GAAG,CAAC;MACjC;MAEA,IAAI,IAAAC,kBAAQ,EAACD,GAAG,CAAC,EAAE;QACjBY,KAAK,GAAGY,IAAI,CAACzB,GAAG,CAACa,KAAK,EAAEZ,GAAG,CAAC;MAC9B;MAEA,IAAI,IAAAC,kBAAQ,EAACF,GAAG,CAAC,EAAE;QACjBa,KAAK,GAAGY,IAAI,CAACxB,GAAG,CAACY,KAAK,EAAEb,GAAG,CAAC;MAC9B;MAEA,OAAOa,KAAK;IACd;EAAC;IAAA6C,GAAA;IAAA7C,KAAA,EAqFD,SAAAuC,QAAQA,CAACZ,KAAK,EAAE;MACd,IAAQ5B,IAAI,GAAK,IAAI,CAACN,KAAK,CAAnBM,IAAI;MACZ,IAAQC,KAAK,GAAK2B,KAAK,CAACG,MAAM,CAAtB9B,KAAK;MACb,IAAID,IAAI,KAAK,MAAM,IAAI,OAAOC,KAAK,KAAK,QAAQ,IAAIA,KAAK,CAACgB,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE;QACvE;MACF;MACA,IAAI,CAACqB,QAAQ,CAAC;QAAErC,KAAK,EAALA;MAAM,CAAC,CAAC;IAC1B;EAAC;IAAA6C,GAAA;IAAA7C,KAAA,EAED,SAAAkD,WAAWA,CAACvB,KAAK,EAAkC;MAAA,IAAhCwB,IAAI,GAAAH,SAAA,CAAA3C,MAAA,QAAA2C,SAAA,QAAAC,SAAA,GAAAD,SAAA,MAAG,CAAC;MAAA,IAAEI,YAAY,GAAAJ,SAAA,CAAA3C,MAAA,QAAA2C,SAAA,QAAAC,SAAA,GAAAD,SAAA,MAAG,KAAK;MAC/CrB,KAAK,CAAC0B,cAAc,CAAC,CAAC;MACtB,IAAAC,YAAA,GAA8D,IAAI,CAAC7D,KAAK;QAAhEI,YAAY,GAAAyD,YAAA,CAAZzD,YAAY;QAAE0D,IAAI,GAAAD,YAAA,CAAJC,IAAI;QAAE1B,mBAAmB,GAAAyB,YAAA,CAAnBzB,mBAAmB;QAAEU,QAAQ,GAAAe,YAAA,CAARf,QAAQ;MACzD,IAAAiB,WAAA,GAAgC,IAAI,CAACf,KAAK;QAAlCvC,YAAY,GAAAsD,WAAA,CAAZtD,YAAY;QAAEF,KAAK,GAAAwD,WAAA,CAALxD,KAAK;MAC3B,IAAMyD,YAAY,GAAGvD,YAAY,GAAGiD,IAAI,GAAG,CAAC;MAC5C,IAAIrD,MAAM;MACV,IAAID,YAAY,CAACQ,MAAM,GAAG,CAAC,EAAE;QAC3B,IAAIoD,YAAY,GAAG,CAAC,IAAIA,YAAY,IAAI5D,YAAY,CAACQ,MAAM,EAAE;UAC3D;QACF;QACAP,MAAM,GAAGD,YAAY,CAAC4D,YAAY,CAAC;MACrC,CAAC,MAAM;QACL,IAAMxB,SAAS,GAAGJ,mBAAmB,GAAG6B,QAAQ,CAAC1D,KAAK,CAAC,GAAGwB,UAAU,CAACxB,KAAK,CAAC;QAC3E,IAAM2D,YAAY,GAAG,CAAC1B,SAAS,GAAG,KAAK,GAAGsB,IAAI,GAAGJ,IAAI,GAAG,KAAK,IAAI,KAAK;QACtErD,MAAM,GAAG,IAAI,CAACG,KAAK,CAAC0D,YAAY,CAAC;MACnC;MACA,IAAI,CAACtB,QAAQ,CACX;QACErC,KAAK,EAAEF,MAAM,CAACwC,QAAQ,CAAC,CAAC;QACxBpC,YAAY,EAAEuD;MAChB,CAAC,EACD,YAAM;QACJ,IAAIL,YAAY,EAAE;UAChBb,QAAQ,CAACZ,KAAK,EAAE7B,MAAM,CAAC;QACzB;MACF,CACF,CAAC;IACH;EAAC;IAAA+C,GAAA;IAAA7C,KAAA,EAED,SAAA4D,MAAMA,CAAA,EAAG;MAAA,IAAAC,MAAA;MACP,IAAAC,YAAA,GAcI,IAAI,CAACrE,KAAK;QAbZsE,SAAS,GAAAD,YAAA,CAATC,SAAS;QACTC,KAAK,GAAAF,YAAA,CAALE,KAAK;QACLC,QAAQ,GAAAH,YAAA,CAARG,QAAQ;QACRC,KAAK,GAAAJ,YAAA,CAALI,KAAK;QACL/E,GAAG,GAAA2E,YAAA,CAAH3E,GAAG;QACHC,GAAG,GAAA0E,YAAA,CAAH1E,GAAG;QACHS,YAAY,GAAAiE,YAAA,CAAZjE,YAAY;QACZsE,cAAc,GAAAL,YAAA,CAAdK,cAAc;QACdC,gBAAgB,GAAAN,YAAA,CAAhBM,gBAAgB;QAChBC,UAAU,GAAAP,YAAA,CAAVO,UAAU;QACVC,OAAO,GAAAR,YAAA,CAAPQ,OAAO;QACPC,SAAS,GAAAT,YAAA,CAATS,SAAS;QAAAC,iBAAA,GAAAV,YAAA,CACT/D,IAAI;QAAJA,IAAI,GAAAyE,iBAAA,cAAG,QAAQ,GAAAA,iBAAA;MAEjB,IAAQxE,KAAK,GAAK,IAAI,CAACyC,KAAK,CAApBzC,KAAK;MACb,IAAMyE,KAAK,GAAGV,SAAS;MACvB;MACA,IAAIW,aAAa,GAAG,KAAK;MACzB,IAAIC,WAAW,GAAG,KAAK;MACvB,IAAI9E,YAAY,CAACQ,MAAM,GAAG,CAAC,EAAE;QAC3BqE,aAAa,GAAG1E,KAAK,KAAKH,YAAY,CAAC,CAAC,CAAC;QACzC8E,WAAW,GAAG3E,KAAK,KAAKH,YAAY,CAACA,YAAY,CAACQ,MAAM,GAAG,CAAC,CAAC;MAC/D,CAAC,MAAM,IAAI,IAAAhB,kBAAQ,EAACF,GAAG,CAAC,IAAI,IAAAE,kBAAQ,EAACD,GAAG,CAAC,EAAE;QACzCsF,aAAa,GAAG1E,KAAK,KAAKb,GAAG;QAC7BwF,WAAW,GAAG3E,KAAK,KAAKZ,GAAG;MAC7B;MAEA,oBACEpD,MAAA,YAAA4I,aAAA,CAACnG,eAAe;QACd6F,OAAO,EAAEA,OAAQ;QACjBO,QAAQ,EAAE,SAAVA,QAAQA,CAAGC,GAAG;UAAA,OAAMjB,MAAI,CAACgB,QAAQ,GAAGC,GAAG;QAAA,CAAE;QACzCb,QAAQ,EAAEA,QAAS;QACnBD,KAAK,EAAEA,KAAM;QACbhE,KAAK,EAAEA,KAAM;QACbkE,KAAK,EAAEA,KAAM;QACbG,UAAU,EAAEA,UAAW;QACvB9B,QAAQ,EAAE,IAAI,CAACA,QAAS;QACxBwC,MAAM,EAAE,IAAI,CAACA,MAAO;QACpBC,UAAU,EAAE,SAAZA,UAAUA,CAAGtI,CAAC,EAAK;UACjB;UACA,IAAIA,CAAC,CAACmG,GAAG,KAAK,OAAO,IAAIgB,MAAI,CAACgB,QAAQ,EAAE;YACtChB,MAAI,CAACgB,QAAQ,CAACI,IAAI,CAAC,CAAC;UACtB;QACF,CAAE;QACFC,SAAS,EAAE,SAAXA,SAASA,CAAGxI,CAAC,EAAK;UAChB,IAAIA,CAAC,CAACmG,GAAG,KAAK,SAAS,EAAE;YACvBgB,MAAI,CAACX,WAAW,CAACxG,CAAC,CAAC;UACrB;UAEA,IAAIA,CAAC,CAACmG,GAAG,KAAK,WAAW,EAAE;YACzBgB,MAAI,CAACX,WAAW,CAACxG,CAAC,EAAE,CAAC,CAAC,CAAC;UACzB;QACF,CAAE;QACFyI,KAAK,EAAE,EAAG;QACVpF,IAAI,EAAEA,IAAK;QACXgE,SAAS,EAAEU,KAAM;QACjBW,UAAU,EAAE;UACVrB,SAAS,EAAEI,cAAc;UACzBC,gBAAgB,EAAEA,gBAAgB;UAClCiB,cAAc,eACZrJ,MAAA,YAAA4I,aAAA,CAACvI,eAAA,WAAc;YAACiJ,QAAQ,EAAC;UAAO,gBAC9BtJ,MAAA,YAAA4I,aAAA,CAAC7F,gBAAgB;YACfkF,QAAQ,EAAEA,QAAQ,GAAGA,QAAQ,GAAGS,aAAc;YAC9Ca,OAAO,EAAE,SAATA,OAAOA,CAAG7I,CAAC;cAAA,OAAKmH,MAAI,CAACX,WAAW,CAACxG,CAAC,EAAE,CAAC,CAAC,EAAE,IAAI,CAAC;YAAA,CAAC;YAC9C8I,IAAI,EAAC;UAAO,gBAEZxJ,MAAA,YAAA4I,aAAA,CAACtI,OAAA,WAAM;YAACmJ,QAAQ,EAAC;UAAO,CAAE,CACV,CACJ,CACjB;UACDC,YAAY,eACV1J,MAAA,YAAA4I,aAAA,CAACvI,eAAA,WAAc;YAACiJ,QAAQ,EAAC;UAAK,gBAC5BtJ,MAAA,YAAA4I,aAAA,CAAC7F,gBAAgB;YACfkF,QAAQ,EAAEA,QAAQ,GAAGA,QAAQ,GAAGU,WAAY;YAC5CY,OAAO,EAAE,SAATA,OAAOA,CAAG7I,CAAC;cAAA,OAAKmH,MAAI,CAACX,WAAW,CAACxG,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC;YAAA,CAAC;YAC7C8I,IAAI,EAAC;UAAO,gBAEZxJ,MAAA,YAAA4I,aAAA,CAACrI,IAAA,WAAG;YAACkJ,QAAQ,EAAC;UAAO,CAAE,CACP,CACJ;QAEpB,CAAE;QACFE,UAAU,EAAE;UACVC,KAAK,EAAE;YAAErB,SAAS,EAATA;UAAU,CAAC;UACpBpF,GAAG,EAAHA,GAAG;UACHC,GAAG,EAAHA;QACF;MAAE,CACH,CAAC;IAEN;EAAC;AAAA,EA9RwCyG,iBAAK,CAACC,SAAS;AAAA,IAAAlG,gBAAA,aAA7CN,qBAAqB,eACb;EACjByE,SAAS,EAAEgC,qBAAS,CAACC,MAAM;EAC3BnG,YAAY,EAAEkG,qBAAS,CAACE,KAAK;EAC7BhC,QAAQ,EAAE8B,qBAAS,CAACG,IAAI;EACxBhC,KAAK,EAAE6B,qBAAS,CAACG,IAAI;EACrB/B,cAAc,EAAE4B,qBAAS,CAACC,MAAM;EAChC3B,UAAU,EAAE0B,qBAAS,CAACC,MAAM;EAC5BzD,QAAQ,EAAEwD,qBAAS,CAACI,IAAI,CAACC,UAAU;EACnCvE,mBAAmB,EAAEkE,qBAAS,CAACG,IAAI;EACnClG,KAAK,EAAE+F,qBAAS,CAACM,GAAG;EACpBlH,GAAG,EAAE4G,qBAAS,CAACjG,MAAM;EACrBV,GAAG,EAAE2G,qBAAS,CAACjG,MAAM;EACrByD,IAAI,EAAEwC,qBAAS,CAACjG,MAAM;EACtBkE,KAAK,EAAE+B,qBAAS,CAACC,MAAM;EACvB5B,gBAAgB,EAAE2B,qBAAS,CAACG,IAAI;EAChC3B,SAAS,EAAEwB,qBAAS,CAACC,MAAM;EAC3B1B,OAAO,EAAEyB,qBAAS,CAACC,MAAM;EACzBjG,IAAI,EAAEgG,qBAAS,CAACC;AAClB,CAAC;AAAA,IAAApG,gBAAA,aAnBUN,qBAAqB,kBAqBV;EACpBiE,IAAI,EAAE,CAAC;EACP1D,YAAY,EAAE,EAAE;EAChB0E,SAAS,EAAE,QAAQ;EACnBD,OAAO,EAAE,UAAU;EACnBzC,mBAAmB,EAAE;AACvB,CAAC;AAAA,IAAAyE,QAAA,GAAA/G,OAAA,cAsQYD,qBAAqB","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