@pie-lib/config-ui 12.0.0-beta.4 → 12.0.0-beta.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +221 -80
- package/lib/alert-dialog.js +5 -11
- package/lib/alert-dialog.js.map +1 -1
- package/lib/checkbox.js +8 -20
- package/lib/checkbox.js.map +1 -1
- package/lib/choice-configuration/feedback-menu.js +6 -39
- package/lib/choice-configuration/feedback-menu.js.map +1 -1
- package/lib/choice-configuration/index.js +96 -106
- package/lib/choice-configuration/index.js.map +1 -1
- package/lib/choice-utils.js +2 -12
- package/lib/choice-utils.js.map +1 -1
- package/lib/feedback-config/feedback-selector.js +25 -47
- package/lib/feedback-config/feedback-selector.js.map +1 -1
- package/lib/feedback-config/group.js +8 -19
- package/lib/feedback-config/group.js.map +1 -1
- package/lib/feedback-config/index.js +21 -50
- package/lib/feedback-config/index.js.map +1 -1
- package/lib/form-section.js +5 -13
- package/lib/form-section.js.map +1 -1
- package/lib/help.js +14 -43
- package/lib/help.js.map +1 -1
- package/lib/index.js +1 -30
- package/lib/index.js.map +1 -1
- package/lib/input.js +12 -40
- package/lib/input.js.map +1 -1
- package/lib/inputs.js +28 -45
- package/lib/inputs.js.map +1 -1
- package/lib/langs.js +11 -40
- package/lib/langs.js.map +1 -1
- package/lib/layout/config-layout.js +42 -45
- package/lib/layout/config-layout.js.map +1 -1
- package/lib/layout/index.js +1 -4
- package/lib/layout/index.js.map +1 -1
- package/lib/layout/layout-contents.js +101 -44
- package/lib/layout/layout-contents.js.map +1 -1
- package/lib/layout/settings-box.js +8 -30
- package/lib/layout/settings-box.js.map +1 -1
- package/lib/mui-box/index.js +4 -11
- package/lib/mui-box/index.js.map +1 -1
- package/lib/number-text-field-custom.js +34 -84
- package/lib/number-text-field-custom.js.map +1 -1
- package/lib/number-text-field.js +29 -72
- package/lib/number-text-field.js.map +1 -1
- package/lib/radio-with-label.js +5 -12
- package/lib/radio-with-label.js.map +1 -1
- package/lib/settings/display-size.js +4 -16
- package/lib/settings/display-size.js.map +1 -1
- package/lib/settings/index.js +15 -29
- package/lib/settings/index.js.map +1 -1
- package/lib/settings/panel.js +142 -160
- package/lib/settings/panel.js.map +1 -1
- package/lib/settings/settings-radio-label.js +14 -19
- package/lib/settings/settings-radio-label.js.map +1 -1
- package/lib/settings/toggle.js +5 -12
- package/lib/settings/toggle.js.map +1 -1
- package/lib/tabs/index.js +10 -29
- package/lib/tabs/index.js.map +1 -1
- package/lib/tags-input/index.js +7 -44
- package/lib/tags-input/index.js.map +1 -1
- package/lib/two-choice.js +15 -49
- package/lib/two-choice.js.map +1 -1
- package/lib/with-stateful-model.js +3 -22
- package/lib/with-stateful-model.js.map +1 -1
- package/package.json +4 -4
- package/src/alert-dialog.jsx +2 -9
- package/src/checkbox.jsx +10 -10
- package/src/choice-configuration/feedback-menu.jsx +10 -23
- package/src/choice-configuration/index.jsx +88 -53
- package/src/choice-utils.js +1 -1
- package/src/feedback-config/feedback-selector.jsx +29 -23
- package/src/feedback-config/group.jsx +10 -12
- package/src/feedback-config/index.jsx +49 -35
- package/src/form-section.jsx +4 -4
- package/src/help.jsx +14 -15
- package/src/index.js +2 -5
- package/src/input.jsx +8 -8
- package/src/inputs.jsx +15 -20
- package/src/langs.jsx +28 -39
- package/src/layout/config-layout.jsx +26 -23
- package/src/layout/layout-contents.jsx +81 -22
- package/src/layout/settings-box.jsx +12 -8
- package/src/mui-box/index.jsx +9 -9
- package/src/number-text-field-custom.jsx +28 -25
- package/src/number-text-field.jsx +17 -12
- package/src/radio-with-label.jsx +2 -2
- package/src/settings/display-size.jsx +5 -5
- package/src/settings/index.js +18 -11
- package/src/settings/panel.jsx +89 -61
- package/src/settings/settings-radio-label.jsx +5 -5
- package/src/settings/toggle.jsx +7 -7
- package/src/tabs/index.jsx +11 -15
- package/src/tags-input/index.jsx +17 -19
- package/src/two-choice.jsx +8 -8
- package/src/with-stateful-model.jsx +5 -5
package/lib/number-text-field.js
CHANGED
|
@@ -1,92 +1,68 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
|
|
5
4
|
Object.defineProperty(exports, "__esModule", {
|
|
6
5
|
value: true
|
|
7
6
|
});
|
|
8
7
|
exports["default"] = exports.NumberTextField = void 0;
|
|
9
|
-
|
|
10
8
|
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
|
|
11
|
-
|
|
12
9
|
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
|
|
13
|
-
|
|
14
10
|
var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
|
|
15
|
-
|
|
16
11
|
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
|
|
17
|
-
|
|
18
12
|
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
|
|
19
|
-
|
|
20
13
|
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
|
|
21
|
-
|
|
22
14
|
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
23
|
-
|
|
24
15
|
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
25
|
-
|
|
26
16
|
var _react = _interopRequireDefault(require("react"));
|
|
27
|
-
|
|
28
17
|
var _TextField = _interopRequireDefault(require("@material-ui/core/TextField"));
|
|
29
|
-
|
|
30
18
|
var _classnames = _interopRequireDefault(require("classnames"));
|
|
31
|
-
|
|
32
19
|
var _styles = require("@material-ui/core/styles");
|
|
33
|
-
|
|
34
20
|
var _debug = _interopRequireDefault(require("debug"));
|
|
35
|
-
|
|
36
21
|
var _isFinite = _interopRequireDefault(require("lodash/isFinite"));
|
|
37
|
-
|
|
38
22
|
var _InputAdornment = _interopRequireDefault(require("@material-ui/core/InputAdornment"));
|
|
39
|
-
|
|
40
23
|
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; }
|
|
41
|
-
|
|
42
24
|
function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
|
|
43
|
-
|
|
44
25
|
var log = (0, _debug["default"])('@pie-lib:config-ui:number-text-field');
|
|
45
|
-
|
|
46
26
|
var styles = function styles(theme) {
|
|
47
27
|
return {
|
|
48
28
|
root: {
|
|
49
|
-
marginRight: theme.spacing.unit
|
|
29
|
+
marginRight: theme.spacing.unit,
|
|
30
|
+
'& label': {
|
|
31
|
+
width: 'max-content'
|
|
32
|
+
}
|
|
50
33
|
}
|
|
51
34
|
};
|
|
52
35
|
};
|
|
53
|
-
|
|
54
36
|
var fallbackNumber = function fallbackNumber(min, max) {
|
|
55
37
|
if (!(0, _isFinite["default"])(min) && !(0, _isFinite["default"])(max)) {
|
|
56
38
|
return 0;
|
|
57
39
|
}
|
|
58
|
-
|
|
59
40
|
if (!(0, _isFinite["default"])(min) && (0, _isFinite["default"])(max)) {
|
|
60
41
|
return max;
|
|
61
42
|
}
|
|
62
|
-
|
|
63
43
|
if ((0, _isFinite["default"])(min)) {
|
|
64
44
|
return min;
|
|
65
45
|
}
|
|
66
46
|
};
|
|
67
|
-
|
|
68
47
|
var NumberTextField = /*#__PURE__*/function (_React$Component) {
|
|
69
48
|
(0, _inherits2["default"])(NumberTextField, _React$Component);
|
|
70
|
-
|
|
71
49
|
var _super = _createSuper(NumberTextField);
|
|
72
|
-
|
|
73
50
|
function NumberTextField(props) {
|
|
74
51
|
var _this;
|
|
75
|
-
|
|
76
52
|
(0, _classCallCheck2["default"])(this, NumberTextField);
|
|
77
53
|
_this = _super.call(this, props);
|
|
54
|
+
/**
|
|
55
|
+
* on Blur (this can be triggered by pressing Enter, see below)
|
|
56
|
+
* we check the entered value and reset it if needed
|
|
57
|
+
*/
|
|
78
58
|
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onBlur", function (event) {
|
|
79
59
|
var value = event.target.value;
|
|
80
60
|
var rawNumber = parseFloat(value);
|
|
81
61
|
log('rawNumber: ', rawNumber);
|
|
82
|
-
|
|
83
62
|
var number = _this.clamp(rawNumber);
|
|
84
|
-
|
|
85
63
|
log('number: ', number);
|
|
86
|
-
|
|
87
64
|
if (number !== _this.state.value) {
|
|
88
65
|
log('trigger update...');
|
|
89
|
-
|
|
90
66
|
_this.setState({
|
|
91
67
|
value: number.toString()
|
|
92
68
|
}, function () {
|
|
@@ -96,47 +72,41 @@ var NumberTextField = /*#__PURE__*/function (_React$Component) {
|
|
|
96
72
|
});
|
|
97
73
|
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "errorMessage", function () {
|
|
98
74
|
var _this$props = _this.props,
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
75
|
+
min = _this$props.min,
|
|
76
|
+
max = _this$props.max;
|
|
102
77
|
if (min && max) {
|
|
103
78
|
return "The value must be between ".concat(min, " and ").concat(max);
|
|
104
79
|
}
|
|
105
|
-
|
|
106
80
|
if (min) {
|
|
107
81
|
return "The value must be greater than ".concat(min);
|
|
108
82
|
}
|
|
109
|
-
|
|
110
83
|
if (max) {
|
|
111
84
|
return "The value must be less than ".concat(max);
|
|
112
85
|
}
|
|
113
86
|
});
|
|
87
|
+
/**
|
|
88
|
+
* if the input has to show error when outside range,
|
|
89
|
+
* and the entered value is not matching the requirements
|
|
90
|
+
* we display error message
|
|
91
|
+
*/
|
|
114
92
|
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "getError", function () {
|
|
115
93
|
var value = _this.state.value;
|
|
116
|
-
|
|
117
94
|
var _float = parseFloat(value);
|
|
118
|
-
|
|
119
95
|
var clamped = _this.clamp(_float);
|
|
120
|
-
|
|
121
96
|
if (clamped !== _float) {
|
|
122
97
|
return _this.errorMessage();
|
|
123
98
|
}
|
|
124
99
|
});
|
|
125
|
-
|
|
126
100
|
var _value = _this.clamp(props.value);
|
|
127
|
-
|
|
128
101
|
_this.state = {
|
|
129
102
|
value: _value
|
|
130
103
|
};
|
|
131
|
-
|
|
132
104
|
if (_value !== props.value) {
|
|
133
105
|
_this.props.onChange({}, _value);
|
|
134
106
|
}
|
|
135
|
-
|
|
136
107
|
_this.onChange = _this.onChange.bind((0, _assertThisInitialized2["default"])(_this));
|
|
137
108
|
return _this;
|
|
138
109
|
}
|
|
139
|
-
|
|
140
110
|
(0, _createClass2["default"])(NumberTextField, [{
|
|
141
111
|
key: "UNSAFE_componentWillReceiveProps",
|
|
142
112
|
value: function UNSAFE_componentWillReceiveProps(props) {
|
|
@@ -151,26 +121,17 @@ var NumberTextField = /*#__PURE__*/function (_React$Component) {
|
|
|
151
121
|
if (!(0, _isFinite["default"])(value)) {
|
|
152
122
|
return fallbackNumber(this.props.min, this.props.max);
|
|
153
123
|
}
|
|
154
|
-
|
|
155
124
|
var _this$props2 = this.props,
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
125
|
+
min = _this$props2.min,
|
|
126
|
+
max = _this$props2.max;
|
|
159
127
|
if ((0, _isFinite["default"])(max)) {
|
|
160
128
|
value = Math.min(value, max);
|
|
161
129
|
}
|
|
162
|
-
|
|
163
130
|
if ((0, _isFinite["default"])(min)) {
|
|
164
131
|
value = Math.max(value, min);
|
|
165
132
|
}
|
|
166
|
-
|
|
167
133
|
return value;
|
|
168
134
|
}
|
|
169
|
-
/**
|
|
170
|
-
* on Blur (this can be triggered by pressing Enter, see below)
|
|
171
|
-
* we check the entered value and reset it if needed
|
|
172
|
-
*/
|
|
173
|
-
|
|
174
135
|
}, {
|
|
175
136
|
key: "onChange",
|
|
176
137
|
value: function onChange(event) {
|
|
@@ -183,19 +144,18 @@ var NumberTextField = /*#__PURE__*/function (_React$Component) {
|
|
|
183
144
|
key: "render",
|
|
184
145
|
value: function render() {
|
|
185
146
|
var _this2 = this;
|
|
186
|
-
|
|
187
147
|
var _this$props3 = this.props,
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
148
|
+
className = _this$props3.className,
|
|
149
|
+
classes = _this$props3.classes,
|
|
150
|
+
label = _this$props3.label,
|
|
151
|
+
disabled = _this$props3.disabled,
|
|
152
|
+
suffix = _this$props3.suffix,
|
|
153
|
+
min = _this$props3.min,
|
|
154
|
+
max = _this$props3.max,
|
|
155
|
+
inputClassName = _this$props3.inputClassName,
|
|
156
|
+
disableUnderline = _this$props3.disableUnderline,
|
|
157
|
+
showErrorWhenOutsideRange = _this$props3.showErrorWhenOutsideRange,
|
|
158
|
+
variant = _this$props3.variant;
|
|
199
159
|
var names = (0, _classnames["default"])(classes.root, className);
|
|
200
160
|
var error = showErrorWhenOutsideRange && this.getError();
|
|
201
161
|
return /*#__PURE__*/_react["default"].createElement(_TextField["default"], {
|
|
@@ -238,7 +198,6 @@ var NumberTextField = /*#__PURE__*/function (_React$Component) {
|
|
|
238
198
|
}]);
|
|
239
199
|
return NumberTextField;
|
|
240
200
|
}(_react["default"].Component);
|
|
241
|
-
|
|
242
201
|
exports.NumberTextField = NumberTextField;
|
|
243
202
|
(0, _defineProperty2["default"])(NumberTextField, "propTypes", {
|
|
244
203
|
disabled: _propTypes["default"].bool,
|
|
@@ -258,8 +217,6 @@ exports.NumberTextField = NumberTextField;
|
|
|
258
217
|
(0, _defineProperty2["default"])(NumberTextField, "defaultProps", {
|
|
259
218
|
showErrorWhenOutsideRange: false
|
|
260
219
|
});
|
|
261
|
-
|
|
262
220
|
var _default = (0, _styles.withStyles)(styles)(NumberTextField);
|
|
263
|
-
|
|
264
221
|
exports["default"] = _default;
|
|
265
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["log","debug","styles","theme","root","marginRight","spacing","unit","fallbackNumber","min","max","isFinite","NumberTextField","props","event","value","target","rawNumber","parseFloat","number","clamp","state","setState","toString","onChange","float","clamped","errorMessage","bind","Math","className","classes","label","disabled","suffix","inputClassName","disableUnderline","showErrorWhenOutsideRange","variant","names","classNames","error","getError","ref","inputRef","onBlur","e","key","blur","shrink","endAdornment","React","Component","PropTypes","bool","object","isRequired","string","func","withStyles"],"sources":["../src/number-text-field.jsx"],"sourcesContent":["import PropTypes from 'prop-types';\nimport React from 'react';\nimport TextField from '@material-ui/core/TextField';\nimport classNames from 'classnames';\nimport { withStyles } from '@material-ui/core/styles';\nimport debug from 'debug';\nimport isFinite from 'lodash/isFinite';\nimport InputAdornment from '@material-ui/core/InputAdornment';\nconst log = debug('@pie-lib:config-ui:number-text-field');\n\nconst styles = theme => ({\n  root: { marginRight: theme.spacing.unit }\n});\n\nconst fallbackNumber = (min, max) => {\n  if (!isFinite(min) && !isFinite(max)) {\n    return 0;\n  }\n  if (!isFinite(min) && isFinite(max)) {\n    return max;\n  }\n\n  if (isFinite(min)) {\n    return min;\n  }\n};\n\nexport class NumberTextField extends React.Component {\n  static propTypes = {\n    disabled: PropTypes.bool,\n    classes: PropTypes.object.isRequired,\n    className: PropTypes.string,\n    inputClassName: PropTypes.string,\n    onChange: PropTypes.func.isRequired,\n    value: PropTypes.number,\n    min: PropTypes.number,\n    max: PropTypes.number,\n    label: PropTypes.string,\n    suffix: PropTypes.string,\n    showErrorWhenOutsideRange: PropTypes.bool,\n    disableUnderline: PropTypes.bool,\n    variant: PropTypes.string\n  };\n\n  static defaultProps = {\n    showErrorWhenOutsideRange: false\n  };\n\n  constructor(props) {\n    super(props);\n\n    const value = this.clamp(props.value);\n\n    this.state = {\n      value\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 = this.clamp(props.value);\n    this.setState({ value });\n  }\n\n  clamp(value) {\n    if (!isFinite(value)) {\n      return fallbackNumber(this.props.min, this.props.max);\n    }\n\n    const { min, max } = this.props;\n\n    if (isFinite(max)) {\n      value = Math.min(value, max);\n    }\n    if (isFinite(min)) {\n      value = Math.max(value, min);\n    }\n    return value;\n  }\n\n  /**\n   * on Blur (this can be triggered by pressing Enter, see below)\n   * we check the entered value and reset it if needed\n   */\n  onBlur = event => {\n    const value = event.target.value;\n\n    const rawNumber = parseFloat(value);\n    log('rawNumber: ', rawNumber);\n\n    const number = this.clamp(rawNumber);\n    log('number: ', number);\n\n    if (number !== this.state.value) {\n      log('trigger update...');\n      this.setState({ value: number.toString() }, () => {\n        this.props.onChange(event, number);\n      });\n    }\n  };\n\n  onChange(event) {\n    const value = event.target.value;\n    this.setState({ value });\n  }\n\n  errorMessage = () => {\n    const { min, max } = this.props;\n    if (min && max) {\n      return `The value must be between ${min} and ${max}`;\n    }\n    if (min) {\n      return `The value must be greater than ${min}`;\n    }\n    if (max) {\n      return `The value must be less than ${max}`;\n    }\n  };\n\n  /**\n   * if the input has to show error when outside range,\n   * and the entered value is not matching the requirements\n   * we display error message\n   */\n\n  getError = () => {\n    const { value } = this.state;\n    const float = parseFloat(value);\n    const clamped = this.clamp(float);\n    if (clamped !== float) {\n      return this.errorMessage();\n    }\n  };\n\n  render() {\n    const {\n      className,\n      classes,\n      label,\n      disabled,\n      suffix,\n      min,\n      max,\n      inputClassName,\n      disableUnderline,\n      showErrorWhenOutsideRange,\n      variant\n    } = this.props;\n    const names = classNames(classes.root, className);\n\n    const error = showErrorWhenOutsideRange && this.getError();\n    return (\n      <TextField\n        variant={variant || 'standard'}\n        inputRef={ref => {\n          this.inputRef = ref;\n        }}\n        disabled={disabled}\n        label={label}\n        value={this.state.value}\n        error={!!error}\n        helperText={error}\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        type=\"number\"\n        className={names}\n        InputLabelProps={{\n          shrink: true\n        }}\n        InputProps={{\n          endAdornment: suffix && <InputAdornment position=\"end\">{suffix}</InputAdornment>,\n          className: inputClassName,\n          disableUnderline: disableUnderline\n        }}\n        inputProps={{\n          min,\n          max\n        }}\n        margin=\"normal\"\n      />\n    );\n  }\n}\n\nexport default withStyles(styles)(NumberTextField);\n"],"mappings":"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"}
|
|
222
|
+
//# sourceMappingURL=number-text-field.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"number-text-field.js","names":["log","debug","styles","theme","root","marginRight","spacing","unit","fallbackNumber","min","max","isFinite","NumberTextField","props","event","value","target","rawNumber","parseFloat","number","clamp","state","setState","toString","onChange","float","clamped","errorMessage","bind","Math","className","classes","label","disabled","suffix","inputClassName","disableUnderline","showErrorWhenOutsideRange","variant","names","classNames","error","getError","ref","inputRef","onBlur","e","key","blur","shrink","endAdornment","React","Component","PropTypes","bool","object","isRequired","string","func","withStyles"],"sources":["../src/number-text-field.jsx"],"sourcesContent":["import PropTypes from 'prop-types';\nimport React from 'react';\nimport TextField from '@material-ui/core/TextField';\nimport classNames from 'classnames';\nimport { withStyles } from '@material-ui/core/styles';\nimport debug from 'debug';\nimport isFinite from 'lodash/isFinite';\nimport InputAdornment from '@material-ui/core/InputAdornment';\nconst log = debug('@pie-lib:config-ui:number-text-field');\n\nconst styles = theme => ({\n root: { marginRight: theme.spacing.unit }\n});\n\nconst fallbackNumber = (min, max) => {\n if (!isFinite(min) && !isFinite(max)) {\n return 0;\n }\n if (!isFinite(min) && isFinite(max)) {\n return max;\n }\n\n if (isFinite(min)) {\n return min;\n }\n};\n\nexport class NumberTextField extends React.Component {\n static propTypes = {\n disabled: PropTypes.bool,\n classes: PropTypes.object.isRequired,\n className: PropTypes.string,\n inputClassName: PropTypes.string,\n onChange: PropTypes.func.isRequired,\n value: PropTypes.number,\n min: PropTypes.number,\n max: PropTypes.number,\n label: PropTypes.string,\n suffix: PropTypes.string,\n showErrorWhenOutsideRange: PropTypes.bool,\n disableUnderline: PropTypes.bool,\n variant: PropTypes.string\n };\n\n static defaultProps = {\n showErrorWhenOutsideRange: false\n };\n\n constructor(props) {\n super(props);\n\n const value = this.clamp(props.value);\n\n this.state = {\n value\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 = this.clamp(props.value);\n this.setState({ value });\n }\n\n clamp(value) {\n if (!isFinite(value)) {\n return fallbackNumber(this.props.min, this.props.max);\n }\n\n const { min, max } = this.props;\n\n if (isFinite(max)) {\n value = Math.min(value, max);\n }\n if (isFinite(min)) {\n value = Math.max(value, min);\n }\n return value;\n }\n\n /**\n * on Blur (this can be triggered by pressing Enter, see below)\n * we check the entered value and reset it if needed\n */\n onBlur = event => {\n const value = event.target.value;\n\n const rawNumber = parseFloat(value);\n log('rawNumber: ', rawNumber);\n\n const number = this.clamp(rawNumber);\n log('number: ', number);\n\n if (number !== this.state.value) {\n log('trigger update...');\n this.setState({ value: number.toString() }, () => {\n this.props.onChange(event, number);\n });\n }\n };\n\n onChange(event) {\n const value = event.target.value;\n this.setState({ value });\n }\n\n errorMessage = () => {\n const { min, max } = this.props;\n if (min && max) {\n return `The value must be between ${min} and ${max}`;\n }\n if (min) {\n return `The value must be greater than ${min}`;\n }\n if (max) {\n return `The value must be less than ${max}`;\n }\n };\n\n /**\n * if the input has to show error when outside range,\n * and the entered value is not matching the requirements\n * we display error message\n */\n\n getError = () => {\n const { value } = this.state;\n const float = parseFloat(value);\n const clamped = this.clamp(float);\n if (clamped !== float) {\n return this.errorMessage();\n }\n };\n\n render() {\n const {\n className,\n classes,\n label,\n disabled,\n suffix,\n min,\n max,\n inputClassName,\n disableUnderline,\n showErrorWhenOutsideRange,\n variant\n } = this.props;\n const names = classNames(classes.root, className);\n\n const error = showErrorWhenOutsideRange && this.getError();\n return (\n <TextField\n variant={variant || 'standard'}\n inputRef={ref => {\n this.inputRef = ref;\n }}\n disabled={disabled}\n label={label}\n value={this.state.value}\n error={!!error}\n helperText={error}\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 type=\"number\"\n className={names}\n InputLabelProps={{\n shrink: true\n }}\n InputProps={{\n endAdornment: suffix && <InputAdornment position=\"end\">{suffix}</InputAdornment>,\n className: inputClassName,\n disableUnderline: disableUnderline\n }}\n inputProps={{\n min,\n max\n }}\n margin=\"normal\"\n />\n );\n }\n}\n\nexport default withStyles(styles)(NumberTextField);\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"number-text-field.js","names":["_propTypes","_interopRequireDefault","require","_react","_TextField","_classnames","_styles","_debug","_isFinite","_InputAdornment","_createSuper","Derived","hasNativeReflectConstruct","_isNativeReflectConstruct","_createSuperInternal","Super","_getPrototypeOf2","result","NewTarget","constructor","Reflect","construct","arguments","apply","_possibleConstructorReturn2","sham","Proxy","Boolean","prototype","valueOf","call","e","log","debug","styles","theme","root","marginRight","spacing","unit","width","fallbackNumber","min","max","isFinite","NumberTextField","_React$Component","_inherits2","_super","props","_this","_classCallCheck2","_defineProperty2","_assertThisInitialized2","event","value","target","rawNumber","parseFloat","number","clamp","state","setState","toString","onChange","_this$props","concat","float","clamped","errorMessage","bind","_createClass2","key","UNSAFE_componentWillReceiveProps","_this$props2","Math","render","_this2","_this$props3","className","classes","label","disabled","suffix","inputClassName","disableUnderline","showErrorWhenOutsideRange","variant","names","classNames","error","getError","createElement","inputRef","ref","helperText","onBlur","onKeyPress","blur","type","InputLabelProps","shrink","InputProps","endAdornment","position","inputProps","margin","React","Component","exports","PropTypes","bool","object","isRequired","string","func","_default","withStyles"],"sources":["../src/number-text-field.jsx"],"sourcesContent":["import PropTypes from 'prop-types';\nimport React from 'react';\nimport TextField from '@material-ui/core/TextField';\nimport classNames from 'classnames';\nimport { withStyles } from '@material-ui/core/styles';\nimport debug from 'debug';\nimport isFinite from 'lodash/isFinite';\nimport InputAdornment from '@material-ui/core/InputAdornment';\nconst log = debug('@pie-lib:config-ui:number-text-field');\n\nconst styles = (theme) => ({\n root: {\n marginRight: theme.spacing.unit,\n '& label': {\n width: 'max-content',\n },\n },\n});\n\nconst fallbackNumber = (min, max) => {\n if (!isFinite(min) && !isFinite(max)) {\n return 0;\n }\n if (!isFinite(min) && isFinite(max)) {\n return max;\n }\n\n if (isFinite(min)) {\n return min;\n }\n};\n\nexport class NumberTextField extends React.Component {\n static propTypes = {\n disabled: PropTypes.bool,\n classes: PropTypes.object.isRequired,\n className: PropTypes.string,\n inputClassName: PropTypes.string,\n onChange: PropTypes.func.isRequired,\n value: PropTypes.number,\n min: PropTypes.number,\n max: PropTypes.number,\n label: PropTypes.string,\n suffix: PropTypes.string,\n showErrorWhenOutsideRange: PropTypes.bool,\n disableUnderline: PropTypes.bool,\n variant: PropTypes.string,\n };\n\n static defaultProps = {\n showErrorWhenOutsideRange: false,\n };\n\n constructor(props) {\n super(props);\n\n const value = this.clamp(props.value);\n\n this.state = {\n value,\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 = this.clamp(props.value);\n this.setState({ value });\n }\n\n clamp(value) {\n if (!isFinite(value)) {\n return fallbackNumber(this.props.min, this.props.max);\n }\n\n const { min, max } = this.props;\n\n if (isFinite(max)) {\n value = Math.min(value, max);\n }\n if (isFinite(min)) {\n value = Math.max(value, min);\n }\n return value;\n }\n\n /**\n * on Blur (this can be triggered by pressing Enter, see below)\n * we check the entered value and reset it if needed\n */\n onBlur = (event) => {\n const value = event.target.value;\n\n const rawNumber = parseFloat(value);\n log('rawNumber: ', rawNumber);\n\n const number = this.clamp(rawNumber);\n log('number: ', number);\n\n if (number !== this.state.value) {\n log('trigger update...');\n this.setState({ value: number.toString() }, () => {\n this.props.onChange(event, number);\n });\n }\n };\n\n onChange(event) {\n const value = event.target.value;\n this.setState({ value });\n }\n\n errorMessage = () => {\n const { min, max } = this.props;\n if (min && max) {\n return `The value must be between ${min} and ${max}`;\n }\n if (min) {\n return `The value must be greater than ${min}`;\n }\n if (max) {\n return `The value must be less than ${max}`;\n }\n };\n\n /**\n * if the input has to show error when outside range,\n * and the entered value is not matching the requirements\n * we display error message\n */\n\n getError = () => {\n const { value } = this.state;\n const float = parseFloat(value);\n const clamped = this.clamp(float);\n if (clamped !== float) {\n return this.errorMessage();\n }\n };\n\n render() {\n const {\n className,\n classes,\n label,\n disabled,\n suffix,\n min,\n max,\n inputClassName,\n disableUnderline,\n showErrorWhenOutsideRange,\n variant,\n } = this.props;\n const names = classNames(classes.root, className);\n\n const error = showErrorWhenOutsideRange && this.getError();\n return (\n <TextField\n variant={variant || 'standard'}\n inputRef={(ref) => {\n this.inputRef = ref;\n }}\n disabled={disabled}\n label={label}\n value={this.state.value}\n error={!!error}\n helperText={error}\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 type=\"number\"\n className={names}\n InputLabelProps={{\n shrink: true,\n }}\n InputProps={{\n endAdornment: suffix && <InputAdornment position=\"end\">{suffix}</InputAdornment>,\n className: inputClassName,\n disableUnderline: disableUnderline,\n }}\n inputProps={{\n min,\n max,\n }}\n margin=\"normal\"\n />\n );\n }\n}\n\nexport default withStyles(styles)(NumberTextField);\n"],"mappings":"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"}
|
package/lib/radio-with-label.js
CHANGED
|
@@ -1,20 +1,14 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
|
|
5
4
|
Object.defineProperty(exports, "__esModule", {
|
|
6
5
|
value: true
|
|
7
6
|
});
|
|
8
7
|
exports["default"] = void 0;
|
|
9
|
-
|
|
10
8
|
var _FormControlLabel = _interopRequireDefault(require("@material-ui/core/FormControlLabel"));
|
|
11
|
-
|
|
12
9
|
var _Radio = _interopRequireDefault(require("@material-ui/core/Radio"));
|
|
13
|
-
|
|
14
10
|
var _react = _interopRequireDefault(require("react"));
|
|
15
|
-
|
|
16
11
|
var _styles = require("@material-ui/core/styles");
|
|
17
|
-
|
|
18
12
|
var _default = (0, _styles.withStyles)({
|
|
19
13
|
label: {
|
|
20
14
|
left: '-5px',
|
|
@@ -22,10 +16,10 @@ var _default = (0, _styles.withStyles)({
|
|
|
22
16
|
}
|
|
23
17
|
})(function (_ref) {
|
|
24
18
|
var label = _ref.label,
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
19
|
+
value = _ref.value,
|
|
20
|
+
checked = _ref.checked,
|
|
21
|
+
onChange = _ref.onChange,
|
|
22
|
+
classes = _ref.classes;
|
|
29
23
|
return /*#__PURE__*/_react["default"].createElement(_FormControlLabel["default"], {
|
|
30
24
|
value: value,
|
|
31
25
|
classes: classes,
|
|
@@ -36,6 +30,5 @@ var _default = (0, _styles.withStyles)({
|
|
|
36
30
|
label: label
|
|
37
31
|
});
|
|
38
32
|
});
|
|
39
|
-
|
|
40
33
|
exports["default"] = _default;
|
|
41
|
-
//# sourceMappingURL=
|
|
34
|
+
//# sourceMappingURL=radio-with-label.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"radio-with-label.js","names":["withStyles","label","left","position","value","checked","onChange","classes"],"sources":["../src/radio-with-label.jsx"],"sourcesContent":["import FormControlLabel from '@material-ui/core/FormControlLabel';\nimport Radio from '@material-ui/core/Radio';\nimport React from 'react';\nimport { withStyles } from '@material-ui/core/styles';\n\nexport default withStyles({\n label: {\n left: '-5px',\n position: 'relative'
|
|
1
|
+
{"version":3,"file":"radio-with-label.js","names":["_FormControlLabel","_interopRequireDefault","require","_Radio","_react","_styles","_default","withStyles","label","left","position","_ref","value","checked","onChange","classes","createElement","control","exports"],"sources":["../src/radio-with-label.jsx"],"sourcesContent":["import FormControlLabel from '@material-ui/core/FormControlLabel';\nimport Radio from '@material-ui/core/Radio';\nimport React from 'react';\nimport { withStyles } from '@material-ui/core/styles';\n\nexport default withStyles({\n label: {\n left: '-5px',\n position: 'relative',\n },\n})(({ label, value, checked, onChange, classes }) => (\n <FormControlLabel\n value={value}\n classes={classes}\n control={<Radio checked={checked} onChange={onChange} />}\n label={label}\n />\n));\n"],"mappings":";;;;;;;AAAA,IAAAA,iBAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,MAAA,GAAAF,sBAAA,CAAAC,OAAA;AACA,IAAAE,MAAA,GAAAH,sBAAA,CAAAC,OAAA;AACA,IAAAG,OAAA,GAAAH,OAAA;AAAsD,IAAAI,QAAA,GAEvC,IAAAC,kBAAU,EAAC;EACxBC,KAAK,EAAE;IACLC,IAAI,EAAE,MAAM;IACZC,QAAQ,EAAE;EACZ;AACF,CAAC,CAAC,CAAC,UAAAC,IAAA;EAAA,IAAGH,KAAK,GAAAG,IAAA,CAALH,KAAK;IAAEI,KAAK,GAAAD,IAAA,CAALC,KAAK;IAAEC,OAAO,GAAAF,IAAA,CAAPE,OAAO;IAAEC,QAAQ,GAAAH,IAAA,CAARG,QAAQ;IAAEC,OAAO,GAAAJ,IAAA,CAAPI,OAAO;EAAA,oBAC5CX,MAAA,YAAAY,aAAA,CAAChB,iBAAA,WAAgB;IACfY,KAAK,EAAEA,KAAM;IACbG,OAAO,EAAEA,OAAQ;IACjBE,OAAO,eAAEb,MAAA,YAAAY,aAAA,CAACb,MAAA,WAAK;MAACU,OAAO,EAAEA,OAAQ;MAACC,QAAQ,EAAEA;IAAS,CAAE,CAAE;IACzDN,KAAK,EAAEA;EAAM,CACd,CAAC;AAAA,CACH,CAAC;AAAAU,OAAA,cAAAZ,QAAA"}
|
|
@@ -1,28 +1,18 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
|
|
5
4
|
Object.defineProperty(exports, "__esModule", {
|
|
6
5
|
value: true
|
|
7
6
|
});
|
|
8
7
|
exports["default"] = void 0;
|
|
9
|
-
|
|
10
8
|
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
11
|
-
|
|
12
9
|
var _react = _interopRequireDefault(require("react"));
|
|
13
|
-
|
|
14
10
|
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
15
|
-
|
|
16
11
|
var _Typography = _interopRequireDefault(require("@material-ui/core/Typography"));
|
|
17
|
-
|
|
18
12
|
var _styles = require("@material-ui/core/styles");
|
|
19
|
-
|
|
20
13
|
var _numberTextField = _interopRequireDefault(require("../number-text-field"));
|
|
21
|
-
|
|
22
14
|
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
23
|
-
|
|
24
15
|
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
25
|
-
|
|
26
16
|
var DisplaySize = (0, _styles.withStyles)(function (theme) {
|
|
27
17
|
return {
|
|
28
18
|
displaySize: {
|
|
@@ -32,14 +22,12 @@ var DisplaySize = (0, _styles.withStyles)(function (theme) {
|
|
|
32
22
|
};
|
|
33
23
|
})(function (_ref) {
|
|
34
24
|
var size = _ref.size,
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
25
|
+
label = _ref.label,
|
|
26
|
+
classes = _ref.classes,
|
|
27
|
+
onChange = _ref.onChange;
|
|
39
28
|
var updateSize = function updateSize(key, v) {
|
|
40
29
|
onChange(_objectSpread(_objectSpread({}, size), {}, (0, _defineProperty2["default"])({}, key, v)));
|
|
41
30
|
};
|
|
42
|
-
|
|
43
31
|
return /*#__PURE__*/_react["default"].createElement("div", null, /*#__PURE__*/_react["default"].createElement(_Typography["default"], null, label), /*#__PURE__*/_react["default"].createElement("div", {
|
|
44
32
|
className: classes.displaySize
|
|
45
33
|
}, /*#__PURE__*/_react["default"].createElement(_numberTextField["default"], {
|
|
@@ -74,4 +62,4 @@ DisplaySize.propTypes = {
|
|
|
74
62
|
};
|
|
75
63
|
var _default = DisplaySize;
|
|
76
64
|
exports["default"] = _default;
|
|
77
|
-
//# sourceMappingURL=
|
|
65
|
+
//# sourceMappingURL=display-size.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"display-size.js","names":["DisplaySize","withStyles","theme","displaySize","display","paddingTop","spacing","unit","size","label","classes","onChange","updateSize","
|
|
1
|
+
{"version":3,"file":"display-size.js","names":["_react","_interopRequireDefault","require","_propTypes","_Typography","_styles","_numberTextField","ownKeys","object","enumerableOnly","keys","Object","getOwnPropertySymbols","symbols","filter","sym","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","key","_defineProperty2","getOwnPropertyDescriptors","defineProperties","defineProperty","DisplaySize","withStyles","theme","displaySize","display","paddingTop","spacing","unit","_ref","size","label","classes","onChange","updateSize","v","createElement","className","type","variant","value","width","min","max","e","height","propTypes","PropTypes","shape","number","isRequired","string","func","_default","exports"],"sources":["../../src/settings/display-size.jsx"],"sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport Typography from '@material-ui/core/Typography';\nimport { withStyles } from '@material-ui/core/styles';\nimport NumberTextField from '../number-text-field';\n\nconst DisplaySize = withStyles((theme) => ({\n displaySize: {\n display: 'flex',\n paddingTop: theme.spacing.unit,\n },\n}))(({ size, label, classes, onChange }) => {\n const updateSize = (key, v) => {\n onChange({ ...size, [key]: v });\n };\n return (\n <div>\n <Typography>{label}</Typography>\n <div className={classes.displaySize}>\n <NumberTextField\n label=\"Width\"\n type=\"number\"\n variant=\"outlined\"\n value={size.width}\n min={150}\n max={1000}\n onChange={(e, v) => updateSize('width', v)}\n />\n <NumberTextField\n label=\"Height\"\n type=\"number\"\n variant=\"outlined\"\n min={150}\n max={1000}\n value={size.height}\n onChange={(e, v) => updateSize('height', v)}\n />\n </div>\n </div>\n );\n});\n\nDisplaySize.propTypes = {\n size: PropTypes.shape({\n width: PropTypes.number.isRequired,\n height: PropTypes.number.isRequired,\n }).isRequired,\n label: PropTypes.string.isRequired,\n onChange: PropTypes.func,\n};\n\nexport default DisplaySize;\n"],"mappings":"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"}
|
package/lib/settings/index.js
CHANGED
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
|
|
5
4
|
Object.defineProperty(exports, "__esModule", {
|
|
6
5
|
value: true
|
|
7
6
|
});
|
|
@@ -11,18 +10,21 @@ Object.defineProperty(exports, "Panel", {
|
|
|
11
10
|
return _panel["default"];
|
|
12
11
|
}
|
|
13
12
|
});
|
|
14
|
-
exports.toggle = exports.radio = exports.numberFields = exports.numberField = exports.dropdown = exports.checkboxes = exports.checkbox = void 0;
|
|
15
|
-
|
|
13
|
+
exports.toggle = exports.textField = exports.radio = exports.numberFields = exports.numberField = exports.dropdown = exports.checkboxes = exports.checkbox = void 0;
|
|
16
14
|
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
17
|
-
|
|
18
15
|
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
19
|
-
|
|
20
16
|
var _panel = _interopRequireDefault(require("./panel"));
|
|
21
|
-
|
|
22
17
|
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
23
|
-
|
|
24
18
|
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
25
|
-
|
|
19
|
+
var textField = function textField(label) {
|
|
20
|
+
var isConfigProperty = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;
|
|
21
|
+
return {
|
|
22
|
+
label: label,
|
|
23
|
+
type: 'textField',
|
|
24
|
+
isConfigProperty: isConfigProperty
|
|
25
|
+
};
|
|
26
|
+
};
|
|
27
|
+
exports.textField = textField;
|
|
26
28
|
var toggle = function toggle(label) {
|
|
27
29
|
var isConfigProperty = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
|
|
28
30
|
return {
|
|
@@ -31,9 +33,7 @@ var toggle = function toggle(label) {
|
|
|
31
33
|
isConfigProperty: isConfigProperty
|
|
32
34
|
};
|
|
33
35
|
};
|
|
34
|
-
|
|
35
36
|
exports.toggle = toggle;
|
|
36
|
-
|
|
37
37
|
var toChoice = function toChoice(opt) {
|
|
38
38
|
if (typeof opt === 'string') {
|
|
39
39
|
return {
|
|
@@ -44,16 +44,13 @@ var toChoice = function toChoice(opt) {
|
|
|
44
44
|
return opt;
|
|
45
45
|
}
|
|
46
46
|
};
|
|
47
|
-
|
|
48
47
|
var radio = function radio() {
|
|
49
48
|
var args = Array.prototype.slice.call(arguments);
|
|
50
|
-
|
|
51
49
|
var _args = (0, _slicedToArray2["default"])(args, 3),
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
50
|
+
label = _args[0],
|
|
51
|
+
choices = _args[1],
|
|
52
|
+
_args$ = _args[2],
|
|
53
|
+
isConfigProperty = _args$ === void 0 ? false : _args$;
|
|
57
54
|
return {
|
|
58
55
|
type: 'radio',
|
|
59
56
|
label: label,
|
|
@@ -63,9 +60,7 @@ var radio = function radio() {
|
|
|
63
60
|
isConfigProperty: isConfigProperty
|
|
64
61
|
};
|
|
65
62
|
};
|
|
66
|
-
|
|
67
63
|
exports.radio = radio;
|
|
68
|
-
|
|
69
64
|
var dropdown = function dropdown(label, choices) {
|
|
70
65
|
var isConfigProperty = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;
|
|
71
66
|
return {
|
|
@@ -75,9 +70,7 @@ var dropdown = function dropdown(label, choices) {
|
|
|
75
70
|
isConfigProperty: isConfigProperty
|
|
76
71
|
};
|
|
77
72
|
};
|
|
78
|
-
|
|
79
73
|
exports.dropdown = dropdown;
|
|
80
|
-
|
|
81
74
|
var numberField = function numberField(label, options) {
|
|
82
75
|
var isConfigProperty = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;
|
|
83
76
|
return _objectSpread(_objectSpread({}, options), {}, {
|
|
@@ -86,9 +79,7 @@ var numberField = function numberField(label, options) {
|
|
|
86
79
|
isConfigProperty: isConfigProperty
|
|
87
80
|
});
|
|
88
81
|
};
|
|
89
|
-
|
|
90
82
|
exports.numberField = numberField;
|
|
91
|
-
|
|
92
83
|
var numberFields = function numberFields(label, fields) {
|
|
93
84
|
var isConfigProperty = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;
|
|
94
85
|
Object.keys(fields).map(function (key) {
|
|
@@ -100,9 +91,7 @@ var numberFields = function numberFields(label, fields) {
|
|
|
100
91
|
fields: fields
|
|
101
92
|
};
|
|
102
93
|
};
|
|
103
|
-
|
|
104
94
|
exports.numberFields = numberFields;
|
|
105
|
-
|
|
106
95
|
var checkbox = function checkbox(label, settings) {
|
|
107
96
|
var isConfigProperty = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;
|
|
108
97
|
return _objectSpread(_objectSpread({}, settings), {}, {
|
|
@@ -111,9 +100,7 @@ var checkbox = function checkbox(label, settings) {
|
|
|
111
100
|
isConfigProperty: isConfigProperty
|
|
112
101
|
});
|
|
113
102
|
};
|
|
114
|
-
|
|
115
103
|
exports.checkbox = checkbox;
|
|
116
|
-
|
|
117
104
|
var checkboxes = function checkboxes(label, choices) {
|
|
118
105
|
var isConfigProperty = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;
|
|
119
106
|
Object.keys(choices).map(function (key) {
|
|
@@ -125,6 +112,5 @@ var checkboxes = function checkboxes(label, choices) {
|
|
|
125
112
|
choices: choices
|
|
126
113
|
};
|
|
127
114
|
};
|
|
128
|
-
|
|
129
115
|
exports.checkboxes = checkboxes;
|
|
130
|
-
//# sourceMappingURL=
|
|
116
|
+
//# sourceMappingURL=index.js.map
|