{"version":3,"file":"static/js/fed77b2bfb4af331fa0d.bundle.js","mappings":"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","sources":["webpack://Msdyn365.Commerce.Online/./src/themes/cirrus/views/media-gallery.view.tsx?3287","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":["/*--------------------------------------------------------------\r\n * Copyright (c) Microsoft Corporation. All rights reserved.\r\n * See License.txt in the project root for license information.\r\n *--------------------------------------------------------------*/\r\n\r\nimport { IImageData, IImageSettings, Image } from '@msdyn365-commerce/core';\r\nimport { IMediaGalleryThumbnailItemViewProps,\r\n IMediaGalleryThumbnailsViewProps,\r\n IMediaGalleryViewProps\r\n} from '@msdyn365-commerce-modules/media-gallery';\r\nimport { Button, KeyCodes, Module, Node, NodeTag } from '@msdyn365-commerce-modules/utilities';\r\nimport classnames from 'classnames';\r\nimport React from 'react';\r\n\r\n/**\r\n * Render the thumbnail item images.\r\n * @param thumbnail - The carousel thumbnail line props.\r\n * @returns Return HTML having thumnailcontainer props with image.\r\n */\r\nconst renderThumbnailItem = (thumbnail: IMediaGalleryThumbnailItemViewProps): JSX.Element => {\r\n // eslint-disable-next-line @typescript-eslint/naming-convention -- Dependency from media-gallery.tsx file\r\n const { ThumbnailItemContainerProps, Picture } = thumbnail;\r\n\r\n return (\r\n \r\n {Picture}\r\n \r\n );\r\n};\r\n\r\n/**\r\n * Gets the thumbnail item to display media gallery images.\r\n * @param image - The media gallery images.\r\n * @param imageSettings - Image settings for the image gallery items.\r\n * @param imageId - Image id.\r\n * @param modifiedActiveIndex - Modified Index of the images when selection changes.\r\n * @param props - The Media gallery view props from business layer.\r\n * @returns Return thumbnail view props which will be used to render images.\r\n */\r\nconst GetThumbnailItemComponent = (\r\n image: IImageData,\r\n imageSettings: IImageSettings,\r\n imageId: number,\r\n modifiedActiveIndex: number,\r\n props: IMediaGalleryViewProps\r\n): IMediaGalleryThumbnailItemViewProps => {\r\n\r\n /**\r\n * OnClick method of media gallery item.\r\n * */\r\n const onClick = () => {\r\n props.callbackToggle?.();\r\n props.callbackThumbnailClick?.(imageId);\r\n props.state.activeIndex = imageId;\r\n };\r\n\r\n const classes = classnames(\r\n 'ms-media-gallery__thumbnail-item',\r\n modifiedActiveIndex === imageId ? 'ms-media-gallery__thumbnail-item-active' : ''\r\n );\r\n\r\n /**\r\n * Keydown event of media gallery item.\r\n * @param event - React.KeyboardEvent.\r\n * */\r\n const handleKeyDown = (event: React.KeyboardEvent) => {\r\n if (event.keyCode === KeyCodes.Enter) {\r\n event.preventDefault();\r\n onClick();\r\n }\r\n };\r\n\r\n return {\r\n ThumbnailItemContainerProps: {\r\n tag: 'li' as NodeTag,\r\n className: classes,\r\n role: 'presentation',\r\n key: imageId\r\n },\r\n Picture: (\r\n \r\n \r\n \r\n \r\n \r\n \r\n )\r\n };\r\n};\r\n\r\n/**\r\n * Gets the empty thumbnail item to display media gallery images.\r\n * @param imageSettings - Image settings for the image gallery items.\r\n * @param props - The Media gallery view props from business layer.\r\n * @returns Return thumbnail view props which will be used to render empty images.\r\n */\r\nconst GetEmptyThumbnailItemComponent = (imageSettings: IImageSettings, props: IMediaGalleryViewProps): IMediaGalleryThumbnailItemViewProps => {\r\n return {\r\n ThumbnailItemContainerProps: {\r\n tag: 'li' as NodeTag,\r\n className: 'ms-media-gallery__thumbnail-item',\r\n role: 'tab',\r\n tabIndex: 0,\r\n key: 0,\r\n 'aria-label': '',\r\n 'aria-selected': true\r\n },\r\n Picture: (\r\n \r\n )\r\n };\r\n};\r\n\r\n/**\r\n * Update media gallery items method.\r\n * @param items - The media gallery thumbnail item view props.\r\n * @returns The IImageData array.\r\n */\r\nconst getMediaGalleryItems = (items?: IMediaGalleryThumbnailItemViewProps[]): IImageData[] | undefined => {\r\n return items?.map(item => {\r\n return {\r\n altText: item.Picture.props.altText,\r\n src: item.Picture.props.src\r\n };\r\n });\r\n};\r\n\r\nconst defaultThumbnailImageSettings: IImageSettings = {\r\n viewports: {\r\n xs: { q: 'w=295&h=295&q=80&m=6&f=jpg', w: 295, h: 295 },\r\n xl: { q: 'w=295&h=295&q=80&m=6&f=jpg', w: 295, h: 295 }\r\n },\r\n lazyload: true,\r\n cropFocalRegion: true\r\n};\r\n\r\n/**\r\n * Render the Media gallery thumbnails to represent images in grid view.\r\n * @param thumbnails - The thumbnail view props.\r\n * @param props - The media gallery view props.\r\n * @returns - The single slide carousel component to render as media gallery image.\r\n */\r\nconst renderThumbnails = (\r\n thumbnails: IMediaGalleryThumbnailsViewProps,\r\n props: IMediaGalleryViewProps\r\n): JSX.Element => {\r\n // eslint-disable-next-line @typescript-eslint/naming-convention -- Dependency from media-gallery.tsx file\r\n const { ThumbnailsContainerProps, SingleSlideCarouselComponentProps } = thumbnails;\r\n const { state, Thumbnails } = props;\r\n const mediaGalleryItems = getMediaGalleryItems(Thumbnails.items);\r\n\r\n const items: IMediaGalleryThumbnailItemViewProps[] | undefined =\r\n // eslint-disable-next-line multiline-ternary -- need multiline for easy code reading\r\n state.lastUpdate && mediaGalleryItems && mediaGalleryItems[0].src === 'empty' ? [GetEmptyThumbnailItemComponent(defaultThumbnailImageSettings, props)] :\r\n // eslint-disable-next-line @typescript-eslint/naming-convention -- Dependency from media-gallery\r\n mediaGalleryItems?.map((item: IImageData, id: number) => GetThumbnailItemComponent(item,\r\n defaultThumbnailImageSettings, id, state.activeIndex, props));\r\n\r\n return (\r\n \r\n \r\n {items?.map(renderThumbnailItem)}\r\n \r\n \r\n );\r\n};\r\n\r\n/**\r\n * Render the Media gallery items using viewprops.\r\n * @param props - The media gallery view props.\r\n * @returns The media gallery module wrapping up images node.\r\n */\r\nconst mediaGalleryView: React.FC = props => {\r\n // eslint-disable-next-line @typescript-eslint/naming-convention -- Dependency from media-gallery.tsx file\r\n const { CarouselProps, Thumbnails, MediaGallery, Modal } = props;\r\n return (\r\n \r\n \r\n {Modal}\r\n {renderThumbnails(Thumbnails, props)}\r\n \r\n );\r\n};\r\n\r\nexport default mediaGalleryView;\r\n","const binding = { modules: {}, dataActions: {} };\n\n const registerActionId = (actionPath) => {\n if (binding.dataActions[actionPath] &&\n binding.dataActions[actionPath].default &&\n binding.dataActions[actionPath].default.prototype &&\n binding.dataActions[actionPath].default.prototype.id) {\n binding.dataActions[binding.dataActions[actionPath].default.prototype.id] = binding.dataActions[actionPath];\n } else {\n Object.keys(binding.dataActions[actionPath] || {}).forEach(exportName => {\n if (binding.dataActions[actionPath][exportName] &&\n binding.dataActions[actionPath][exportName].prototype &&\n binding.dataActions[actionPath][exportName].prototype.Action) {\n binding.dataActions[binding.dataActions[actionPath][exportName].prototype.id] = binding.dataActions[actionPath][exportName];\n }\n })\n }\n };\n\n const registerSanitizedActionPath = (sanitizedActionPath, dataAction) => {\n if (process.env.NODE_ENV === 'development') {\n if (!dataAction.default) {\n throw new Error('Data action path does not have a default export');\n }\n if (!(dataAction.default.prototype.id && binding.dataActions[dataAction.default.prototype.id]) || !binding.dataActions[sanitizedActionPath]) {\n binding.dataActions[sanitizedActionPath] = dataAction;\n }\n } else {\n binding.dataActions[sanitizedActionPath] = dataAction;\n if (!binding.dataActions[sanitizedActionPath].default) {\n throw new Error('Data action path ' + sanitizedActionPath + ' does not have a default export');\n }\n binding.dataActions[sanitizedActionPath].default.prototype.RegistrationId = sanitizedActionPath;\n if (binding.dataActions[sanitizedActionPath].default.prototype.id) {\n binding.dataActions[binding.dataActions[sanitizedActionPath].default.prototype.id] = sanitizedActionPath;\n }\n }\n };\n \n\n (binding.modules['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['__local__|__local__|themes|cirrus|views|media-gallery'] = {\n c: () => require('partner/themes/cirrus/views/media-gallery.view.tsx'),\n cn: '__local__-__local__-media-gallery'\n };\nviewDictionary['@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},${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 private _renderImageFullScreenOnZoom(image: IImageData, imageSettings: IImageSettings, index: number): React.ReactNode {\n return (\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 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: 'presentation',\n key: imageId\n },\n Picture: (\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: 'presentation',\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: 'tab',\n tabIndex: 0,\n key: 0,\n 'aria-label': '',\n 'aria-selected': true\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 return (\n \n \n {Modal}\n {renderThumbnails(Thumbnails, props)}\n \n );\n};\n\nexport default mediaGalleryView;\n","module.exports = React;","module.exports = ReactDOM;"],"names":["renderThumbnailItem","thumbnail","ThumbnailItemContainerProps","Picture","React","Node","Object","assign","GetEmptyThumbnailItemComponent","imageSettings","props","_props$config$thumbna2","tag","className","role","tabIndex","key","Image","requestContext","context","actionContext","src","gridSettings","request","config","thumbnailImageSettings","loadFailureBehavior","defaultThumbnailImageSettings","viewports","xs","q","w","h","xl","lazyload","cropFocalRegion","renderThumbnails","thumbnails","ThumbnailsContainerProps","SingleSlideCarouselComponentProps","state","Thumbnails","mediaGalleryItems","items","map","item","altText","getMediaGalleryItems","lastUpdate","id","GetThumbnailItemComponent","image","imageId","modifiedActiveIndex","_props$config$thumbna","onClick","_props$callbackToggle","_props$callbackThumbn","callbackToggle","call","callbackThumbnailClick","activeIndex","handleKeyDown","event","keyCode","KeyCodes","Enter","preventDefault","classnames","Button","onKeyDown","title","resources","fullScreenTitleText","CarouselProps","MediaGallery","Modal","Module","binding","modules","dataActions","registerSanitizedActionPath","sanitizedActionPath","dataAction","default","Error","prototype","RegistrationId","c","require","$type","da","name","path","runOn","iNM","ns","n","p","pdp","md","window","__bindings__","_objectSpread","viewDictionary","cn","constructor","_this","_ref","_props$config$zoomedI","super","this","_inlineZoomDivRef","Map","fullScreenOverlayButtonRef","player","defaultGalleryImageSettings","sm","lg","onExiting","setState","animating","onExited","next","removeInlineZoomStyle","undefined","isLastItem","nextIndex","goToIndex","updateZoomedInImage","previous","images","isFirstItem","length","index","autoplay","currentIndex","mediaItems","_mediaItems","_this$player$current","mediaTypeValue","MediaType","Video","current","play","_this$player$current2","pause","getImagesData","_this$props$context$r","skipImageValidation","app","OmniChannelMedia","_this$props$config$im","_this$props$config$im2","source","imageSource","mediaLocations","data","mediaLocationsForSelectedVariant","result","mediaLocation","_mediaLocation$Uri","_this$props$data$prod","Uri","getAltText","shouldUseCmsAltText","product","Name","AltText","additionalProperties","IsApplicableForChildEntities","isApplicableForChildEntities","curatedImages","_filterMasterImageFromVariant","_renderCarouselItemVideo","mediaData","videoData","_videoData$_links","options","playerResources","videoMetaData","videoId","duration","playTime","posterframeUrl","_links","binaryReferences","videoBinaryReferences","videoPlayerData","metaData","attributes","editProps","Player","ref","playerData","isEditor","params","_renderEmptyImage","_getCarouselItem","_this$props$context$r2","isInPopup","arguments","fallBackSrc","fallbackImage","shouldSkipToMainImage","bypassHideOnFailure","_getThumbnailItem","_generateOnThumbnailClick","_generateOnThumbnailKeyDown","imageFallbackOptimize","shouldUseOptimizedImage","getVideoThumbNailItem","classes","_refHandler","divRef","set","which","Space","_renderVideoThumbnail","openModalDialog","_toggleModal","imageModalSlider","ZoomView","_mapProductToImageData","carouselprops","Carousel","_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","_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","callbackThumbnailKeyDown","indicatorAriaText","ariaLabelForSlide","keys","SingleSlideCarousel","vertical","flipperPrevLabel","flipperNextLabel","parentId","useTabList","JSON","stringify","renderView","ArrayExtensions","hasElements","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","_renderThumbnailItem","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","_props$context$app$co","_props$context$reques2","_props$context$reques","playVideoTitleText","_props$context$app$co2","_props$context$reques3","_item$videoData","videoThumbnail","RenderVideo","module","exports","ReactDOM"],"sourceRoot":""}