@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.
- package/build/inputs/money.js +13 -19
- package/build/use-current-user.js +50 -19
- package/package.json +1 -1
- package/src/inputs/money.jsx +18 -26
- package/src/use-current-user.js +48 -17
package/build/inputs/money.js
CHANGED
|
@@ -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:
|
|
76
|
-
onChange:
|
|
77
|
-
onKeyUp:
|
|
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:
|
|
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":"AAAA,OAAOA,KAAK,IAAGC,MAAM,QAAO,OAAO;AACnC,SAAQC,cAAc,EAAEC,cAAc,QAAO,uCAAuC;AACpF,OAAOC,UAAU,MAAM,YAAY;AACnC,OAAOC,MAAM,MAAM,WAAW;AAC9B,SAAQC,IAAI,QAAO,WAAW;AAC9B,OAAOC,cAAc,MAAM,oBAAoB;AAC/C,OAAO,KAAKC,UAAU,MAAM,YAAY;AACxC,OAAOC,IAAI,MAAM,4BAA4B;AAC7C,OAAOC,cAAc,MAAM,oBAAoB;AAC/C,OAAOC,SAAS,MAAM,YAAY;AAClC,OAAOC,cAAc,MAAM,kBAAkB;AAE7C,eAAeH,IAAI,CAACP,cAAc,CAAC,MAAMW,mBAAmB,SAASV,cAAc,CAAC;EAClF,OAAOW,YAAY,GAAG;IACpBC,QAAQ,EAAE,KAAK;IACfC,mBAAmB,EAAE;EACvB,CAAC;EAED,OAAOC,SAAS,GAAGL,cAAc,CAAC;IAChCM,SAAS,EAAEP,SAAS,CAACQ,MAAM;IAC3BC,cAAc,EAAET,SAAS,CAACQ,MAAM;IAChCE,SAAS,EAAEV,SAAS,CAACQ,MAAM;IAC3BG,oBAAoB,EAAEX,SAAS,CAACY,KAAK;IACrCC,YAAY,EAAEb,SAAS,CAACQ,MAAM;IAC9BM,WAAW,EAAEd,SAAS,CAACe,MAAM;IAC7BC,YAAY,EAAEhB,SAAS,CAACe,MAAM;IAC9BX,QAAQ,EAAEJ,SAAS,CAACiB,IAAI,CAACC,UAAU;IACnCC,EAAE,EAAEnB,SAAS,CAACQ,MAAM;IACpBY,QAAQ,EAAEpB,SAAS,CAACe,MAAM;IAC1BM,KAAK,EAAErB,SAAS,CAACsB,IAAI;IACrBC,KAAK,EAAEvB,SAAS,CAACe,MAAM;IACvBS,IAAI,EAAExB,SAAS,CAACQ,MAAM;IACtBiB,QAAQ,EAAEzB,SAAS,CAAC0B,IAAI;IACxBC,WAAW,EAAE3B,SAAS,CAACsB,IAAI;IAC3BjB,mBAAmB,EAAEL,SAAS,CAACiB,IAAI;IACnCW,KAAK,EAAE5B,SAAS,CAACiB,IAAI;IACrBY,IAAI,EAAE7B,SAAS,CAACQ,MAAM;IACtBsB,QAAQ,EAAE9B,SAAS,CAACe;EACtB,CAAC,CAAC;EAEFgB,KAAKA,CAAA,EAAG;IACN,IAAI,CAACX,QAAQ,GAAG9B,MAAM,CAAC,CAAC;IACxB,IAAI,CAAC0C,iBAAiB,GAAG1C,MAAM,CAAC,CAAC;IACjC,IAAI,CAACwB,WAAW,GAAG,IAAI,CAACmB,KAAK,CAACnB,WAAW,IAAI,IAAI,CAACkB,iBAAiB;IACnE,IAAI,CAACE,cAAc,GAAG5C,MAAM,CAAC,CAAC;IAC9B,IAAI,CAACwC,QAAQ,GAAG,IAAI,CAACG,KAAK,CAACH,QAAQ,IAAI,IAAI,CAACI,cAAc;EAC5D;EAEAC,WAAWA,CAAA,EAAI;IACb,OAAO,IAAI,CAACF,KAAK,CAACb,QAAQ,IAAI,IAAI,CAACA,QAAQ;EAC7C;EAEAgB,MAAMA,CAAA,EAAI;IACR,MAAM;MAAC7B,SAAS;MAAEG,SAAS;MAAEN,QAAQ;MAAEmB,KAAK;MAAElB;IAAmB,CAAC,GAAG,IAAI,CAAC4B,KAAK;IAC/E,IAAI;MAACtB;IAAoB,CAAC,GAAG,IAAI,CAACsB,KAAK;IAEvC,IAAI,CAACtB,oBAAoB,EAAEA,oBAAoB,GAAGjB,MAAM,CAAC2C,uBAAuB,CAAC,CAAC;IAElF,oBACEhD,KAAA,CAAAiD,aAAA;MAAK5B,SAAS,EAAC,wBAAwB;MAAC,kBAAgBH,SAAU;MAAC,iBAAegB,KAAK,EAAEJ,EAAE,CAAC;IAAE,gBAC5F9B,KAAA,CAAAiD,aAAA;MAAOtB,YAAY,EAAE,IAAI,CAACuB,sBAAsB,CAAC,CAAE;MAACpB,EAAE,EAAE,IAAI,CAACqB,YAAY,CAAC,CAAE;MAAChB,IAAI,EAAE,IAAI,CAACiB,cAAc,CAAC,CAAE;MAACC,GAAG,EAAE,IAAI,CAACP,WAAW,CAAC,CAAE;MAACN,IAAI,EAAC;IAAQ,CAAE,CAAC,eACnJxC,KAAA,CAAAiD,aAAA;MACE5B,SAAS,EAAEjB,UAAU,CAAC,aAAa,EAAEiB,SAAS,CAAE;MAChDM,YAAY,EAAE,IAAI,CAAC2B,iBAAiB,CAAC,CAAE;MACvCvC,QAAQ,EAAEA,QAAS;MACnBe,EAAE,EAAE,IAAI,CAACyB,OAAO,CAAC,CAAE;MACnBC,MAAM,EAAElD,IAAI,CAAC,IAAI,EAAE,WAAW,CAAE;MAChC8B,QAAQ,EAAE9B,IAAI,CAAC,IAAI,EAAE,UAAU,CAAE;MACjCmD,OAAO,EAAEnD,IAAI,CAAC,IAAI,EAAE,UAAU,CAAE;MAChCgC,WAAW,EAAE,IAAI,CAACM,KAAK,CAACN,WAAY;MACpCe,GAAG,EAAE,IAAI,CAACZ,QAAS;MACnBD,IAAI,EAAC;IAAM,CACZ,CAAC,EACDxB,mBAAmB,iBAClBhB,KAAA,CAAAiD,aAAA;MACE5B,SAAS,EAAC,gBAAgB;MAC1BM,YAAY,EAAE,IAAI,CAAC+B,kBAAkB,CAAC,CAAE;MACxC3C,QAAQ,EAAEA,QAAS;MACnBe,EAAE,EAAE,IAAI,CAAC6B,eAAe,CAAC,CAAE;MAC3BxB,IAAI,EAAE,IAAI,CAACyB,iBAAiB,CAAC,CAAE;MAC/BxB,QAAQ,EAAE9B,IAAI,CAAC,IAAI,EAAE,mBAAmB,CAAE;MAC1C+C,GAAG,EAAE,IAAI,CAAC5B;IAAY,gBAEtBzB,KAAA,CAAAiD,aAAA,eAAgB,CAAC,EAChB3B,oBAAoB,CAACuC,GAAG,CAAEC,MAAM,iBAC/B9D,KAAA,CAAAiD,aAAA;MAAQc,GAAG,EAAE,iBAAiBD,MAAM,CAAC,CAAC,CAAC,EAAG;MAACE,KAAK,EAAEF,MAAM,CAAC,CAAC;IAAE,GACzD,IAAI,CAAClB,KAAK,CAACL,KAAK,IAAIuB,MAAM,CAAC,CAAC,CAAC,EAC7B,CAAC,IAAI,CAAClB,KAAK,CAACL,KAAK,IAAIuB,MAAM,CAAC,CAAC,CACxB,CACT,CACK,CAEP,CAAC;EAEV;EAEAH,eAAeA,CAAA,EAAI;IACjB,OAAO,GAAG,IAAI,CAACJ,OAAO,CAAC,CAAC,WAAW;EACrC;EAEAK,iBAAiBA,CAAA,EAAI;IACnB,IAAI,cAAc,IAAI,IAAI,CAAChB,KAAK,EAC9B,OAAO,IAAI,CAACA,KAAK,CAACpB,YAAY;IAEhC,OAAO,GAAG,IAAI,CAACoB,KAAK,CAACV,KAAK,CAAC+B,cAAc,CAAC,CAAC,CAACC,QAAQ,IAAI1D,UAAU,CAAC2D,UAAU,CAAC,IAAI,CAACvB,KAAK,CAAC1B,SAAS,CAAC,YAAY;EACjH;EAEAwC,kBAAkBA,CAAA,EAAI;IACpB,MAAM;MAAC/B;IAAY,CAAC,GAAG,IAAI,CAACiB,KAAK;IAEjC,IAAIjB,YAAY,EAAE;MAChB,OAAOjB,cAAc,CAAC0D,iBAAiB,CAACzC,YAAY,CAAC,CAAC0C,IAAI;IAC5D,CAAC,MAAM;MACL,OAAO,KAAK;IACd;EACF;EAEAf,iBAAiBA,CAAA,EAAI;IACnB,MAAM;MAAC3B;IAAY,CAAC,GAAG,IAAI,CAACiB,KAAK;IAEjC,IAAIjB,YAAY,EAAE;MAChB,OAAOjB,cAAc,CAAC4D,SAAS,CAAC;QAACC,MAAM,EAAE5C,YAAY,CAAC4C,MAAM;QAAEC,QAAQ,EAAE,IAAI,CAACd,kBAAkB,CAAC;MAAC,CAAC,EAAE;QAACe,QAAQ,EAAE,CAAC;QAAEC,eAAe,EAAE;MAAI,CAAC,CAAC,CAACC,QAAQ,CAAC,CAAC;IACtJ,CAAC,MAAM;MACL,OAAO,EAAE;IACX;EACF;EAEAzB,sBAAsBA,CAAA,EAAI;IACxB,MAAM;MAACvB;IAAY,CAAC,GAAG,IAAI,CAACiB,KAAK;IAEjC,IAAI,IAAI,CAACE,WAAW,CAAC,CAAC,CAAC8B,OAAO,EAAE;MAC9B,OAAOtE,IAAI,CAAC,IAAI,CAACwC,WAAW,CAAC,CAAC,EAAE,SAAS,EAAE,OAAO,CAAC;IACrD,CAAC,MAAM,IAAInB,YAAY,EAAE;MACvB,OAAOjB,cAAc,CAACmE,eAAe,CAAClD,YAAY,CAAC;IACrD;EACF;EAEAwB,YAAYA,CAAA,EAAI;IACd,OAAO,GAAG,IAAI,CAACI,OAAO,CAAC,CAAC,QAAQ;EAClC;EAEAH,cAAcA,CAAA,EAAI;IAChB,IAAI,MAAM,IAAI,IAAI,CAACR,KAAK,EACtB,OAAO,IAAI,CAACA,KAAK,CAACT,IAAI;IAExB,OAAO,GAAG,IAAI,CAACS,KAAK,CAACV,KAAK,CAAC+B,cAAc,CAAC,CAAC,CAACC,QAAQ,IAAI1D,UAAU,CAAC2D,UAAU,CAAC,IAAI,CAACvB,KAAK,CAAC1B,SAAS,CAAC,SAAS;EAC9G;EAEAqC,OAAOA,CAAA,EAAI;IACT,OAAOhD,cAAc,CAAC,IAAI,CAAC;EAC7B;EAEAuE,iBAAiB,GAAGA,CAAA,KAAM;IACxB,IAAI,IAAI,CAAClC,KAAK,CAACR,QAAQ,EACrB,IAAI,CAACQ,KAAK,CAACR,QAAQ,CAAC,CAAC;EACzB,CAAC;EAED2C,SAAS,GAAGA,CAAA,KAAM;IAChB,MAAMC,YAAY,GAAG,IAAI,CAAClC,WAAW,CAAC,CAAC,CAAC8B,OAAO;IAE/C,IAAI,CAACI,YAAY,CAAChB,KAAK,IAAIgB,YAAY,CAAChB,KAAK,IAAI,EAAE,EAAE;MACnD,IAAI,CAACvB,QAAQ,CAACmC,OAAO,CAACZ,KAAK,GAAG,EAAE;IAClC,CAAC,MAAM;MACL,MAAMiB,KAAK,GAAGC,UAAU,CAACF,YAAY,CAAChB,KAAK,CAAC;MAC5C,MAAMmB,SAAS,GAAGzE,cAAc,CAAC4D,SAAS,CAAC;QAACC,MAAM,EAAEU,KAAK;QAAET,QAAQ,EAAE,IAAI,CAACd,kBAAkB,CAAC;MAAC,CAAC,EAAE;QAACe,QAAQ,EAAE,CAAC;QAAEC,eAAe,EAAE;MAAI,CAAC,CAAC,CAACC,QAAQ,CAAC,CAAC;MAEjJ,IAAI,CAAClC,QAAQ,CAACmC,OAAO,CAACZ,KAAK,GAAGmB,SAAS;IACzC;EACF,CAAC;EAEDC,QAAQ,GAAGA,CAAA,KAAM;IACf,MAAMJ,YAAY,GAAG,IAAI,CAAClC,WAAW,CAAC,CAAC,CAAC8B,OAAO;IAE/C,IAAIS,KAAK,GAAG3E,cAAc,CAAC4E,aAAa,CAAC,IAAI,CAAC7C,QAAQ,CAACmC,OAAO,CAACZ,KAAK,CAAC;IACrE,IAAIiB,KAAK,GAAGM,QAAQ,CAACF,KAAK,GAAG,GAAG,EAAE,EAAE,CAAC;IACrC,IAAIG,QAAQ,GAAGD,QAAQ,CAACP,YAAY,CAAChB,KAAK,EAAE,EAAE,CAAC;IAE/C,IAAI,OAAOiB,KAAK,IAAI,QAAQ,EAAE;MAC5BD,YAAY,CAAChB,KAAK,GAAGiB,KAAK;IAC5B,CAAC,MAAM;MACLD,YAAY,CAAChB,KAAK,GAAG,EAAE;IACzB;IAEA,IAAI,IAAI,CAACpB,KAAK,CAACR,QAAQ,IAAIoD,QAAQ,IAAIP,KAAK,EAC1C,IAAI,CAACrC,KAAK,CAACR,QAAQ,CAAC,CAAC;EACzB,CAAC;AACH,CAAC,CAAC,CAAC","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, {
|
|
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":"AAAA,OAAOA,KAAK,IAAGC,aAAa,EAAEC,WAAW,EAAEC,UAAU,EAAEC,OAAO,QAAO,OAAO;AAC5E,OAAOC,MAAM,MAAM,UAAU;AAC7B,SAAQC,IAAI,QAAO,WAAW;AAC9B,OAAO,KAAKC,UAAU,MAAM,YAAY;AACxC,OAAOC,MAAM,MAAM,UAAU;AAC7B,OAAOC,QAAQ,MAAM,YAAY;AACjC,OAAOC,eAAe,MAAM,qBAAqB;AACjD,OAAOC,QAAQ,MAAM,iCAAiC;AAEtD,MAAMC,MAAM,GAAG,IAAIJ,MAAM,CAAC;EAACK,IAAI,EAAE;AAA2B,CAAC,CAAC;;AAE9D;;AAEA,MAAMC,cAAc,GAAIC,KAAK,IAAK;EAChC,MAAMC,KAAK,GAAGD,KAAK,EAAEC,KAAK,IAAI,MAAM;EACpC,MAAMC,aAAa,GAAGZ,MAAM,CAACa,QAAQ,CAACF,KAAK,CAAC;EAC5C,MAAMG,kBAAkB,GAAGhB,UAAU,CAACc,aAAa,CAACG,UAAU,CAAC,CAAC,CAAC;EAEjE,OAAOD,kBAAkB;AAC3B,CAAC;AAED,MAAME,eAAe,GAAIN,KAAK,IAAK;EACjC,MAAMO,CAAC,GAAGX,QAAQ,CAACI,KAAK,IAAI,CAAC,CAAC,CAAC;EAC/B,MAAMC,KAAK,GAAGD,KAAK,EAAEC,KAAK,IAAI,MAAM;EACpC,MAAMO,SAAS,GAAG,UAAUhB,UAAU,CAACiB,QAAQ,CAACR,KAAK,CAAC,EAAE;EACxD,MAAMC,aAAa,GAAGZ,MAAM,CAACa,QAAQ,CAACF,KAAK,CAAC;EAC5C,MAAMS,YAAY,GAAGR,aAAa,CAACG,UAAU,CAAC,CAAC;EAE/CE,CAAC,CAACI,IAAI,CAACV,KAAK,GAAGA,KAAK;EACpBM,CAAC,CAACI,IAAI,CAACH,SAAS,GAAGA,SAAS;EAE5B,MAAMI,0BAA0B,GAAGzB,WAAW,CAAC,YAAY;IACzD,MAAM;MAACc;IAAK,CAAC,GAAGM,CAAC,CAACM,CAAC;IACnB,MAAMC,iBAAiB,GAAG,MAAMtB,UAAU,CAACiB,QAAQ,CAACR,KAAK,CAAC,MAAM;IAChE,MAAMc,IAAI,GAAGzB,MAAM,CAACwB,iBAAiB,CAAC,CAAC,CAAC;IAExCjB,MAAM,CAACmB,KAAK,CAAC,MAAM,WAAWf,KAAK,eAAe,CAAC;IAEnD,MAAMgB,MAAM,GAAG,MAAMvB,QAAQ,CAACwB,OAAO,CAAC,CAAC,CAACC,WAAW,CAAC,iBAAiB,EAAE;MAACC,KAAK,EAAEL,IAAI,CAACK,KAAK;MAAEnB;IAAK,CAAC,CAAC;IAClG,MAAMiB,OAAO,GAAG3B,IAAI,CAAC0B,MAAM,EAAE,SAAS,CAAC,CAAC,CAAC,CAAC;IAE1C,IAAIC,OAAO,EAAE5B,MAAM,CAAC+B,aAAa,CAACH,OAAO,CAAC;IAE1CX,CAAC,CAACe,GAAG,CAAC;MAACJ;IAAO,CAAC,CAAC;IAEhB,IAAIX,CAAC,CAACP,KAAK,CAACuB,mBAAmB,EAAEC,UAAU,CAAC,MAAMjB,CAAC,CAACP,KAAK,CAACuB,mBAAmB,CAACL,OAAO,CAAC,EAAE,CAAC,CAAC;EAC5F,CAAC,EAAE,EAAE,CAAC;EAEN,MAAMO,kBAAkB,GAAGtC,WAAW,CAAC,MAAM;IAC3C,MAAM;MAACc,KAAK;MAAEO;IAAS,CAAC,GAAGD,CAAC,CAACM,CAAC;IAC9B,IAAIK,OAAO;IAEX,IAAI5B,MAAM,CAAC4B,OAAO,CAAC,CAAC,CAACQ,eAAe,CAACnB,CAAC,CAACM,CAAC,CAACZ,KAAK,CAAC,EAAE;MAC/CiB,OAAO,GAAG5B,MAAM,CAAC4B,OAAO,CAAC,CAAC,CAACS,eAAe,CAAC1B,KAAK,CAAC;MAEjDJ,MAAM,CAACmB,KAAK,CAAC,MAAM,WAAWf,KAAK,wBAAwBiB,OAAO,EAAEU,EAAE,CAAC,CAAC,EAAE,CAAC;IAC7E,CAAC,MAAM,IAAItC,MAAM,CAAC4B,OAAO,CAAC,CAAC,CAACW,qBAAqB,CAAC5B,KAAK,CAAC,EAAE;MACxDiB,OAAO,GAAG5B,MAAM,CAACkB,SAAS,CAAC,CAAC,CAAC;MAE7BX,MAAM,CAACmB,KAAK,CAAC,MAAM,WAAWf,KAAK,+BAA+BiB,OAAO,EAAEU,EAAE,CAAC,CAAC,EAAE,CAAC;IACpF;IAEA,IAAIV,OAAO,IAAIX,CAAC,CAACP,KAAK,CAACuB,mBAAmB,EAAE;MAC1CC,UAAU,CAAC,MAAMjB,CAAC,CAACP,KAAK,CAACuB,mBAAmB,CAACL,OAAO,CAAC,EAAE,CAAC,CAAC;IAC3D;IAEA,OAAOA,OAAO;EAChB,CAAC,EAAE,EAAE,CAAC;EAENX,CAAC,CAACuB,SAAS,CAAC;IAACZ,OAAO,EAAEA,CAAA,KAAMO,kBAAkB,CAAC;EAAC,CAAC,CAAC;EAElD,MAAMM,iBAAiB,GAAG5C,WAAW,CAAC,MAAM;IAC1CoB,CAAC,CAACe,GAAG,CAAC;MAACJ,OAAO,EAAE5B,MAAM,CAACiB,CAAC,CAACM,CAAC,CAACL,SAAS,CAAC,CAAC;IAAC,CAAC,CAAC;EAC3C,CAAC,EAAE,EAAE,CAAC;EAENnB,OAAO,CAAC,MAAM;IACZ,IAAI,CAACC,MAAM,CAAC4B,OAAO,CAAC,CAAC,CAACW,qBAAqB,CAACtB,CAAC,CAACM,CAAC,CAACZ,KAAK,CAAC,IAAI,CAACX,MAAM,CAAC4B,OAAO,CAAC,CAAC,CAACQ,eAAe,CAACnB,CAAC,CAACM,CAAC,CAACZ,KAAK,CAAC,EAAE;MACtGJ,MAAM,CAACmB,KAAK,CAAC,MAAM,mCAAmCT,CAAC,CAACM,CAAC,CAACZ,KAAK,0BAA0B,CAAC;MAC1FW,0BAA0B,CAAC,CAAC;IAC9B;EACF,CAAC,EAAE,EAAE,CAAC;EAEN,MAAMoB,cAAc,GAAG7C,WAAW,CAAC,MAAM;IACvC4C,iBAAiB,CAAC,CAAC;EACrB,CAAC,EAAE,EAAE,CAAC;EAEN,MAAME,eAAe,GAAG9C,WAAW,CAAC,MAAM;IACxC4C,iBAAiB,CAAC,CAAC;EACrB,CAAC,EAAE,EAAE,CAAC;EAENpC,eAAe,CAACL,MAAM,CAAC4C,MAAM,CAAC,CAAC,EAAE,gBAAgB,EAAEF,cAAc,CAAC;EAClErC,eAAe,CAACL,MAAM,CAAC4C,MAAM,CAAC,CAAC,EAAE,iBAAiB,EAAED,eAAe,CAAC;EAEpE,oBACEhD,KAAA,CAAAkD,aAAA,CAACzB,YAAY,CAAC0B,QAAQ;IAACC,KAAK,EAAE9B,CAAC,CAACA,CAAC,CAACW;EAAQ,GACvClB,KAAK,CAACsC,QACc,CAAC;AAE5B,CAAC;AAED,SAAQhC,eAAe;AACvB,eAAeP,cAAc","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/inputs/money.jsx
CHANGED
|
@@ -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={
|
|
68
|
-
onChange={
|
|
69
|
-
onKeyUp={
|
|
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={
|
|
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
|
}))
|
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
|