@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.
- package/build/bootstrap/invalid-feedback.d.ts +1 -4
- package/build/bootstrap/invalid-feedback.d.ts.map +1 -1
- package/build/event-connection.d.ts +1 -7
- package/build/event-connection.d.ts.map +1 -1
- package/build/event-model-class.d.ts +1 -6
- package/build/event-model-class.d.ts.map +1 -1
- package/build/utils/checkbox.d.ts +6 -1
- package/build/utils/checkbox.d.ts.map +1 -1
- package/build/utils/checkbox.js +64 -21
- package/package.json +1 -1
|
@@ -1,11 +1,8 @@
|
|
|
1
1
|
export default class ApiMakerBootstrapInvalidFeedback extends React.PureComponent<any, any, any> {
|
|
2
|
-
static propTypes:
|
|
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;;
|
|
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:
|
|
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
|
|
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:
|
|
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
|
|
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
|
|
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":";;;
|
|
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"}
|
package/build/utils/checkbox.js
CHANGED
|
@@ -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
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
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
|
|
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.
|
|
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 {
|
|
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 }),
|
|
60
|
-
_jsx(Pressable, { onPress: this.tt.onLabelPressed, children: _jsx(Text, { style: this.cache("textStyle", { marginLeft: 3 }), children:
|
|
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
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
this.p.onCheckedChange(newChecked);
|
|
89
|
+
defaultChecked() {
|
|
90
|
+
if ("defaultChecked" in this.props) {
|
|
91
|
+
return Boolean(this.props.defaultChecked);
|
|
66
92
|
}
|
|
67
|
-
if (
|
|
68
|
-
this.
|
|
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2tib3guanMiLCJzb3VyY2VSb290IjoiL3NyYy8iLCJzb3VyY2VzIjpbInV0aWxzL2NoZWNrYm94LmpzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsWUFBWTtBQUNaLHVEQUF1RDtBQUN2RCw2RUFBNkU7QUFDN0UsT0FBTyxFQUFDLFFBQVEsRUFBRSxTQUFTLEVBQUUsSUFBSSxFQUFDLE1BQU0sY0FBYyxDQUFBO0FBQ3RELE9BQU8sS0FBSyxFQUFFLEVBQUMsT0FBTyxFQUFDLE1BQU0sT0FBTyxDQUFBO0FBQ3BDLE9BQU8sSUFBSSxNQUFNLGlDQUFpQyxDQUFBO0FBQ2xELE9BQU8sU0FBUyxNQUFNLFlBQVksQ0FBQTtBQUNsQyxPQUFPLGNBQWMsTUFBTSxrQkFBa0IsQ0FBQTtBQUM3QyxPQUFPLEVBQUMsY0FBYyxFQUFFLGNBQWMsRUFBQyxNQUFNLDRDQUE0QyxDQUFBO0FBQ3pGLE9BQU8sSUFBSSxNQUFNLFFBQVEsQ0FBQTtBQUV6Qjs7Ozs7Ozs7O0dBU0c7QUFDSDs7O0dBR0c7QUFDSCxlQUFlLElBQUksQ0FBQyxjQUFjLENBQUMsK0NBQStDLENBQUMsTUFBTSxxQkFBc0IsU0FBUSxjQUFjO0lBQ25JLE1BQU0sQ0FBQyxZQUFZLEdBQUc7UUFDcEIsT0FBTyxFQUFFLElBQUk7UUFDYixLQUFLLEVBQUUsU0FBUztRQUNoQixLQUFLLEVBQUUsSUFBSTtRQUNYLE1BQU0sRUFBRSxTQUFTO0tBQ2xCLENBQUE7SUFFRCxNQUFNLENBQUMsU0FBUyxHQUFHLGNBQWMsQ0FBQztRQUNoQyxPQUFPLEVBQUUsU0FBUyxDQUFDLElBQUk7UUFDdkIsT0FBTyxFQUFFLFNBQVMsQ0FBQyxNQUFNO1FBQ3pCLGNBQWMsRUFBRSxTQUFTLENBQUMsSUFBSTtRQUM5QixLQUFLLEVBQUUsU0FBUyxDQUFDLE1BQU07UUFDdkIsZUFBZSxFQUFFLFNBQVMsQ0FBQyxJQUFJO1FBQy9CLEtBQUssRUFBRSxTQUFTLENBQUMsTUFBTTtRQUN2QixNQUFNLEVBQUUsU0FBUyxDQUFD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c0NvbnRlbnQiOlsiLy8gQHRzLWNoZWNrXG4vKiBlc2xpbnQtZGlzYWJsZSBwcmVmZXItb2JqZWN0LXNwcmVhZCwgc29ydC1pbXBvcnRzICovXG4vLyBAdHMtZXhwZWN0LWVycm9yIENoZWNrQm94IHJlbW92ZWQgZnJvbSByZWFjdC1uYXRpdmUgY29yZSBpbiBuZXdlciB2ZXJzaW9uc1xuaW1wb3J0IHtDaGVja0JveCwgUHJlc3NhYmxlLCBWaWV3fSBmcm9tIFwicmVhY3QtbmF0aXZlXCJcbmltcG9ydCBSZWFjdCwge3VzZU1lbW99IGZyb20gXCJyZWFjdFwiXG5pbXBvcnQgbWVtbyBmcm9tIFwic2V0LXN0YXRlLWNvbXBhcmUvYnVpbGQvbWVtby5qc1wiXG5pbXBvcnQgUHJvcFR5cGVzIGZyb20gXCJwcm9wLXR5cGVzXCJcbmltcG9ydCBwcm9wVHlwZXNFeGFjdCBmcm9tIFwicHJvcC10eXBlcy1leGFjdFwiXG5pbXBvcnQge1NoYXBlQ29tcG9uZW50LCBzaGFwZUNvbXBvbmVudH0gZnJvbSBcInNldC1zdGF0ZS1jb21wYXJlL2J1aWxkL3NoYXBlLWNvbXBvbmVudC5qc1wiXG5pbXBvcnQgVGV4dCBmcm9tIFwiLi90ZXh0XCJcblxuLyoqXG4gKiBAdHlwZWRlZiB7b2JqZWN0fSBQcm9wc1xuICogQHByb3BlcnR5IHtib29sZWFufSBbY2hlY2tlZF1cbiAqIEBwcm9wZXJ0eSB7b2JqZWN0fSBbZGF0YVNldF1cbiAqIEBwcm9wZXJ0eSB7Ym9vbGVhbn0gW2RlZmF1bHRDaGVja2VkXVxuICAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBbbGFiZWxdXG4gICogQHByb3BlcnR5IHtGdW5jdGlvbn0gW29uQ2hlY2tlZENoYW5nZV1cbiAgKiBAcHJvcGVydHkge29iamVjdH0gW3N0eWxlXVxuICAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBbdGVzdElEXVxuICovXG4vKipcbiAqIEB0eXBlZGVmIHtvYmplY3R9IFN0YXRlXG4gKiBAcHJvcGVydHkge2Jvb2xlYW4gfCB1bmRlZmluZWR9IGNoZWNrZWRcbiAqL1xuZXhwb3J0IGRlZmF1bHQgbWVtbyhzaGFwZUNvbXBvbmVudCgvKiogQGF1Z21lbnRzIHtTaGFwZUNvbXBvbmVudDxQcm9wcywgU3RhdGU+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"]}
|