Skip to main content
Skip to main content

ProductVariantService

Properties

__configModule__Record<string, unknown>
__container__anyRequired
__moduleDeclaration__Record<string, unknown>
cartRepository_Repository<Cart> & { findOneWithRelations: Method findOneWithRelations ; findWithRelations: Method findWithRelations }Required
eventBus_EventBusServiceRequired
manager_EntityManagerRequired
moneyAmountRepository_Repository<MoneyAmount> & { addPriceListPrices: Method addPriceListPrices ; createProductVariantMoneyAmounts: Method createProductVariantMoneyAmounts ; deletePriceListPrices: Method deletePriceListPrices ; deleteVariantPricesNotIn: Method deleteVariantPricesNotIn ; findCurrencyMoneyAmounts: Method findCurrencyMoneyAmounts ; findManyForVariantInPriceList: Method findManyForVariantInPriceList ; findManyForVariantInRegion: Method findManyForVariantInRegion ; findManyForVariantsInRegion: Method findManyForVariantsInRegion ; findRegionMoneyAmounts: Method findRegionMoneyAmounts ; findVariantPricesNotIn: Method findVariantPricesNotIn ; getPricesForVariantInRegion: Method getPricesForVariantInRegion ; insertBulk: Method insertBulk ; updatePriceListPrices: Method updatePriceListPrices ; upsertVariantCurrencyPrice: Method upsertVariantCurrencyPrice }Required
priceSelectionStrategy_IPriceSelectionStrategyRequired
productOptionValueRepository_Repository<ProductOptionValue>Required
productRepository_Repository<Product> & { _applyCategoriesQuery: Method _applyCategoriesQuery ; _findWithRelations: Method _findWithRelations ; bulkAddToCollection: Method bulkAddToCollection ; bulkRemoveFromCollection: Method bulkRemoveFromCollection ; findOneWithRelations: Method findOneWithRelations ; findWithRelations: Method findWithRelations ; findWithRelationsAndCount: Method findWithRelationsAndCount ; getCategoryIdsFromInput: Method getCategoryIdsFromInput ; getCategoryIdsRecursively: Method getCategoryIdsRecursively ; getFreeTextSearchResultsAndCount: Method getFreeTextSearchResultsAndCount ; isProductInSalesChannels: Method isProductInSalesChannels ; queryProducts: Method queryProducts ; queryProductsWithIds: Method queryProductsWithIds }Required
productVariantRepository_Repository<ProductVariant>Required
regionService_RegionServiceRequired
transactionManager_undefined | EntityManagerRequired
EventsobjectRequired
Events.CREATEDstringRequired
Events.DELETEDstringRequired
Events.UPDATEDstringRequired

Accessors

activeManager_

Returns

EntityManagerEntityManagerRequired

Methods

addOptionValue

Adds option value to a variant. Fails when product with variant does not exist or if that product does not have an option with the given option id. Fails if given variant is not found. Option value must be of type string or number.

Parameters

variantIdstringRequired
the variant to decorate.
optionIdstringRequired
the option from product.
optionValuestringRequired
option value to add.

Returns

PromisePromise<ProductOptionValue>Required
the result of the update operation.

atomicPhase_

Wraps some work within a transactional block. If the service already has a transaction manager attached this will be reused, otherwise a new transaction manager is created.

Parameters

work(transactionManager: EntityManager) => Promise<TResult>Required
the transactional work to be done
isolationOrErrorHandlerIsolationLevel | (error: TError) => Promise<void | TResult>
the isolation level to be used for the work.
maybeErrorHandlerOrDontFail(error: TError) => Promise<void | TResult>
Potential error handler

Returns

PromisePromise<TResult>Required
the result of the transactional work

create

Creates an unpublished product variant. Will validate against parent product to ensure that the variant can in fact be created.

Parameters

productOrProductIdstring | ProductRequired
the product the variant will be added to

Returns

PromisePromise<TOutput>Required
resolves to the creation result.

delete

Deletes variant or variants. Will never fail due to delete being idempotent.

Parameters

variantIdsstring | string[]Required
the id of the variant to delete. Must be castable as an ObjectId

Returns

PromisePromise<void>Required
empty promise

deleteOptionValue

Deletes option value from given variant. Will never fail due to delete being idempotent.

Parameters

variantIdstringRequired
the variant to decorate.
optionIdstringRequired
the option from product.

Returns

PromisePromise<void>Required
empty promise

getFreeTextQueryBuilder_

Lists variants based on the provided parameters and includes the count of variants that match the query.

Parameters

variantRepoRepository<ProductVariant>Required
the variant repository
object that defines the scope for what should be returned
qstring
free text query

Returns

SelectQueryBuilderSelectQueryBuilder<ProductVariant>Required
an array containing the products as the first element and the total count of products that matches the query as the second element.

getRegionPrice

Gets the price specific to a region. If no region specific money amount exists the function will try to use a currency price. If no default currency price exists the function will throw an error.

Parameters

variantIdstringRequired
the id of the variant to get price from
contextGetRegionPriceContextRequired
context for getting region price

Returns

PromisePromise<null | number>Required
the price specific to the region

isVariantInSalesChannels

Check if the variant is assigned to at least one of the provided sales channels.

Parameters

idstringRequired
product variant id
salesChannelIdsstring[]Required
an array of sales channel ids

Returns

PromisePromise<boolean>Required

list

Parameters

the query object for find
query config object for variant retrieval

Returns

PromisePromise<ProductVariant[]>Required
the result of the find operation

listAndCount

Parameters

the query object for find
query config object for variant retrieval

Returns

PromisePromise<[ProductVariant[], number]>Required
the result of the find operation

retrieve

Gets a product variant by id.

Parameters

variantIdstringRequired
the id of the product to get.
query config object for variant retrieval.

Returns

PromisePromise<ProductVariant>Required
the product document.

retrieveBySKU

Gets a product variant by id.

Parameters

skustringRequired
The unique stock keeping unit used to identify the product variant.
query config object for variant retrieval.

Returns

PromisePromise<ProductVariant>Required
the product document.

setCurrencyPrice

Parameters

variantIdstringRequired
the id of the variant to set prices for
priceProductVariantPriceRequired
the price for the variant

Returns

PromisePromise<MoneyAmount>Required
the result of the update operation

Deprecated

use addOrUpdateCurrencyPrices instead Sets the default price for the given currency.


setRegionPrice

Parameters

variantIdstringRequired
the id of the variant to update
priceProductVariantPriceRequired
the price for the variant.

Returns

PromisePromise<MoneyAmount>Required
the result of the update operation

Deprecated

use addOrUpdateRegionPrices instead Sets the default price of a specific region


shouldRetryTransaction_

Parameters

errRecord<string, unknown> | { code: string }Required

Returns

booleanboolean

update

**update**(variantData): Promise&#60;[ProductVariant](/references/js-client/internal/classes/internal.internal.ProductVariant)[]&#62;

Updates a collection of variant.

Parameters

variantData{ updateData: [UpdateProductVariantInput](/references/js-client/internal/types/internal.UpdateProductVariantInput) ; variant: [ProductVariant](/references/js-client/internal/classes/internal.internal.ProductVariant) }[]Required
a collection of variant and the data to update.

Returns

PromisePromise<ProductVariant[]>Required
resolves to the update result.

**update**(variantOrVariantId, update): Promise&#60;[ProductVariant](/references/js-client/internal/classes/internal.internal.ProductVariant)&#62;

Updates a variant. Price updates should use dedicated methods. The function will throw, if price updates are attempted.

Parameters

variantOrVariantIdstring | Partial<ProductVariant>Required
variant or id of a variant.
an object with the update values.

Returns

PromisePromise<ProductVariant>Required
resolves to the update result.

**update**(variantOrVariantId, update): Promise&#60;[ProductVariant](/references/js-client/internal/classes/internal.internal.ProductVariant)&#62;

Parameters

variantOrVariantIdstring | Partial<ProductVariant>Required

Returns

PromisePromise<ProductVariant>Required

updateBatch

Parameters

variantDataUpdateProductVariantData[]Required

Returns

PromisePromise<ProductVariant[]>Required

updateOptionValue

Updates variant's option value. Option value must be of type string or number.

Parameters

variantIdstringRequired
the variant to decorate.
optionIdstringRequired
the option from product.
optionValuestringRequired
option value to add.

Returns

PromisePromise<ProductOptionValue>Required
the result of the update operation.

updateVariantPrices

**updateVariantPrices**(data): Promise&#60;void&#62;

Updates variant/prices collection. Deletes any prices that are not in the update object, and is not associated with a price list.

Parameters

Returns

PromisePromise<void>Required
empty promise

**updateVariantPrices**(variantId, prices): Promise&#60;void&#62;

Updates a variant's prices. Deletes any prices that are not in the update object, and is not associated with a price list.

Parameters

variantIdstringRequired
the id of variant
pricesProductVariantPrice[]Required
the update prices

Returns

PromisePromise<void>Required
empty promise

updateVariantPricesBatch

Parameters

Returns

PromisePromise<void>Required

upsertCurrencyPrices

Parameters

data{ price: [WithRequiredProperty](/references/js-client/internal/types/internal.internal.WithRequiredProperty)&#60;[ProductVariantPrice](/references/js-client/internal/types/internal.ProductVariantPrice), "currency_code"&#62; ; variantId: string }[]Required

Returns

PromisePromise<void>Required

upsertRegionPrices

Parameters

Returns

PromisePromise<void>Required

validateVariantsToCreate_

Parameters

productProductRequired
A product is a saleable item that holds general information such as name or description. It must include at least one Product Variant, where each product variant defines different options to purchase the product with (for example, different sizes or colors). The prices and inventory of the product are defined on the variant level.
variantsCreateProductVariantInput[]Required

Returns

voidvoid

withTransaction

Parameters

transactionManagerEntityManager

Returns

ProductVariantServiceProductVariantServiceRequired
Was this section helpful?