@kaspernj/api-maker 1.0.142 → 1.0.145

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/.eslintrc.js CHANGED
@@ -112,6 +112,7 @@ module.exports = {
112
112
  "no-bitwise": "error",
113
113
  "no-caller": "error",
114
114
  "no-confusing-arrow": "error",
115
+ "no-constant-binary-expression": "error",
115
116
  "no-constructor-return": "error",
116
117
  "no-continue": "error",
117
118
  "no-div-regex": "error",
package/package.json CHANGED
@@ -16,7 +16,7 @@
16
16
  ]
17
17
  },
18
18
  "name": "@kaspernj/api-maker",
19
- "version": "1.0.142",
19
+ "version": "1.0.145",
20
20
  "description": "",
21
21
  "main": "index.js",
22
22
  "repository": {
@@ -65,13 +65,13 @@
65
65
  "@babel/eslint-parser": "^7.16.3",
66
66
  "@babel/preset-env": "^7.12.11",
67
67
  "@babel/preset-react": "^7.12.10",
68
- "babel-jest": "^27.0.6",
68
+ "babel-jest": "^28.0.3",
69
69
  "eslint": "^8.2.0",
70
70
  "eslint-find-rules": "^4.0.0",
71
71
  "eslint-plugin-jest": "^26.0.0",
72
72
  "eslint-plugin-react": "^7.23.2",
73
73
  "i18n-on-steroids": "^1.0.2",
74
- "jest": "^27.0.6",
74
+ "jest": "^28.0.3",
75
75
  "jsdom": "^19.0.0"
76
76
  }
77
77
  }
@@ -366,8 +366,8 @@ class BaseModel {
366
366
  }
367
367
 
368
368
  isNewRecord () {
369
- if (this.newRecord === false) {
370
- return false
369
+ if (this.newRecord !== undefined) {
370
+ return this.newRecord
371
371
  } else if ("id" in this.modelData && this.modelData.id) {
372
372
  return false
373
373
  } else {
@@ -676,7 +676,9 @@ class BaseModel {
676
676
  if (attributeName in attributes) return null
677
677
  }
678
678
 
679
- throw new AttributeNotLoadedError(`No such attribute: ${digg(this.modelClassData(), "name")}#${attributeName}: ${JSON.stringify(this.modelData)}`)
679
+ if (this.isPersisted()) {
680
+ throw new AttributeNotLoadedError(`No such attribute: ${digg(this.modelClassData(), "name")}#${attributeName}: ${JSON.stringify(this.modelData)}`)
681
+ }
680
682
  }
681
683
 
682
684
  isAttributeLoaded (attributeName) {
package/src/config.js CHANGED
@@ -1,12 +1,18 @@
1
1
  class ApiMakerConfig {
2
+ constructor() {
3
+ if (!global.apiMakerConfigGlobal) global.apiMakerConfigGlobal = {}
4
+
5
+ this.global = global.apiMakerConfigGlobal
6
+ }
7
+
2
8
  getCurrenciesCollection() {
3
- if (!this._currenciesCollection) throw new Error("Currencies collection hasn't been set")
9
+ if (!this.global.currenciesCollection) throw new Error("Currencies collection hasn't been set")
4
10
 
5
- return this._currenciesCollection
11
+ return this.global.currenciesCollection
6
12
  }
7
13
 
8
14
  setCurrenciesCollection(newCurrenciesCollection) {
9
- this._currenciesCollection = newCurrenciesCollection
15
+ this.global.currenciesCollection = newCurrenciesCollection
10
16
  }
11
17
  }
12
18
 
@@ -36,11 +36,18 @@ export default (WrappedComponent, ModelClass, args = {}) => class modelLoadWrapp
36
36
  this.setState({model})
37
37
  }
38
38
 
39
- loadNewModel() {
39
+ async loadNewModel() {
40
40
  const params = Params.parse()
41
41
  const paramKey = ModelClass.modelName().paramKey()
42
42
  const modelDataFromParams = params[paramKey] || {}
43
- const modelData = Object.assign({}, args.newAttributes, modelDataFromParams)
43
+
44
+ let defaults = {}
45
+
46
+ if (args.newIfNoId?.defaults) {
47
+ defaults = await args.newIfNoId.defaults()
48
+ }
49
+
50
+ const modelData = Object.assign(defaults, args.newAttributes, modelDataFromParams)
44
51
  const model = new ModelClass(modelData)
45
52
 
46
53
  this.setState({model})
@@ -57,7 +57,7 @@ module.exports = class MoneyFormatter {
57
57
  static isMoney(value) {
58
58
  if (value instanceof Money) return true
59
59
 
60
- if (typeof value == "object" && value && Object.keys(value).length == 2 && value.amount && value.currency)
60
+ if (typeof value == "object" && value && Object.keys(value).length == 2 && "amount" in value && "currency" in value)
61
61
  return true
62
62
 
63
63
  return false