{"version":3,"file":"static/js/dfdb49fcb1e9ba2d8379.bundle.js","mappings":"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","sources":["webpack://Msdyn365.Commerce.Online/./lib/product-collection/module-registration.js?36d3","webpack://Msdyn365.Commerce.Online/./src/modules/product-collection/product-collection.tsx?4008","webpack://Msdyn365.Commerce.Online/./src/modules/product-collection/product-collection.view.tsx?5d36","webpack://Msdyn365.Commerce.Online/external var \"React\"?0d3b","webpack://Msdyn365.Commerce.Online/external var \"ReactDOM\"?853b"],"sourcesContent":["const binding = { modules: {}, dataActions: {} };\n\n const registerActionId = (actionPath) => {\n if (binding.dataActions[actionPath] &&\n binding.dataActions[actionPath].default &&\n binding.dataActions[actionPath].default.prototype &&\n binding.dataActions[actionPath].default.prototype.id) {\n binding.dataActions[binding.dataActions[actionPath].default.prototype.id] = binding.dataActions[actionPath];\n } else {\n Object.keys(binding.dataActions[actionPath] || {}).forEach(exportName => {\n if (binding.dataActions[actionPath][exportName] &&\n binding.dataActions[actionPath][exportName].prototype &&\n binding.dataActions[actionPath][exportName].prototype.Action) {\n binding.dataActions[binding.dataActions[actionPath][exportName].prototype.id] = binding.dataActions[actionPath][exportName];\n }\n })\n }\n };\n\n const registerSanitizedActionPath = (sanitizedActionPath, dataAction) => {\n if (process.env.NODE_ENV === 'development') {\n if (!dataAction.default) {\n throw new Error('Data action path does not have a default export');\n }\n if (!(dataAction.default.prototype.id && binding.dataActions[dataAction.default.prototype.id]) || !binding.dataActions[sanitizedActionPath]) {\n binding.dataActions[sanitizedActionPath] = dataAction;\n }\n } else {\n binding.dataActions[sanitizedActionPath] = dataAction;\n if (!binding.dataActions[sanitizedActionPath].default) {\n throw new Error('Data action path ' + sanitizedActionPath + ' does not have a default export');\n }\n binding.dataActions[sanitizedActionPath].default.prototype.RegistrationId = sanitizedActionPath;\n if (binding.dataActions[sanitizedActionPath].default.prototype.id) {\n binding.dataActions[binding.dataActions[sanitizedActionPath].default.prototype.id] = sanitizedActionPath;\n }\n }\n };\n \n\n (binding.modules['product-collection'] = {\n c: () => require('@msdyn365-commerce-modules/product-collection/dist/lib/modules/product-collection/product-collection'),\n $type: 'containerModule',\n da: [{name:'featureState', path:'@msdyn365-commerce-modules/retail-actions/dist/lib/get-feature-state', runOn: 0}],\n \n iNM: true,\n ns: '@msdyn365-commerce-modules',\n n: 'product-collection',\n p: 'product-collection',\n \n pdp: '',\n \n \n md: 'node_modules/@msdyn365-commerce-modules/product-collection/dist/lib/modules/product-collection'\n });\n \n\n {\n const sanitizedActionPath = '@msdyn365-commerce-modules/retail-actions/dist/lib/get-feature-state';\n let dataAction = require('@msdyn365-commerce-modules/retail-actions/dist/lib/get-feature-state');\n registerSanitizedActionPath(sanitizedActionPath, dataAction);\n }\n \n\n \n window.__bindings__ = window.__bindings__ || {};\n window.__bindings__.modules = {\n ...window.__bindings__.modules || {},\n ...binding.modules\n };\n \n window.__bindings__.dataActions = {\n ...window.__bindings__.dataActions || {},\n ...binding.dataActions\n };\n export const viewDictionary = {};\n viewDictionary['@msdyn365-commerce-modules|product-collection|modules|product-collection|product-collection'] = {\n c: () => require('@msdyn365-commerce-modules/product-collection/dist/lib/modules/product-collection/product-collection.view.js'),\n cn: '@msdyn365-commerce-modules-product-collection-product-collection'\n };\nwindow.__bindings__ = window.__bindings__ || {};\nwindow.__bindings__.viewDictionary = {\n ...window.__bindings__.viewDictionary || {},\n ...viewDictionary\n };","/*!\n * Copyright (c) Microsoft Corporation.\n * All rights reserved. See LICENSE in the project root for license information.\n */\n\nimport { IProductsDimensionsAvailabilities } from '@msdyn365-commerce/commerce-entities';\nimport { IPriceComponentResources, ProductComponent } from '@msdyn365-commerce/components';\nimport * as Msdyn365 from '@msdyn365-commerce/core';\nimport { getCatalogId, getUrlSync, ICoreContext } from '@msdyn365-commerce/core';\nimport { ProductPrice, ProductSearchResult } from '@msdyn365-commerce/retail-proxy';\nimport {\n ArrayExtensions,\n DimensionAvailabilitiesForProductSearchResultInput,\n DimensionTypes,\n DimensionSwatchDisplayTypes,\n getDimensionAvailabilitiesForProductSearchResultAction,\n getPriceForProductSearchResult,\n IDimensionsApp,\n ObjectExtensions,\n PriceForProductSearchResultInput,\n validateCatalogId\n} from '@msdyn365-commerce-modules/retail-actions';\nimport {\n Button,\n getTelemetryObject,\n IComponentNodeProps,\n IModuleProps,\n INodeProps,\n ISingleSlideCarouselProps,\n ITelemetryContent,\n NodeTag,\n SingleSlideCarousel\n} from '@msdyn365-commerce-modules/utilities';\nimport classnames from 'classnames';\nimport * as React from 'react';\n\nimport { IProductCollectionData } from './product-collection.data';\nimport { IProductCollectionProps, layout } from './product-collection.props.autogenerated';\n\nexport interface IProductCollectionViewProps extends IProductCollectionProps {\n heading?: React.ReactNode;\n ProductCollectionContainer: IModuleProps;\n SingleSlideCarouselComponentProps: INodeProps;\n GridComponentProps: INodeProps;\n products: IProductComponentViewProps[];\n isCarousel: boolean;\n productPrices?: ProductPrice[];\n seeAllButton?: React.ReactNode;\n}\n\nexport interface IProductComponentViewProps {\n ProductContainer: INodeProps;\n productComponent: React.ReactNode;\n}\nexport interface IProductComponentState {\n products: ProductSearchResult[];\n productsDimensionAvailabilities?: IProductsDimensionsAvailabilities[][];\n}\n\n/**\n * ProductCollection component.\n */\nclass ProductCollection extends React.PureComponent, IProductComponentState> {\n private readonly telemetryContent: ITelemetryContent;\n\n private readonly productPrices: ProductPrice[];\n\n constructor(props: IProductCollectionProps) {\n super(props);\n this.productPrices = [];\n this.state = {\n products: this.props.config.productCollection.products || []\n };\n this.telemetryContent = getTelemetryObject(\n this.props.context.request.telemetryPageName!,\n this.props.friendlyName,\n this.props.telemetry\n );\n }\n\n public async componentDidMount(): Promise {\n if (this.props.config.enableAffiliationBasedPricing && this.props.context.actionContext.requestContext.user.isAuthenticated) {\n await this._getActivePrice();\n }\n }\n\n public render(): JSX.Element | null {\n const { heading, className, shouldDisplaySeeAllButton } = this.props.config;\n const { resources } = this.props;\n const recommendation = this.props.config.productCollection.recommendationListId;\n\n // Initialize state in case if the products were not found during initial module render\n // eslint-disable-next-line @typescript-eslint/no-floating-promises -- Initialize data if not there.\n this.initProductState(this.props.config.productCollection);\n\n const products = this.state.products;\n const isCarousel = this.props.config.layout === layout.carousel;\n const headingLabel = heading ? heading.text : '';\n const headingComponent = heading && (\n \n );\n\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition -- product check for safety.\n const updatedProducts = products?.map((item: ProductSearchResult, index: number) => {\n const getProductData = this._getProduct(item, index);\n return !ObjectExtensions.isNullOrUndefined(getProductData) ? getProductData : undefined;\n });\n\n const productCollectionViewProps = {\n ...this.props,\n heading: headingComponent,\n SingleSlideCarouselComponentProps: {\n tag: SingleSlideCarousel,\n className: '',\n flipperPrevLabel: `${headingLabel} ${resources.flipperPrevious}`,\n flipperNextLabel: `${headingLabel} ${resources.flipperNext}`,\n parentId: this.props.id,\n telemetryContent: this.telemetryContent\n } as IComponentNodeProps,\n ProductCollectionContainer: {\n moduleProps: this.props,\n className: classnames('ms-product-collection', className)\n },\n GridComponentProps: {\n tag: 'ul' as NodeTag,\n className: 'ms-product-collection__items'\n },\n isCarousel,\n\n products:\n ArrayExtensions.hasElements(updatedProducts) &&\n updatedProducts.filter(item => {\n return item !== undefined;\n }),\n productPrices: this.productPrices,\n seeAllButton:\n recommendation && shouldDisplaySeeAllButton && ArrayExtensions.hasElements(updatedProducts)\n ? this._getSeeAllButton(recommendation, headingLabel)\n : undefined\n };\n return this.props.renderView(productCollectionViewProps) as React.ReactElement;\n }\n\n public handleHeadingChange = (event: Msdyn365.ContentEditableEvent) => (this.props.config.heading!.text = event.target.value);\n\n /**\n * Get products dimension availabilities.\n * @param products - Products.\n * @returns Promise.\n */\n private readonly _getProductsDimensionsAvailabilities = async (products: ProductSearchResult[]): Promise => {\n const context = this.props.context as ICoreContext;\n const dimensionsToDisplayOnProductCard = context.app.config.dimensionsInProductCard;\n const dimensionsToDisplayAsSwatch = context.app.config.dimensionsAsSwatchType;\n const validProducts = ArrayExtensions.validValues(products);\n if (\n ArrayExtensions.hasElements(validProducts) &&\n ArrayExtensions.hasElements(dimensionsToDisplayOnProductCard) &&\n !dimensionsToDisplayOnProductCard.includes(DimensionTypes.none) &&\n ArrayExtensions.hasElements(dimensionsToDisplayAsSwatch) &&\n !dimensionsToDisplayAsSwatch.includes(DimensionTypes.none)\n ) {\n const productsDimensionAvailabilities = await getDimensionAvailabilitiesForProductSearchResultAction(\n new DimensionAvailabilitiesForProductSearchResultInput(\n validProducts,\n this.props.context as ICoreContext,\n DimensionSwatchDisplayTypes.productCard\n ),\n this.props.context.actionContext\n );\n\n if (ArrayExtensions.hasElements(productsDimensionAvailabilities)) {\n this.setState({ productsDimensionAvailabilities });\n }\n }\n };\n\n /**\n * Helper method to initialize products state.\n * @param productCollection - List of products.\n */\n private readonly initProductState = async (productCollection: Msdyn365.IProductList) => {\n let products = this.state.products;\n const productCollectionProducts = productCollection.products;\n if (!ArrayExtensions.hasElements(products) && ArrayExtensions.hasElements(productCollectionProducts)) {\n products = productCollectionProducts;\n this.setState({ products });\n } else if (\n ArrayExtensions.hasElements(products) &&\n ArrayExtensions.hasElements(productCollectionProducts) &&\n !ArrayExtensions.equals(products, productCollectionProducts)\n ) {\n products = productCollectionProducts;\n this.setState({ products });\n } else if (productCollectionProducts === undefined && ArrayExtensions.hasElements(this.state.products)) {\n products = [];\n this.setState({ products: products });\n }\n\n if (Msdyn365.msdyn365Commerce.isBrowser && !ArrayExtensions.hasElements(this.state.productsDimensionAvailabilities)) {\n await this._getProductsDimensionsAvailabilities(products);\n }\n };\n\n private readonly _getProduct = (product: ProductSearchResult, index: number): IProductComponentViewProps | null => {\n if (!product || !product.Name) {\n this.props.telemetry.trace('[product-collection] Product or product name is null');\n return null;\n }\n const telemetryContent = getTelemetryObject(\n this.props.context.request.telemetryPageName!,\n this.props.friendlyName,\n this.props.telemetry\n );\n const { imageSettings, allowBackNavigation } = this.props.config;\n const resources = this.props.resources;\n const breaCrumbType = this.props.context.app.config.breadcrumbType;\n const allowBack = allowBackNavigation && (breaCrumbType === 'back' || breaCrumbType === 'categoryAndBack');\n const quickviewSlot =\n this.props.slots && this.props.slots.quickview && this.props.slots.quickview.length > 0 ? this.props.slots.quickview[0] : null;\n const productComparisonButtonSlot = ArrayExtensions.hasElements(this.props.slots.productComparisonButton)\n ? this.props.slots.productComparisonButton[0]\n : null;\n\n const reviewCount = 1;\n const reviewTotalRatings = Number(product.TotalRatings);\n const reviewCountAriaLabelValue =\n reviewTotalRatings > reviewCount ? resources.ratingCountAriaLabel : resources.ratingCountAriaLabelSingleUser;\n const isPriceMinMaxEnabled = this.props.data.featureState.result?.find(\n featureState => featureState.Name === 'Dynamics.AX.Application.RetailSearchPriceRangeFeature'\n );\n const priceResources: IPriceComponentResources = {\n priceRangeSeparator: resources.priceRangeSeparator\n };\n return {\n ProductContainer: {\n tag: 'li' as NodeTag,\n className: 'ms-product-collection__item',\n role: 'listitem',\n key: index\n },\n productComponent: (\n \n ArrayExtensions.hasElements(dimensionAvailability) &&\n dimensionAvailability[0].masterProductId === (product.MasterProductId ?? product.RecordId)\n )}\n />\n )\n };\n };\n\n /**\n * Get the active price for products.\n */\n private readonly _getActivePrice = async (): Promise => {\n const productsList = this.state.products;\n const products = await getPriceForProductSearchResult(\n new PriceForProductSearchResultInput(productsList),\n this.props.context.actionContext\n );\n if (Msdyn365.msdyn365Commerce.isBrowser) {\n await this._getProductsDimensionsAvailabilities(products);\n }\n\n this.setState({ products });\n };\n\n /**\n * Get the see all button.\n * @param recommendation - Recommendation.\n * @param headingLabel - Heading label.\n * @returns IProductComponentSeeAllViewProps - Product component see all view props.\n */\n private readonly _getSeeAllButton = (recommendation: string, headingLabel: string): React.ReactNode => {\n if (!Msdyn365.msdyn365Commerce.isBrowser) {\n return null;\n }\n\n const catalogId = getCatalogId(this.props.context.request);\n validateCatalogId(catalogId);\n const searchPageLink = getUrlSync('search', this.props.context.actionContext);\n if (!searchPageLink) {\n return null;\n }\n\n const url = new URL(searchPageLink, window.location.href);\n url.searchParams.set('recommendation', recommendation);\n url.searchParams.set('title', headingLabel);\n url.searchParams.set('catalogid', `${catalogId}`);\n\n return (\n \n {this.props.resources.seeAllButtonText}\n \n );\n };\n}\n\nexport default ProductCollection;\n","/*!\n * Copyright (c) Microsoft Corporation.\n * All rights reserved. See LICENSE in the project root for license information.\n */\n\nimport { INodeProps, Module, Node } from '@msdyn365-commerce-modules/utilities';\nimport * as React from 'react';\n\nimport { IProductCollectionViewProps, IProductComponentViewProps } from './product-collection';\n\nconst ProductCollectionView: React.FC = props => {\n const {\n heading,\n ProductCollectionContainer,\n products,\n SingleSlideCarouselComponentProps,\n GridComponentProps,\n isCarousel,\n seeAllButton\n } = props;\n\n if (products) {\n return (\n \n {heading}\n {seeAllButton}\n {isCarousel ? _renderCarousel(SingleSlideCarouselComponentProps, products) : _renderGrid(GridComponentProps, products)}\n \n );\n }\n props.context.telemetry.error('Product collection content is empty, module wont render.');\n return null;\n};\n\nconst _renderCarousel = (carouselContainer: INodeProps, items: IProductComponentViewProps[]): JSX.Element => {\n return {items && items.map(_renderProduct)};\n};\n\nconst _renderGrid = (gridContainer: INodeProps, items: IProductComponentViewProps[]): JSX.Element => {\n return {items && items.map(_renderProduct)};\n};\n\nconst _renderProduct = (product: IProductComponentViewProps): JSX.Element => {\n const { ProductContainer, productComponent } = product;\n\n return {productComponent};\n};\n\nexport default ProductCollectionView;\n","module.exports = React;","module.exports = ReactDOM;"],"names":["binding","modules","dataActions","c","require","$type","da","name","path","runOn","iNM","ns","n","p","pdp","md","registerSanitizedActionPath","sanitizedActionPath","dataAction","default","Error","prototype","RegistrationId","id","window","__bindings__","_objectSpread","viewDictionary","cn","ProductCollection","React","constructor","props","super","handleHeadingChange","event","this","config","heading","text","target","value","_getProductsDimensionsAvailabilities","async","context","dimensionsToDisplayOnProductCard","app","dimensionsInProductCard","dimensionsToDisplayAsSwatch","dimensionsAsSwatchType","validProducts","ArrayExtensions","products","includes","DimensionTypes","productsDimensionAvailabilities","getDimensionAvailabilitiesForProductSearchResultAction","DimensionAvailabilitiesForProductSearchResultInput","DimensionSwatchDisplayTypes","actionContext","setState","initProductState","state","productCollectionProducts","productCollection","undefined","Msdyn365","_getProduct","product","index","_this$props$data$feat","_this$state$productsD","Name","telemetry","trace","telemetryContent","getTelemetryObject","request","telemetryPageName","friendlyName","imageSettings","allowBackNavigation","resources","breaCrumbType","breadcrumbType","allowBack","quickviewSlot","slots","quickview","length","productComparisonButtonSlot","productComparisonButton","reviewCountAriaLabelValue","Number","TotalRatings","ratingCountAriaLabel","ratingCountAriaLabelSingleUser","isPriceMinMaxEnabled","data","featureState","result","find","priceResources","priceRangeSeparator","ProductContainer","tag","className","role","key","productComponent","ProductComponent","freePriceText","priceFree","originalPriceText","currentPriceText","ratingAriaLabel","typeName","quickViewButton","IsEnabled","dimensionAvailabilities","dimensionAvailability","_product$MasterProduc","masterProductId","MasterProductId","RecordId","_getActivePrice","productsList","getPriceForProductSearchResult","PriceForProductSearchResultInput","_getSeeAllButton","recommendation","headingLabel","catalogId","getCatalogId","validateCatalogId","searchPageLink","getUrlSync","url","URL","location","href","searchParams","set","Button","title","seeAllButtonText","productPrices","enableAffiliationBasedPricing","requestContext","user","isAuthenticated","render","shouldDisplaySeeAllButton","recommendationListId","isCarousel","layout","headingComponent","editProps","onEdit","updatedProducts","map","item","getProductData","ObjectExtensions","productCollectionViewProps","SingleSlideCarouselComponentProps","SingleSlideCarousel","flipperPrevLabel","flipperPrevious","flipperNextLabel","flipperNext","parentId","ProductCollectionContainer","moduleProps","classnames","GridComponentProps","filter","seeAllButton","renderView","_renderCarousel","carouselContainer","items","Node","Object","assign","_renderProduct","_renderGrid","gridContainer","Module","error","module","exports","ReactDOM"],"sourceRoot":""}