@uql/core 0.4.81 → 0.4.84

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.
Files changed (49) hide show
  1. package/README.md +36 -51
  2. package/dialect/abstractSqlDialect-spec.d.ts +49 -0
  3. package/dialect/abstractSqlDialect-spec.js +765 -0
  4. package/dialect/mysqlDialect.spec.d.ts +6 -0
  5. package/dialect/mysqlDialect.spec.js +33 -0
  6. package/dialect/postgresDialect.spec.d.ts +1 -0
  7. package/dialect/postgresDialect.spec.js +139 -0
  8. package/dialect/sqliteDialect.spec.d.ts +1 -0
  9. package/dialect/sqliteDialect.spec.js +12 -0
  10. package/entity/decorator/definition.js +18 -18
  11. package/entity/decorator/definition.spec.d.ts +1 -0
  12. package/entity/decorator/definition.spec.js +725 -0
  13. package/entity/decorator/relation.spec.d.ts +1 -0
  14. package/entity/decorator/relation.spec.js +55 -0
  15. package/options.spec.d.ts +1 -0
  16. package/options.spec.js +50 -0
  17. package/package.json +3 -3
  18. package/querier/abstractQuerier-it.d.ts +41 -0
  19. package/querier/abstractQuerier-it.js +410 -0
  20. package/querier/abstractSqlQuerier-it.d.ts +9 -0
  21. package/querier/abstractSqlQuerier-it.js +19 -0
  22. package/querier/abstractSqlQuerier-spec.d.ts +53 -0
  23. package/querier/abstractSqlQuerier-spec.js +607 -0
  24. package/querier/decorator/injectQuerier.spec.d.ts +1 -0
  25. package/querier/decorator/injectQuerier.spec.js +108 -0
  26. package/querier/decorator/transactional.spec.d.ts +1 -0
  27. package/querier/decorator/transactional.spec.js +241 -0
  28. package/repository/genericRepository.spec.d.ts +1 -0
  29. package/repository/genericRepository.spec.js +86 -0
  30. package/test/entityMock.d.ts +180 -0
  31. package/test/entityMock.js +451 -0
  32. package/test/index.d.ts +3 -0
  33. package/test/index.js +7 -0
  34. package/test/it.util.d.ts +4 -0
  35. package/test/it.util.js +60 -0
  36. package/test/spec.util.d.ts +13 -0
  37. package/test/spec.util.js +54 -0
  38. package/type/entity.d.ts +15 -20
  39. package/type/entity.js +1 -1
  40. package/type/utility.d.ts +1 -1
  41. package/type/utility.js +1 -1
  42. package/util/dialect.util.spec.d.ts +1 -0
  43. package/util/dialect.util.spec.js +23 -0
  44. package/util/object.util.spec.d.ts +1 -0
  45. package/util/object.util.spec.js +26 -0
  46. package/util/sql.util.spec.d.ts +1 -0
  47. package/util/sql.util.spec.js +164 -0
  48. package/util/string.util.spec.d.ts +1 -0
  49. package/util/string.util.spec.js +26 -0
@@ -0,0 +1,180 @@
1
+ import { idKey } from '@uql/core/type';
2
+ /**
3
+ * interfaces can (optionally) be used to avoid circular-reference issue between entities.
4
+ */
5
+ export interface IEntity {
6
+ id?: number;
7
+ companyId?: number;
8
+ company?: ICompany;
9
+ creatorId?: number;
10
+ creator?: IUser;
11
+ createdAt?: number;
12
+ updatedAt?: number;
13
+ }
14
+ interface ICompany extends IEntity {
15
+ name?: string;
16
+ description?: string;
17
+ }
18
+ interface IUser extends IEntity {
19
+ name?: string;
20
+ email?: string;
21
+ password?: string;
22
+ profile?: Profile;
23
+ }
24
+ /**
25
+ * an abstract class can (optionally) be used as a "template" for the entities
26
+ * (so the common attributes' declaration is reused).
27
+ */
28
+ export declare abstract class BaseEntity implements IEntity {
29
+ id?: number;
30
+ /**
31
+ * foreign-keys are really simple to specify
32
+ */
33
+ companyId?: number;
34
+ company?: ICompany;
35
+ creatorId?: number;
36
+ creator?: IUser;
37
+ /**
38
+ * 'onInsert' callback can be used to specify a custom mechanism for
39
+ * obtaining the value of a field when inserting:
40
+ */
41
+ createdAt?: number;
42
+ /**
43
+ * 'onUpdate' callback can be used to specify a custom mechanism for
44
+ * obtaining the value of a field when updating:
45
+ */
46
+ updatedAt?: number;
47
+ }
48
+ /**
49
+ * `Company` will inherit all the fields (including the `Id`) declared in `BaseEntity`.
50
+ */
51
+ export declare class Company extends BaseEntity implements ICompany {
52
+ name?: string;
53
+ description?: string;
54
+ }
55
+ /**
56
+ * and entity can specify the table name
57
+ */
58
+ export declare class Profile extends BaseEntity {
59
+ /**
60
+ * an entity can specify its own ID Field and still inherit the others
61
+ * columns/relations from its parent entity.
62
+ * 'onInsert' callback can be used to specify a custom mechanism for
63
+ * auto-generating the primary-key's value when inserting.
64
+ */
65
+ id?: number;
66
+ picture?: string;
67
+ creator?: IUser;
68
+ }
69
+ export declare class User extends BaseEntity implements IUser {
70
+ name?: string;
71
+ email?: string;
72
+ password?: string;
73
+ /**
74
+ * `mappedBy` can be a callback or a string (callback is useful for auto-refactoring).
75
+ */
76
+ profile?: Profile;
77
+ users?: User[];
78
+ }
79
+ export declare class LedgerAccount extends BaseEntity {
80
+ name?: string;
81
+ description?: string;
82
+ parentLedgerId?: number;
83
+ parentLedger?: LedgerAccount;
84
+ }
85
+ export declare class TaxCategory extends BaseEntity {
86
+ /**
87
+ * `idKey` symbol can be used to specify the name of the identifier property,
88
+ * so the type of the identifier can always be type-safe
89
+ * (the identifiers named as `id` or `_id` are auto-inferred).
90
+ */
91
+ [idKey]?: 'pk';
92
+ /**
93
+ * an entity can specify its own ID Field and still inherit the others
94
+ * columns/relations from its parent entity.
95
+ * 'onInsert' callback can be used to specify a custom mechanism for
96
+ * auto-generating the primary-key's value when inserting.
97
+ */
98
+ pk?: string;
99
+ name?: string;
100
+ description?: string;
101
+ }
102
+ export declare class Test {
103
+ name?: string;
104
+ percentage?: number;
105
+ categoryId?: string;
106
+ category?: TaxCategory;
107
+ description?: string;
108
+ }
109
+ export declare class Tax extends BaseEntity {
110
+ name?: string;
111
+ percentage?: number;
112
+ categoryId?: string;
113
+ category?: TaxCategory;
114
+ description?: string;
115
+ }
116
+ /**
117
+ * `softDelete` will make the entity "soft deletable".
118
+ */
119
+ export declare class MeasureUnitCategory extends BaseEntity {
120
+ name?: string;
121
+ measureUnits?: MeasureUnit[];
122
+ /**
123
+ * `onDelete` callback allows to specify which field will be used when deleting/querying this entity.
124
+ */
125
+ deletedAt?: number;
126
+ }
127
+ export declare class MeasureUnit extends BaseEntity {
128
+ name?: string;
129
+ categoryId?: number;
130
+ category?: MeasureUnitCategory;
131
+ deletedAt?: number;
132
+ }
133
+ export declare class Storehouse extends BaseEntity {
134
+ name?: string;
135
+ address?: string;
136
+ description?: string;
137
+ }
138
+ export declare class Item extends BaseEntity {
139
+ name?: string;
140
+ description?: string;
141
+ code?: string;
142
+ buyLedgerAccountId?: number;
143
+ buyLedgerAccount?: LedgerAccount;
144
+ saleLedgerAccountId?: number;
145
+ saleLedgerAccount?: LedgerAccount;
146
+ taxId?: number;
147
+ tax?: Tax;
148
+ measureUnitId?: number;
149
+ measureUnit?: MeasureUnit;
150
+ salePrice?: number;
151
+ inventoryable?: boolean;
152
+ tags?: Tag[];
153
+ tagsCount?: number;
154
+ }
155
+ export declare class Tag extends BaseEntity {
156
+ name?: string;
157
+ items?: Item[];
158
+ itemsCount?: number;
159
+ }
160
+ export declare class ItemTag {
161
+ id?: number;
162
+ itemId?: number;
163
+ tagId?: number;
164
+ }
165
+ export declare class InventoryAdjustment extends BaseEntity {
166
+ itemAdjustments?: ItemAdjustment[];
167
+ date?: Date;
168
+ description?: string;
169
+ }
170
+ export declare class ItemAdjustment extends BaseEntity {
171
+ itemId?: number;
172
+ item?: Item;
173
+ number?: number;
174
+ buyPrice?: number;
175
+ storehouseId?: number;
176
+ storehouse?: Storehouse;
177
+ inventoryAdjustmentId?: number;
178
+ inventoryAdjustment?: InventoryAdjustment;
179
+ }
180
+ export {};
@@ -0,0 +1,451 @@
1
+ "use strict";
2
+ var User_1, LedgerAccount_1;
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.ItemAdjustment = exports.InventoryAdjustment = exports.ItemTag = exports.Tag = exports.Item = exports.Storehouse = exports.MeasureUnit = exports.MeasureUnitCategory = exports.Tax = exports.Test = exports.TaxCategory = exports.LedgerAccount = exports.User = exports.Profile = exports.Company = exports.BaseEntity = void 0;
5
+ const tslib_1 = require("tslib");
6
+ const uuid_1 = require("uuid");
7
+ const entity_1 = require("@uql/core/entity");
8
+ const util_1 = require("@uql/core/util");
9
+ const type_1 = require("@uql/core/type");
10
+ /**
11
+ * an abstract class can (optionally) be used as a "template" for the entities
12
+ * (so the common attributes' declaration is reused).
13
+ */
14
+ class BaseEntity {
15
+ }
16
+ tslib_1.__decorate([
17
+ (0, entity_1.Id)(),
18
+ tslib_1.__metadata("design:type", Number)
19
+ ], BaseEntity.prototype, "id", void 0);
20
+ tslib_1.__decorate([
21
+ (0, entity_1.Field)({ reference: () => Company }),
22
+ tslib_1.__metadata("design:type", Number)
23
+ ], BaseEntity.prototype, "companyId", void 0);
24
+ tslib_1.__decorate([
25
+ (0, entity_1.ManyToOne)({ entity: () => Company }),
26
+ tslib_1.__metadata("design:type", Object)
27
+ ], BaseEntity.prototype, "company", void 0);
28
+ tslib_1.__decorate([
29
+ (0, entity_1.Field)({ reference: () => User }),
30
+ tslib_1.__metadata("design:type", Number)
31
+ ], BaseEntity.prototype, "creatorId", void 0);
32
+ tslib_1.__decorate([
33
+ (0, entity_1.ManyToOne)({ entity: () => User }),
34
+ tslib_1.__metadata("design:type", Object)
35
+ ], BaseEntity.prototype, "creator", void 0);
36
+ tslib_1.__decorate([
37
+ (0, entity_1.Field)({ onInsert: () => Date.now() }),
38
+ tslib_1.__metadata("design:type", Number)
39
+ ], BaseEntity.prototype, "createdAt", void 0);
40
+ tslib_1.__decorate([
41
+ (0, entity_1.Field)({ onUpdate: () => Date.now() }),
42
+ tslib_1.__metadata("design:type", Number)
43
+ ], BaseEntity.prototype, "updatedAt", void 0);
44
+ exports.BaseEntity = BaseEntity;
45
+ /**
46
+ * `Company` will inherit all the fields (including the `Id`) declared in `BaseEntity`.
47
+ */
48
+ let Company = class Company extends BaseEntity {
49
+ };
50
+ tslib_1.__decorate([
51
+ (0, entity_1.Field)(),
52
+ tslib_1.__metadata("design:type", String)
53
+ ], Company.prototype, "name", void 0);
54
+ tslib_1.__decorate([
55
+ (0, entity_1.Field)(),
56
+ tslib_1.__metadata("design:type", String)
57
+ ], Company.prototype, "description", void 0);
58
+ Company = tslib_1.__decorate([
59
+ (0, entity_1.Entity)()
60
+ ], Company);
61
+ exports.Company = Company;
62
+ /**
63
+ * and entity can specify the table name
64
+ */
65
+ let Profile = class Profile extends BaseEntity {
66
+ };
67
+ tslib_1.__decorate([
68
+ (0, entity_1.Id)({ name: 'pk' }),
69
+ tslib_1.__metadata("design:type", Number)
70
+ ], Profile.prototype, "id", void 0);
71
+ tslib_1.__decorate([
72
+ (0, entity_1.Field)({ name: 'image' }),
73
+ tslib_1.__metadata("design:type", String)
74
+ ], Profile.prototype, "picture", void 0);
75
+ tslib_1.__decorate([
76
+ (0, entity_1.OneToOne)({ entity: () => User }),
77
+ tslib_1.__metadata("design:type", Object)
78
+ ], Profile.prototype, "creator", void 0);
79
+ Profile = tslib_1.__decorate([
80
+ (0, entity_1.Entity)({ name: 'user_profile' })
81
+ ], Profile);
82
+ exports.Profile = Profile;
83
+ let User = User_1 = class User extends BaseEntity {
84
+ };
85
+ tslib_1.__decorate([
86
+ (0, entity_1.Field)(),
87
+ tslib_1.__metadata("design:type", String)
88
+ ], User.prototype, "name", void 0);
89
+ tslib_1.__decorate([
90
+ (0, entity_1.Field)(),
91
+ tslib_1.__metadata("design:type", String)
92
+ ], User.prototype, "email", void 0);
93
+ tslib_1.__decorate([
94
+ (0, entity_1.Field)(),
95
+ tslib_1.__metadata("design:type", String)
96
+ ], User.prototype, "password", void 0);
97
+ tslib_1.__decorate([
98
+ (0, entity_1.OneToOne)({ entity: () => Profile, mappedBy: (profile) => profile.creator, cascade: true }),
99
+ tslib_1.__metadata("design:type", Profile)
100
+ ], User.prototype, "profile", void 0);
101
+ tslib_1.__decorate([
102
+ (0, entity_1.OneToMany)({ entity: () => User_1, mappedBy: 'creator' }),
103
+ tslib_1.__metadata("design:type", Array)
104
+ ], User.prototype, "users", void 0);
105
+ User = User_1 = tslib_1.__decorate([
106
+ (0, entity_1.Entity)()
107
+ ], User);
108
+ exports.User = User;
109
+ let LedgerAccount = LedgerAccount_1 = class LedgerAccount extends BaseEntity {
110
+ };
111
+ tslib_1.__decorate([
112
+ (0, entity_1.Field)(),
113
+ tslib_1.__metadata("design:type", String)
114
+ ], LedgerAccount.prototype, "name", void 0);
115
+ tslib_1.__decorate([
116
+ (0, entity_1.Field)(),
117
+ tslib_1.__metadata("design:type", String)
118
+ ], LedgerAccount.prototype, "description", void 0);
119
+ tslib_1.__decorate([
120
+ (0, entity_1.Field)({ reference: () => LedgerAccount_1 }),
121
+ tslib_1.__metadata("design:type", Number)
122
+ ], LedgerAccount.prototype, "parentLedgerId", void 0);
123
+ tslib_1.__decorate([
124
+ (0, entity_1.ManyToOne)(),
125
+ tslib_1.__metadata("design:type", LedgerAccount)
126
+ ], LedgerAccount.prototype, "parentLedger", void 0);
127
+ LedgerAccount = LedgerAccount_1 = tslib_1.__decorate([
128
+ (0, entity_1.Entity)()
129
+ ], LedgerAccount);
130
+ exports.LedgerAccount = LedgerAccount;
131
+ let TaxCategory = class TaxCategory extends BaseEntity {
132
+ };
133
+ tslib_1.__decorate([
134
+ (0, entity_1.Id)({ onInsert: uuid_1.v4 }),
135
+ tslib_1.__metadata("design:type", String)
136
+ ], TaxCategory.prototype, "pk", void 0);
137
+ tslib_1.__decorate([
138
+ (0, entity_1.Field)(),
139
+ tslib_1.__metadata("design:type", String)
140
+ ], TaxCategory.prototype, "name", void 0);
141
+ tslib_1.__decorate([
142
+ (0, entity_1.Field)(),
143
+ tslib_1.__metadata("design:type", String)
144
+ ], TaxCategory.prototype, "description", void 0);
145
+ TaxCategory = tslib_1.__decorate([
146
+ (0, entity_1.Entity)()
147
+ ], TaxCategory);
148
+ exports.TaxCategory = TaxCategory;
149
+ class Test {
150
+ }
151
+ tslib_1.__decorate([
152
+ (0, entity_1.Field)(),
153
+ tslib_1.__metadata("design:type", String)
154
+ ], Test.prototype, "name", void 0);
155
+ tslib_1.__decorate([
156
+ (0, entity_1.Field)(),
157
+ tslib_1.__metadata("design:type", Number)
158
+ ], Test.prototype, "percentage", void 0);
159
+ tslib_1.__decorate([
160
+ (0, entity_1.Field)({ reference: () => TaxCategory }),
161
+ tslib_1.__metadata("design:type", String)
162
+ ], Test.prototype, "categoryId", void 0);
163
+ tslib_1.__decorate([
164
+ (0, entity_1.ManyToOne)(),
165
+ tslib_1.__metadata("design:type", TaxCategory)
166
+ ], Test.prototype, "category", void 0);
167
+ tslib_1.__decorate([
168
+ (0, entity_1.Field)(),
169
+ tslib_1.__metadata("design:type", String)
170
+ ], Test.prototype, "description", void 0);
171
+ exports.Test = Test;
172
+ let Tax = class Tax extends BaseEntity {
173
+ };
174
+ tslib_1.__decorate([
175
+ (0, entity_1.Field)(),
176
+ tslib_1.__metadata("design:type", String)
177
+ ], Tax.prototype, "name", void 0);
178
+ tslib_1.__decorate([
179
+ (0, entity_1.Field)(),
180
+ tslib_1.__metadata("design:type", Number)
181
+ ], Tax.prototype, "percentage", void 0);
182
+ tslib_1.__decorate([
183
+ (0, entity_1.Field)({ reference: () => TaxCategory }),
184
+ tslib_1.__metadata("design:type", String)
185
+ ], Tax.prototype, "categoryId", void 0);
186
+ tslib_1.__decorate([
187
+ (0, entity_1.ManyToOne)(),
188
+ tslib_1.__metadata("design:type", TaxCategory)
189
+ ], Tax.prototype, "category", void 0);
190
+ tslib_1.__decorate([
191
+ (0, entity_1.Field)(),
192
+ tslib_1.__metadata("design:type", String)
193
+ ], Tax.prototype, "description", void 0);
194
+ Tax = tslib_1.__decorate([
195
+ (0, entity_1.Entity)()
196
+ ], Tax);
197
+ exports.Tax = Tax;
198
+ /**
199
+ * `softDelete` will make the entity "soft deletable".
200
+ */
201
+ let MeasureUnitCategory = class MeasureUnitCategory extends BaseEntity {
202
+ };
203
+ tslib_1.__decorate([
204
+ (0, entity_1.Field)(),
205
+ tslib_1.__metadata("design:type", String)
206
+ ], MeasureUnitCategory.prototype, "name", void 0);
207
+ tslib_1.__decorate([
208
+ (0, entity_1.OneToMany)({ entity: () => MeasureUnit, mappedBy: (measureUnit) => measureUnit.categoryId }),
209
+ tslib_1.__metadata("design:type", Array)
210
+ ], MeasureUnitCategory.prototype, "measureUnits", void 0);
211
+ tslib_1.__decorate([
212
+ (0, entity_1.Field)({ onDelete: () => Date.now() }),
213
+ tslib_1.__metadata("design:type", Number)
214
+ ], MeasureUnitCategory.prototype, "deletedAt", void 0);
215
+ MeasureUnitCategory = tslib_1.__decorate([
216
+ (0, entity_1.Entity)({ softDelete: true })
217
+ ], MeasureUnitCategory);
218
+ exports.MeasureUnitCategory = MeasureUnitCategory;
219
+ let MeasureUnit = class MeasureUnit extends BaseEntity {
220
+ };
221
+ tslib_1.__decorate([
222
+ (0, entity_1.Field)(),
223
+ tslib_1.__metadata("design:type", String)
224
+ ], MeasureUnit.prototype, "name", void 0);
225
+ tslib_1.__decorate([
226
+ (0, entity_1.Field)({ reference: () => MeasureUnitCategory }),
227
+ tslib_1.__metadata("design:type", Number)
228
+ ], MeasureUnit.prototype, "categoryId", void 0);
229
+ tslib_1.__decorate([
230
+ (0, entity_1.ManyToOne)({ cascade: 'persist' }),
231
+ tslib_1.__metadata("design:type", MeasureUnitCategory)
232
+ ], MeasureUnit.prototype, "category", void 0);
233
+ tslib_1.__decorate([
234
+ (0, entity_1.Field)({ onDelete: () => Date.now() }),
235
+ tslib_1.__metadata("design:type", Number)
236
+ ], MeasureUnit.prototype, "deletedAt", void 0);
237
+ MeasureUnit = tslib_1.__decorate([
238
+ (0, entity_1.Entity)({ softDelete: true })
239
+ ], MeasureUnit);
240
+ exports.MeasureUnit = MeasureUnit;
241
+ let Storehouse = class Storehouse extends BaseEntity {
242
+ };
243
+ tslib_1.__decorate([
244
+ (0, entity_1.Field)(),
245
+ tslib_1.__metadata("design:type", String)
246
+ ], Storehouse.prototype, "name", void 0);
247
+ tslib_1.__decorate([
248
+ (0, entity_1.Field)(),
249
+ tslib_1.__metadata("design:type", String)
250
+ ], Storehouse.prototype, "address", void 0);
251
+ tslib_1.__decorate([
252
+ (0, entity_1.Field)(),
253
+ tslib_1.__metadata("design:type", String)
254
+ ], Storehouse.prototype, "description", void 0);
255
+ Storehouse = tslib_1.__decorate([
256
+ (0, entity_1.Entity)()
257
+ ], Storehouse);
258
+ exports.Storehouse = Storehouse;
259
+ let Item = class Item extends BaseEntity {
260
+ };
261
+ tslib_1.__decorate([
262
+ (0, entity_1.Field)(),
263
+ tslib_1.__metadata("design:type", String)
264
+ ], Item.prototype, "name", void 0);
265
+ tslib_1.__decorate([
266
+ (0, entity_1.Field)(),
267
+ tslib_1.__metadata("design:type", String)
268
+ ], Item.prototype, "description", void 0);
269
+ tslib_1.__decorate([
270
+ (0, entity_1.Field)(),
271
+ tslib_1.__metadata("design:type", String)
272
+ ], Item.prototype, "code", void 0);
273
+ tslib_1.__decorate([
274
+ (0, entity_1.Field)({ reference: () => LedgerAccount }),
275
+ tslib_1.__metadata("design:type", Number)
276
+ ], Item.prototype, "buyLedgerAccountId", void 0);
277
+ tslib_1.__decorate([
278
+ (0, entity_1.ManyToOne)(),
279
+ tslib_1.__metadata("design:type", LedgerAccount)
280
+ ], Item.prototype, "buyLedgerAccount", void 0);
281
+ tslib_1.__decorate([
282
+ (0, entity_1.Field)({ reference: () => LedgerAccount }),
283
+ tslib_1.__metadata("design:type", Number)
284
+ ], Item.prototype, "saleLedgerAccountId", void 0);
285
+ tslib_1.__decorate([
286
+ (0, entity_1.ManyToOne)(),
287
+ tslib_1.__metadata("design:type", LedgerAccount)
288
+ ], Item.prototype, "saleLedgerAccount", void 0);
289
+ tslib_1.__decorate([
290
+ (0, entity_1.Field)({ reference: () => Tax }),
291
+ tslib_1.__metadata("design:type", Number)
292
+ ], Item.prototype, "taxId", void 0);
293
+ tslib_1.__decorate([
294
+ (0, entity_1.ManyToOne)(),
295
+ tslib_1.__metadata("design:type", Tax)
296
+ ], Item.prototype, "tax", void 0);
297
+ tslib_1.__decorate([
298
+ (0, entity_1.Field)({ reference: () => MeasureUnit }),
299
+ tslib_1.__metadata("design:type", Number)
300
+ ], Item.prototype, "measureUnitId", void 0);
301
+ tslib_1.__decorate([
302
+ (0, entity_1.ManyToOne)(),
303
+ tslib_1.__metadata("design:type", MeasureUnit)
304
+ ], Item.prototype, "measureUnit", void 0);
305
+ tslib_1.__decorate([
306
+ (0, entity_1.Field)(),
307
+ tslib_1.__metadata("design:type", Number)
308
+ ], Item.prototype, "salePrice", void 0);
309
+ tslib_1.__decorate([
310
+ (0, entity_1.Field)(),
311
+ tslib_1.__metadata("design:type", Boolean)
312
+ ], Item.prototype, "inventoryable", void 0);
313
+ tslib_1.__decorate([
314
+ (0, entity_1.ManyToMany)({ entity: () => Tag, through: () => ItemTag, cascade: true }),
315
+ tslib_1.__metadata("design:type", Array)
316
+ ], Item.prototype, "tags", void 0);
317
+ tslib_1.__decorate([
318
+ (0, entity_1.Field)({
319
+ /**
320
+ * `virtual` property allows defining the value for a non-persistent field,
321
+ * such value might be a scalar or a (`raw`) function. Virtual-fields can be
322
+ * used in `$project`, `$filter` and `$having` as a common field whose value
323
+ * is replaced at runtime.
324
+ */
325
+ virtual: (0, util_1.raw)(({ escapedPrefix, dialect }) => {
326
+ const query = dialect.count(ItemTag, {
327
+ $filter: {
328
+ itemId: (0, util_1.raw)(`${escapedPrefix}${dialect.escapeId('id')}`),
329
+ },
330
+ }, { autoPrefix: true });
331
+ return `(${query})`;
332
+ }),
333
+ }),
334
+ tslib_1.__metadata("design:type", Number)
335
+ ], Item.prototype, "tagsCount", void 0);
336
+ Item = tslib_1.__decorate([
337
+ (0, entity_1.Entity)()
338
+ ], Item);
339
+ exports.Item = Item;
340
+ let Tag = class Tag extends BaseEntity {
341
+ };
342
+ tslib_1.__decorate([
343
+ (0, entity_1.Field)(),
344
+ tslib_1.__metadata("design:type", String)
345
+ ], Tag.prototype, "name", void 0);
346
+ tslib_1.__decorate([
347
+ (0, entity_1.ManyToMany)({ entity: () => Item, mappedBy: (item) => item.tags }),
348
+ tslib_1.__metadata("design:type", Array)
349
+ ], Tag.prototype, "items", void 0);
350
+ tslib_1.__decorate([
351
+ (0, entity_1.Field)({
352
+ virtual: (0, util_1.raw)(({ escapedPrefix, dialect }) => {
353
+ /**
354
+ * `virtual` property allows defining the value for a non-persistent field,
355
+ * such value might be a scalar or a (`raw`) function. Virtual-fields can be
356
+ * used in `$project`, `$filter` and `$having` as a common field whose value
357
+ * is replaced at runtime.
358
+ */
359
+ const query = dialect.count(ItemTag, {
360
+ $filter: {
361
+ tagId: (0, util_1.raw)(`${escapedPrefix}${dialect.escapeId('id')}`),
362
+ },
363
+ }, { autoPrefix: true });
364
+ return `(${query})`;
365
+ }),
366
+ }),
367
+ tslib_1.__metadata("design:type", Number)
368
+ ], Tag.prototype, "itemsCount", void 0);
369
+ Tag = tslib_1.__decorate([
370
+ (0, entity_1.Entity)()
371
+ ], Tag);
372
+ exports.Tag = Tag;
373
+ let ItemTag = class ItemTag {
374
+ };
375
+ tslib_1.__decorate([
376
+ (0, entity_1.Id)(),
377
+ tslib_1.__metadata("design:type", Number)
378
+ ], ItemTag.prototype, "id", void 0);
379
+ tslib_1.__decorate([
380
+ (0, entity_1.Field)({ reference: () => Item }),
381
+ tslib_1.__metadata("design:type", Number)
382
+ ], ItemTag.prototype, "itemId", void 0);
383
+ tslib_1.__decorate([
384
+ (0, entity_1.Field)({ reference: () => Tag }),
385
+ tslib_1.__metadata("design:type", Number)
386
+ ], ItemTag.prototype, "tagId", void 0);
387
+ ItemTag = tslib_1.__decorate([
388
+ (0, entity_1.Entity)()
389
+ ], ItemTag);
390
+ exports.ItemTag = ItemTag;
391
+ let InventoryAdjustment = class InventoryAdjustment extends BaseEntity {
392
+ };
393
+ tslib_1.__decorate([
394
+ (0, entity_1.OneToMany)({
395
+ entity: () => ItemAdjustment,
396
+ mappedBy: (rel) => rel.inventoryAdjustment,
397
+ cascade: true,
398
+ }),
399
+ tslib_1.__metadata("design:type", Array)
400
+ ], InventoryAdjustment.prototype, "itemAdjustments", void 0);
401
+ tslib_1.__decorate([
402
+ (0, entity_1.Field)(),
403
+ tslib_1.__metadata("design:type", Date)
404
+ ], InventoryAdjustment.prototype, "date", void 0);
405
+ tslib_1.__decorate([
406
+ (0, entity_1.Field)(),
407
+ tslib_1.__metadata("design:type", String)
408
+ ], InventoryAdjustment.prototype, "description", void 0);
409
+ InventoryAdjustment = tslib_1.__decorate([
410
+ (0, entity_1.Entity)()
411
+ ], InventoryAdjustment);
412
+ exports.InventoryAdjustment = InventoryAdjustment;
413
+ let ItemAdjustment = class ItemAdjustment extends BaseEntity {
414
+ };
415
+ tslib_1.__decorate([
416
+ (0, entity_1.Field)({ reference: () => Item }),
417
+ tslib_1.__metadata("design:type", Number)
418
+ ], ItemAdjustment.prototype, "itemId", void 0);
419
+ tslib_1.__decorate([
420
+ (0, entity_1.ManyToOne)(),
421
+ tslib_1.__metadata("design:type", Item)
422
+ ], ItemAdjustment.prototype, "item", void 0);
423
+ tslib_1.__decorate([
424
+ (0, entity_1.Field)(),
425
+ tslib_1.__metadata("design:type", Number)
426
+ ], ItemAdjustment.prototype, "number", void 0);
427
+ tslib_1.__decorate([
428
+ (0, entity_1.Field)(),
429
+ tslib_1.__metadata("design:type", Number)
430
+ ], ItemAdjustment.prototype, "buyPrice", void 0);
431
+ tslib_1.__decorate([
432
+ (0, entity_1.Field)({ reference: () => Storehouse }),
433
+ tslib_1.__metadata("design:type", Number)
434
+ ], ItemAdjustment.prototype, "storehouseId", void 0);
435
+ tslib_1.__decorate([
436
+ (0, entity_1.ManyToOne)(),
437
+ tslib_1.__metadata("design:type", Storehouse)
438
+ ], ItemAdjustment.prototype, "storehouse", void 0);
439
+ tslib_1.__decorate([
440
+ (0, entity_1.Field)({ reference: () => InventoryAdjustment }),
441
+ tslib_1.__metadata("design:type", Number)
442
+ ], ItemAdjustment.prototype, "inventoryAdjustmentId", void 0);
443
+ tslib_1.__decorate([
444
+ (0, entity_1.ManyToOne)(),
445
+ tslib_1.__metadata("design:type", InventoryAdjustment)
446
+ ], ItemAdjustment.prototype, "inventoryAdjustment", void 0);
447
+ ItemAdjustment = tslib_1.__decorate([
448
+ (0, entity_1.Entity)()
449
+ ], ItemAdjustment);
450
+ exports.ItemAdjustment = ItemAdjustment;
451
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"entityMock.js","sourceRoot":"","sources":["../../src/test/entityMock.ts"],"names":[],"mappings":"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","sourcesContent":["import { v4 as uuidv4 } from 'uuid';\nimport { Field, ManyToOne, Id, OneToMany, Entity, OneToOne, ManyToMany } from '@uql/core/entity';\nimport { raw } from '@uql/core/util';\nimport { idKey } from '@uql/core/type';\n\n/**\n * interfaces can (optionally) be used to avoid circular-reference issue between entities.\n */\nexport interface IEntity {\n  id?: number;\n  companyId?: number;\n  company?: ICompany;\n  creatorId?: number;\n  creator?: IUser;\n  createdAt?: number;\n  updatedAt?: number;\n}\n\ninterface ICompany extends IEntity {\n  name?: string;\n  description?: string;\n}\n\ninterface IUser extends IEntity {\n  name?: string;\n  email?: string;\n  password?: string;\n  profile?: Profile;\n}\n\n/**\n * an abstract class can (optionally) be used as a \"template\" for the entities\n * (so the common attributes' declaration is reused).\n */\nexport abstract class BaseEntity implements IEntity {\n  @Id()\n  id?: number;\n  /**\n   * foreign-keys are really simple to specify\n   */\n  @Field({ reference: () => Company })\n  companyId?: number;\n  @ManyToOne({ entity: () => Company })\n  company?: ICompany;\n  @Field({ reference: () => User })\n  creatorId?: number;\n  @ManyToOne({ entity: () => User })\n  creator?: IUser;\n  /**\n   * 'onInsert' callback can be used to specify a custom mechanism for\n   * obtaining the value of a field when inserting:\n   */\n  @Field({ onInsert: () => Date.now() })\n  createdAt?: number;\n  /**\n   * 'onUpdate' callback can be used to specify a custom mechanism for\n   * obtaining the value of a field when updating:\n   */\n  @Field({ onUpdate: () => Date.now() })\n  updatedAt?: number;\n}\n\n/**\n * `Company` will inherit all the fields (including the `Id`) declared in `BaseEntity`.\n */\n@Entity()\nexport class Company extends BaseEntity implements ICompany {\n  @Field()\n  name?: string;\n  @Field()\n  description?: string;\n}\n\n/**\n * and entity can specify the table name\n */\n@Entity({ name: 'user_profile' })\nexport class Profile extends BaseEntity {\n  /**\n   * an entity can specify its own ID Field and still inherit the others\n   * columns/relations from its parent entity.\n   * 'onInsert' callback can be used to specify a custom mechanism for\n   * auto-generating the primary-key's value when inserting.\n   */\n  @Id({ name: 'pk' })\n  override id?: number;\n  @Field({ name: 'image' })\n  picture?: string;\n  @OneToOne({ entity: () => User })\n  override creator?: IUser;\n}\n\n@Entity()\nexport class User extends BaseEntity implements IUser {\n  @Field()\n  name?: string;\n  @Field()\n  email?: string;\n  @Field()\n  password?: string;\n  /**\n   * `mappedBy` can be a callback or a string (callback is useful for auto-refactoring).\n   */\n  @OneToOne({ entity: () => Profile, mappedBy: (profile) => profile.creator, cascade: true })\n  profile?: Profile;\n  @OneToMany({ entity: () => User, mappedBy: 'creator' })\n  users?: User[];\n}\n\n@Entity()\nexport class LedgerAccount extends BaseEntity {\n  @Field()\n  name?: string;\n  @Field()\n  description?: string;\n  @Field({ reference: () => LedgerAccount })\n  parentLedgerId?: number;\n  @ManyToOne()\n  parentLedger?: LedgerAccount;\n}\n\n@Entity()\nexport class TaxCategory extends BaseEntity {\n  /**\n   * `idKey` symbol can be used to specify the name of the identifier property,\n   * so the type of the identifier can always be type-safe\n   * (the identifiers named as `id` or `_id` are auto-inferred).\n   */\n  [idKey]?: 'pk';\n  /**\n   * an entity can specify its own ID Field and still inherit the others\n   * columns/relations from its parent entity.\n   * 'onInsert' callback can be used to specify a custom mechanism for\n   * auto-generating the primary-key's value when inserting.\n   */\n  @Id({ onInsert: uuidv4 })\n  pk?: string;\n  @Field()\n  name?: string;\n  @Field()\n  description?: string;\n}\n\nexport class Test {\n  @Field()\n  name?: string;\n  @Field()\n  percentage?: number;\n  @Field({ reference: () => TaxCategory })\n  categoryId?: string;\n  @ManyToOne()\n  category?: TaxCategory;\n  @Field()\n  description?: string;\n}\n\n@Entity()\nexport class Tax extends BaseEntity {\n  @Field()\n  name?: string;\n  @Field()\n  percentage?: number;\n  @Field({ reference: () => TaxCategory })\n  categoryId?: string;\n  @ManyToOne()\n  category?: TaxCategory;\n  @Field()\n  description?: string;\n}\n\n/**\n * `softDelete` will make the entity \"soft deletable\".\n */\n@Entity({ softDelete: true })\nexport class MeasureUnitCategory extends BaseEntity {\n  @Field()\n  name?: string;\n  @OneToMany({ entity: () => MeasureUnit, mappedBy: (measureUnit) => measureUnit.categoryId })\n  measureUnits?: MeasureUnit[];\n  /**\n   * `onDelete` callback allows to specify which field will be used when deleting/querying this entity.\n   */\n  @Field({ onDelete: () => Date.now() })\n  deletedAt?: number;\n}\n\n@Entity({ softDelete: true })\nexport class MeasureUnit extends BaseEntity {\n  @Field()\n  name?: string;\n  @Field({ reference: () => MeasureUnitCategory })\n  categoryId?: number;\n  @ManyToOne({ cascade: 'persist' })\n  category?: MeasureUnitCategory;\n  @Field({ onDelete: () => Date.now() })\n  deletedAt?: number;\n}\n\n@Entity()\nexport class Storehouse extends BaseEntity {\n  @Field()\n  name?: string;\n  @Field()\n  address?: string;\n  @Field()\n  description?: string;\n}\n\n@Entity()\nexport class Item extends BaseEntity {\n  @Field()\n  name?: string;\n  @Field()\n  description?: string;\n  @Field()\n  code?: string;\n  @Field({ reference: () => LedgerAccount })\n  buyLedgerAccountId?: number;\n  @ManyToOne()\n  buyLedgerAccount?: LedgerAccount;\n  @Field({ reference: () => LedgerAccount })\n  saleLedgerAccountId?: number;\n  @ManyToOne()\n  saleLedgerAccount?: LedgerAccount;\n  @Field({ reference: () => Tax })\n  taxId?: number;\n  @ManyToOne()\n  tax?: Tax;\n  @Field({ reference: () => MeasureUnit })\n  measureUnitId?: number;\n  @ManyToOne()\n  measureUnit?: MeasureUnit;\n  @Field()\n  salePrice?: number;\n  @Field()\n  inventoryable?: boolean;\n  @ManyToMany({ entity: () => Tag, through: () => ItemTag, cascade: true })\n  tags?: Tag[];\n  @Field({\n    /**\n     * `virtual` property allows defining the value for a non-persistent field,\n     * such value might be a scalar or a (`raw`) function. Virtual-fields can be\n     * used in `$project`, `$filter` and `$having` as a common field whose value\n     * is replaced at runtime.\n     */\n    virtual: raw(({ escapedPrefix, dialect }) => {\n      const query = dialect.count(\n        ItemTag,\n        {\n          $filter: {\n            itemId: raw(`${escapedPrefix}${dialect.escapeId('id')}`),\n          },\n        },\n        { autoPrefix: true }\n      );\n      return `(${query})`;\n    }),\n  })\n  tagsCount?: number;\n}\n\n@Entity()\nexport class Tag extends BaseEntity {\n  @Field()\n  name?: string;\n  @ManyToMany({ entity: () => Item, mappedBy: (item) => item.tags })\n  items?: Item[];\n  @Field({\n    virtual: raw(({ escapedPrefix, dialect }) => {\n      /**\n       * `virtual` property allows defining the value for a non-persistent field,\n       * such value might be a scalar or a (`raw`) function. Virtual-fields can be\n       * used in `$project`, `$filter` and `$having` as a common field whose value\n       * is replaced at runtime.\n       */\n      const query = dialect.count(\n        ItemTag,\n        {\n          $filter: {\n            tagId: raw(`${escapedPrefix}${dialect.escapeId('id')}`),\n          },\n        },\n        { autoPrefix: true }\n      );\n      return `(${query})`;\n    }),\n  })\n  itemsCount?: number;\n}\n\n@Entity()\nexport class ItemTag {\n  @Id()\n  id?: number;\n  @Field({ reference: () => Item })\n  itemId?: number;\n  @Field({ reference: () => Tag })\n  tagId?: number;\n}\n\n@Entity()\nexport class InventoryAdjustment extends BaseEntity {\n  @OneToMany({\n    entity: () => ItemAdjustment,\n    mappedBy: (rel) => rel.inventoryAdjustment,\n    cascade: true,\n  })\n  itemAdjustments?: ItemAdjustment[];\n  @Field()\n  date?: Date;\n  @Field()\n  description?: string;\n}\n\n@Entity()\nexport class ItemAdjustment extends BaseEntity {\n  @Field({ reference: () => Item })\n  itemId?: number;\n  @ManyToOne()\n  item?: Item;\n  @Field()\n  number?: number;\n  @Field()\n  buyPrice?: number;\n  @Field({ reference: () => Storehouse })\n  storehouseId?: number;\n  @ManyToOne()\n  storehouse?: Storehouse;\n  @Field({ reference: () => InventoryAdjustment })\n  inventoryAdjustmentId?: number;\n  @ManyToOne()\n  inventoryAdjustment?: InventoryAdjustment;\n}\n"]}
@@ -0,0 +1,3 @@
1
+ export * from './entityMock';
2
+ export * from './spec.util';
3
+ export * from './it.util';
package/test/index.js ADDED
@@ -0,0 +1,7 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const tslib_1 = require("tslib");
4
+ tslib_1.__exportStar(require("./entityMock"), exports);
5
+ tslib_1.__exportStar(require("./spec.util"), exports);
6
+ tslib_1.__exportStar(require("./it.util"), exports);
7
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdGVzdC9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSx1REFBNkI7QUFDN0Isc0RBQTRCO0FBQzVCLG9EQUEwQiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vZW50aXR5TW9jayc7XG5leHBvcnQgKiBmcm9tICcuL3NwZWMudXRpbCc7XG5leHBvcnQgKiBmcm9tICcuL2l0LnV0aWwnO1xuIl19