@kaspernj/api-maker 1.0.469 → 1.0.471

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.
@@ -11,17 +11,32 @@ export default memo(shapeComponent(class ApiMakerUtilsCheckbox extends BaseCompo
11
11
  label: undefined
12
12
  };
13
13
  static propTypes = propTypesExact({
14
- checked: PropTypes.bool.isRequired,
14
+ checked: PropTypes.bool,
15
15
  dataSet: PropTypes.object,
16
+ defaultChecked: PropTypes.bool,
16
17
  label: PropTypes.string,
17
- onCheckedChange: PropTypes.func.isRequired,
18
+ onCheckedChange: PropTypes.func,
18
19
  style: PropTypes.object
19
20
  });
21
+ setup() {
22
+ this.useStates({
23
+ checked: this.props.defaultChecked
24
+ });
25
+ this.isChecked = this.calculateChecked();
26
+ }
27
+ calculateChecked() {
28
+ if ("checked" in this.props) {
29
+ return this.p.checked;
30
+ } else {
31
+ return this.s.checked;
32
+ }
33
+ }
20
34
  render() {
21
35
  const {
22
- checked,
23
- label,
24
- onCheckedChange
36
+ isChecked
37
+ } = this.tt;
38
+ const {
39
+ label
25
40
  } = this.p;
26
41
  const actualStyle = Object.assign({
27
42
  flexDirection: "row",
@@ -29,13 +44,13 @@ export default memo(shapeComponent(class ApiMakerUtilsCheckbox extends BaseCompo
29
44
  }, this.props.style);
30
45
  return /*#__PURE__*/React.createElement(View, {
31
46
  dataSet: {
32
- component: "api-maker--utils--checkbox"
47
+ component: "api-maker/utils/checkbox"
33
48
  },
34
49
  style: actualStyle
35
50
  }, /*#__PURE__*/React.createElement(CheckBox, {
36
51
  dataSet: this.props.dataSet,
37
- onValueChange: onCheckedChange,
38
- value: checked
52
+ onValueChange: this.tt.onValueChange,
53
+ value: isChecked
39
54
  }), label && /*#__PURE__*/React.createElement(Pressable, {
40
55
  onPress: this.tt.onLabelPressed
41
56
  }, /*#__PURE__*/React.createElement(Text, {
@@ -44,6 +59,14 @@ export default memo(shapeComponent(class ApiMakerUtilsCheckbox extends BaseCompo
44
59
  }
45
60
  }, label)));
46
61
  }
47
- onLabelPressed = () => this.p.onCheckedChange(!this.p.checked);
62
+ onLabelPressed = () => this.p.onCheckedChange(!this.tt.isChecked);
63
+ onValueChange = e => {
64
+ if (this.props.onCheckedChange) {
65
+ this.p.onCheckedChange(e);
66
+ }
67
+ this.setState({
68
+ checked: !this.tt.isChecked
69
+ });
70
+ };
48
71
  }));
49
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJCYXNlQ29tcG9uZW50IiwiQ2hlY2tCb3giLCJQcmVzc2FibGUiLCJWaWV3IiwibWVtbyIsIlByb3BUeXBlcyIsInByb3BUeXBlc0V4YWN0IiwiUmVhY3QiLCJzaGFwZUNvbXBvbmVudCIsIlRleHQiLCJBcGlNYWtlclV0aWxzQ2hlY2tib3giLCJkZWZhdWx0UHJvcHMiLCJsYWJlbCIsInVuZGVmaW5lZCIsInByb3BUeXBlcyIsImNoZWNrZWQiLCJib29sIiwiaXNSZXF1aXJlZCIsImRhdGFTZXQiLCJvYmplY3QiLCJzdHJpbmciLCJvbkNoZWNrZWRDaGFuZ2UiLCJmdW5jIiwic3R5bGUiLCJyZW5kZXIiLCJwIiwiYWN0dWFsU3R5bGUiLCJPYmplY3QiLCJhc3NpZ24iLCJmbGV4RGlyZWN0aW9uIiwiYWxpZ25JdGVtcyIsInByb3BzIiwiY3JlYXRlRWxlbWVudCIsImNvbXBvbmVudCIsIm9uVmFsdWVDaGFuZ2UiLCJ2YWx1ZSIsIm9uUHJlc3MiLCJ0dCIsIm9uTGFiZWxQcmVzc2VkIiwibWFyZ2luTGVmdCJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy9jaGVja2JveC5qc3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IEJhc2VDb21wb25lbnQgZnJvbSBcIi4uL2Jhc2UtY29tcG9uZW50XCJcbmltcG9ydCB7Q2hlY2tCb3gsIFByZXNzYWJsZSwgVmlld30gZnJvbSBcInJlYWN0LW5hdGl2ZVwiXG5pbXBvcnQgbWVtbyBmcm9tIFwic2V0LXN0YXRlLWNvbXBhcmUvc3JjL21lbW9cIlxuaW1wb3J0IFByb3BUeXBlcyBmcm9tIFwicHJvcC10eXBlc1wiXG5pbXBvcnQgcHJvcFR5cGVzRXhhY3QgZnJvbSBcInByb3AtdHlwZXMtZXhhY3RcIlxuaW1wb3J0IFJlYWN0IGZyb20gXCJyZWFjdFwiXG5pbXBvcnQge3NoYXBlQ29tcG9uZW50fSBmcm9tIFwic2V0LXN0YXRlLWNvbXBhcmUvc3JjL3NoYXBlLWNvbXBvbmVudFwiXG5pbXBvcnQgVGV4dCBmcm9tIFwiLi90ZXh0XCJcblxuZXhwb3J0IGRlZmF1bHQgbWVtbyhzaGFwZUNvbXBvbmVudChjbGFzcyBBcGlNYWtlclV0aWxzQ2hlY2tib3ggZXh0ZW5kcyBCYXNlQ29tcG9uZW50IHtcbiAgc3RhdGljIGRlZmF1bHRQcm9wcyA9IHtcbiAgICBsYWJlbDogdW5kZWZpbmVkXG4gIH1cblxuICBzdGF0aWMgcHJvcFR5cGVzID0gcHJvcFR5cGVzRXhhY3Qoe1xuICAgIGNoZWNrZWQ6IFByb3BUeXBlcy5ib29sLmlzUmVxdWlyZWQsXG4gICAgZGF0YVNldDogUHJvcFR5cGVzLm9iamVjdCxcbiAgICBsYWJlbDogUHJvcFR5cGVzLnN0cmluZyxcbiAgICBvbkNoZWNrZWRDaGFuZ2U6IFByb3BUeXBlcy5mdW5jLmlzUmVxdWlyZWQsXG4gICAgc3R5bGU6IFByb3BUeXBlcy5vYmplY3RcbiAgfSlcblxuICByZW5kZXIoKSB7XG4gICAgY29uc3Qge2NoZWNrZWQsIGxhYmVsLCBvbkNoZWNrZWRDaGFuZ2V9ID0gdGhpcy5wXG4gICAgY29uc3QgYWN0dWFsU3R5bGUgPSBPYmplY3QuYXNzaWduKFxuICAgICAge2ZsZXhEaXJlY3Rpb246IFwicm93XCIsIGFsaWduSXRlbXM6IFwiY2VudGVyXCJ9LFxuICAgICAgdGhpcy5wcm9wcy5zdHlsZVxuICAgIClcblxuICAgIHJldHVybiAoXG4gICAgICA8VmlldyBkYXRhU2V0PXt7Y29tcG9uZW50OiBcImFwaS1tYWtlci0tdXRpbHMtLWNoZWNrYm94XCJ9fSBzdHlsZT17YWN0dWFsU3R5bGV9PlxuICAgICAgICA8Q2hlY2tCb3ggZGF0YVNldD17dGhpcy5wcm9wcy5kYXRhU2V0fSBvblZhbHVlQ2hhbmdlPXtvbkNoZWNrZWRDaGFuZ2V9IHZhbHVlPXtjaGVja2VkfSAvPlxuICAgICAgICB7bGFiZWwgJiZcbiAgICAgICAgICA8UHJlc3NhYmxlIG9uUHJlc3M9e3RoaXMudHQub25MYWJlbFByZXNzZWR9PlxuICAgICAgICAgICAgPFRleHQgc3R5bGU9e3ttYXJnaW5MZWZ0OiAzfX0+XG4gICAgICAgICAgICAgIHtsYWJlbH1cbiAgICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgICA8L1ByZXNzYWJsZT5cbiAgICAgICAgfVxuICAgICAgPC9WaWV3PlxuICAgIClcbiAgfVxuXG4gIG9uTGFiZWxQcmVzc2VkID0gKCkgPT4gdGhpcy5wLm9uQ2hlY2tlZENoYW5nZSghdGhpcy5wLmNoZWNrZWQpXG59KSlcbiJdLCJtYXBwaW5ncyI6IkFBQUEsT0FBT0EsYUFBYSxNQUFNLG1CQUFtQjtBQUM3QyxTQUFRQyxRQUFRLEVBQUVDLFNBQVMsRUFBRUMsSUFBSSxRQUFPLGNBQWM7QUFDdEQsT0FBT0MsSUFBSSxNQUFNLDRCQUE0QjtBQUM3QyxPQUFPQyxTQUFTLE1BQU0sWUFBWTtBQUNsQyxPQUFPQyxjQUFjLE1BQU0sa0JBQWtCO0FBQzdDLE9BQU9DLEtBQUssTUFBTSxPQUFPO0FBQ3pCLFNBQVFDLGNBQWMsUUFBTyx1Q0FBdUM7QUFDcEUsT0FBT0MsSUFBSSxNQUFNLFFBQVE7QUFFekIsZUFBZUwsSUFBSSxDQUFDSSxjQUFjLENBQUMsTUFBTUUscUJBQXFCLFNBQVNWLGFBQWEsQ0FBQztFQUNuRixPQUFPVyxZQUFZLEdBQUc7SUFDcEJDLEtBQUssRUFBRUM7RUFDVCxDQUFDO0VBRUQsT0FBT0MsU0FBUyxHQUFHUixjQUFjLENBQUM7SUFDaENTLE9BQU8sRUFBRVYsU0FBUyxDQUFDVyxJQUFJLENBQUNDLFVBQVU7SUFDbENDLE9BQU8sRUFBRWIsU0FBUyxDQUFDYyxNQUFNO0lBQ3pCUCxLQUFLLEVBQUVQLFNBQVMsQ0FBQ2UsTUFBTTtJQUN2QkMsZUFBZSxFQUFFaEIsU0FBUyxDQUFDaUIsSUFBSSxDQUFDTCxVQUFVO0lBQzFDTSxLQUFLLEVBQUVsQixTQUFTLENBQUNjO0VBQ25CLENBQUMsQ0FBQztFQUVGSyxNQUFNQSxDQUFBLEVBQUc7SUFDUCxNQUFNO01BQUNULE9BQU87TUFBRUgsS0FBSztNQUFFUztJQUFlLENBQUMsR0FBRyxJQUFJLENBQUNJLENBQUM7SUFDaEQsTUFBTUMsV0FBVyxHQUFHQyxNQUFNLENBQUNDLE1BQU0sQ0FDL0I7TUFBQ0MsYUFBYSxFQUFFLEtBQUs7TUFBRUMsVUFBVSxFQUFFO0lBQVEsQ0FBQyxFQUM1QyxJQUFJLENBQUNDLEtBQUssQ0FBQ1IsS0FDYixDQUFDO0lBRUQsb0JBQ0VoQixLQUFBLENBQUF5QixhQUFBLENBQUM3QixJQUFJO01BQUNlLE9BQU8sRUFBRTtRQUFDZSxTQUFTLEVBQUU7TUFBNEIsQ0FBRTtNQUFDVixLQUFLLEVBQUVHO0lBQVksZ0JBQzNFbkIsS0FBQSxDQUFBeUIsYUFBQSxDQUFDL0IsUUFBUTtNQUFDaUIsT0FBTyxFQUFFLElBQUksQ0FBQ2EsS0FBSyxDQUFDYixPQUFRO01BQUNnQixhQUFhLEVBQUViLGVBQWdCO01BQUNjLEtBQUssRUFBRXBCO0lBQVEsQ0FBRSxDQUFDLEVBQ3hGSCxLQUFLLGlCQUNKTCxLQUFBLENBQUF5QixhQUFBLENBQUM5QixTQUFTO01BQUNrQyxPQUFPLEVBQUUsSUFBSSxDQUFDQyxFQUFFLENBQUNDO0lBQWUsZ0JBQ3pDL0IsS0FBQSxDQUFBeUIsYUFBQSxDQUFDdkIsSUFBSTtNQUFDYyxLQUFLLEVBQUU7UUFBQ2dCLFVBQVUsRUFBRTtNQUFDO0lBQUUsR0FDMUIzQixLQUNHLENBQ0csQ0FFVCxDQUFDO0VBRVg7RUFFQTBCLGNBQWMsR0FBR0EsQ0FBQSxLQUFNLElBQUksQ0FBQ2IsQ0FBQyxDQUFDSixlQUFlLENBQUMsQ0FBQyxJQUFJLENBQUNJLENBQUMsQ0FBQ1YsT0FBTyxDQUFDO0FBQ2hFLENBQUMsQ0FBQyxDQUFDIiwiaWdub3JlTGlzdCI6W119
72
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJCYXNlQ29tcG9uZW50IiwiQ2hlY2tCb3giLCJQcmVzc2FibGUiLCJWaWV3IiwibWVtbyIsIlByb3BUeXBlcyIsInByb3BUeXBlc0V4YWN0IiwiUmVhY3QiLCJzaGFwZUNvbXBvbmVudCIsIlRleHQiLCJBcGlNYWtlclV0aWxzQ2hlY2tib3giLCJkZWZhdWx0UHJvcHMiLCJsYWJlbCIsInVuZGVmaW5lZCIsInByb3BUeXBlcyIsImNoZWNrZWQiLCJib29sIiwiZGF0YVNldCIsIm9iamVjdCIsImRlZmF1bHRDaGVja2VkIiwic3RyaW5nIiwib25DaGVja2VkQ2hhbmdlIiwiZnVuYyIsInN0eWxlIiwic2V0dXAiLCJ1c2VTdGF0ZXMiLCJwcm9wcyIsImlzQ2hlY2tlZCIsImNhbGN1bGF0ZUNoZWNrZWQiLCJwIiwicyIsInJlbmRlciIsInR0IiwiYWN0dWFsU3R5bGUiLCJPYmplY3QiLCJhc3NpZ24iLCJmbGV4RGlyZWN0aW9uIiwiYWxpZ25JdGVtcyIsImNyZWF0ZUVsZW1lbnQiLCJjb21wb25lbnQiLCJvblZhbHVlQ2hhbmdlIiwidmFsdWUiLCJvblByZXNzIiwib25MYWJlbFByZXNzZWQiLCJtYXJnaW5MZWZ0IiwiZSIsInNldFN0YXRlIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL3V0aWxzL2NoZWNrYm94LmpzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgQmFzZUNvbXBvbmVudCBmcm9tIFwiLi4vYmFzZS1jb21wb25lbnRcIlxuaW1wb3J0IHtDaGVja0JveCwgUHJlc3NhYmxlLCBWaWV3fSBmcm9tIFwicmVhY3QtbmF0aXZlXCJcbmltcG9ydCBtZW1vIGZyb20gXCJzZXQtc3RhdGUtY29tcGFyZS9zcmMvbWVtb1wiXG5pbXBvcnQgUHJvcFR5cGVzIGZyb20gXCJwcm9wLXR5cGVzXCJcbmltcG9ydCBwcm9wVHlwZXNFeGFjdCBmcm9tIFwicHJvcC10eXBlcy1leGFjdFwiXG5pbXBvcnQgUmVhY3QgZnJvbSBcInJlYWN0XCJcbmltcG9ydCB7c2hhcGVDb21wb25lbnR9IGZyb20gXCJzZXQtc3RhdGUtY29tcGFyZS9zcmMvc2hhcGUtY29tcG9uZW50XCJcbmltcG9ydCBUZXh0IGZyb20gXCIuL3RleHRcIlxuXG5leHBvcnQgZGVmYXVsdCBtZW1vKHNoYXBlQ29tcG9uZW50KGNsYXNzIEFwaU1ha2VyVXRpbHNDaGVja2JveCBleHRlbmRzIEJhc2VDb21wb25lbnQge1xuICBzdGF0aWMgZGVmYXVsdFByb3BzID0ge1xuICAgIGxhYmVsOiB1bmRlZmluZWRcbiAgfVxuXG4gIHN0YXRpYyBwcm9wVHlwZXMgPSBwcm9wVHlwZXNFeGFjdCh7XG4gICAgY2hlY2tlZDogUHJvcFR5cGVzLmJvb2wsXG4gICAgZGF0YVNldDogUHJvcFR5cGVzLm9iamVjdCxcbiAgICBkZWZhdWx0Q2hlY2tlZDogUHJvcFR5cGVzLmJvb2wsXG4gICAgbGFiZWw6IFByb3BUeXBlcy5zdHJpbmcsXG4gICAgb25DaGVja2VkQ2hhbmdlOiBQcm9wVHlwZXMuZnVuYyxcbiAgICBzdHlsZTogUHJvcFR5cGVzLm9iamVjdFxuICB9KVxuXG4gIHNldHVwKCkge1xuICAgIHRoaXMudXNlU3RhdGVzKHtcbiAgICAgIGNoZWNrZWQ6IHRoaXMucHJvcHMuZGVmYXVsdENoZWNrZWRcbiAgICB9KVxuICAgIHRoaXMuaXNDaGVja2VkID0gdGhpcy5jYWxjdWxhdGVDaGVja2VkKClcbiAgfVxuXG4gIGNhbGN1bGF0ZUNoZWNrZWQoKSB7XG4gICAgaWYgKFwiY2hlY2tlZFwiIGluIHRoaXMucHJvcHMpIHtcbiAgICAgIHJldHVybiB0aGlzLnAuY2hlY2tlZFxuICAgIH0gZWxzZSB7XG4gICAgICByZXR1cm4gdGhpcy5zLmNoZWNrZWRcbiAgICB9XG4gIH1cblxuICByZW5kZXIoKSB7XG4gICAgY29uc3Qge2lzQ2hlY2tlZH0gPSB0aGlzLnR0XG4gICAgY29uc3Qge2xhYmVsfSA9IHRoaXMucFxuICAgIGNvbnN0IGFjdHVhbFN0eWxlID0gT2JqZWN0LmFzc2lnbihcbiAgICAgIHtmbGV4RGlyZWN0aW9uOiBcInJvd1wiLCBhbGlnbkl0ZW1zOiBcImNlbnRlclwifSxcbiAgICAgIHRoaXMucHJvcHMuc3R5bGVcbiAgICApXG5cbiAgICByZXR1cm4gKFxuICAgICAgPFZpZXcgZGF0YVNldD17e2NvbXBvbmVudDogXCJhcGktbWFrZXIvdXRpbHMvY2hlY2tib3hcIn19IHN0eWxlPXthY3R1YWxTdHlsZX0+XG4gICAgICAgIDxDaGVja0JveCBkYXRhU2V0PXt0aGlzLnByb3BzLmRhdGFTZXR9IG9uVmFsdWVDaGFuZ2U9e3RoaXMudHQub25WYWx1ZUNoYW5nZX0gdmFsdWU9e2lzQ2hlY2tlZH0gLz5cbiAgICAgICAge2xhYmVsICYmXG4gICAgICAgICAgPFByZXNzYWJsZSBvblByZXNzPXt0aGlzLnR0Lm9uTGFiZWxQcmVzc2VkfT5cbiAgICAgICAgICAgIDxUZXh0IHN0eWxlPXt7bWFyZ2luTGVmdDogM319PlxuICAgICAgICAgICAgICB7bGFiZWx9XG4gICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgPC9QcmVzc2FibGU+XG4gICAgICAgIH1cbiAgICAgIDwvVmlldz5cbiAgICApXG4gIH1cblxuICBvbkxhYmVsUHJlc3NlZCA9ICgpID0+IHRoaXMucC5vbkNoZWNrZWRDaGFuZ2UoIXRoaXMudHQuaXNDaGVja2VkKVxuXG4gIG9uVmFsdWVDaGFuZ2UgPSAoZSkgPT4ge1xuICAgIGlmICh0aGlzLnByb3BzLm9uQ2hlY2tlZENoYW5nZSkge1xuICAgICAgdGhpcy5wLm9uQ2hlY2tlZENoYW5nZShlKVxuICAgIH1cblxuICAgIHRoaXMuc2V0U3RhdGUoe2NoZWNrZWQ6ICF0aGlzLnR0LmlzQ2hlY2tlZH0pXG4gIH1cbn0pKVxuIl0sIm1hcHBpbmdzIjoiQUFBQSxPQUFPQSxhQUFhLE1BQU0sbUJBQW1CO0FBQzdDLFNBQVFDLFFBQVEsRUFBRUMsU0FBUyxFQUFFQyxJQUFJLFFBQU8sY0FBYztBQUN0RCxPQUFPQyxJQUFJLE1BQU0sNEJBQTRCO0FBQzdDLE9BQU9DLFNBQVMsTUFBTSxZQUFZO0FBQ2xDLE9BQU9D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
@@ -0,0 +1,163 @@
1
+ import { shapeComponent, ShapeComponent } from "set-state-compare/src/shape-component";
2
+ import React, { useMemo } from "react";
3
+ import Checkbox from "./checkbox";
4
+ import { digs } from "diggerize";
5
+ import { useForm } from "../form";
6
+ import * as inflection from "inflection";
7
+ import InvalidFeedback from "./invalid-feedback";
8
+ import memo from "set-state-compare/src/memo";
9
+ import PropTypes from "prop-types";
10
+ import propTypesExact from "prop-types-exact";
11
+ import Text from "./text";
12
+ import useInput from "../use-input";
13
+ import { View } from "react-native";
14
+ const OptionElement = memo(shapeComponent(class OptionElement extends ShapeComponent {
15
+ static propTypes = propTypesExact({
16
+ checked: PropTypes.bool.isRequired,
17
+ inputName: PropTypes.string.isRequired,
18
+ onChange: PropTypes.func.isRequired,
19
+ option: PropTypes.array.isRequired
20
+ });
21
+ render() {
22
+ const {
23
+ checked,
24
+ inputName,
25
+ option
26
+ } = this.p;
27
+ return /*#__PURE__*/React.createElement(View, null, /*#__PURE__*/React.createElement(Checkbox, {
28
+ checked: checked,
29
+ dataSet: {
30
+ component: "api-maker/utils/checkboxes/option",
31
+ name: inputName,
32
+ value: option[1]
33
+ },
34
+ label: option[0],
35
+ onCheckedChange: this.tt.onChange
36
+ }));
37
+ }
38
+ onChange = checked => this.p.onChange({
39
+ checked,
40
+ option: this.p.option
41
+ });
42
+ }));
43
+ export default memo(shapeComponent(class ApiMakerUtilsCheckboxes extends ShapeComponent {
44
+ static propTypes = propTypesExact({
45
+ attribute: PropTypes.string,
46
+ defaultValue: PropTypes.array,
47
+ label: PropTypes.string,
48
+ labelClassName: PropTypes.string,
49
+ model: PropTypes.object,
50
+ name: PropTypes.string,
51
+ onChange: PropTypes.func,
52
+ options: PropTypes.array.isRequired
53
+ });
54
+ setup() {
55
+ const {
56
+ inputProps,
57
+ wrapperOpts
58
+ } = useInput({
59
+ props: this.props
60
+ });
61
+ this.generatedId = useMemo(() => Math.random().toString(36).substring(2, 15) + Math.random().toString(36).substring(2, 15), []);
62
+ this.setInstance({
63
+ form: useForm(),
64
+ inputProps,
65
+ wrapperOpts
66
+ });
67
+ this.useStates({
68
+ checkedOptions: () => {
69
+ if (Array.isArray(this.props.defaultValue)) return this.props.defaultValue;
70
+ if (this.props.defaultValue) return [this.props.defaultValue];
71
+ return [];
72
+ }
73
+ });
74
+ useMemo(() => {
75
+ if (this.form && inputProps.name) {
76
+ this.form.setValue(inputProps.name, this.s.checkedOptions);
77
+ }
78
+ }, []);
79
+ }
80
+ render() {
81
+ const {
82
+ wrapperOpts
83
+ } = this.tt;
84
+ const {
85
+ errors
86
+ } = digs(wrapperOpts, "errors");
87
+ return /*#__PURE__*/React.createElement(View, {
88
+ dataSet: {
89
+ component: "api-maker/utils/checkboxes"
90
+ }
91
+ }, /*#__PURE__*/React.createElement(Text, {
92
+ style: {
93
+ fontWeight: "bold"
94
+ }
95
+ }, this.tt.wrapperOpts.label), this.props.options.map(option => /*#__PURE__*/React.createElement(OptionElement, {
96
+ checked: this.isChecked(option),
97
+ inputName: this.inputName(),
98
+ key: option[1],
99
+ onChange: this.tt.onOptionChecked,
100
+ option: option
101
+ })), errors.length > 0 && /*#__PURE__*/React.createElement(InvalidFeedback, {
102
+ errors: errors
103
+ }));
104
+ }
105
+ inputDefaultValue() {
106
+ const {
107
+ attribute,
108
+ defaultValue,
109
+ model
110
+ } = this.props;
111
+ if (defaultValue) {
112
+ return defaultValue;
113
+ } else if (attribute && model) {
114
+ if (!model[attribute]) throw `No such attribute: ${attribute}`;
115
+ return this.props.model[attribute]();
116
+ }
117
+ }
118
+ inputName() {
119
+ if (this.props.name) {
120
+ return `${this.props.name}[]`;
121
+ } else if (this.props.model) {
122
+ return `${this.props.model.modelClassData().paramKey}[${inflection.underscore(this.props.attribute)}]`;
123
+ }
124
+ }
125
+ isChecked = option => this.s.checkedOptions.includes(option[1]);
126
+ onOptionChecked = ({
127
+ checked,
128
+ option
129
+ }) => {
130
+ const {
131
+ inputProps,
132
+ form
133
+ } = this.tt;
134
+ const {
135
+ name
136
+ } = inputProps;
137
+ let newOptions;
138
+ if (checked) {
139
+ newOptions = this.s.checkedOptions.concat([option[1]]);
140
+ this.setState({
141
+ checkedOptions: newOptions
142
+ });
143
+ } else {
144
+ newOptions = this.s.checkedOptions.filter(value => value != option[1]);
145
+ this.setState({
146
+ checkedOptions: newOptions
147
+ });
148
+ }
149
+ console.log({
150
+ checkedOptions: this.s.checkedOptions
151
+ });
152
+ if (this.props.onChange) {
153
+ this.p.onChange({
154
+ checked,
155
+ option
156
+ });
157
+ }
158
+ if (form && name) {
159
+ form.setValue(name, newOptions);
160
+ }
161
+ };
162
+ }));
163
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["shapeComponent","ShapeComponent","React","useMemo","Checkbox","digs","useForm","inflection","InvalidFeedback","memo","PropTypes","propTypesExact","Text","useInput","View","OptionElement","propTypes","checked","bool","isRequired","inputName","string","onChange","func","option","array","render","p","createElement","dataSet","component","name","value","label","onCheckedChange","tt","ApiMakerUtilsCheckboxes","attribute","defaultValue","labelClassName","model","object","options","setup","inputProps","wrapperOpts","props","generatedId","Math","random","toString","substring","setInstance","form","useStates","checkedOptions","Array","isArray","setValue","s","errors","style","fontWeight","map","isChecked","key","onOptionChecked","length","inputDefaultValue","modelClassData","paramKey","underscore","includes","newOptions","concat","setState","filter","console","log"],"sources":["../../src/utils/checkboxes.jsx"],"sourcesContent":["import {shapeComponent, ShapeComponent} from \"set-state-compare/src/shape-component\"\nimport React, {useMemo} from \"react\"\nimport Checkbox from \"./checkbox\"\nimport {digs} from \"diggerize\"\nimport {useForm} from \"../form\"\nimport * as inflection from \"inflection\"\nimport InvalidFeedback from \"./invalid-feedback\"\nimport memo from \"set-state-compare/src/memo\"\nimport PropTypes from \"prop-types\"\nimport propTypesExact from \"prop-types-exact\"\nimport Text from \"./text\"\nimport useInput from \"../use-input\"\nimport {View} from \"react-native\"\n\nconst OptionElement = memo(shapeComponent(class OptionElement extends ShapeComponent {\n  static propTypes = propTypesExact({\n    checked: PropTypes.bool.isRequired,\n    inputName: PropTypes.string.isRequired,\n    onChange: PropTypes.func.isRequired,\n    option: PropTypes.array.isRequired\n  })\n\n  render() {\n    const {checked, inputName, option} = this.p\n\n    return (\n      <View >\n        <Checkbox\n          checked={checked}\n          dataSet={{\n            component: \"api-maker/utils/checkboxes/option\",\n            name: inputName,\n            value: option[1]\n          }}\n          label={option[0]}\n          onCheckedChange={this.tt.onChange}\n        />\n      </View>\n    )\n  }\n\n  onChange = (checked) => this.p.onChange({checked, option: this.p.option})\n}))\n\nexport default memo(shapeComponent(class ApiMakerUtilsCheckboxes extends ShapeComponent {\n  static propTypes = propTypesExact({\n    attribute: PropTypes.string,\n    defaultValue: PropTypes.array,\n    label: PropTypes.string,\n    labelClassName: PropTypes.string,\n    model: PropTypes.object,\n    name: PropTypes.string,\n    onChange: PropTypes.func,\n    options: PropTypes.array.isRequired\n  })\n\n  setup() {\n    const {inputProps, wrapperOpts} = useInput({props: this.props})\n\n    this.generatedId = useMemo(\n      () => Math.random().toString(36).substring(2, 15) + Math.random().toString(36).substring(2, 15),\n      []\n    )\n\n    this.setInstance({\n      form: useForm(),\n      inputProps,\n      wrapperOpts\n    })\n    this.useStates({\n      checkedOptions: () => {\n        if (Array.isArray(this.props.defaultValue)) return this.props.defaultValue\n        if (this.props.defaultValue) return [this.props.defaultValue]\n\n        return []\n      }\n    })\n\n    useMemo(() => {\n      if (this.form && inputProps.name) {\n        this.form.setValue(inputProps.name, this.s.checkedOptions)\n      }\n    }, [])\n  }\n\n  render () {\n    const {wrapperOpts} = this.tt\n    const {errors} = digs(wrapperOpts, \"errors\")\n\n    return (\n      <View dataSet={{component: \"api-maker/utils/checkboxes\"}}>\n        <Text style={{fontWeight: \"bold\"}}>\n          {this.tt.wrapperOpts.label}\n        </Text>\n        {this.props.options.map((option) =>\n          <OptionElement\n            checked={this.isChecked(option)}\n            inputName={this.inputName()}\n            key={option[1]}\n            onChange={this.tt.onOptionChecked}\n            option={option}\n          />\n        )}\n        {errors.length > 0 &&\n          <InvalidFeedback errors={errors} />\n        }\n      </View>\n    )\n  }\n\n  inputDefaultValue () {\n    const {attribute, defaultValue, model} = this.props\n\n    if (defaultValue) {\n      return defaultValue\n    } else if (attribute && model) {\n      if (!model[attribute]) throw `No such attribute: ${attribute}`\n\n      return this.props.model[attribute]()\n    }\n  }\n\n  inputName () {\n    if (this.props.name) {\n      return `${this.props.name}[]`\n    } else if (this.props.model) {\n      return `${this.props.model.modelClassData().paramKey}[${inflection.underscore(this.props.attribute)}]`\n    }\n  }\n\n  isChecked = (option) => this.s.checkedOptions.includes(option[1])\n\n  onOptionChecked = ({checked, option}) => {\n    const {inputProps, form} = this.tt\n    const {name} = inputProps\n    let newOptions\n\n    if (checked) {\n      newOptions = this.s.checkedOptions.concat([option[1]])\n\n      this.setState({checkedOptions: newOptions})\n    } else {\n      newOptions = this.s.checkedOptions.filter((value) => value != option[1])\n\n      this.setState({checkedOptions: newOptions})\n    }\n\n    console.log({checkedOptions: this.s.checkedOptions})\n\n    if (this.props.onChange) {\n      this.p.onChange({checked, option})\n    }\n\n    if (form && name) {\n      form.setValue(name, newOptions)\n    }\n  }\n}))\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,19 @@
1
+ import { shapeComponent, ShapeComponent } from "set-state-compare/src/shape-component";
2
+ import memo from "set-state-compare/src/memo";
3
+ import PropTypes from "prop-types";
4
+ import propTypesExact from "prop-types-exact";
5
+ import React from "react";
6
+ import Text from "./text";
7
+ export default memo(shapeComponent(class ApiMakerUtilsInvalidFeedback extends ShapeComponent {
8
+ static propTypes = propTypesExact({
9
+ message: PropTypes.string.isRequired
10
+ });
11
+ render() {
12
+ return /*#__PURE__*/React.createElement(Text, {
13
+ style: {
14
+ color: "red"
15
+ }
16
+ }, this.p.message);
17
+ }
18
+ }));
19
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJzaGFwZUNvbXBvbmVudCIsIlNoYXBlQ29tcG9uZW50IiwibWVtbyIsIlByb3BUeXBlcyIsInByb3BUeXBlc0V4YWN0IiwiUmVhY3QiLCJUZXh0IiwiQXBpTWFrZXJVdGlsc0ludmFsaWRGZWVkYmFjayIsInByb3BUeXBlcyIsIm1lc3NhZ2UiLCJzdHJpbmciLCJpc1JlcXVpcmVkIiwicmVuZGVyIiwiY3JlYXRlRWxlbWVudCIsInN0eWxlIiwiY29sb3IiLCJwIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL3V0aWxzL2ludmFsaWQtZmVlZGJhY2suanN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7c2hhcGVDb21wb25lbnQsIFNoYXBlQ29tcG9uZW50fSBmcm9tIFwic2V0LXN0YXRlLWNvbXBhcmUvc3JjL3NoYXBlLWNvbXBvbmVudFwiXG5pbXBvcnQgbWVtbyBmcm9tIFwic2V0LXN0YXRlLWNvbXBhcmUvc3JjL21lbW9cIlxuaW1wb3J0IFByb3BUeXBlcyBmcm9tIFwicHJvcC10eXBlc1wiXG5pbXBvcnQgcHJvcFR5cGVzRXhhY3QgZnJvbSBcInByb3AtdHlwZXMtZXhhY3RcIlxuaW1wb3J0IFJlYWN0IGZyb20gXCJyZWFjdFwiXG5pbXBvcnQgVGV4dCBmcm9tIFwiLi90ZXh0XCJcblxuZXhwb3J0IGRlZmF1bHQgbWVtbyhzaGFwZUNvbXBvbmVudChjbGFzcyBBcGlNYWtlclV0aWxzSW52YWxpZEZlZWRiYWNrIGV4dGVuZHMgU2hhcGVDb21wb25lbnQge1xuICBzdGF0aWMgcHJvcFR5cGVzID0gcHJvcFR5cGVzRXhhY3Qoe1xuICAgIG1lc3NhZ2U6IFByb3BUeXBlcy5zdHJpbmcuaXNSZXF1aXJlZFxuICB9KVxuXG4gIHJlbmRlcigpIHtcbiAgICByZXR1cm4gKFxuICAgICAgPFRleHQgc3R5bGU9e3tjb2xvcjogXCJyZWRcIn19PlxuICAgICAgICB7dGhpcy5wLm1lc3NhZ2V9XG4gICAgICA8L1RleHQ+XG4gICAgKVxuICB9XG59KSlcbiJdLCJtYXBwaW5ncyI6IkFBQUEsU0FBUUEsY0FBYyxFQUFFQyxjQUFjLFFBQU8sdUNBQXVDO0FBQ3BGLE9BQU9DLElBQUksTUFBTSw0QkFBNEI7QUFDN0MsT0FBT0MsU0FBUyxNQUFNLFlBQVk7QUFDbEMsT0FBT0MsY0FBYyxNQUFNLGtCQUFrQjtBQUM3QyxPQUFPQyxLQUFLLE1BQU0sT0FBTztBQUN6QixPQUFPQyxJQUFJLE1BQU0sUUFBUTtBQUV6QixlQUFlSixJQUFJLENBQUNGLGNBQWMsQ0FBQyxNQUFNTyw0QkFBNEIsU0FBU04sY0FBYyxDQUFDO0VBQzNGLE9BQU9PLFNBQVMsR0FBR0osY0FBYyxDQUFDO0lBQ2hDSyxPQUFPLEVBQUVOLFNBQVMsQ0FBQ08sTUFBTSxDQUFDQztFQUM1QixDQUFDLENBQUM7RUFFRkMsTUFBTUEsQ0FBQSxFQUFHO0lBQ1Asb0JBQ0VQLEtBQUEsQ0FBQVEsYUFBQSxDQUFDUCxJQUFJO01BQUNRLEtBQUssRUFBRTtRQUFDQyxLQUFLLEVBQUU7TUFBSztJQUFFLEdBQ3pCLElBQUksQ0FBQ0MsQ0FBQyxDQUFDUCxPQUNKLENBQUM7RUFFWDtBQUNGLENBQUMsQ0FBQyxDQUFDIiwiaWdub3JlTGlzdCI6W119
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@kaspernj/api-maker",
3
- "version": "1.0.469",
3
+ "version": "1.0.471",
4
4
  "description": "My new module",
5
5
  "main": "build/index.js",
6
6
  "scripts": {
@@ -77,7 +77,6 @@
77
77
  "i18n-on-steroids": "*",
78
78
  "react": "*",
79
79
  "react-native": "*",
80
- "react-native-vector-icons": "*",
81
- "i18n-on-steroids": "*"
80
+ "react-native-vector-icons": "*"
82
81
  }
83
82
  }
@@ -13,23 +13,40 @@ export default memo(shapeComponent(class ApiMakerUtilsCheckbox extends BaseCompo
13
13
  }
14
14
 
15
15
  static propTypes = propTypesExact({
16
- checked: PropTypes.bool.isRequired,
16
+ checked: PropTypes.bool,
17
17
  dataSet: PropTypes.object,
18
+ defaultChecked: PropTypes.bool,
18
19
  label: PropTypes.string,
19
- onCheckedChange: PropTypes.func.isRequired,
20
+ onCheckedChange: PropTypes.func,
20
21
  style: PropTypes.object
21
22
  })
22
23
 
24
+ setup() {
25
+ this.useStates({
26
+ checked: this.props.defaultChecked
27
+ })
28
+ this.isChecked = this.calculateChecked()
29
+ }
30
+
31
+ calculateChecked() {
32
+ if ("checked" in this.props) {
33
+ return this.p.checked
34
+ } else {
35
+ return this.s.checked
36
+ }
37
+ }
38
+
23
39
  render() {
24
- const {checked, label, onCheckedChange} = this.p
40
+ const {isChecked} = this.tt
41
+ const {label} = this.p
25
42
  const actualStyle = Object.assign(
26
43
  {flexDirection: "row", alignItems: "center"},
27
44
  this.props.style
28
45
  )
29
46
 
30
47
  return (
31
- <View dataSet={{component: "api-maker--utils--checkbox"}} style={actualStyle}>
32
- <CheckBox dataSet={this.props.dataSet} onValueChange={onCheckedChange} value={checked} />
48
+ <View dataSet={{component: "api-maker/utils/checkbox"}} style={actualStyle}>
49
+ <CheckBox dataSet={this.props.dataSet} onValueChange={this.tt.onValueChange} value={isChecked} />
33
50
  {label &&
34
51
  <Pressable onPress={this.tt.onLabelPressed}>
35
52
  <Text style={{marginLeft: 3}}>
@@ -41,5 +58,13 @@ export default memo(shapeComponent(class ApiMakerUtilsCheckbox extends BaseCompo
41
58
  )
42
59
  }
43
60
 
44
- onLabelPressed = () => this.p.onCheckedChange(!this.p.checked)
61
+ onLabelPressed = () => this.p.onCheckedChange(!this.tt.isChecked)
62
+
63
+ onValueChange = (e) => {
64
+ if (this.props.onCheckedChange) {
65
+ this.p.onCheckedChange(e)
66
+ }
67
+
68
+ this.setState({checked: !this.tt.isChecked})
69
+ }
45
70
  }))
@@ -0,0 +1,158 @@
1
+ import {shapeComponent, ShapeComponent} from "set-state-compare/src/shape-component"
2
+ import React, {useMemo} from "react"
3
+ import Checkbox from "./checkbox"
4
+ import {digs} from "diggerize"
5
+ import {useForm} from "../form"
6
+ import * as inflection from "inflection"
7
+ import InvalidFeedback from "./invalid-feedback"
8
+ import memo from "set-state-compare/src/memo"
9
+ import PropTypes from "prop-types"
10
+ import propTypesExact from "prop-types-exact"
11
+ import Text from "./text"
12
+ import useInput from "../use-input"
13
+ import {View} from "react-native"
14
+
15
+ const OptionElement = memo(shapeComponent(class OptionElement extends ShapeComponent {
16
+ static propTypes = propTypesExact({
17
+ checked: PropTypes.bool.isRequired,
18
+ inputName: PropTypes.string.isRequired,
19
+ onChange: PropTypes.func.isRequired,
20
+ option: PropTypes.array.isRequired
21
+ })
22
+
23
+ render() {
24
+ const {checked, inputName, option} = this.p
25
+
26
+ return (
27
+ <View >
28
+ <Checkbox
29
+ checked={checked}
30
+ dataSet={{
31
+ component: "api-maker/utils/checkboxes/option",
32
+ name: inputName,
33
+ value: option[1]
34
+ }}
35
+ label={option[0]}
36
+ onCheckedChange={this.tt.onChange}
37
+ />
38
+ </View>
39
+ )
40
+ }
41
+
42
+ onChange = (checked) => this.p.onChange({checked, option: this.p.option})
43
+ }))
44
+
45
+ export default memo(shapeComponent(class ApiMakerUtilsCheckboxes extends ShapeComponent {
46
+ static propTypes = propTypesExact({
47
+ attribute: PropTypes.string,
48
+ defaultValue: PropTypes.array,
49
+ label: PropTypes.string,
50
+ labelClassName: PropTypes.string,
51
+ model: PropTypes.object,
52
+ name: PropTypes.string,
53
+ onChange: PropTypes.func,
54
+ options: PropTypes.array.isRequired
55
+ })
56
+
57
+ setup() {
58
+ const {inputProps, wrapperOpts} = useInput({props: this.props})
59
+
60
+ this.generatedId = useMemo(
61
+ () => Math.random().toString(36).substring(2, 15) + Math.random().toString(36).substring(2, 15),
62
+ []
63
+ )
64
+
65
+ this.setInstance({
66
+ form: useForm(),
67
+ inputProps,
68
+ wrapperOpts
69
+ })
70
+ this.useStates({
71
+ checkedOptions: () => {
72
+ if (Array.isArray(this.props.defaultValue)) return this.props.defaultValue
73
+ if (this.props.defaultValue) return [this.props.defaultValue]
74
+
75
+ return []
76
+ }
77
+ })
78
+
79
+ useMemo(() => {
80
+ if (this.form && inputProps.name) {
81
+ this.form.setValue(inputProps.name, this.s.checkedOptions)
82
+ }
83
+ }, [])
84
+ }
85
+
86
+ render () {
87
+ const {wrapperOpts} = this.tt
88
+ const {errors} = digs(wrapperOpts, "errors")
89
+
90
+ return (
91
+ <View dataSet={{component: "api-maker/utils/checkboxes"}}>
92
+ <Text style={{fontWeight: "bold"}}>
93
+ {this.tt.wrapperOpts.label}
94
+ </Text>
95
+ {this.props.options.map((option) =>
96
+ <OptionElement
97
+ checked={this.isChecked(option)}
98
+ inputName={this.inputName()}
99
+ key={option[1]}
100
+ onChange={this.tt.onOptionChecked}
101
+ option={option}
102
+ />
103
+ )}
104
+ {errors.length > 0 &&
105
+ <InvalidFeedback errors={errors} />
106
+ }
107
+ </View>
108
+ )
109
+ }
110
+
111
+ inputDefaultValue () {
112
+ const {attribute, defaultValue, model} = this.props
113
+
114
+ if (defaultValue) {
115
+ return defaultValue
116
+ } else if (attribute && model) {
117
+ if (!model[attribute]) throw `No such attribute: ${attribute}`
118
+
119
+ return this.props.model[attribute]()
120
+ }
121
+ }
122
+
123
+ inputName () {
124
+ if (this.props.name) {
125
+ return `${this.props.name}[]`
126
+ } else if (this.props.model) {
127
+ return `${this.props.model.modelClassData().paramKey}[${inflection.underscore(this.props.attribute)}]`
128
+ }
129
+ }
130
+
131
+ isChecked = (option) => this.s.checkedOptions.includes(option[1])
132
+
133
+ onOptionChecked = ({checked, option}) => {
134
+ const {inputProps, form} = this.tt
135
+ const {name} = inputProps
136
+ let newOptions
137
+
138
+ if (checked) {
139
+ newOptions = this.s.checkedOptions.concat([option[1]])
140
+
141
+ this.setState({checkedOptions: newOptions})
142
+ } else {
143
+ newOptions = this.s.checkedOptions.filter((value) => value != option[1])
144
+
145
+ this.setState({checkedOptions: newOptions})
146
+ }
147
+
148
+ console.log({checkedOptions: this.s.checkedOptions})
149
+
150
+ if (this.props.onChange) {
151
+ this.p.onChange({checked, option})
152
+ }
153
+
154
+ if (form && name) {
155
+ form.setValue(name, newOptions)
156
+ }
157
+ }
158
+ }))
@@ -0,0 +1,20 @@
1
+ import {shapeComponent, ShapeComponent} from "set-state-compare/src/shape-component"
2
+ import memo from "set-state-compare/src/memo"
3
+ import PropTypes from "prop-types"
4
+ import propTypesExact from "prop-types-exact"
5
+ import React from "react"
6
+ import Text from "./text"
7
+
8
+ export default memo(shapeComponent(class ApiMakerUtilsInvalidFeedback extends ShapeComponent {
9
+ static propTypes = propTypesExact({
10
+ message: PropTypes.string.isRequired
11
+ })
12
+
13
+ render() {
14
+ return (
15
+ <Text style={{color: "red"}}>
16
+ {this.p.message}
17
+ </Text>
18
+ )
19
+ }
20
+ }))