{"version":3,"file":"static/js/c5e100bebb5b9bd8104f.bundle.js","mappings":"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","sources":["webpack://sgi-bookstore/./src/themes/sgi-theme/views/product-collection.view.tsx?25be","webpack://sgi-bookstore/./lib/product-collection/module-registration.js?36d3","webpack://sgi-bookstore/./src/modules/product-collection/product-collection.tsx?4008","webpack://sgi-bookstore/./src/modules/product-collection/product-collection.view.tsx?5d36","webpack://sgi-bookstore/external var \"React\"?0d3b","webpack://sgi-bookstore/external var \"ReactDOM\"?853b"],"sourcesContent":["/*--------------------------------------------------------------\r\n * Copyright (c) Microsoft Corporation. All rights reserved.\r\n * See License.txt in the project root for license information.\r\n *--------------------------------------------------------------*/\r\n\r\nimport { INodeProps, Module, Node } from '@msdyn365-commerce-modules/utilities';\r\nimport * as React from 'react';\r\nimport { IProductCollectionProps } from '../definition-extensions/product-collection.ext.props.autogenerated';\r\nimport {\r\n IProductCollectionViewProps,\r\n IProductComponentViewProps\r\n} from '@msdyn365-commerce-modules/product-collection/src/modules/product-collection/./product-collection';\r\n\r\nconst ProductCollectionView: React.FC> = props => {\r\n const { heading, ProductCollectionContainer, products, SingleSlideCarouselComponentProps, GridComponentProps, isCarousel } = props;\r\n const { productCardLayout } = props.config;\r\n if (products) {\r\n return (\r\n \r\n {heading}\r\n {isCarousel ? _renderCarousel(SingleSlideCarouselComponentProps, products) : _renderGrid(GridComponentProps, products)}\r\n \r\n );\r\n }\r\n props.context.telemetry.error('Product collection content is empty, module wont render.');\r\n return null;\r\n};\r\n\r\nconst _renderCarousel = (carouselContainer: INodeProps, items: IProductComponentViewProps[]): JSX.Element => {\r\n return {items && items.map(_renderProduct)};\r\n};\r\n\r\nconst _renderGrid = (gridContainer: INodeProps, items: IProductComponentViewProps[]): JSX.Element => {\r\n return {items && items.map(_renderProduct)};\r\n};\r\n\r\nconst _renderProduct = (product: IProductComponentViewProps): JSX.Element => {\r\n const { ProductContainer, productComponent } = product;\r\n\r\n return {productComponent};\r\n};\r\n\r\nexport default ProductCollectionView;\r\n","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['__local__|__local__|themes|sgi-theme|views|product-collection'] = {\n c: () => require('partner/themes/sgi-theme/views/product-collection.view.tsx'),\n cn: '__local__-__local__-product-collection'\n };\nviewDictionary['@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":["_renderCarousel","carouselContainer","items","React","Node","Object","assign","map","_renderProduct","_renderGrid","gridContainer","product","ProductContainer","productComponent","props","heading","ProductCollectionContainer","products","SingleSlideCarouselComponentProps","GridComponentProps","isCarousel","productCardLayout","config","Module","context","telemetry","error","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","constructor","super","handleHeadingChange","event","this","text","target","value","_getProductsDimensionsAvailabilities","async","dimensionsToDisplayOnProductCard","app","dimensionsInProductCard","dimensionsToDisplayAsSwatch","dimensionsAsSwatchType","validProducts","ArrayExtensions","validValues","hasElements","includes","DimensionTypes","none","productsDimensionAvailabilities","getDimensionAvailabilitiesForProductSearchResultAction","DimensionAvailabilitiesForProductSearchResultInput","DimensionSwatchDisplayTypes","productCard","actionContext","setState","initProductState","state","productCollectionProducts","productCollection","equals","undefined","Msdyn365","isBrowser","_getProduct","index","_this$props$data$feat","_this$state$productsD","Name","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","tag","className","role","key","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","layout","headingComponent","editProps","onEdit","updatedProducts","item","getProductData","ObjectExtensions","isNullOrUndefined","productCollectionViewProps","SingleSlideCarousel","flipperPrevLabel","flipperPrevious","flipperNextLabel","flipperNext","parentId","moduleProps","classnames","filter","seeAllButton","renderView","module","exports","ReactDOM"],"sourceRoot":""}