{"version":3,"file":"static/js/fe539ce2789c90af1d52.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 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\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 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 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\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 cardActionWrapperRef = React.createRef();\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\r\n const ProductAvailableQuantity: any = {\r\n AvailableQuantity: 1000\r\n };\r\n return (\r\n \r\n {\r\n setOrderQuantity(quantity);\r\n }}\r\n onBuyValidate={onBuyValidate}\r\n />\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
{product.Name}
\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 />\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","addToOrderTemplateResources","onUpdateOrderTemplates","retrieveOrderTemplates","onBuyValidate","locale","getLocale","product","simpleProduct","modal","setModal","useState","allergensModal","productInformationModal","cartQuantity","cart","CartLines","x","ProductId","RecordId","Quantity","orderQuantity","setOrderQuantity","productUrl","getProductPageUrlSync","Name","Number","MIN_VALUE","undefined","productImageUrlFromSwatch","defaultSwatch","swatchProductImageUrls","ProductImageUrls","generateImageUrl","PrimaryImageUrl","getProductImageUrlFromDefaultSwatch","productPageUrlFromSwatch","SwatchValue","encodeURIComponent","getProductPageUrlFromDefaultSwatch","productPageUrl","setProductPageUrl","productImageUrl","setProductImageUrl","cardActionsOpen","setCardActionsOpen","cardActionWrapperRef","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","unitOfMeasureDisplayType","onClick","onTelemetryClick","cultureFormatter","formatCurrency","Price","AverageRating","TotalRatings","user","isAuthenticated","PriceFailed","ProductPrice","description","Description","ItemId","classnames","title","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","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","product1","ProductTypeValue","DefaultUnitOfMeasure","MasterProductId","ExtensionProperties","productDimensionAvailabilities","masterProductId","Node","AddToCartComponent","hasAvailableProducts","productAvailability","AvailableQuantity","productSearch","quantity","onUpdateQuantity","open","tabIndex","e","target","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":""}