{"version":3,"file":"static/js/2899e4bd47e809b80762.bundle.js","mappings":"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","sources":["webpack://Msdyn365.Commerce.Online/./src/themes/rwb-adventureworks/views/media-gallery.view.tsx?3230","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.\r\n * All rights reserved. See LICENSE in the project root for license information.\r\n */\r\n\r\nimport { IImageData, IImageSettings, Image } from '@msdyn365-commerce/core';\r\nimport {\r\n IMediaGalleryThumbnailItemViewProps,\r\n IMediaGalleryThumbnailsViewProps,\r\n IMediaGalleryViewProps\r\n} from '@msdyn365-commerce-modules/media-gallery';\r\nimport { getFallbackImageUrl } from '@msdyn365-commerce-modules/retail-actions';\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 {Picture};\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 let fallbackImage: string | undefined = '';\r\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access -- Site level config can be of any type.\r\n const emptyPlaceHolderImage = props.context.app.config?.placeholderImageName as string;\r\n if (props.data.product.result) {\r\n fallbackImage = getFallbackImageUrl(props.data.product.result.ItemId, props.context.request.apiSettings);\r\n }\r\n if (emptyPlaceHolderImage && fallbackImage) {\r\n fallbackImage = `${fallbackImage},${emptyPlaceHolderImage}`;\r\n }\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 const defaultIndex = 0;\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 = (\r\n imageSettings: IImageSettings,\r\n props: IMediaGalleryViewProps\r\n): IMediaGalleryThumbnailItemViewProps => {\r\n let fallbackImage: string | undefined = '';\r\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access -- Site level config can be of any type.\r\n const emptyPlaceHolderImage = props.context.app.config?.placeholderImageName as string;\r\n if (props.data.product.result) {\r\n fallbackImage = getFallbackImageUrl(props.data.product.result.ItemId, props.context.request.apiSettings);\r\n }\r\n if (emptyPlaceHolderImage && fallbackImage) {\r\n fallbackImage = `${fallbackImage},${emptyPlaceHolderImage}`;\r\n }\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 = (thumbnails: IMediaGalleryThumbnailsViewProps, props: IMediaGalleryViewProps): 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'\r\n ? [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) =>\r\n GetThumbnailItemComponent(item, defaultThumbnailImageSettings, id, state.activeIndex, props)\r\n );\r\n\r\n return (\r\n \r\n {items?.map(renderThumbnailItem)}\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|rwb-adventureworks|views|media-gallery'] = {\n c: () => require('partner/themes/rwb-adventureworks/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\n private mediaGalleryImages: IImageData[] = [];\n\n private fallbackImage?: string;\n\n private readonly defaultGalleryImageSettings: IImageSettings = {\n viewports: {\n xs: { q: 'w=767&h=767&m=8', w: 0, h: 0 },\n sm: { q: 'w=600&h=600&m=8', w: 0, h: 0 },\n md: { q: 'w=600&h=772&m=8', w: 0, h: 0 },\n lg: { q: 'h=772&m=8', w: 0, h: 0 }\n },\n lazyload: true,\n cropFocalRegion: true\n };\n\n private readonly defaultThumbnailImageSettings: IImageSettings = {\n viewports: {\n xs: { q: 'w=100&m=8', w: 100, h: 0 },\n lg: { q: 'w=100&m=8', w: 100, h: 0 }\n },\n lazyload: true,\n cropFocalRegion: true\n };\n\n private readonly _zoomedImageSettings: IImageSettings;\n\n public constructor(props: IMediaGalleryProps) {\n super(props);\n this._toggleModal = this._toggleModal.bind(this);\n this.state = {\n activeIndex: 0,\n animating: false,\n isImageZoomed: false,\n modalIsOpen: false,\n isInitialLoad: true,\n shouldUseOptimizedImage: !!this.props.config.skipImageValidation\n };\n\n this._zoomedImageSettings =\n props.config.zoomedImageSettings ?? props.config.galleryImageSettings ?? this.defaultGalleryImageSettings;\n\n this._onImageMouseOut = this._onImageMouseOut.bind(this);\n this._inlineZoomImageOnHover = this._inlineZoomImageOnHover.bind(this);\n this._onInlineImageClick = this._onInlineImageClick.bind(this);\n this._onContainerZoomImageClick = this._onContainerZoomImageClick.bind(this);\n this._onMouseOutLensContainer = this._onMouseOutLensContainer.bind(this);\n }\n\n public isMobile(): boolean {\n const size = isMobile({ variant: VariantType.Viewport, context: this.props.context.request });\n return size === 'xs';\n }\n\n public async componentDidMount(): Promise {\n const source = this.props.config.imageSource ?? imageSource.pageContext;\n const shouldUpdateOnPartialDimensionSelection = this.props.config.shouldUpdateOnPartialDimensionSelection;\n this._setRenderType();\n if (!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 const source = this.props.config.imageSource ?? imageSource.pageContext;\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access -- Site level config can be of any type.\n const emptyPlaceHolderImage = this.props.context.app.config?.placeholderImageName as string;\n if (this.props.data.product.result) {\n this.fallbackImage = getFallbackImageUrl(\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 if (this.props.config.skipImageValidation && !this.state.mediaGalleryItems && this.state.isInitialLoad) {\n let images: IImageData[] = [];\n let mediaLocations: MediaLocation[] = [];\n if (source === imageSource.pageContext && this.props.data.mediaLocationsForSelectedVariant.result) {\n mediaLocations = this.props.data.mediaLocationsForSelectedVariant.result;\n } else if (source === imageSource.productId && this.props.data.mediaLocations.result) {\n mediaLocations = this.props.data.mediaLocations.result;\n }\n images = mediaLocations.map(mediaLocation => {\n return {\n src: mediaLocation.Uri ?? '',\n altText: getAltText(\n this.props.context.actionContext.requestContext,\n this.shouldUseCmsAltText(),\n this.props.data.product.result?.Name,\n mediaLocation.AltText\n )\n };\n });\n const curatedImages = this.props.config.images ?? [];\n this.mediaGalleryImages = [...this._filterMasterImageFromVariant(images), ...curatedImages];\n }\n const mediaGalleryCarouselItems = this._getMediaGalleryItems(isFullscreenAllowed, zoomViewMode);\n const mediaGalleryThumbnailCarouselItems = this._getMediaGalleryThumbnailItems();\n const viewProps: IMediaGalleryViewProps = {\n ...(this.props as IMediaGalleryProps),\n state: this.state,\n MediaGallery: {\n moduleProps: this.props,\n className: classnames(`ms-media-gallery ${isVertical ? 'vertical' : ''}`, className)\n },\n Modal: isFullscreenAllowed ? this.imageModalSlider(zoomViewMode) : null,\n callbackToggle: this.openModalDialog,\n callbackThumbnailClick: this._generateOnThumbnailClick,\n callbackThumbnailKeyDown: this._generateOnThumbnailKeyDown,\n CarouselProps: {\n tag: Carousel,\n className: 'ms-media-gallery__carousel',\n items: mediaGalleryCarouselItems.items,\n activeIndex: this.state.activeIndex,\n next: this.next,\n previous: this.previous,\n interval: false,\n directionTextPrev: resources.previousScreenshotFlipperText,\n directionTextNext: resources.nextScreenshotFlipperText,\n onIndicatorsClickHandler: this.goToIndex,\n showPaginationTooltip: showPaginationTooltip === true,\n indicatorAriaText: resources.ariaLabelForSlide,\n handleOnExited: this.onExited,\n handleOnExiting: this.onExiting,\n key: mediaGalleryCarouselItems.keys\n } as IComponentNodeProps,\n Thumbnails: {\n ThumbnailsContainerProps: { className: 'ms-media-gallery__thumbnails-container' },\n SingleSlideCarouselComponentProps: {\n tag: SingleSlideCarousel,\n className: 'ms-media-gallery__thumbnails',\n vertical: isVertical,\n flipperPrevLabel: resources.previousScreenshotFlipperText,\n flipperNextLabel: resources.nextScreenshotFlipperText,\n parentId: id,\n useTabList: true,\n key: JSON.stringify(mediaGalleryThumbnailCarouselItems.keys)\n } as IComponentNodeProps,\n items: mediaGalleryThumbnailCarouselItems.items\n }\n };\n\n return this.props.renderView(viewProps) as React.ReactElement;\n }\n\n /**\n * Zoomed out image on previous/next click.\n */\n public updateZoomedInImage(): void {\n this.setState({ isImageZoomed: false });\n }\n\n private readonly onExiting = () => {\n this.setState({ animating: true });\n };\n\n private readonly onExited = () => {\n this.setState({ animating: false });\n };\n\n /**\n * On click next in carousel.\n */\n private readonly next = (): void => {\n removeInlineZoomStyle();\n if (this.isLastItem() === undefined) {\n return;\n }\n\n const nextIndex = this.isLastItem() ? 0 : this.state.activeIndex + 1;\n this.goToIndex(nextIndex);\n\n this.updateZoomedInImage();\n };\n\n /**\n * On click previous in carousel.\n */\n private readonly previous = (): void => {\n removeInlineZoomStyle();\n const images = this.state.mediaGalleryItems;\n const nextIndex = this.isFirstItem() ? (images ? images.length - 1 : 0) : this.state.activeIndex - 1;\n this.goToIndex(nextIndex);\n this.updateZoomedInImage();\n };\n\n private readonly goToIndex = (index: number): void => {\n 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 ?? this.mediaGalleryImages;\n const thumbnailImageSettings = this.props.config.thumbnailImageSettings;\n if (thumbnailImageSettings) {\n thumbnailImageSettings.cropFocalRegion = true;\n }\n\n const hasMediaGalleryItems = ArrayExtensions.hasElements(mediaGalleryItems);\n\n if (!hasMediaGalleryItems) {\n if (this.state.lastUpdate) {\n const defaultKey = 0;\n return {\n items: [this._getEmptyThumbnailItem(thumbnailImageSettings, defaultKey, this.state.activeIndex)],\n keys: ['empty']\n };\n }\n return { items: [], keys: [] };\n }\n\n return {\n items: [\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-type-assertion\n ...mediaGalleryItems!.map((item: 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 _getMediaGalleryItems(isFullscreenAllowed: boolean, zoomViewMode: string): IMediaGalleryCarouselItems {\n const mediaGalleryItems = this.state.mediaGalleryItems ?? this.mediaGalleryImages;\n const galleryImageSettings = this.props.config.galleryImageSettings;\n if (galleryImageSettings) {\n galleryImageSettings.cropFocalRegion = true;\n }\n\n const zoomView = isFullscreenAllowed ? 'fullscreen' : zoomViewMode;\n\n const hasMediaGalleryItems = ArrayExtensions.hasElements(mediaGalleryItems);\n\n if (!hasMediaGalleryItems) {\n if (this.state.lastUpdate) {\n return { items: [this._renderEmptyImage(galleryImageSettings)], keys: ['empty'] };\n }\n return { items: [], keys: [] };\n }\n\n return {\n items: [\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-type-assertion\n ...mediaGalleryItems!.map((item: 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$context$app$co2","_props$config$thumbna2","fallbackImage","emptyPlaceHolderImage","context","app","config","placeholderImageName","data","product","result","getFallbackImageUrl","ItemId","request","apiSettings","tag","className","role","tabIndex","key","Image","requestContext","actionContext","src","gridSettings","thumbnailImageSettings","loadFailureBehavior","imageFallbackOptimize","skipImageValidation","fallBackSrc","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$context$app$co","_props$config$thumbna","onClick","_props$callbackToggle","_props$callbackThumbn","callbackToggle","call","callbackThumbnailClick","activeIndex","handleKeyDown","event","keyCode","KeyCodes","Enter","preventDefault","classnames","Button","onKeyDown","shouldUseOptimizedImage","bypassHideOnFailure","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","mediaGalleryImages","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","_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","isInPopup","arguments","shouldSkipToMainImage","_getThumbnailItem","_generateOnThumbnailClick","_generateOnThumbnailKeyDown","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","shouldUseCmsAltText","altTextSource","bind","isImageZoomed","isInitialLoad","zoomedImageSettings","galleryImageSettings","_onImageMouseOut","_inlineZoomImageOnHover","_onInlineImageClick","_onContainerZoomImageClick","_onMouseOutLensContainer","isMobile","variant","VariantType","Viewport","_this$props$config$im","_this$props$context$r","source","imageSource","shouldUpdateOnPartialDimensionSelection","_setRenderType","OmniChannelMedia","mediaLocationsForSelectedVariant","_this$props$config$th","validateProductImages","_setImages","_this$props$config$th2","getValidProductImages","RecordId","channelId","productVariant","reaction","_product$productVaria","async","_this$props$context$a","_this$props$config$th3","getProductImages","Name","fireImmediately","mediaLocations","_this$props$config$th4","shouldComponentUpdate","nextProps","nextState","render","_this$props$config$im2","_this$props$context$a2","isVertical","thumbnailsOrientation","isFullscreenAllowed","allowFullScreen","zoomViewMode","imageZoom","_this$props$context$r2","_this$props$config$im3","mediaLocation","_mediaLocation$Uri","_this$props$data$prod","Uri","getAltText","AltText","curatedImages","_filterMasterImageFromVariant","mediaGalleryCarouselItems","_getMediaGalleryItems","mediaGalleryThumbnailCarouselItems","_getMediaGalleryThumbnailItems","viewProps","moduleProps","callbackThumbnailKeyDown","indicatorAriaText","ariaLabelForSlide","keys","SingleSlideCarousel","vertical","flipperPrevLabel","flipperNextLabel","parentId","useTabList","JSON","stringify","renderView","_this$state$mediaGall","ArrayExtensions","hasElements","defaultKey","_getEmptyThumbnailItem","_this$state$mediaGall2","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","additionalProperties","isApplicableForChildEntities","_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","IsApplicableForChildEntities","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$reques","playVideoTitleText","_props$context$reques2","_item$videoData","videoThumbnail","RenderVideo","module","exports","ReactDOM"],"sourceRoot":""}