@kaspernj/api-maker 1.0.2048 → 1.0.2050
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/form.js +15 -2
- package/build/merge-styles.js +13 -0
- package/package.json +1 -1
- package/src/form.jsx +16 -2
- package/src/merge-styles.js +15 -0
package/build/form.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
function _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); }
|
|
2
|
-
import React, { createContext, useContext, useMemo } from "react";
|
|
2
|
+
import React, { createContext, useContext, useEffect, useMemo } from "react";
|
|
3
3
|
import BaseComponent from "./base-component";
|
|
4
4
|
import FormDataObjectizer from "form-data-objectizer";
|
|
5
5
|
import memo from "set-state-compare/src/memo";
|
|
@@ -52,6 +52,7 @@ const Form = memo(shapeComponent(class Form extends BaseComponent {
|
|
|
52
52
|
render() {
|
|
53
53
|
const {
|
|
54
54
|
children,
|
|
55
|
+
formObjectRef,
|
|
55
56
|
formRef,
|
|
56
57
|
onSubmit,
|
|
57
58
|
setForm,
|
|
@@ -60,6 +61,18 @@ const Form = memo(shapeComponent(class Form extends BaseComponent {
|
|
|
60
61
|
const form = useMemo(() => new FormInputs({
|
|
61
62
|
onSubmit
|
|
62
63
|
}), []);
|
|
64
|
+
useMemo(() => {
|
|
65
|
+
if (formObjectRef) {
|
|
66
|
+
formObjectRef.current = form;
|
|
67
|
+
}
|
|
68
|
+
}, [form, formObjectRef]);
|
|
69
|
+
useEffect(() => {
|
|
70
|
+
return () => {
|
|
71
|
+
if (formObjectRef) {
|
|
72
|
+
formObjectRef.current = null;
|
|
73
|
+
}
|
|
74
|
+
};
|
|
75
|
+
}, [form, formObjectRef]);
|
|
63
76
|
useMemo(() => {
|
|
64
77
|
if (setForm) {
|
|
65
78
|
setForm(form);
|
|
@@ -80,4 +93,4 @@ const Form = memo(shapeComponent(class Form extends BaseComponent {
|
|
|
80
93
|
};
|
|
81
94
|
}));
|
|
82
95
|
export { Form, FormContext, FormInputs, useForm };
|
|
83
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
96
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","createContext","useContext","useEffect","useMemo","BaseComponent","FormDataObjectizer","memo","Platform","PropTypes","shapeComponent","FormContext","useForm","FormInputs","constructor","props","inputs","onSubmit","asObject","result","formDataObjectizer","key","value","treatInitial","setValue","name","Error","setValueWithHidden","OS","createElement","type","undefined","submit","Form","propTypes","children","node","formRef","object","func","setForm","render","formObjectRef","restProps","form","current","Provider","_extends","ref","tt","onFormSubmit","e","preventDefault"],"sources":["../src/form.jsx"],"sourcesContent":["import React, {createContext, useContext, useEffect, useMemo} from \"react\"\nimport BaseComponent from \"./base-component\"\nimport FormDataObjectizer from \"form-data-objectizer\"\nimport memo from \"set-state-compare/src/memo\"\nimport {Platform} from \"react-native\"\nimport PropTypes from \"prop-types\"\nimport {shapeComponent} from \"set-state-compare/src/shape-component\"\n\nconst FormContext = createContext(null)\nconst useForm = () => useContext(FormContext)\n\nclass FormInputs {\n  constructor(props) {\n    this.inputs = {}\n    this.onSubmit = props?.onSubmit\n  }\n\n  asObject() {\n    const result = {}\n    const formDataObjectizer = new FormDataObjectizer()\n\n    for(const key in this.inputs) {\n      const value = this.inputs[key]\n\n      formDataObjectizer.treatInitial(key, value, result)\n    }\n\n    return result\n  }\n\n  setValue(name, value) {\n    if (!name) throw new Error(\"'name' is required\")\n\n    this.inputs[name] = value\n  }\n\n  setValueWithHidden(name, value) {\n    this.setValue(name, value)\n\n    if (Platform.OS == \"web\") {\n      return <input name={name} type=\"hidden\" value={value !== null && value !== undefined ? value : \"\"} />\n    }\n  }\n\n  submit() {\n    if (this.onSubmit) {\n      this.onSubmit()\n    }\n  }\n}\n\nconst Form = memo(shapeComponent(class Form extends BaseComponent {\n  static propTypes = {\n    children: PropTypes.node,\n    formRef: PropTypes.object,\n    onSubmit: PropTypes.func,\n    setForm: PropTypes.func\n  }\n\n  render() {\n    const {children, formObjectRef, formRef, onSubmit, setForm, ...restProps} = this.props\n    const form = useMemo(() => new FormInputs({onSubmit}), [])\n\n    useMemo(() => {\n      if (formObjectRef) {\n        formObjectRef.current = form\n      }\n    }, [form, formObjectRef])\n\n    useEffect(() => {\n      return () => {\n        if (formObjectRef) {\n          formObjectRef.current = null\n        }\n      }\n    }, [form, formObjectRef])\n\n    useMemo(() => {\n      if (setForm) {\n        setForm(form)\n      }\n    }, [setForm])\n\n    return (\n      <FormContext.Provider value={form}>\n        {Platform.OS == \"web\" &&\n          <form ref={formRef} onSubmit={this.tt.onFormSubmit} {...restProps}>\n            {children}\n          </form>\n        }\n        {Platform.OS != \"web\" && this.props.children}\n      </FormContext.Provider>\n    )\n  }\n\n  onFormSubmit = (e) => {\n    e.preventDefault()\n\n    if (this.props.onSubmit) {\n      this.props.onSubmit()\n    }\n  }\n}))\n\nexport {Form, FormContext, FormInputs, useForm}\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { StyleSheet } from "react-native";
|
|
2
|
+
export default function mergeStyles(stylesList) {
|
|
3
|
+
const mergedStyle = {};
|
|
4
|
+
for (const style of stylesList) {
|
|
5
|
+
if (typeof style == "object") {
|
|
6
|
+
Object.assign(mergedStyle, StyleSheet.flatten(style));
|
|
7
|
+
} else if (style === null) {
|
|
8
|
+
// Ignore - do nothing
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
return mergedStyle;
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJTdHlsZVNoZWV0IiwibWVyZ2VTdHlsZXMiLCJzdHlsZXNMaXN0IiwibWVyZ2VkU3R5bGUiLCJzdHlsZSIsIk9iamVjdCIsImFzc2lnbiIsImZsYXR0ZW4iXSwic291cmNlcyI6WyIuLi9zcmMvbWVyZ2Utc3R5bGVzLmpzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7U3R5bGVTaGVldH0gZnJvbSBcInJlYWN0LW5hdGl2ZVwiXG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIG1lcmdlU3R5bGVzKHN0eWxlc0xpc3QpIHtcbiAgY29uc3QgbWVyZ2VkU3R5bGUgPSB7fVxuXG4gIGZvciAoY29uc3Qgc3R5bGUgb2Ygc3R5bGVzTGlzdCkge1xuICAgIGlmICh0eXBlb2Ygc3R5bGUgPT0gXCJvYmplY3RcIikge1xuICAgICAgT2JqZWN0LmFzc2lnbihtZXJnZWRTdHlsZSwgU3R5bGVTaGVldC5mbGF0dGVuKHN0eWxlKSlcbiAgICB9IGVsc2UgaWYgKHN0eWxlID09PSBudWxsKSB7XG4gICAgICAvLyBJZ25vcmUgLSBkbyBub3RoaW5nXG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIG1lcmdlZFN0eWxlXG59XG4iXSwibWFwcGluZ3MiOiJBQUFBLFNBQVFBLFVBQVUsUUFBTyxjQUFjO0FBRXZDLGVBQWUsU0FBU0MsV0FBV0EsQ0FBQ0MsVUFBVSxFQUFFO0VBQzlDLE1BQU1DLFdBQVcsR0FBRyxDQUFDLENBQUM7RUFFdEIsS0FBSyxNQUFNQyxLQUFLLElBQUlGLFVBQVUsRUFBRTtJQUM5QixJQUFJLE9BQU9FLEtBQUssSUFBSSxRQUFRLEVBQUU7TUFDNUJDLE1BQU0sQ0FBQ0MsTUFBTSxDQUFDSCxXQUFXLEVBQUVILFVBQVUsQ0FBQ08sT0FBTyxDQUFDSCxLQUFLLENBQUMsQ0FBQztJQUN2RCxDQUFDLE1BQU0sSUFBSUEsS0FBSyxLQUFLLElBQUksRUFBRTtNQUN6QjtJQUFBO0VBRUo7RUFFQSxPQUFPRCxXQUFXO0FBQ3BCIiwiaWdub3JlTGlzdCI6W119
|
package/package.json
CHANGED
package/src/form.jsx
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import React, {createContext, useContext, useMemo} from "react"
|
|
1
|
+
import React, {createContext, useContext, useEffect, useMemo} from "react"
|
|
2
2
|
import BaseComponent from "./base-component"
|
|
3
3
|
import FormDataObjectizer from "form-data-objectizer"
|
|
4
4
|
import memo from "set-state-compare/src/memo"
|
|
@@ -58,9 +58,23 @@ const Form = memo(shapeComponent(class Form extends BaseComponent {
|
|
|
58
58
|
}
|
|
59
59
|
|
|
60
60
|
render() {
|
|
61
|
-
const {children, formRef, onSubmit, setForm, ...restProps} = this.props
|
|
61
|
+
const {children, formObjectRef, formRef, onSubmit, setForm, ...restProps} = this.props
|
|
62
62
|
const form = useMemo(() => new FormInputs({onSubmit}), [])
|
|
63
63
|
|
|
64
|
+
useMemo(() => {
|
|
65
|
+
if (formObjectRef) {
|
|
66
|
+
formObjectRef.current = form
|
|
67
|
+
}
|
|
68
|
+
}, [form, formObjectRef])
|
|
69
|
+
|
|
70
|
+
useEffect(() => {
|
|
71
|
+
return () => {
|
|
72
|
+
if (formObjectRef) {
|
|
73
|
+
formObjectRef.current = null
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
}, [form, formObjectRef])
|
|
77
|
+
|
|
64
78
|
useMemo(() => {
|
|
65
79
|
if (setForm) {
|
|
66
80
|
setForm(form)
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import {StyleSheet} from "react-native"
|
|
2
|
+
|
|
3
|
+
export default function mergeStyles(stylesList) {
|
|
4
|
+
const mergedStyle = {}
|
|
5
|
+
|
|
6
|
+
for (const style of stylesList) {
|
|
7
|
+
if (typeof style == "object") {
|
|
8
|
+
Object.assign(mergedStyle, StyleSheet.flatten(style))
|
|
9
|
+
} else if (style === null) {
|
|
10
|
+
// Ignore - do nothing
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
return mergedStyle
|
|
15
|
+
}
|