@kaspernj/api-maker 1.0.2030 → 1.0.2031
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/use-current-user.js +50 -19
- package/package.json +1 -1
- package/src/use-current-user.js +48 -17
|
@@ -1,26 +1,44 @@
|
|
|
1
|
-
import React, {
|
|
1
|
+
import React, { useCallback, useContext, useMemo } from "react";
|
|
2
2
|
import Devise from "./devise";
|
|
3
3
|
import { digg } from "diggerize";
|
|
4
|
+
import EventEmitter from "events";
|
|
4
5
|
import * as inflection from "inflection";
|
|
5
6
|
import Logger from "./logger";
|
|
6
7
|
import Services from "./services";
|
|
7
8
|
import useEventEmitter from "./use-event-emitter";
|
|
8
9
|
import useShape from "set-state-compare/src/use-shape";
|
|
10
|
+
const events = new EventEmitter();
|
|
9
11
|
const logger = new Logger({
|
|
10
12
|
name: "ApiMaker / useCurrentUser"
|
|
11
13
|
});
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
14
|
+
logger.setDebug(false);
|
|
15
|
+
const useCurrentUser = (props = {}) => {
|
|
16
|
+
const {
|
|
17
|
+
scope = "user",
|
|
18
|
+
withData,
|
|
19
|
+
...restProps
|
|
20
|
+
} = props;
|
|
21
|
+
if (Object.keys(restProps).length > 0) {
|
|
22
|
+
throw new Error(`Unknown props given to useCurrentUser: ${Object.keys(restProps).join(", ")}`);
|
|
23
|
+
}
|
|
17
24
|
const scopeInstance = Devise.getScope(scope);
|
|
18
25
|
const currentUserContext = useContext(scopeInstance.getContext());
|
|
19
|
-
|
|
26
|
+
if (withData) {
|
|
27
|
+
return currentUserContext;
|
|
28
|
+
} else {
|
|
29
|
+
return currentUserContext.model;
|
|
30
|
+
}
|
|
20
31
|
};
|
|
21
|
-
const WithCurrentUser = props => {
|
|
22
|
-
const
|
|
23
|
-
|
|
32
|
+
const WithCurrentUser = (props = {}) => {
|
|
33
|
+
const {
|
|
34
|
+
children,
|
|
35
|
+
scope = "user",
|
|
36
|
+
...restProps
|
|
37
|
+
} = props;
|
|
38
|
+
if (Object.keys(restProps).length > 0) {
|
|
39
|
+
throw new Error(`Unknown props given to WithCurrentUser: ${Object.keys(restProps).join(", ")}`);
|
|
40
|
+
}
|
|
41
|
+
const s = useShape(props);
|
|
24
42
|
const scopeName = `current${inflection.camelize(scope)}`;
|
|
25
43
|
const scopeInstance = Devise.getScope(scope);
|
|
26
44
|
const ScopeContext = scopeInstance.getContext();
|
|
@@ -40,9 +58,14 @@ const WithCurrentUser = props => {
|
|
|
40
58
|
const current = digg(result, "current")[0];
|
|
41
59
|
if (current) Devise.updateSession(current);
|
|
42
60
|
s.set({
|
|
61
|
+
result: {
|
|
62
|
+
loaded: true,
|
|
63
|
+
model: current
|
|
64
|
+
}
|
|
65
|
+
});
|
|
66
|
+
events.emit("currentUserLoaded", {
|
|
43
67
|
current
|
|
44
68
|
});
|
|
45
|
-
if (s.props.onCurrentUserLoaded) setTimeout(() => s.props.onCurrentUserLoaded(current), 0);
|
|
46
69
|
}, []);
|
|
47
70
|
const defaultCurrentUser = useCallback(() => {
|
|
48
71
|
const {
|
|
@@ -57,17 +80,25 @@ const WithCurrentUser = props => {
|
|
|
57
80
|
current = Devise[scopeName]();
|
|
58
81
|
logger.debug(() => `Setting ${scope} from global current scope: ${current?.id()}`);
|
|
59
82
|
}
|
|
60
|
-
if (current
|
|
61
|
-
|
|
83
|
+
if (current) {
|
|
84
|
+
events.emit("currentUserLoaded", {
|
|
85
|
+
current
|
|
86
|
+
});
|
|
62
87
|
}
|
|
63
88
|
return current;
|
|
64
89
|
}, []);
|
|
65
90
|
s.useStates({
|
|
66
|
-
|
|
91
|
+
result: () => ({
|
|
92
|
+
loaded: false,
|
|
93
|
+
model: defaultCurrentUser()
|
|
94
|
+
})
|
|
67
95
|
});
|
|
68
96
|
const updateCurrentUser = useCallback(() => {
|
|
69
97
|
s.set({
|
|
70
|
-
|
|
98
|
+
result: {
|
|
99
|
+
loaded: true,
|
|
100
|
+
model: Devise[s.m.scopeName]()
|
|
101
|
+
}
|
|
71
102
|
});
|
|
72
103
|
}, []);
|
|
73
104
|
useMemo(() => {
|
|
@@ -85,9 +116,9 @@ const WithCurrentUser = props => {
|
|
|
85
116
|
useEventEmitter(Devise.events(), "onDeviseSignIn", onDeviseSignIn);
|
|
86
117
|
useEventEmitter(Devise.events(), "onDeviseSignOut", onDeviseSignOut);
|
|
87
118
|
return /*#__PURE__*/React.createElement(ScopeContext.Provider, {
|
|
88
|
-
value: s.s.
|
|
89
|
-
},
|
|
119
|
+
value: s.s.result
|
|
120
|
+
}, children);
|
|
90
121
|
};
|
|
91
|
-
export { WithCurrentUser };
|
|
122
|
+
export { events, WithCurrentUser };
|
|
92
123
|
export default useCurrentUser;
|
|
93
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","createContext","useCallback","useContext","useMemo","Devise","digg","inflection","Logger","Services","useEventEmitter","useShape","logger","name","useCurrentUser","props","scope","scopeInstance","getScope","currentUserContext","getContext","WithCurrentUser","s","scopeName","camelize","ScopeContext","meta","loadCurrentUserFromRequest","m","getArgsMethodName","args","debug","result","current","sendRequest","query","updateSession","set","onCurrentUserLoaded","setTimeout","defaultCurrentUser","hasCurrentScope","getCurrentScope","id","hasGlobalCurrentScope","useStates","updateCurrentUser","onDeviseSignIn","onDeviseSignOut","events","createElement","Provider","value","children"],"sources":["../src/use-current-user.js"],"sourcesContent":["import React, {createContext, useCallback, useContext, useMemo} from \"react\"\nimport Devise from \"./devise\"\nimport {digg} from \"diggerize\"\nimport * as inflection from \"inflection\"\nimport Logger from \"./logger\"\nimport Services from \"./services\"\nimport useEventEmitter from \"./use-event-emitter\"\nimport useShape from \"set-state-compare/src/use-shape\"\n\nconst logger = new Logger({name: \"ApiMaker / useCurrentUser\"})\n\n// logger.setDebug(true)\n\nconst useCurrentUser = (props) => {\n  const scope = props?.scope || \"user\"\n  const scopeInstance = Devise.getScope(scope)\n  const currentUserContext = useContext(scopeInstance.getContext())\n\n  return currentUserContext\n}\n\nconst WithCurrentUser = (props) => {\n  const s = useShape(props || {})\n  const scope = props?.scope || \"user\"\n  const scopeName = `current${inflection.camelize(scope)}`\n  const scopeInstance = Devise.getScope(scope)\n  const ScopeContext = scopeInstance.getContext()\n\n  s.meta.scope = scope\n  s.meta.scopeName = scopeName\n\n  const loadCurrentUserFromRequest = useCallback(async () => {\n    const {scope} = s.m\n    const getArgsMethodName = `get${inflection.camelize(scope)}Args`\n    const args = Devise[getArgsMethodName]()\n\n    logger.debug(() => `Loading ${scope} with request`)\n\n    const result = await Services.current().sendRequest(\"Devise::Current\", {query: args.query, scope})\n    const current = digg(result, \"current\")[0]\n\n    if (current) Devise.updateSession(current)\n\n    s.set({current})\n\n    if (s.props.onCurrentUserLoaded) setTimeout(() => s.props.onCurrentUserLoaded(current), 0)\n  }, [])\n\n  const defaultCurrentUser = useCallback(() => {\n    const {scope, scopeName} = s.m\n    let current\n\n    if (Devise.current().hasCurrentScope(s.m.scope)) {\n      current = Devise.current().getCurrentScope(scope)\n\n      logger.debug(() => `Setting ${scope} from current scope: ${current?.id()}`)\n    } else if (Devise.current().hasGlobalCurrentScope(scope)) {\n      current = Devise[scopeName]()\n\n      logger.debug(() => `Setting ${scope} from global current scope: ${current?.id()}`)\n    }\n\n    if (current && s.props.onCurrentUserLoaded) {\n      setTimeout(() => s.props.onCurrentUserLoaded(current), 0)\n    }\n\n    return current\n  }, [])\n\n  s.useStates({current: () => defaultCurrentUser()})\n\n  const updateCurrentUser = useCallback(() => {\n    s.set({current: Devise[s.m.scopeName]()})\n  }, [])\n\n  useMemo(() => {\n    if (!Devise.current().hasGlobalCurrentScope(s.m.scope) && !Devise.current().hasCurrentScope(s.m.scope)) {\n      logger.debug(() => `Devise hasn't got current scope ${s.m.scope} so loading from request`)\n      loadCurrentUserFromRequest()\n    }\n  }, [])\n\n  const onDeviseSignIn = useCallback(() => {\n    updateCurrentUser()\n  }, [])\n\n  const onDeviseSignOut = useCallback(() => {\n    updateCurrentUser()\n  }, [])\n\n  useEventEmitter(Devise.events(), \"onDeviseSignIn\", onDeviseSignIn)\n  useEventEmitter(Devise.events(), \"onDeviseSignOut\", onDeviseSignOut)\n\n  return (\n    <ScopeContext.Provider value={s.s.current}>\n      {props.children}\n    </ScopeContext.Provider>\n  )\n}\n\nexport {WithCurrentUser}\nexport default useCurrentUser\n"],"mappings":"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","ignoreList":[]}
|
|
124
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","useCallback","useContext","useMemo","Devise","digg","EventEmitter","inflection","Logger","Services","useEventEmitter","useShape","events","logger","name","setDebug","useCurrentUser","props","scope","withData","restProps","Object","keys","length","Error","join","scopeInstance","getScope","currentUserContext","getContext","model","WithCurrentUser","children","s","scopeName","camelize","ScopeContext","meta","loadCurrentUserFromRequest","m","getArgsMethodName","args","debug","result","current","sendRequest","query","updateSession","set","loaded","emit","defaultCurrentUser","hasCurrentScope","getCurrentScope","id","hasGlobalCurrentScope","useStates","updateCurrentUser","onDeviseSignIn","onDeviseSignOut","createElement","Provider","value"],"sources":["../src/use-current-user.js"],"sourcesContent":["import React, {useCallback, useContext, useMemo} from \"react\"\nimport Devise from \"./devise\"\nimport {digg} from \"diggerize\"\nimport EventEmitter from \"events\"\nimport * as inflection from \"inflection\"\nimport Logger from \"./logger\"\nimport Services from \"./services\"\nimport useEventEmitter from \"./use-event-emitter\"\nimport useShape from \"set-state-compare/src/use-shape\"\n\nconst events = new EventEmitter()\nconst logger = new Logger({name: \"ApiMaker / useCurrentUser\"})\n\nlogger.setDebug(false)\n\nconst useCurrentUser = (props = {}) => {\n  const {scope = \"user\", withData, ...restProps} = props\n\n  if (Object.keys(restProps).length > 0) {\n    throw new Error(`Unknown props given to useCurrentUser: ${Object.keys(restProps).join(\", \")}`)\n  }\n\n  const scopeInstance = Devise.getScope(scope)\n  const currentUserContext = useContext(scopeInstance.getContext())\n\n  if (withData) {\n    return currentUserContext\n  } else {\n    return currentUserContext.model\n  }\n}\n\nconst WithCurrentUser = (props = {}) => {\n  const {children, scope = \"user\", ...restProps} = props\n\n  if (Object.keys(restProps).length > 0) {\n    throw new Error(`Unknown props given to WithCurrentUser: ${Object.keys(restProps).join(\", \")}`)\n  }\n\n  const s = useShape(props)\n  const scopeName = `current${inflection.camelize(scope)}`\n  const scopeInstance = Devise.getScope(scope)\n  const ScopeContext = scopeInstance.getContext()\n\n  s.meta.scope = scope\n  s.meta.scopeName = scopeName\n\n  const loadCurrentUserFromRequest = useCallback(async () => {\n    const {scope} = s.m\n    const getArgsMethodName = `get${inflection.camelize(scope)}Args`\n    const args = Devise[getArgsMethodName]()\n\n    logger.debug(() => `Loading ${scope} with request`)\n\n    const result = await Services.current().sendRequest(\"Devise::Current\", {query: args.query, scope})\n    const current = digg(result, \"current\")[0]\n\n    if (current) Devise.updateSession(current)\n\n    s.set({\n      result: {\n        loaded: true,\n        model: current\n      }\n    })\n\n    events.emit(\"currentUserLoaded\", {current})\n  }, [])\n\n  const defaultCurrentUser = useCallback(() => {\n    const {scope, scopeName} = s.m\n    let current\n\n    if (Devise.current().hasCurrentScope(s.m.scope)) {\n      current = Devise.current().getCurrentScope(scope)\n\n      logger.debug(() => `Setting ${scope} from current scope: ${current?.id()}`)\n    } else if (Devise.current().hasGlobalCurrentScope(scope)) {\n      current = Devise[scopeName]()\n\n      logger.debug(() => `Setting ${scope} from global current scope: ${current?.id()}`)\n    }\n\n    if (current) {\n      events.emit(\"currentUserLoaded\", {current})\n    }\n\n    return current\n  }, [])\n\n  s.useStates({\n    result: () => ({\n      loaded: false,\n      model: defaultCurrentUser()\n    })\n  })\n\n  const updateCurrentUser = useCallback(() => {\n    s.set({\n      result: {\n        loaded: true,\n        model: Devise[s.m.scopeName]()\n      }\n    })\n  }, [])\n\n  useMemo(() => {\n    if (!Devise.current().hasGlobalCurrentScope(s.m.scope) && !Devise.current().hasCurrentScope(s.m.scope)) {\n      logger.debug(() => `Devise hasn't got current scope ${s.m.scope} so loading from request`)\n      loadCurrentUserFromRequest()\n    }\n  }, [])\n\n  const onDeviseSignIn = useCallback(() => {\n    updateCurrentUser()\n  }, [])\n\n  const onDeviseSignOut = useCallback(() => {\n    updateCurrentUser()\n  }, [])\n\n  useEventEmitter(Devise.events(), \"onDeviseSignIn\", onDeviseSignIn)\n  useEventEmitter(Devise.events(), \"onDeviseSignOut\", onDeviseSignOut)\n\n  return (\n    <ScopeContext.Provider value={s.s.result}>\n      {children}\n    </ScopeContext.Provider>\n  )\n}\n\nexport {events, WithCurrentUser}\nexport default useCurrentUser\n"],"mappings":"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","ignoreList":[]}
|
package/package.json
CHANGED
package/src/use-current-user.js
CHANGED
|
@@ -1,27 +1,43 @@
|
|
|
1
|
-
import React, {
|
|
1
|
+
import React, {useCallback, useContext, useMemo} from "react"
|
|
2
2
|
import Devise from "./devise"
|
|
3
3
|
import {digg} from "diggerize"
|
|
4
|
+
import EventEmitter from "events"
|
|
4
5
|
import * as inflection from "inflection"
|
|
5
6
|
import Logger from "./logger"
|
|
6
7
|
import Services from "./services"
|
|
7
8
|
import useEventEmitter from "./use-event-emitter"
|
|
8
9
|
import useShape from "set-state-compare/src/use-shape"
|
|
9
10
|
|
|
11
|
+
const events = new EventEmitter()
|
|
10
12
|
const logger = new Logger({name: "ApiMaker / useCurrentUser"})
|
|
11
13
|
|
|
12
|
-
|
|
14
|
+
logger.setDebug(false)
|
|
15
|
+
|
|
16
|
+
const useCurrentUser = (props = {}) => {
|
|
17
|
+
const {scope = "user", withData, ...restProps} = props
|
|
18
|
+
|
|
19
|
+
if (Object.keys(restProps).length > 0) {
|
|
20
|
+
throw new Error(`Unknown props given to useCurrentUser: ${Object.keys(restProps).join(", ")}`)
|
|
21
|
+
}
|
|
13
22
|
|
|
14
|
-
const useCurrentUser = (props) => {
|
|
15
|
-
const scope = props?.scope || "user"
|
|
16
23
|
const scopeInstance = Devise.getScope(scope)
|
|
17
24
|
const currentUserContext = useContext(scopeInstance.getContext())
|
|
18
25
|
|
|
19
|
-
|
|
26
|
+
if (withData) {
|
|
27
|
+
return currentUserContext
|
|
28
|
+
} else {
|
|
29
|
+
return currentUserContext.model
|
|
30
|
+
}
|
|
20
31
|
}
|
|
21
32
|
|
|
22
|
-
const WithCurrentUser = (props) => {
|
|
23
|
-
const
|
|
24
|
-
|
|
33
|
+
const WithCurrentUser = (props = {}) => {
|
|
34
|
+
const {children, scope = "user", ...restProps} = props
|
|
35
|
+
|
|
36
|
+
if (Object.keys(restProps).length > 0) {
|
|
37
|
+
throw new Error(`Unknown props given to WithCurrentUser: ${Object.keys(restProps).join(", ")}`)
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
const s = useShape(props)
|
|
25
41
|
const scopeName = `current${inflection.camelize(scope)}`
|
|
26
42
|
const scopeInstance = Devise.getScope(scope)
|
|
27
43
|
const ScopeContext = scopeInstance.getContext()
|
|
@@ -41,9 +57,14 @@ const WithCurrentUser = (props) => {
|
|
|
41
57
|
|
|
42
58
|
if (current) Devise.updateSession(current)
|
|
43
59
|
|
|
44
|
-
s.set({
|
|
60
|
+
s.set({
|
|
61
|
+
result: {
|
|
62
|
+
loaded: true,
|
|
63
|
+
model: current
|
|
64
|
+
}
|
|
65
|
+
})
|
|
45
66
|
|
|
46
|
-
|
|
67
|
+
events.emit("currentUserLoaded", {current})
|
|
47
68
|
}, [])
|
|
48
69
|
|
|
49
70
|
const defaultCurrentUser = useCallback(() => {
|
|
@@ -60,17 +81,27 @@ const WithCurrentUser = (props) => {
|
|
|
60
81
|
logger.debug(() => `Setting ${scope} from global current scope: ${current?.id()}`)
|
|
61
82
|
}
|
|
62
83
|
|
|
63
|
-
if (current
|
|
64
|
-
|
|
84
|
+
if (current) {
|
|
85
|
+
events.emit("currentUserLoaded", {current})
|
|
65
86
|
}
|
|
66
87
|
|
|
67
88
|
return current
|
|
68
89
|
}, [])
|
|
69
90
|
|
|
70
|
-
s.useStates({
|
|
91
|
+
s.useStates({
|
|
92
|
+
result: () => ({
|
|
93
|
+
loaded: false,
|
|
94
|
+
model: defaultCurrentUser()
|
|
95
|
+
})
|
|
96
|
+
})
|
|
71
97
|
|
|
72
98
|
const updateCurrentUser = useCallback(() => {
|
|
73
|
-
s.set({
|
|
99
|
+
s.set({
|
|
100
|
+
result: {
|
|
101
|
+
loaded: true,
|
|
102
|
+
model: Devise[s.m.scopeName]()
|
|
103
|
+
}
|
|
104
|
+
})
|
|
74
105
|
}, [])
|
|
75
106
|
|
|
76
107
|
useMemo(() => {
|
|
@@ -92,11 +123,11 @@ const WithCurrentUser = (props) => {
|
|
|
92
123
|
useEventEmitter(Devise.events(), "onDeviseSignOut", onDeviseSignOut)
|
|
93
124
|
|
|
94
125
|
return (
|
|
95
|
-
<ScopeContext.Provider value={s.s.
|
|
96
|
-
{
|
|
126
|
+
<ScopeContext.Provider value={s.s.result}>
|
|
127
|
+
{children}
|
|
97
128
|
</ScopeContext.Provider>
|
|
98
129
|
)
|
|
99
130
|
}
|
|
100
131
|
|
|
101
|
-
export {WithCurrentUser}
|
|
132
|
+
export {events, WithCurrentUser}
|
|
102
133
|
export default useCurrentUser
|