dataflux 1.2.2 → 1.3.0

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/dist/Store.js CHANGED
@@ -5,7 +5,7 @@ Object.defineProperty(exports, "__esModule", {
5
5
  });
6
6
  exports["default"] = void 0;
7
7
 
8
- var _StoreObject = _interopRequireDefault(require("./StoreObject"));
8
+ var _Obj = _interopRequireDefault(require("./Obj"));
9
9
 
10
10
  var _PubSub = _interopRequireDefault(require("./PubSub"));
11
11
 
@@ -17,21 +17,29 @@ function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o =
17
17
 
18
18
  function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
19
19
 
20
- function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
21
-
22
20
  function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
23
21
 
24
22
  function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
25
23
 
26
24
  function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
27
25
 
26
+ function _classPrivateFieldInitSpec(obj, privateMap, value) { _checkPrivateRedeclaration(obj, privateMap); privateMap.set(obj, value); }
27
+
28
28
  function _classPrivateMethodInitSpec(obj, privateSet) { _checkPrivateRedeclaration(obj, privateSet); privateSet.add(obj); }
29
29
 
30
30
  function _checkPrivateRedeclaration(obj, privateCollection) { if (privateCollection.has(obj)) { throw new TypeError("Cannot initialize the same private elements twice on an object"); } }
31
31
 
32
+ function _classPrivateFieldGet(receiver, privateMap) { var descriptor = _classExtractFieldDescriptor(receiver, privateMap, "get"); return _classApplyDescriptorGet(receiver, descriptor); }
33
+
34
+ function _classExtractFieldDescriptor(receiver, privateMap, action) { if (!privateMap.has(receiver)) { throw new TypeError("attempted to " + action + " private field on non-instance"); } return privateMap.get(receiver); }
35
+
36
+ function _classApplyDescriptorGet(receiver, descriptor) { if (descriptor.get) { return descriptor.get.call(receiver); } return descriptor.value; }
37
+
32
38
  function _classPrivateMethodGet(receiver, privateSet, fn) { if (!privateSet.has(receiver)) { throw new TypeError("attempted to get private field on non-instance"); } return fn; }
33
39
 
34
- var _deleteByObject = /*#__PURE__*/new WeakSet();
40
+ var _error = /*#__PURE__*/new WeakSet();
41
+
42
+ var _deleteByObject = /*#__PURE__*/new WeakMap();
35
43
 
36
44
  var _deleteByFilter = /*#__PURE__*/new WeakSet();
37
45
 
@@ -43,6 +51,8 @@ var _loadObjects = /*#__PURE__*/new WeakSet();
43
51
 
44
52
  var Store = /*#__PURE__*/function () {
45
53
  function Store() {
54
+ var _this = this;
55
+
46
56
  var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
47
57
 
48
58
  _classCallCheck(this, Store);
@@ -55,10 +65,23 @@ var Store = /*#__PURE__*/function () {
55
65
 
56
66
  _classPrivateMethodInitSpec(this, _deleteByFilter);
57
67
 
58
- _classPrivateMethodInitSpec(this, _deleteByObject);
68
+ _classPrivateMethodInitSpec(this, _error);
69
+
70
+ _classPrivateFieldInitSpec(this, _deleteByObject, {
71
+ writable: true,
72
+ value: function value(object) {
73
+ var id = object.getId();
74
+
75
+ var filterFunction = function filterFunction(item) {
76
+ return id === item.getId();
77
+ };
78
+
79
+ return _classPrivateMethodGet(_this, _deleteByFilter, _deleteByFilter2).call(_this, object.getModel().getType(), filterFunction);
80
+ }
81
+ });
59
82
 
60
83
  this.options = {
61
- autoSave: options.autoSave !== undefined ? options.autoSave : 5000,
84
+ autoSave: options.autoSave !== undefined ? options.autoSave : true,
62
85
  saveDelay: options.saveDelay || 1000,
63
86
  lazyLoad: options.lazyLoad || false
64
87
  };
@@ -83,65 +106,75 @@ var Store = /*#__PURE__*/function () {
83
106
  }, {
84
107
  key: "addModel",
85
108
  value: function addModel(model) {
86
- var _this = this;
109
+ var _this2 = this;
87
110
 
88
111
  return new Promise(function (resolve, reject) {
89
- _this.validateModel(model);
112
+ _this2.validateModel(model);
90
113
 
91
114
  var type = model.getType();
92
115
 
93
- if (!_this.models[type]) {
94
- _this.models[type] = {
116
+ if (!_this2.models[type]) {
117
+ _this2.models[type] = {
95
118
  model: model,
96
119
  storedObjects: {}
97
120
  };
98
- model.setStore(_this);
121
+ model.setStore(_this2);
99
122
 
100
- if (!_this.options.lazyLoad) {
101
- resolve(_classPrivateMethodGet(_this, _loadObjects, _loadObjects2).call(_this, type));
123
+ if (!_this2.options.lazyLoad) {
124
+ resolve(_classPrivateMethodGet(_this2, _loadObjects, _loadObjects2).call(_this2, type));
102
125
  } else {
103
126
  resolve();
104
127
  }
105
128
  } else {
106
- reject("The model already exists");
129
+ var error = "The model already exists";
130
+
131
+ _this2.pubSub.publish("error", error);
132
+
133
+ reject(error);
107
134
  }
108
135
  });
109
136
  }
110
137
  }, {
111
138
  key: "update",
112
139
  value: function update(objects) {
113
- return Promise.resolve(); // Nothing to do at this level
140
+ return Promise.resolve(objects); // Nothing to do at this level
114
141
  }
115
142
  }, {
116
143
  key: "delete",
117
144
  value: function _delete(typeOrObjects, filterFunction) {
118
145
  if (typeof typeOrObjects === "string" && typeof filterFunction === "function") {
119
- return _classPrivateMethodGet(this, _deleteByFilter, _deleteByFilter2).call(this, typeOrObjects, filterFunction);
120
- } else if (_typeof(typeOrObjects) === "object" && typeOrObjects.length) {
121
- return Promise.all(typeOrObjects.map(_classPrivateMethodGet(this, _deleteByObject, _deleteByObject2)));
146
+ var type = typeOrObjects;
147
+ return _classPrivateMethodGet(this, _deleteByFilter, _deleteByFilter2).call(this, type, filterFunction);
148
+ } else if (Array.isArray(typeOrObjects) && typeOrObjects.length && !filterFunction) {
149
+ var objects = typeOrObjects;
150
+ return Promise.all(objects.map(_classPrivateFieldGet(this, _deleteByObject))).then(function (data) {
151
+ return data.flat();
152
+ });
122
153
  } else {
123
- return Promise.reject("Invalid delete request. You have to provide a list of objects or a type and a filter function");
154
+ var error = "Invalid delete request. You have to provide a list of objects or a type and a filter function";
155
+ this.pubSub.publish("error", error);
156
+ return Promise.reject(error);
124
157
  }
125
158
  }
126
159
  }, {
127
160
  key: "insert",
128
161
  value: function insert(type, objects) {
129
- var _this2 = this;
162
+ var _this3 = this;
130
163
 
131
164
  return _classPrivateMethodGet(this, _getPromise, _getPromise2).call(this, type).then(function () {
132
165
  return objects.map(function (object) {
133
- return _classPrivateMethodGet(_this2, _insertObject, _insertObject2).call(_this2, type, object, true);
166
+ return _classPrivateMethodGet(_this3, _insertObject, _insertObject2).call(_this3, type, object, true);
134
167
  });
135
168
  });
136
169
  }
137
170
  }, {
138
171
  key: "get",
139
172
  value: function get(type, id) {
140
- var _this3 = this;
173
+ var _this4 = this;
141
174
 
142
175
  return _classPrivateMethodGet(this, _getPromise, _getPromise2).call(this, type).then(function () {
143
176
  try {
144
- return _this3.models[type].storedObjects[id].object;
177
+ return _this4.models[type].storedObjects[id].object;
145
178
  } catch (error) {
146
179
  return Promise.reject("Object not found");
147
180
  }
@@ -150,17 +183,17 @@ var Store = /*#__PURE__*/function () {
150
183
  }, {
151
184
  key: "find",
152
185
  value: function find(type, filterFunction) {
153
- var _this4 = this;
186
+ var _this5 = this;
154
187
 
155
188
  return _classPrivateMethodGet(this, _getPromise, _getPromise2).call(this, type).then(function () {
156
- var all = Object.values(_this4.models[type].storedObjects).filter(function (i) {
189
+ var all = Object.values(_this5.models[type].storedObjects).filter(function (i) {
157
190
  return i.status !== "deleted";
158
191
  }).map(function (i) {
159
192
  return i.object;
160
193
  });
161
194
  return filterFunction ? all.filter(filterFunction) : all;
162
195
  })["catch"](function (error) {
163
- _this4.pubSub.publish("error", error);
196
+ _this5.pubSub.publish("error", error);
164
197
 
165
198
  return Promise.reject(error);
166
199
  });
@@ -168,7 +201,7 @@ var Store = /*#__PURE__*/function () {
168
201
  }, {
169
202
  key: "applyDiff",
170
203
  value: function applyDiff(_ref, type) {
171
- var _this5 = this;
204
+ var _this6 = this;
172
205
 
173
206
  var _ref$inserted = _ref.inserted,
174
207
  inserted = _ref$inserted === void 0 ? [] : _ref$inserted,
@@ -185,7 +218,7 @@ var Store = /*#__PURE__*/function () {
185
218
  for (_iterator.s(); !(_step = _iterator.n()).done;) {
186
219
  var object = _step.value;
187
220
 
188
- var item = _this5.models[type || object.object.getModel().getType()].storedObjects[object.id];
221
+ var item = _this6.models[type || object.object.getModel().getType()].storedObjects[object.id];
189
222
 
190
223
  item.fingerprint = object.object.getFingerprint();
191
224
  item.status = "old";
@@ -202,7 +235,7 @@ var Store = /*#__PURE__*/function () {
202
235
  try {
203
236
  for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {
204
237
  var _object = _step2.value;
205
- delete _this5.models[type || _object.object.getModel().getType()].storedObjects[_object.id];
238
+ delete _this6.models[type || _object.object.getModel().getType()].storedObjects[_object.id];
206
239
  }
207
240
  } catch (err) {
208
241
  _iterator2.e(err);
@@ -216,13 +249,19 @@ var Store = /*#__PURE__*/function () {
216
249
  }
217
250
  });
218
251
  }
252
+ }, {
253
+ key: "hasChanged",
254
+ value: function hasChanged(type, object) {
255
+ var obj = this.models[type].storedObjects[object.getId()];
256
+ return obj.fingerprint !== obj.object.getFingerprint();
257
+ }
219
258
  }, {
220
259
  key: "getDiff",
221
260
  value: function getDiff(type) {
222
- var _this6 = this;
261
+ var _this7 = this;
223
262
 
224
263
  return _classPrivateMethodGet(this, _getPromise, _getPromise2).call(this, type).then(function () {
225
- var objects = Object.values(_this6.models[type].storedObjects);
264
+ var objects = Object.values(_this7.models[type].storedObjects);
226
265
  var inserted = [];
227
266
  var updated = [];
228
267
  var deleted = [];
@@ -234,7 +273,7 @@ var Store = /*#__PURE__*/function () {
234
273
  inserted.push(object);
235
274
  } else if (object.status === "deleted") {
236
275
  deleted.push(object);
237
- } else if (object.fingerprint !== object.object.getFingerprint()) {
276
+ } else if (_this7.hasChanged(type, object.object)) {
238
277
  updated.push(object);
239
278
  }
240
279
  }
@@ -253,17 +292,17 @@ var Store = /*#__PURE__*/function () {
253
292
 
254
293
  exports["default"] = Store;
255
294
 
256
- function _deleteByObject2(object) {
257
- return _classPrivateMethodGet(this, _deleteByFilter, _deleteByFilter2).call(this, object.getType(), function (item) {
258
- return object.getId() === item.getId();
259
- });
295
+ function _error2(error) {
296
+ error = error.message || error;
297
+ this.pubSub.publish("error", error);
298
+ return Promise.reject(error);
260
299
  }
261
300
 
262
301
  function _deleteByFilter2(type, filterFunction) {
263
- var _this7 = this;
302
+ var _this8 = this;
264
303
 
265
304
  return _classPrivateMethodGet(this, _getPromise, _getPromise2).call(this, type).then(function () {
266
- var deleted = Object.values(_this7.models[type].storedObjects).filter(function (i) {
305
+ var deleted = Object.values(_this8.models[type].storedObjects).filter(function (i) {
267
306
  return filterFunction(i.object);
268
307
  });
269
308
 
@@ -281,12 +320,14 @@ function _deleteByFilter2(type, filterFunction) {
281
320
  _iterator3.f();
282
321
  }
283
322
 
284
- return true;
323
+ return deleted.map(function (i) {
324
+ return i.object;
325
+ });
285
326
  });
286
327
  }
287
328
 
288
329
  function _getPromise2(type) {
289
- var _this8 = this;
330
+ var _this9 = this;
290
331
 
291
332
  if (!this.models[type]) {
292
333
  return Promise.reject("The model doesn't exist");
@@ -294,7 +335,7 @@ function _getPromise2(type) {
294
335
  return Promise.reject("The model is not loaded");
295
336
  } else if (!this.models[type].promise && this.options.lazyLoad) {
296
337
  return _classPrivateMethodGet(this, _loadObjects, _loadObjects2).call(this, type).then(function () {
297
- return _this8.models[type].promise;
338
+ return _this9.models[type].promise;
298
339
  });
299
340
  } else {
300
341
  return this.models[type].promise;
@@ -304,7 +345,7 @@ function _getPromise2(type) {
304
345
  function _insertObject2(type, item) {
305
346
  var markAsNew = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;
306
347
  var model = this.models[type].model;
307
- var wrapper = new _StoreObject["default"](item, model);
348
+ var wrapper = new _Obj["default"](item, model);
308
349
  var id = wrapper.getId();
309
350
 
310
351
  if (this.models[type].storedObjects[id]) {
@@ -321,7 +362,7 @@ function _insertObject2(type, item) {
321
362
  }
322
363
 
323
364
  function _loadObjects2(type) {
324
- var _this9 = this;
365
+ var _this10 = this;
325
366
 
326
367
  var item = this.models[type];
327
368
  this.pubSub.publish("loading", {
@@ -336,7 +377,7 @@ function _loadObjects2(type) {
336
377
  for (_iterator4.s(); !(_step4 = _iterator4.n()).done;) {
337
378
  var _item = _step4.value;
338
379
 
339
- _classPrivateMethodGet(_this9, _insertObject, _insertObject2).call(_this9, type, _item, false);
380
+ _classPrivateMethodGet(_this10, _insertObject, _insertObject2).call(_this10, type, _item, false);
340
381
  }
341
382
  } catch (err) {
342
383
  _iterator4.e(err);
@@ -344,7 +385,7 @@ function _loadObjects2(type) {
344
385
  _iterator4.f();
345
386
  }
346
387
 
347
- _this9.pubSub.publish("loading", {
388
+ _this10.pubSub.publish("loading", {
348
389
  status: "end",
349
390
  model: type
350
391
  });
@@ -5,6 +5,10 @@ Object.defineProperty(exports, "__esModule", {
5
5
  });
6
6
  exports["default"] = fingerprint;
7
7
 
8
+ var _moment = _interopRequireDefault(require("moment"));
9
+
10
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
11
+
8
12
  function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it["return"] != null) it["return"](); } finally { if (didErr) throw err; } } }; }
9
13
 
10
14
  function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
@@ -18,7 +22,15 @@ var CRC32 = require('crc-32');
18
22
  var _getFingerprint = function _getFingerprint(object) {
19
23
  switch (_typeof(object)) {
20
24
  case "object":
21
- return "o:".concat(object !== null ? getObjectFingerprint(object) : "null");
25
+ if (object._isAMomentObject) {
26
+ return "m:".concat(object.toISOString());
27
+ } else if (object instanceof Date) {
28
+ return "m:".concat((0, _moment["default"])(object).toISOString());
29
+ } else if (object !== null) {
30
+ return "o:".concat(getObjectFingerprint(object));
31
+ } else {
32
+ return "o:null";
33
+ }
22
34
 
23
35
  case "boolean":
24
36
  return "b:".concat(object ? "t" : "f");
package/package.json CHANGED
@@ -1,12 +1,12 @@
1
1
  {
2
2
  "name": "dataflux",
3
- "version": "1.2.2",
3
+ "version": "1.3.0",
4
4
  "description": "DataFlux, automatically interfaces with your REST APIs to create a 2-way-synced local data store. Transparently manages data propagation in the React state.",
5
5
  "main": "dist/index.js",
6
6
  "bin": "dist/index.js",
7
7
  "scripts": {
8
8
  "babel": "node_modules/.bin/babel",
9
- "test": "./node_modules/.bin/mocha tests --require @babel/register",
9
+ "test": "./node_modules/.bin/mocha tests/*.test.js --require @babel/register --exit",
10
10
  "compile": "rm -rf dist/ && ./node_modules/.bin/babel src -d dist",
11
11
  "release": "dotenv release-it"
12
12
  },
@@ -86,14 +86,18 @@
86
86
  "@babel/plugin-transform-runtime": "^7.16.10",
87
87
  "@babel/preset-env": "^7.16.11",
88
88
  "@babel/preset-react": "^7.16.7",
89
+ "chai": "^4.3.4",
90
+ "chai-subset": "^1.6.0",
89
91
  "dotenv-cli": "^4.1.1",
90
- "release-it": "^14.12.3"
92
+ "mocha": "^9.2.0",
93
+ "release-it": "^14.12.4"
91
94
  },
92
95
  "dependencies": {
93
96
  "axios": "^0.25.0",
94
97
  "batch-promises": "^0.0.3",
95
98
  "brembo": "^2.0.6",
96
99
  "crc-32": "^1.2.0",
100
+ "moment": "^2.29.1",
97
101
  "uuid": "^8.3.2"
98
102
  },
99
103
  "resolutions": {}