1 | ;
|
2 | // Copyright IBM Corp. and LoopBack contributors 2018,2020. All Rights Reserved.
|
3 | // Node module: @loopback/repository
|
4 | // This file is licensed under the MIT License.
|
5 | // License text available at https://opensource.org/licenses/MIT
|
6 | Object.defineProperty(exports, "__esModule", { value: true });
|
7 | exports.hasMany = void 0;
|
8 | const relation_decorator_1 = require("../relation.decorator");
|
9 | const relation_types_1 = require("../relation.types");
|
10 | /**
|
11 | * Decorator for hasMany
|
12 | * Calls property.array decorator underneath the hood and infers foreign key
|
13 | * name from target model name unless explicitly specified
|
14 | * @param targetResolver - Target model for hasMany relation
|
15 | * @param definition - Optional metadata for setting up hasMany relation
|
16 | * @returns A property decorator
|
17 | */
|
18 | function hasMany(targetResolver, definition) {
|
19 | return function (decoratedTarget, key) {
|
20 | const meta = Object.assign(
|
21 | // default values, can be customized by the caller
|
22 | { name: key },
|
23 | // properties provided by the caller
|
24 | definition,
|
25 | // properties enforced by the decorator
|
26 | {
|
27 | type: relation_types_1.RelationType.hasMany,
|
28 | targetsMany: true,
|
29 | source: decoratedTarget.constructor,
|
30 | target: targetResolver,
|
31 | });
|
32 | (0, relation_decorator_1.relation)(meta)(decoratedTarget, key);
|
33 | };
|
34 | }
|
35 | exports.hasMany = hasMany;
|
36 | //# sourceMappingURL=has-many.decorator.js.map |
\ | No newline at end of file |