@kaspernj/api-maker 1.0.2169 → 1.0.2170

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.
@@ -1,11 +1,8 @@
1
1
  export default class ApiMakerBootstrapInvalidFeedback extends React.PureComponent<any, any, any> {
2
- static propTypes: PropTypes.ValidationMap<{
3
- errors: any[];
4
- }>;
2
+ static propTypes: ValidationMap<T>;
5
3
  constructor(props: any);
6
4
  render(): import("react/jsx-runtime").JSX.Element;
7
5
  errorMessages(): any[];
8
6
  }
9
7
  import React from "react";
10
- import PropTypes from "prop-types";
11
8
  //# sourceMappingURL=invalid-feedback.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"invalid-feedback.d.ts","sourceRoot":"/src/","sources":["bootstrap/invalid-feedback.jsx"],"names":[],"mappings":"AAMA;IACE;;OAEE;;IAEF,kDAMC;IAED,uBAWC;CACF;kBA3BiB,OAAO;sBAFH,YAAY"}
1
+ {"version":3,"file":"invalid-feedback.d.ts","sourceRoot":"/src/","sources":["bootstrap/invalid-feedback.jsx"],"names":[],"mappings":"AAMA;IACE,mCAEE;;IAEF,kDAMC;IAED,uBAWC;CACF;kBA3BiB,OAAO"}
@@ -2,12 +2,7 @@ export default class ApiMakerEventConnection extends React.PureComponent<any, an
2
2
  static defaultProps: {
3
3
  active: boolean;
4
4
  };
5
- static propTypes: PropTypes.ValidationMap<{
6
- active: boolean;
7
- model: object;
8
- event: string;
9
- onCall: (...args: any[]) => any;
10
- }>;
5
+ static propTypes: ValidationMap<T>;
11
6
  constructor(props: any);
12
7
  componentDidMount(): void;
13
8
  subscription: import("./cable-subscription.js").default;
@@ -16,5 +11,4 @@ export default class ApiMakerEventConnection extends React.PureComponent<any, an
16
11
  onCall(...args: any[]): void;
17
12
  }
18
13
  import React from "react";
19
- import PropTypes from "prop-types";
20
14
  //# sourceMappingURL=event-connection.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"event-connection.d.ts","sourceRoot":"/src/","sources":["event-connection.jsx"],"names":[],"mappings":"AAMA;IACE;;MAEC;IAED;;;;;OAKE;;IAEF,0BAEC;IADC,wDAA8G;IAGhH,6BAIC;IAED,cAEC;IAED,6BAIC;CACF;kBAlCiB,OAAO;sBADH,YAAY"}
1
+ {"version":3,"file":"event-connection.d.ts","sourceRoot":"/src/","sources":["event-connection.jsx"],"names":[],"mappings":"AAMA;IACE;;MAEC;IAED,mCAKE;;IAEF,0BAEC;IADC,wDAA8G;IAGhH,6BAIC;IAED,cAEC;IAED,6BAIC;CACF;kBAlCiB,OAAO"}
@@ -1,9 +1,5 @@
1
1
  export default class ApiMakerEventModelClass extends React.PureComponent<any, any, any> {
2
- static propTypes: PropTypes.ValidationMap<{
3
- event: string;
4
- modelClass: (...args: any[]) => any;
5
- onCall: (...args: any[]) => any;
6
- }>;
2
+ static propTypes: ValidationMap<T>;
7
3
  constructor(props: any);
8
4
  componentDidMount(): void;
9
5
  componentWillUnmount(): void;
@@ -12,5 +8,4 @@ export default class ApiMakerEventModelClass extends React.PureComponent<any, an
12
8
  render(): any;
13
9
  }
14
10
  import React from "react";
15
- import PropTypes from "prop-types";
16
11
  //# sourceMappingURL=event-model-class.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"event-model-class.d.ts","sourceRoot":"/src/","sources":["event-model-class.jsx"],"names":[],"mappings":"AAMA;IACE;;;;OAIE;;IAEF,0BAEC;IAED,6BAIC;IAED,gBAEC;IADC,sDAA2G;IAG7G,cAEC;CACF;kBA3BiB,OAAO;sBADH,YAAY"}
1
+ {"version":3,"file":"event-model-class.d.ts","sourceRoot":"/src/","sources":["event-model-class.jsx"],"names":[],"mappings":"AAMA;IACE,mCAIE;;IAEF,0BAEC;IAED,6BAIC;IAED,gBAEC;IADC,sDAA2G;IAG7G,cAEC;CACF;kBA3BiB,OAAO"}
@@ -1,16 +1,21 @@
1
1
  declare const _default: React.NamedExoticComponent<Record<string, any>>;
2
2
  export default _default;
3
3
  export type Props = {
4
+ attribute?: string;
4
5
  checked?: boolean;
5
6
  dataSet?: object;
6
7
  defaultChecked?: boolean;
8
+ id?: string;
9
+ inputRef?: object;
7
10
  label?: string;
11
+ model?: object;
12
+ name?: string;
8
13
  onCheckedChange?: Function;
9
14
  style?: object;
10
15
  testID?: string;
11
16
  };
12
17
  export type State = {
13
- checked: boolean | undefined;
18
+ checked: boolean;
14
19
  };
15
20
  import React from "react";
16
21
  //# sourceMappingURL=checkbox.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"checkbox.d.ts","sourceRoot":"/src/","sources":["utils/checkbox.jsx"],"names":[],"mappings":";;;cAac,OAAO;cACP,MAAM;qBACN,OAAO;YACN,MAAM;;YAEN,MAAM;aACN,MAAM;;;aAIP,OAAO,GAAG,SAAS;;kBAnBJ,OAAO"}
1
+ {"version":3,"file":"checkbox.d.ts","sourceRoot":"/src/","sources":["utils/checkbox.jsx"],"names":[],"mappings":";;;gBAec,MAAM;cACN,OAAO;cACP,MAAM;qBACN,OAAO;SACP,MAAM;eACN,MAAM;YACN,MAAM;YACN,MAAM;WACN,MAAM;;YAEN,MAAM;aACN,MAAM;;;aAIN,OAAO;;kBA1BmB,OAAO"}
@@ -3,78 +3,121 @@ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
3
  /* eslint-disable prefer-object-spread, sort-imports */
4
4
  // @ts-expect-error CheckBox removed from react-native core in newer versions
5
5
  import { CheckBox, Pressable, View } from "react-native";
6
- import React, { useMemo } from "react";
6
+ import React, { useEffect, useMemo } from "react";
7
7
  import memo from "set-state-compare/build/memo.js";
8
8
  import PropTypes from "prop-types";
9
9
  import propTypesExact from "prop-types-exact";
10
10
  import { ShapeComponent, shapeComponent } from "set-state-compare/build/shape-component.js";
11
11
  import Text from "./text";
12
+ import { useForm } from "../form";
13
+ import useInput from "../use-input.js";
12
14
  /**
13
15
  * @typedef {object} Props
16
+ * @property {string} [attribute]
14
17
  * @property {boolean} [checked]
15
18
  * @property {object} [dataSet]
16
19
  * @property {boolean} [defaultChecked]
17
- * @property {string} [label]
18
- * @property {Function} [onCheckedChange]
19
- * @property {object} [style]
20
- * @property {string} [testID]
20
+ * @property {string} [id]
21
+ * @property {object} [inputRef]
22
+ * @property {string} [label]
23
+ * @property {object} [model]
24
+ * @property {string} [name]
25
+ * @property {Function} [onCheckedChange]
26
+ * @property {object} [style]
27
+ * @property {string} [testID]
21
28
  */
22
29
  /**
23
30
  * @typedef {object} State
24
- * @property {boolean | undefined} checked
31
+ * @property {boolean} checked
25
32
  */
26
33
  export default memo(shapeComponent(/** @augments {ShapeComponent<Props, State>} */ class ApiMakerUtilsCheckbox extends ShapeComponent {
27
34
  static defaultProps = {
28
35
  dataSet: null,
29
- label: undefined,
30
36
  style: null,
31
37
  testID: undefined
32
38
  };
33
39
  static propTypes = propTypesExact({
40
+ attribute: PropTypes.string,
34
41
  checked: PropTypes.bool,
35
42
  dataSet: PropTypes.object,
36
43
  defaultChecked: PropTypes.bool,
44
+ id: PropTypes.string,
45
+ inputRef: PropTypes.object,
37
46
  label: PropTypes.string,
47
+ model: PropTypes.object,
48
+ name: PropTypes.string,
38
49
  onCheckedChange: PropTypes.func,
39
50
  style: PropTypes.object,
40
51
  testID: PropTypes.string
41
52
  });
42
53
  state = {
43
- checked: this.props.defaultChecked
54
+ checked: this.defaultChecked()
44
55
  };
45
- setup() { }
56
+ setup() {
57
+ const { inputProps, restProps: useInputRestProps, wrapperOpts } = useInput({ props: this.props, wrapperOptions: { type: "checkbox" } });
58
+ const form = useForm();
59
+ const inputName = inputProps.name;
60
+ const initialChecked = this.calculateChecked();
61
+ this.form = form;
62
+ this.inputProps = inputProps;
63
+ this.useInputRestProps = useInputRestProps;
64
+ this.wrapperOpts = wrapperOpts;
65
+ useEffect(() => {
66
+ if (form && inputName) {
67
+ form.setValue(inputName, initialChecked);
68
+ }
69
+ }, [form, inputName]);
70
+ }
46
71
  calculateChecked() {
47
72
  if ("checked" in this.props) {
48
- return this.p.checked;
73
+ return Boolean(this.p.checked);
49
74
  }
50
75
  else {
51
76
  return this.s.checked;
52
77
  }
53
78
  }
54
79
  render() {
55
- const { dataSet, label, style, testID } = this.p;
80
+ const { inputProps, useInputRestProps, wrapperOpts } = this.tt;
81
+ const { attribute, checked, dataSet, defaultChecked, id, inputRef, label, model, name, onCheckedChange, style, testID, ...restProps } = useInputRestProps;
56
82
  const isChecked = this.calculateChecked();
83
+ const actualLabel = typeof label == "undefined" ? wrapperOpts.label : label;
57
84
  const actualStyle = useMemo(() => Object.assign({ flexDirection: "row", alignItems: "center" }, style), [style]);
58
85
  const actualDataSet = useMemo(() => Object.assign({ checked: isChecked }, dataSet), [dataSet, isChecked]);
59
- return (_jsxs(View, { dataSet: this.cache("viewContainerDataSet", { component: "api-maker/utils/checkbox" }), style: actualStyle, children: [_jsx(CheckBox, { dataSet: actualDataSet, onValueChange: this.tt.onValueChange, testID: testID, value: isChecked }), label &&
60
- _jsx(Pressable, { onPress: this.tt.onLabelPressed, children: _jsx(Text, { style: this.cache("textStyle", { marginLeft: 3 }), children: label }) })] }));
86
+ return (_jsxs(View, { dataSet: this.cache("viewContainerDataSet", { component: "api-maker/utils/checkbox" }), style: actualStyle, children: [_jsx(CheckBox, { ...restProps, dataSet: actualDataSet, onValueChange: this.tt.onValueChange, ref: inputProps.ref, testID: testID, value: isChecked }), actualLabel &&
87
+ _jsx(Pressable, { onPress: this.tt.onLabelPressed, children: _jsx(Text, { style: this.cache("textStyle", { marginLeft: 3 }), children: actualLabel }) })] }));
61
88
  }
62
- onLabelPressed = () => {
63
- const newChecked = !this.calculateChecked();
64
- if (this.props.onCheckedChange) {
65
- this.p.onCheckedChange(newChecked);
89
+ defaultChecked() {
90
+ if ("defaultChecked" in this.props) {
91
+ return Boolean(this.props.defaultChecked);
66
92
  }
67
- if (!("checked" in this.props)) {
68
- this.s.checked = newChecked;
93
+ else if (this.props.attribute && this.props.model) {
94
+ if (!this.props.model[this.props.attribute]) {
95
+ throw new Error(`No such attribute: ${this.props.attribute}`);
96
+ }
97
+ return Boolean(this.props.model[this.props.attribute]());
98
+ }
99
+ else {
100
+ return false;
69
101
  }
102
+ }
103
+ onLabelPressed = () => {
104
+ const newChecked = !this.calculateChecked();
105
+ this.setChecked(newChecked);
70
106
  };
71
107
  onValueChange = (newChecked) => {
108
+ this.setChecked(newChecked);
109
+ };
110
+ setChecked(newChecked) {
111
+ const { form, inputProps } = this.tt;
112
+ if (form && inputProps.name) {
113
+ form.setValue(inputProps.name, newChecked);
114
+ }
72
115
  if (this.props.onCheckedChange) {
73
116
  this.p.onCheckedChange(newChecked);
74
117
  }
75
118
  if (!("checked" in this.props)) {
76
119
  this.s.checked = newChecked;
77
120
  }
78
- };
121
+ }
79
122
  }));
80
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2tib3guanMiLCJzb3VyY2VSb290IjoiL3NyYy8iLCJzb3VyY2VzIjpbInV0aWxzL2NoZWNrYm94LmpzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsWUFBWTtBQUNaLHVEQUF1RDtBQUN2RCw2RUFBNkU7QUFDN0UsT0FBTyxFQUFDLFFBQVEsRUFBRSxTQUFTLEVBQUUsSUFBSSxFQUFDLE1BQU0sY0FBYyxDQUFBO0FBQ3RELE9BQU8sS0FBSyxFQUFFLEVBQUMsT0FBTyxFQUFDLE1BQU0sT0FBTyxDQUFBO0FBQ3BDLE9BQU8sSUFBSSxNQUFNLGlDQUFpQyxDQUFBO0FBQ2xELE9BQU8sU0FBUyxNQUFNLFlBQVksQ0FBQTtBQUNsQyxPQUFPLGNBQWMsTUFBTSxrQkFBa0IsQ0FBQTtBQUM3QyxPQUFPLEVBQUMsY0FBYyxFQUFFLGNBQWMsRUFBQyxNQUFNLDRDQUE0QyxDQUFBO0FBQ3pGLE9BQU8sSUFBSSxNQUFNLFFBQVEsQ0FBQTtBQUV6Qjs7Ozs7Ozs7O0dBU0c7QUFDSDs7O0dBR0c7QUFDSCxlQUFlLElBQUksQ0FBQyxjQUFjLENBQUMsK0NBQStDLENBQUMsTUFBTSxxQkFBc0IsU0FBUSxjQUFjO0lBQ25JLE1BQU0sQ0FBQyxZQUFZLEdBQUc7UUFDcEIsT0FBTyxFQUFFLElBQUk7UUFDYixLQUFLLEVBQUUsU0FBUztRQUNoQixLQUFLLEVBQUUsSUFBSTtRQUNYLE1BQU0sRUFBRSxTQUFTO0tBQ2xCLENBQUE7SUFFRCxNQUFNLENBQUMsU0FBUyxHQUFHLGNBQWMsQ0FBQztRQUNoQyxPQUFPLEVBQUUsU0FBUyxDQUFDLElBQUk7UUFDdkIsT0FBTyxFQUFFLFNBQVMsQ0FBQyxNQUFNO1FBQ3pCLGNBQWMsRUFBRSxTQUFTLENBQUMsSUFBSTtRQUM5QixLQUFLLEVBQUUsU0FBUyxDQUFDLE1BQU07UUFDdkIsZUFBZSxFQUFFLFNBQVMsQ0FBQyxJQUFJO1FBQy9CLEtBQUssRUFBRSxTQUFTLENBQUMsTUFBTTtRQUN2QixNQUFNLEVBQUUsU0FBUyxDQUFDLE1BQU07S0FDekIsQ0FBQyxDQUFBO0lBQ0YsS0FBSyxHQUFHO1FBQ04sT0FBTyxFQUFFLElBQUksQ0FBQyxLQUFLLENBQUMsY0FBYztLQUNuQyxDQUFBO0lBRUQsS0FBSyxLQUFJLENBQUM7SUFFVixnQkFBZ0I7UUFDZCxJQUFJLFNBQVMsSUFBSSxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUM7WUFDNUIsT0FBTyxJQUFJLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQTtRQUN2QixDQUFDO2FBQU0sQ0FBQztZQUNOLE9BQU8sSUFBSSxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUE7UUFDdkIsQ0FBQztJQUNILENBQUM7SUFFRCxNQUFNO1FBQ0osTUFBTSxFQUFDLE9BQU8sRUFBRSxLQUFLLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBQyxHQUFHLElBQUksQ0FBQyxDQUFDLENBQUE7UUFDOUMsTUFBTSxTQUFTLEdBQUcsSUFBSSxDQUFDLGdCQUFnQixFQUFFLENBQUE7UUFDekMsTUFBTSxXQUFXLEdBQUcsT0FBTyxDQUFDLEdBQUcsRUFBRSxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsRUFBQyxhQUFhLEVBQUUsS0FBSyxFQUFFLFVBQVUsRUFBRSxRQUFRLEVBQUMsRUFBRSxLQUFLLENBQUMsRUFBRSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUE7UUFDOUcsTUFBTSxhQUFhLEdBQUcsT0FBTyxDQUFDLEdBQUcsRUFBRSxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsRUFBQyxPQUFPLEVBQUUsU0FBUyxFQUFDLEVBQUUsT0FBTyxDQUFDLEVBQUUsQ0FBQyxPQUFPLEVBQUUsU0FBUyxDQUFDLENBQUMsQ0FBQTtRQUV2RyxPQUFPLENBQ0wsTUFBQyxJQUFJLElBQ0gsT0FBTyxFQUFFLElBQUksQ0FBQyxLQUFLLENBQUMsc0JBQXNCLEVBQUUsRUFBQyxTQUFTLEVBQUUsMEJBQTBCLEVBQUMsQ0FBQyxFQUNwRixLQUFLLEVBQUUsV0FBVyxhQUVsQixLQUFDLFFBQVEsSUFBQyxPQUFPLEVBQUUsYUFBYSxFQUFFLGFBQWEsRUFBRSxJQUFJLENBQUMsRUFBRSxDQUFDLGFBQWEsRUFBRSxNQUFNLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxTQUFTLEdBQUksRUFDM0csS0FBSztvQkFDSixLQUFDLFNBQVMsSUFBQyxPQUFPLEVBQUUsSUFBSSxDQUFDLEVBQUUsQ0FBQyxjQUFjLFlBQ3hDLEtBQUMsSUFBSSxJQUFDLEtBQUssRUFBRSxJQUFJLENBQUMsS0FBSyxDQUFDLFdBQVcsRUFBRSxFQUFDLFVBQVUsRUFBRSxDQUFDLEVBQUMsQ0FBQyxZQUNsRCxLQUFLLEdBQ0QsR0FDRyxJQUVULENBQ1IsQ0FBQTtJQUNILENBQUM7SUFFRCxjQUFjLEdBQUcsR0FBRyxFQUFFO1FBQ3BCLE1BQU0sVUFBVSxHQUFHLENBQUMsSUFBSSxDQUFDLGdCQUFnQixFQUFFLENBQUE7UUFFM0MsSUFBSSxJQUFJLENBQUMsS0FBSyxDQUFDLGVBQWUsRUFBRSxDQUFDO1lBQy9CLElBQUksQ0FBQyxDQUFDLENBQUMsZUFBZSxDQUFDLFVBQVUsQ0FBQyxDQUFBO1FBQ3BDLENBQUM7UUFFRCxJQUFJLENBQUMsQ0FBQyxTQUFTLElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUM7WUFDL0IsSUFBSSxDQUFDLENBQUMsQ0FBQyxPQUFPLEdBQUcsVUFBVSxDQUFBO1FBQzdCLENBQUM7SUFDSCxDQUFDLENBQUE7SUFFRCxhQUFhLEdBQUcsQ0FBQyxVQUFVLEVBQUUsRUFBRTtRQUM3QixJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsZUFBZSxFQUFFLENBQUM7WUFDL0IsSUFBSSxDQUFDLENBQUMsQ0FBQyxlQUFlLENBQUMsVUFBVSxDQUFDLENBQUE7UUFDcEMsQ0FBQztRQUVELElBQUksQ0FBQyxDQUFDLFNBQVMsSUFBSSxJQUFJLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQztZQUMvQixJQUFJLENBQUMsQ0FBQyxDQUFDLE9BQU8sR0FBRyxVQUFVLENBQUE7UUFDN0IsQ0FBQztJQUNILENBQUMsQ0FBQTtDQUNGLENBQUMsQ0FBQyxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiLy8gQHRzLWNoZWNrXG4vKiBlc2xpbnQtZGlzYWJsZSBwcmVmZXItb2JqZWN0LXNwcmVhZCwgc29ydC1pbXBvcnRzICovXG4vLyBAdHMtZXhwZWN0LWVycm9yIENoZWNrQm94IHJlbW92ZWQgZnJvbSByZWFjdC1uYXRpdmUgY29yZSBpbiBuZXdlciB2ZXJzaW9uc1xuaW1wb3J0IHtDaGVja0JveCwgUHJlc3NhYmxlLCBWaWV3fSBmcm9tIFwicmVhY3QtbmF0aXZlXCJcbmltcG9ydCBSZWFjdCwge3VzZU1lbW99IGZyb20gXCJyZWFjdFwiXG5pbXBvcnQgbWVtbyBmcm9tIFwic2V0LXN0YXRlLWNvbXBhcmUvYnVpbGQvbWVtby5qc1wiXG5pbXBvcnQgUHJvcFR5cGVzIGZyb20gXCJwcm9wLXR5cGVzXCJcbmltcG9ydCBwcm9wVHlwZXNFeGFjdCBmcm9tIFwicHJvcC10eXBlcy1leGFjdFwiXG5pbXBvcnQge1NoYXBlQ29tcG9uZW50LCBzaGFwZUNvbXBvbmVudH0gZnJvbSBcInNldC1zdGF0ZS1jb21wYXJlL2J1aWxkL3NoYXBlLWNvbXBvbmVudC5qc1wiXG5pbXBvcnQgVGV4dCBmcm9tIFwiLi90ZXh0XCJcblxuLyoqXG4gKiBAdHlwZWRlZiB7b2JqZWN0fSBQcm9wc1xuICogQHByb3BlcnR5IHtib29sZWFufSBbY2hlY2tlZF1cbiAqIEBwcm9wZXJ0eSB7b2JqZWN0fSBbZGF0YVNldF1cbiAqIEBwcm9wZXJ0eSB7Ym9vbGVhbn0gW2RlZmF1bHRDaGVja2VkXVxuICAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBbbGFiZWxdXG4gICogQHByb3BlcnR5IHtGdW5jdGlvbn0gW29uQ2hlY2tlZENoYW5nZV1cbiAgKiBAcHJvcGVydHkge29iamVjdH0gW3N0eWxlXVxuICAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBbdGVzdElEXVxuICovXG4vKipcbiAqIEB0eXBlZGVmIHtvYmplY3R9IFN0YXRlXG4gKiBAcHJvcGVydHkge2Jvb2xlYW4gfCB1bmRlZmluZWR9IGNoZWNrZWRcbiAqL1xuZXhwb3J0IGRlZmF1bHQgbWVtbyhzaGFwZUNvbXBvbmVudCgvKiogQGF1Z21lbnRzIHtTaGFwZUNvbXBvbmVudDxQcm9wcywgU3RhdGU+fSAqLyBjbGFzcyBBcGlNYWtlclV0aWxzQ2hlY2tib3ggZXh0ZW5kcyBTaGFwZUNvbXBvbmVudCB7XG4gIHN0YXRpYyBkZWZhdWx0UHJvcHMgPSB7XG4gICAgZGF0YVNldDogbnVsbCxcbiAgICBsYWJlbDogdW5kZWZpbmVkLFxuICAgIHN0eWxlOiBudWxsLFxuICAgIHRlc3RJRDogdW5kZWZpbmVkXG4gIH1cblxuICBzdGF0aWMgcHJvcFR5cGVzID0gcHJvcFR5cGVzRXhhY3Qoe1xuICAgIGNoZWNrZWQ6IFByb3BUeXBlcy5ib29sLFxuICAgIGRhdGFTZXQ6IFByb3BUeXBlcy5vYmplY3QsXG4gICAgZGVmYXVsdENoZWNrZWQ6IFByb3BUeXBlcy5ib29sLFxuICAgIGxhYmVsOiBQcm9wVHlwZXMuc3RyaW5nLFxuICAgIG9uQ2hlY2tlZENoYW5nZTogUHJvcFR5cGVzLmZ1bmMsXG4gICAgc3R5bGU6IFByb3BUeXBlcy5vYmplY3QsXG4gICAgdGVzdElEOiBQcm9wVHlwZXMuc3RyaW5nXG4gIH0pXG4gIHN0YXRlID0ge1xuICAgIGNoZWNrZWQ6IHRoaXMucHJvcHMuZGVmYXVsdENoZWNrZWRcbiAgfVxuXG4gIHNldHVwKCkge31cblxuICBjYWxjdWxhdGVDaGVja2VkKCkge1xuICAgIGlmIChcImNoZWNrZWRcIiBpbiB0aGlzLnByb3BzKSB7XG4gICAgICByZXR1cm4gdGhpcy5wLmNoZWNrZWRcbiAgICB9IGVsc2Uge1xuICAgICAgcmV0dXJuIHRoaXMucy5jaGVja2VkXG4gICAgfVxuICB9XG5cbiAgcmVuZGVyKCkge1xuICAgIGNvbnN0IHtkYXRhU2V0LCBsYWJlbCwgc3R5bGUsIHRlc3RJRH0gPSB0aGlzLnBcbiAgICBjb25zdCBpc0NoZWNrZWQgPSB0aGlzLmNhbGN1bGF0ZUNoZWNrZWQoKVxuICAgIGNvbnN0IGFjdHVhbFN0eWxlID0gdXNlTWVtbygoKSA9PiBPYmplY3QuYXNzaWduKHtmbGV4RGlyZWN0aW9uOiBcInJvd1wiLCBhbGlnbkl0ZW1zOiBcImNlbnRlclwifSwgc3R5bGUpLCBbc3R5bGVdKVxuICAgIGNvbnN0IGFjdHVhbERhdGFTZXQgPSB1c2VNZW1vKCgpID0+IE9iamVjdC5hc3NpZ24oe2NoZWNrZWQ6IGlzQ2hlY2tlZH0sIGRhdGFTZXQpLCBbZGF0YVNldCwgaXNDaGVja2VkXSlcblxuICAgIHJldHVybiAoXG4gICAgICA8Vmlld1xuICAgICAgICBkYXRhU2V0PXt0aGlzLmNhY2hlKFwidmlld0NvbnRhaW5lckRhdGFTZXRcIiwge2NvbXBvbmVudDogXCJhcGktbWFrZXIvdXRpbHMvY2hlY2tib3hcIn0pfVxuICAgICAgICBzdHlsZT17YWN0dWFsU3R5bGV9XG4gICAgICA+XG4gICAgICAgIDxDaGVja0JveCBkYXRhU2V0PXthY3R1YWxEYXRhU2V0fSBvblZhbHVlQ2hhbmdlPXt0aGlzLnR0Lm9uVmFsdWVDaGFuZ2V9IHRlc3RJRD17dGVzdElEfSB2YWx1ZT17aXNDaGVja2VkfSAvPlxuICAgICAgICB7bGFiZWwgJiZcbiAgICAgICAgICA8UHJlc3NhYmxlIG9uUHJlc3M9e3RoaXMudHQub25MYWJlbFByZXNzZWR9PlxuICAgICAgICAgICAgPFRleHQgc3R5bGU9e3RoaXMuY2FjaGUoXCJ0ZXh0U3R5bGVcIiwge21hcmdpbkxlZnQ6IDN9KX0+XG4gICAgICAgICAgICAgIHtsYWJlbH1cbiAgICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgICA8L1ByZXNzYWJsZT5cbiAgICAgICAgfVxuICAgICAgPC9WaWV3PlxuICAgIClcbiAgfVxuXG4gIG9uTGFiZWxQcmVzc2VkID0gKCkgPT4ge1xuICAgIGNvbnN0IG5ld0NoZWNrZWQgPSAhdGhpcy5jYWxjdWxhdGVDaGVja2VkKClcblxuICAgIGlmICh0aGlzLnByb3BzLm9uQ2hlY2tlZENoYW5nZSkge1xuICAgICAgdGhpcy5wLm9uQ2hlY2tlZENoYW5nZShuZXdDaGVja2VkKVxuICAgIH1cblxuICAgIGlmICghKFwiY2hlY2tlZFwiIGluIHRoaXMucHJvcHMpKSB7XG4gICAgICB0aGlzLnMuY2hlY2tlZCA9IG5ld0NoZWNrZWRcbiAgICB9XG4gIH1cblxuICBvblZhbHVlQ2hhbmdlID0gKG5ld0NoZWNrZWQpID0+IHtcbiAgICBpZiAodGhpcy5wcm9wcy5vbkNoZWNrZWRDaGFuZ2UpIHtcbiAgICAgIHRoaXMucC5vbkNoZWNrZWRDaGFuZ2UobmV3Q2hlY2tlZClcbiAgICB9XG5cbiAgICBpZiAoIShcImNoZWNrZWRcIiBpbiB0aGlzLnByb3BzKSkge1xuICAgICAgdGhpcy5zLmNoZWNrZWQgPSBuZXdDaGVja2VkXG4gICAgfVxuICB9XG59KSlcbiJdfQ==
123
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checkbox.js","sourceRoot":"/src/","sources":["utils/checkbox.jsx"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n/* eslint-disable prefer-object-spread, sort-imports */\n// @ts-expect-error CheckBox removed from react-native core in newer versions\nimport {CheckBox, Pressable, View} from \"react-native\"\nimport React, {useEffect, useMemo} from \"react\"\nimport memo from \"set-state-compare/build/memo.js\"\nimport PropTypes from \"prop-types\"\nimport propTypesExact from \"prop-types-exact\"\nimport {ShapeComponent, shapeComponent} from \"set-state-compare/build/shape-component.js\"\nimport Text from \"./text\"\nimport {useForm} from \"../form\"\nimport useInput from \"../use-input.js\"\n\n/**\n * @typedef {object} Props\n * @property {string} [attribute]\n * @property {boolean} [checked]\n * @property {object} [dataSet]\n * @property {boolean} [defaultChecked]\n * @property {string} [id]\n * @property {object} [inputRef]\n * @property {string} [label]\n * @property {object} [model]\n * @property {string} [name]\n * @property {Function} [onCheckedChange]\n * @property {object} [style]\n * @property {string} [testID]\n */\n/**\n * @typedef {object} State\n * @property {boolean} checked\n */\nexport default memo(shapeComponent(/** @augments {ShapeComponent<Props, State>} */ class ApiMakerUtilsCheckbox extends ShapeComponent {\n  static defaultProps = {\n    dataSet: null,\n    style: null,\n    testID: undefined\n  }\n\n  static propTypes = propTypesExact({\n    attribute: PropTypes.string,\n    checked: PropTypes.bool,\n    dataSet: PropTypes.object,\n    defaultChecked: PropTypes.bool,\n    id: PropTypes.string,\n    inputRef: PropTypes.object,\n    label: PropTypes.string,\n    model: PropTypes.object,\n    name: PropTypes.string,\n    onCheckedChange: PropTypes.func,\n    style: PropTypes.object,\n    testID: PropTypes.string\n  })\n\n  state = {\n    checked: this.defaultChecked()\n  }\n\n  setup() {\n    const {inputProps, restProps: useInputRestProps, wrapperOpts} = useInput({props: this.props, wrapperOptions: {type: \"checkbox\"}})\n    const form = useForm()\n    const inputName = inputProps.name\n    const initialChecked = this.calculateChecked()\n\n    this.form = form\n    this.inputProps = inputProps\n    this.useInputRestProps = useInputRestProps\n    this.wrapperOpts = wrapperOpts\n\n    useEffect(() => {\n      if (form && inputName) {\n        form.setValue(inputName, initialChecked)\n      }\n    }, [form, inputName])\n  }\n\n  calculateChecked() {\n    if (\"checked\" in this.props) {\n      return Boolean(this.p.checked)\n    } else {\n      return this.s.checked\n    }\n  }\n\n  render() {\n    const {inputProps, useInputRestProps, wrapperOpts} = this.tt\n    const {\n      attribute,\n      checked,\n      dataSet,\n      defaultChecked,\n      id,\n      inputRef,\n      label,\n      model,\n      name,\n      onCheckedChange,\n      style,\n      testID,\n      ...restProps\n    } = useInputRestProps\n    const isChecked = this.calculateChecked()\n    const actualLabel = typeof label == \"undefined\" ? wrapperOpts.label : label\n    const actualStyle = useMemo(() => Object.assign({flexDirection: \"row\", alignItems: \"center\"}, style), [style])\n    const actualDataSet = useMemo(() => Object.assign({checked: isChecked}, dataSet), [dataSet, isChecked])\n\n    return (\n      <View\n        dataSet={this.cache(\"viewContainerDataSet\", {component: \"api-maker/utils/checkbox\"})}\n        style={actualStyle}\n      >\n        <CheckBox\n          {...restProps}\n          dataSet={actualDataSet}\n          onValueChange={this.tt.onValueChange}\n          ref={inputProps.ref}\n          testID={testID}\n          value={isChecked}\n        />\n        {actualLabel &&\n          <Pressable onPress={this.tt.onLabelPressed}>\n            <Text style={this.cache(\"textStyle\", {marginLeft: 3})}>\n              {actualLabel}\n            </Text>\n          </Pressable>\n        }\n      </View>\n    )\n  }\n\n  defaultChecked() {\n    if (\"defaultChecked\" in this.props) {\n      return Boolean(this.props.defaultChecked)\n    } else if (this.props.attribute && this.props.model) {\n      if (!this.props.model[this.props.attribute]) {\n        throw new Error(`No such attribute: ${this.props.attribute}`)\n      }\n\n      return Boolean(this.props.model[this.props.attribute]())\n    } else {\n      return false\n    }\n  }\n\n  onLabelPressed = () => {\n    const newChecked = !this.calculateChecked()\n\n    this.setChecked(newChecked)\n  }\n\n  onValueChange = (newChecked) => {\n    this.setChecked(newChecked)\n  }\n\n  setChecked(newChecked) {\n    const {form, inputProps} = this.tt\n\n    if (form && inputProps.name) {\n      form.setValue(inputProps.name, newChecked)\n    }\n\n    if (this.props.onCheckedChange) {\n      this.p.onCheckedChange(newChecked)\n    }\n\n    if (!(\"checked\" in this.props)) {\n      this.s.checked = newChecked\n    }\n  }\n}))\n"]}
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@kaspernj/api-maker",
3
3
  "type": "module",
4
- "version": "1.0.2169",
4
+ "version": "1.0.2170",
5
5
  "description": "My new module",
6
6
  "files": [
7
7
  "build/**"