{"version":3,"file":"static/js/2b2af1be5cdffb76826c.bundle.js","mappings":"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","sources":["webpack://Msdyn365.Commerce.Online/./src/themes/dlvry-adventureworks/views/components/product.component.tsx?81ba"],"sourcesContent":["/*!\r\n * Copyright (c) Microsoft Corporation.\r\n * All rights reserved. See LICENSE in the project root for license information.\r\n */\r\n\r\nimport React, { useState } from 'react';\r\nimport classnames from 'classnames';\r\nimport { reaction } from 'mobx';\r\nimport { IProductsDimensionsAvailabilities } from '@msdyn365-commerce/commerce-entities';\r\nimport {\r\n //AddToCartComponent,\r\n //AddToOrderTemplateComponent,\r\n IPriceComponentResources,\r\n ISwatchItem,\r\n //PriceComponent,\r\n ProductComponentSwatchComponent,\r\n RatingComponent,\r\n IOrderTemplateNameDialogResources,\r\n IAddToOrderTemplateDialogResources,\r\n IItemAddedToOrderTemplateDialogResources,\r\n IDuplicateItemsWhenAddingToOrderTemplateDialogResources\r\n} from '@msdyn365-commerce/components';\r\nimport { PriceComponent } from './price.component';\r\nimport {\r\n getCatalogId,\r\n IAny,\r\n IComponent,\r\n IComponentProps,\r\n ICoreContext,\r\n IGeneric,\r\n IGridSettings,\r\n IImageData,\r\n IImageSettings,\r\n Image,\r\n msdyn365Commerce\r\n} from '@msdyn365-commerce/core';\r\nimport {\r\n AttributeSwatch,\r\n AttributeValue,\r\n Customer,\r\n ProductDimension,\r\n ProductList,\r\n ProductPrice,\r\n ProductSearchResult,\r\n SimpleProduct,\r\n UnitOfMeasureConversion\r\n} from '@msdyn365-commerce/retail-proxy';\r\nimport {\r\n ArrayExtensions,\r\n convertDimensionTypeToProductDimensionType,\r\n Dictionary,\r\n DimensionTypes,\r\n generateImageUrl,\r\n getProductPageUrlSync,\r\n IDimensionsApp,\r\n StringExtensions,\r\n OrderTemplate\r\n} from '@msdyn365-commerce-modules/retail-actions';\r\nimport {\r\n format,\r\n Tooltip,\r\n getPayloadObject,\r\n getTelemetryAttributes,\r\n ITelemetryContent, Node,\r\n onTelemetryClick\r\n} from '@msdyn365-commerce-modules/utilities';\r\nimport { ICartState } from '@msdyn365-commerce/global-state';\r\nimport { AllergensModal } from '../../../../components/product-list-component/components/allergens-modal';\r\nimport { ProductInformationModal } from '../../../../components/product-list-component/components/product-information-modal';\r\nimport ProductListOrderQuantity from '../../../../components/common/product-list-order-quantity';\r\nimport { getLocale } from '../../../../components/product-list-component/locale';\r\nimport { AddToCartComponent, IAddToCartToastResources } from '../../../../modules/dlvry-buybox/common/add-to-cart.component';\r\nimport { toast } from '../../../../components/toast/toast';\r\nimport AddToOrderTemplateComponent from './addtoordertemplate.component';\r\nimport PQueue from 'p-queue';\r\nimport { IProductInventoryInformation } from '../../../../components/common/product-inventory-utils';\r\nimport { ProductSearchResultExt } from '../../../../modules/dlvry-search-result-container/components';\r\nimport { UnitOfMeasure } from '../../../../components/unit-of-measure';\r\nimport DiscountBadge from '../../../../components/discount-badge/discount-badge';\r\nimport { getTemperatureZoneIcon } from '../../../../shared-utils/attributes/get-temperature-zone';\r\n\r\nexport interface IProductComponentProps extends IComponentProps<{\r\n cart?: ICartState,\r\n product?: ProductSearchResultExt,\r\n simpleProduct?: SimpleProduct,\r\n orderTemplates?: OrderTemplate[],\r\n customerInformation?: Customer,\r\n unitConversions?: UnitOfMeasureConversion[]\r\n}> {\r\n className?: string;\r\n imageSettings?: IImageSettings;\r\n savingsText?: string;\r\n freePriceText?: string;\r\n originalPriceText?: string;\r\n currentPriceText?: string;\r\n ratingAriaLabel?: string;\r\n ratingCountAriaLabel?: string;\r\n cartQueue?: PQueue;\r\n allowBack?: boolean;\r\n telemetryContent?: ITelemetryContent;\r\n quickViewButton?: React.ReactNode;\r\n productComparisonButton?: React.ReactNode;\r\n wishlistButton?: React.ReactNode;\r\n isEnabledProductDescription?: boolean;\r\n isPriceMinMaxEnabled?: boolean;\r\n disableBuyButton?: boolean;\r\n showPrice?: boolean;\r\n showAgreementProduct?: boolean;\r\n userHasAccess?: boolean;\r\n buyAlwaysAdd?: boolean;\r\n priceResources?: IPriceComponentResources;\r\n inventoryLabel?: string;\r\n inventoryStatus?: IProductInventoryInformation;\r\n dimensionAvailabilities?: IProductsDimensionsAvailabilities[];\r\n swatchItemAriaLabel?: string;\r\n addToCartText?: string;\r\n updateCartText?: string,\r\n removeFromCartText?: string;\r\n outOfStockText?: string;\r\n priceErrorText?: string;\r\n toastStrings?: IAddToCartToastResources;\r\n inCartTooltipText?: string;\r\n transitTooltip?: string;\r\n agreementProductTooltip?: string\r\n addToOrderTemplateResources?: IAddToOrderTemplateResources;\r\n onUpdateOrderTemplates?: (orderTemplate?: ProductList) => Promise;\r\n retrieveOrderTemplates?(): Promise;\r\n onBuyValidate?: (product: ProductSearchResultExt, quantity: number) => Promise;\r\n}\r\n\r\nexport interface IProductComponent extends IComponent {\r\n}\r\n\r\nexport interface IAddToOrderTemplateResources {\r\n addToOrderTemplateHeader: string;\r\n noOrderTemplatesMessage: string;\r\n noOrderTemplatesDescription: string;\r\n createAnOrderTemplateButtonText: string;\r\n createNewOrderTemplateButtonText: string;\r\n cancelOrderTemplateCreationButtonText: string;\r\n selectTemplatesText: string;\r\n addToTemplateButtonText: string;\r\n lineItemsText: string;\r\n createOrderTemplateHeader: string;\r\n orderTemplateTitle: string;\r\n orderTemplateNameAriaLabel: string;\r\n createOrderTemplateDescription: string;\r\n defaultOrderTemplateName: string;\r\n createOrderTemplateButtonText: string;\r\n cancelNewOrderTemplateCreationButtonText: string;\r\n viewOrderTemplateButtonText: string;\r\n continueShoppingButtonText: string;\r\n itemAddedToOrderTemplateHeaderItemOneText: string;\r\n itemAddedToOrderTemplateHeaderItemFormatText: string;\r\n itemAddedToOrderTemplateHeaderMessageText: string;\r\n priceFree: string;\r\n originalPriceText: string;\r\n currentPriceText: string;\r\n duplicatedProductsHeader: string;\r\n duplicatedProductsDescription: string;\r\n updateQuantityButtonText: string;\r\n cancelDuplicateItemsButtonText: string;\r\n addToOrderTemplateButtonText: string;\r\n addToOrderTemplateButtonTooltip: string;\r\n}\r\n\r\nexport interface BuyValidationResult {\r\n isValid: boolean;\r\n message?: string;\r\n}\r\n\r\nconst PriceComponentActions = {};\r\n\r\n/**\r\n * Gets the product page url from the default swatch selected.\r\n * @param productData - Product card to be rendered.\r\n * @returns The default color swatch selected if any.\r\n */\r\nfunction getDefaultSwatchSelected(coreContext: ICoreContext, productData?: ProductSearchResult): AttributeSwatch | null {\r\n if (!productData || !productData.AttributeValues) {\r\n return null;\r\n }\r\n\r\n const siteContext = coreContext as ICoreContext;\r\n const dimensionToPreSelectInProductCard = siteContext.app.config.dimensionToPreSelectInProductCard;\r\n\r\n const attributeSwatches = productData.AttributeValues.find(\r\n attributeValue => attributeValue.KeyName?.toLocaleLowerCase() === dimensionToPreSelectInProductCard\r\n )?.Swatches;\r\n\r\n if (!ArrayExtensions.hasElements(attributeSwatches)) {\r\n return null;\r\n }\r\n\r\n const defaultSwatch = attributeSwatches.find(item => item.IsDefault === true) ?? attributeSwatches[0];\r\n return defaultSwatch;\r\n}\r\n\r\n/**\r\n * Gets the product image from the default swatch selected.\r\n * @param coreContext - Context of the module using the component.\r\n * @param productData - Product card to be rendered.\r\n * @returns The product card image url.\r\n */\r\nfunction getProductImageUrlFromDefaultSwatch(coreContext: ICoreContext, productData?: ProductSearchResult): string | undefined {\r\n const defaultSwatch = getDefaultSwatchSelected(coreContext, productData);\r\n const swatchProductImageUrls = defaultSwatch?.ProductImageUrls;\r\n if (!ArrayExtensions.hasElements(swatchProductImageUrls)) {\r\n return productData?.PrimaryImageUrl;\r\n }\r\n\r\n return generateImageUrl(swatchProductImageUrls[0], coreContext.request.apiSettings);\r\n}\r\n\r\n/**\r\n * Updates the product url link to product details page.\r\n * @param productDetailsPageUrl - Product page url.\r\n * @param coreContext - Context of the module using the component.\r\n * @param queryString - Querystring to be added to the URL.\r\n * @returns The update product page url.\r\n */\r\nfunction updateProductUrl(productDetailsPageUrl: string, coreContext: ICoreContext, queryString: string): string {\r\n const sourceUrl = new URL(productDetailsPageUrl, coreContext.request.apiSettings.baseUrl);\r\n if (sourceUrl.search) {\r\n sourceUrl.search += `&${queryString}`;\r\n } else {\r\n sourceUrl.search += queryString;\r\n }\r\n\r\n const updatedUrl = new URL(sourceUrl.href);\r\n return updatedUrl.pathname + sourceUrl.search;\r\n}\r\n\r\n/**\r\n * Gets the react node for product unit of measure display.\r\n * @param unitOfMeasure - DefaultUnitOfMeasure property from product.\r\n * @returns The node representing markup for unit of measure component.\r\n */\r\n// @ts-expect-error\r\nfunction renderProductUnitOfMeasure(context: ICoreContext, unitOfMeasure?: string): JSX.Element | null {\r\n if (!unitOfMeasure) {\r\n return null;\r\n }\r\n return (\r\n \r\n );\r\n}\r\n\r\n/**\r\n * Gets the react node for product availability.\r\n * @param inventoryAvailabilityLabel - The product information.\r\n * @returns The node representing markup for product availability.\r\n */\r\nfunction renderProductAvailability(inventoryAvailabilityLabel: string | undefined, inventoryStatus?: IProductInventoryInformation): JSX.Element | null {\r\n let availabilityClassName = 'retrieving';\r\n\r\n if (inventoryStatus?.IsProductAvailable || inventoryStatus?.StockLevelLabel?.startsWith('!')) {\r\n availabilityClassName = 'available';\r\n } else if (inventoryStatus?.IsProductAvailable === false) {\r\n availabilityClassName = 'not-available';\r\n }\r\n\r\n if (inventoryStatus?.StockLevelCode === 'ERR') {\r\n availabilityClassName = 'error';\r\n }\r\n\r\n const stockLevelLabel = inventoryStatus?.StockLevelLabel?.startsWith('!')\r\n ? inventoryStatus?.StockLevelLabel?.substring(1)\r\n : inventoryStatus?.StockLevelLabel;\r\n const inventoryStatusText = inventoryStatus?.StockLevelCode === 'ERR'\r\n ? stockLevelLabel || 'ERROR'\r\n : inventoryStatus\r\n ? inventoryAvailabilityLabel?.substring(inventoryAvailabilityLabel.startsWith('!') ? 1 : 0)\r\n : <> ;\r\n\r\n return (\r\n
\r\n \r\n {inventoryStatusText}\r\n \r\n
\r\n );\r\n}\r\n\r\n/**\r\n * Renders product comparison button similar to the quick view button.\r\n * @param productComparisonButton - React element of the button.\r\n * @param product - Current product info.\r\n * @param catalogId - Current catalog.\r\n * @returns React element for the specific product.\r\n */\r\nfunction renderProductComparisonButton(\r\n productComparisonButton: React.ReactNode,\r\n product: ProductSearchResult,\r\n catalogId: number\r\n): JSX.Element | undefined {\r\n return React.cloneElement(productComparisonButton as React.ReactElement, { product, catalogId });\r\n}\r\n\r\n/**\r\n * Gets the product page url from the default swatch selected.\r\n * @param coreContext - Context of the module using the component.\r\n * @param productUrl - Product page url for the product card.\r\n * @param productData - Product card to be rendered.\r\n * @returns The product card image url.\r\n */\r\nfunction getProductPageUrlFromDefaultSwatch(\r\n coreContext: ICoreContext,\r\n productUrl: string,\r\n productData?: ProductSearchResult\r\n): string | undefined {\r\n const defaultSwatch = getDefaultSwatchSelected(coreContext, productData);\r\n if (!defaultSwatch?.SwatchValue) {\r\n return productUrl;\r\n }\r\n\r\n const siteContext = coreContext as ICoreContext;\r\n const dimensionToPreSelectInProductCard = siteContext.app.config.dimensionToPreSelectInProductCard;\r\n\r\n const queryStringEncoded = encodeURIComponent(defaultSwatch.SwatchValue);\r\n const queryString = `${dimensionToPreSelectInProductCard}=${queryStringEncoded}`;\r\n return updateProductUrl(productUrl, coreContext, queryString);\r\n}\r\n\r\nfunction generateAddToOrderTemplateDialogResources(resources: IAddToOrderTemplateResources | undefined): IAddToOrderTemplateDialogResources {\r\n return {\r\n addToOrderTemplateHeader: resources?.addToOrderTemplateHeader || 'addToOrderTemplateHeader',\r\n\r\n noOrderTemplatesMessage: resources?.noOrderTemplatesMessage || 'noOrderTemplatesMessage',\r\n noOrderTemplatesDescription: resources?.noOrderTemplatesDescription || 'noOrderTemplatesDescription',\r\n\r\n createAnOrderTemplateButtonText: resources?.createAnOrderTemplateButtonText || 'createAnOrderTemplateButtonText',\r\n createNewOrderTemplateButtonText: resources?.createNewOrderTemplateButtonText || 'createNewOrderTemplateButtonText',\r\n cancelOrderTemplateCreationButtonText: resources?.cancelOrderTemplateCreationButtonText || 'cancelOrderTemplateCreationButtonText',\r\n\r\n selectTemplatesText: resources?.selectTemplatesText || 'selectTemplatesText',\r\n addToTemplateButtonText: resources?.addToTemplateButtonText || 'addToTemplateButtonText',\r\n lineItemsText: resources?.lineItemsText || 'lineItemsText',\r\n };\r\n}\r\n\r\nfunction generateOrderTemplateNameDialogResources(resources: IAddToOrderTemplateResources | undefined): IOrderTemplateNameDialogResources {\r\n return {\r\n orderTemplateHeaderLabel: resources?.createOrderTemplateHeader || 'createOrderTemplateHeader',\r\n orderTemplateTitleLabel: resources?.orderTemplateTitle || 'orderTemplateTitle',\r\n orderTemplateNameAriaLabel: resources?.orderTemplateNameAriaLabel || 'orderTemplateNameAriaLabel',\r\n orderTemplateDescription: resources?.createOrderTemplateDescription || 'createOrderTemplateDescription',\r\n\r\n defaultOrderTemplateName: resources?.defaultOrderTemplateName || 'defaultOrderTemplateName',\r\n\r\n orderTemplateButtonLabel: resources?.createOrderTemplateButtonText || 'createOrderTemplateButtonText',\r\n orderTemplateCancelButtonLabel: resources?.cancelNewOrderTemplateCreationButtonText || 'cancelNewOrderTemplateCreationButtonText',\r\n };\r\n}\r\n\r\nfunction generateItemAddedToOrderTemplateDialogResources(resources: IAddToOrderTemplateResources | undefined): IItemAddedToOrderTemplateDialogResources {\r\n return {\r\n viewOrderTemplateButtonText: resources?.viewOrderTemplateButtonText || 'viewOrderTemplateButtonText',\r\n continueShoppingButtonText: resources?.continueShoppingButtonText || 'continueShoppingButtonText',\r\n itemAddedToOrderTemplateHeaderItemOneText: resources?.itemAddedToOrderTemplateHeaderItemOneText || 'itemAddedToOrderTemplateHeaderItemOneText',\r\n itemAddedToOrderTemplateHeaderItemFormatText: resources?.itemAddedToOrderTemplateHeaderItemFormatText || 'itemAddedToOrderTemplateHeaderItemFormatText',\r\n itemAddedToOrderTemplateHeaderMessageText: resources?.itemAddedToOrderTemplateHeaderMessageText || 'itemAddedToOrderTemplateHeaderMessageText',\r\n freePriceText: resources?.priceFree || 'priceFree',\r\n originalPriceText: resources?.originalPriceText || 'originalPriceText',\r\n currentPriceText: resources?.currentPriceText || 'currentPriceText',\r\n };\r\n}\r\n\r\nfunction generateDuplicateItemsWhenAddingToOrderTemplateDialogResources(resources: IAddToOrderTemplateResources | undefined): IDuplicateItemsWhenAddingToOrderTemplateDialogResources {\r\n return {\r\n duplicatedProductsHeader: resources?.duplicatedProductsHeader || 'duplicatedProductsHeader',\r\n duplicatedProductsDescription: resources?.duplicatedProductsDescription || 'duplicatedProductsDescription',\r\n updateQuantityButtonText: resources?.updateQuantityButtonText || 'updateQuantityButtonText',\r\n cancelDuplicateItemsButtonText: resources?.cancelDuplicateItemsButtonText || 'cancelDuplicateItemsButtonText',\r\n };\r\n}\r\n\r\nconst ProductCard: React.FC = ({\r\n data,\r\n context,\r\n imageSettings,\r\n savingsText,\r\n freePriceText,\r\n originalPriceText,\r\n currentPriceText,\r\n ratingAriaLabel,\r\n ratingCountAriaLabel,\r\n cartQueue,\r\n allowBack,\r\n typeName,\r\n id,\r\n telemetryContent,\r\n quickViewButton,\r\n productComparisonButton,\r\n wishlistButton,\r\n isEnabledProductDescription,\r\n isPriceMinMaxEnabled,\r\n disableBuyButton,\r\n showPrice = true,\r\n showAgreementProduct,\r\n buyAlwaysAdd,\r\n priceResources,\r\n inventoryLabel,\r\n inventoryStatus,\r\n dimensionAvailabilities,\r\n swatchItemAriaLabel,\r\n addToCartText,\r\n updateCartText,\r\n removeFromCartText,\r\n outOfStockText,\r\n priceErrorText,\r\n toastStrings,\r\n inCartTooltipText,\r\n transitTooltip,\r\n agreementProductTooltip,\r\n addToOrderTemplateResources,\r\n onUpdateOrderTemplates,\r\n retrieveOrderTemplates,\r\n onBuyValidate\r\n}) => {\r\n const locale = getLocale(context);\r\n const { product, simpleProduct } = data;\r\n const [modal, setModal] = useState({\r\n allergensModal: false,\r\n productInformationModal: false\r\n });\r\n const cartQuantity = buyAlwaysAdd\r\n ? 0\r\n : data.cart?.cart?.CartLines?.find(x => x.ProductId === product?.RecordId)?.Quantity ?? 0;\r\n const [orderQuantity, setOrderQuantity] = useState(cartQuantity);\r\n const [breakoff, setBreakoff] = useState(false);\r\n\r\n let productUrl = getProductPageUrlSync(product?.Name ?? '', product?.RecordId ?? Number.MIN_VALUE, context.actionContext, undefined);\r\n if (allowBack) {\r\n productUrl = updateProductUrl(productUrl, context, 'back=true');\r\n }\r\n const productImageUrlFromSwatch = getProductImageUrlFromDefaultSwatch(context, product) ?? product?.PrimaryImageUrl;\r\n const productPageUrlFromSwatch = getProductPageUrlFromDefaultSwatch(context, productUrl, product) ?? productUrl;\r\n const [productPageUrl, setProductPageUrl] = useState(productPageUrlFromSwatch);\r\n const [productImageUrl, setProductImageUrl] = useState(productImageUrlFromSwatch);\r\n const [cardActionsOpen, setCardActionsOpen] = useState(false);\r\n const [showCartCountTooltip, setShowCartCountTooltip] = useState(false);\r\n const cardActionWrapperRef = React.createRef();\r\n const temperatureZoneIcon = React.useMemo(() => product?.TemperatureZone ? getTemperatureZoneIcon(context, product.TemperatureZone) : undefined, [product]);\r\n\r\n // @ts-expect-error -- Variable is declared but its value is never read.\r\n const [forceUpdate, setForceUpdate] = useState(0);\r\n\r\n React.useEffect(() => {\r\n if (buyAlwaysAdd) {\r\n return;\r\n }\r\n\r\n const disposer = reaction(\r\n () => data.cart?.cart.CartLines,\r\n () => {\r\n if (cartQuantity > 0 && !data.cart?.cart.CartLines?.find(x => x.ProductId === product?.RecordId)) {\r\n // This product was removed from cart, reset quantity\r\n setOrderQuantity(0);\r\n }\r\n });\r\n\r\n return disposer;\r\n }, []);\r\n\r\n React.useEffect(() => {\r\n setProductPageUrl(productPageUrlFromSwatch);\r\n setProductImageUrl(productImageUrlFromSwatch);\r\n }, [productUrl, productPageUrlFromSwatch, productImageUrlFromSwatch]);\r\n\r\n React.useEffect(() => {\r\n // Set 'title' attribute on AddToOrderTemplate buttons\r\n document.querySelectorAll('.order-template-button').forEach(element => {\r\n element.setAttribute('title', element.getAttribute('aria-label') || '');\r\n });\r\n }, []);\r\n const [selectedSwatchItems] = useState(new Dictionary());\r\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment,@typescript-eslint/no-unsafe-member-access -- app context is generic\r\n const enableStockCheck = context.app.config.enableStockCheck;\r\n\r\n const siteContext = context as ICoreContext;\r\n const dimensionToPreSelectInProductCard = siteContext.app.config.dimensionToPreSelectInProductCard;\r\n\r\n /**\r\n * Updates the product page and Image url based on swatch selected.\r\n * @param coreContext - Context of the caller.\r\n * @param swatchItem - Dimension swatch selected.\r\n */\r\n const updatePageAndImageUrl = React.useCallback(\r\n (coreContext: ICoreContext, swatchItem: ISwatchItem) => {\r\n const dimensionType = swatchItem.dimensionType;\r\n selectedSwatchItems.setValue(dimensionType, swatchItem);\r\n if (StringExtensions.isNullOrWhitespace(swatchItem.value)) {\r\n return;\r\n }\r\n const queryString = `${dimensionType}=${swatchItem.value}`;\r\n let productPageUrlWithSwatch = '';\r\n if (productPageUrl.includes(dimensionType)) {\r\n const newUrl = new URL(productPageUrl, coreContext.request.apiSettings.baseUrl);\r\n newUrl.searchParams.delete(dimensionType);\r\n productPageUrlWithSwatch = updateProductUrl(newUrl.toString(), context, queryString);\r\n } else {\r\n productPageUrlWithSwatch = updateProductUrl(productPageUrl, context, queryString);\r\n }\r\n setProductPageUrl(productPageUrlWithSwatch);\r\n if (dimensionType === dimensionToPreSelectInProductCard) {\r\n const swatchProductImageUrl = ArrayExtensions.hasElements(swatchItem.productImageUrls)\r\n ? swatchItem.productImageUrls[0]\r\n : undefined;\r\n const newImageUrl = generateImageUrl(swatchProductImageUrl, coreContext.request.apiSettings);\r\n setProductImageUrl(newImageUrl);\r\n }\r\n },\r\n [selectedSwatchItems, context, productPageUrl]\r\n );\r\n\r\n if (!product) {\r\n return null;\r\n }\r\n\r\n /**\r\n * Checks if rendering the particular dimensions is allowed for product card.\r\n * @param dimensionType - Dimension to be displayed.\r\n * @returns Updates the state with new product page url.\r\n */\r\n function shouldDisplayDimension(dimensionType: string): boolean {\r\n const dimensionsContext = context as ICoreContext;\r\n const dimensionsToDisplayOnProductCard = dimensionsContext.app.config.dimensionsInProductCard;\r\n return (\r\n ArrayExtensions.hasElements(dimensionsToDisplayOnProductCard) &&\r\n !dimensionsToDisplayOnProductCard.includes(DimensionTypes.none) &&\r\n dimensionsToDisplayOnProductCard.includes(dimensionType.toLocaleLowerCase() as DimensionTypes)\r\n );\r\n }\r\n\r\n /**\r\n * Gets the react node for product dimension as swatch.\r\n * @param attributeValues - Attribute value property from product.\r\n * @returns The node representing markup for unit of measure component.\r\n */\r\n function renderProductDimensions(attributeValues?: AttributeValue[]): JSX.Element | null {\r\n if (!attributeValues) {\r\n return null;\r\n }\r\n\r\n return (\r\n
\r\n {attributeValues.map((item: AttributeValue) => {\r\n const dimensionTypeValue = item.KeyName?.toLocaleLowerCase() ?? '';\r\n if (!shouldDisplayDimension(dimensionTypeValue)) {\r\n return null;\r\n }\r\n\r\n const siteContext = context as ICoreContext;\r\n const dimensionToPreSelectInProductCard = siteContext.app.config.dimensionToPreSelectInProductCard;\r\n const dimensionType = dimensionTypeValue as DimensionTypes;\r\n const swatches =\r\n item.Swatches?.map(swatchItem => {\r\n return {\r\n itemId: `${item.RecordId ?? ''}-${dimensionTypeValue}-${swatchItem.SwatchValue ?? ''}`,\r\n value: swatchItem.SwatchValue ?? '',\r\n dimensionType,\r\n colorHexCode: swatchItem.SwatchColorHexCode,\r\n imageUrl: swatchItem.SwatchImageUrl,\r\n productImageUrls: swatchItem.ProductImageUrls,\r\n isDefault: swatchItem.IsDefault,\r\n swatchItemAriaLabel: swatchItemAriaLabel ? format(swatchItemAriaLabel, dimensionType) : '',\r\n isDisabled:\r\n enableStockCheck &&\r\n dimensionAvailabilities?.find(\r\n dimensionAvailability => dimensionAvailability.value === (swatchItem.SwatchValue ?? '')\r\n )?.isDisabled\r\n };\r\n }) ?? [];\r\n if (\r\n dimensionType === dimensionToPreSelectInProductCard &&\r\n ArrayExtensions.hasElements(swatches) &&\r\n !swatches.some(swatch => swatch.isDefault)\r\n ) {\r\n swatches[0].isDefault = true;\r\n }\r\n return (\r\n \r\n );\r\n })}\r\n
\r\n );\r\n }\r\n\r\n function renderQuickView(quickview: React.ReactNode, item?: number): JSX.Element | undefined {\r\n if (quickview === null) {\r\n return undefined;\r\n }\r\n const selectedDimensions: ProductDimension[] = selectedSwatchItems.getValues().map(swatches => {\r\n return {\r\n DimensionTypeValue: convertDimensionTypeToProductDimensionType(swatches.dimensionType),\r\n DimensionValue: {\r\n RecordId: 0,\r\n Value: swatches.value\r\n }\r\n };\r\n });\r\n return React.cloneElement(quickview as React.ReactElement, { selectedProductId: item, selectedDimensions });\r\n }\r\n\r\n function renderOrderTemplateButton() {\r\n if (!data.customerInformation?.IsB2b) {\r\n return null;\r\n }\r\n\r\n return (\r\n
\r\n {\r\n await onUpdateOrderTemplates?.(orderTemplate);\r\n toast({\r\n text: `${data.product?.Name}${addToOrderTemplateResources?.itemAddedToOrderTemplateHeaderMessageText}`,\r\n autoClose: 3000,\r\n canClose: true,\r\n position: 'bottom-right',\r\n type: 'success',\r\n showProgress: true\r\n });\r\n }}\r\n retrieveOrderTemplates={retrieveOrderTemplates}\r\n />\r\n
\r\n );\r\n }\r\n\r\n function renderWishlistButton(wishlistButton: React.ReactNode): React.ReactNode | undefined {\r\n return wishlistButton;\r\n }\r\n\r\n // Construct telemetry attribute to render\r\n const payLoad = getPayloadObject('click', telemetryContent!, '', product.RecordId.toString());\r\n\r\n const attribute = getTelemetryAttributes(telemetryContent!, payLoad);\r\n\r\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access -- -- Do not need type check for appsettings\r\n // @ts-expect-error\r\n const isUnitOfMeasureEnabled = context.app.config && context.app.config.unitOfMeasureDisplayType === 'buyboxAndBrowse';\r\n const _renderCartButton = (): JSX.Element => {\r\n const product1: SimpleProduct = {\r\n RecordId: data.product?.RecordId!,\r\n ItemId: data.product?.ItemId,\r\n Name: data.product?.Name,\r\n Description: data.product?.Description,\r\n ProductTypeValue: data.product?.RecordId!,\r\n DefaultUnitOfMeasure: data.product?.DefaultUnitOfMeasure,\r\n BasePrice: data.product?.BasePrice!,\r\n Price: data.product?.Price!,\r\n AdjustedPrice: data.product?.Price!,\r\n MasterProductId: data.product?.MasterProductId,\r\n PrimaryImageUrl: data.product?.PrimaryImageUrl,\r\n ExtensionProperties: data.product?.ExtensionProperties\r\n };\r\n const productDimensionAvailabilities =\r\n dimensionAvailabilities &&\r\n dimensionAvailabilities?.find(\r\n dimensionAvailability =>\r\n ArrayExtensions.hasElements(dimensionAvailabilities) &&\r\n dimensionAvailability.masterProductId &&\r\n dimensionAvailability.masterProductId === product.MasterProductId\r\n );\r\n const ProductAvailableQuantity: any = {\r\n AvailableQuantity: 1000\r\n };\r\n\r\n let cartCount: JSX.Element | undefined = undefined;\r\n // const cartQuantity = data.cart?.cart.CartLines?.find(x => x.ProductId === product.RecordId)?.Quantity;\r\n const cartQuantity = data.cart?.cart.CartLines?.filter(x => x.ProductId === product.RecordId).reduce((acc, val) => acc + (val.Quantity || 0), 0);\r\n\r\n if (cartQuantity) {\r\n const cartCountId = `product-component-cart-count-${product.RecordId}`;\r\n const tooltipString = inCartTooltipText || '{0} i handlekurven';\r\n const tooltipText = format(tooltipString, cartQuantity);\r\n\r\n cartCount = (\r\n setShowCartCountTooltip(true)}\r\n onMouseOut={() => setShowCartCountTooltip(false)}\r\n onTouchStart={() => setShowCartCountTooltip(true)}\r\n >\r\n {cartQuantity}\r\n \r\n {tooltipText}\r\n \r\n \r\n );\r\n }\r\n\r\n return (\r\n \r\n {\r\n setOrderQuantity(quantity);\r\n }}\r\n onBuyValidate={onBuyValidate}\r\n onAdd={e => {\r\n setForceUpdate((prev) => prev + 1);\r\n }}\r\n />\r\n {cartCount}\r\n \r\n );\r\n };\r\n\r\n const baseClassName = 'msc-product-component';\r\n const shouldUseAlternativeProducer = (product.AgentImporter?.length || 0) > 3 || (product.Producer?.length || 0) > 3;\r\n\r\n return (\r\n
\r\n {isEnabledProductDescription ? (\r\n \r\n
\r\n
\r\n {renderProductPlacementImage(\r\n imageSettings,\r\n context.request.gridSettings,\r\n productImageUrl,\r\n product.PrimaryImageUrl,\r\n product.Name,\r\n context\r\n )}\r\n
\r\n
\r\n
{product.Name}
\r\n {context.request.user.isAuthenticated && renderPrice(\r\n context,\r\n typeName,\r\n id,\r\n showPrice,\r\n product.BasePrice,\r\n product.Price,\r\n savingsText,\r\n freePriceText,\r\n originalPriceText,\r\n currentPriceText,\r\n isPriceMinMaxEnabled,\r\n priceResources,\r\n product.PriceFailed,\r\n priceErrorText,\r\n product.ProductPrice\r\n )}\r\n {renderDescription(product.Description)}\r\n
\r\n
\r\n \r\n ) : (\r\n \r\n
\r\n {renderProductPlacementImage(\r\n imageSettings,\r\n context.request.gridSettings,\r\n productImageUrl,\r\n product.PrimaryImageUrl,\r\n product.Name,\r\n context\r\n )}\r\n
\r\n
\r\n
{product.ItemId}
\r\n
\r\n
\r\n {product.Transit && (\r\n
T
\r\n )}\r\n {showAgreementProduct && product.IsAgreementProduct && (\r\n
A
\r\n )}\r\n {temperatureZoneIcon && (\r\n \r\n )}\r\n {product.Name}\r\n
\r\n {product.Brand &&
{product.Brand}
}\r\n {shouldUseAlternativeProducer === false ? (\r\n <>\r\n {product.Manufacturer &&
{product.Manufacturer}
}\r\n \r\n ) : (\r\n <>\r\n {product.Producer && product.Producer.length > 3 && (\r\n
{product.Producer}
\r\n )}\r\n {product.AgentImporter && product.AgentImporter.length > 3 && (\r\n
{product.AgentImporter}
\r\n )}\r\n \r\n )}\r\n
\r\n {context.request.user.isAuthenticated && renderPrice(\r\n context,\r\n typeName,\r\n id,\r\n showPrice,\r\n product.BasePrice,\r\n product.Price,\r\n savingsText,\r\n freePriceText,\r\n originalPriceText,\r\n currentPriceText,\r\n undefined,\r\n undefined,\r\n product.PriceFailed,\r\n priceErrorText,\r\n product.ProductPrice\r\n )}\r\n {context.request.user.isAuthenticated && renderProductAvailability(inventoryLabel, inventoryStatus)}\r\n
\r\n \r\n )}\r\n {renderProductDimensions(product.AttributeValues)}\r\n {context.request.user.isAuthenticated && (\r\n
\r\n
\r\n setOrderQuantity(newValue)}\r\n inputQuantityAriaLabel=''\r\n incrementButtonAriaLabel=''\r\n decrementButtonAriaLabel=''\r\n disabled={disableBuyButton}\r\n onBreakoffChange={(newValue) => setBreakoff(newValue)}\r\n />\r\n
\r\n
\r\n )}\r\n {!context.app.config.hideRating &&\r\n renderRating(context, typeName, id, product.AverageRating, product.TotalRatings, ratingAriaLabel, ratingCountAriaLabel)}\r\n {context.request.user.isAuthenticated && _renderCartButton()}\r\n {\r\n if (e.target === cardActionWrapperRef.current) {\r\n setCardActionsOpen(!cardActionsOpen);\r\n }\r\n }}\r\n onBlur={(e) => {\r\n if (!cardActionWrapperRef.current?.contains(e.relatedTarget as Node)) {\r\n setCardActionsOpen(false);\r\n }\r\n }}\r\n ref={cardActionWrapperRef}\r\n >\r\n
\r\n {quickViewButton && renderQuickView(quickViewButton, product.RecordId)}\r\n {productComparisonButton && renderProductComparisonButton(productComparisonButton, product, getCatalogId(context.request))}\r\n {context.request.user.isAuthenticated && (\r\n <>\r\n
\r\n {modal.allergensModal && (\r\n setModal({ ...modal, allergensModal: false })}\r\n context={context}\r\n product={product}/>\r\n )}\r\n {\r\n setModal({ ...modal, allergensModal: true });\r\n }\r\n }>\r\n \r\n \r\n
\r\n {renderOrderTemplateButton()}\r\n
\r\n {modal.productInformationModal && (\r\n setModal({ ...modal, productInformationModal: false })}\r\n context={context}\r\n product={product}/>\r\n )}\r\n {\r\n setModal({ ...modal, productInformationModal: true });\r\n }\r\n }>\r\n \r\n \r\n
\r\n {wishlistButton && renderWishlistButton(wishlistButton)}\r\n \r\n )}\r\n
\r\n
\r\n\r\n {product.Badge && (\r\n \r\n )}\r\n \r\n );\r\n};\r\n\r\nfunction renderLabel(\r\n name?: string,\r\n price?: string,\r\n rating?: number,\r\n ratingAriaLabelText?: string,\r\n reviewCount?: number,\r\n ratingCountAriaLabelText?: string\r\n): string {\r\n const reviewCountArialableText = getReviewAriaLabel(reviewCount, ratingCountAriaLabelText ?? '');\r\n return `${name ?? ''} ${price ?? ''} ${getRatingAriaLabel(rating, ratingAriaLabelText)}${\r\n reviewCountArialableText ? ` ${reviewCountArialableText}` : ''\r\n }`;\r\n}\r\n\r\nfunction renderDescription(description?: string): JSX.Element | null {\r\n return

{description}

;\r\n}\r\n\r\nfunction getRatingAriaLabel(rating?: number, ratingAriaLabel?: string): string {\r\n if (rating && ratingAriaLabel) {\r\n const roundedRating = rating.toFixed(2);\r\n return format(ratingAriaLabel || '', roundedRating, '5');\r\n }\r\n return '';\r\n}\r\n\r\nfunction getReviewAriaLabel(reviewCount?: number, ratingCountAriaLabelText?: string): string {\r\n if (reviewCount && ratingCountAriaLabelText) {\r\n return format(ratingCountAriaLabelText || '', reviewCount);\r\n }\r\n return '';\r\n}\r\n\r\nfunction renderRating(\r\n coreContext: ICoreContext,\r\n moduleTypeName: string,\r\n moduleId: string,\r\n avgRating?: number,\r\n totalRatings?: number,\r\n ariaLabel?: string,\r\n ratingCountAriaLabel?: string\r\n): JSX.Element | null {\r\n if (!avgRating) {\r\n return null;\r\n }\r\n\r\n const numberRatings = totalRatings?.toString() || undefined;\r\n const ratingAriaLabelText = getRatingAriaLabel(avgRating, ariaLabel);\r\n const ratingCountAriaLabelText = getReviewAriaLabel(Number(numberRatings), ratingCountAriaLabel);\r\n\r\n return (\r\n \r\n );\r\n}\r\n\r\nfunction renderPrice(\r\n context: ICoreContext,\r\n typeName: string,\r\n id: string,\r\n show: boolean,\r\n basePrice?: number,\r\n adjustedPrice?: number,\r\n savingsText?: string,\r\n freePriceText?: string,\r\n originalPriceText?: string,\r\n currentPriceText?: string,\r\n isPriceMinMaxEnabled?: boolean,\r\n priceResources?: IPriceComponentResources,\r\n priceFailed?: boolean,\r\n priceErrorText?: string,\r\n productPrice?: ProductPrice\r\n): JSX.Element | null {\r\n const price: ProductPrice = {\r\n BasePrice: basePrice,\r\n AdjustedPrice: adjustedPrice,\r\n CustomerContextualPrice: adjustedPrice\r\n };\r\n\r\n if (priceFailed) {\r\n return (\r\n \r\n \r\n {priceErrorText || 'Pris n/a'}\r\n \r\n \r\n )\r\n }\r\n\r\n if (!show) {\r\n return (\r\n \r\n \r\n ...\r\n \r\n \r\n )\r\n }\r\n\r\n return (\r\n \r\n );\r\n}\r\n\r\nfunction renderProductPlacementImage(\r\n imageSettings?: IImageSettings,\r\n gridSettings?: IGridSettings,\r\n imageUrl?: string,\r\n fallbackImageUrl?: string,\r\n altText?: string,\r\n context?: ICoreContext>\r\n): JSX.Element | null {\r\n if (!imageUrl || !gridSettings || !imageSettings) {\r\n return null;\r\n }\r\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access, @typescript-eslint/no-unsafe-assignment -- Site level config can be of any type.\r\n const contextConfig = context?.app.config?.placeholderImageName;\r\n const emptyPlaceHolderImage = contextConfig as string;\r\n let fallbackImageSource = fallbackImageUrl;\r\n if (emptyPlaceHolderImage && fallbackImageUrl) {\r\n fallbackImageSource = `${fallbackImageUrl},${emptyPlaceHolderImage}`;\r\n }\r\n const img: IImageData = {\r\n src: imageUrl,\r\n altText: altText ? altText : '',\r\n fallBackSrc: fallbackImageSource\r\n };\r\n const imageProps = {\r\n gridSettings,\r\n imageSettings\r\n };\r\n imageProps.imageSettings.cropFocalRegion = true;\r\n imageProps.imageSettings.mode = 0;\r\n imageProps.imageSettings.viewports = {\r\n xs: { h: 200, w: 200, q: 'w=200&h=200&q=80&m=0&f=webp', qe: 't=200h200qhigh' },\r\n lg: { h: 200, w: 200, q: 'w=200&h=200&q=80&m=0&f=webp', qe: 't=200h200qhigh' },\r\n md: { h: 200, w: 200, q: 'w=200&h=200&q=80&m=0&f=webp', qe: 't=200h200qhigh' },\r\n sm: { h: 200, w: 200, q: 'w=200&h=200&q=80&m=0&f=webp', qe: 't=200h200qhigh' },\r\n xl: { h: 200, w: 200, q: 'w=200&h=200&q=80&m=0&f=webp', qe: 't=200h200qhigh' }\r\n };\r\n\r\n return (\r\n \r\n );\r\n}\r\n\r\nexport const ProductComponent: React.FunctionComponent = msdyn365Commerce.createComponentOverride('Product', { component: ProductCard, ...PriceComponentActions });\r\n\r\nexport default ProductComponent;\r\n"],"names":["getDefaultSwatchSelected","coreContext","productData","_productData$Attribut","_attributeSwatches$fi","AttributeValues","dimensionToPreSelectInProductCard","app","config","attributeSwatches","find","attributeValue","_attributeValue$KeyNa","KeyName","toLocaleLowerCase","Swatches","ArrayExtensions","hasElements","item","IsDefault","updateProductUrl","productDetailsPageUrl","queryString","sourceUrl","URL","request","apiSettings","baseUrl","search","href","pathname","generateOrderTemplateNameDialogResources","resources","orderTemplateHeaderLabel","createOrderTemplateHeader","orderTemplateTitleLabel","orderTemplateTitle","orderTemplateNameAriaLabel","orderTemplateDescription","createOrderTemplateDescription","defaultOrderTemplateName","orderTemplateButtonLabel","createOrderTemplateButtonText","orderTemplateCancelButtonLabel","cancelNewOrderTemplateCreationButtonText","generateItemAddedToOrderTemplateDialogResources","viewOrderTemplateButtonText","continueShoppingButtonText","itemAddedToOrderTemplateHeaderItemOneText","itemAddedToOrderTemplateHeaderItemFormatText","itemAddedToOrderTemplateHeaderMessageText","freePriceText","priceFree","originalPriceText","currentPriceText","generateDuplicateItemsWhenAddingToOrderTemplateDialogResources","duplicatedProductsHeader","duplicatedProductsDescription","updateQuantityButtonText","cancelDuplicateItemsButtonText","renderLabel","name","price","rating","ratingAriaLabelText","reviewCount","ratingCountAriaLabelText","reviewCountArialableText","getReviewAriaLabel","getRatingAriaLabel","ratingAriaLabel","roundedRating","toFixed","format","renderPrice","context","typeName","id","show","basePrice","adjustedPrice","savingsText","isPriceMinMaxEnabled","priceResources","priceFailed","priceErrorText","productPrice","BasePrice","AdjustedPrice","CustomerContextualPrice","React","className","PriceComponent","data","renderProductPlacementImage","imageSettings","gridSettings","imageUrl","fallbackImageUrl","altText","_context$app$config","contextConfig","placeholderImageName","fallbackImageSource","img","src","fallBackSrc","imageProps","cropFocalRegion","mode","viewports","xs","h","w","q","qe","lg","md","sm","xl","Image","Object","assign","requestContext","actionContext","loadFailureBehavior","bypassHideOnFailure","ProductComponent","msdyn365Commerce","createComponentOverride","_objectSpread","component","_ref","_data$cart$cart$CartL","_data$cart","_product$Name","_product$RecordId","_getProductImageUrlFr","_getProductPageUrlFro","_product$AgentImporte","_product$Producer","ratingCountAriaLabel","cartQueue","allowBack","telemetryContent","quickViewButton","productComparisonButton","wishlistButton","isEnabledProductDescription","disableBuyButton","showPrice","showAgreementProduct","buyAlwaysAdd","inventoryLabel","inventoryStatus","dimensionAvailabilities","swatchItemAriaLabel","addToCartText","updateCartText","removeFromCartText","outOfStockText","toastStrings","inCartTooltipText","transitTooltip","agreementProductTooltip","addToOrderTemplateResources","onUpdateOrderTemplates","retrieveOrderTemplates","onBuyValidate","locale","getLocale","product","simpleProduct","modal","setModal","useState","allergensModal","productInformationModal","cartQuantity","cart","CartLines","x","ProductId","RecordId","Quantity","orderQuantity","setOrderQuantity","breakoff","setBreakoff","productUrl","getProductPageUrlSync","Name","Number","MIN_VALUE","undefined","productImageUrlFromSwatch","defaultSwatch","swatchProductImageUrls","ProductImageUrls","generateImageUrl","PrimaryImageUrl","getProductImageUrlFromDefaultSwatch","productPageUrlFromSwatch","SwatchValue","encodeURIComponent","getProductPageUrlFromDefaultSwatch","productPageUrl","setProductPageUrl","productImageUrl","setProductImageUrl","cardActionsOpen","setCardActionsOpen","showCartCountTooltip","setShowCartCountTooltip","cardActionWrapperRef","temperatureZoneIcon","TemperatureZone","getTemperatureZoneIcon","forceUpdate","setForceUpdate","reaction","_data$cart2","_data$cart3","document","querySelectorAll","forEach","element","setAttribute","getAttribute","selectedSwatchItems","Dictionary","enableStockCheck","updatePageAndImageUrl","swatchItem","dimensionType","setValue","StringExtensions","isNullOrWhitespace","value","productPageUrlWithSwatch","includes","newUrl","searchParams","delete","toString","swatchProductImageUrl","productImageUrls","newImageUrl","payLoad","getPayloadObject","attribute","getTelemetryAttributes","baseClassName","unitOfMeasureDisplayType","shouldUseAlternativeProducer","AgentImporter","length","Producer","onClick","onTelemetryClick","cultureFormatter","formatCurrency","Price","AverageRating","TotalRatings","user","isAuthenticated","PriceFailed","ProductPrice","description","Description","ItemId","classnames","title","Transit","IsAgreementProduct","Brand","Manufacturer","inventoryAvailabilityLabel","_inventoryStatus$Stoc","_inventoryStatus$Stoc2","_inventoryStatus$Stoc3","availabilityClassName","IsProductAvailable","StockLevelLabel","startsWith","StockLevelCode","stockLevelLabel","substring","inventoryStatusText","renderProductAvailability","attributeValues","map","_item$KeyName$toLocal","_item$KeyName","_item$Swatches$map","_item$Swatches","dimensionTypeValue","dimensionsToDisplayOnProductCard","dimensionsInProductCard","DimensionTypes","none","shouldDisplayDimension","swatches","_item$RecordId","_swatchItem$SwatchVal","_swatchItem$SwatchVal2","_dimensionAvailabilit","itemId","colorHexCode","SwatchColorHexCode","SwatchImageUrl","isDefault","isDisabled","dimensionAvailability","_swatchItem$SwatchVal3","some","swatch","ProductComponentSwatchComponent","onSelectDimension","key","ProductListOrderQuantity","unitConversions","currentCount","onChange","newValue","inputQuantityAriaLabel","incrementButtonAriaLabel","decrementButtonAriaLabel","disabled","onBreakoffChange","hideRating","moduleTypeName","moduleId","avgRating","totalRatings","ariaLabel","numberRatings","RatingComponent","ratingCount","readOnly","renderRating","_renderCartButton","_data$product14","_data$product15","_data$product16","_data$product17","_data$product18","_data$product19","_data$product20","_data$product21","_data$product22","_data$product23","_data$product24","_data$product25","_data$cart4","product1","ProductTypeValue","DefaultUnitOfMeasure","MasterProductId","ExtensionProperties","productDimensionAvailabilities","masterProductId","cartCount","filter","reduce","acc","val","cartCountId","tooltipString","tooltipText","onMouseOver","onMouseOut","onTouchStart","Tooltip","isOpen","target","Node","AddToCartComponent","hasAvailableProducts","productAvailability","AvailableQuantity","productSearch","quantity","onUpdateQuantity","onAdd","e","prev","open","tabIndex","current","onBlur","_cardActionWrapperRef","contains","relatedTarget","ref","quickview","selectedDimensions","getValues","DimensionTypeValue","convertDimensionTypeToProductDimensionType","DimensionValue","Value","selectedProductId","renderQuickView","catalogId","renderProductComparisonButton","getCatalogId","AllergensModal","onClose","allergens","async","_data$customerInforma","customerInformation","IsB2b","AddToOrderTemplateComponent","addToOrderTemplateButtonText","addToOrderTemplateButtonTooltip","addToOrderTemplateDialogResources","addToOrderTemplateHeader","noOrderTemplatesMessage","noOrderTemplatesDescription","createAnOrderTemplateButtonText","createNewOrderTemplateButtonText","cancelOrderTemplateCreationButtonText","selectTemplatesText","addToTemplateButtonText","lineItemsText","createOrderTemplateDialogResources","itemAddedToOrderTemplateDialogResources","duplicateItemsWhenAddingToOrderTemplateDialogResources","_data$product","_data$product2","_data$product3","_data$product4","_data$product5","_data$product6","_data$product7","_data$product8","_data$product9","_data$product10","_data$product11","_data$product12","showButtonTooltip","onSuccess","_data$product13","orderTemplate","toast","text","autoClose","canClose","position","type","showProgress","ProductInformationModal","productInformationTitle","Badge","DiscountBadge","badge","size"],"sourceRoot":""}