{"version":3,"file":"static/js/6f9e34d8e9dc6c9aa5a3.bundle.js","mappings":"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","sources":["webpack://Msdyn365.Commerce.Online/./lib/media-gallery/module-registration.js?47e5","webpack://Msdyn365.Commerce.Online/./src/modules/media-gallery/utils/get-valid-product-images.ts?a364","webpack://Msdyn365.Commerce.Online/./src/modules/media-gallery/media-gallery.tsx?24d7","webpack://Msdyn365.Commerce.Online/./src/modules/media-gallery/media-gallery.view.tsx?5061","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['media-gallery'] = {\n c: () => require('@msdyn365-commerce-modules/media-gallery/dist/lib/modules/media-gallery/media-gallery'),\n $type: 'contentModule',\n da: [{name:'mediaLocations', path:'@msdyn365-commerce-modules/retail-actions/dist/lib/get-media-locations-by-id', runOn: 0},{name:'mediaLocationsForSelectedVariant', path:'@msdyn365-commerce-modules/retail-actions/dist/lib/get-media-locations-for-selected-variant', runOn: 0},{name:'product', path:'@msdyn365-commerce-modules/retail-actions/dist/lib/get-selected-variant', runOn: 0}],\n \n iNM: true,\n ns: '@msdyn365-commerce-modules',\n n: 'media-gallery',\n p: 'media-gallery',\n \n pdp: '',\n \n \n md: 'node_modules/@msdyn365-commerce-modules/media-gallery/dist/lib/modules/media-gallery'\n });\n \n\n {\n const sanitizedActionPath = '@msdyn365-commerce-modules/retail-actions/dist/lib/get-media-locations-by-id';\n let dataAction = require('@msdyn365-commerce-modules/retail-actions/dist/lib/get-media-locations-by-id');\n registerSanitizedActionPath(sanitizedActionPath, dataAction);\n }\n \n\n {\n const sanitizedActionPath = '@msdyn365-commerce-modules/retail-actions/dist/lib/get-media-locations-for-selected-variant';\n let dataAction = require('@msdyn365-commerce-modules/retail-actions/dist/lib/get-media-locations-for-selected-variant');\n registerSanitizedActionPath(sanitizedActionPath, dataAction);\n }\n \n\n {\n const sanitizedActionPath = '@msdyn365-commerce-modules/retail-actions/dist/lib/get-selected-variant';\n let dataAction = require('@msdyn365-commerce-modules/retail-actions/dist/lib/get-selected-variant');\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|media-gallery|modules|media-gallery|media-gallery'] = {\n c: () => require('@msdyn365-commerce-modules/media-gallery/dist/lib/modules/media-gallery/media-gallery.view.js'),\n cn: '@msdyn365-commerce-modules-media-gallery-media-gallery'\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 { getCatalogId, IActionContext, IImageData, IImageSettings } from '@msdyn365-commerce/core';\nimport { MediaLocation, SimpleProduct } from '@msdyn365-commerce/retail-proxy';\nimport { getMediaLocationsForSelectedVariant, MediaLocationsForSelectedVariantInput } from '@msdyn365-commerce-modules/retail-actions';\n\nasync function validateMediaLocationAsync(mediaLocation: MediaLocation): Promise<[IImageData, boolean]> {\n const imageData: IImageData = {\n src: mediaLocation.Uri || '',\n altText: mediaLocation.AltText || ''\n };\n if (mediaLocation.IsApplicableForChildEntities) {\n imageData.additionalProperties = { isApplicableForChildEntities: 'true' };\n }\n\n if (imageData.src === '') {\n return [imageData, false];\n }\n\n return new Promise<[IImageData, boolean]>(resolve => {\n try {\n const http = new XMLHttpRequest();\n http.open('HEAD', imageData.src!, true);\n\n http.addEventListener('load', () => {\n resolve([imageData, http.status === 200 || http.status === 201]);\n });\n\n http.addEventListener('error', () => {\n resolve([imageData, false]);\n });\n\n http.send();\n } catch {\n resolve([imageData, false]);\n }\n });\n}\n\nexport async function getValidProductImages(\n productId: number,\n channelId: number,\n actionContext: IActionContext,\n imageSettings: IImageSettings,\n selectedProduct?: SimpleProduct\n): Promise {\n const catalogId = getCatalogId(actionContext.requestContext);\n const actionInput = new MediaLocationsForSelectedVariantInput(productId, channelId, selectedProduct, catalogId);\n\n return getMediaLocationsForSelectedVariant(actionInput, actionContext)\n .then(mediaLocations => {\n if (mediaLocations) {\n return Promise.all(mediaLocations.map(mediaLocation => validateMediaLocationAsync(mediaLocation))).then(pairs => {\n return pairs.filter(pair => pair[1]).map(pair => pair[0]);\n });\n }\n\n return [];\n })\n .catch(error => {\n actionContext.telemetry.exception(error);\n actionContext.telemetry.debug('Unable to get Media Locations for Selected Variant');\n return [];\n });\n}\n\nexport async function validateProductImages(\n mediaLocations: MediaLocation[],\n actionContext: IActionContext,\n imageSettings: IImageSettings\n): Promise {\n return Promise.all(mediaLocations.map(mediaLocation => validateMediaLocationAsync(mediaLocation)))\n .then(pairs => {\n return pairs.filter(pair => pair[1]).map(pair => pair[0]);\n })\n .catch(error => {\n actionContext.telemetry.exception(error);\n actionContext.telemetry.debug('Unable to validate product images');\n return [];\n });\n}\n","/*!\n * Copyright (c) Microsoft Corporation.\n * All rights reserved. See LICENSE in the project root for license information.\n */\n\nimport { Carousel, ICarouselProps } from '@msdyn365-commerce/components';\nimport { IImageData, IImageSettings, Image } from '@msdyn365-commerce/core';\nimport { MediaLocation, SimpleProduct } from '@msdyn365-commerce/retail-proxy';\nimport { ArrayExtensions, getFallbackImageUrl, ObjectExtensions } from '@msdyn365-commerce-modules/retail-actions';\nimport {\n defaultDataScale,\n IComponentNodeProps,\n ImagefullView,\n IModalViewProps,\n IModuleProps,\n inlineZoomImageOnHover,\n inlineZoomImageOnMouseMove,\n inlineZoomImageOnMouseOut,\n inlineZoomInitClick,\n INodeProps,\n ISingleSlideCarouselProps,\n isMobile,\n KeyCodes,\n NodeTag,\n onContainerZoomInit,\n onMouseMoveLensContainer,\n onMouseOutLensContainer,\n onMouseOverImageContainer,\n removeContainerZoomStyle,\n removeInlineZoomStyle,\n SingleSlideCarousel,\n VariantType\n} from '@msdyn365-commerce-modules/utilities';\nimport classnames from 'classnames';\nimport { reaction } from 'mobx';\nimport * as React from 'react';\n\nimport { IMediaGalleryData } from './media-gallery.data';\nimport { imageSource, imageZoom, IMediaGalleryProps, thumbnailsOrientation } from './media-gallery.props.autogenerated';\nimport { getValidProductImages, validateProductImages } from './utils';\n\n/**\n * IMediaGalleryState Interface.\n */\nexport interface IMediaGalleryState {\n animating: boolean;\n activeIndex: number;\n isImageZoomed: boolean;\n modalIsOpen: boolean;\n lastUpdate?: number;\n isMobileImageZoomed?: boolean;\n mediaGalleryItems?: IImageData[];\n isInitialLoad?: boolean;\n shouldUseOptimizedImage?: boolean;\n}\n\n/**\n * IMediaGalleryThumbnailsViewProps Interface.\n */\nexport interface IMediaGalleryThumbnailsViewProps {\n ThumbnailsContainerProps: INodeProps;\n SingleSlideCarouselComponentProps: INodeProps;\n items?: IMediaGalleryThumbnailItemViewProps[];\n}\n\n/**\n * IMediaGalleryThumbnailItemViewProps Interface.\n */\nexport interface IMediaGalleryThumbnailItemViewProps {\n ThumbnailItemContainerProps: INodeProps;\n Picture: React.ReactElement;\n}\n\n/**\n * IMediaGalleryViewProps Interface.\n */\nexport interface IMediaGalleryViewProps extends IMediaGalleryProps {\n state: IMediaGalleryState;\n MediaGallery: IModuleProps;\n CarouselProps: INodeProps;\n Thumbnails: IMediaGalleryThumbnailsViewProps;\n Modal?: React.ReactElement | null;\n callbackToggle?(): void;\n callbackThumbnailClick?(index: number): void;\n callbackThumbnailKeyDown?(index: number): void;\n}\n\n/**\n * Props for carousel.\n */\ninterface IMediaGalleryCarouselItems {\n items: ItemType[];\n keys: (string | undefined)[];\n}\n\n/**\n * Media gallery component.\n */\nclass MediaGallery extends React.Component, IMediaGalleryState> {\n private readonly _inlineZoomDivRef: Map = new Map();\n\n private readonly fullScreenOverlayButtonRef: React.RefObject = React.createRef();\n\n private mediaGalleryImages: IImageData[] = [];\n\n private fallbackImage?: string;\n\n private readonly defaultGalleryImageSettings: IImageSettings = {\n viewports: {\n xs: { q: 'w=767&h=767&m=8', w: 0, h: 0 },\n sm: { q: 'w=600&h=600&m=8', w: 0, h: 0 },\n md: { q: 'w=600&h=772&m=8', w: 0, h: 0 },\n lg: { q: 'h=772&m=8', w: 0, h: 0 }\n },\n lazyload: true,\n cropFocalRegion: true\n };\n\n private readonly defaultThumbnailImageSettings: IImageSettings = {\n viewports: {\n xs: { q: 'w=100&m=8', w: 100, h: 0 },\n lg: { q: 'w=100&m=8', w: 100, h: 0 }\n },\n lazyload: true,\n cropFocalRegion: true\n };\n\n private readonly _zoomedImageSettings: IImageSettings;\n\n public constructor(props: IMediaGalleryProps) {\n super(props);\n this._toggleModal = this._toggleModal.bind(this);\n this.state = {\n activeIndex: 0,\n animating: false,\n isImageZoomed: false,\n modalIsOpen: false,\n isInitialLoad: true,\n shouldUseOptimizedImage: !!this.props.config.skipImageValidation\n };\n\n this._zoomedImageSettings =\n props.config.zoomedImageSettings ?? props.config.galleryImageSettings ?? this.defaultGalleryImageSettings;\n\n this._onImageMouseOut = this._onImageMouseOut.bind(this);\n this._inlineZoomImageOnHover = this._inlineZoomImageOnHover.bind(this);\n this._onInlineImageClick = this._onInlineImageClick.bind(this);\n this._onContainerZoomImageClick = this._onContainerZoomImageClick.bind(this);\n this._onMouseOutLensContainer = this._onMouseOutLensContainer.bind(this);\n }\n\n public isMobile(): boolean {\n const size = isMobile({ variant: VariantType.Viewport, context: this.props.context.request });\n return size === 'xs';\n }\n\n public async componentDidMount(): Promise {\n const source = this.props.config.imageSource ?? imageSource.pageContext;\n const shouldUpdateOnPartialDimensionSelection = this.props.config.shouldUpdateOnPartialDimensionSelection;\n this._setRenderType();\n if (source === imageSource.pageContext) {\n if (this.state.mediaGalleryItems === undefined && this.props.data.mediaLocationsForSelectedVariant.result) {\n const images = await validateProductImages(\n this.props.data.mediaLocationsForSelectedVariant.result,\n this.props.context.actionContext,\n this.props.config.thumbnailImageSettings ?? this.defaultThumbnailImageSettings\n );\n this._setImages(images);\n } else if (this.state.mediaGalleryItems === undefined && this.props.data.product.result) {\n const product = this.props.data.product.result;\n const images = await getValidProductImages(\n product.RecordId,\n +this.props.context.request.apiSettings.channelId,\n this.props.context.actionContext,\n this.props.config.thumbnailImageSettings ?? this.defaultThumbnailImageSettings,\n product.productVariant\n );\n\n this._setImages(images);\n } else {\n this._setImages([]);\n }\n\n reaction(\n () => {\n const product = this.props.data.product.result;\n if (!product) {\n return null;\n }\n\n if (!shouldUpdateOnPartialDimensionSelection || ObjectExtensions.isNullOrUndefined(product.productVariant?.RecordId)) {\n return `${product.RecordId}`;\n }\n\n return `${product.RecordId}-${product.productVariant!.RecordId}`;\n },\n async () => {\n const product = this.props.data.product.result;\n if (product) {\n const images = await getValidProductImages(\n product.RecordId,\n +this.props.context.request.apiSettings.channelId,\n this.props.context.actionContext,\n this.props.config.thumbnailImageSettings ?? this.defaultThumbnailImageSettings,\n shouldUpdateOnPartialDimensionSelection ? product.productVariant : undefined\n );\n this._setImages(images);\n } else {\n this._setImages([]);\n }\n }\n );\n }\n\n if (source === imageSource.productId && this.props.data.mediaLocations.result) {\n const images = await validateProductImages(\n this.props.data.mediaLocations.result,\n this.props.context.actionContext,\n this.props.config.thumbnailImageSettings ?? this.defaultThumbnailImageSettings\n );\n this._setImages(images);\n }\n }\n\n public shouldComponentUpdate(nextProps: IMediaGalleryProps, nextState: IMediaGalleryState): boolean {\n if (this.state === nextState && this.props.data === nextProps.data) {\n return false;\n }\n return true;\n }\n\n public render(): JSX.Element {\n const { id, config, resources } = this.props;\n\n const { className, showPaginationTooltip } = config;\n\n const isVertical: boolean = config.thumbnailsOrientation === thumbnailsOrientation.vertical;\n // eslint-disable-next-line @typescript-eslint/prefer-nullish-coalescing -- || is required.\n const isFullscreenAllowed: boolean = this.isMobile() || config.allowFullScreen || false;\n const zoomViewMode: string =\n config.imageZoom === imageZoom.inline ? imageZoom.inline : config.imageZoom === imageZoom.container ? imageZoom.container : '';\n const source = this.props.config.imageSource ?? imageSource.pageContext;\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access -- Site level config can be of any type.\n const emptyPlaceHolderImage = this.props.context.app.config?.placeholderImageName as string;\n if (this.props.data.product.result) {\n this.fallbackImage = getFallbackImageUrl(this.props.data.product.result.ItemId, this.props.context.request.apiSettings);\n }\n if (emptyPlaceHolderImage && this.fallbackImage) {\n this.fallbackImage = `${this.fallbackImage},${emptyPlaceHolderImage}`;\n }\n if (this.props.config.skipImageValidation && !this.state.mediaGalleryItems && this.state.isInitialLoad) {\n let images: IImageData[] = [];\n let mediaLocations: MediaLocation[] = [];\n if (source === imageSource.pageContext && this.props.data.mediaLocationsForSelectedVariant.result) {\n mediaLocations = this.props.data.mediaLocationsForSelectedVariant.result;\n } else if (source === imageSource.productId && this.props.data.mediaLocations.result) {\n mediaLocations = this.props.data.mediaLocations.result;\n }\n images = mediaLocations.map(mediaLocation => {\n return {\n src: mediaLocation.Uri ?? '',\n altText: mediaLocation.AltText ?? ''\n };\n });\n const curatedImages = this.props.config.images ?? [];\n this.mediaGalleryImages = [...this._filterMasterImageFromVariant(images), ...curatedImages];\n }\n const mediaGalleryCarouselItems = this._getMediaGalleryItems(isFullscreenAllowed, zoomViewMode);\n const mediaGalleryThumbnailCarouselItems = this._getMediaGalleryThumbnailItems();\n const viewProps: IMediaGalleryViewProps = {\n ...(this.props as IMediaGalleryProps),\n state: this.state,\n MediaGallery: {\n moduleProps: this.props,\n className: classnames(`ms-media-gallery ${isVertical ? 'vertical' : ''}`, className)\n },\n Modal: isFullscreenAllowed ? this.imageModalSlider(zoomViewMode) : null,\n callbackToggle: this.openModalDialog,\n callbackThumbnailClick: this._generateOnThumbnailClick,\n callbackThumbnailKeyDown: this._generateOnThumbnailKeyDown,\n CarouselProps: {\n tag: Carousel,\n className: 'ms-media-gallery__carousel',\n items: mediaGalleryCarouselItems.items,\n activeIndex: this.state.activeIndex,\n next: this.next,\n previous: this.previous,\n interval: false,\n directionTextPrev: resources.previousScreenshotFlipperText,\n directionTextNext: resources.nextScreenshotFlipperText,\n onIndicatorsClickHandler: this.goToIndex,\n showPaginationTooltip: showPaginationTooltip === true,\n indicatorAriaText: resources.ariaLabelForSlide,\n handleOnExited: this.onExited,\n handleOnExiting: this.onExiting,\n key: mediaGalleryCarouselItems.keys\n } as IComponentNodeProps,\n Thumbnails: {\n ThumbnailsContainerProps: { className: 'ms-media-gallery__thumbnails-container' },\n SingleSlideCarouselComponentProps: {\n tag: SingleSlideCarousel,\n className: 'ms-media-gallery__thumbnails',\n vertical: isVertical,\n flipperPrevLabel: resources.previousScreenshotFlipperText,\n flipperNextLabel: resources.nextScreenshotFlipperText,\n parentId: id,\n useTabList: true,\n key: JSON.stringify(mediaGalleryThumbnailCarouselItems.keys)\n } as IComponentNodeProps,\n items: mediaGalleryThumbnailCarouselItems.items\n }\n };\n\n return this.props.renderView(viewProps) as React.ReactElement;\n }\n\n /**\n * Zoomed out image on previous/next click.\n */\n public updateZoomedInImage(): void {\n this.setState({ isImageZoomed: false });\n }\n\n private readonly onExiting = () => {\n this.setState({ animating: true });\n };\n\n private readonly onExited = () => {\n this.setState({ animating: false });\n };\n\n /**\n * On click next in carousel.\n */\n private readonly next = (): void => {\n removeInlineZoomStyle();\n if (this.isLastItem() === undefined) {\n return;\n }\n\n const nextIndex = this.isLastItem() ? 0 : this.state.activeIndex + 1;\n this.goToIndex(nextIndex);\n\n this.updateZoomedInImage();\n };\n\n /**\n * On click previous in carousel.\n */\n private readonly previous = (): void => {\n removeInlineZoomStyle();\n const images = this.state.mediaGalleryItems;\n const nextIndex = this.isFirstItem() ? (images ? images.length - 1 : 0) : this.state.activeIndex - 1;\n this.goToIndex(nextIndex);\n this.updateZoomedInImage();\n };\n\n private readonly goToIndex = (index: number): void => {\n this.setState({ activeIndex: index });\n };\n\n private _getMediaGalleryThumbnailItems(): IMediaGalleryCarouselItems {\n const mediaGalleryItems = this.state.mediaGalleryItems ?? this.mediaGalleryImages;\n const thumbnailImageSettings = this.props.config.thumbnailImageSettings;\n if (thumbnailImageSettings) {\n thumbnailImageSettings.cropFocalRegion = true;\n }\n\n const hasMediaGalleryItems = ArrayExtensions.hasElements(mediaGalleryItems);\n\n if (!hasMediaGalleryItems) {\n if (this.state.lastUpdate) {\n const defaultKey = 0;\n return {\n items: [this._getEmptyThumbnailItem(thumbnailImageSettings, defaultKey, this.state.activeIndex)],\n keys: ['empty']\n };\n }\n return { items: [], keys: [] };\n }\n\n return {\n items: [\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-type-assertion\n ...mediaGalleryItems!.map((item: IImageData, index: number) =>\n this._getThumbnailItem(\n item,\n thumbnailImageSettings ?? this.defaultThumbnailImageSettings,\n index,\n this.state.activeIndex\n )\n )\n ],\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-type-assertion\n keys: [...mediaGalleryItems!.map(item => item.src)]\n };\n }\n\n private _getMediaGalleryItems(isFullscreenAllowed: boolean, zoomViewMode: string): IMediaGalleryCarouselItems {\n const mediaGalleryItems = this.state.mediaGalleryItems ?? this.mediaGalleryImages;\n const galleryImageSettings = this.props.config.galleryImageSettings;\n if (galleryImageSettings) {\n galleryImageSettings.cropFocalRegion = true;\n }\n\n const zoomView = isFullscreenAllowed ? 'fullscreen' : zoomViewMode;\n\n const hasMediaGalleryItems = ArrayExtensions.hasElements(mediaGalleryItems);\n\n if (!hasMediaGalleryItems) {\n if (this.state.lastUpdate) {\n return { items: [this._renderEmptyImage(galleryImageSettings)], keys: ['empty'] };\n }\n return { items: [], keys: [] };\n }\n\n return {\n items: [\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-type-assertion\n ...mediaGalleryItems!.map((item: IImageData, index: number) =>\n this._renderCarouselItemImageView(zoomView, item, galleryImageSettings ?? this.defaultGalleryImageSettings, index)\n )\n ],\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-type-assertion\n keys: [...mediaGalleryItems!.map(item => item.src)]\n };\n }\n\n private _setImages(images?: IImageData[]): void {\n const curatedImage = this.props.config.images || [];\n const imagesToSet = this._filterMasterImageFromVariant(images);\n\n this.setState({\n mediaGalleryItems: [...imagesToSet, ...curatedImage],\n activeIndex: 0,\n lastUpdate: Date.now(),\n shouldUseOptimizedImage: false\n });\n }\n\n private _setRenderType(): void {\n this.setState({\n isInitialLoad: false\n });\n }\n\n private _renderCarouselItemImageView(\n zoomView: string,\n image: IImageData,\n imageSettings: IImageSettings,\n index: number,\n isInPopup: boolean = false\n ): React.ReactNode {\n if (this.isMobile()) {\n if (isInPopup) {\n return this._renderImageInContainerOnZoom(image, this._zoomedImageSettings, index);\n }\n return this._renderImageFullScreenOnZoom(image, imageSettings, index);\n }\n\n switch (zoomView) {\n case 'container': {\n return this._renderImageInContainerOnZoom(image, this._zoomedImageSettings, index);\n }\n case 'inline': {\n return this._renderImageInlineOnZoom(image, this._zoomedImageSettings, index);\n }\n case 'fullscreen': {\n return this._renderImageFullScreenOnZoom(image, imageSettings, index);\n }\n\n // No default\n }\n return <>{this._getCarouselItem(image, imageSettings, index, isInPopup)};\n }\n\n private _filterMasterImageFromVariant(images?: IImageData[]): IImageData[] {\n const shouldHidePrimaryImages = this.props.config.shouldHideMasterProductImagesForVariant ?? true;\n let variantImages = images ?? [];\n const isVariantProduct =\n !ObjectExtensions.isNullOrUndefined(this.props.data.product.result?.MasterProductId) ||\n !ObjectExtensions.isNullOrUndefined(this.props.data.product.result?.productVariant);\n const itemId = this.props.data.product.result?.ItemId;\n if (shouldHidePrimaryImages && isVariantProduct && itemId) {\n variantImages = variantImages.filter(item => {\n const isApplicableForChildEntities = item.additionalProperties?.isApplicableForChildEntities;\n return !isApplicableForChildEntities;\n });\n if (!ArrayExtensions.hasElements(variantImages)) {\n variantImages = images ?? [];\n }\n }\n return variantImages;\n }\n\n private readonly _getCarouselItem = (\n image: IImageData,\n imageSettings: IImageSettings,\n index: number,\n isInPopup: boolean = false\n ): React.ReactNode => (\n \n );\n\n private readonly _getThumbnailItem = (\n image: IImageData,\n imageSettings: IImageSettings,\n index: number,\n modifiedActiveIndex: number\n ): IMediaGalleryThumbnailItemViewProps => {\n const classes = classnames(\n 'ms-media-gallery__thumbnail-item',\n modifiedActiveIndex === index ? 'ms-media-gallery__thumbnail-item-active' : ''\n );\n\n return {\n ThumbnailItemContainerProps: {\n tag: 'li' as NodeTag,\n className: classes,\n role: 'tab',\n tabIndex: 0,\n key: index,\n 'aria-label': image.altText,\n 'aria-selected': modifiedActiveIndex === index,\n onClick: this._generateOnThumbnailClick(index),\n onKeyDown: this._generateOnThumbnailKeyDown(index)\n },\n Picture: (\n \n )\n };\n };\n\n /**\n * Ref Handler.\n * @param index -Remove item click function.\n * @returns Set inline zoom.\n */\n private readonly _refHandler = (index: number) => (divRef: HTMLDivElement) => {\n this._inlineZoomDivRef.set(index, divRef);\n };\n\n private readonly _generateOnThumbnailKeyDown = (index: number) => {\n return (event: React.KeyboardEvent) => {\n if (event.which === KeyCodes.Enter || event.which === KeyCodes.Space) {\n event.preventDefault();\n\n this.goToIndex(index);\n }\n };\n };\n\n private readonly _generateOnThumbnailClick = (index: number) => {\n return (event: React.MouseEvent) => {\n event.preventDefault();\n\n this.goToIndex(index);\n };\n };\n\n private _renderImageInlineOnZoom(image: IImageData, imageSettings: IImageSettings, index: number): React.ReactNode {\n return (\n \n \n \n \n );\n }\n\n private _inlineZoomImageOnHover(event: React.MouseEvent): void {\n inlineZoomImageOnHover(event, this.props.config.dataScale ?? String(defaultDataScale));\n }\n\n private _handleMobileViewZoomedImageClick(event: React.MouseEvent) {\n const target = this.state.shouldUseOptimizedImage ? (event.target as HTMLImageElement) : event.currentTarget;\n const mobileZoomedInImageClassName = 'msc-mobile-zoomed-in';\n if (!this.state.isMobileImageZoomed) {\n const bounds = target.getBoundingClientRect();\n const dataScale = Number(this.props.config.dataScale ?? defaultDataScale);\n\n const positionX = event.clientX - bounds.left;\n const positionY = event.clientY - bounds.top;\n const scaledPositionX = positionX * dataScale;\n const scaledPositionY = positionY * dataScale;\n\n target.style.transform = `scale(${dataScale})`;\n target.classList.add(mobileZoomedInImageClassName);\n target.parentElement!.style.overflow = 'auto';\n target.parentElement!.scrollTo(scaledPositionX - positionX, scaledPositionY - positionY);\n this.setState({\n isMobileImageZoomed: true\n });\n } else {\n target.style.transform = '';\n target.classList.remove(mobileZoomedInImageClassName);\n target.parentElement!.style.overflow = '';\n this.setState({\n isMobileImageZoomed: false\n });\n }\n }\n\n private _onInlineImageClick(event: React.MouseEvent): void {\n if (window.innerWidth <= 768) {\n // $msv-breakpoint-m\n this._handleMobileViewZoomedImageClick(event);\n return;\n }\n inlineZoomInitClick(event, this.props.config.dataScale ?? String(defaultDataScale));\n this.setState({\n isImageZoomed: true\n });\n }\n\n private _onImageMouseOut(event: React.MouseEvent): void {\n inlineZoomImageOnMouseOut(event);\n this.setState({\n isImageZoomed: false\n });\n }\n\n private _onContainerZoomImageClick(event: React.MouseEvent): void {\n if (window.innerWidth <= 768) {\n // $msv-breakpoint-m\n this._handleMobileViewZoomedImageClick(event);\n return;\n }\n\n onContainerZoomInit(event);\n\n this.setState({\n isImageZoomed: true\n });\n }\n\n private _onMouseOutLensContainer(event: React.MouseEvent): void {\n onMouseOutLensContainer(event);\n\n this.setState({\n isImageZoomed: false\n });\n }\n\n private _renderImageInContainerOnZoom(image: IImageData, imageSettings: IImageSettings, index: number): React.ReactNode {\n return (\n
\n \n \n
\n );\n }\n\n private _renderImageFullScreenOnZoom(image: IImageData, imageSettings: IImageSettings, index: number): React.ReactNode {\n return (\n
\n \n
\n {}\n \n
\n
\n );\n }\n\n private _mapProductToImageData(product: SimpleProduct): IImageData {\n return {\n src: product.PrimaryImageUrl ?? ''\n };\n }\n\n private _renderEmptyImage(imageSettings: IImageSettings | undefined): React.ReactNode {\n return (\n
\n \n
\n );\n }\n\n private _getEmptyThumbnailItem(\n imageSettings: IImageSettings | undefined,\n index: number,\n modifiedActiveIndex: number\n ): IMediaGalleryThumbnailItemViewProps {\n const classes = classnames(\n 'ms-media-gallery__thumbnail-item',\n modifiedActiveIndex === index ? 'ms-media-gallery__thumbnail-item-active' : ''\n );\n return {\n ThumbnailItemContainerProps: {\n tag: 'li' as NodeTag,\n className: classes,\n role: 'tab',\n tabIndex: 0,\n key: 'empty',\n 'aria-label': '',\n 'aria-selected': modifiedActiveIndex === index,\n onClick: this._generateOnThumbnailClick(index),\n onKeyDown: this._generateOnThumbnailKeyDown(index)\n },\n Picture: (\n \n )\n };\n }\n\n private readonly isFirstItem = () => this.state.activeIndex === 0;\n\n private readonly isLastItem = () => {\n const images = this.state.mediaGalleryItems;\n return images && this.state.activeIndex === images.length - 1;\n };\n\n private readonly openModalDialog = (): void => {\n this._toggleModal();\n };\n\n private _toggleModal(): void {\n if (this.state.modalIsOpen) {\n this.fullScreenOverlayButtonRef.current?.focus();\n const parentDiv = this._inlineZoomDivRef.get(this.state.activeIndex);\n if (parentDiv && parentDiv.children && parentDiv.children.length >= 2) {\n const image = parentDiv.children[1].querySelector('img');\n if (image) {\n image.removeAttribute('style');\n }\n }\n this.setState({\n isImageZoomed: false\n });\n }\n this.setState({\n isImageZoomed: false,\n modalIsOpen: !this.state.modalIsOpen\n });\n removeInlineZoomStyle();\n removeContainerZoomStyle();\n }\n\n private readonly imageModalSlider = (ZoomView: string): React.ReactElement => {\n const {\n data: {\n product: { result: product }\n },\n resources\n } = this.props;\n let mediaGalleryItems = this.state.mediaGalleryItems;\n\n if (!mediaGalleryItems && product) {\n mediaGalleryItems = [this._mapProductToImageData(product)];\n }\n const carouselprops = {\n tag: Carousel,\n className: 'ms-media-gallery__carousel',\n items:\n mediaGalleryItems &&\n mediaGalleryItems.map((item: IImageData, index: number) =>\n this._renderCarouselItemImageView(ZoomView, item, this._zoomedImageSettings, index, true)\n ),\n activeIndex: this.state.activeIndex,\n next: this.next,\n previous: this.previous,\n interval: false,\n directionTextPrev: resources.previousScreenshotFlipperText,\n directionTextNext: resources.nextScreenshotFlipperText,\n onIndicatorsClickHandler: this.goToIndex,\n showPaginationTooltip: true,\n hideIndicator: false,\n keyboard: false,\n handleOnExited: this.onExited,\n handleOnExiting: this.onExiting,\n isDisabledFunctionality: this.state.isMobileImageZoomed\n } as IComponentNodeProps;\n const carousel = ;\n\n const imageModalSliderProps: IModalViewProps = {\n modalIsOpen: this.state.modalIsOpen,\n ontoggle: this._toggleModal,\n galleryCarousel: carousel,\n classNames: classnames('ms-media-gallery__modal', 'msc-modal-input-required')\n };\n return ImagefullView(imageModalSliderProps) as React.ReactElement;\n };\n}\n\nexport default MediaGallery;\n","/*!\n * Copyright (c) Microsoft Corporation.\n * All rights reserved. See LICENSE in the project root for license information.\n */\n\nimport { Module, Node } from '@msdyn365-commerce-modules/utilities';\nimport * as React from 'react';\n\nimport { IMediaGalleryThumbnailItemViewProps, IMediaGalleryThumbnailsViewProps, IMediaGalleryViewProps } from '../..';\n\nconst MediaGalleryView: React.FC = props => {\n const { CarouselProps, Thumbnails, MediaGallery, Modal } = props;\n\n return (\n \n \n {Modal}\n {_renderThumbnails(Thumbnails)}\n \n );\n};\n\nconst _renderThumbnails = (thumbnails: IMediaGalleryThumbnailsViewProps): JSX.Element => {\n const { ThumbnailsContainerProps, SingleSlideCarouselComponentProps, items } = thumbnails;\n\n return (\n \n {items && items.map(_renderThumbnailItem)}\n \n );\n};\n\nconst _renderThumbnailItem = (thumbnail: IMediaGalleryThumbnailItemViewProps): JSX.Element => {\n const { ThumbnailItemContainerProps, Picture } = thumbnail;\n\n return {Picture};\n};\n\nexport default MediaGalleryView;\n","module.exports = React;","module.exports = ReactDOM;"],"names":["binding","modules","dataActions","registerSanitizedActionPath","sanitizedActionPath","dataAction","default","Error","prototype","RegistrationId","id","c","require","$type","da","name","path","runOn","iNM","ns","n","p","pdp","md","window","__bindings__","_objectSpread","viewDictionary","cn","async","validateMediaLocationAsync","mediaLocation","imageData","src","Uri","altText","AltText","IsApplicableForChildEntities","additionalProperties","isApplicableForChildEntities","Promise","resolve","http","XMLHttpRequest","open","addEventListener","status","send","_unused","getValidProductImages","productId","channelId","actionContext","imageSettings","selectedProduct","catalogId","getCatalogId","requestContext","actionInput","MediaLocationsForSelectedVariantInput","getMediaLocationsForSelectedVariant","then","mediaLocations","all","map","pairs","filter","pair","catch","error","telemetry","exception","debug","validateProductImages","MediaGallery","React","constructor","props","_this","_ref","_props$config$zoomedI","super","this","_inlineZoomDivRef","Map","fullScreenOverlayButtonRef","mediaGalleryImages","defaultGalleryImageSettings","viewports","xs","q","w","h","sm","lg","lazyload","cropFocalRegion","defaultThumbnailImageSettings","onExiting","setState","animating","onExited","next","removeInlineZoomStyle","undefined","isLastItem","nextIndex","state","activeIndex","goToIndex","updateZoomedInImage","previous","images","mediaGalleryItems","isFirstItem","length","index","_getCarouselItem","image","isInPopup","arguments","Image","Object","assign","context","className","fallBackSrc","fallbackImage","gridSettings","request","loadFailureBehavior","shouldSkipToMainImage","bypassHideOnFailure","_getThumbnailItem","modifiedActiveIndex","ThumbnailItemContainerProps","tag","classnames","role","tabIndex","key","onClick","_generateOnThumbnailClick","onKeyDown","_generateOnThumbnailKeyDown","Picture","imageFallbackOptimize","shouldUseOptimizedImage","_refHandler","divRef","set","event","which","KeyCodes","Enter","Space","preventDefault","openModalDialog","_toggleModal","imageModalSlider","ZoomView","data","product","result","resources","_mapProductToImageData","carouselprops","Carousel","items","item","_renderCarouselItemImageView","_zoomedImageSettings","interval","directionTextPrev","previousScreenshotFlipperText","directionTextNext","nextScreenshotFlipperText","onIndicatorsClickHandler","showPaginationTooltip","hideIndicator","keyboard","handleOnExited","handleOnExiting","isDisabledFunctionality","isMobileImageZoomed","carousel","imageModalSliderProps","modalIsOpen","ontoggle","galleryCarousel","classNames","ImagefullView","bind","isImageZoomed","isInitialLoad","config","skipImageValidation","zoomedImageSettings","galleryImageSettings","_onImageMouseOut","_inlineZoomImageOnHover","_onInlineImageClick","_onContainerZoomImageClick","_onMouseOutLensContainer","isMobile","variant","VariantType","Viewport","_this$props$config$im","source","imageSource","shouldUpdateOnPartialDimensionSelection","_setRenderType","mediaLocationsForSelectedVariant","_this$props$config$th","thumbnailImageSettings","_setImages","_this$props$config$th2","RecordId","apiSettings","productVariant","reaction","_product$productVaria","ObjectExtensions","isNullOrUndefined","_this$props$config$th3","_this$props$config$th4","shouldComponentUpdate","nextProps","nextState","render","_this$props$config$im2","_this$props$context$a","isVertical","thumbnailsOrientation","isFullscreenAllowed","allowFullScreen","zoomViewMode","imageZoom","emptyPlaceHolderImage","app","placeholderImageName","getFallbackImageUrl","ItemId","_this$props$config$im3","_mediaLocation$Uri","_mediaLocation$AltTex","curatedImages","_filterMasterImageFromVariant","mediaGalleryCarouselItems","_getMediaGalleryItems","mediaGalleryThumbnailCarouselItems","_getMediaGalleryThumbnailItems","viewProps","moduleProps","Modal","callbackToggle","callbackThumbnailClick","callbackThumbnailKeyDown","CarouselProps","indicatorAriaText","ariaLabelForSlide","keys","Thumbnails","ThumbnailsContainerProps","SingleSlideCarouselComponentProps","SingleSlideCarousel","vertical","flipperPrevLabel","flipperNextLabel","parentId","useTabList","JSON","stringify","renderView","_this$state$mediaGall","ArrayExtensions","hasElements","lastUpdate","defaultKey","_getEmptyThumbnailItem","_this$state$mediaGall2","zoomView","_renderEmptyImage","curatedImage","imagesToSet","Date","now","_renderImageInContainerOnZoom","_renderImageFullScreenOnZoom","_renderImageInlineOnZoom","_this$props$config$sh","_this$props$data$prod","_this$props$data$prod2","_this$props$data$prod3","shouldHidePrimaryImages","shouldHideMasterProductImagesForVariant","variantImages","isVariantProduct","MasterProductId","itemId","_item$additionalPrope","_this$props$config$da","ref","dataScale","defaultDataScale","onMouseOver","onMouseMove","inlineZoomImageOnMouseMove","_this$props$config$da2","inlineZoomImageOnHover","String","_handleMobileViewZoomedImageClick","target","currentTarget","mobileZoomedInImageClassName","style","transform","classList","remove","parentElement","overflow","_this$props$config$da3","bounds","getBoundingClientRect","Number","positionX","clientX","left","positionY","clientY","top","scaledPositionX","scaledPositionY","add","scrollTo","_this$props$config$da4","innerWidth","inlineZoomInitClick","inlineZoomImageOnMouseOut","onContainerZoomInit","onMouseOutLensContainer","_this$props$config$da5","onMouseOut","onMouseMoveLensContainer","onMouseOverImageContainer","href","title","fullScreenTitleText","_product$PrimaryImage","PrimaryImageUrl","_this$fullScreenOverl","current","focus","parentDiv","get","children","querySelector","removeAttribute","removeContainerZoomStyle","_renderThumbnails","thumbnails","Node","_renderThumbnailItem","thumbnail","Module","module","exports","ReactDOM"],"sourceRoot":""}