@kaspernj/api-maker 1.0.381 → 1.0.383

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,4 +1,4 @@
1
- import {useCallback, useEffect, useMemo} from "react"
1
+ import {useCallback, useMemo} from "react"
2
2
  import debounceFunction from "debounce"
3
3
  import ModelEvents from "./model-events.mjs"
4
4
  import useShape from "set-state-compare/src/use-shape.js"
@@ -34,7 +34,7 @@ const apiMakerUseDestroyedEvent = (model, onDestroyed, props) => {
34
34
  }
35
35
  }, [])
36
36
 
37
- useEffect(() => {
37
+ useMemo(() => {
38
38
  let connectDestroyed, onConnectedListener
39
39
 
40
40
  if (model) {
@@ -1,7 +1,7 @@
1
- import {useEffect} from "react"
1
+ import {useMemo} from "react"
2
2
 
3
3
  const ApiMakerUseEventEmitter = (events, event, onCalled) => {
4
- useEffect(() => {
4
+ useMemo(() => {
5
5
  if (events) {
6
6
  events.addListener(event, onCalled)
7
7
 
@@ -1,11 +1,11 @@
1
- import {useCallback, useEffect} from "react"
1
+ import {useCallback, useMemo} from "react"
2
2
 
3
3
  const ApiMakerUseEventListener = (target, event, onCalled) => {
4
4
  const onCalledCallback = useCallback((...args) => {
5
5
  onCalled.apply(null, args)
6
6
  }, [target, event, onCalled])
7
7
 
8
- useEffect(() => {
8
+ useMemo(() => {
9
9
  if (target) {
10
10
  target.addEventListener(event, onCalledCallback)
11
11
 
package/src/use-model.mjs CHANGED
@@ -1,4 +1,4 @@
1
- import {useCallback, useEffect, useState} from "react"
1
+ import {useCallback, useMemo, useState} from "react"
2
2
  import Devise from "./devise.mjs"
3
3
  import * as inflection from "inflection"
4
4
  import ModelEvents from "./model-events.mjs"
@@ -90,12 +90,12 @@ const useModel = (modelClassArg, argsArg = {}) => {
90
90
  }
91
91
  }, [])
92
92
 
93
- useEffect(
93
+ useMemo(
94
94
  () => { loadModel() },
95
95
  cacheArgs
96
96
  )
97
97
 
98
- useEffect(() => {
98
+ useMemo(() => {
99
99
  let reloadModelCallback
100
100
 
101
101
  if (args.events) {
@@ -109,7 +109,7 @@ const useModel = (modelClassArg, argsArg = {}) => {
109
109
  }
110
110
  }, [args.events])
111
111
 
112
- useEffect(() => {
112
+ useMemo(() => {
113
113
  let connectUpdated
114
114
 
115
115
  if (model && args.eventUpdated) {
@@ -129,7 +129,7 @@ const useModel = (modelClassArg, argsArg = {}) => {
129
129
  loadModel()
130
130
  }, [])
131
131
 
132
- useEffect(() => {
132
+ useMemo(() => {
133
133
  Devise.events().addListener("onDeviseSignIn", onSignedIn)
134
134
  Devise.events().addListener("onDeviseSignOut", onSignedOut)
135
135
 
@@ -147,7 +147,7 @@ const useModel = (modelClassArg, argsArg = {}) => {
147
147
  s.p.onDestroyed(forwardArgs)
148
148
  }, [])
149
149
 
150
- useEffect(() => {
150
+ useMemo(() => {
151
151
  let connectDestroyed
152
152
 
153
153
  if (model && args.onDestroyed) {
@@ -8,7 +8,7 @@ const useResizeObserver = (element, callback) => {
8
8
  }, [])
9
9
  const observer = useMemo(() => new ResizeObserver(onResize), [])
10
10
 
11
- useEffect(() => {
11
+ useMemo(() => {
12
12
  if (element) {
13
13
  observer.observe(element)
14
14
  }
@@ -1,4 +1,4 @@
1
- import {useCallback, useEffect, useMemo} from "react"
1
+ import {useCallback, useMemo} from "react"
2
2
  import debounceFunction from "debounce"
3
3
  import ModelEvents from "./model-events.mjs"
4
4
  import useShape from "set-state-compare/src/use-shape.js"
@@ -32,7 +32,7 @@ const apiMakerUseUpdatedEvent = (model, onUpdated, {active = true, debounce, onC
32
32
  }
33
33
  }, [])
34
34
 
35
- useEffect(() => {
35
+ useMemo(() => {
36
36
  let connectUpdated, onConnectedListener
37
37
 
38
38
  if (model) {
@@ -0,0 +1,33 @@
1
+ import BaseComponent from "../base-component"
2
+ import {CheckBox, Text, View} from "react-native"
3
+ import {memo} from "react"
4
+ import PropTypes from "prop-types"
5
+ import propTypesExact from "prop-types-exact"
6
+ import {shapeComponent} from "set-state-compare/src/shape-component.js"
7
+
8
+ export default memo(shapeComponent(class ApiMakerUtilsCheckbox extends BaseComponent {
9
+ static defaultProps = {
10
+ label: undefined
11
+ }
12
+
13
+ static propTypes = propTypesExact({
14
+ checked: PropTypes.bool.isRequired,
15
+ label: PropTypes.string,
16
+ onValueChange: PropTypes.func.isRequired
17
+ })
18
+
19
+ render() {
20
+ const {checked, label, onValueChange} = this.p
21
+
22
+ return (
23
+ <View dataSet={{component: "api-maker--utils--checkbox"}} style={{flexDirection: "row", alignItems: "center"}}>
24
+ <CheckBox onValueChange={onValueChange} value={checked} />
25
+ {label &&
26
+ <Text style={{marginLeft: 3}}>
27
+ {label}
28
+ </Text>
29
+ }
30
+ </View>
31
+ )
32
+ }
33
+ }))