xdriver 1.0.4 → 1.0.8

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/lib/Driver.d.ts CHANGED
@@ -6,7 +6,7 @@ declare class Driver extends Database {
6
6
  selectByKey(table: string, key: any): any;
7
7
  count(table: string, keyRange?: KeyRange): any;
8
8
  update(table: string, modify: any, where: any): Promise<unknown> | undefined;
9
- delete(table: string, key: any): void;
10
- truncate(table: string): void;
9
+ delete(table: string, key: any): any;
10
+ truncate(table: string): any;
11
11
  }
12
12
  export default Driver;
package/lib/Table.d.ts CHANGED
@@ -16,12 +16,14 @@ export default class Table {
16
16
  }, database: Database);
17
17
  insert(data: Array<any>): Promise<unknown>;
18
18
  update(modify: any, where?: any): Promise<unknown> | undefined;
19
- delete(key: any): void;
20
- clear(): void;
21
- dropIndex(name: string): void;
19
+ merge(row: any): Promise<unknown> | undefined;
20
+ delete(key: any): any;
21
+ clear(): any;
22
+ dropIndex(name: string): any;
22
23
  keys(keyRange?: KeyRange, limit?: number): any;
23
24
  count(keyRange?: KeyRange): any;
24
25
  query(keyRange?: KeyRange, limit?: number): any;
26
+ select(where: any, options?: any): any;
25
27
  queryByKey(key: any): any;
26
28
  fetch(keyRange?: KeyRange, direction?: CursorDirection): Promise<unknown>;
27
29
  queryByIndex(name: string, key: any, count?: number): any;
package/lib/Table.js CHANGED
@@ -68,14 +68,27 @@ export default class Table {
68
68
  });
69
69
  }
70
70
  }
71
+ merge(row) {
72
+ let { primaryKey } = this;
73
+ if (row[primaryKey]) {
74
+ let where = {};
75
+ where[primaryKey] = primaryKey;
76
+ let modify = Object.assign({}, row);
77
+ delete modify[primaryKey];
78
+ return this.update(modify, where);
79
+ }
80
+ else {
81
+ return this.insert(row);
82
+ }
83
+ }
71
84
  delete(key) {
72
- _request(_getObjectStore(this, TransactionMode.READ_WRITE).delete(key));
85
+ return _request(_getObjectStore(this, TransactionMode.READ_WRITE).delete(key));
73
86
  }
74
87
  clear() {
75
- _request(_getObjectStore(this, TransactionMode.READ_WRITE).clear());
88
+ return _request(_getObjectStore(this, TransactionMode.READ_WRITE).clear());
76
89
  }
77
90
  dropIndex(name) {
78
- _getObjectStore(this, TransactionMode.READ_WRITE).deleteIndex(name);
91
+ return _getObjectStore(this, TransactionMode.READ_WRITE).deleteIndex(name);
79
92
  }
80
93
  keys(keyRange, limit) {
81
94
  const store = _getObjectStore(this);
@@ -90,6 +103,16 @@ export default class Table {
90
103
  const request = _getObjectStore(this).getAll(keyRange, limit);
91
104
  return _request(request);
92
105
  }
106
+ select(where, options) {
107
+ if (!where) {
108
+ return this.query();
109
+ }
110
+ let { index = '', limit = void 0, useIndex = false } = options;
111
+ if (useIndex && index) {
112
+ return this.queryByIndex(index, where, limit);
113
+ }
114
+ return this.query(where, limit);
115
+ }
93
116
  queryByKey(key) {
94
117
  const request = _getObjectStore(this).get(key);
95
118
  return _request(request);
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "xdriver",
3
- "version": "1.0.04",
3
+ "version": "1.0.08",
4
4
  "description": "A simple driver for IndexDB",
5
5
  "main": "./lib/index",
6
6
  "files": [