@pie-lib/config-ui 13.0.4-next.3 → 13.0.4-next.31

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/dist/_virtual/_rolldown/runtime.js +11 -0
  2. package/dist/alert-dialog.d.ts +44 -0
  3. package/dist/alert-dialog.js +47 -0
  4. package/dist/checkbox.d.ts +34 -0
  5. package/dist/checkbox.js +57 -0
  6. package/dist/choice-configuration/feedback-menu.d.ts +32 -0
  7. package/dist/choice-configuration/feedback-menu.js +85 -0
  8. package/dist/choice-configuration/index.d.ts +62 -0
  9. package/dist/choice-configuration/index.js +240 -0
  10. package/dist/choice-utils.d.ts +21 -0
  11. package/dist/choice-utils.js +15 -0
  12. package/dist/feedback-config/feedback-selector.d.ts +33 -0
  13. package/dist/feedback-config/feedback-selector.js +92 -0
  14. package/dist/feedback-config/group.d.ts +21 -0
  15. package/dist/feedback-config/group.js +33 -0
  16. package/dist/feedback-config/index.d.ts +48 -0
  17. package/dist/feedback-config/index.js +96 -0
  18. package/dist/form-section.d.ts +25 -0
  19. package/dist/form-section.js +25 -0
  20. package/dist/fraction-to-number.d.ts +7 -0
  21. package/dist/fraction-to-number.js +9 -0
  22. package/dist/help.d.ts +41 -0
  23. package/dist/help.js +61 -0
  24. package/dist/index.d.ts +31 -0
  25. package/dist/index.js +34 -0
  26. package/dist/input.d.ts +29 -0
  27. package/dist/input.js +65 -0
  28. package/dist/inputs.d.ts +63 -0
  29. package/dist/inputs.js +70 -0
  30. package/dist/langs.d.ts +41 -0
  31. package/dist/langs.js +76 -0
  32. package/dist/layout/config-layout.d.ts +10 -0
  33. package/dist/layout/config-layout.js +75 -0
  34. package/dist/layout/index.d.ts +11 -0
  35. package/dist/layout/index.js +10 -0
  36. package/dist/layout/layout-contents.d.ts +21 -0
  37. package/dist/layout/layout-contents.js +70 -0
  38. package/dist/layout/settings-box.d.ts +19 -0
  39. package/dist/layout/settings-box.js +31 -0
  40. package/dist/mui-box/index.d.ts +21 -0
  41. package/dist/mui-box/index.js +47 -0
  42. package/dist/node_modules/.bun/@babel_runtime@7.28.6/node_modules/@babel/runtime/helpers/esm/extends.js +12 -0
  43. package/dist/node_modules/.bun/@babel_runtime@7.28.6/node_modules/@babel/runtime/helpers/esm/inheritsLoose.js +7 -0
  44. package/dist/node_modules/.bun/@babel_runtime@7.28.6/node_modules/@babel/runtime/helpers/esm/objectWithoutPropertiesLoose.js +12 -0
  45. package/dist/node_modules/.bun/@babel_runtime@7.28.6/node_modules/@babel/runtime/helpers/esm/setPrototypeOf.js +8 -0
  46. package/dist/node_modules/.bun/react-measure@2.5.2_6dbf9a050bc9aadb/node_modules/react-measure/dist/index.esm.js +122 -0
  47. package/dist/node_modules/.bun/resize-observer-polyfill@1.5.1/node_modules/resize-observer-polyfill/dist/ResizeObserver.es.js +276 -0
  48. package/dist/number-text-field-custom.d.ts +51 -0
  49. package/dist/number-text-field-custom.js +192 -0
  50. package/dist/number-text-field.d.ts +47 -0
  51. package/dist/number-text-field.js +122 -0
  52. package/dist/radio-with-label.d.ts +25 -0
  53. package/dist/radio-with-label.js +27 -0
  54. package/dist/settings/display-size.d.ts +26 -0
  55. package/dist/settings/display-size.js +45 -0
  56. package/dist/settings/index.d.ts +45 -0
  57. package/dist/settings/index.js +63 -0
  58. package/dist/settings/panel.d.ts +27 -0
  59. package/dist/settings/panel.js +201 -0
  60. package/dist/settings/settings-radio-label.d.ts +25 -0
  61. package/dist/settings/settings-radio-label.js +29 -0
  62. package/dist/settings/toggle.d.ts +25 -0
  63. package/dist/settings/toggle.js +33 -0
  64. package/dist/tabs/index.d.ts +22 -0
  65. package/dist/tabs/index.js +39 -0
  66. package/dist/tags-input/index.d.ts +21 -0
  67. package/dist/tags-input/index.js +83 -0
  68. package/dist/two-choice.d.ts +43 -0
  69. package/dist/two-choice.js +79 -0
  70. package/dist/with-stateful-model.d.ts +42 -0
  71. package/dist/with-stateful-model.js +32 -0
  72. package/package.json +33 -19
  73. package/CHANGELOG.json +0 -32
  74. package/CHANGELOG.md +0 -2419
  75. package/LICENSE.md +0 -5
  76. package/lib/alert-dialog.js +0 -68
  77. package/lib/alert-dialog.js.map +0 -1
  78. package/lib/checkbox.js +0 -84
  79. package/lib/checkbox.js.map +0 -1
  80. package/lib/choice-configuration/feedback-menu.js +0 -129
  81. package/lib/choice-configuration/feedback-menu.js.map +0 -1
  82. package/lib/choice-configuration/index.js +0 -381
  83. package/lib/choice-configuration/index.js.map +0 -1
  84. package/lib/choice-utils.js +0 -42
  85. package/lib/choice-utils.js.map +0 -1
  86. package/lib/feedback-config/feedback-selector.js +0 -155
  87. package/lib/feedback-config/feedback-selector.js.map +0 -1
  88. package/lib/feedback-config/group.js +0 -61
  89. package/lib/feedback-config/group.js.map +0 -1
  90. package/lib/feedback-config/index.js +0 -146
  91. package/lib/feedback-config/index.js.map +0 -1
  92. package/lib/form-section.js +0 -44
  93. package/lib/form-section.js.map +0 -1
  94. package/lib/help.js +0 -106
  95. package/lib/help.js.map +0 -1
  96. package/lib/index.js +0 -186
  97. package/lib/index.js.map +0 -1
  98. package/lib/input.js +0 -106
  99. package/lib/input.js.map +0 -1
  100. package/lib/inputs.js +0 -105
  101. package/lib/inputs.js.map +0 -1
  102. package/lib/langs.js +0 -136
  103. package/lib/langs.js.map +0 -1
  104. package/lib/layout/config-layout.js +0 -137
  105. package/lib/layout/config-layout.js.map +0 -1
  106. package/lib/layout/index.js +0 -21
  107. package/lib/layout/index.js.map +0 -1
  108. package/lib/layout/layout-contents.js +0 -160
  109. package/lib/layout/layout-contents.js.map +0 -1
  110. package/lib/layout/settings-box.js +0 -57
  111. package/lib/layout/settings-box.js.map +0 -1
  112. package/lib/mui-box/index.js +0 -63
  113. package/lib/mui-box/index.js.map +0 -1
  114. package/lib/number-text-field-custom.js +0 -376
  115. package/lib/number-text-field-custom.js.map +0 -1
  116. package/lib/number-text-field.js +0 -229
  117. package/lib/number-text-field.js.map +0 -1
  118. package/lib/radio-with-label.js +0 -48
  119. package/lib/radio-with-label.js.map +0 -1
  120. package/lib/settings/display-size.js +0 -61
  121. package/lib/settings/display-size.js.map +0 -1
  122. package/lib/settings/index.js +0 -110
  123. package/lib/settings/index.js.map +0 -1
  124. package/lib/settings/panel.js +0 -392
  125. package/lib/settings/panel.js.map +0 -1
  126. package/lib/settings/settings-radio-label.js +0 -51
  127. package/lib/settings/settings-radio-label.js.map +0 -1
  128. package/lib/settings/toggle.js +0 -63
  129. package/lib/settings/toggle.js.map +0 -1
  130. package/lib/tabs/index.js +0 -75
  131. package/lib/tabs/index.js.map +0 -1
  132. package/lib/tags-input/index.js +0 -149
  133. package/lib/tags-input/index.js.map +0 -1
  134. package/lib/two-choice.js +0 -136
  135. package/lib/two-choice.js.map +0 -1
  136. package/lib/with-stateful-model.js +0 -61
  137. package/lib/with-stateful-model.js.map +0 -1
  138. package/src/__tests__/alert-dialog.test.jsx +0 -183
  139. package/src/__tests__/checkbox.test.jsx +0 -152
  140. package/src/__tests__/choice-utils.test.js +0 -12
  141. package/src/__tests__/form-section.test.jsx +0 -328
  142. package/src/__tests__/help.test.jsx +0 -184
  143. package/src/__tests__/input.test.jsx +0 -156
  144. package/src/__tests__/langs.test.jsx +0 -376
  145. package/src/__tests__/number-text-field-custom.test.jsx +0 -255
  146. package/src/__tests__/number-text-field.test.jsx +0 -263
  147. package/src/__tests__/radio-with-label.test.jsx +0 -155
  148. package/src/__tests__/settings-panel.test.js +0 -187
  149. package/src/__tests__/settings.test.jsx +0 -452
  150. package/src/__tests__/tabs.test.jsx +0 -188
  151. package/src/__tests__/two-choice.test.js +0 -110
  152. package/src/__tests__/with-stateful-model.test.jsx +0 -139
  153. package/src/alert-dialog.jsx +0 -75
  154. package/src/checkbox.jsx +0 -61
  155. package/src/choice-configuration/__tests__/feedback-menu.test.jsx +0 -151
  156. package/src/choice-configuration/__tests__/index.test.jsx +0 -234
  157. package/src/choice-configuration/feedback-menu.jsx +0 -96
  158. package/src/choice-configuration/index.jsx +0 -357
  159. package/src/choice-utils.js +0 -30
  160. package/src/feedback-config/__tests__/feedback-config.test.jsx +0 -141
  161. package/src/feedback-config/__tests__/feedback-selector.test.jsx +0 -97
  162. package/src/feedback-config/feedback-selector.jsx +0 -112
  163. package/src/feedback-config/group.jsx +0 -51
  164. package/src/feedback-config/index.jsx +0 -111
  165. package/src/form-section.jsx +0 -31
  166. package/src/help.jsx +0 -79
  167. package/src/index.js +0 -55
  168. package/src/input.jsx +0 -72
  169. package/src/inputs.jsx +0 -69
  170. package/src/langs.jsx +0 -111
  171. package/src/layout/__tests__/config.layout.test.jsx +0 -59
  172. package/src/layout/__tests__/layout-content.test.jsx +0 -3
  173. package/src/layout/config-layout.jsx +0 -103
  174. package/src/layout/index.js +0 -4
  175. package/src/layout/layout-contents.jsx +0 -117
  176. package/src/layout/settings-box.jsx +0 -32
  177. package/src/mui-box/index.jsx +0 -56
  178. package/src/number-text-field-custom.jsx +0 -333
  179. package/src/number-text-field.jsx +0 -215
  180. package/src/radio-with-label.jsx +0 -30
  181. package/src/settings/display-size.jsx +0 -53
  182. package/src/settings/index.js +0 -83
  183. package/src/settings/panel.jsx +0 -333
  184. package/src/settings/settings-radio-label.jsx +0 -32
  185. package/src/settings/toggle.jsx +0 -46
  186. package/src/tabs/index.jsx +0 -47
  187. package/src/tags-input/__tests__/index.test.jsx +0 -113
  188. package/src/tags-input/index.jsx +0 -116
  189. package/src/two-choice.jsx +0 -90
  190. 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":[]}
@@ -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