@vendure/core 1.5.2 → 1.6.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/api/common/configurable-operation-codec.js +2 -2
- package/dist/api/common/configurable-operation-codec.js.map +1 -1
- package/dist/api/decorators/relations.decorator.d.ts +102 -0
- package/dist/api/decorators/relations.decorator.js +187 -0
- package/dist/api/decorators/relations.decorator.js.map +1 -0
- package/dist/api/index.d.ts +1 -0
- package/dist/api/index.js +1 -0
- package/dist/api/index.js.map +1 -1
- package/dist/api/resolvers/admin/administrator.resolver.d.ts +3 -2
- package/dist/api/resolvers/admin/administrator.resolver.js +10 -6
- package/dist/api/resolvers/admin/administrator.resolver.js.map +1 -1
- package/dist/api/resolvers/admin/asset.resolver.d.ts +3 -2
- package/dist/api/resolvers/admin/asset.resolver.js +10 -6
- package/dist/api/resolvers/admin/asset.resolver.js.map +1 -1
- package/dist/api/resolvers/admin/collection.resolver.d.ts +5 -3
- package/dist/api/resolvers/admin/collection.resolver.js +25 -7
- package/dist/api/resolvers/admin/collection.resolver.js.map +1 -1
- package/dist/api/resolvers/admin/country.resolver.d.ts +3 -2
- package/dist/api/resolvers/admin/country.resolver.js +10 -6
- package/dist/api/resolvers/admin/country.resolver.js.map +1 -1
- package/dist/api/resolvers/admin/customer-group.resolver.d.ts +3 -2
- package/dist/api/resolvers/admin/customer-group.resolver.js +8 -4
- package/dist/api/resolvers/admin/customer-group.resolver.js.map +1 -1
- package/dist/api/resolvers/admin/customer.resolver.d.ts +3 -2
- package/dist/api/resolvers/admin/customer.resolver.js +10 -6
- package/dist/api/resolvers/admin/customer.resolver.js.map +1 -1
- package/dist/api/resolvers/admin/facet.resolver.d.ts +3 -2
- package/dist/api/resolvers/admin/facet.resolver.js +10 -6
- package/dist/api/resolvers/admin/facet.resolver.js.map +1 -1
- package/dist/api/resolvers/admin/order.resolver.d.ts +6 -5
- package/dist/api/resolvers/admin/order.resolver.js +25 -11
- package/dist/api/resolvers/admin/order.resolver.js.map +1 -1
- package/dist/api/resolvers/admin/payment-method.resolver.d.ts +3 -2
- package/dist/api/resolvers/admin/payment-method.resolver.js +10 -6
- package/dist/api/resolvers/admin/payment-method.resolver.js.map +1 -1
- package/dist/api/resolvers/admin/product-option.resolver.d.ts +3 -2
- package/dist/api/resolvers/admin/product-option.resolver.js +8 -4
- package/dist/api/resolvers/admin/product-option.resolver.js.map +1 -1
- package/dist/api/resolvers/admin/product.resolver.d.ts +4 -3
- package/dist/api/resolvers/admin/product.resolver.js +16 -10
- package/dist/api/resolvers/admin/product.resolver.js.map +1 -1
- package/dist/api/resolvers/admin/promotion.resolver.d.ts +3 -2
- package/dist/api/resolvers/admin/promotion.resolver.js +9 -6
- package/dist/api/resolvers/admin/promotion.resolver.js.map +1 -1
- package/dist/api/resolvers/admin/role.resolver.d.ts +3 -2
- package/dist/api/resolvers/admin/role.resolver.js +10 -6
- package/dist/api/resolvers/admin/role.resolver.js.map +1 -1
- package/dist/api/resolvers/admin/shipping-method.resolver.d.ts +3 -2
- package/dist/api/resolvers/admin/shipping-method.resolver.js +10 -6
- package/dist/api/resolvers/admin/shipping-method.resolver.js.map +1 -1
- package/dist/api/resolvers/admin/tax-rate.resolver.d.ts +3 -2
- package/dist/api/resolvers/admin/tax-rate.resolver.js +10 -6
- package/dist/api/resolvers/admin/tax-rate.resolver.js.map +1 -1
- package/dist/api/resolvers/entity/collection-entity.resolver.d.ts +2 -1
- package/dist/api/resolvers/entity/collection-entity.resolver.js +5 -3
- package/dist/api/resolvers/entity/collection-entity.resolver.js.map +1 -1
- package/dist/api/resolvers/entity/customer-entity.resolver.d.ts +2 -1
- package/dist/api/resolvers/entity/customer-entity.resolver.js +5 -3
- package/dist/api/resolvers/entity/customer-entity.resolver.js.map +1 -1
- package/dist/api/resolvers/entity/order-line-entity.resolver.d.ts +2 -1
- package/dist/api/resolvers/entity/order-line-entity.resolver.js +6 -3
- package/dist/api/resolvers/entity/order-line-entity.resolver.js.map +1 -1
- package/dist/api/resolvers/entity/product-entity.resolver.d.ts +3 -2
- package/dist/api/resolvers/entity/product-entity.resolver.js +10 -6
- package/dist/api/resolvers/entity/product-entity.resolver.js.map +1 -1
- package/dist/api/resolvers/shop/shop-order.resolver.d.ts +4 -3
- package/dist/api/resolvers/shop/shop-order.resolver.js +16 -8
- package/dist/api/resolvers/shop/shop-order.resolver.js.map +1 -1
- package/dist/api/resolvers/shop/shop-products.resolver.d.ts +8 -8
- package/dist/api/resolvers/shop/shop-products.resolver.js +32 -21
- package/dist/api/resolvers/shop/shop-products.resolver.js.map +1 -1
- package/dist/api/schema/admin-api/collection.api.graphql +7 -0
- package/dist/bootstrap.js +2 -0
- package/dist/bootstrap.js.map +1 -1
- package/dist/common/calculated-decorator.d.ts +16 -3
- package/dist/common/calculated-decorator.js +3 -0
- package/dist/common/calculated-decorator.js.map +1 -1
- package/dist/common/types/entity-relation-paths.d.ts +1 -1
- package/dist/config/catalog/collection-filter.d.ts +32 -0
- package/dist/config/catalog/collection-filter.js +32 -0
- package/dist/config/catalog/collection-filter.js.map +1 -1
- package/dist/config/catalog/default-collection-filters.d.ts +100 -0
- package/dist/config/catalog/default-collection-filters.js +154 -21
- package/dist/config/catalog/default-collection-filters.js.map +1 -1
- package/dist/config/config.module.js +2 -0
- package/dist/config/config.module.js.map +1 -1
- package/dist/config/config.service.d.ts +2 -1
- package/dist/config/config.service.js +3 -0
- package/dist/config/config.service.js.map +1 -1
- package/dist/config/custom-field/custom-field-types.d.ts +3 -0
- package/dist/config/default-config.js +5 -0
- package/dist/config/default-config.js.map +1 -1
- package/dist/config/entity-metadata/add-foreign-key-indices.d.ts +12 -0
- package/dist/config/entity-metadata/add-foreign-key-indices.js +33 -0
- package/dist/config/entity-metadata/add-foreign-key-indices.js.map +1 -0
- package/dist/config/entity-metadata/entity-metadata-modifier.d.ts +55 -0
- package/dist/config/entity-metadata/entity-metadata-modifier.js +3 -0
- package/dist/config/entity-metadata/entity-metadata-modifier.js.map +1 -0
- package/dist/config/index.d.ts +3 -0
- package/dist/config/index.js +3 -0
- package/dist/config/index.js.map +1 -1
- package/dist/config/payment/dummy-payment-method-handler.js +2 -2
- package/dist/config/payment/dummy-payment-method-handler.js.map +1 -1
- package/dist/config/payment/example-payment-method-handler.js +2 -2
- package/dist/config/payment/example-payment-method-handler.js.map +1 -1
- package/dist/config/payment/payment-method-eligibility-checker.d.ts +3 -3
- package/dist/config/payment/payment-method-eligibility-checker.js +2 -2
- package/dist/config/payment/payment-method-eligibility-checker.js.map +1 -1
- package/dist/config/payment/payment-method-handler.d.ts +7 -8
- package/dist/config/payment/payment-method-handler.js +6 -6
- package/dist/config/payment/payment-method-handler.js.map +1 -1
- package/dist/config/shipping-method/shipping-calculator.d.ts +3 -3
- package/dist/config/shipping-method/shipping-calculator.js +2 -2
- package/dist/config/shipping-method/shipping-calculator.js.map +1 -1
- package/dist/config/shipping-method/shipping-eligibility-checker.d.ts +4 -4
- package/dist/config/shipping-method/shipping-eligibility-checker.js +5 -5
- package/dist/config/shipping-method/shipping-eligibility-checker.js.map +1 -1
- package/dist/config/system/health-check-strategy.d.ts +47 -0
- package/dist/config/system/health-check-strategy.js +3 -0
- package/dist/config/system/health-check-strategy.js.map +1 -0
- package/dist/config/vendure-config.d.ts +39 -0
- package/dist/connection/transactional-connection.js +5 -0
- package/dist/connection/transactional-connection.js.map +1 -1
- package/dist/data-import/providers/importer/importer.d.ts +3 -2
- package/dist/data-import/providers/importer/importer.js +1 -0
- package/dist/data-import/providers/importer/importer.js.map +1 -1
- package/dist/entity/order/order.entity.js +3 -2
- package/dist/entity/order/order.entity.js.map +1 -1
- package/dist/entity/order-line/order-line.entity.js +22 -22
- package/dist/entity/order-line/order-line.entity.js.map +1 -1
- package/dist/entity/register-custom-entity-fields.js +8 -0
- package/dist/entity/register-custom-entity-fields.js.map +1 -1
- package/dist/entity/run-entity-metadata-modifiers.d.ts +2 -0
- package/dist/entity/run-entity-metadata-modifiers.js +15 -0
- package/dist/entity/run-entity-metadata-modifiers.js.map +1 -0
- package/dist/entity/shipping-method/shipping-method.entity.js +2 -2
- package/dist/entity/shipping-method/shipping-method.entity.js.map +1 -1
- package/dist/event-bus/events/role-event.d.ts +1 -1
- package/dist/event-bus/events/role-event.js +1 -1
- package/dist/event-bus/events/search-event.d.ts +20 -0
- package/dist/event-bus/events/search-event.js +21 -0
- package/dist/event-bus/events/search-event.js.map +1 -0
- package/dist/event-bus/index.d.ts +1 -0
- package/dist/event-bus/index.js +1 -0
- package/dist/event-bus/index.js.map +1 -1
- package/dist/health-check/health-check-registry.service.d.ts +7 -1
- package/dist/health-check/health-check-registry.service.js +7 -1
- package/dist/health-check/health-check-registry.service.js.map +1 -1
- package/dist/health-check/health-check.module.d.ts +1 -3
- package/dist/health-check/health-check.module.js +6 -5
- package/dist/health-check/health-check.module.js.map +1 -1
- package/dist/health-check/http-health-check-strategy.d.ts +36 -0
- package/dist/health-check/http-health-check-strategy.js +41 -0
- package/dist/health-check/http-health-check-strategy.js.map +1 -0
- package/dist/health-check/index.d.ts +2 -0
- package/dist/health-check/index.js +2 -0
- package/dist/health-check/index.js.map +1 -1
- package/dist/health-check/typeorm-health-check-strategy.d.ts +36 -0
- package/dist/health-check/typeorm-health-check-strategy.js +44 -0
- package/dist/health-check/typeorm-health-check-strategy.js.map +1 -0
- package/dist/job-queue/subscribable-job.js +1 -1
- package/dist/plugin/default-search-plugin/default-search-plugin.d.ts +9 -3
- package/dist/plugin/default-search-plugin/default-search-plugin.js +25 -2
- package/dist/plugin/default-search-plugin/default-search-plugin.js.map +1 -1
- package/dist/plugin/default-search-plugin/fulltext-search.service.d.ts +3 -1
- package/dist/plugin/default-search-plugin/fulltext-search.service.js +29 -19
- package/dist/plugin/default-search-plugin/fulltext-search.service.js.map +1 -1
- package/dist/plugin/default-search-plugin/indexer/search-index.service.js +1 -1
- package/dist/plugin/default-search-plugin/indexer/search-index.service.js.map +1 -1
- package/dist/plugin/default-search-plugin/search-strategy/mysql-search-strategy.d.ts +4 -4
- package/dist/plugin/default-search-plugin/search-strategy/mysql-search-strategy.js +7 -3
- package/dist/plugin/default-search-plugin/search-strategy/mysql-search-strategy.js.map +1 -1
- package/dist/plugin/default-search-plugin/search-strategy/postgres-search-strategy.d.ts +4 -4
- package/dist/plugin/default-search-plugin/search-strategy/postgres-search-strategy.js +7 -3
- package/dist/plugin/default-search-plugin/search-strategy/postgres-search-strategy.js.map +1 -1
- package/dist/plugin/default-search-plugin/search-strategy/search-strategy.d.ts +2 -1
- package/dist/plugin/default-search-plugin/search-strategy/sqlite-search-strategy.d.ts +4 -4
- package/dist/plugin/default-search-plugin/search-strategy/sqlite-search-strategy.js +7 -3
- package/dist/plugin/default-search-plugin/search-strategy/sqlite-search-strategy.js.map +1 -1
- package/dist/plugin/default-search-plugin/types.d.ts +84 -0
- package/dist/service/helpers/list-query-builder/list-query-builder.d.ts +28 -0
- package/dist/service/helpers/list-query-builder/list-query-builder.js +118 -17
- package/dist/service/helpers/list-query-builder/list-query-builder.js.map +1 -1
- package/dist/service/helpers/list-query-builder/parse-channel-param.d.ts +1 -1
- package/dist/service/helpers/list-query-builder/parse-channel-param.js +2 -2
- package/dist/service/helpers/list-query-builder/parse-channel-param.js.map +1 -1
- package/dist/service/helpers/list-query-builder/parse-filter-params.d.ts +1 -1
- package/dist/service/helpers/list-query-builder/parse-filter-params.js +3 -2
- package/dist/service/helpers/list-query-builder/parse-filter-params.js.map +1 -1
- package/dist/service/helpers/list-query-builder/parse-sort-params.d.ts +1 -1
- package/dist/service/helpers/list-query-builder/parse-sort-params.js +4 -3
- package/dist/service/helpers/list-query-builder/parse-sort-params.js.map +1 -1
- package/dist/service/helpers/order-modifier/order-modifier.js +2 -1
- package/dist/service/helpers/order-modifier/order-modifier.js.map +1 -1
- package/dist/service/services/administrator.service.d.ts +4 -3
- package/dist/service/services/administrator.service.js +6 -5
- package/dist/service/services/administrator.service.js.map +1 -1
- package/dist/service/services/asset.service.d.ts +3 -2
- package/dist/service/services/asset.service.js +6 -4
- package/dist/service/services/asset.service.js.map +1 -1
- package/dist/service/services/collection.service.d.ts +8 -5
- package/dist/service/services/collection.service.js +42 -12
- package/dist/service/services/collection.service.js.map +1 -1
- package/dist/service/services/country.service.d.ts +3 -2
- package/dist/service/services/country.service.js +4 -4
- package/dist/service/services/country.service.js.map +1 -1
- package/dist/service/services/customer-group.service.d.ts +3 -2
- package/dist/service/services/customer-group.service.js +4 -4
- package/dist/service/services/customer-group.service.js.map +1 -1
- package/dist/service/services/customer.service.d.ts +3 -2
- package/dist/service/services/customer.service.js +3 -3
- package/dist/service/services/customer.service.js.map +1 -1
- package/dist/service/services/facet.service.d.ts +3 -2
- package/dist/service/services/facet.service.js +10 -6
- package/dist/service/services/facet.service.js.map +1 -1
- package/dist/service/services/order.service.d.ts +15 -8
- package/dist/service/services/order.service.js +57 -40
- package/dist/service/services/order.service.js.map +1 -1
- package/dist/service/services/payment-method.service.d.ts +3 -2
- package/dist/service/services/payment-method.service.js +7 -5
- package/dist/service/services/payment-method.service.js.map +1 -1
- package/dist/service/services/payment.service.js +4 -4
- package/dist/service/services/payment.service.js.map +1 -1
- package/dist/service/services/product-option-group.service.d.ts +3 -2
- package/dist/service/services/product-option-group.service.js +4 -4
- package/dist/service/services/product-option-group.service.js.map +1 -1
- package/dist/service/services/product-variant.service.d.ts +10 -3
- package/dist/service/services/product-variant.service.js +35 -35
- package/dist/service/services/product-variant.service.js.map +1 -1
- package/dist/service/services/product.service.d.ts +5 -4
- package/dist/service/services/product.service.js +18 -8
- package/dist/service/services/product.service.js.map +1 -1
- package/dist/service/services/promotion.service.d.ts +3 -2
- package/dist/service/services/promotion.service.js +4 -3
- package/dist/service/services/promotion.service.js.map +1 -1
- package/dist/service/services/role.service.d.ts +3 -2
- package/dist/service/services/role.service.js +4 -4
- package/dist/service/services/role.service.js.map +1 -1
- package/dist/service/services/shipping-method.service.d.ts +3 -2
- package/dist/service/services/shipping-method.service.js +4 -4
- package/dist/service/services/shipping-method.service.js.map +1 -1
- package/dist/service/services/tax-rate.service.d.ts +3 -2
- package/dist/service/services/tax-rate.service.js +4 -4
- package/dist/service/services/tax-rate.service.js.map +1 -1
- package/dist/service/services/zone.service.d.ts +2 -2
- package/dist/service/services/zone.service.js +2 -2
- package/dist/service/services/zone.service.js.map +1 -1
- package/package.json +5 -3
|
@@ -35,7 +35,7 @@ let ConfigurableOperationCodec = class ConfigurableOperationCodec {
|
|
|
35
35
|
}
|
|
36
36
|
for (const arg of operationInput.arguments) {
|
|
37
37
|
const argDef = def.args[arg.name];
|
|
38
|
-
if (argDef.type === 'ID' && arg.value) {
|
|
38
|
+
if (argDef && argDef.type === 'ID' && arg.value) {
|
|
39
39
|
if (argDef.list === true) {
|
|
40
40
|
const ids = JSON.parse(arg.value);
|
|
41
41
|
const decodedIds = ids.map(id => this.idCodecService.decode(id));
|
|
@@ -62,7 +62,7 @@ let ConfigurableOperationCodec = class ConfigurableOperationCodec {
|
|
|
62
62
|
}
|
|
63
63
|
for (const arg of operationInput.args) {
|
|
64
64
|
const argDef = def.args[arg.name];
|
|
65
|
-
if (argDef.type === 'ID' && arg.value) {
|
|
65
|
+
if (argDef && argDef.type === 'ID' && arg.value) {
|
|
66
66
|
if (argDef.list === true) {
|
|
67
67
|
const ids = JSON.parse(arg.value);
|
|
68
68
|
const encodedIds = ids.map(id => this.idCodecService.encode(id));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"configurable-operation-codec.js","sourceRoot":"","sources":["../../../src/api/common/configurable-operation-codec.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAA4C;AAK5C,sDAAgE;AAChE,yCAMsB;AACtB,8EAA0E;AAC1E,gEAA4D;AAC5D,gHAA0G;AAC1G,wFAAmF;AAEnF,yDAAoD;AAGpD,IAAa,0BAA0B,GAAvC,MAAa,0BAA0B;IACnC,YAAoB,aAA4B,EAAU,cAA8B;QAApE,kBAAa,GAAb,aAAa,CAAe;QAAU,mBAAc,GAAd,cAAc,CAAgB;IAAG,CAAC;IAE5F;;OAEG;IACH,8BAA8B,CAC1B,OAA4C,EAC5C,KAAmC;QAEnC,MAAM,aAAa,GAAG,IAAI,CAAC,sBAAsB,CAAC,OAAO,CAAC,CAAC;QAC3D,KAAK,MAAM,cAAc,IAAI,KAAK,EAAE;YAChC,MAAM,GAAG,GAAG,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,cAAc,CAAC,IAAI,CAAC,CAAC;YACpE,IAAI,CAAC,GAAG,EAAE;gBACN,SAAS;aACZ;YACD,KAAK,MAAM,GAAG,IAAI,cAAc,CAAC,SAAS,EAAE;gBACxC,MAAM,MAAM,GAAG,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;gBAClC,IAAI,MAAM,CAAC,IAAI,KAAK,IAAI,IAAI,GAAG,CAAC,KAAK,EAAE;
|
|
1
|
+
{"version":3,"file":"configurable-operation-codec.js","sourceRoot":"","sources":["../../../src/api/common/configurable-operation-codec.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,102 @@
|
|
|
1
|
+
import { Type } from '@vendure/common/lib/shared-types';
|
|
2
|
+
import { EntityRelationPaths } from '../../common/index';
|
|
3
|
+
import { VendureEntity } from '../../entity/index';
|
|
4
|
+
export declare type RelationPaths<T extends VendureEntity> = Array<EntityRelationPaths<T>>;
|
|
5
|
+
export declare type FieldsDecoratorConfig = Type<VendureEntity> | {
|
|
6
|
+
entity: Type<VendureEntity>;
|
|
7
|
+
depth: number;
|
|
8
|
+
};
|
|
9
|
+
/**
|
|
10
|
+
* @description
|
|
11
|
+
* Resolver param decorator which returns an array of relation paths which can be passed through
|
|
12
|
+
* to the TypeORM data layer in order to join only the required relations. This works by inspecting
|
|
13
|
+
* the GraphQL `info` object, examining the field selection, and then comparing this with information
|
|
14
|
+
* about the return type's relations.
|
|
15
|
+
*
|
|
16
|
+
* In addition to analyzing the field selection, this decorator also checks for any `@Calculated()`
|
|
17
|
+
* properties on the entity, and additionally includes relations from the `relations` array of the calculated
|
|
18
|
+
* metadata, if defined.
|
|
19
|
+
*
|
|
20
|
+
* So if, for example, the query only selects the `id` field of an Order, then no other relations need
|
|
21
|
+
* be joined in the resulting SQL query. This can massively speed up execution time for queries which do
|
|
22
|
+
* not include many deep nested relations.
|
|
23
|
+
*
|
|
24
|
+
* @example
|
|
25
|
+
* ```TypeScript
|
|
26
|
+
* \@Query()
|
|
27
|
+
* \@Allow(Permission.ReadOrder)
|
|
28
|
+
* orders(
|
|
29
|
+
* \@Ctx() ctx: RequestContext,
|
|
30
|
+
* \@Args() args: QueryOrdersArgs,
|
|
31
|
+
* \@Relations(Order) relations: RelationPaths<Order>,
|
|
32
|
+
* ): Promise<PaginatedList<Order>> {
|
|
33
|
+
* return this.orderService.findAll(ctx, args.options || undefined, relations);
|
|
34
|
+
* }
|
|
35
|
+
* ```
|
|
36
|
+
*
|
|
37
|
+
* In the above example, given the following query:
|
|
38
|
+
*
|
|
39
|
+
* @example
|
|
40
|
+
* ```GraphQL
|
|
41
|
+
* {
|
|
42
|
+
* orders(options: { take: 10 }) {
|
|
43
|
+
* items {
|
|
44
|
+
* id
|
|
45
|
+
* customer {
|
|
46
|
+
* id
|
|
47
|
+
* firstName
|
|
48
|
+
* lastName
|
|
49
|
+
* }
|
|
50
|
+
* totalQuantity
|
|
51
|
+
* totalWithTax
|
|
52
|
+
* }
|
|
53
|
+
* }
|
|
54
|
+
* }
|
|
55
|
+
* ```
|
|
56
|
+
* then the value of `relations` will be
|
|
57
|
+
*
|
|
58
|
+
* ```
|
|
59
|
+
* ['customer', 'lines', 'lines.items']
|
|
60
|
+
* ```
|
|
61
|
+
* The `'customer'` comes from the fact that the query is nesting the "customer" object, and the `'lines'` & `'lines.items'` are taken
|
|
62
|
+
* from the `Order` entity's `totalQuantity` property, which uses {@link Calculated} decorator and defines those relations as dependencies
|
|
63
|
+
* for deriving the calculated value.
|
|
64
|
+
*
|
|
65
|
+
* ## Depth
|
|
66
|
+
*
|
|
67
|
+
* By default, when inspecting the GraphQL query, the Relations decorator will look 3 levels deep in any nested fields. So, e.g. if
|
|
68
|
+
* the above `orders` query were changed to:
|
|
69
|
+
*
|
|
70
|
+
* @example
|
|
71
|
+
* ```GraphQL
|
|
72
|
+
* {
|
|
73
|
+
* orders(options: { take: 10 }) {
|
|
74
|
+
* items {
|
|
75
|
+
* id
|
|
76
|
+
* lines {
|
|
77
|
+
* productVariant {
|
|
78
|
+
* product {
|
|
79
|
+
* featuredAsset {
|
|
80
|
+
* preview
|
|
81
|
+
* }
|
|
82
|
+
* }
|
|
83
|
+
* }
|
|
84
|
+
* }
|
|
85
|
+
* }
|
|
86
|
+
* }
|
|
87
|
+
* }
|
|
88
|
+
* ```
|
|
89
|
+
* then the `relations` array would include `'lines'`, `'lines.productVariant'`, & `'lines.productVariant.product'` - 3 levels deep - but it would
|
|
90
|
+
* _not_ include `'lines.productVariant.product.featuredAsset'` since that exceeds the default depth. To specify a custom depth, you would
|
|
91
|
+
* use the decorator like this:
|
|
92
|
+
*
|
|
93
|
+
* @example
|
|
94
|
+
* ```TypeScript
|
|
95
|
+
* \@Relations({ entity: Order, depth: 2 }) relations: RelationPaths<Order>,
|
|
96
|
+
* ```
|
|
97
|
+
*
|
|
98
|
+
* @docsCategory request
|
|
99
|
+
* @docsPage Api Decorator
|
|
100
|
+
* @since 1.6.0
|
|
101
|
+
*/
|
|
102
|
+
export declare const Relations: (...dataOrPipes: (FieldsDecoratorConfig | import("@nestjs/common").PipeTransform<any, any> | import("@nestjs/common").Type<import("@nestjs/common").PipeTransform<any, any>>)[]) => ParameterDecorator;
|
|
@@ -0,0 +1,187 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.Relations = void 0;
|
|
7
|
+
const common_1 = require("@nestjs/common");
|
|
8
|
+
const unique_1 = require("@vendure/common/lib/unique");
|
|
9
|
+
const graphql_1 = require("graphql");
|
|
10
|
+
const graphql_fields_1 = __importDefault(require("graphql-fields"));
|
|
11
|
+
const typeorm_1 = require("typeorm");
|
|
12
|
+
const calculated_decorator_1 = require("../../common/calculated-decorator");
|
|
13
|
+
const index_1 = require("../../common/index");
|
|
14
|
+
const DEFAULT_DEPTH = 3;
|
|
15
|
+
const cache = new index_1.TtlCache({ cacheSize: 500, ttl: 5 * 60 * 1000 });
|
|
16
|
+
/**
|
|
17
|
+
* @description
|
|
18
|
+
* Resolver param decorator which returns an array of relation paths which can be passed through
|
|
19
|
+
* to the TypeORM data layer in order to join only the required relations. This works by inspecting
|
|
20
|
+
* the GraphQL `info` object, examining the field selection, and then comparing this with information
|
|
21
|
+
* about the return type's relations.
|
|
22
|
+
*
|
|
23
|
+
* In addition to analyzing the field selection, this decorator also checks for any `@Calculated()`
|
|
24
|
+
* properties on the entity, and additionally includes relations from the `relations` array of the calculated
|
|
25
|
+
* metadata, if defined.
|
|
26
|
+
*
|
|
27
|
+
* So if, for example, the query only selects the `id` field of an Order, then no other relations need
|
|
28
|
+
* be joined in the resulting SQL query. This can massively speed up execution time for queries which do
|
|
29
|
+
* not include many deep nested relations.
|
|
30
|
+
*
|
|
31
|
+
* @example
|
|
32
|
+
* ```TypeScript
|
|
33
|
+
* \@Query()
|
|
34
|
+
* \@Allow(Permission.ReadOrder)
|
|
35
|
+
* orders(
|
|
36
|
+
* \@Ctx() ctx: RequestContext,
|
|
37
|
+
* \@Args() args: QueryOrdersArgs,
|
|
38
|
+
* \@Relations(Order) relations: RelationPaths<Order>,
|
|
39
|
+
* ): Promise<PaginatedList<Order>> {
|
|
40
|
+
* return this.orderService.findAll(ctx, args.options || undefined, relations);
|
|
41
|
+
* }
|
|
42
|
+
* ```
|
|
43
|
+
*
|
|
44
|
+
* In the above example, given the following query:
|
|
45
|
+
*
|
|
46
|
+
* @example
|
|
47
|
+
* ```GraphQL
|
|
48
|
+
* {
|
|
49
|
+
* orders(options: { take: 10 }) {
|
|
50
|
+
* items {
|
|
51
|
+
* id
|
|
52
|
+
* customer {
|
|
53
|
+
* id
|
|
54
|
+
* firstName
|
|
55
|
+
* lastName
|
|
56
|
+
* }
|
|
57
|
+
* totalQuantity
|
|
58
|
+
* totalWithTax
|
|
59
|
+
* }
|
|
60
|
+
* }
|
|
61
|
+
* }
|
|
62
|
+
* ```
|
|
63
|
+
* then the value of `relations` will be
|
|
64
|
+
*
|
|
65
|
+
* ```
|
|
66
|
+
* ['customer', 'lines', 'lines.items']
|
|
67
|
+
* ```
|
|
68
|
+
* The `'customer'` comes from the fact that the query is nesting the "customer" object, and the `'lines'` & `'lines.items'` are taken
|
|
69
|
+
* from the `Order` entity's `totalQuantity` property, which uses {@link Calculated} decorator and defines those relations as dependencies
|
|
70
|
+
* for deriving the calculated value.
|
|
71
|
+
*
|
|
72
|
+
* ## Depth
|
|
73
|
+
*
|
|
74
|
+
* By default, when inspecting the GraphQL query, the Relations decorator will look 3 levels deep in any nested fields. So, e.g. if
|
|
75
|
+
* the above `orders` query were changed to:
|
|
76
|
+
*
|
|
77
|
+
* @example
|
|
78
|
+
* ```GraphQL
|
|
79
|
+
* {
|
|
80
|
+
* orders(options: { take: 10 }) {
|
|
81
|
+
* items {
|
|
82
|
+
* id
|
|
83
|
+
* lines {
|
|
84
|
+
* productVariant {
|
|
85
|
+
* product {
|
|
86
|
+
* featuredAsset {
|
|
87
|
+
* preview
|
|
88
|
+
* }
|
|
89
|
+
* }
|
|
90
|
+
* }
|
|
91
|
+
* }
|
|
92
|
+
* }
|
|
93
|
+
* }
|
|
94
|
+
* }
|
|
95
|
+
* ```
|
|
96
|
+
* then the `relations` array would include `'lines'`, `'lines.productVariant'`, & `'lines.productVariant.product'` - 3 levels deep - but it would
|
|
97
|
+
* _not_ include `'lines.productVariant.product.featuredAsset'` since that exceeds the default depth. To specify a custom depth, you would
|
|
98
|
+
* use the decorator like this:
|
|
99
|
+
*
|
|
100
|
+
* @example
|
|
101
|
+
* ```TypeScript
|
|
102
|
+
* \@Relations({ entity: Order, depth: 2 }) relations: RelationPaths<Order>,
|
|
103
|
+
* ```
|
|
104
|
+
*
|
|
105
|
+
* @docsCategory request
|
|
106
|
+
* @docsPage Api Decorator
|
|
107
|
+
* @since 1.6.0
|
|
108
|
+
*/
|
|
109
|
+
exports.Relations = common_1.createParamDecorator((data, ctx) => {
|
|
110
|
+
var _a;
|
|
111
|
+
const info = ctx.getArgByIndex(3);
|
|
112
|
+
if (data == null) {
|
|
113
|
+
throw new index_1.InternalServerError(`The @Relations() decorator requires an entity type argument`);
|
|
114
|
+
}
|
|
115
|
+
if (!isGraphQLResolveInfo(info)) {
|
|
116
|
+
return [];
|
|
117
|
+
}
|
|
118
|
+
const cacheKey = info.fieldName + '__' + ctx.getArgByIndex(2).req.body.query;
|
|
119
|
+
const cachedResult = cache.get(cacheKey);
|
|
120
|
+
if (cachedResult) {
|
|
121
|
+
return cachedResult;
|
|
122
|
+
}
|
|
123
|
+
const fields = graphql_fields_1.default(info);
|
|
124
|
+
const targetFields = isPaginatedListQuery(info) ? (_a = fields.items) !== null && _a !== void 0 ? _a : {} : fields;
|
|
125
|
+
const entity = typeof data === 'function' ? data : data.entity;
|
|
126
|
+
const maxDepth = typeof data === 'function' ? DEFAULT_DEPTH : data.depth;
|
|
127
|
+
const relationFields = getRelationPaths(targetFields, entity, maxDepth);
|
|
128
|
+
const result = unique_1.unique(relationFields);
|
|
129
|
+
cache.set(cacheKey, result);
|
|
130
|
+
return result;
|
|
131
|
+
});
|
|
132
|
+
function getRelationPaths(fields, entity, maxDepth, depth = 1) {
|
|
133
|
+
var _a, _b;
|
|
134
|
+
const relations = typeorm_1.getMetadataArgsStorage().filterRelations(entity);
|
|
135
|
+
const metadata = typeorm_1.getMetadataArgsStorage();
|
|
136
|
+
const relationPaths = [];
|
|
137
|
+
for (const [property, value] of Object.entries(fields)) {
|
|
138
|
+
if (property === 'customFields') {
|
|
139
|
+
const customFieldEntity = (_a = metadata
|
|
140
|
+
.filterEmbeddeds(entity)
|
|
141
|
+
.find(e => e.propertyName === 'customFields')) === null || _a === void 0 ? void 0 : _a.type();
|
|
142
|
+
if (customFieldEntity) {
|
|
143
|
+
if (depth < maxDepth) {
|
|
144
|
+
depth++;
|
|
145
|
+
const subPaths = getRelationPaths(value, customFieldEntity, maxDepth, depth);
|
|
146
|
+
depth--;
|
|
147
|
+
for (const subPath of subPaths) {
|
|
148
|
+
relationPaths.push([property, subPath].join('.'));
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
else {
|
|
154
|
+
const relationMetadata = relations.find(r => r.propertyName === property);
|
|
155
|
+
if (relationMetadata) {
|
|
156
|
+
relationPaths.push(property);
|
|
157
|
+
const relatedEntity = typeof relationMetadata.type === 'function'
|
|
158
|
+
? relationMetadata.type()
|
|
159
|
+
: relationMetadata.type;
|
|
160
|
+
if (depth < maxDepth) {
|
|
161
|
+
depth++;
|
|
162
|
+
const subPaths = getRelationPaths(value, relatedEntity, maxDepth, depth);
|
|
163
|
+
depth--;
|
|
164
|
+
for (const subPath of subPaths) {
|
|
165
|
+
relationPaths.push([property, subPath].join('.'));
|
|
166
|
+
}
|
|
167
|
+
}
|
|
168
|
+
}
|
|
169
|
+
const calculatedProperties = (_b = Object.getPrototypeOf(new entity())[calculated_decorator_1.CALCULATED_PROPERTIES]) !== null && _b !== void 0 ? _b : [];
|
|
170
|
+
const selectedFields = new Set(Object.keys(fields));
|
|
171
|
+
const dependencyRelations = calculatedProperties
|
|
172
|
+
.filter(p => { var _a, _b; return selectedFields.has(p.name) && ((_b = (_a = p.listQuery) === null || _a === void 0 ? void 0 : _a.relations) === null || _b === void 0 ? void 0 : _b.length); })
|
|
173
|
+
.map(p => { var _a, _b; return (_b = (_a = p.listQuery) === null || _a === void 0 ? void 0 : _a.relations) !== null && _b !== void 0 ? _b : []; })
|
|
174
|
+
.flat();
|
|
175
|
+
relationPaths.push(...dependencyRelations);
|
|
176
|
+
}
|
|
177
|
+
}
|
|
178
|
+
return relationPaths;
|
|
179
|
+
}
|
|
180
|
+
function isGraphQLResolveInfo(input) {
|
|
181
|
+
return !!(input && typeof input === 'object' && input.schema instanceof graphql_1.GraphQLSchema);
|
|
182
|
+
}
|
|
183
|
+
function isPaginatedListQuery(info) {
|
|
184
|
+
const returnType = graphql_1.getNamedType(info.returnType);
|
|
185
|
+
return graphql_1.isObjectType(returnType) && !!returnType.getInterfaces().find(i => i.name === 'PaginatedList');
|
|
186
|
+
}
|
|
187
|
+
//# sourceMappingURL=relations.decorator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"relations.decorator.js","sourceRoot":"","sources":["../../../src/api/decorators/relations.decorator.ts"],"names":[],"mappings":"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"}
|
package/dist/api/index.d.ts
CHANGED
|
@@ -4,6 +4,7 @@ export * from './common/extract-session-token';
|
|
|
4
4
|
export * from './decorators/allow.decorator';
|
|
5
5
|
export * from './decorators/transaction.decorator';
|
|
6
6
|
export * from './decorators/api.decorator';
|
|
7
|
+
export * from './decorators/relations.decorator';
|
|
7
8
|
export * from './decorators/request-context.decorator';
|
|
8
9
|
export * from './resolvers/admin/search.resolver';
|
|
9
10
|
export * from './middleware/auth-guard';
|
package/dist/api/index.js
CHANGED
|
@@ -15,6 +15,7 @@ __exportStar(require("./common/extract-session-token"), exports);
|
|
|
15
15
|
__exportStar(require("./decorators/allow.decorator"), exports);
|
|
16
16
|
__exportStar(require("./decorators/transaction.decorator"), exports);
|
|
17
17
|
__exportStar(require("./decorators/api.decorator"), exports);
|
|
18
|
+
__exportStar(require("./decorators/relations.decorator"), exports);
|
|
18
19
|
__exportStar(require("./decorators/request-context.decorator"), exports);
|
|
19
20
|
__exportStar(require("./resolvers/admin/search.resolver"), exports);
|
|
20
21
|
__exportStar(require("./middleware/auth-guard"), exports);
|
package/dist/api/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/api/index.ts"],"names":[],"mappings":";;;;;;;;;;;;AACA,2DAAyC;AACzC,iEAA+C;AAC/C,+DAA6C;AAC7C,qEAAmD;AACnD,6DAA2C;AAC3C,yEAAuD;AACvD,oEAAkD;AAClD,0DAAwC;AACxC,uEAAqD;AACrD,8DAA4C"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/api/index.ts"],"names":[],"mappings":";;;;;;;;;;;;AACA,2DAAyC;AACzC,iEAA+C;AAC/C,+DAA6C;AAC7C,qEAAmD;AACnD,6DAA2C;AAC3C,mEAAiD;AACjD,yEAAuD;AACvD,oEAAkD;AAClD,0DAAwC;AACxC,uEAAqD;AACrD,8DAA4C"}
|
|
@@ -3,11 +3,12 @@ import { PaginatedList } from '@vendure/common/lib/shared-types';
|
|
|
3
3
|
import { Administrator } from '../../../entity/administrator/administrator.entity';
|
|
4
4
|
import { AdministratorService } from '../../../service/services/administrator.service';
|
|
5
5
|
import { RequestContext } from '../../common/request-context';
|
|
6
|
+
import { RelationPaths } from '../../decorators/relations.decorator';
|
|
6
7
|
export declare class AdministratorResolver {
|
|
7
8
|
private administratorService;
|
|
8
9
|
constructor(administratorService: AdministratorService);
|
|
9
|
-
administrators(ctx: RequestContext, args: QueryAdministratorsArgs): Promise<PaginatedList<Administrator>>;
|
|
10
|
-
administrator(ctx: RequestContext, args: QueryAdministratorArgs): Promise<Administrator | undefined>;
|
|
10
|
+
administrators(ctx: RequestContext, args: QueryAdministratorsArgs, relations: RelationPaths<Administrator>): Promise<PaginatedList<Administrator>>;
|
|
11
|
+
administrator(ctx: RequestContext, args: QueryAdministratorArgs, relations: RelationPaths<Administrator>): Promise<Administrator | undefined>;
|
|
11
12
|
activeAdministrator(ctx: RequestContext): Promise<Administrator | undefined>;
|
|
12
13
|
createAdministrator(ctx: RequestContext, args: MutationCreateAdministratorArgs): Promise<Administrator>;
|
|
13
14
|
updateAdministrator(ctx: RequestContext, args: MutationUpdateAdministratorArgs): Promise<Administrator>;
|
|
@@ -15,20 +15,22 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
15
15
|
exports.AdministratorResolver = void 0;
|
|
16
16
|
const graphql_1 = require("@nestjs/graphql");
|
|
17
17
|
const generated_types_1 = require("@vendure/common/lib/generated-types");
|
|
18
|
+
const administrator_entity_1 = require("../../../entity/administrator/administrator.entity");
|
|
18
19
|
const administrator_service_1 = require("../../../service/services/administrator.service");
|
|
19
20
|
const request_context_1 = require("../../common/request-context");
|
|
20
21
|
const allow_decorator_1 = require("../../decorators/allow.decorator");
|
|
22
|
+
const relations_decorator_1 = require("../../decorators/relations.decorator");
|
|
21
23
|
const request_context_decorator_1 = require("../../decorators/request-context.decorator");
|
|
22
24
|
const transaction_decorator_1 = require("../../decorators/transaction.decorator");
|
|
23
25
|
let AdministratorResolver = class AdministratorResolver {
|
|
24
26
|
constructor(administratorService) {
|
|
25
27
|
this.administratorService = administratorService;
|
|
26
28
|
}
|
|
27
|
-
administrators(ctx, args) {
|
|
28
|
-
return this.administratorService.findAll(ctx, args.options || undefined);
|
|
29
|
+
administrators(ctx, args, relations) {
|
|
30
|
+
return this.administratorService.findAll(ctx, args.options || undefined, relations);
|
|
29
31
|
}
|
|
30
|
-
administrator(ctx, args) {
|
|
31
|
-
return this.administratorService.findOne(ctx, args.id);
|
|
32
|
+
administrator(ctx, args, relations) {
|
|
33
|
+
return this.administratorService.findOne(ctx, args.id, relations);
|
|
32
34
|
}
|
|
33
35
|
async activeAdministrator(ctx) {
|
|
34
36
|
if (ctx.activeUserId) {
|
|
@@ -65,8 +67,9 @@ __decorate([
|
|
|
65
67
|
allow_decorator_1.Allow(generated_types_1.Permission.ReadAdministrator),
|
|
66
68
|
__param(0, request_context_decorator_1.Ctx()),
|
|
67
69
|
__param(1, graphql_1.Args()),
|
|
70
|
+
__param(2, relations_decorator_1.Relations(administrator_entity_1.Administrator)),
|
|
68
71
|
__metadata("design:type", Function),
|
|
69
|
-
__metadata("design:paramtypes", [request_context_1.RequestContext, Object]),
|
|
72
|
+
__metadata("design:paramtypes", [request_context_1.RequestContext, Object, Array]),
|
|
70
73
|
__metadata("design:returntype", Promise)
|
|
71
74
|
], AdministratorResolver.prototype, "administrators", null);
|
|
72
75
|
__decorate([
|
|
@@ -74,8 +77,9 @@ __decorate([
|
|
|
74
77
|
allow_decorator_1.Allow(generated_types_1.Permission.ReadAdministrator),
|
|
75
78
|
__param(0, request_context_decorator_1.Ctx()),
|
|
76
79
|
__param(1, graphql_1.Args()),
|
|
80
|
+
__param(2, relations_decorator_1.Relations(administrator_entity_1.Administrator)),
|
|
77
81
|
__metadata("design:type", Function),
|
|
78
|
-
__metadata("design:paramtypes", [request_context_1.RequestContext, Object]),
|
|
82
|
+
__metadata("design:paramtypes", [request_context_1.RequestContext, Object, Array]),
|
|
79
83
|
__metadata("design:returntype", Promise)
|
|
80
84
|
], AdministratorResolver.prototype, "administrator", null);
|
|
81
85
|
__decorate([
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"administrator.resolver.js","sourceRoot":"","sources":["../../../../src/api/resolvers/admin/administrator.resolver.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,6CAAkE;AAClE,yEAU6C;
|
|
1
|
+
{"version":3,"file":"administrator.resolver.js","sourceRoot":"","sources":["../../../../src/api/resolvers/admin/administrator.resolver.ts"],"names":[],"mappings":"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"}
|
|
@@ -3,11 +3,12 @@ import { PaginatedList } from '@vendure/common/lib/shared-types';
|
|
|
3
3
|
import { Asset } from '../../../entity/asset/asset.entity';
|
|
4
4
|
import { AssetService } from '../../../service/services/asset.service';
|
|
5
5
|
import { RequestContext } from '../../common/request-context';
|
|
6
|
+
import { RelationPaths } from '../../decorators/relations.decorator';
|
|
6
7
|
export declare class AssetResolver {
|
|
7
8
|
private assetService;
|
|
8
9
|
constructor(assetService: AssetService);
|
|
9
|
-
asset(ctx: RequestContext, args: QueryAssetArgs): Promise<Asset | undefined>;
|
|
10
|
-
assets(ctx: RequestContext, args: QueryAssetsArgs): Promise<PaginatedList<Asset>>;
|
|
10
|
+
asset(ctx: RequestContext, args: QueryAssetArgs, relations: RelationPaths<Asset>): Promise<Asset | undefined>;
|
|
11
|
+
assets(ctx: RequestContext, args: QueryAssetsArgs, relations: RelationPaths<Asset>): Promise<PaginatedList<Asset>>;
|
|
11
12
|
createAssets(ctx: RequestContext, args: MutationCreateAssetsArgs): Promise<CreateAssetResult[]>;
|
|
12
13
|
updateAsset(ctx: RequestContext, { input }: MutationUpdateAssetArgs): Promise<Asset>;
|
|
13
14
|
deleteAsset(ctx: RequestContext, { input: { assetId, force, deleteFromAllChannels } }: MutationDeleteAssetArgs): Promise<import("@vendure/common/lib/generated-types").DeletionResponse>;
|
|
@@ -15,20 +15,22 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
15
15
|
exports.AssetResolver = void 0;
|
|
16
16
|
const graphql_1 = require("@nestjs/graphql");
|
|
17
17
|
const generated_types_1 = require("@vendure/common/lib/generated-types");
|
|
18
|
+
const asset_entity_1 = require("../../../entity/asset/asset.entity");
|
|
18
19
|
const asset_service_1 = require("../../../service/services/asset.service");
|
|
19
20
|
const request_context_1 = require("../../common/request-context");
|
|
20
21
|
const allow_decorator_1 = require("../../decorators/allow.decorator");
|
|
22
|
+
const relations_decorator_1 = require("../../decorators/relations.decorator");
|
|
21
23
|
const request_context_decorator_1 = require("../../decorators/request-context.decorator");
|
|
22
24
|
const transaction_decorator_1 = require("../../decorators/transaction.decorator");
|
|
23
25
|
let AssetResolver = class AssetResolver {
|
|
24
26
|
constructor(assetService) {
|
|
25
27
|
this.assetService = assetService;
|
|
26
28
|
}
|
|
27
|
-
async asset(ctx, args) {
|
|
28
|
-
return this.assetService.findOne(ctx, args.id);
|
|
29
|
+
async asset(ctx, args, relations) {
|
|
30
|
+
return this.assetService.findOne(ctx, args.id, relations);
|
|
29
31
|
}
|
|
30
|
-
async assets(ctx, args) {
|
|
31
|
-
return this.assetService.findAll(ctx, args.options || undefined);
|
|
32
|
+
async assets(ctx, args, relations) {
|
|
33
|
+
return this.assetService.findAll(ctx, args.options || undefined, relations);
|
|
32
34
|
}
|
|
33
35
|
async createAssets(ctx, args) {
|
|
34
36
|
// TODO: Is there some way to parellelize this while still preserving
|
|
@@ -58,8 +60,9 @@ __decorate([
|
|
|
58
60
|
allow_decorator_1.Allow(generated_types_1.Permission.ReadCatalog, generated_types_1.Permission.ReadAsset),
|
|
59
61
|
__param(0, request_context_decorator_1.Ctx()),
|
|
60
62
|
__param(1, graphql_1.Args()),
|
|
63
|
+
__param(2, relations_decorator_1.Relations(asset_entity_1.Asset)),
|
|
61
64
|
__metadata("design:type", Function),
|
|
62
|
-
__metadata("design:paramtypes", [request_context_1.RequestContext, Object]),
|
|
65
|
+
__metadata("design:paramtypes", [request_context_1.RequestContext, Object, Array]),
|
|
63
66
|
__metadata("design:returntype", Promise)
|
|
64
67
|
], AssetResolver.prototype, "asset", null);
|
|
65
68
|
__decorate([
|
|
@@ -67,8 +70,9 @@ __decorate([
|
|
|
67
70
|
allow_decorator_1.Allow(generated_types_1.Permission.ReadCatalog, generated_types_1.Permission.ReadAsset),
|
|
68
71
|
__param(0, request_context_decorator_1.Ctx()),
|
|
69
72
|
__param(1, graphql_1.Args()),
|
|
73
|
+
__param(2, relations_decorator_1.Relations(asset_entity_1.Asset)),
|
|
70
74
|
__metadata("design:type", Function),
|
|
71
|
-
__metadata("design:paramtypes", [request_context_1.RequestContext, Object]),
|
|
75
|
+
__metadata("design:paramtypes", [request_context_1.RequestContext, Object, Array]),
|
|
72
76
|
__metadata("design:returntype", Promise)
|
|
73
77
|
], AssetResolver.prototype, "assets", null);
|
|
74
78
|
__decorate([
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"asset.resolver.js","sourceRoot":"","sources":["../../../../src/api/resolvers/admin/asset.resolver.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,6CAAkE;AAClE,yEAU6C;
|
|
1
|
+
{"version":3,"file":"asset.resolver.js","sourceRoot":"","sources":["../../../../src/api/resolvers/admin/asset.resolver.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { ConfigurableOperationDefinition, DeletionResponse, MutationCreateCollectionArgs, MutationDeleteCollectionArgs, MutationMoveCollectionArgs, MutationUpdateCollectionArgs, QueryCollectionArgs, QueryCollectionsArgs } from '@vendure/common/lib/generated-types';
|
|
1
|
+
import { ConfigurableOperationDefinition, DeletionResponse, MutationCreateCollectionArgs, MutationDeleteCollectionArgs, MutationMoveCollectionArgs, MutationUpdateCollectionArgs, QueryCollectionArgs, QueryCollectionsArgs, QueryPreviewCollectionVariantsArgs } from '@vendure/common/lib/generated-types';
|
|
2
2
|
import { PaginatedList } from '@vendure/common/lib/shared-types';
|
|
3
3
|
import { Translated } from '../../../common/types/locale-types';
|
|
4
4
|
import { Collection } from '../../../entity/collection/collection.entity';
|
|
@@ -6,14 +6,16 @@ import { CollectionService } from '../../../service/services/collection.service'
|
|
|
6
6
|
import { FacetValueService } from '../../../service/services/facet-value.service';
|
|
7
7
|
import { ConfigurableOperationCodec } from '../../common/configurable-operation-codec';
|
|
8
8
|
import { RequestContext } from '../../common/request-context';
|
|
9
|
+
import { RelationPaths } from '../../decorators/relations.decorator';
|
|
9
10
|
export declare class CollectionResolver {
|
|
10
11
|
private collectionService;
|
|
11
12
|
private facetValueService;
|
|
12
13
|
private configurableOperationCodec;
|
|
13
14
|
constructor(collectionService: CollectionService, facetValueService: FacetValueService, configurableOperationCodec: ConfigurableOperationCodec);
|
|
14
15
|
collectionFilters(ctx: RequestContext, args: QueryCollectionsArgs): Promise<ConfigurableOperationDefinition[]>;
|
|
15
|
-
collections(ctx: RequestContext, args: QueryCollectionsArgs): Promise<PaginatedList<Translated<Collection>>>;
|
|
16
|
-
collection(ctx: RequestContext, args: QueryCollectionArgs): Promise<Translated<Collection> | undefined>;
|
|
16
|
+
collections(ctx: RequestContext, args: QueryCollectionsArgs, relations: RelationPaths<Collection>): Promise<PaginatedList<Translated<Collection>>>;
|
|
17
|
+
collection(ctx: RequestContext, args: QueryCollectionArgs, relations: RelationPaths<Collection>): Promise<Translated<Collection> | undefined>;
|
|
18
|
+
previewCollectionVariants(ctx: RequestContext, args: QueryPreviewCollectionVariantsArgs, relations: RelationPaths<Collection>): Promise<PaginatedList<import("../../..").ProductVariant>>;
|
|
17
19
|
createCollection(ctx: RequestContext, args: MutationCreateCollectionArgs): Promise<Translated<Collection>>;
|
|
18
20
|
updateCollection(ctx: RequestContext, args: MutationUpdateCollectionArgs): Promise<Translated<Collection>>;
|
|
19
21
|
moveCollection(ctx: RequestContext, args: MutationMoveCollectionArgs): Promise<Translated<Collection>>;
|
|
@@ -17,11 +17,13 @@ const graphql_1 = require("@nestjs/graphql");
|
|
|
17
17
|
const generated_types_1 = require("@vendure/common/lib/generated-types");
|
|
18
18
|
const errors_1 = require("../../../common/error/errors");
|
|
19
19
|
const collection_filter_1 = require("../../../config/catalog/collection-filter");
|
|
20
|
+
const collection_entity_1 = require("../../../entity/collection/collection.entity");
|
|
20
21
|
const collection_service_1 = require("../../../service/services/collection.service");
|
|
21
22
|
const facet_value_service_1 = require("../../../service/services/facet-value.service");
|
|
22
23
|
const configurable_operation_codec_1 = require("../../common/configurable-operation-codec");
|
|
23
24
|
const request_context_1 = require("../../common/request-context");
|
|
24
25
|
const allow_decorator_1 = require("../../decorators/allow.decorator");
|
|
26
|
+
const relations_decorator_1 = require("../../decorators/relations.decorator");
|
|
25
27
|
const request_context_decorator_1 = require("../../decorators/request-context.decorator");
|
|
26
28
|
const transaction_decorator_1 = require("../../decorators/transaction.decorator");
|
|
27
29
|
let CollectionResolver = class CollectionResolver {
|
|
@@ -42,28 +44,32 @@ let CollectionResolver = class CollectionResolver {
|
|
|
42
44
|
async collectionFilters(ctx, args) {
|
|
43
45
|
return this.collectionService.getAvailableFilters(ctx);
|
|
44
46
|
}
|
|
45
|
-
async collections(ctx, args) {
|
|
46
|
-
return this.collectionService.findAll(ctx, args.options || undefined).then(res => {
|
|
47
|
+
async collections(ctx, args, relations) {
|
|
48
|
+
return this.collectionService.findAll(ctx, args.options || undefined, relations).then(res => {
|
|
47
49
|
res.items.forEach(this.encodeFilters);
|
|
48
50
|
return res;
|
|
49
51
|
});
|
|
50
52
|
}
|
|
51
|
-
async collection(ctx, args) {
|
|
53
|
+
async collection(ctx, args, relations) {
|
|
52
54
|
let collection;
|
|
53
55
|
if (args.id) {
|
|
54
|
-
collection = await this.collectionService.findOne(ctx, args.id);
|
|
56
|
+
collection = await this.collectionService.findOne(ctx, args.id, relations);
|
|
55
57
|
if (args.slug && collection && collection.slug !== args.slug) {
|
|
56
58
|
throw new errors_1.UserInputError(`error.collection-id-slug-mismatch`);
|
|
57
59
|
}
|
|
58
60
|
}
|
|
59
61
|
else if (args.slug) {
|
|
60
|
-
collection = await this.collectionService.findOneBySlug(ctx, args.slug);
|
|
62
|
+
collection = await this.collectionService.findOneBySlug(ctx, args.slug, relations);
|
|
61
63
|
}
|
|
62
64
|
else {
|
|
63
65
|
throw new errors_1.UserInputError(`error.collection-id-or-slug-must-be-provided`);
|
|
64
66
|
}
|
|
65
67
|
return this.encodeFilters(collection);
|
|
66
68
|
}
|
|
69
|
+
previewCollectionVariants(ctx, args, relations) {
|
|
70
|
+
this.configurableOperationCodec.decodeConfigurableOperationIds(collection_filter_1.CollectionFilter, args.input.filters);
|
|
71
|
+
return this.collectionService.previewCollectionVariants(ctx, args.input, args.options || undefined);
|
|
72
|
+
}
|
|
67
73
|
async createCollection(ctx, args) {
|
|
68
74
|
const { input } = args;
|
|
69
75
|
this.configurableOperationCodec.decodeConfigurableOperationIds(collection_filter_1.CollectionFilter, input.filters);
|
|
@@ -96,8 +102,9 @@ __decorate([
|
|
|
96
102
|
allow_decorator_1.Allow(generated_types_1.Permission.ReadCatalog, generated_types_1.Permission.ReadCollection),
|
|
97
103
|
__param(0, request_context_decorator_1.Ctx()),
|
|
98
104
|
__param(1, graphql_1.Args()),
|
|
105
|
+
__param(2, relations_decorator_1.Relations(collection_entity_1.Collection)),
|
|
99
106
|
__metadata("design:type", Function),
|
|
100
|
-
__metadata("design:paramtypes", [request_context_1.RequestContext, Object]),
|
|
107
|
+
__metadata("design:paramtypes", [request_context_1.RequestContext, Object, Array]),
|
|
101
108
|
__metadata("design:returntype", Promise)
|
|
102
109
|
], CollectionResolver.prototype, "collections", null);
|
|
103
110
|
__decorate([
|
|
@@ -105,10 +112,21 @@ __decorate([
|
|
|
105
112
|
allow_decorator_1.Allow(generated_types_1.Permission.ReadCatalog, generated_types_1.Permission.ReadCollection),
|
|
106
113
|
__param(0, request_context_decorator_1.Ctx()),
|
|
107
114
|
__param(1, graphql_1.Args()),
|
|
115
|
+
__param(2, relations_decorator_1.Relations(collection_entity_1.Collection)),
|
|
108
116
|
__metadata("design:type", Function),
|
|
109
|
-
__metadata("design:paramtypes", [request_context_1.RequestContext, Object]),
|
|
117
|
+
__metadata("design:paramtypes", [request_context_1.RequestContext, Object, Array]),
|
|
110
118
|
__metadata("design:returntype", Promise)
|
|
111
119
|
], CollectionResolver.prototype, "collection", null);
|
|
120
|
+
__decorate([
|
|
121
|
+
graphql_1.Query(),
|
|
122
|
+
allow_decorator_1.Allow(generated_types_1.Permission.ReadCatalog, generated_types_1.Permission.ReadCollection),
|
|
123
|
+
__param(0, request_context_decorator_1.Ctx()),
|
|
124
|
+
__param(1, graphql_1.Args()),
|
|
125
|
+
__param(2, relations_decorator_1.Relations(collection_entity_1.Collection)),
|
|
126
|
+
__metadata("design:type", Function),
|
|
127
|
+
__metadata("design:paramtypes", [request_context_1.RequestContext, Object, Array]),
|
|
128
|
+
__metadata("design:returntype", void 0)
|
|
129
|
+
], CollectionResolver.prototype, "previewCollectionVariants", null);
|
|
112
130
|
__decorate([
|
|
113
131
|
transaction_decorator_1.Transaction(),
|
|
114
132
|
graphql_1.Mutation(),
|