{"version":3,"file":"static/js/28528908b2ccb4742783.bundle.js","mappings":"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","sources":["webpack://bestseller.commerce.online/./src/modules/ext-media-gallery/ext-media-gallery.props.autogenerated.ts?4de4","webpack://bestseller.commerce.online/./src/modules/ext-media-gallery/utils/helper.ts?448e","webpack://bestseller.commerce.online/./src/modules/ext-media-gallery/utils/get-valid-product-images.ts?a5b9","webpack://bestseller.commerce.online/./src/modules/ext-media-gallery/ext-media-gallery.tsx?4052","webpack://bestseller.commerce.online/./src/modules/ext-media-gallery/ext-media-gallery.view.tsx?47b1","webpack://bestseller.commerce.online/./src/shared/functions/is-valid-image.ts?b7db","webpack://bestseller.commerce.online/./lib/ext-media-gallery/module-registration.js?7d2c","webpack://bestseller.commerce.online/external var \"React\"?0d3b","webpack://bestseller.commerce.online/external var \"ReactDOM\"?853b"],"sourcesContent":["/**\r\n * Copyright (c) Microsoft Corporation\r\n * All rights reserved. See License.txt in the project root for license information.\r\n * IExtMediaGallery contentModule Interface Properties\r\n * THIS FILE IS AUTO-GENERATED - MANUAL MODIFICATIONS WILL BE LOST\r\n */\r\n\r\nimport * as Msdyn365 from '@msdyn365-commerce/core';\r\n\r\nexport const enum imageSource {\r\n pageContext = 'pageContext',\r\n productId = 'productId'\r\n}\r\n\r\nexport const enum imageZoom {\r\n inline = 'inline',\r\n container = 'container'\r\n}\r\n\r\nexport const enum thumbnailsOrientation {\r\n vertical = 'vertical',\r\n horizontal = 'horizontal'\r\n}\r\n\r\nexport const enum altTextSource {\r\n product = 'product',\r\n cms = 'cms'\r\n}\r\n\r\nexport interface IExtMediaGalleryConfig extends Msdyn365.IModuleConfig {\r\n imageSource?: imageSource;\r\n images?: Msdyn365.IImageData[];\r\n productId?: string;\r\n imageZoom?: imageZoom;\r\n allowFullScreen?: boolean;\r\n dataScale?: string;\r\n zoomedImageSettings?: Msdyn365.IImageSettings;\r\n thumbnailsOrientation?: thumbnailsOrientation;\r\n thumbnailImageSettings?: Msdyn365.IImageSettings;\r\n galleryImageSettings?: Msdyn365.IImageSettings;\r\n shouldHideMasterProductImagesForVariant?: boolean;\r\n altTextSource?: altTextSource;\r\n showPaginationTooltip?: boolean;\r\n shouldUpdateOnPartialDimensionSelection?: boolean;\r\n className?: string;\r\n skipImageValidation?: boolean;\r\n autoplay?: boolean;\r\n mute?: boolean;\r\n playPauseTrigger?: boolean;\r\n controls?: boolean;\r\n clientRender?: boolean;\r\n preventImageUpdateOnSizeDimensionUpdate?: boolean;\r\n}\r\n\r\nexport interface IExtMediaGalleryResources {\r\n nextScreenshotFlipperText: string;\r\n previousScreenshotFlipperText: string;\r\n fullScreenTitleText: string;\r\n ariaLabelForSlide: string;\r\n playLabel: string;\r\n pauseLabel: string;\r\n pausedLabel: string;\r\n playingLabel: string;\r\n unMuteLabel: string;\r\n muteLabel: string;\r\n fullScreenLabel: string;\r\n exitFullScreenLabel: string;\r\n seekBarLabel: string;\r\n videoTimeDurationLabel: string;\r\n closedCaptionLabel: string;\r\n optionButtonLabel: string;\r\n sliderThumbLabel: string;\r\n volumeThumbLabel: string;\r\n playVideoTitleText: string;\r\n}\r\n\r\nexport interface IExtMediaGalleryProps extends Msdyn365.IModule {\r\n resources: IExtMediaGalleryResources;\r\n config: IExtMediaGalleryConfig;\r\n}\r\n","/*!\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\n/* eslint-disable no-duplicate-imports */\r\nimport { IImageData, IRequestContext, IVideoData } from '@msdyn365-commerce/core';\r\n\r\nexport enum MediaType {\r\n /**\r\n * The None.\r\n */\r\n None = 0,\r\n /**\r\n * The Image type.\r\n */\r\n Image = 1,\r\n /**\r\n * The video type.\r\n */\r\n Video = 2,\r\n /**\r\n * The file type.\r\n */\r\n File = 3\r\n}\r\n\r\nexport interface IMediaData extends IImageData {\r\n mediaTypeValue?: MediaType;\r\n displayOrder?: number;\r\n videoData?: IVideoData;\r\n}\r\n\r\n/**\r\n * Gets correct alt text for image based on configuration of site.\r\n * @param productName Product name.\r\n * @param context Current request context.\r\n * @param imageAltText Alt-text from CMS image.\r\n */\r\nexport function getAltText(\r\n context: IRequestContext,\r\n shouldUseCmsAltText: boolean,\r\n productName?: string,\r\n imageAltText?: string\r\n): string | undefined {\r\n if (!context?.app?.config?.OmniChannelMedia) {\r\n return productName;\r\n }\r\n if (shouldUseCmsAltText) {\r\n return imageAltText;\r\n }\r\n return productName;\r\n}\r\n","/*!\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\n/* eslint-disable no-duplicate-imports */\r\nimport {\r\n commerceApiRequest,\r\n commerceVideoMetadataRequest,\r\n getCatalogId,\r\n IActionContext,\r\n IImageData,\r\n IImageSettings,\r\n IVideoData\r\n} from '@msdyn365-commerce/core';\r\nimport { MediaLocation, SimpleProduct } from '@msdyn365-commerce/retail-proxy';\r\nimport {\r\n ArrayExtensions,\r\n getMediaLocationsForSelectedVariant,\r\n MediaLocationsForSelectedVariantInput\r\n} from '@msdyn365-commerce-modules/retail-actions';\r\nimport { getAltText } from './helper';\r\nimport { isValidImage } from '../../../shared/functions/is-valid-image';\r\n\r\nasync function validateMediaLocationAsync(mediaLocation: MediaLocation, filterLegacy?: boolean): Promise<[IImageData, boolean]> {\r\n const imageData: IImageData = {\r\n src: mediaLocation.Uri || '',\r\n altText: mediaLocation.AltText || ''\r\n };\r\n //BS CUSTOM\r\n if (mediaLocation.Uri && filterLegacy) {\r\n const fileName = mediaLocation?.Uri.split('fileName=/')[1];\r\n if (!isValidImage(fileName)) {\r\n return [imageData, false];\r\n }\r\n }\r\n if (mediaLocation.IsApplicableForChildEntities) {\r\n imageData.additionalProperties = { isApplicableForChildEntities: 'true' };\r\n }\r\n\r\n if (imageData.src === '') {\r\n return [imageData, false];\r\n }\r\n\r\n return new Promise<[IImageData, boolean]>(resolve => {\r\n try {\r\n const http = new XMLHttpRequest();\r\n http.open('HEAD', imageData.src!, true);\r\n\r\n http.addEventListener('load', () => {\r\n resolve([imageData, http.status === 200 || http.status === 201]);\r\n });\r\n\r\n http.addEventListener('error', () => {\r\n resolve([imageData, false]);\r\n });\r\n\r\n http.send();\r\n } catch {\r\n resolve([imageData, false]);\r\n }\r\n });\r\n}\r\n\r\nexport async function getValidProductImages(\r\n productId: number,\r\n channelId: number,\r\n actionContext: IActionContext,\r\n imageSettings: IImageSettings,\r\n selectedProduct?: SimpleProduct,\r\n filterLegacy?: boolean\r\n): Promise {\r\n const catalogId = getCatalogId(actionContext.requestContext);\r\n const actionInput = new MediaLocationsForSelectedVariantInput(productId, channelId, selectedProduct, catalogId);\r\n\r\n return getMediaLocationsForSelectedVariant(actionInput, actionContext)\r\n .then(mediaLocations => {\r\n if (mediaLocations) {\r\n return Promise.all(mediaLocations.map(mediaLocation => validateMediaLocationAsync(mediaLocation, filterLegacy))).then(\r\n pairs => {\r\n return pairs.filter(pair => pair[1]).map(pair => pair[0]);\r\n }\r\n );\r\n }\r\n\r\n return [];\r\n })\r\n .catch(error => {\r\n actionContext.telemetry.exception(error);\r\n actionContext.telemetry.debug('Unable to get Media Locations for Selected Variant');\r\n return [];\r\n });\r\n}\r\n\r\n/**\r\n * Gets product variant images on dimension change of buy-box module for Omni scenario.\r\n * @param productId Product record id.\r\n * @param shouldUseCmsAltText Alt-text source to use.\r\n * @param channelId Current channel id.\r\n * @param actionContext Current action context.\r\n * @param productName Product name.\r\n * @param selectedProduct Currently selected variant product.\r\n * @returns List of images.\r\n */\r\n\r\nexport async function getProductImages(\r\n productId: number,\r\n shouldUseCmsAltText: boolean,\r\n channelId: number,\r\n actionContext: IActionContext,\r\n productName?: string,\r\n selectedProduct?: SimpleProduct\r\n): Promise {\r\n const catalogId = getCatalogId(actionContext.requestContext);\r\n if (actionContext.requestContext?.params?.isPreview) {\r\n const response = await commerceApiRequest(actionContext.requestContext, 'msdyn365-ochannel-product-info', 'post', {\r\n productId: productId,\r\n channelId: channelId,\r\n catalogId: catalogId\r\n });\r\n if (response.status !== 200) {\r\n actionContext.telemetry.debug('Unable to get Media Locations for Selected Variant for preview scenario');\r\n return [];\r\n }\r\n const previewImageData = response?.data as MediaLocation[];\r\n if (previewImageData) {\r\n return previewImageData.map(mediaLocation => {\r\n return {\r\n src: mediaLocation.Uri ?? '',\r\n altText: getAltText(actionContext.requestContext, shouldUseCmsAltText, productName, mediaLocation.AltText),\r\n displayOrder: mediaLocation.DisplayOrder,\r\n mediaTypeValue: mediaLocation.MediaTypeValue,\r\n additionalProperties: mediaLocation.IsApplicableForChildEntities\r\n ? {\r\n isApplicableForChildEntities: 'true'\r\n }\r\n : undefined\r\n };\r\n });\r\n }\r\n return [];\r\n }\r\n const actionInput = new MediaLocationsForSelectedVariantInput(productId, channelId, selectedProduct, catalogId);\r\n return getMediaLocationsForSelectedVariant(actionInput, actionContext)\r\n .then(mediaLocations => {\r\n if (mediaLocations) {\r\n return mediaLocations.map(mediaLocation => {\r\n return {\r\n src: mediaLocation.Uri ?? '',\r\n altText: getAltText(actionContext.requestContext, shouldUseCmsAltText, productName, mediaLocation.AltText),\r\n displayOrder: mediaLocation.DisplayOrder,\r\n mediaTypeValue: mediaLocation.MediaTypeValue,\r\n additionalProperties: mediaLocation.IsApplicableForChildEntities\r\n ? {\r\n isApplicableForChildEntities: 'true'\r\n }\r\n : undefined\r\n };\r\n });\r\n }\r\n return [];\r\n })\r\n .catch(error => {\r\n actionContext.telemetry.exception(error);\r\n actionContext.telemetry.debug('Unable to get Media Locations for Selected Variant');\r\n return [];\r\n });\r\n}\r\n\r\nexport async function validateProductImages(\r\n mediaLocations: MediaLocation[],\r\n actionContext: IActionContext,\r\n imageSettings: IImageSettings,\r\n filterLegacy?: boolean\r\n): Promise {\r\n return Promise.all(mediaLocations.map(mediaLocation => validateMediaLocationAsync(mediaLocation, filterLegacy)))\r\n .then(pairs => {\r\n return pairs.filter(pair => pair[1]).map(pair => pair[0]);\r\n })\r\n .catch(error => {\r\n actionContext.telemetry.exception(error);\r\n actionContext.telemetry.debug('Unable to validate product images');\r\n return [];\r\n });\r\n}\r\n\r\n/**\r\n * GetVideoMetadataFromAPI - Makes API call to get video metadata.\r\n * @param videoId: Video Id\r\n * @param actionContext: Action context\r\n * @returns: Returns the meta data of the video.\r\n */\r\nexport async function getVideoMetadataFromApi(videoId: string, actionContext: IActionContext): Promise {\r\n let videoPlayerData: IVideoData | undefined;\r\n if (videoId) {\r\n const response = await commerceVideoMetadataRequest(actionContext.requestContext, [videoId]);\r\n\r\n if (response.status !== 200) {\r\n actionContext.telemetry.debug(`Unable to get video metadata for videoId: ${videoId}`);\r\n return;\r\n }\r\n\r\n const videoData = response.data as [];\r\n if (videoData && ArrayExtensions.hasElements(videoData)) {\r\n videoPlayerData = videoData[0];\r\n }\r\n }\r\n return videoPlayerData;\r\n}\r\n","/*!\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\n/* eslint-disable no-duplicate-imports */\r\nimport { Carousel, ICarouselProps, Player, IPlayerData, IPlayerOptions, IVideoMetadata } from '@msdyn365-commerce/components';\r\nimport { IImageData, IImageSettings, Image, Video } from '@msdyn365-commerce/core';\r\nimport { MediaLocation, MediaType, SimpleProduct } from '@msdyn365-commerce/retail-proxy';\r\nimport { ArrayExtensions, getFallbackImageUrl, ISelectedProduct, ObjectExtensions } from '@msdyn365-commerce-modules/retail-actions';\r\nimport {\r\n defaultDataScale,\r\n IComponentNodeProps,\r\n ImagefullView,\r\n IModalViewProps,\r\n IModuleProps,\r\n inlineZoomImageOnHover,\r\n inlineZoomImageOnMouseMove,\r\n inlineZoomImageOnMouseOut,\r\n inlineZoomInitClick,\r\n INodeProps,\r\n ISingleSlideCarouselProps,\r\n isMobile,\r\n KeyCodes,\r\n NodeTag,\r\n onContainerZoomInit,\r\n onMouseMoveLensContainer,\r\n onMouseOutLensContainer,\r\n onMouseOverImageContainer,\r\n removeContainerZoomStyle,\r\n removeInlineZoomStyle,\r\n SingleSlideCarousel,\r\n VariantType\r\n} from '@msdyn365-commerce-modules/utilities';\r\nimport classnames from 'classnames';\r\nimport { reaction } from 'mobx';\r\nimport * as React from 'react';\r\n\r\nimport { IExtMediaGalleryData } from './ext-media-gallery.data';\r\nimport { imageSource, imageZoom, IExtMediaGalleryProps, thumbnailsOrientation } from './ext-media-gallery.props.autogenerated';\r\nimport { getProductImages, getValidProductImages, getVideoMetadataFromApi, validateProductImages } from './utils';\r\nimport { getAltText, IMediaData } from './utils/helper';\r\n\r\n/**\r\n * IMediaGalleryState Interface.\r\n */\r\nexport interface IMediaGalleryState {\r\n animating: boolean;\r\n activeIndex: number;\r\n isImageZoomed: boolean;\r\n modalIsOpen: boolean;\r\n lastUpdate?: number;\r\n isMobileImageZoomed?: boolean;\r\n mediaGalleryItems?: IMediaData[];\r\n isInitialLoad?: boolean;\r\n shouldUseOptimizedImage?: boolean;\r\n lastSelectedProduct?: ISelectedProduct;\r\n}\r\n\r\n/**\r\n * IMediaGalleryThumbnailsViewProps Interface.\r\n */\r\nexport interface IMediaGalleryThumbnailsViewProps {\r\n ThumbnailsContainerProps: INodeProps;\r\n SingleSlideCarouselComponentProps: INodeProps;\r\n items?: IMediaGalleryThumbnailItemViewProps[];\r\n}\r\n\r\n/**\r\n * IMediaGalleryThumbnailItemViewProps Interface.\r\n */\r\nexport interface IMediaGalleryThumbnailItemViewProps {\r\n ThumbnailItemContainerProps: INodeProps;\r\n Picture: React.ReactElement;\r\n}\r\n\r\n/**\r\n * IMediaGalleryViewProps Interface.\r\n */\r\nexport interface IMediaGalleryViewProps extends IExtMediaGalleryProps {\r\n state: IMediaGalleryState;\r\n MediaGallery: IModuleProps;\r\n CarouselProps: INodeProps;\r\n Thumbnails: IMediaGalleryThumbnailsViewProps;\r\n Modal?: React.ReactElement | null;\r\n callbackToggle?(): void;\r\n callbackThumbnailClick?(index: number): void;\r\n callbackThumbnailKeyDown?(index: number): void;\r\n}\r\n\r\n/**\r\n * Props for carousel.\r\n */\r\ninterface IMediaGalleryCarouselItems {\r\n items: ItemType[];\r\n keys: (string | undefined)[];\r\n}\r\n\r\n/**\r\n * Media gallery component.\r\n */\r\nclass MediaGallery extends React.Component, IMediaGalleryState> {\r\n private readonly _inlineZoomDivRef: Map = new Map();\r\n\r\n private readonly fullScreenOverlayButtonRef: React.RefObject = React.createRef();\r\n private readonly player: React.RefObject = React.createRef();\r\n private fallbackImage?: string;\r\n\r\n private readonly defaultGalleryImageSettings: IImageSettings = {\r\n viewports: {\r\n xs: { q: 'w=767&h=767&m=8', w: 0, h: 0 },\r\n sm: { q: 'w=600&h=600&m=8', w: 0, h: 0 },\r\n md: { q: 'w=600&h=772&m=8', w: 0, h: 0 },\r\n lg: { q: 'h=772&m=8', w: 0, h: 0 }\r\n },\r\n lazyload: true,\r\n cropFocalRegion: true\r\n };\r\n\r\n private readonly defaultThumbnailImageSettings: IImageSettings = {\r\n viewports: {\r\n xs: { q: 'w=100&m=8', w: 100, h: 0 },\r\n lg: { q: 'w=100&m=8', w: 100, h: 0 }\r\n },\r\n lazyload: true,\r\n cropFocalRegion: true\r\n };\r\n\r\n private readonly _zoomedImageSettings: IImageSettings;\r\n\r\n public constructor(props: IExtMediaGalleryProps) {\r\n super(props);\r\n this._toggleModal = this._toggleModal.bind(this);\r\n const mediaGalleryImages = this.getImagesData();\r\n this.state = {\r\n activeIndex: 0,\r\n animating: false,\r\n isImageZoomed: false,\r\n modalIsOpen: false,\r\n isInitialLoad: true,\r\n shouldUseOptimizedImage: !!this.props.config.skipImageValidation,\r\n mediaGalleryItems: mediaGalleryImages\r\n };\r\n\r\n this._zoomedImageSettings =\r\n props.config.zoomedImageSettings ?? props.config.galleryImageSettings ?? this.defaultGalleryImageSettings;\r\n\r\n this._onImageMouseOut = this._onImageMouseOut.bind(this);\r\n this._inlineZoomImageOnHover = this._inlineZoomImageOnHover.bind(this);\r\n this._onInlineImageClick = this._onInlineImageClick.bind(this);\r\n this._onContainerZoomImageClick = this._onContainerZoomImageClick.bind(this);\r\n this._onMouseOutLensContainer = this._onMouseOutLensContainer.bind(this);\r\n }\r\n\r\n public isMobile(): boolean {\r\n const size = isMobile({ variant: VariantType.Viewport, context: this.props.context.request });\r\n return size === 'xs';\r\n }\r\n\r\n public async componentDidMount(): Promise {\r\n const source = this.props.config.imageSource ?? imageSource.pageContext;\r\n const shouldUpdateOnPartialDimensionSelection = this.props.config.shouldUpdateOnPartialDimensionSelection;\r\n this._setRenderType();\r\n if (!this.props.context.request.app?.config?.OmniChannelMedia) {\r\n if (source === imageSource.pageContext) {\r\n if (this.state.mediaGalleryItems === undefined && this.props.data.mediaLocationsForSelectedVariant.result) {\r\n const images = await validateProductImages(\r\n this.props.data.mediaLocationsForSelectedVariant.result,\r\n this.props.context.actionContext,\r\n this.props.config.thumbnailImageSettings ?? this.defaultThumbnailImageSettings,\r\n this.props.app.config.filterLegacyImageUrls\r\n );\r\n await this._setImages(images);\r\n } else if (this.state.mediaGalleryItems === undefined && this.props.data.product.result) {\r\n const product = this.props.data.product.result;\r\n const images = await getValidProductImages(\r\n product.RecordId,\r\n +this.props.context.request.apiSettings.channelId,\r\n this.props.context.actionContext,\r\n this.props.config.thumbnailImageSettings ?? this.defaultThumbnailImageSettings,\r\n product.productVariant,\r\n this.props.app.config.filterLegacyImageUrls\r\n );\r\n\r\n await this._setImages(images);\r\n } else {\r\n await this._setImages([]);\r\n }\r\n }\r\n }\r\n\r\n reaction(\r\n () => {\r\n const product = this.props.data.product.result;\r\n if (!product) {\r\n return null;\r\n }\r\n\r\n if (!shouldUpdateOnPartialDimensionSelection || !product.productVariant?.RecordId) {\r\n return `${product.RecordId}`;\r\n }\r\n\r\n return `${product.RecordId}-${product.productVariant.RecordId}`;\r\n },\r\n async () => {\r\n const product = this.props.data.product.result;\r\n let images: IImageData[] = [];\r\n if (product) {\r\n if (this.props.config.preventImageUpdateOnSizeDimensionUpdate) {\r\n const { lastSelectedProduct } = this.state;\r\n let differsBeyondSize = false;\r\n if (!lastSelectedProduct) {\r\n differsBeyondSize = true;\r\n } else {\r\n // check previous variant's dimensions against new one\r\n product?.Dimensions?.forEach(dimension => {\r\n const lastSelectedDimension = lastSelectedProduct?.Dimensions?.find(\r\n lastDimension =>\r\n dimension.DimensionTypeValue === lastDimension.DimensionTypeValue &&\r\n dimension.DimensionValue?.Value !== lastDimension.DimensionValue?.Value\r\n );\r\n // there'll only be a dimension to look at if it had a different value\r\n // 3 = size dimeension inside D365\r\n if (lastSelectedDimension && lastSelectedDimension.DimensionTypeValue !== 3) {\r\n differsBeyondSize = true;\r\n }\r\n });\r\n }\r\n this.setState({ lastSelectedProduct: product });\r\n //If the dimensions are the same, we don't need to update the images\r\n if (!differsBeyondSize) {\r\n return;\r\n }\r\n }\r\n if (this.props.context.app?.config?.OmniChannelMedia) {\r\n images = await getProductImages(\r\n product.RecordId,\r\n this.shouldUseCmsAltText(),\r\n +this.props.context.request.apiSettings.channelId,\r\n this.props.context.actionContext,\r\n product.Name,\r\n shouldUpdateOnPartialDimensionSelection ? product.productVariant : undefined\r\n );\r\n } else {\r\n images = await getValidProductImages(\r\n product.RecordId,\r\n +this.props.context.request.apiSettings.channelId,\r\n this.props.context.actionContext,\r\n this.props.config.thumbnailImageSettings ?? this.defaultThumbnailImageSettings,\r\n shouldUpdateOnPartialDimensionSelection ? product.productVariant : undefined,\r\n this.props.app.config.filterLegacyImageUrls\r\n );\r\n }\r\n await this._setImages(images);\r\n } else {\r\n await this._setImages([]);\r\n }\r\n },\r\n { fireImmediately: true }\r\n );\r\n\r\n if (source === imageSource.productId && this.props.data.mediaLocations.result) {\r\n const images = await validateProductImages(\r\n this.props.data.mediaLocations.result,\r\n this.props.context.actionContext,\r\n this.props.config.thumbnailImageSettings ?? this.defaultThumbnailImageSettings,\r\n this.props.app.config.filterLegacyImageUrls\r\n );\r\n await this._setImages(images);\r\n }\r\n }\r\n\r\n public shouldComponentUpdate(nextProps: IExtMediaGalleryProps, nextState: IMediaGalleryState): boolean {\r\n if (this.state === nextState && this.props.data === nextProps.data) {\r\n return false;\r\n }\r\n return true;\r\n }\r\n\r\n public render(): JSX.Element {\r\n const { id, config, resources } = this.props;\r\n\r\n const { className, showPaginationTooltip } = config;\r\n\r\n const isVertical: boolean = config.thumbnailsOrientation === thumbnailsOrientation.vertical;\r\n // eslint-disable-next-line @typescript-eslint/prefer-nullish-coalescing -- || is required.\r\n const isFullscreenAllowed: boolean = this.isMobile() || config.allowFullScreen || false;\r\n const zoomViewMode: string =\r\n config.imageZoom === imageZoom.inline ? imageZoom.inline : config.imageZoom === imageZoom.container ? imageZoom.container : '';\r\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access -- Site level config can be of any type.\r\n const emptyPlaceHolderImage = this.props.context.app.config?.placeholderImageName as string;\r\n if (this.props.data.product.result) {\r\n this.fallbackImage = getFallbackImageUrl(\r\n this.props.data.product.result.ItemId,\r\n this.props.context.request.apiSettings,\r\n this.props.context.request.app?.config?.OmniChannelMedia\r\n );\r\n }\r\n if (emptyPlaceHolderImage && this.fallbackImage) {\r\n this.fallbackImage = `${this.fallbackImage}&fallback=${emptyPlaceHolderImage}`;\r\n }\r\n\r\n const mediaGalleryCarouselItems = this._getMediaGalleryItems(isFullscreenAllowed, zoomViewMode);\r\n const mediaGalleryThumbnailCarouselItems = this._getMediaGalleryThumbnailItems();\r\n const viewProps: IMediaGalleryViewProps = {\r\n ...(this.props as IExtMediaGalleryProps),\r\n state: this.state,\r\n MediaGallery: {\r\n moduleProps: this.props,\r\n className: classnames(`ms-media-gallery ${isVertical ? 'vertical' : ''}`, className)\r\n },\r\n Modal: isFullscreenAllowed ? this.imageModalSlider(zoomViewMode) : null,\r\n callbackToggle: this.openModalDialog,\r\n callbackThumbnailClick: this._generateOnThumbnailClick,\r\n callbackThumbnailKeyDown: this._generateOnThumbnailKeyDown,\r\n CarouselProps: {\r\n tag: Carousel,\r\n className: 'ms-media-gallery__carousel',\r\n items: mediaGalleryCarouselItems.items,\r\n activeIndex: this.state.activeIndex,\r\n next: this.next,\r\n previous: this.previous,\r\n interval: false,\r\n directionTextPrev: resources.previousScreenshotFlipperText,\r\n directionTextNext: resources.nextScreenshotFlipperText,\r\n onIndicatorsClickHandler: this.goToIndex,\r\n showPaginationTooltip: showPaginationTooltip === true,\r\n indicatorAriaText: resources.ariaLabelForSlide,\r\n handleOnExited: this.onExited,\r\n handleOnExiting: this.onExiting,\r\n key: mediaGalleryCarouselItems.keys\r\n } as IComponentNodeProps,\r\n Thumbnails: {\r\n ThumbnailsContainerProps: { className: 'ms-media-gallery__thumbnails-container' },\r\n SingleSlideCarouselComponentProps: {\r\n tag: SingleSlideCarousel,\r\n className: 'ms-media-gallery__thumbnails',\r\n vertical: isVertical,\r\n flipperPrevLabel: resources.previousScreenshotFlipperText,\r\n flipperNextLabel: resources.nextScreenshotFlipperText,\r\n parentId: id,\r\n useTabList: true,\r\n key: JSON.stringify(mediaGalleryThumbnailCarouselItems.keys)\r\n } as IComponentNodeProps,\r\n items: mediaGalleryThumbnailCarouselItems.items\r\n }\r\n };\r\n\r\n return this.props.renderView(viewProps) as React.ReactElement;\r\n }\r\n\r\n /**\r\n * Zoomed out image on previous/next click.\r\n */\r\n public updateZoomedInImage(): void {\r\n this.setState({ isImageZoomed: false });\r\n }\r\n\r\n private readonly onExiting = () => {\r\n this.setState({ animating: true });\r\n };\r\n\r\n private readonly onExited = () => {\r\n this.setState({ animating: false });\r\n };\r\n\r\n /**\r\n * On click next in carousel.\r\n */\r\n private readonly next = (): void => {\r\n removeInlineZoomStyle();\r\n if (this.isLastItem() === undefined) {\r\n return;\r\n }\r\n\r\n const nextIndex = this.isLastItem() ? 0 : this.state.activeIndex + 1;\r\n this.goToIndex(nextIndex);\r\n\r\n this.updateZoomedInImage();\r\n };\r\n\r\n /**\r\n * On click previous in carousel.\r\n */\r\n private readonly previous = (): void => {\r\n removeInlineZoomStyle();\r\n const images = this.state.mediaGalleryItems;\r\n const nextIndex = this.isFirstItem() ? (images ? images.length - 1 : 0) : this.state.activeIndex - 1;\r\n this.goToIndex(nextIndex);\r\n this.updateZoomedInImage();\r\n };\r\n\r\n private readonly goToIndex = (index: number): void => {\r\n const { autoplay } = this.props.config;\r\n const currentIndex = this.state.activeIndex;\r\n const mediaItems = this.state.mediaGalleryItems;\r\n if (autoplay && mediaItems) {\r\n if (mediaItems[`${index}`]?.mediaTypeValue === MediaType.Video) {\r\n this.player.current?.play();\r\n } else if (mediaItems[`${currentIndex}`].mediaTypeValue === MediaType.Video) {\r\n this.player.current?.pause();\r\n }\r\n }\r\n this.setState({ activeIndex: index });\r\n };\r\n\r\n private _getMediaGalleryThumbnailItems(): IMediaGalleryCarouselItems {\r\n const mediaGalleryItems = this.state.mediaGalleryItems;\r\n const thumbnailImageSettings = this.props.config.thumbnailImageSettings;\r\n if (thumbnailImageSettings) {\r\n thumbnailImageSettings.cropFocalRegion = true;\r\n }\r\n\r\n const hasMediaGalleryItems = ArrayExtensions.hasElements(mediaGalleryItems);\r\n\r\n if (!hasMediaGalleryItems) {\r\n if (this.state.lastUpdate) {\r\n const defaultKey = 0;\r\n return {\r\n items: [this._getEmptyThumbnailItem(thumbnailImageSettings, defaultKey, this.state.activeIndex)],\r\n keys: ['empty']\r\n };\r\n }\r\n return { items: [], keys: [] };\r\n }\r\n\r\n return {\r\n items: [\r\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-type-assertion\r\n ...mediaGalleryItems!.map((item: IMediaData, index: number) => {\r\n if (item.mediaTypeValue === MediaType.Video) {\r\n return this.getVideoThumbNailItem(\r\n item,\r\n thumbnailImageSettings ?? this.defaultThumbnailImageSettings,\r\n index,\r\n this.state.activeIndex\r\n );\r\n } else {\r\n return this._getThumbnailItem(\r\n item,\r\n thumbnailImageSettings ?? this.defaultThumbnailImageSettings,\r\n index,\r\n this.state.activeIndex\r\n );\r\n }\r\n })\r\n ],\r\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-type-assertion\r\n keys: [...mediaGalleryItems!.map(item => item.src)]\r\n };\r\n }\r\n\r\n private getImagesData = (): IImageData[] => {\r\n if (this.props.config.skipImageValidation || this.props.context.request.app?.config?.OmniChannelMedia) {\r\n const source = this.props.config.imageSource ?? imageSource.pageContext;\r\n let images: IImageData[] = [];\r\n let mediaLocations: MediaLocation[] = [];\r\n if (source === imageSource.pageContext && this.props.data.mediaLocationsForSelectedVariant.result) {\r\n mediaLocations = this.props.data.mediaLocationsForSelectedVariant.result;\r\n } else if (source === imageSource.productId && this.props.data.mediaLocations.result) {\r\n mediaLocations = this.props.data.mediaLocations.result;\r\n }\r\n images = mediaLocations.map(mediaLocation => {\r\n return {\r\n src: mediaLocation.Uri ?? '',\r\n altText: getAltText(\r\n this.props.context.actionContext.requestContext,\r\n this.shouldUseCmsAltText(),\r\n this.props.data.product.result?.Name,\r\n mediaLocation.AltText\r\n ),\r\n additionalProperties: mediaLocation.IsApplicableForChildEntities\r\n ? {\r\n isApplicableForChildEntities: 'true'\r\n }\r\n : undefined\r\n };\r\n });\r\n const curatedImages = this.props.config.images ?? [];\r\n\r\n return [...this._filterMasterImageFromVariant(images), ...curatedImages];\r\n }\r\n return [];\r\n };\r\n\r\n private _getMediaGalleryItems(isFullscreenAllowed: boolean, zoomViewMode: string): IMediaGalleryCarouselItems {\r\n const mediaGalleryItems = this.state.mediaGalleryItems;\r\n const galleryImageSettings = this.props.config.galleryImageSettings;\r\n if (galleryImageSettings) {\r\n galleryImageSettings.cropFocalRegion = true;\r\n }\r\n\r\n const zoomView = isFullscreenAllowed ? 'fullscreen' : zoomViewMode;\r\n\r\n const hasMediaGalleryItems = ArrayExtensions.hasElements(mediaGalleryItems);\r\n\r\n if (!hasMediaGalleryItems) {\r\n if (this.state.lastUpdate) {\r\n return { items: [this._renderEmptyImage(galleryImageSettings)], keys: ['empty'] };\r\n }\r\n return { items: [], keys: [] };\r\n }\r\n\r\n return {\r\n items: [\r\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-type-assertion\r\n ...mediaGalleryItems!.map((item: IMediaData, index: number) => {\r\n return this._renderCarouselItemImageView(\r\n zoomView,\r\n item,\r\n galleryImageSettings ?? this.defaultGalleryImageSettings,\r\n index\r\n );\r\n })\r\n ],\r\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-type-assertion\r\n keys: [...mediaGalleryItems!.map(item => item.src)]\r\n };\r\n }\r\n\r\n private async _setImages(images?: IMediaData[]): Promise {\r\n const curatedImage = this.props.config.images || [];\r\n const mediaToSet: IMediaData[] = this._filterMasterImageFromVariant(images);\r\n console.log('mediaToSet', mediaToSet);\r\n\r\n void Promise.all(\r\n mediaToSet.map(async mediaData => {\r\n if (mediaData.mediaTypeValue === MediaType.Video && mediaData.src) {\r\n try {\r\n const url = new URL(mediaData.src);\r\n const videoId = url.searchParams.get('CVID');\r\n if (videoId) {\r\n mediaData.videoData = await getVideoMetadataFromApi(videoId, this.props.context.actionContext);\r\n }\r\n } catch (error) {\r\n if (this.props.telemetry) {\r\n this.props.telemetry.debug('Error while fetching videoId');\r\n }\r\n }\r\n }\r\n return mediaData;\r\n })\r\n ).then(mediaData => {\r\n const mediaItems = mediaData.filter(element => {\r\n return (\r\n element.mediaTypeValue !== MediaType.Video ||\r\n (element.mediaTypeValue === MediaType.Video && element.videoData !== undefined)\r\n );\r\n });\r\n\r\n this.setState({\r\n mediaGalleryItems: [...mediaItems, ...curatedImage],\r\n activeIndex: 0,\r\n lastUpdate: Date.now(),\r\n shouldUseOptimizedImage: false\r\n });\r\n });\r\n\r\n this.setState({\r\n mediaGalleryItems: [...mediaToSet, ...curatedImage],\r\n activeIndex: 0,\r\n lastUpdate: Date.now(),\r\n shouldUseOptimizedImage: false\r\n });\r\n }\r\n\r\n private _setRenderType(): void {\r\n this.setState({\r\n isInitialLoad: false\r\n });\r\n }\r\n\r\n private _renderCarouselItemImageView(\r\n zoomView: string,\r\n media: IMediaData,\r\n imageSettings: IImageSettings,\r\n index: number,\r\n isInPopup: boolean = false\r\n ): React.ReactNode {\r\n if (media.mediaTypeValue === MediaType.Video) {\r\n if (isInPopup || zoomView !== 'fullscreen') {\r\n return <>{this._renderCarouselItemVideo(media, index, imageSettings)};\r\n }\r\n return <>{this._renderVideoThumbnail(media, index, imageSettings)};\r\n } else {\r\n if (this.isMobile()) {\r\n if (isInPopup) {\r\n return this._renderImageInContainerOnZoom(media, this._zoomedImageSettings, index);\r\n }\r\n return this._renderImageFullScreenOnZoom(media, imageSettings, index);\r\n }\r\n\r\n switch (zoomView) {\r\n case 'container': {\r\n return this._renderImageInContainerOnZoom(media, this._zoomedImageSettings, index);\r\n }\r\n case 'inline': {\r\n return this._renderImageInlineOnZoom(media, this._zoomedImageSettings, index);\r\n }\r\n case 'fullscreen': {\r\n return this._renderImageFullScreenOnZoom(media, imageSettings, index);\r\n }\r\n\r\n // No default\r\n }\r\n return <>{this._getCarouselItem(media, imageSettings, index, isInPopup)};\r\n }\r\n }\r\n\r\n private _filterMasterImageFromVariant(images?: IImageData[]): IImageData[] {\r\n const shouldHidePrimaryImages = this.props.config.shouldHideMasterProductImagesForVariant ?? true;\r\n let variantImages = images ?? [];\r\n const isVariantProduct =\r\n !ObjectExtensions.isNullOrUndefined(this.props.data.product.result?.MasterProductId) ||\r\n !ObjectExtensions.isNullOrUndefined(this.props.data.product.result?.productVariant);\r\n const itemId = this.props.data.product.result?.ItemId;\r\n if (shouldHidePrimaryImages && isVariantProduct && itemId) {\r\n variantImages = variantImages.filter(item => {\r\n const isApplicableForChildEntities = item.additionalProperties?.isApplicableForChildEntities;\r\n return !isApplicableForChildEntities;\r\n });\r\n if (!ArrayExtensions.hasElements(variantImages)) {\r\n variantImages = images ?? [];\r\n }\r\n }\r\n return variantImages;\r\n }\r\n\r\n private readonly _renderCarouselItemVideo = (mediaData: IMediaData, index: number, imageSettings: IImageSettings): React.ReactNode => {\r\n const videoData = mediaData.videoData;\r\n if (videoData) {\r\n const options: IPlayerOptions = this.props.config as IPlayerOptions;\r\n const playerResources = this.props.resources;\r\n const videoMetaData: IVideoMetadata = {};\r\n videoMetaData.videoId = videoData.id;\r\n videoMetaData.title = videoData.title;\r\n videoMetaData.duration = videoData.playTime;\r\n if (videoData.thumbnail) {\r\n videoMetaData.posterframeUrl = videoData.thumbnail.src;\r\n }\r\n if (videoData._links?.binaryReferences) {\r\n videoMetaData.videoBinaryReferences = videoData._links.binaryReferences;\r\n }\r\n const videoPlayerData: IPlayerData = { options, metaData: videoMetaData };\r\n const attributes = {\r\n id: `${this.props.id}__carousel-item__${index}`\r\n };\r\n return (\r\n \r\n );\r\n }\r\n return this._renderEmptyImage(imageSettings);\r\n };\r\n\r\n private readonly _getCarouselItem = (\r\n image: IImageData,\r\n imageSettings: IImageSettings,\r\n index: number,\r\n isInPopup: boolean = false\r\n ): React.ReactNode => (\r\n \r\n );\r\n\r\n private readonly _getThumbnailItem = (\r\n image: IImageData,\r\n imageSettings: IImageSettings,\r\n index: number,\r\n modifiedActiveIndex: number\r\n ): IMediaGalleryThumbnailItemViewProps => {\r\n const classes = classnames(\r\n 'ms-media-gallery__thumbnail-item',\r\n modifiedActiveIndex === index ? 'ms-media-gallery__thumbnail-item-active' : ''\r\n );\r\n\r\n return {\r\n ThumbnailItemContainerProps: {\r\n tag: 'li' as NodeTag,\r\n className: classes,\r\n role: 'tab',\r\n tabIndex: 0,\r\n key: index,\r\n 'aria-label': image.altText,\r\n 'aria-selected': modifiedActiveIndex === index,\r\n onClick: this._generateOnThumbnailClick(index),\r\n onKeyDown: this._generateOnThumbnailKeyDown(index)\r\n },\r\n Picture: (\r\n \r\n )\r\n };\r\n };\r\n\r\n /**\r\n * Gets the video thumbnail item to display media gallery.\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 video.\r\n */\r\n private readonly getVideoThumbNailItem = (\r\n mediaData: IMediaData,\r\n imageSettings: IImageSettings,\r\n index: number,\r\n modifiedActiveIndex: number\r\n ): IMediaGalleryThumbnailItemViewProps => {\r\n const classes = classnames(\r\n 'ms-media-gallery__thumbnail-item',\r\n modifiedActiveIndex === index ? 'ms-media-gallery__thumbnail-item-active' : ''\r\n );\r\n\r\n const videoData = mediaData.videoData;\r\n let image: IImageData;\r\n if (videoData?.thumbnail) {\r\n image = videoData.thumbnail;\r\n } else {\r\n image = {\r\n src: 'empty'\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: 'tab',\r\n tabIndex: 0,\r\n key: index,\r\n 'aria-label': image.altText,\r\n 'aria-selected': modifiedActiveIndex === index,\r\n onClick: this._generateOnThumbnailClick(index),\r\n onKeyDown: this._generateOnThumbnailKeyDown(index)\r\n },\r\n Picture: (\r\n \r\n )\r\n };\r\n };\r\n\r\n /**\r\n * Ref Handler.\r\n * @param index -Remove item click function.\r\n * @returns Set inline zoom.\r\n */\r\n private readonly _refHandler = (index: number) => (divRef: HTMLDivElement) => {\r\n this._inlineZoomDivRef.set(index, divRef);\r\n };\r\n\r\n private readonly _generateOnThumbnailKeyDown = (index: number) => {\r\n return (event: React.KeyboardEvent) => {\r\n if (event.which === KeyCodes.Enter || event.which === KeyCodes.Space) {\r\n event.preventDefault();\r\n\r\n this.goToIndex(index);\r\n }\r\n };\r\n };\r\n\r\n private readonly _generateOnThumbnailClick = (index: number) => {\r\n return (event: React.MouseEvent) => {\r\n event.preventDefault();\r\n\r\n this.goToIndex(index);\r\n };\r\n };\r\n\r\n private _renderImageInlineOnZoom(image: IImageData, imageSettings: IImageSettings, index: number): React.ReactNode {\r\n return (\r\n \r\n \r\n \r\n \r\n );\r\n }\r\n\r\n private _inlineZoomImageOnHover(event: React.MouseEvent): void {\r\n inlineZoomImageOnHover(event, this.props.config.dataScale ?? String(defaultDataScale));\r\n }\r\n\r\n private _handleMobileViewZoomedImageClick(event: React.MouseEvent) {\r\n const target = this.state.shouldUseOptimizedImage ? (event.target as HTMLImageElement) : event.currentTarget;\r\n const mobileZoomedInImageClassName = 'msc-mobile-zoomed-in';\r\n if (!this.state.isMobileImageZoomed) {\r\n const bounds = target.getBoundingClientRect();\r\n const dataScale = Number(this.props.config.dataScale ?? defaultDataScale);\r\n\r\n const positionX = event.clientX - bounds.left;\r\n const positionY = event.clientY - bounds.top;\r\n const scaledPositionX = positionX * dataScale;\r\n const scaledPositionY = positionY * dataScale;\r\n\r\n target.style.transform = `scale(${dataScale})`;\r\n target.classList.add(mobileZoomedInImageClassName);\r\n target.parentElement!.style.overflow = 'auto';\r\n target.parentElement!.scrollTo(scaledPositionX - positionX, scaledPositionY - positionY);\r\n this.setState({\r\n isMobileImageZoomed: true\r\n });\r\n } else {\r\n target.style.transform = '';\r\n target.classList.remove(mobileZoomedInImageClassName);\r\n target.parentElement!.style.overflow = '';\r\n this.setState({\r\n isMobileImageZoomed: false\r\n });\r\n }\r\n }\r\n\r\n private _onInlineImageClick(event: React.MouseEvent): void {\r\n if (window.innerWidth <= 768) {\r\n // $msv-breakpoint-m\r\n this._handleMobileViewZoomedImageClick(event);\r\n return;\r\n }\r\n inlineZoomInitClick(event, this.props.config.dataScale ?? String(defaultDataScale));\r\n this.setState({\r\n isImageZoomed: true\r\n });\r\n }\r\n\r\n private _onImageMouseOut(event: React.MouseEvent): void {\r\n inlineZoomImageOnMouseOut(event);\r\n this.setState({\r\n isImageZoomed: false\r\n });\r\n }\r\n\r\n private _onContainerZoomImageClick(event: React.MouseEvent): void {\r\n if (window.innerWidth <= 768) {\r\n // $msv-breakpoint-m\r\n this._handleMobileViewZoomedImageClick(event);\r\n return;\r\n }\r\n\r\n onContainerZoomInit(event);\r\n\r\n this.setState({\r\n isImageZoomed: true\r\n });\r\n }\r\n\r\n private _onMouseOutLensContainer(event: React.MouseEvent): void {\r\n onMouseOutLensContainer(event);\r\n\r\n this.setState({\r\n isImageZoomed: false\r\n });\r\n }\r\n\r\n private _renderImageInContainerOnZoom(image: IImageData, imageSettings: IImageSettings, index: number): React.ReactNode {\r\n return (\r\n
\r\n \r\n \r\n
\r\n );\r\n }\r\n\r\n private _renderImageFullScreenOnZoom(image: IImageData, imageSettings: IImageSettings, index: number): React.ReactNode {\r\n return (\r\n
\r\n \r\n
\r\n {}\r\n \r\n
\r\n
\r\n );\r\n }\r\n\r\n /**\r\n * Render the video thumbnail in full screen.\r\n * @param mediaData - Media Data.\r\n * @param index - Index\r\n * @param imageSettings - Image settings.\r\n * @returns - JSX.Element\r\n */\r\n private readonly _renderVideoThumbnail = (mediaData: IMediaData, index: number, imageSettings: IImageSettings): React.ReactNode => {\r\n const videoData = mediaData.videoData;\r\n let image: IImageData;\r\n if (videoData?.thumbnail) {\r\n image = videoData.thumbnail;\r\n } else {\r\n image = {\r\n src: 'empty'\r\n };\r\n }\r\n\r\n return (\r\n
\r\n \r\n
\r\n {}\r\n \r\n
\r\n
\r\n );\r\n };\r\n\r\n private _mapProductToImageData(product: SimpleProduct): IImageData {\r\n return {\r\n src: product.PrimaryImageUrl ?? ''\r\n };\r\n }\r\n\r\n private _renderEmptyImage(imageSettings: IImageSettings | undefined): React.ReactNode {\r\n return (\r\n
\r\n \r\n
\r\n );\r\n }\r\n\r\n private _getEmptyThumbnailItem(\r\n imageSettings: IImageSettings | undefined,\r\n index: number,\r\n modifiedActiveIndex: number\r\n ): IMediaGalleryThumbnailItemViewProps {\r\n const classes = classnames(\r\n 'ms-media-gallery__thumbnail-item',\r\n modifiedActiveIndex === index ? 'ms-media-gallery__thumbnail-item-active' : ''\r\n );\r\n return {\r\n ThumbnailItemContainerProps: {\r\n tag: 'li' as NodeTag,\r\n className: classes,\r\n role: 'tab',\r\n tabIndex: 0,\r\n key: 'empty',\r\n 'aria-label': '',\r\n 'aria-selected': modifiedActiveIndex === index,\r\n onClick: this._generateOnThumbnailClick(index),\r\n onKeyDown: this._generateOnThumbnailKeyDown(index)\r\n },\r\n Picture: (\r\n \r\n )\r\n };\r\n }\r\n\r\n private readonly isFirstItem = () => this.state.activeIndex === 0;\r\n\r\n private readonly isLastItem = () => {\r\n const images = this.state.mediaGalleryItems;\r\n return images && this.state.activeIndex === images.length - 1;\r\n };\r\n\r\n private readonly openModalDialog = (): void => {\r\n this._toggleModal();\r\n };\r\n\r\n private _toggleModal(): void {\r\n if (this.state.modalIsOpen) {\r\n this.fullScreenOverlayButtonRef.current?.focus();\r\n const parentDiv = this._inlineZoomDivRef.get(this.state.activeIndex);\r\n if (parentDiv && parentDiv.children && parentDiv.children.length >= 2) {\r\n const image = parentDiv.children[1].querySelector('img');\r\n if (image) {\r\n image.removeAttribute('style');\r\n }\r\n }\r\n this.setState({\r\n isImageZoomed: false\r\n });\r\n }\r\n this.setState({\r\n isImageZoomed: false,\r\n modalIsOpen: !this.state.modalIsOpen\r\n });\r\n removeInlineZoomStyle();\r\n removeContainerZoomStyle();\r\n }\r\n\r\n private readonly imageModalSlider = (ZoomView: string): React.ReactElement => {\r\n const {\r\n data: {\r\n product: { result: product }\r\n },\r\n resources\r\n } = this.props;\r\n let mediaGalleryItems = this.state.mediaGalleryItems;\r\n\r\n if (!mediaGalleryItems && product) {\r\n mediaGalleryItems = [this._mapProductToImageData(product)];\r\n }\r\n const carouselprops = {\r\n tag: Carousel,\r\n className: 'ms-media-gallery__carousel',\r\n items:\r\n mediaGalleryItems &&\r\n mediaGalleryItems.map((item: IImageData, index: number) =>\r\n this._renderCarouselItemImageView(ZoomView, item, this._zoomedImageSettings, index, true)\r\n ),\r\n activeIndex: this.state.activeIndex,\r\n next: this.next,\r\n previous: this.previous,\r\n interval: false,\r\n directionTextPrev: resources.previousScreenshotFlipperText,\r\n directionTextNext: resources.nextScreenshotFlipperText,\r\n onIndicatorsClickHandler: this.goToIndex,\r\n showPaginationTooltip: true,\r\n hideIndicator: false,\r\n keyboard: false,\r\n handleOnExited: this.onExited,\r\n handleOnExiting: this.onExiting,\r\n isDisabledFunctionality: this.state.isMobileImageZoomed\r\n } as IComponentNodeProps;\r\n const carousel = ;\r\n\r\n const imageModalSliderProps: IModalViewProps = {\r\n modalIsOpen: this.state.modalIsOpen,\r\n ontoggle: this._toggleModal,\r\n galleryCarousel: carousel,\r\n classNames: classnames('ms-media-gallery__modal', 'msc-modal-input-required')\r\n };\r\n return ImagefullView(imageModalSliderProps) as React.ReactElement;\r\n };\r\n\r\n private shouldUseCmsAltText = (): boolean => {\r\n if (this.props.config.altTextSource === 'product') {\r\n return false;\r\n } else {\r\n return true;\r\n }\r\n };\r\n}\r\n\r\nexport default MediaGallery;\r\n","/*!\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\n/* eslint-disable no-duplicate-imports */\r\nimport { Module, Node } from '@msdyn365-commerce-modules/utilities';\r\nimport * as React from 'react';\r\n\r\nimport {\r\n IMediaGalleryThumbnailItemViewProps,\r\n IMediaGalleryThumbnailsViewProps,\r\n IMediaGalleryViewProps\r\n} from '@msdyn365-commerce-modules/media-gallery';\r\n\r\nconst MediaGalleryView: React.FC = props => {\r\n const { CarouselProps, Thumbnails, MediaGallery, Modal } = props;\r\n\r\n return (\r\n \r\n \r\n {Modal}\r\n {_renderThumbnails(Thumbnails)}\r\n \r\n );\r\n};\r\n\r\nconst _renderThumbnails = (thumbnails: IMediaGalleryThumbnailsViewProps): JSX.Element => {\r\n const { ThumbnailsContainerProps, SingleSlideCarouselComponentProps, items } = thumbnails;\r\n\r\n return (\r\n \r\n {items && items.map(_renderThumbnailItem)}\r\n \r\n );\r\n};\r\n\r\nconst _renderThumbnailItem = (thumbnail: IMediaGalleryThumbnailItemViewProps): JSX.Element => {\r\n const { ThumbnailItemContainerProps, Picture } = thumbnail;\r\n\r\n return {Picture};\r\n};\r\n\r\nexport default MediaGalleryView;\r\n","import { generateImageUrl, ICommerceApiSettings } from '@msdyn365-commerce/core';\r\n/**\r\n * Parses whether a URL is valid\r\n * @param url\r\n * @returns\r\n */\r\nexport const isValidImage = (url?: string): boolean => {\r\n if (url) {\r\n return url.startsWith('https') || url.startsWith('Products');\r\n } else {\r\n return false;\r\n }\r\n};\r\n\r\nexport async function validateUrlsAsync(\r\n urls: string[],\r\n apiSettings: ICommerceApiSettings,\r\n filterLegacy: boolean = false\r\n): Promise {\r\n var results: Promise[] = [];\r\n var isValid = false;\r\n for (const url of urls) {\r\n results.push(validateUrlAsync(url, apiSettings, filterLegacy));\r\n }\r\n await Promise.all(results).then(values => {\r\n //If any of the values are true, the image is valid\r\n isValid = values.some(value => value);\r\n });\r\n\r\n return isValid;\r\n}\r\n\r\nexport async function validateUrlAsync(url: string, apiSettings: ICommerceApiSettings, filterLegacy: boolean = false): Promise {\r\n //If we filter legacy images and the image is a legacy image, we know it is not valid\r\n if (filterLegacy && !isValidImage(url)) {\r\n return false;\r\n }\r\n\r\n const imageUrl = generateImageUrl(apiSettings, url);\r\n\r\n if (imageUrl === '') {\r\n return false;\r\n }\r\n\r\n return new Promise(resolve => {\r\n try {\r\n const http = new XMLHttpRequest();\r\n http.open('HEAD', imageUrl ?? '', true);\r\n\r\n http.addEventListener('load', () => {\r\n resolve(http.status === 200 || http.status === 201);\r\n });\r\n\r\n http.addEventListener('error', () => {\r\n resolve(false);\r\n });\r\n\r\n http.send();\r\n } catch {\r\n resolve(false);\r\n }\r\n });\r\n}\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['ext-media-gallery'] = {\n c: () => require('partner/modules/ext-media-gallery/ext-media-gallery.tsx'),\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: 1}],\n \n iNM: false,\n ns: '__local__',\n n: 'ext-media-gallery',\n p: '__local__',\n \n pdp: '',\n \n \n md: 'src/modules/ext-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__|modules|ext-media-gallery|ext-media-gallery'] = {\n c: () => require('partner/modules/ext-media-gallery/ext-media-gallery.view.tsx'),\n cn: '__local__-__local__-ext-media-gallery'\n };\nwindow.__bindings__ = window.__bindings__ || {};\nwindow.__bindings__.viewDictionary = {\n ...window.__bindings__.viewDictionary || {},\n ...viewDictionary\n };","module.exports = React;","module.exports = ReactDOM;"],"names":["imageSource","imageZoom","thumbnailsOrientation","altTextSource","MediaType","getAltText","context","shouldUseCmsAltText","productName","imageAltText","_context$app","app","config","OmniChannelMedia","async","validateMediaLocationAsync","mediaLocation","filterLegacy","imageData","src","Uri","altText","AltText","fileName","split","isValidImage","IsApplicableForChildEntities","additionalProperties","isApplicableForChildEntities","Promise","resolve","http","XMLHttpRequest","open","addEventListener","status","send","_unused","getValidProductImages","productId","channelId","actionContext","imageSettings","selectedProduct","catalogId","getCatalogId","requestContext","actionInput","MediaLocationsForSelectedVariantInput","getMediaLocationsForSelectedVariant","then","mediaLocations","all","map","pairs","filter","pair","catch","error","telemetry","exception","debug","validateProductImages","MediaGallery","React","constructor","props","_this","_ref","_props$config$zoomedI","super","this","_inlineZoomDivRef","Map","fullScreenOverlayButtonRef","player","defaultGalleryImageSettings","viewports","xs","q","w","h","sm","md","lg","lazyload","cropFocalRegion","defaultThumbnailImageSettings","onExiting","setState","animating","onExited","next","removeInlineZoomStyle","undefined","isLastItem","nextIndex","state","activeIndex","goToIndex","updateZoomedInImage","previous","images","mediaGalleryItems","isFirstItem","length","index","autoplay","currentIndex","mediaItems","_mediaItems","_this$player$current","mediaTypeValue","Video","current","play","_this$player$current2","pause","getImagesData","_this$props$context$r","skipImageValidation","request","_this$props$config$im","_this$props$config$im2","source","pageContext","data","mediaLocationsForSelectedVariant","result","_mediaLocation$Uri","_this$props$data$prod","product","Name","curatedImages","_filterMasterImageFromVariant","_renderCarouselItemVideo","mediaData","videoData","_videoData$_links","options","playerResources","resources","videoMetaData","videoId","id","title","duration","playTime","thumbnail","posterframeUrl","_links","binaryReferences","videoBinaryReferences","videoPlayerData","metaData","attributes","className","editProps","key","Player","Object","assign","ref","playerData","isEditor","params","_renderEmptyImage","_getCarouselItem","image","_this$props$context$r2","isInPopup","arguments","Image","fallBackSrc","fallbackImage","gridSettings","loadFailureBehavior","shouldSkipToMainImage","bypassHideOnFailure","_getThumbnailItem","modifiedActiveIndex","ThumbnailItemContainerProps","tag","classnames","role","tabIndex","onClick","_generateOnThumbnailClick","onKeyDown","_generateOnThumbnailKeyDown","Picture","imageFallbackOptimize","shouldUseOptimizedImage","getVideoThumbNailItem","classes","_refHandler","divRef","set","event","which","KeyCodes","Enter","Space","preventDefault","_renderVideoThumbnail","fullScreenTitleText","openModalDialog","_toggleModal","imageModalSlider","ZoomView","_mapProductToImageData","carouselprops","Carousel","items","item","_renderCarouselItemImageView","_zoomedImageSettings","interval","directionTextPrev","previousScreenshotFlipperText","directionTextNext","nextScreenshotFlipperText","onIndicatorsClickHandler","showPaginationTooltip","hideIndicator","keyboard","handleOnExited","handleOnExiting","isDisabledFunctionality","isMobileImageZoomed","carousel","imageModalSliderProps","modalIsOpen","ontoggle","galleryCarousel","classNames","ImagefullView","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","thumbnailImageSettings","filterLegacyImageUrls","_setImages","_this$props$config$th2","RecordId","apiSettings","productVariant","reaction","_product$productVaria","_this$props$context$a","_this$props$config$th3","preventImageUpdateOnSizeDimensionUpdate","lastSelectedProduct","differsBeyondSize","_product$Dimensions","Dimensions","forEach","dimension","_lastSelectedProduct$","lastSelectedDimension","find","lastDimension","_dimension$DimensionV","_lastDimension$Dimens","DimensionTypeValue","DimensionValue","Value","_actionContext$reques","isPreview","response","commerceApiRequest","previewImageData","displayOrder","DisplayOrder","MediaTypeValue","_mediaLocation$Uri2","getProductImages","fireImmediately","_this$props$config$th4","shouldComponentUpdate","nextProps","nextState","render","_this$props$context$a2","isVertical","vertical","isFullscreenAllowed","allowFullScreen","zoomViewMode","inline","container","emptyPlaceHolderImage","placeholderImageName","_this$props$context$r4","getFallbackImageUrl","ItemId","mediaGalleryCarouselItems","_getMediaGalleryItems","mediaGalleryThumbnailCarouselItems","_getMediaGalleryThumbnailItems","viewProps","_objectSpread","moduleProps","Modal","callbackToggle","callbackThumbnailClick","callbackThumbnailKeyDown","CarouselProps","indicatorAriaText","ariaLabelForSlide","keys","Thumbnails","ThumbnailsContainerProps","SingleSlideCarouselComponentProps","SingleSlideCarousel","flipperPrevLabel","flipperNextLabel","parentId","useTabList","JSON","stringify","renderView","ArrayExtensions","hasElements","lastUpdate","defaultKey","_getEmptyThumbnailItem","zoomView","curatedImage","mediaToSet","console","log","URL","searchParams","get","commerceVideoMetadataRequest","getVideoMetadataFromApi","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","window","innerWidth","inlineZoomInitClick","inlineZoomImageOnMouseOut","onContainerZoomInit","onMouseOutLensContainer","_this$props$config$da5","onMouseOut","onMouseMoveLensContainer","onMouseOverImageContainer","href","_product$PrimaryImage","PrimaryImageUrl","_this$fullScreenOverl","focus","parentDiv","children","querySelector","removeAttribute","removeContainerZoomStyle","_renderThumbnails","thumbnails","Node","_renderThumbnailItem","Module","url","startsWith","binding","modules","dataActions","registerSanitizedActionPath","sanitizedActionPath","dataAction","default","Error","prototype","RegistrationId","c","require","$type","da","name","path","runOn","iNM","ns","n","p","pdp","__bindings__","viewDictionary","cn","module","exports","ReactDOM"],"sourceRoot":""}