@kaspernj/api-maker 1.0.470 → 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.
- package/build/router.js +2 -2
- package/build/utils/checkbox.js +33 -10
- package/build/utils/checkboxes.js +163 -0
- package/build/utils/invalid-feedback.js +19 -0
- package/link.sh +8 -0
- package/package.json +2 -3
- package/src/router.jsx +1 -1
- package/src/utils/checkbox.jsx +31 -6
- package/src/utils/checkboxes.jsx +158 -0
- package/src/utils/invalid-feedback.jsx +20 -0
package/build/router.js
CHANGED
|
@@ -45,7 +45,7 @@ export default /*#__PURE__*/memo(shapeComponent(class ApiMakerRouter extends Bas
|
|
|
45
45
|
}
|
|
46
46
|
const Component = requireComponent({
|
|
47
47
|
routeDefinition: matchingRoute.parsedRouteDefinition.routeDefinition
|
|
48
|
-
})
|
|
48
|
+
});
|
|
49
49
|
return /*#__PURE__*/React.createElement(Suspense, {
|
|
50
50
|
fallback: /*#__PURE__*/React.createElement("div", null)
|
|
51
51
|
}, /*#__PURE__*/React.createElement(Component, {
|
|
@@ -53,4 +53,4 @@ export default /*#__PURE__*/memo(shapeComponent(class ApiMakerRouter extends Bas
|
|
|
53
53
|
}));
|
|
54
54
|
}
|
|
55
55
|
}));
|
|
56
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
56
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJCYXNlQ29tcG9uZW50IiwiUHJvcFR5cGVzIiwicHJvcFR5cGVzRXhhY3QiLCJSZWFjdCIsIm1lbW8iLCJTdXNwZW5zZSIsInNoYXBlQ29tcG9uZW50IiwidXNlUGF0aCIsInVzZVJvdXRlciIsIkFwaU1ha2VyUm91dGVyIiwicHJvcFR5cGVzIiwiaGlzdG9yeSIsIm9iamVjdCIsIm5vdEZvdW5kQ29tcG9uZW50IiwiZWxlbWVudFR5cGUiLCJyZXF1aXJlQ29tcG9uZW50IiwiZnVuYyIsImlzUmVxdWlyZWQiLCJyb3V0ZURlZmluaXRpb25zIiwicm91dGVzIiwicmVuZGVyIiwicGF0aCIsInByb3BzIiwibWF0Y2giLCJtYXRjaGluZ1JvdXRlIiwiTm90Rm91bmRDb21wb25lbnQiLCJjcmVhdGVFbGVtZW50IiwiZmFsbGJhY2siLCJDb21wb25lbnQiLCJyb3V0ZURlZmluaXRpb24iLCJwYXJzZWRSb3V0ZURlZmluaXRpb24iXSwic291cmNlcyI6WyIuLi9zcmMvcm91dGVyLmpzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgQmFzZUNvbXBvbmVudCBmcm9tIFwiLi9iYXNlLWNvbXBvbmVudFwiXG5pbXBvcnQgUHJvcFR5cGVzIGZyb20gXCJwcm9wLXR5cGVzXCJcbmltcG9ydCBwcm9wVHlwZXNFeGFjdCBmcm9tIFwicHJvcC10eXBlcy1leGFjdFwiXG5pbXBvcnQgUmVhY3QsIHttZW1vLCBTdXNwZW5zZX0gZnJvbSBcInJlYWN0XCJcbmltcG9ydCB7c2hhcGVDb21wb25lbnR9IGZyb20gXCJzZXQtc3RhdGUtY29tcGFyZS9zcmMvc2hhcGUtY29tcG9uZW50XCJcbmltcG9ydCB1c2VQYXRoIGZyb20gXCJvbi1sb2NhdGlvbi1jaGFuZ2VkL2J1aWxkL3VzZS1wYXRoXCJcbmltcG9ydCB1c2VSb3V0ZXIgZnJvbSBcIi4vdXNlLXJvdXRlclwiXG5cbmV4cG9ydCBkZWZhdWx0IG1lbW8oc2hhcGVDb21wb25lbnQoY2xhc3MgQXBpTWFrZXJSb3V0ZXIgZXh0ZW5kcyBCYXNlQ29tcG9uZW50IHtcbiAgc3RhdGljIHByb3BUeXBlcyA9IHByb3BUeXBlc0V4YWN0KHtcbiAgICBoaXN0b3J5OiBQcm9wVHlwZXMub2JqZWN0LFxuICAgIG5vdEZvdW5kQ29tcG9uZW50OiBQcm9wVHlwZXMuZWxlbWVudFR5cGUsXG4gICAgcmVxdWlyZUNvbXBvbmVudDogUHJvcFR5cGVzLmZ1bmMuaXNSZXF1aXJlZCxcbiAgICByb3V0ZURlZmluaXRpb25zOiBQcm9wVHlwZXMub2JqZWN0LFxuICAgIHJvdXRlczogUHJvcFR5cGVzLm9iamVjdFxuICB9KVxuXG4gIHJlbmRlcigpIHtcbiAgICBjb25zdCBwYXRoID0gdXNlUGF0aCgpXG4gICAgY29uc3Qge25vdEZvdW5kQ29tcG9uZW50LCByZXF1aXJlQ29tcG9uZW50LCByb3V0ZURlZmluaXRpb25zLCByb3V0ZXN9ID0gdGhpcy5wcm9wc1xuICAgIGNvbnN0IHttYXRjaH0gPSB1c2VSb3V0ZXIoe3BhdGgsIHJvdXRlcywgcm91dGVEZWZpbml0aW9uc30pXG4gICAgY29uc3Qge21hdGNoaW5nUm91dGV9ID0gbWF0Y2hcblxuICAgIGlmICghbWF0Y2hpbmdSb3V0ZSkge1xuICAgICAgaWYgKG5vdEZvdW5kQ29tcG9uZW50KSB7XG4gICAgICAgIGNvbnN0IE5vdEZvdW5kQ29tcG9uZW50ID0gbm90Rm91bmRDb21wb25lbnRcblxuICAgICAgICByZXR1cm4gKFxuICAgICAgICAgIDxTdXNwZW5zZSBmYWxsYmFjaz17PGRpdiAvPn0+XG4gICAgICAgICAgICA8Tm90Rm91bmRDb21wb25lbnQgbWF0Y2g9e21hdGNofSAvPlxuICAgICAgICAgIDwvU3VzcGVuc2U+XG4gICAgICAgIClcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIHJldHVybiBudWxsXG4gICAgICB9XG4gICAgfVxuXG4gICAgY29uc3QgQ29tcG9uZW50ID0gcmVxdWlyZUNvbXBvbmVudCh7cm91dGVEZWZpbml0aW9uOiBtYXRjaGluZ1JvdXRlLnBhcnNlZFJvdXRlRGVmaW5pdGlvbi5yb3V0ZURlZmluaXRpb259KVxuXG4gICAgcmV0dXJuIChcbiAgICAgIDxTdXNwZW5zZSBmYWxsYmFjaz17PGRpdiAvPn0+XG4gICAgICAgIDxDb21wb25lbnQgbWF0Y2g9e21hdGNofSAvPlxuICAgICAgPC9TdXNwZW5zZT5cbiAgICApXG4gIH1cbn0pKVxuIl0sIm1hcHBpbmdzIjoiQUFBQSxPQUFPQSxhQUFhLE1BQU0sa0JBQWtCO0FBQzVDLE9BQU9DLFNBQVMsTUFBTSxZQUFZO0FBQ2xDLE9BQU9DLGNBQWMsTUFBTSxrQkFBa0I7QUFDN0MsT0FBT0MsS0FBSyxJQUFHQyxJQUFJLEVBQUVDLFFBQVEsUUFBTyxPQUFPO0FBQzNDLFNBQVFDLGNBQWMsUUFBTyx1Q0FBdUM7QUFDcEUsT0FBT0MsT0FBTyxNQUFNLG9DQUFvQztBQUN4RCxPQUFPQyxTQUFTLE1BQU0sY0FBYztBQUVwQyw0QkFBZUosSUFBSSxDQUFDRSxjQUFjLENBQUMsTUFBTUcsY0FBYyxTQUFTVCxhQUFhLENBQUM7RUFDNUUsT0FBT1UsU0FBUyxHQUFHUixjQUFjLENBQUM7SUFDaENTLE9BQU8sRUFBRVYsU0FBUyxDQUFDVyxNQUFNO0lBQ3pCQyxpQkFBaUIsRUFBRVosU0FBUyxDQUFDYSxXQUFXO0lBQ3hDQyxnQkFBZ0IsRUFBRWQsU0FBUyxDQUFDZSxJQUFJLENBQUNDLFVBQVU7SUFDM0NDLGdCQUFnQixFQUFFakIsU0FBUyxDQUFDVyxNQUFNO0lBQ2xDTyxNQUFNLEVBQUVsQixTQUFTLENBQUNXO0VBQ3BCLENBQUMsQ0FBQztFQUVGUSxNQUFNQSxDQUFBLEVBQUc7SUFDUCxNQUFNQyxJQUFJLEdBQUdkLE9BQU8sQ0FBQyxDQUFDO0lBQ3RCLE1BQU07TUFBQ00saUJBQWlCO01BQUVFLGdCQUFnQjtNQUFFRyxnQkFBZ0I7TUFBRUM7SUFBTSxDQUFDLEdBQUcsSUFBSSxDQUFDRyxLQUFLO0lBQ2xGLE1BQU07TUFBQ0M7SUFBSyxDQUFDLEdBQUdmLFNBQVMsQ0FBQztNQUFDYSxJQUFJO01BQUVGLE1BQU07TUFBRUQ7SUFBZ0IsQ0FBQyxDQUFDO0lBQzNELE1BQU07TUFBQ007SUFBYSxDQUFDLEdBQUdELEtBQUs7SUFFN0IsSUFBSSxDQUFDQyxhQUFhLEVBQUU7TUFDbEIsSUFBSVgsaUJBQWlCLEVBQUU7UUFDckIsTUFBTVksaUJBQWlCLEdBQUdaLGlCQUFpQjtRQUUzQyxvQkFDRVYsS0FBQSxDQUFBdUIsYUFBQSxDQUFDckIsUUFBUTtVQUFDc0IsUUFBUSxlQUFFeEIsS0FBQSxDQUFBdUIsYUFBQSxZQUFNO1FBQUUsZ0JBQzFCdkIsS0FBQSxDQUFBdUIsYUFBQSxDQUFDRCxpQkFBaUI7VUFBQ0YsS0FBSyxFQUFFQTtRQUFNLENBQUUsQ0FDMUIsQ0FBQztNQUVmLENBQUMsTUFBTTtRQUNMLE9BQU8sSUFBSTtNQUNiO0lBQ0Y7SUFFQSxNQUFNSyxTQUFTLEdBQUdiLGdCQUFnQixDQUFDO01BQUNjLGVBQWUsRUFBRUwsYUFBYSxDQUFDTSxxQkFBcUIsQ0FBQ0Q7SUFBZSxDQUFDLENBQUM7SUFFMUcsb0JBQ0UxQixLQUFBLENBQUF1QixhQUFBLENBQUNyQixRQUFRO01BQUNzQixRQUFRLGVBQUV4QixLQUFBLENBQUF1QixhQUFBLFlBQU07SUFBRSxnQkFDMUJ2QixLQUFBLENBQUF1QixhQUFBLENBQUNFLFNBQVM7TUFBQ0wsS0FBSyxFQUFFQTtJQUFNLENBQUUsQ0FDbEIsQ0FBQztFQUVmO0FBQ0YsQ0FBQyxDQUFDLENBQUMiLCJpZ25vcmVMaXN0IjpbXX0=
|
package/build/utils/checkbox.js
CHANGED
|
@@ -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
|
|
14
|
+
checked: PropTypes.bool,
|
|
15
15
|
dataSet: PropTypes.object,
|
|
16
|
+
defaultChecked: PropTypes.bool,
|
|
16
17
|
label: PropTypes.string,
|
|
17
|
-
onCheckedChange: PropTypes.func
|
|
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
|
-
|
|
23
|
-
|
|
24
|
-
|
|
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
|
|
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:
|
|
38
|
-
value:
|
|
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.
|
|
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,
|
|
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/link.sh
ADDED
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@kaspernj/api-maker",
|
|
3
|
-
"version": "1.0.
|
|
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
|
}
|
package/src/router.jsx
CHANGED
|
@@ -35,7 +35,7 @@ export default memo(shapeComponent(class ApiMakerRouter extends BaseComponent {
|
|
|
35
35
|
}
|
|
36
36
|
}
|
|
37
37
|
|
|
38
|
-
const Component = requireComponent({routeDefinition: matchingRoute.parsedRouteDefinition.routeDefinition})
|
|
38
|
+
const Component = requireComponent({routeDefinition: matchingRoute.parsedRouteDefinition.routeDefinition})
|
|
39
39
|
|
|
40
40
|
return (
|
|
41
41
|
<Suspense fallback={<div />}>
|
package/src/utils/checkbox.jsx
CHANGED
|
@@ -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
|
|
16
|
+
checked: PropTypes.bool,
|
|
17
17
|
dataSet: PropTypes.object,
|
|
18
|
+
defaultChecked: PropTypes.bool,
|
|
18
19
|
label: PropTypes.string,
|
|
19
|
-
onCheckedChange: PropTypes.func
|
|
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 {
|
|
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
|
|
32
|
-
<CheckBox dataSet={this.props.dataSet} onValueChange={
|
|
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.
|
|
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
|
+
}))
|