From 98e6481c0683c812e0fc4b3c14a5aab4c9a320b5 Mon Sep 17 00:00:00 2001 From: dylan Date: Mon, 22 Apr 2024 13:07:21 -0700 Subject: [PATCH] fix: Update Relations on Stock Location update The Stock Location update method was not updating relation customFields Refs: #2804 --- .../services/stock-location.service.ts | 19 ++++++++++++------- 1 file changed, 12 insertions(+), 7 deletions(-) diff --git a/packages/core/src/service/services/stock-location.service.ts b/packages/core/src/service/services/stock-location.service.ts index c5aee8f299..b4368e7f82 100644 --- a/packages/core/src/service/services/stock-location.service.ts +++ b/packages/core/src/service/services/stock-location.service.ts @@ -14,18 +14,15 @@ import { ID, PaginatedList } from '@vendure/common/lib/shared-types'; import { RequestContext } from '../../api/common/request-context'; import { RelationPaths } from '../../api/decorators/relations.decorator'; import { RequestContextCacheService } from '../../cache/request-context-cache.service'; -import { - EntityNotFoundError, - ForbiddenError, - UserInputError, -} from '../../common/error/errors'; +import { EntityNotFoundError, ForbiddenError, UserInputError } from '../../common/error/errors'; import { ListQueryOptions } from '../../common/types/common-types'; -import { idsAreEqual } from '../../common/utils'; +import { assertFound, idsAreEqual } from '../../common/utils'; import { ConfigService } from '../../config/config.service'; import { TransactionalConnection } from '../../connection/transactional-connection'; import { OrderLine } from '../../entity/order-line/order-line.entity'; import { StockLevel } from '../../entity/stock-level/stock-level.entity'; import { StockLocation } from '../../entity/stock-location/stock-location.entity'; +import { CustomFieldRelationService } from '../helpers/custom-field-relation/custom-field-relation.service'; import { ListQueryBuilder } from '../helpers/list-query-builder/list-query-builder'; import { RequestContextService } from '../helpers/request-context/request-context.service'; import { patchEntity } from '../helpers/utils/patch-entity'; @@ -43,6 +40,7 @@ export class StockLocationService { private listQueryBuilder: ListQueryBuilder, private configService: ConfigService, private requestContextCache: RequestContextCacheService, + private customFieldRelationService: CustomFieldRelationService, ) {} async initStockLocations() { @@ -89,7 +87,14 @@ export class StockLocationService { async update(ctx: RequestContext, input: UpdateStockLocationInput): Promise { const stockLocation = await this.connection.getEntityOrThrow(ctx, StockLocation, input.id); const updatedStockLocation = patchEntity(stockLocation, input); - return this.connection.getRepository(ctx, StockLocation).save(updatedStockLocation); + await this.connection.getRepository(ctx, StockLocation).save(updatedStockLocation); + await this.customFieldRelationService.updateRelations( + ctx, + StockLocation, + input, + updatedStockLocation, + ); + return assertFound(this.findOne(ctx, updatedStockLocation.id)); } async delete(ctx: RequestContext, input: DeleteStockLocationInput): Promise {