{"version":3,"file":"static/js/8f5cbcff2ec5d1a3408e.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 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 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) {\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 inventoryStatusText = inventoryStatus?.StockLevelCode === 'ERR'\r\n ? inventoryStatus?.StockLevelLabel || 'ERROR'\r\n : inventoryStatus ? inventoryAvailabilityLabel : <> ;\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 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 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\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 {temperatureZoneIcon && (\r\n \r\n )}\r\n {product.Name}\r\n
\r\n {product.Brand &&
{product.Brand}
}\r\n {product.Manufacturer &&
{product.Manufacturer}
}\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","ratingCountAriaLabel","cartQueue","allowBack","telemetryContent","quickViewButton","productComparisonButton","wishlistButton","isEnabledProductDescription","disableBuyButton","showPrice","buyAlwaysAdd","inventoryLabel","inventoryStatus","dimensionAvailabilities","swatchItemAriaLabel","addToCartText","updateCartText","removeFromCartText","outOfStockText","toastStrings","inCartTooltipText","transitTooltip","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","onClick","onTelemetryClick","cultureFormatter","formatCurrency","Price","AverageRating","TotalRatings","user","isAuthenticated","PriceFailed","ProductPrice","description","Description","ItemId","classnames","title","Transit","Brand","Manufacturer","inventoryAvailabilityLabel","availabilityClassName","IsProductAvailable","StockLevelCode","inventoryStatusText","StockLevelLabel","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":""}