react-survey-builder 1.0.5 → 1.0.6

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.
@@ -36,6 +36,16 @@ object-assign
36
36
 
37
37
  /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/facebook/regenerator/blob/main/LICENSE */
38
38
 
39
+ /**
40
+ * @license React
41
+ * react-jsx-runtime.production.min.js
42
+ *
43
+ * Copyright (c) Facebook, Inc. and its affiliates.
44
+ *
45
+ * This source code is licensed under the MIT license found in the
46
+ * LICENSE file in the root directory of this source tree.
47
+ */
48
+
39
49
  /** @license React v16.13.1
40
50
  * react-is.production.min.js
41
51
  *
package/lib/form.js CHANGED
@@ -201,7 +201,8 @@ var ReactSurvey = /*#__PURE__*/function (_React$Component) {
201
201
  var itemData = {
202
202
  id: item.id,
203
203
  name: item.field_name,
204
- custom_name: item.custom_name || item.field_name
204
+ custom_name: item.custom_name || item.field_name,
205
+ help: item.help
205
206
  };
206
207
  if (!itemData.name) return null;
207
208
  var ref = this.inputs[item.field_name];
@@ -24,11 +24,14 @@
24
24
  "step": "Step",
25
25
  "min": "Min",
26
26
  "max": "Max",
27
+ "min_label": "Minimum Value Label",
28
+ "max_label": "Maximum Value Label",
27
29
  "default-selected": "Default Selected",
28
30
  "text-style": "Text Style",
29
31
  "bold": "Bold",
30
32
  "italic": "Italic",
31
33
  "description": "Description",
34
+ "help": "Help",
32
35
  "correct-answer": "Correct Answer",
33
36
  "populate-options-from-api": "Populate Options from API",
34
37
  "populate": "Populate",
@@ -14,6 +14,7 @@ var ComponentLabel = function ComponentLabel(props) {
14
14
  return null;
15
15
  }
16
16
  return /*#__PURE__*/_react["default"].createElement("label", {
17
+ htmlFor: props.name,
17
18
  className: props.className || 'form-label'
18
19
  }, /*#__PURE__*/_react["default"].createElement("span", {
19
20
  dangerouslySetInnerHTML: {
@@ -7,8 +7,8 @@ Object.defineProperty(exports, "__esModule", {
7
7
  exports["default"] = void 0;
8
8
  var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
9
9
  var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
10
- var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
11
10
  var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
11
+ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
12
12
  var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
13
13
  var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
14
14
  var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
@@ -27,6 +27,7 @@ var _componentHeader = _interopRequireDefault(require("./component-header"));
27
27
  var _componentLabel = _interopRequireDefault(require("./component-label"));
28
28
  var _myxss = _interopRequireDefault(require("./myxss"));
29
29
  var _fa = require("react-icons/fa");
30
+ var _reactBootstrap = require("react-bootstrap");
30
31
  function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
31
32
  function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
32
33
  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); }; }
@@ -191,7 +192,13 @@ var TextInput = /*#__PURE__*/function (_React$Component5) {
191
192
  className: baseClasses
192
193
  }, /*#__PURE__*/_react["default"].createElement(_componentHeader["default"], this.props), /*#__PURE__*/_react["default"].createElement("div", {
193
194
  className: "form-group"
194
- }, /*#__PURE__*/_react["default"].createElement(_componentLabel["default"], this.props), /*#__PURE__*/_react["default"].createElement("input", props)));
195
+ }, /*#__PURE__*/_react["default"].createElement(_reactBootstrap.Form.Floating, {
196
+ className: "mb-3"
197
+ }, /*#__PURE__*/_react["default"].createElement(_componentLabel["default"], (0, _extends2["default"])({}, this.props, {
198
+ name: props.name
199
+ })), /*#__PURE__*/_react["default"].createElement(_reactBootstrap.Form.Control, (0, _extends2["default"])({
200
+ id: props.name
201
+ }, props)))));
195
202
  }
196
203
  }]);
197
204
  return TextInput;
@@ -435,7 +435,16 @@ var SurveyElementsEdit = exports["default"] = /*#__PURE__*/function (_React$Comp
435
435
  defaultValue: this.props.element.min_value,
436
436
  onBlur: this.updateElement.bind(this),
437
437
  onChange: this.editElementProp.bind(this, 'min_value', 'value')
438
- }), /*#__PURE__*/_react["default"].createElement("input", {
438
+ }))), this.props.element.hasOwnProperty('min_label') && /*#__PURE__*/_react["default"].createElement("div", {
439
+ className: "form-group"
440
+ }, /*#__PURE__*/_react["default"].createElement("div", {
441
+ className: "form-group-range"
442
+ }, /*#__PURE__*/_react["default"].createElement("label", {
443
+ className: "control-label",
444
+ htmlFor: "rangeMin"
445
+ }, /*#__PURE__*/_react["default"].createElement(_IntlMessages["default"], {
446
+ id: "min_label"
447
+ })), /*#__PURE__*/_react["default"].createElement("input", {
439
448
  type: "text",
440
449
  className: "form-control",
441
450
  defaultValue: this.props.element.min_label,
@@ -457,7 +466,16 @@ var SurveyElementsEdit = exports["default"] = /*#__PURE__*/function (_React$Comp
457
466
  defaultValue: this.props.element.max_value,
458
467
  onBlur: this.updateElement.bind(this),
459
468
  onChange: this.editElementProp.bind(this, 'max_value', 'value')
460
- }), /*#__PURE__*/_react["default"].createElement("input", {
469
+ }))), this.props.element.hasOwnProperty('max_label') && /*#__PURE__*/_react["default"].createElement("div", {
470
+ className: "form-group"
471
+ }, /*#__PURE__*/_react["default"].createElement("div", {
472
+ className: "form-group-range"
473
+ }, /*#__PURE__*/_react["default"].createElement("label", {
474
+ className: "control-label",
475
+ htmlFor: "rangeMax"
476
+ }, /*#__PURE__*/_react["default"].createElement(_IntlMessages["default"], {
477
+ id: "max_label"
478
+ })), /*#__PURE__*/_react["default"].createElement("input", {
461
479
  type: "text",
462
480
  className: "form-control",
463
481
  defaultValue: this.props.element.max_label,
@@ -527,7 +545,7 @@ var SurveyElementsEdit = exports["default"] = /*#__PURE__*/function (_React$Comp
527
545
  defaultValue: this.props.element.placeholder,
528
546
  onBlur: this.updateElement.bind(this),
529
547
  onChange: this.editElementProp.bind(this, 'placeholder', 'value')
530
- })), this.props.element.show_custom_name && /*#__PURE__*/_react["default"].createElement("div", {
548
+ })), this.props.element.showCustomName && /*#__PURE__*/_react["default"].createElement("div", {
531
549
  className: "form-group"
532
550
  }, /*#__PURE__*/_react["default"].createElement("label", {
533
551
  className: "control-label",
@@ -541,6 +559,20 @@ var SurveyElementsEdit = exports["default"] = /*#__PURE__*/function (_React$Comp
541
559
  defaultValue: this.props.element.custom_name,
542
560
  onBlur: this.updateElement.bind(this),
543
561
  onChange: this.editElementProp.bind(this, 'custom_name', 'value')
562
+ })), this.props.element.showHelp && /*#__PURE__*/_react["default"].createElement("div", {
563
+ className: "form-group"
564
+ }, /*#__PURE__*/_react["default"].createElement("label", {
565
+ className: "control-label",
566
+ htmlFor: "help"
567
+ }, /*#__PURE__*/_react["default"].createElement(_IntlMessages["default"], {
568
+ id: "help-label"
569
+ })), /*#__PURE__*/_react["default"].createElement(_reactTextareaAutosize["default"], {
570
+ type: "text",
571
+ className: "form-control",
572
+ id: "help",
573
+ defaultValue: this.props.element.help,
574
+ onBlur: this.updateElement.bind(this),
575
+ onChange: this.editElementProp.bind(this, 'help', 'value')
544
576
  })), this.props.element.showDescription && /*#__PURE__*/_react["default"].createElement("div", {
545
577
  className: "form-group"
546
578
  }, /*#__PURE__*/_react["default"].createElement("label", {
package/lib/toolbar.js CHANGED
@@ -159,7 +159,9 @@ var Toolbar = /*#__PURE__*/function (_React$Component) {
159
159
  id: 'place-holder-label'
160
160
  }),
161
161
  field_name: 'dropdown_',
162
- show_custom_name: true,
162
+ showCustomName: true,
163
+ showDescription: true,
164
+ showHelp: true,
163
165
  options: []
164
166
  }, {
165
167
  key: 'Tags',
@@ -172,7 +174,9 @@ var Toolbar = /*#__PURE__*/function (_React$Component) {
172
174
  id: 'place-holder-label'
173
175
  }),
174
176
  field_name: 'tags_',
175
- show_custom_name: true,
177
+ showCustomName: true,
178
+ showDescription: true,
179
+ showHelp: true,
176
180
  options: []
177
181
  }, {
178
182
  key: 'Checkboxes',
@@ -185,7 +189,9 @@ var Toolbar = /*#__PURE__*/function (_React$Component) {
185
189
  id: 'place-holder-label'
186
190
  }),
187
191
  field_name: 'checkboxes_',
188
- show_custom_name: true,
192
+ showCustomName: true,
193
+ showDescription: true,
194
+ showHelp: true,
189
195
  options: []
190
196
  }, {
191
197
  key: 'Checkbox',
@@ -198,7 +204,9 @@ var Toolbar = /*#__PURE__*/function (_React$Component) {
198
204
  id: 'place-holder-label'
199
205
  }),
200
206
  field_name: 'checkbox_',
201
- show_custom_name: true,
207
+ showCustomName: true,
208
+ showDescription: true,
209
+ showHelp: true,
202
210
  boxLabel: 'Agree To Rules & Regs'
203
211
  }, {
204
212
  key: 'RadioButtons',
@@ -211,7 +219,9 @@ var Toolbar = /*#__PURE__*/function (_React$Component) {
211
219
  id: 'place-holder-label'
212
220
  }),
213
221
  field_name: 'radiobuttons_',
214
- show_custom_name: true,
222
+ showCustomName: true,
223
+ showDescription: true,
224
+ showHelp: true,
215
225
  options: []
216
226
  }, {
217
227
  key: 'TextInput',
@@ -224,7 +234,9 @@ var Toolbar = /*#__PURE__*/function (_React$Component) {
224
234
  }),
225
235
  icon: _fa.FaFont,
226
236
  field_name: 'text_input_',
227
- show_custom_name: true
237
+ showCustomName: true,
238
+ showDescription: true,
239
+ showHelp: true
228
240
  }, {
229
241
  key: 'EmailInput',
230
242
  canHaveAnswer: true,
@@ -236,7 +248,9 @@ var Toolbar = /*#__PURE__*/function (_React$Component) {
236
248
  }),
237
249
  icon: _fa.FaEnvelope,
238
250
  field_name: 'email_input_',
239
- show_custom_name: true,
251
+ showCustomName: true,
252
+ showDescription: true,
253
+ showHelp: true,
240
254
  placeholder: ''
241
255
  }, {
242
256
  key: 'NumberInput',
@@ -249,9 +263,11 @@ var Toolbar = /*#__PURE__*/function (_React$Component) {
249
263
  }),
250
264
  icon: _fa.FaPlus,
251
265
  field_name: 'number_input_',
252
- show_custom_name: true,
266
+ showCustomName: true,
267
+ showDescription: true,
268
+ showHelp: true,
253
269
  step: 1,
254
- min_value: 1,
270
+ min_value: 0,
255
271
  max_value: 5
256
272
  }, {
257
273
  key: 'PhoneNumber',
@@ -264,7 +280,9 @@ var Toolbar = /*#__PURE__*/function (_React$Component) {
264
280
  }),
265
281
  icon: _fa.FaPhone,
266
282
  field_name: 'phone_input_',
267
- show_custom_name: true
283
+ showCustomName: true,
284
+ showDescription: true,
285
+ showHelp: true
268
286
  }, {
269
287
  key: 'TextArea',
270
288
  canHaveAnswer: true,
@@ -276,7 +294,9 @@ var Toolbar = /*#__PURE__*/function (_React$Component) {
276
294
  }),
277
295
  icon: _fa.FaTextHeight,
278
296
  field_name: 'text_area_',
279
- show_custom_name: true
297
+ showCustomName: true,
298
+ showDescription: true,
299
+ showHelp: true
280
300
  }, {
281
301
  key: 'FieldSet',
282
302
  canHaveAnswer: false,
@@ -362,7 +382,9 @@ var Toolbar = /*#__PURE__*/function (_React$Component) {
362
382
  }),
363
383
  icon: _fa.FaStar,
364
384
  field_name: 'rating_',
365
- show_custom_name: true
385
+ showCustomName: true,
386
+ showDescription: true,
387
+ showHelp: true
366
388
  }, {
367
389
  key: 'DatePicker',
368
390
  canDefaultToday: true,
@@ -380,7 +402,9 @@ var Toolbar = /*#__PURE__*/function (_React$Component) {
380
402
  id: 'place-holder-label'
381
403
  }),
382
404
  field_name: 'date_picker_',
383
- show_custom_name: true
405
+ showCustomName: true,
406
+ showDescription: true,
407
+ showHelp: true
384
408
  }, {
385
409
  key: 'Signature',
386
410
  canReadOnly: true,
@@ -436,7 +460,9 @@ var Toolbar = /*#__PURE__*/function (_React$Component) {
436
460
  max_label: intl.formatMessage({
437
461
  id: 'difficult'
438
462
  }),
439
- show_custom_name: true
463
+ showCustomName: true,
464
+ showDescription: true,
465
+ showHelp: true
440
466
  }, {
441
467
  key: 'Camera',
442
468
  name: intl.formatMessage({
@@ -506,8 +532,10 @@ var Toolbar = /*#__PURE__*/function (_React$Component) {
506
532
  elementOptions.bold = false;
507
533
  elementOptions.italic = false;
508
534
  }
509
- elementOptions.show_custom_name = item.show_custom_name;
535
+ elementOptions.showCustomName = item.showCustomName;
510
536
  elementOptions.custom_name = item.custom_name;
537
+ elementOptions.showHelp = item.showHelp;
538
+ elementOptions.help = item.help;
511
539
  if (item.canHaveAnswer) {
512
540
  elementOptions.canHaveAnswer = item.canHaveAnswer;
513
541
  }
@@ -552,6 +580,11 @@ var Toolbar = /*#__PURE__*/function (_React$Component) {
552
580
  elementOptions._href = item._href;
553
581
  elementOptions.file_path = item.file_path;
554
582
  }
583
+ if (element === 'NumberInput') {
584
+ elementOptions.step = item.step;
585
+ elementOptions.min_value = item.min_value;
586
+ elementOptions.max_value = item.max_value;
587
+ }
555
588
  if (element === 'Range') {
556
589
  elementOptions.step = item.step;
557
590
  elementOptions.default_value = item.default_value;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "react-survey-builder",
3
- "version": "1.0.5",
3
+ "version": "1.0.6",
4
4
  "description": "A complete survey builder for react.",
5
5
  "main": "lib/index.js",
6
6
  "types": "types/index.d.ts",
package/types/index.d.ts CHANGED
@@ -138,6 +138,7 @@ export interface SurveyGeneratorOnSubmitParams {
138
138
  id: number;
139
139
  name: string;
140
140
  custom_name: string;
141
+ help: string;
141
142
  value: string | string[];
142
143
  }
143
144