{"version":3,"file":"static/js/a63f04e46c5c2261d8ae.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/media-gallery.tsx?24d7","webpack://Msdyn365.Commerce.Online/./src/modules/media-gallery/media-gallery.view.tsx?5061","webpack://Msdyn365.Commerce.Online/./src/modules/media-gallery/utils/helper.ts?b895","webpack://Msdyn365.Commerce.Online/./src/modules/media-gallery/utils/get-valid-product-images.ts?a364","webpack://Msdyn365.Commerce.Online/./src/modules/adventureworks/views/media-gallery.view.tsx?7624","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 };\nviewDictionary['@msdyn365-commerce-theme|adventureworks-theme-kit|modules|adventureworks|views|media-gallery'] = {\n c: () => require('@msdyn365-commerce-theme/adventureworks-theme-kit/dist/lib/modules/adventureworks/views/media-gallery.view.js'),\n cn: '@msdyn365-commerce-theme-adventureworks-theme-kit-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 { Carousel, ICarouselProps, Player, IPlayerData, IPlayerOptions, IVideoMetadata } from '@msdyn365-commerce/components';\nimport { IImageData, IImageSettings, Image, Video } from '@msdyn365-commerce/core';\nimport { MediaLocation, MediaType, 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 { getProductImages, getValidProductImages, getVideoMetadataFromApi, validateProductImages } from './utils';\nimport { getAltText, IMediaData } from './utils/helper';\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?: IMediaData[];\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 private readonly player: React.RefObject = React.createRef();\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 const mediaGalleryImages = this.getImagesData();\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 mediaGalleryItems: mediaGalleryImages\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 (!this.props.context.request.app?.config?.OmniChannelMedia) {\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 await 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 await this._setImages(images);\n } else {\n await this._setImages([]);\n }\n }\n }\n\n reaction(\n () => {\n const product = this.props.data.product.result;\n if (!product) {\n return null;\n }\n\n if (!shouldUpdateOnPartialDimensionSelection || !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 let images: IImageData[] = [];\n if (product) {\n if (this.props.context.app?.config?.OmniChannelMedia) {\n images = await getProductImages(\n product.RecordId,\n this.shouldUseCmsAltText(),\n +this.props.context.request.apiSettings.channelId,\n this.props.context.actionContext,\n product.Name,\n shouldUpdateOnPartialDimensionSelection ? product.productVariant : undefined\n );\n } else {\n 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 }\n await this._setImages(images);\n } else {\n await this._setImages([]);\n }\n },\n { fireImmediately: true }\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 await 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 // 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(\n this.props.data.product.result.ItemId,\n this.props.context.request.apiSettings,\n this.props.context.request.app?.config?.OmniChannelMedia\n );\n }\n if (emptyPlaceHolderImage && this.fallbackImage) {\n this.fallbackImage = `${this.fallbackImage}&fallback=${emptyPlaceHolderImage}`;\n }\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 const { autoplay } = this.props.config;\n const currentIndex = this.state.activeIndex;\n const mediaItems = this.state.mediaGalleryItems;\n if (autoplay && mediaItems) {\n if (mediaItems[`${index}`]?.mediaTypeValue === MediaType.Video) {\n this.player.current?.play();\n } else if (mediaItems[`${currentIndex}`].mediaTypeValue === MediaType.Video) {\n this.player.current?.pause();\n }\n }\n this.setState({ activeIndex: index });\n };\n\n private _getMediaGalleryThumbnailItems(): IMediaGalleryCarouselItems {\n const mediaGalleryItems = this.state.mediaGalleryItems;\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: IMediaData, index: number) => {\n if (item.mediaTypeValue === MediaType.Video) {\n return this.getVideoThumbNailItem(\n item,\n thumbnailImageSettings ?? this.defaultThumbnailImageSettings,\n index,\n this.state.activeIndex\n );\n } else {\n return this._getThumbnailItem(\n item,\n thumbnailImageSettings ?? this.defaultThumbnailImageSettings,\n index,\n this.state.activeIndex\n );\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 getImagesData = (): IImageData[] => {\n if (this.props.config.skipImageValidation || this.props.context.request.app?.config?.OmniChannelMedia) {\n const source = this.props.config.imageSource ?? imageSource.pageContext;\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: getAltText(\n this.props.context.actionContext.requestContext,\n this.shouldUseCmsAltText(),\n this.props.data.product.result?.Name,\n mediaLocation.AltText\n ),\n additionalProperties: mediaLocation.IsApplicableForChildEntities\n ? {\n isApplicableForChildEntities: 'true'\n }\n : undefined\n };\n });\n const curatedImages = this.props.config.images ?? [];\n\n return [...this._filterMasterImageFromVariant(images), ...curatedImages];\n }\n return [];\n };\n\n private _getMediaGalleryItems(isFullscreenAllowed: boolean, zoomViewMode: string): IMediaGalleryCarouselItems {\n const mediaGalleryItems = this.state.mediaGalleryItems;\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: IMediaData, index: number) => {\n return this._renderCarouselItemImageView(\n zoomView,\n item,\n galleryImageSettings ?? this.defaultGalleryImageSettings,\n index\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 async _setImages(images?: IMediaData[]): Promise {\n const curatedImage = this.props.config.images || [];\n const mediaToSet: IMediaData[] = this._filterMasterImageFromVariant(images);\n\n void Promise.all(\n mediaToSet.map(async mediaData => {\n if (mediaData.mediaTypeValue === MediaType.Video && mediaData.src) {\n try {\n const url = new URL(mediaData.src);\n const videoId = url.searchParams.get('CVID');\n if (videoId) {\n mediaData.videoData = await getVideoMetadataFromApi(videoId, this.props.context.actionContext);\n }\n } catch (error) {\n if (this.props.telemetry) {\n this.props.telemetry.debug('Error while fetching videoId');\n }\n }\n }\n return mediaData;\n })\n ).then(mediaData => {\n const mediaItems = mediaData.filter(element => {\n return (\n element.mediaTypeValue !== MediaType.Video ||\n (element.mediaTypeValue === MediaType.Video && element.videoData !== undefined)\n );\n });\n\n this.setState({\n mediaGalleryItems: [...mediaItems, ...curatedImage],\n activeIndex: 0,\n lastUpdate: Date.now(),\n shouldUseOptimizedImage: false\n });\n });\n\n this.setState({\n mediaGalleryItems: [...mediaToSet, ...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 media: IMediaData,\n imageSettings: IImageSettings,\n index: number,\n isInPopup: boolean = false\n ): React.ReactNode {\n if (media.mediaTypeValue === MediaType.Video) {\n if (isInPopup || zoomView !== 'fullscreen') {\n return <>{this._renderCarouselItemVideo(media, index, imageSettings)};\n }\n return <>{this._renderVideoThumbnail(media, index, imageSettings)};\n } else {\n if (this.isMobile()) {\n if (isInPopup) {\n return this._renderImageInContainerOnZoom(media, this._zoomedImageSettings, index);\n }\n return this._renderImageFullScreenOnZoom(media, imageSettings, index);\n }\n\n switch (zoomView) {\n case 'container': {\n return this._renderImageInContainerOnZoom(media, this._zoomedImageSettings, index);\n }\n case 'inline': {\n return this._renderImageInlineOnZoom(media, this._zoomedImageSettings, index);\n }\n case 'fullscreen': {\n return this._renderImageFullScreenOnZoom(media, imageSettings, index);\n }\n\n // No default\n }\n return <>{this._getCarouselItem(media, imageSettings, index, isInPopup)};\n }\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 _renderCarouselItemVideo = (mediaData: IMediaData, index: number, imageSettings: IImageSettings): React.ReactNode => {\n const videoData = mediaData.videoData;\n if (videoData) {\n const options: IPlayerOptions = this.props.config as IPlayerOptions;\n const playerResources = this.props.resources;\n const videoMetaData: IVideoMetadata = {};\n videoMetaData.videoId = videoData.id;\n videoMetaData.title = videoData.title;\n videoMetaData.duration = videoData.playTime;\n if (videoData.thumbnail) {\n videoMetaData.posterframeUrl = videoData.thumbnail.src;\n }\n if (videoData._links?.binaryReferences) {\n videoMetaData.videoBinaryReferences = videoData._links.binaryReferences;\n }\n const videoPlayerData: IPlayerData = { options, metaData: videoMetaData };\n const attributes = {\n id: `${this.props.id}__carousel-item__${index}`\n };\n return (\n \n );\n }\n return this._renderEmptyImage(imageSettings);\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 * Gets the video thumbnail item to display media gallery.\n * @param props - The Media gallery view props from business layer.\n * @returns Return thumbnail view props which will be used to render video.\n */\n private readonly getVideoThumbNailItem = (\n mediaData: IMediaData,\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 const videoData = mediaData.videoData;\n let image: IImageData;\n if (videoData?.thumbnail) {\n image = videoData.thumbnail;\n } else {\n image = {\n src: 'empty'\n };\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 /**\n * Render the video thumbnail in full screen.\n * @param mediaData - Media Data.\n * @param index - Index\n * @param imageSettings - Image settings.\n * @returns - JSX.Element\n */\n private readonly _renderVideoThumbnail = (mediaData: IMediaData, index: number, imageSettings: IImageSettings): React.ReactNode => {\n const videoData = mediaData.videoData;\n let image: IImageData;\n if (videoData?.thumbnail) {\n image = videoData.thumbnail;\n } else {\n image = {\n src: 'empty'\n };\n }\n\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 private shouldUseCmsAltText = (): boolean => {\n if (this.props.config.altTextSource === 'product') {\n return false;\n } else {\n return true;\n }\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","/*!\n * Copyright (c) Microsoft Corporation.\n * All rights reserved. See LICENSE in the project root for license information.\n */\n\nimport { IImageData, IRequestContext, IVideoData } from '@msdyn365-commerce/core';\n\nexport enum MediaType {\n /**\n * The None.\n */\n None = 0,\n /**\n * The Image type.\n */\n Image = 1,\n /**\n * The video type.\n */\n Video = 2,\n /**\n * The file type.\n */\n File = 3\n}\n\nexport interface IMediaData extends IImageData {\n mediaTypeValue?: MediaType;\n displayOrder?: number;\n videoData?: IVideoData;\n}\n\n/**\n * Gets correct alt text for image based on configuration of site.\n * @param productName Product name.\n * @param context Current request context.\n * @param imageAltText Alt-text from CMS image.\n */\nexport function getAltText(\n context: IRequestContext,\n shouldUseCmsAltText: boolean,\n productName?: string,\n imageAltText?: string\n): string | undefined {\n if (!context?.app?.config?.OmniChannelMedia) {\n return productName;\n }\n if (shouldUseCmsAltText) {\n return imageAltText;\n }\n return productName;\n}\n","/*!\n * Copyright (c) Microsoft Corporation.\n * All rights reserved. See LICENSE in the project root for license information.\n */\n\nimport {\n commerceApiRequest,\n commerceVideoMetadataRequest,\n getCatalogId,\n IActionContext,\n IImageData,\n IImageSettings,\n IVideoData\n} from '@msdyn365-commerce/core';\nimport { MediaLocation, SimpleProduct } from '@msdyn365-commerce/retail-proxy';\nimport {\n ArrayExtensions,\n getMediaLocationsForSelectedVariant,\n MediaLocationsForSelectedVariantInput\n} from '@msdyn365-commerce-modules/retail-actions';\nimport { getAltText } from './helper';\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\n/**\n * Gets product variant images on dimension change of buy-box module for Omni scenario.\n * @param productId Product record id.\n * @param shouldUseCmsAltText Alt-text source to use.\n * @param channelId Current channel id.\n * @param actionContext Current action context.\n * @param productName Product name.\n * @param selectedProduct Currently selected variant product.\n * @returns List of images.\n */\n\nexport async function getProductImages(\n productId: number,\n shouldUseCmsAltText: boolean,\n channelId: number,\n actionContext: IActionContext,\n productName?: string,\n selectedProduct?: SimpleProduct\n): Promise {\n const catalogId = getCatalogId(actionContext.requestContext);\n if (actionContext.requestContext?.params?.isPreview) {\n const response = await commerceApiRequest(actionContext.requestContext, 'msdyn365-ochannel-product-info', 'post', {\n productId: productId,\n channelId: channelId,\n catalogId: catalogId\n });\n if (response.status !== 200) {\n actionContext.telemetry.debug('Unable to get Media Locations for Selected Variant for preview scenario');\n return [];\n }\n const previewImageData = response?.data as MediaLocation[];\n if (previewImageData) {\n return previewImageData.map(mediaLocation => {\n return {\n src: mediaLocation.Uri ?? '',\n altText: getAltText(actionContext.requestContext, shouldUseCmsAltText, productName, mediaLocation.AltText),\n displayOrder: mediaLocation.DisplayOrder,\n mediaTypeValue: mediaLocation.MediaTypeValue,\n additionalProperties: mediaLocation.IsApplicableForChildEntities\n ? {\n isApplicableForChildEntities: 'true'\n }\n : undefined\n };\n });\n }\n return [];\n }\n const actionInput = new MediaLocationsForSelectedVariantInput(productId, channelId, selectedProduct, catalogId);\n return getMediaLocationsForSelectedVariant(actionInput, actionContext)\n .then(mediaLocations => {\n if (mediaLocations) {\n return mediaLocations.map(mediaLocation => {\n return {\n src: mediaLocation.Uri ?? '',\n altText: getAltText(actionContext.requestContext, shouldUseCmsAltText, productName, mediaLocation.AltText),\n displayOrder: mediaLocation.DisplayOrder,\n mediaTypeValue: mediaLocation.MediaTypeValue,\n additionalProperties: mediaLocation.IsApplicableForChildEntities\n ? {\n isApplicableForChildEntities: 'true'\n }\n : undefined\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/**\n * GetVideoMetadataFromAPI - Makes API call to get video metadata.\n * @param videoId: Video Id\n * @param actionContext: Action context\n * @returns: Returns the meta data of the video.\n */\nexport async function getVideoMetadataFromApi(videoId: string, actionContext: IActionContext): Promise {\n let videoPlayerData: IVideoData | undefined;\n if (videoId) {\n const response = await commerceVideoMetadataRequest(actionContext.requestContext, [videoId]);\n\n if (response.status !== 200) {\n actionContext.telemetry.debug(`Unable to get video metadata for videoId: ${videoId}`);\n return;\n }\n\n const videoData = response.data as [];\n if (videoData && ArrayExtensions.hasElements(videoData)) {\n videoPlayerData = videoData[0];\n }\n }\n return videoPlayerData;\n}\n","/*!\n * Copyright (c) Microsoft Corporation.\n * All rights reserved. See LICENSE in the project root for license information.\n */\n\nimport { IImageData, IImageSettings, Image, Video } from '@msdyn365-commerce/core';\nimport {\n IMediaData,\n IMediaGalleryThumbnailItemViewProps,\n IMediaGalleryThumbnailsViewProps,\n IMediaGalleryViewProps,\n MediaType\n} from '@msdyn365-commerce-modules/media-gallery';\nimport { ArrayExtensions, getFallbackImageUrl } from '@msdyn365-commerce-modules/retail-actions';\nimport { Button, KeyCodes, Module, Node, NodeTag } from '@msdyn365-commerce-modules/utilities';\nimport classnames from 'classnames';\nimport React from 'react';\nimport { IPlayerData, IPlayerOptions, IVideoMetadata, Player } from '@msdyn365-commerce-modules/video-player-utilities';\n\ninterface IMediaGalleryItemsProps extends IMediaGalleryThumbnailItemViewProps {\n Video?: React.ReactElement;\n}\n\n/**\n * Render the thumbnail item images.\n * @param thumbnail - The carousel thumbnail line props.\n * @returns Return HTML having thumbnail container props with image.\n */\nconst renderThumbnailItem = (thumbnail: IMediaGalleryItemsProps): JSX.Element => {\n // eslint-disable-next-line @typescript-eslint/naming-convention -- Dependency from media-gallery.tsx file\n const { ThumbnailItemContainerProps, Picture, Video } = thumbnail;\n\n return {Video ? Video : Picture};\n};\n\n/**\n * Gets the thumbnail item to display media gallery images.\n * @param image - The media gallery images.\n * @param imageSettings - Image settings for the image gallery items.\n * @param imageId - Image id.\n * @param modifiedActiveIndex - Modified Index of the images when selection changes.\n * @param props - The Media gallery view props from business layer.\n * @returns Return thumbnail view props which will be used to render images.\n */\nconst GetThumbnailItemComponent = (\n image: IImageData,\n imageSettings: IImageSettings,\n imageId: number,\n modifiedActiveIndex: number,\n props: IMediaGalleryViewProps,\n mediaTypeValue?: MediaType\n): IMediaGalleryThumbnailItemViewProps => {\n let fallbackImage: string | undefined = '';\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access -- Site level config can be of any type.\n const emptyPlaceHolderImage = props.context.app.config?.placeholderImageName as string;\n if (props.data.product.result) {\n fallbackImage = getFallbackImageUrl(\n props.data.product.result.ItemId,\n props.context.request.apiSettings,\n props.context.request.app?.config?.OmniChannelMedia\n );\n }\n if (emptyPlaceHolderImage && fallbackImage) {\n fallbackImage = `${fallbackImage},${emptyPlaceHolderImage}`;\n }\n\n /**\n * OnClick method of media gallery item.\n */\n const onClick = () => {\n props.callbackToggle?.();\n props.callbackThumbnailClick?.(imageId);\n props.state.activeIndex = imageId;\n };\n\n const classes = classnames(\n 'ms-media-gallery__thumbnail-item',\n modifiedActiveIndex === imageId ? 'ms-media-gallery__thumbnail-item-active' : ''\n );\n\n /**\n * Keydown event of media gallery item.\n * @param event - React.KeyboardEvent.\n */\n const handleKeyDown = (event: React.KeyboardEvent) => {\n if (event.keyCode === KeyCodes.Enter) {\n event.preventDefault();\n onClick();\n }\n };\n const defaultIndex = 0;\n return {\n ThumbnailItemContainerProps: {\n tag: 'li' as NodeTag,\n className: classes,\n role: 'listitem',\n key: imageId\n },\n Picture: (\n \n \n \n \n \n \n \n \n )\n };\n};\n\n/**\n * Render the video player.\n * @param mediaData - Media Data\n * @param index - Index of the video\n * @param activeIndex - Active Index\n * @param imageSettings - Image settings\n * @param props - Media gallery view props\n * @returns - JSX.Element.\n */\nconst RenderVideo = (\n mediaData: IMediaData,\n index: number,\n activeIndex: number,\n imageSettings: IImageSettings,\n props: IMediaGalleryViewProps\n): IMediaGalleryItemsProps => {\n const videoData = mediaData.videoData;\n if (videoData) {\n const options: IPlayerOptions = props.config as IPlayerOptions;\n const playerResources = props.resources;\n const videoMetaData: IVideoMetadata = {};\n videoMetaData.videoId = videoData.id;\n videoMetaData.title = videoData.title;\n videoMetaData.duration = videoData.playTime;\n if (videoData.thumbnail) {\n videoMetaData.posterframeUrl = videoData.thumbnail.src;\n }\n if (videoData._links?.binaryReferences) {\n videoMetaData.videoBinaryReferences = videoData._links.binaryReferences;\n }\n const videoPlayerData: IPlayerData = { options, metaData: videoMetaData };\n\n const classes = classnames(\n 'ms-media-gallery__thumbnail-item',\n index === activeIndex ? 'ms-media-gallery__thumbnail-item-active' : ''\n );\n\n return {\n ThumbnailItemContainerProps: {\n tag: 'li' as NodeTag,\n className: classes,\n role: 'listitem',\n key: index\n },\n Picture: <>,\n Video: (\n \n )\n };\n }\n return GetEmptyThumbnailItemComponent(imageSettings, props);\n};\n\n/**\n * Gets the empty thumbnail item to display media gallery images.\n * @param imageSettings - Image settings for the image gallery items.\n * @param props - The Media gallery view props from business layer.\n * @returns Return thumbnail view props which will be used to render empty images.\n */\nconst GetEmptyThumbnailItemComponent = (\n imageSettings: IImageSettings,\n props: IMediaGalleryViewProps\n): IMediaGalleryThumbnailItemViewProps => {\n let fallbackImage: string | undefined = '';\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access -- Site level config can be of any type.\n const emptyPlaceHolderImage = props.context.app.config?.placeholderImageName as string;\n\n if (props.data.product.result) {\n fallbackImage = getFallbackImageUrl(\n props.data.product.result.ItemId,\n props.context.request.apiSettings,\n props.context.request.app?.config?.OmniChannelMedia\n );\n }\n if (emptyPlaceHolderImage && fallbackImage) {\n fallbackImage = `${fallbackImage},${emptyPlaceHolderImage}`;\n }\n\n return {\n ThumbnailItemContainerProps: {\n tag: 'li' as NodeTag,\n className: 'ms-media-gallery__thumbnail-item',\n role: 'listitem',\n tabIndex: 0,\n key: 0,\n 'aria-label': ''\n },\n Picture: (\n \n )\n };\n};\n\n/**\n * Update media gallery items method.\n * @param items - The media gallery thumbnail item view props.\n * @returns The IImageData array.\n */\nconst getMediaGalleryItems = (items?: IMediaData[]): IMediaData[] | undefined => {\n return items?.map(item => {\n return {\n displayOrder: item.displayOrder,\n mediaTypeValue: item.mediaTypeValue,\n altText: item.altText,\n src: item.src,\n videoData: item.videoData\n };\n });\n};\n\nconst defaultThumbnailImageSettings: IImageSettings = {\n viewports: {\n xs: { q: 'w=295&h=295&q=80&m=6&f=jpg', w: 295, h: 295 },\n xl: { q: 'w=295&h=295&q=80&m=6&f=jpg', w: 295, h: 295 }\n },\n lazyload: true,\n cropFocalRegion: true\n};\n\n/**\n * Render the Media gallery thumbnails to represent images in grid view.\n * @param thumbnails - The thumbnail view props.\n * @param props - The media gallery view props.\n * @returns - The single slide carousel component to render as media gallery image.\n */\nconst renderThumbnails = (thumbnails: IMediaGalleryThumbnailsViewProps, props: IMediaGalleryViewProps): JSX.Element => {\n // eslint-disable-next-line @typescript-eslint/naming-convention -- Dependency from media-gallery.tsx file\n const { ThumbnailsContainerProps, SingleSlideCarouselComponentProps } = thumbnails;\n const { state } = props;\n const mediaGalleryItems = getMediaGalleryItems(state.mediaGalleryItems);\n\n const items: IMediaGalleryItemsProps[] | undefined =\n // eslint-disable-next-line multiline-ternary -- need multiline for easy code reading\n state.lastUpdate && ArrayExtensions.hasElements(mediaGalleryItems) && mediaGalleryItems[0].src === 'empty'\n ? [GetEmptyThumbnailItemComponent(defaultThumbnailImageSettings, props)]\n : // eslint-disable-next-line @typescript-eslint/naming-convention -- Dependency from media-gallery\n mediaGalleryItems?.map((item: IMediaData, id: number) => {\n if (item.mediaTypeValue === MediaType.Video) {\n if (props.config.allowFullScreen) {\n const videoThumbnail = item.videoData?.thumbnail;\n if (videoThumbnail) {\n return GetThumbnailItemComponent(\n videoThumbnail,\n defaultThumbnailImageSettings,\n id,\n state.activeIndex,\n props,\n item.mediaTypeValue\n );\n } else {\n return GetEmptyThumbnailItemComponent(defaultThumbnailImageSettings, props);\n }\n } else {\n return RenderVideo(item, id, state.activeIndex, defaultThumbnailImageSettings, props);\n }\n } else {\n return GetThumbnailItemComponent(item, defaultThumbnailImageSettings, id, state.activeIndex, props);\n }\n });\n\n return (\n \n {items?.map(renderThumbnailItem)}\n \n );\n};\n\n/**\n * Render the Media gallery items using viewprops.\n * @param props - The media gallery view props.\n * @returns The media gallery module wrapping up images node.\n */\nconst mediaGalleryView: React.FC = props => {\n // eslint-disable-next-line @typescript-eslint/naming-convention -- Dependency from media-gallery.tsx file\n const { CarouselProps, Thumbnails, MediaGallery, Modal } = props;\n\n // The thumbnails in AW theme aren't used as tabs\n const NewSingleSlideCarouselComponentProps = { ...Thumbnails.SingleSlideCarouselComponentProps, useTabList: false };\n const NewThumbnails = { ...Thumbnails, SingleSlideCarouselComponentProps: NewSingleSlideCarouselComponentProps };\n\n return (\n \n \n {Modal}\n {renderThumbnails(NewThumbnails, props)}\n \n );\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","MediaGallery","React","constructor","props","_this","_ref","_props$config$zoomedI","super","this","_inlineZoomDivRef","Map","fullScreenOverlayButtonRef","player","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","autoplay","config","currentIndex","mediaItems","_mediaItems","_this$player$current","mediaTypeValue","MediaType","Video","current","play","_this$player$current2","pause","getImagesData","_this$props$context$r","skipImageValidation","context","request","app","OmniChannelMedia","_this$props$config$im","_this$props$config$im2","source","imageSource","mediaLocations","data","mediaLocationsForSelectedVariant","result","map","mediaLocation","_mediaLocation$Uri","_this$props$data$prod","src","Uri","altText","getAltText","actionContext","requestContext","shouldUseCmsAltText","product","Name","AltText","additionalProperties","IsApplicableForChildEntities","isApplicableForChildEntities","curatedImages","_filterMasterImageFromVariant","_renderCarouselItemVideo","mediaData","imageSettings","videoData","_videoData$_links","options","playerResources","resources","videoMetaData","videoId","title","duration","playTime","thumbnail","posterframeUrl","_links","binaryReferences","videoBinaryReferences","videoPlayerData","metaData","attributes","className","editProps","key","Player","Object","assign","ref","playerData","isEditor","params","_renderEmptyImage","_getCarouselItem","image","_this$props$context$r2","isInPopup","arguments","Image","fallBackSrc","fallbackImage","gridSettings","loadFailureBehavior","shouldSkipToMainImage","bypassHideOnFailure","_getThumbnailItem","modifiedActiveIndex","ThumbnailItemContainerProps","tag","classnames","role","tabIndex","onClick","_generateOnThumbnailClick","onKeyDown","_generateOnThumbnailKeyDown","Picture","imageFallbackOptimize","shouldUseOptimizedImage","getVideoThumbNailItem","classes","_refHandler","divRef","set","event","which","KeyCodes","Enter","Space","preventDefault","_renderVideoThumbnail","fullScreenTitleText","openModalDialog","_toggleModal","imageModalSlider","ZoomView","_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","altTextSource","bind","mediaGalleryImages","isImageZoomed","isInitialLoad","zoomedImageSettings","galleryImageSettings","_onImageMouseOut","_inlineZoomImageOnHover","_onInlineImageClick","_onContainerZoomImageClick","_onMouseOutLensContainer","isMobile","variant","VariantType","Viewport","_this$props$config$im3","_this$props$context$r3","shouldUpdateOnPartialDimensionSelection","_setRenderType","_this$props$config$th","validateProductImages","thumbnailImageSettings","_setImages","_this$props$config$th2","getValidProductImages","RecordId","apiSettings","channelId","productVariant","reaction","_product$productVaria","async","_this$props$context$a","_this$props$config$th3","getProductImages","fireImmediately","_this$props$config$th4","shouldComponentUpdate","nextProps","nextState","render","_this$props$context$a2","isVertical","thumbnailsOrientation","isFullscreenAllowed","allowFullScreen","zoomViewMode","imageZoom","emptyPlaceHolderImage","placeholderImageName","_this$props$context$r4","getFallbackImageUrl","ItemId","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","ArrayExtensions","hasElements","lastUpdate","defaultKey","_getEmptyThumbnailItem","zoomView","curatedImage","mediaToSet","Promise","all","URL","searchParams","get","getVideoMetadataFromApi","error","telemetry","debug","then","filter","element","Date","now","media","_renderImageInContainerOnZoom","_renderImageFullScreenOnZoom","_renderImageInlineOnZoom","_this$props$config$sh","_this$props$data$prod2","_this$props$data$prod3","_this$props$data$prod4","shouldHidePrimaryImages","shouldHideMasterProductImagesForVariant","variantImages","isVariantProduct","ObjectExtensions","isNullOrUndefined","MasterProductId","itemId","_item$additionalPrope","_this$props$config$da","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","_product$PrimaryImage","PrimaryImageUrl","_this$fullScreenOverl","focus","parentDiv","children","querySelector","removeAttribute","removeContainerZoomStyle","_renderThumbnails","thumbnails","Node","_renderThumbnailItem","Module","productName","imageAltText","_context$app","validateMediaLocationAsync","imageData","resolve","http","XMLHttpRequest","open","addEventListener","status","send","_unused","productId","selectedProduct","catalogId","getCatalogId","actionInput","MediaLocationsForSelectedVariantInput","getMediaLocationsForSelectedVariant","pairs","pair","catch","exception","_actionContext$reques","isPreview","response","commerceApiRequest","previewImageData","displayOrder","DisplayOrder","MediaTypeValue","_mediaLocation$Uri2","commerceVideoMetadataRequest","renderThumbnailItem","GetThumbnailItemComponent","imageId","_props$context$app$co","_props$config$thumbna","_props$context$reques2","_props$context$reques","_props$callbackToggle","_props$callbackThumbn","call","handleKeyDown","keyCode","Button","playVideoTitleText","GetEmptyThumbnailItemComponent","_props$context$app$co2","_props$config$thumbna2","_props$context$reques3","xl","renderThumbnails","getMediaGalleryItems","_item$videoData","videoThumbnail","RenderVideo","NewSingleSlideCarouselComponentProps","NewThumbnails","module","exports","ReactDOM"],"sourceRoot":""}