From 3211d75ba578d83cfc2e038dd902090b3848dae8 Mon Sep 17 00:00:00 2001 From: armitjs Date: Tue, 17 Oct 2023 07:58:09 +0800 Subject: [PATCH 1/2] fix(core): Fix Missed Translation For CustomFields With If Early Eager (#2453) --- .../api/common/custom-field-relation-resolver.service.ts | 8 ++++++++ packages/core/src/api/config/generate-resolvers.ts | 8 +++++--- 2 files changed, 13 insertions(+), 3 deletions(-) diff --git a/packages/core/src/api/common/custom-field-relation-resolver.service.ts b/packages/core/src/api/common/custom-field-relation-resolver.service.ts index 27ebba13ec..c008731fb6 100644 --- a/packages/core/src/api/common/custom-field-relation-resolver.service.ts +++ b/packages/core/src/api/common/custom-field-relation-resolver.service.ts @@ -55,6 +55,14 @@ export class CustomFieldRelationResolverService { const result = fieldDef.list ? await qb.getMany() : await qb.getOne(); + return await this.translateEntity(ctx, result, fieldDef); + } + + async translateEntity( + ctx: RequestContext, + result: VendureEntity | VendureEntity[] | null, + fieldDef: RelationCustomFieldConfig, + ) { if (fieldDef.entity === ProductVariant) { if (Array.isArray(result)) { await Promise.all(result.map(r => this.applyVariantPrices(ctx, r as any))); diff --git a/packages/core/src/api/config/generate-resolvers.ts b/packages/core/src/api/config/generate-resolvers.ts index 065c747294..e54d58026a 100644 --- a/packages/core/src/api/config/generate-resolvers.ts +++ b/packages/core/src/api/config/generate-resolvers.ts @@ -207,10 +207,12 @@ function generateCustomFieldRelationResolvers( args: any, context: any, ) => { - if (source[fieldDef.name] != null) { - return source[fieldDef.name]; - } const ctx: RequestContext = context.req[REQUEST_CONTEXT_KEY]; + const eagerntity = source[fieldDef.name]; + // If the relation is eager-loaded, we can simply try to translate this relation entity if they have translations + if (eagerntity != null) { + return customFieldRelationResolverService.translateEntity(ctx, eagerntity, fieldDef); + } const entityId = source[ENTITY_ID_KEY]; return customFieldRelationResolverService.resolveRelation({ ctx, From 30c8e56901f4c55e52ca5819a6ab150b8c982103 Mon Sep 17 00:00:00 2001 From: armitjs Date: Tue, 17 Oct 2023 08:04:36 +0800 Subject: [PATCH 2/2] fix(core): Fix Typo --- packages/core/src/api/config/generate-resolvers.ts | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/packages/core/src/api/config/generate-resolvers.ts b/packages/core/src/api/config/generate-resolvers.ts index e54d58026a..bfde3f677c 100644 --- a/packages/core/src/api/config/generate-resolvers.ts +++ b/packages/core/src/api/config/generate-resolvers.ts @@ -208,10 +208,10 @@ function generateCustomFieldRelationResolvers( context: any, ) => { const ctx: RequestContext = context.req[REQUEST_CONTEXT_KEY]; - const eagerntity = source[fieldDef.name]; + const eagerEntity = source[fieldDef.name]; // If the relation is eager-loaded, we can simply try to translate this relation entity if they have translations - if (eagerntity != null) { - return customFieldRelationResolverService.translateEntity(ctx, eagerntity, fieldDef); + if (eagerEntity != null) { + return customFieldRelationResolverService.translateEntity(ctx, eagerEntity, fieldDef); } const entityId = source[ENTITY_ID_KEY]; return customFieldRelationResolverService.resolveRelation({