@kaspernj/api-maker 1.0.2030 → 1.0.2032

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.
@@ -42,9 +42,7 @@ export default memo(shapeComponent(class ApiMakerInputsMoney extends ShapeCompon
42
42
  this.wholeRefBackup = useRef();
43
43
  this.wholeRef = this.props.wholeRef || this.wholeRefBackup;
44
44
  }
45
- getInputRef() {
46
- return this.props.inputRef || this.inputRef;
47
- }
45
+ getInputRef = () => this.props.inputRef || this.inputRef;
48
46
  render() {
49
47
  const {
50
48
  attribute,
@@ -72,11 +70,11 @@ export default memo(shapeComponent(class ApiMakerInputsMoney extends ShapeCompon
72
70
  defaultValue: this.inputDefaultValue(),
73
71
  disabled: disabled,
74
72
  id: this.inputId(),
75
- onBlur: digg(this, "setAmount"),
76
- onChange: digg(this, "setCents"),
77
- onKeyUp: digg(this, "setCents"),
73
+ onBlur: this.tt.setAmount,
74
+ onChange: this.tt.setCents,
75
+ onKeyUp: this.tt.setCents,
78
76
  placeholder: this.props.placeholder,
79
- ref: this.wholeRef,
77
+ ref: this.tt.wholeRef,
80
78
  type: "text"
81
79
  }), showCurrencyOptions && /*#__PURE__*/React.createElement("select", {
82
80
  className: "money-currency",
@@ -84,16 +82,14 @@ export default memo(shapeComponent(class ApiMakerInputsMoney extends ShapeCompon
84
82
  disabled: disabled,
85
83
  id: this.inputCurrencyId(),
86
84
  name: this.inputCurrencyName(),
87
- onChange: digg(this, "onCurrencyChanged"),
88
- ref: this.currencyRef
85
+ onChange: this.tt.onCurrencyChanged,
86
+ ref: this.tt.currencyRef
89
87
  }, /*#__PURE__*/React.createElement("option", null), currenciesCollection.map(option => /*#__PURE__*/React.createElement("option", {
90
88
  key: `select-option-${option[1]}`,
91
89
  value: option[1]
92
90
  }, this.props.small && option[1], !this.props.small && option[0]))));
93
91
  }
94
- inputCurrencyId() {
95
- return `${this.inputId()}_currency`;
96
- }
92
+ inputCurrencyId = () => `${this.inputId()}_currency`;
97
93
  inputCurrencyName() {
98
94
  if ("currencyName" in this.props) return this.props.currencyName;
99
95
  return `${this.props.model.modelClassData().paramKey}[${inflection.underscore(this.props.attribute)}_currency]`;
@@ -134,21 +130,18 @@ export default memo(shapeComponent(class ApiMakerInputsMoney extends ShapeCompon
134
130
  return MoneyFormatter.amountFromMoney(defaultValue);
135
131
  }
136
132
  }
137
- inputCentsId() {
138
- return `${this.inputId()}_cents`;
139
- }
133
+ inputCentsId = () => `${this.inputId()}_cents`;
140
134
  inputCentsName() {
141
135
  if ("name" in this.props) return this.props.name;
142
136
  return `${this.props.model.modelClassData().paramKey}[${inflection.underscore(this.props.attribute)}_cents]`;
143
137
  }
144
- inputId() {
145
- return idForComponent(this);
146
- }
138
+ inputId = () => idForComponent(this);
147
139
  onCurrencyChanged = () => {
148
140
  if (this.props.onChange) this.props.onChange();
149
141
  };
150
142
  setAmount = () => {
151
143
  const inputElement = this.getInputRef().current;
144
+ if (!inputElement) return;
152
145
  if (!inputElement.value && inputElement.value == "") {
153
146
  this.wholeRef.current.value = "";
154
147
  } else {
@@ -165,6 +158,7 @@ export default memo(shapeComponent(class ApiMakerInputsMoney extends ShapeCompon
165
158
  };
166
159
  setCents = () => {
167
160
  const inputElement = this.getInputRef().current;
161
+ if (!inputElement) return;
168
162
  let whole = MoneyFormatter.stringToFloat(this.wholeRef.current.value);
169
163
  let cents = parseInt(whole * 100, 10);
170
164
  let oldCents = parseInt(inputElement.value, 10);
@@ -176,4 +170,4 @@ export default memo(shapeComponent(class ApiMakerInputsMoney extends ShapeCompon
176
170
  if (this.props.onChange && oldCents != cents) this.props.onChange();
177
171
  };
178
172
  }));
179
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","useRef","shapeComponent","ShapeComponent","classNames","Config","digg","idForComponent","inflection","memo","MoneyFormatter","PropTypes","PropTypesExact","ApiMakerInputsMoney","defaultProps","disabled","showCurrencyOptions","propTypes","attribute","string","centsInputName","className","currenciesCollection","array","currencyName","currencyRef","object","defaultValue","bool","isRequired","id","inputRef","label","node","model","name","onChange","func","placeholder","small","type","wholeRef","setup","currencyRefBackup","props","wholeRefBackup","getInputRef","render","getCurrenciesCollection","createElement","inputDefaultCentsValue","inputCentsId","inputCentsName","ref","inputDefaultValue","inputId","onBlur","onKeyUp","inputCurrencyValue","inputCurrencyId","inputCurrencyName","map","option","key","value","modelClassData","paramKey","underscore","currencyFromMoney","code","fromMoney","amount","currency","decimals","excludeCurrency","toString","current","amountFromMoney","onCurrencyChanged","setAmount","inputElement","cents","parseFloat","formatted","setCents","whole","stringToFloat","parseInt","oldCents"],"sources":["../../src/inputs/money.jsx"],"sourcesContent":["import React, {useRef} from \"react\"\nimport {shapeComponent, ShapeComponent} from \"set-state-compare/src/shape-component\"\nimport classNames from \"classnames\"\nimport Config from \"../config\"\nimport {digg} from \"diggerize\"\nimport idForComponent from \"./id-for-component\"\nimport * as inflection from \"inflection\"\nimport memo from \"set-state-compare/src/memo\"\nimport MoneyFormatter from \"../money-formatter\"\nimport PropTypes from \"prop-types\"\nimport PropTypesExact from \"prop-types-exact\"\n\nexport default memo(shapeComponent(class ApiMakerInputsMoney extends ShapeComponent {\n  static defaultProps = {\n    disabled: false,\n    showCurrencyOptions: true\n  }\n\n  static propTypes = PropTypesExact({\n    attribute: PropTypes.string,\n    centsInputName: PropTypes.string,\n    className: PropTypes.string,\n    currenciesCollection: PropTypes.array,\n    currencyName: PropTypes.string,\n    currencyRef: PropTypes.object,\n    defaultValue: PropTypes.object,\n    disabled: PropTypes.bool.isRequired,\n    id: PropTypes.string,\n    inputRef: PropTypes.object,\n    label: PropTypes.node,\n    model: PropTypes.object,\n    name: PropTypes.string,\n    onChange: PropTypes.func,\n    placeholder: PropTypes.node,\n    showCurrencyOptions: PropTypes.bool,\n    small: PropTypes.bool,\n    type: PropTypes.string,\n    wholeRef: PropTypes.object\n  })\n\n  setup() {\n    this.inputRef = useRef()\n    this.currencyRefBackup = useRef()\n    this.currencyRef = this.props.currencyRef || this.currencyRefBackup\n    this.wholeRefBackup = useRef()\n    this.wholeRef = this.props.wholeRef || this.wholeRefBackup\n  }\n\n  getInputRef () {\n    return this.props.inputRef || this.inputRef\n  }\n\n  render () {\n    const {attribute, className, disabled, model, showCurrencyOptions} = this.props\n    let {currenciesCollection} = this.props\n\n    if (!currenciesCollection) currenciesCollection = Config.getCurrenciesCollection()\n\n    return (\n      <div className=\"api-maker-inputs-money\" data-attribute={attribute} data-model-id={model?.id()}>\n        <input defaultValue={this.inputDefaultCentsValue()} id={this.inputCentsId()} name={this.inputCentsName()} ref={this.getInputRef()} type=\"hidden\" />\n        <input\n          className={classNames(\"money-cents\", className)}\n          defaultValue={this.inputDefaultValue()}\n          disabled={disabled}\n          id={this.inputId()}\n          onBlur={digg(this, \"setAmount\")}\n          onChange={digg(this, \"setCents\")}\n          onKeyUp={digg(this, \"setCents\")}\n          placeholder={this.props.placeholder}\n          ref={this.wholeRef}\n          type=\"text\"\n        />\n        {showCurrencyOptions &&\n          <select\n            className=\"money-currency\"\n            defaultValue={this.inputCurrencyValue()}\n            disabled={disabled}\n            id={this.inputCurrencyId()}\n            name={this.inputCurrencyName()}\n            onChange={digg(this, \"onCurrencyChanged\")}\n            ref={this.currencyRef}\n          >\n            <option></option>\n            {currenciesCollection.map((option) => (\n              <option key={`select-option-${option[1]}`} value={option[1]}>\n                {this.props.small && option[1]}\n                {!this.props.small && option[0]}\n              </option>\n            ))}\n          </select>\n        }\n      </div>\n    )\n  }\n\n  inputCurrencyId () {\n    return `${this.inputId()}_currency`\n  }\n\n  inputCurrencyName () {\n    if (\"currencyName\" in this.props)\n      return this.props.currencyName\n\n    return `${this.props.model.modelClassData().paramKey}[${inflection.underscore(this.props.attribute)}_currency]`\n  }\n\n  inputCurrencyValue () {\n    const {defaultValue} = this.props\n\n    if (defaultValue) {\n      return MoneyFormatter.currencyFromMoney(defaultValue).code\n    } else {\n      return \"DKK\"\n    }\n  }\n\n  inputDefaultValue () {\n    const {defaultValue} = this.props\n\n    if (defaultValue) {\n      return MoneyFormatter.fromMoney({amount: defaultValue.amount, currency: this.inputCurrencyValue()}, {decimals: 2, excludeCurrency: true}).toString()\n    } else {\n      return \"\"\n    }\n  }\n\n  inputDefaultCentsValue () {\n    const {defaultValue} = this.props\n\n    if (this.getInputRef().current) {\n      return digg(this.getInputRef(), \"current\", \"value\")\n    } else if (defaultValue) {\n      return MoneyFormatter.amountFromMoney(defaultValue)\n    }\n  }\n\n  inputCentsId () {\n    return `${this.inputId()}_cents`\n  }\n\n  inputCentsName () {\n    if (\"name\" in this.props)\n      return this.props.name\n\n    return `${this.props.model.modelClassData().paramKey}[${inflection.underscore(this.props.attribute)}_cents]`\n  }\n\n  inputId () {\n    return idForComponent(this)\n  }\n\n  onCurrencyChanged = () => {\n    if (this.props.onChange)\n      this.props.onChange()\n  }\n\n  setAmount = () => {\n    const inputElement = this.getInputRef().current\n\n    if (!inputElement.value && inputElement.value == \"\") {\n      this.wholeRef.current.value = \"\"\n    } else {\n      const cents = parseFloat(inputElement.value)\n      const formatted = MoneyFormatter.fromMoney({amount: cents, currency: this.inputCurrencyValue()}, {decimals: 2, excludeCurrency: true}).toString()\n\n      this.wholeRef.current.value = formatted\n    }\n  }\n\n  setCents = () => {\n    const inputElement = this.getInputRef().current\n\n    let whole = MoneyFormatter.stringToFloat(this.wholeRef.current.value)\n    let cents = parseInt(whole * 100, 10)\n    let oldCents = parseInt(inputElement.value, 10)\n\n    if (typeof cents == \"number\") {\n      inputElement.value = cents\n    } else {\n      inputElement.value = ''\n    }\n\n    if (this.props.onChange && oldCents != cents)\n      this.props.onChange()\n  }\n}))\n"],"mappings":"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","ignoreList":[]}
173
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","useRef","shapeComponent","ShapeComponent","classNames","Config","digg","idForComponent","inflection","memo","MoneyFormatter","PropTypes","PropTypesExact","ApiMakerInputsMoney","defaultProps","disabled","showCurrencyOptions","propTypes","attribute","string","centsInputName","className","currenciesCollection","array","currencyName","currencyRef","object","defaultValue","bool","isRequired","id","inputRef","label","node","model","name","onChange","func","placeholder","small","type","wholeRef","setup","currencyRefBackup","props","wholeRefBackup","getInputRef","render","getCurrenciesCollection","createElement","inputDefaultCentsValue","inputCentsId","inputCentsName","ref","inputDefaultValue","inputId","onBlur","tt","setAmount","setCents","onKeyUp","inputCurrencyValue","inputCurrencyId","inputCurrencyName","onCurrencyChanged","map","option","key","value","modelClassData","paramKey","underscore","currencyFromMoney","code","fromMoney","amount","currency","decimals","excludeCurrency","toString","current","amountFromMoney","inputElement","cents","parseFloat","formatted","whole","stringToFloat","parseInt","oldCents"],"sources":["../../src/inputs/money.jsx"],"sourcesContent":["import React, {useRef} from \"react\"\nimport {shapeComponent, ShapeComponent} from \"set-state-compare/src/shape-component\"\nimport classNames from \"classnames\"\nimport Config from \"../config\"\nimport {digg} from \"diggerize\"\nimport idForComponent from \"./id-for-component\"\nimport * as inflection from \"inflection\"\nimport memo from \"set-state-compare/src/memo\"\nimport MoneyFormatter from \"../money-formatter\"\nimport PropTypes from \"prop-types\"\nimport PropTypesExact from \"prop-types-exact\"\n\nexport default memo(shapeComponent(class ApiMakerInputsMoney extends ShapeComponent {\n  static defaultProps = {\n    disabled: false,\n    showCurrencyOptions: true\n  }\n\n  static propTypes = PropTypesExact({\n    attribute: PropTypes.string,\n    centsInputName: PropTypes.string,\n    className: PropTypes.string,\n    currenciesCollection: PropTypes.array,\n    currencyName: PropTypes.string,\n    currencyRef: PropTypes.object,\n    defaultValue: PropTypes.object,\n    disabled: PropTypes.bool.isRequired,\n    id: PropTypes.string,\n    inputRef: PropTypes.object,\n    label: PropTypes.node,\n    model: PropTypes.object,\n    name: PropTypes.string,\n    onChange: PropTypes.func,\n    placeholder: PropTypes.node,\n    showCurrencyOptions: PropTypes.bool,\n    small: PropTypes.bool,\n    type: PropTypes.string,\n    wholeRef: PropTypes.object\n  })\n\n  setup() {\n    this.inputRef = useRef()\n    this.currencyRefBackup = useRef()\n    this.currencyRef = this.props.currencyRef || this.currencyRefBackup\n    this.wholeRefBackup = useRef()\n    this.wholeRef = this.props.wholeRef || this.wholeRefBackup\n  }\n\n  getInputRef = () => this.props.inputRef || this.inputRef\n\n  render () {\n    const {attribute, className, disabled, model, showCurrencyOptions} = this.props\n    let {currenciesCollection} = this.props\n\n    if (!currenciesCollection) currenciesCollection = Config.getCurrenciesCollection()\n\n    return (\n      <div className=\"api-maker-inputs-money\" data-attribute={attribute} data-model-id={model?.id()}>\n        <input defaultValue={this.inputDefaultCentsValue()} id={this.inputCentsId()} name={this.inputCentsName()} ref={this.getInputRef()} type=\"hidden\" />\n        <input\n          className={classNames(\"money-cents\", className)}\n          defaultValue={this.inputDefaultValue()}\n          disabled={disabled}\n          id={this.inputId()}\n          onBlur={this.tt.setAmount}\n          onChange={this.tt.setCents}\n          onKeyUp={this.tt.setCents}\n          placeholder={this.props.placeholder}\n          ref={this.tt.wholeRef}\n          type=\"text\"\n        />\n        {showCurrencyOptions &&\n          <select\n            className=\"money-currency\"\n            defaultValue={this.inputCurrencyValue()}\n            disabled={disabled}\n            id={this.inputCurrencyId()}\n            name={this.inputCurrencyName()}\n            onChange={this.tt.onCurrencyChanged}\n            ref={this.tt.currencyRef}\n          >\n            <option></option>\n            {currenciesCollection.map((option) => (\n              <option key={`select-option-${option[1]}`} value={option[1]}>\n                {this.props.small && option[1]}\n                {!this.props.small && option[0]}\n              </option>\n            ))}\n          </select>\n        }\n      </div>\n    )\n  }\n\n  inputCurrencyId = () => `${this.inputId()}_currency`\n\n  inputCurrencyName () {\n    if (\"currencyName\" in this.props) return this.props.currencyName\n\n    return `${this.props.model.modelClassData().paramKey}[${inflection.underscore(this.props.attribute)}_currency]`\n  }\n\n  inputCurrencyValue () {\n    const {defaultValue} = this.props\n\n    if (defaultValue) {\n      return MoneyFormatter.currencyFromMoney(defaultValue).code\n    } else {\n      return \"DKK\"\n    }\n  }\n\n  inputDefaultValue () {\n    const {defaultValue} = this.props\n\n    if (defaultValue) {\n      return MoneyFormatter.fromMoney({amount: defaultValue.amount, currency: this.inputCurrencyValue()}, {decimals: 2, excludeCurrency: true}).toString()\n    } else {\n      return \"\"\n    }\n  }\n\n  inputDefaultCentsValue () {\n    const {defaultValue} = this.props\n\n    if (this.getInputRef().current) {\n      return digg(this.getInputRef(), \"current\", \"value\")\n    } else if (defaultValue) {\n      return MoneyFormatter.amountFromMoney(defaultValue)\n    }\n  }\n\n  inputCentsId = () => `${this.inputId()}_cents`\n\n  inputCentsName () {\n    if (\"name\" in this.props) return this.props.name\n\n    return `${this.props.model.modelClassData().paramKey}[${inflection.underscore(this.props.attribute)}_cents]`\n  }\n\n  inputId = () => idForComponent(this)\n\n  onCurrencyChanged = () => {\n    if (this.props.onChange) this.props.onChange()\n  }\n\n  setAmount = () => {\n    const inputElement = this.getInputRef().current\n\n    if (!inputElement) return\n\n    if (!inputElement.value && inputElement.value == \"\") {\n      this.wholeRef.current.value = \"\"\n    } else {\n      const cents = parseFloat(inputElement.value)\n      const formatted = MoneyFormatter.fromMoney({amount: cents, currency: this.inputCurrencyValue()}, {decimals: 2, excludeCurrency: true}).toString()\n\n      this.wholeRef.current.value = formatted\n    }\n  }\n\n  setCents = () => {\n    const inputElement = this.getInputRef().current\n\n    if (!inputElement) return\n\n    let whole = MoneyFormatter.stringToFloat(this.wholeRef.current.value)\n    let cents = parseInt(whole * 100, 10)\n    let oldCents = parseInt(inputElement.value, 10)\n\n    if (typeof cents == \"number\") {\n      inputElement.value = cents\n    } else {\n      inputElement.value = ''\n    }\n\n    if (this.props.onChange && oldCents != cents) this.props.onChange()\n  }\n}))\n"],"mappings":"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","ignoreList":[]}
@@ -1,26 +1,44 @@
1
- import React, { createContext, useCallback, useContext, useMemo } from "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
- // logger.setDebug(true)
14
-
15
- const useCurrentUser = props => {
16
- const scope = props?.scope || "user";
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
- return currentUserContext;
26
+ if (withData) {
27
+ return currentUserContext;
28
+ } else {
29
+ return currentUserContext.model;
30
+ }
20
31
  };
21
- const WithCurrentUser = props => {
22
- const s = useShape(props || {});
23
- const scope = props?.scope || "user";
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 && s.props.onCurrentUserLoaded) {
61
- setTimeout(() => s.props.onCurrentUserLoaded(current), 0);
83
+ if (current) {
84
+ events.emit("currentUserLoaded", {
85
+ current
86
+ });
62
87
  }
63
88
  return current;
64
89
  }, []);
65
90
  s.useStates({
66
- current: () => defaultCurrentUser()
91
+ result: () => ({
92
+ loaded: false,
93
+ model: defaultCurrentUser()
94
+ })
67
95
  });
68
96
  const updateCurrentUser = useCallback(() => {
69
97
  s.set({
70
- current: Devise[s.m.scopeName]()
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.current
89
- }, props.children);
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
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@kaspernj/api-maker",
3
- "version": "1.0.2030",
3
+ "version": "1.0.2032",
4
4
  "description": "My new module",
5
5
  "main": "build/index.js",
6
6
  "scripts": {
@@ -46,9 +46,7 @@ export default memo(shapeComponent(class ApiMakerInputsMoney extends ShapeCompon
46
46
  this.wholeRef = this.props.wholeRef || this.wholeRefBackup
47
47
  }
48
48
 
49
- getInputRef () {
50
- return this.props.inputRef || this.inputRef
51
- }
49
+ getInputRef = () => this.props.inputRef || this.inputRef
52
50
 
53
51
  render () {
54
52
  const {attribute, className, disabled, model, showCurrencyOptions} = this.props
@@ -64,11 +62,11 @@ export default memo(shapeComponent(class ApiMakerInputsMoney extends ShapeCompon
64
62
  defaultValue={this.inputDefaultValue()}
65
63
  disabled={disabled}
66
64
  id={this.inputId()}
67
- onBlur={digg(this, "setAmount")}
68
- onChange={digg(this, "setCents")}
69
- onKeyUp={digg(this, "setCents")}
65
+ onBlur={this.tt.setAmount}
66
+ onChange={this.tt.setCents}
67
+ onKeyUp={this.tt.setCents}
70
68
  placeholder={this.props.placeholder}
71
- ref={this.wholeRef}
69
+ ref={this.tt.wholeRef}
72
70
  type="text"
73
71
  />
74
72
  {showCurrencyOptions &&
@@ -78,8 +76,8 @@ export default memo(shapeComponent(class ApiMakerInputsMoney extends ShapeCompon
78
76
  disabled={disabled}
79
77
  id={this.inputCurrencyId()}
80
78
  name={this.inputCurrencyName()}
81
- onChange={digg(this, "onCurrencyChanged")}
82
- ref={this.currencyRef}
79
+ onChange={this.tt.onCurrencyChanged}
80
+ ref={this.tt.currencyRef}
83
81
  >
84
82
  <option></option>
85
83
  {currenciesCollection.map((option) => (
@@ -94,13 +92,10 @@ export default memo(shapeComponent(class ApiMakerInputsMoney extends ShapeCompon
94
92
  )
95
93
  }
96
94
 
97
- inputCurrencyId () {
98
- return `${this.inputId()}_currency`
99
- }
95
+ inputCurrencyId = () => `${this.inputId()}_currency`
100
96
 
101
97
  inputCurrencyName () {
102
- if ("currencyName" in this.props)
103
- return this.props.currencyName
98
+ if ("currencyName" in this.props) return this.props.currencyName
104
99
 
105
100
  return `${this.props.model.modelClassData().paramKey}[${inflection.underscore(this.props.attribute)}_currency]`
106
101
  }
@@ -135,29 +130,25 @@ export default memo(shapeComponent(class ApiMakerInputsMoney extends ShapeCompon
135
130
  }
136
131
  }
137
132
 
138
- inputCentsId () {
139
- return `${this.inputId()}_cents`
140
- }
133
+ inputCentsId = () => `${this.inputId()}_cents`
141
134
 
142
135
  inputCentsName () {
143
- if ("name" in this.props)
144
- return this.props.name
136
+ if ("name" in this.props) return this.props.name
145
137
 
146
138
  return `${this.props.model.modelClassData().paramKey}[${inflection.underscore(this.props.attribute)}_cents]`
147
139
  }
148
140
 
149
- inputId () {
150
- return idForComponent(this)
151
- }
141
+ inputId = () => idForComponent(this)
152
142
 
153
143
  onCurrencyChanged = () => {
154
- if (this.props.onChange)
155
- this.props.onChange()
144
+ if (this.props.onChange) this.props.onChange()
156
145
  }
157
146
 
158
147
  setAmount = () => {
159
148
  const inputElement = this.getInputRef().current
160
149
 
150
+ if (!inputElement) return
151
+
161
152
  if (!inputElement.value && inputElement.value == "") {
162
153
  this.wholeRef.current.value = ""
163
154
  } else {
@@ -171,6 +162,8 @@ export default memo(shapeComponent(class ApiMakerInputsMoney extends ShapeCompon
171
162
  setCents = () => {
172
163
  const inputElement = this.getInputRef().current
173
164
 
165
+ if (!inputElement) return
166
+
174
167
  let whole = MoneyFormatter.stringToFloat(this.wholeRef.current.value)
175
168
  let cents = parseInt(whole * 100, 10)
176
169
  let oldCents = parseInt(inputElement.value, 10)
@@ -181,7 +174,6 @@ export default memo(shapeComponent(class ApiMakerInputsMoney extends ShapeCompon
181
174
  inputElement.value = ''
182
175
  }
183
176
 
184
- if (this.props.onChange && oldCents != cents)
185
- this.props.onChange()
177
+ if (this.props.onChange && oldCents != cents) this.props.onChange()
186
178
  }
187
179
  }))
@@ -1,27 +1,43 @@
1
- import React, {createContext, useCallback, useContext, useMemo} from "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
- // logger.setDebug(true)
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
- return currentUserContext
26
+ if (withData) {
27
+ return currentUserContext
28
+ } else {
29
+ return currentUserContext.model
30
+ }
20
31
  }
21
32
 
22
- const WithCurrentUser = (props) => {
23
- const s = useShape(props || {})
24
- const scope = props?.scope || "user"
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({current})
60
+ s.set({
61
+ result: {
62
+ loaded: true,
63
+ model: current
64
+ }
65
+ })
45
66
 
46
- if (s.props.onCurrentUserLoaded) setTimeout(() => s.props.onCurrentUserLoaded(current), 0)
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 && s.props.onCurrentUserLoaded) {
64
- setTimeout(() => s.props.onCurrentUserLoaded(current), 0)
84
+ if (current) {
85
+ events.emit("currentUserLoaded", {current})
65
86
  }
66
87
 
67
88
  return current
68
89
  }, [])
69
90
 
70
- s.useStates({current: () => defaultCurrentUser()})
91
+ s.useStates({
92
+ result: () => ({
93
+ loaded: false,
94
+ model: defaultCurrentUser()
95
+ })
96
+ })
71
97
 
72
98
  const updateCurrentUser = useCallback(() => {
73
- s.set({current: Devise[s.m.scopeName]()})
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.current}>
96
- {props.children}
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