{"version":3,"sources":["webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/zoom-image/ZoomImage.tsx?3088","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/table/Table.tsx?8faf","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/progress/Progress.tsx?fbb5","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/tooltip/UncontrolledTooltip.tsx?30ec","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/slider/SliderThumb.tsx?5d3f","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/slider/Slider.tsx?bb4c","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/table/checkbox.tsx?36f8","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/wrapper/node.tsx?cdf8","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/waiting/Waiting.tsx?ba13","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/tooltip/Tooltip.tsx?8355","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/popover/index.ts?bf24","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/collapse/Collapse.tsx?27f6","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/button/Button.tsx?457f","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/index.ts?5680","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/popup-products/Popup-products.tsx?2288","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/common/KeyCodes.ts?0c24","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/labeled-dropdown/LabeledDropdown.tsx?ab7c","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/wrapper/module.tsx?dadb","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/isMobile/isMobile.props.ts?d9d2","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/quantity/Quantity.tsx?b66b","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/incremental-quantity/index.ts?6ddc","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/price/price-editor-mode-selection.tsx?3c70","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/price/price-editor.tsx?ca15","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/pagination/PaginationLink.tsx?b97e","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/zoom-image/ImagefullView.tsx?adc9","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/flipper/Flipper.tsx?36cd","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/table/index.ts?75ef","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/isMobile/isMobile.tsx?1fd3","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/incremental-quantity/IncrementalQuantity.tsx?1af1","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/drawer/Drawer.tsx?da2c","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/popup/Popup.tsx?0173","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/heading/Heading.tsx?c36b","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/popper-content/PopperContent.tsx?1148","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/fade/Fade.tsx?31ba","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/common/telemetryHelper.ts?068b","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/alert/Alert.tsx?44c5","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/back-to-top/BackToTop.tsx?0cf6","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/single-slide-carousel/SingleSlideCarousel.tsx?b47d","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/quantity/index.ts?f7b4","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/drawer/ControlledDrawer.tsx?9a39","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/common/utilities.ts?93e6","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/pagination/PaginationItem.tsx?6f25","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/form-builder/form-builder.tsx?c7f3","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/common/stringExtensions.ts?f421","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/pagination/UncontrolledPagination.tsx?4877","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/pagination/Pagination.tsx?ebf9","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/popover/Popover.tsx?3cf4","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/modal/Portal.tsx?c937","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/modal/Modal.tsx?7d4b","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/modal/ModalBody.tsx?c097","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/modal/ModalFooter.tsx?8e31","webpack:///./node_modules/@msdyn365-commerce-modules/utilities/src/modal/ModalHeader.tsx?627d"],"names":["removeInlineZoomStyle","zoomedImages","document","body","getElementsByClassName","zoomedImagesArray","Array","from","item","style","width","height","defaultDataScale","onMouseOutLensContainer","event","zoomLens","currentTarget","visibility","classList","remove","zoomedImageContainer","querySelector","getCenter","size","x","y","getLensPosition","cursorPosition","lensSize","originalSize","lensCenter","position","maxPositionX","Math","min","max","maxPositionY","getCursorPosition","element","containerBoundingRect","getBoundingClientRect","pageX","left","window","pageXOffset","pageY","top","pageYOffset","formatPixelsValue","numericValue","handleInlineStyles","zoomedImage","dataScaleText","removeAttribute","imageElement","parentElement","previousElementSibling","dataScale","Number","imageContainerSize","offsetWidth","offsetHeight","zoomedImageSize","opacity","imageCenter","offset","scaledCursorPosition","zoomedImagePosition","inlineZoomInitClick","type","zoomImg","nextElementSibling","handleMouseMovementInContainerZoom","lens","zoomedContainer","createElement","setAttribute","appendChild","getAttribute","displayedImageSize","imageInitialHeight","naturalHeight","imageInitialWidth","naturalWidth","imageContainerHeight","widthScaleRatio","heightScaleRatio","scaleRatio","getDisplayedImageSize","lensPosition","mainImageSource","backgroundImage","offsetCenter","lensScaledPositionX","lensScaledPositionY","backgroundPositionX","backgroundPositionY","backgroundSize","topPosition","onMouseOverImageContainer","add","onMouseMoveLensContainer","onContainerZoomInit","containerDiv","inlineZoomImageOnMouseMove","inlineZoomImageOnMouseOut","inlineZoomImageOnHover","scale","zoomedImg","removeContainerZoomStyle","TableDataType","Table","React","PureComponent","constructor","props","super","componentClassName","headingPrefix","capitalizeHeadingPrefix","_selectSortingKey","target","columnName","sortingKey","ascendingOrder","this","state","newOrder","setState","showActions","_onCheckBoxChangeHandler","rows","checkBoxCallback","index","ObjectExtensions","isNumber","isSelected","_renderHeadingRow","columnData","resources","showCheckBoxes","enableToModify","minifyActions","actionLinkText","isSortable","resourcePrefix","isSingleSelectOnly","businessUserSelectCheckBoxAriaLabelText","sortByAscending","sortByDescending","sortingClassName","sortingValue","columns","map","data","cellIndex","updatedCellIndex","heading","name","columnSortValue","undefined","columnAriaLabel","ariaLabel","format","sortable","onClick","onKeyUp","_handleKeyPressPrev","className","classnames","key","scope","role","tabIndex","trim","radioCheckBox","CheckBoxButton","onChange","actionContent","tableCell","header","content","_renderRow","excludedColumns","actions","formatPrice","rowsData","additionalNameAriaLabel","row","value","toString","cell","includes","id","extraClass","Price","cellContent","columnSpecificClass","rowKey","selectedIndex","actionButtons","_renderActions","buttonReferences","records","buttonReference","editLinkText","deleteLinkText","viewLinkText","editLinkTooltip","deleteLinkTooltip","viewLinkTooltip","actionLinkTooltip","minifiedButtonText","onEdit","onDelete","onView","handleClickEdit","edit","current","handleClickDelete","delete","handleClickView","Node","Button","innerRef","title","_toggleActions","newKey","_sortTableRow","table","sortingkey","sort","userOne","userTwo","userOneData","find","userTwoData","cleanFirst","toLowerCase","cleanSecond","_getCurrentPageData","tableRows","start","end","result","i","push","colSpan","_renderPrev","paginationPreviousText","_renderNext","paginationNextText","keyCode","KeyCodes","Enter","Space","headings","render","showPagination","paginationProperty","classname","paginationLinks","skipCount","itemPerPage","nextText","prevText","paginationText","url","UncontrolledPagination","qsp","items","length","itemsPerPage","startingItem","previousText","previousAriaLabel","nextAriaLabel","tableBody","tableHead","Progress","percent","defaultProps","UncontrolledTooltip","isOpen","_toggle","bind","_isAutoDisplayTriggered","isCartPage","StringExtensions","isNullOrWhitespace","cartPageUrl","location","shouldShowMiniCart","Tooltip","toggle","previousState","SliderThumb","sliderButtonRef","sliderThumbClass","trackThumbClass","ref","onMouseDown","handleStart","onMouseUp","handleEnd","onTouchMove","handleDrag","onTouchEnd","onKeyDown","handleKeydown","onFocus","handleFocus","onBlur","handleBlur","showTooltip","placement","tooltip","handleTooltipText","sliderValue","orientations","horizontal","dimension","direction","coordinate","vertical","EventType","Slider","thumb1Ref","thumb2Ref","_renderLabels","labels","label","labelId","labelPositioning","labelString","_renderSliderThumbs","thumbStyles","isMobileCheck","isMobile","variant","VariantType","Browser","context","gridSettings","xs","w","sm","md","lg","xl","isMobileView","sliderAriaLabelMin","sliderThumbs","sliderAriaLabelMax","isRangeSlider","step","orientation","_handleOnChange","_handleStart","_handleDrag","_handleEnd","ariaValueText","_handleUpdate","dimensionStr","toUpperCaseFirstChar","sliderPos","handlePos","limit","grab","e","stopPropagation","eventType","addEventListener","castTarget","thumbid","_prevState","active","_getThumbAndPublishEvent","Start","_position","castEvent","node","coordinateStyle","directionStyle","clientCoordinateStyle","touches","pos","_getValueFromPosition","_getPositionFromValue","percentage","round","clamp","baseVal","_coordinates","fill","handle","_setSliderValue","sliderThumb","Change","_publishNotification","thumb","delegate","slider","firstThumbValue","secondThumbValue","NaN","nativeEventType","elmenentId","replace","_getThumbFromProps","End","onChangeEnd","onChangeStart","_willThumbsCrossOver","_handleOnClick","MsDyn365","isBrowser","shouldSliderAdjustToRTL","nextState","componentDidMount","componentDidUpdate","shouldComponentUpdate","nextProps","_nextState","shouldRender","thumb1Position","thumb2Position","componentWillUnmount","removeEventListener","sliderClass","sliderBaseClass","sliderId","camelCasedDirection","positionThumb1","coordsThumb1","fillStyle","handleStyle","trackProgressClass","sliderKey","String","positionThumb2","coordsThumb2","showProgressBar","fillTrackValue","showLabels","castThumb","thumbId","thumbPressed","thumb1","thumb2","thumbInteractedWith","parseInt","thumbFound","filter","keycode","checkCondition","inForm","isChecked","cssClass","checked","tag","Tag","Element","restAttribute","Waiting","watingClassName","DEFAULT_DELAYS","show","hide","addTargetEvents","handleDocumentClick","removeTargetEvents","onMouseOverTooltip","onMouseLeaveTooltip","onMouseOverTooltipContent","onMouseLeaveTooltipContent","onFocusOutTarget","onEscKeyDown","onEscKeyDownNative","tabPressed","getTargetElement","getElementsByTagName","bodyClasses","attributes","getNamedItem","removeNamedItem","clearHideTimeout","clearShowTimeout","hideTimeout","showTimeout","setTimeout","getDelay","nativeEvent","nextFocus","activeElement","contains","delay","isNaN","ariaAttr","createAttribute","setNamedItem","clearTimeout","trigger","triggers","split","forEach","displayMode","disabled","preventDefault","cssModule","placementPrefix","hideArrow","innerClassName","modifiers","boundariesElement","arrowClassName","classes","mapToCssModules","classNames","popperClasses","PopperContent","shouldShowCloseButton","onMouseOver","onMouseLeave","Collapse","_transitionStatusToClassHash","entering","entered","exiting","exited","_tagRef","_updateParentElement","minHeight","_onEntering","_onExit","_onExited","_onExiting","_reevaluateHeight","children","navbar","in","collapseIn","mountOnEnter","unmountOnExit","appear","enter","exit","timeout","onEnter","onEntering","onEntered","onExit","onExiting","onExited","otherProps","transitionProps","Transition","TransitionTimeouts","status","collapseClass","_getTransitionClass","firstElementChild","scrollHeight","isAppearing","block","color","outline","href","PopupProducts","popupProps","processStatusClass","dialogStrings","text","modalOpen","setModalOpen","closeModal","Modal","onClosed","ModalHeader","ModalBody","closeWindowButtonText","LabeledDropdown","_onSelectOption","selectedKey","selectedOption","keys","dropdownOptions","option","indexOf","labelText","labelClassname","dropdownId","dropdownClassname","labelClassNames","dropdownClassNames","_getSelectedIndex","htmlFor","selected","controlledByParent","onSelectOption","selectedOptions","toggleColor","Module","moduleProps","renderModuleAttributes","Quantity","inputRef","_validateMin","minValue","currentInput","currentCount","_handleChange","currentValue","pattern","inputQuantityAriaLabel","inputElement","HTMLInputElement","debounce","PriceEditorModeSelectionState","getPriceEditorModeSelectionStateResources","modeState","full","payFullAmountButtonText","partial","specifyAmountButtonText","Error","onClickHandler","handleStateChange","togglePopoverHandler","setPopoverState","isPopoverState","PriceEditorModeSelectionComponent","popoverReference","createRef","isPopoverShown","setIsPopoverShown","useState","setModeState","currentState","onChangeMode","clickedState","onStateChanged","Popover","EnumExtensions","getEnumValues","stateStringRepresentation","renderModeStateItem","PriceEditor","_handleInputFocus","isInputFocused","_handleInputBlur","_handleEditorModeStateChange","newState","_updateAmount","maximumValue","_inputRef","focus","newAmount","handleChange","parseFloat","toFixed","_precision","isNullOrUndefined","minimumValue","defaultValue","defaultAmount","hasMultipleModes","mode","formattedValue","editedValue","priceEditorInputAriaLabel","PaginationLink","payLoad","getPayloadObject","telemetryContent","next","previous","etext","paginationLinkclasses","defaultCaret","isArray","contentAction","attribute","getTelemetryAttributes","ImagefullView","galleryCarousel","modalWindow","autoFocus","applicationNode","modalIsOpen","ontoggle","zIndex","modalHeader","cloneElement","Flipper","telemetryLabel","glyphProps","displayTooltip","sizeClass","innerWidth","Viewport","device","Type","IncrementalQuantity","_handleUpdateState","_minValue","isUpdating","_onIncrement","_onDecrement","IncrementalQuantity_1","glyphMinusClassName","decrementGlyphClass","glyphPlusClassName","incrementGlyphClass","decrementDisabled","isGiftCard","incrementDisabled","TelemetryConstant","DecrementQuantity","decrementAttributes","IncrementQuantity","incrementAttributes","ariaLablelText","extraClassDecrement","extraClassIncrement","decrementButtonAriaLabel","incrementButtonAriaLabel","invokeCallback","currQuantity","updatedQuantity","observer","Drawer","isManuallyToggled","collapseProps","buttonText","drawerGlyphClass","toggleGlyphClassName","animateGlyph","drawerOpenGlyph","openGlyph","closeGlyph","drawerCloseGlyph","drawerClass","toggleButtonProps","_generateDrawerButtonInnerMarkup","collapseState","drawerButtonTextClass","toggleButtonClassName","glyphPlacement","toggleButtonText","_generateGlyphMarkup","glyphClass","onToggle","innerText","Popup","imageSettings","product","price","productQuantity","priceComponent","navigationUrl","ContinueShopping","continueShoppingAttribute","ViewBagAndCheckout","viewBagAttribute","fallbackImageUrl","getFallbackImageUrl","ItemId","actionContext","requestContext","apiSettings","cropFocalRegion","quantity","itemsString","headerItemOneText","headerItemFormatText","shouldDisplayUnitOfMeasure","app","config","unitOfMeasureDisplayType","reducedDimensions","Dimensions","reduce","str","productDimension","DimensionValue","Value","headerMessageText","Image","src","PrimaryImageUrl","fallBackSrc","altText","Name","loadFailureBehavior","DefaultUnitOfMeasure","goToCartText","continueShoppingText","Heading","headingTag","HTag","_handlePlacementChange","_handleProps","prevProps","_renderChildren","container","_show","_hide","flip","fallbackPlacement","focusOut","arrowClassNameOrUndefined","attrs","popperClassName","extendedModifiers","enabled","behavior","preventOverflow","update","order","fn","targetElement","ReactPopper","component","display","Arrow","Fade","baseClass","baseClassActive","fadeIn","timeoutOrUndefined","addEndListener","baseClassAlways","baseClassActiveAlways","isActive","getTelemetryObject","pageName","moduleName","telemetry","recid","contentCategory","pgname","mname","etype","contentData","setTelemetryAttribute","onTelemetryClick","linkText","logEvent","TelemetryEvent","Custom","Alert","closeClassName","transition","fade","assertive","includeAlertClass","closeClasses","alertTransition","buttonId","innerContent","closeAriaLabel","BackToTop","_renderHeading","Msdyn365","editProps","_reevaluatePosition","_scrollToTop","threshold","delayInMs","scrollStepInPx","_scrollStep","documentElement","scrollTop","clearInterval","intervalId","scrollTo","setInterval","innerHeight","clientHeight","tabIndexValue","SingleSlideCarousel","carouselSize","slideSize","itemSize","flipperNextLabel","flipperPrevLabel","_onResized","_onCarouselResized","_nextSlide","_previousSlide","_handleTouchStart","_handleTouchEnd","_onFocus","showPrevious","showNext","slideRef","itemRef","parentId","scrollThreshold","touchScrollThreshold","carousel","slide","_setSizes","_updateFlippers","resizeThrottledEventHandler","addThrottledEvent","isVert","slidePositionStyle","modifiedChildren","_getClonedChildren","carouselClass","carouselSlideClass","overflowClass","previousFlipperGlyph","nextFlipperGlyph","previousFlipperClassName","nextFlipperClassName","disableClassName","onTouchStart","useTabList","child","castChild","verticalItemsSelector","itemsSelector","_moveSingleSlide","evt","scrollStart","screenY","screenX","changedTouches","delta","currentOffset","getCSS","maxScrollCount","floor","directionModifier","maxScrollDistance","distanceToEdge","abs","scrollWidth","_calculateCarouselSize","carouselStyle","getComputedStyle","padding","paddingTop","paddingBottom","paddingLeft","paddingRight","clientWidth","_canScrollPrevious","_canScrollNext","_scrollItemIntoView","offsetTop","offsetLeft","updateOffset","scrollLeft","ControlledDrawer","isExpanded","Expand","_generateTitle","isStart","additionalClassName","titleLClassName","onTextChange","charAt","toUpperCase","substr","property","createThrottledEvent","listener","timer","last","now","Date","throttledEventHandler","c","join","canUseDOM","getTarget","selection","querySelectorAll","console","error","findDOMElements","isRef","isElement","Carousel","focusableElements","PaginationItem","paginationItemClasses","FormBuilderErrorComponent","errorMessage","FormBuilder","_onSubmit","async","formData","formKey","values","resourceId","resourceValue","onSubmit","isSubmitted","_onInputChange","changedValueIndex","Promise","reject","currentKey","requiredValueMissing","setValue","isRequired","resolve","Dictionary","confirmationComponent","submitButtonText","requiredValueMissingErrorMessage","every","ArrayExtensions","hasElements","autoComplete","getValue","required","isAnyRequiredValueMissing","getValues","findIndex","isMissing","formatSpecifier","parameters","match","isNullOrWhiteSpace","activePage","maxPages","ceil","qsps","splitUrl","secondSplit","hash","parsedQsps","qspPair","baseUrl","listClassName","listTag","ListTag","activeQsp","paginationClasses","listpaginationClasses","_generatePageLinks","_generateUrl","page","Object","qspUrl","_generatePaginationArrow","disable","tooltipId","nextId","prevId","ariaDescribedBy","nextAreaDescribed","prevAreaDescribed","_generatePaginationItem","_generateEllipse","leftDistance","rightDistance","leftEllipse","pagesDisplayed","rightEllipse","pages","displayedPagesOnLeft","startingIndex","endIndex","Pagination","popover","_addTargetEvents","_handleDocumentClick","_removeTargetEvents","getRef","_focusOutTarget","_focusOutPopover","_keyDown","Portal","defaultNode","createPortal","mounted","_getFocusableChildren","_handleBackdropClick","_handleBackdropMouseDown","_handleEscape","_handleTab","_onOpened","_onClosed","wasOpen","mouseDownElement","_open","HTMLElement","_close","_prevProps","prevState","shouldUpdateFocusToFirstElement","focusableElementArr","componentWillReceiveProps","wrapClassName","modalClassName","backdropClassName","contentClassName","modalTransition","backdropTransition","backdrop","onOpened","external","verticalPosition","horizontalPosition","keyboard","returnFocusRef","ariaLabelledbyId","dialogAttributes","modalAttributes","modalTransitions","backdropTransitions","Backdrop","dialogBaseClass","dialogClasses","dialog","openCount","scrollY","scrollbarWidth","right","removeProperty","modalOpenClassName","modalOpenClassNameRegex","RegExp","_getFocusedChild","focusableChildren","which","totalFocusable","currentFocus","focusedIndex","el","shiftKey","ModalFooter","closeButton","wrapTag","closeButtonLabel","WrapTag"],"mappings":"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","file":"static/js/4.7dd7469ebe086e89e290.chunk.js","sourcesContent":["/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\n/**\n * Removing inline zoom style.\n */\nexport function removeInlineZoomStyle(): void {\n const zoomedImages: HTMLCollectionOf = document.body.getElementsByClassName('ms-inline-zoom__zoomedImg');\n\n // eslint-disable-next-line xss/no-mixed-html -- Need raw HTML.\n const zoomedImagesArray = Array.from(zoomedImages) as HTMLImageElement[];\n for (const item of zoomedImagesArray) {\n item.style.width = '0';\n item.style.height = '0';\n }\n}\n\n/**\n * Represents default data scale value which should be used in case improper value specified in module config.\n */\nexport const defaultDataScale = 2;\n\n/**\n * Clears zooming state and reverts to initial image.\n * @param event - Event of moving the mouse out of the image.\n */\nexport function onMouseOutLensContainer(event: React.MouseEvent): void {\n const zoomLens = event.currentTarget;\n zoomLens.style.visibility = 'hidden';\n zoomLens.classList.remove('ms-containerZoom__zoom-lens__opacity');\n\n const zoomedImageContainer = document.body.querySelector('.ms-containerZoom__result');\n if (zoomedImageContainer) {\n zoomedImageContainer.style.visibility = 'hidden';\n }\n}\n\n/**\n * Represents size dimensions.\n */\ninterface ISize {\n width: number;\n height: number;\n}\n\n/**\n * Represents two-dimensional position.\n */\ninterface ILocation {\n\n /**\n * Left offset.\n */\n x: number; // eslint-disable-line @typescript-eslint/naming-convention -- To align with html standards.\n\n /**\n * Top offset.\n */\n y: number; // eslint-disable-line @typescript-eslint/naming-convention -- To align with html standards.\n}\n\n/**\n * Retrieves the displayed image size preserving image proportions.\n * @param imageElement - The html image element which is displayed.\n * @returns The dimensions of the displayed image ignoring all the offsets and paddings.\n */\nfunction getDisplayedImageSize(imageElement: HTMLImageElement): ISize {\n const imageInitialHeight = imageElement.naturalHeight;\n const imageInitialWidth = imageElement.naturalWidth;\n const imageContainerHeight = imageElement.height;\n const imageContainerWidth = imageElement.width;\n\n const widthScaleRatio = imageContainerWidth / imageInitialWidth;\n const heightScaleRatio = imageContainerHeight / imageInitialHeight;\n\n const scaleRatio = Math.min(widthScaleRatio, heightScaleRatio);\n\n return {\n width: imageInitialWidth * scaleRatio,\n height: imageInitialHeight * scaleRatio\n };\n}\n\n/**\n * Retrieves the center point based on the given dimensions.\n * @param size - Dimensions of an element.\n * @returns The point of the center.\n */\nfunction getCenter(size: ISize): ILocation {\n const centerDivider = 2;\n return {\n x: size.width / centerDivider,\n y: size.height / centerDivider\n };\n}\n\n/**\n * Retrieves the position where the lens must be placed based by the mouse position, lens size, and container size.\n * @param cursorPosition - The location of the mouse.\n * @param lensSize - The size of the lens.\n * @param originalSize - The container in which the lens should be placed.\n * @returns The location where the lens must be placed.\n */\nfunction getLensPosition(cursorPosition: ILocation, lensSize: ISize, originalSize: ISize) {\n const lensCenter = getCenter(lensSize);\n\n const position: ILocation = {\n x: cursorPosition.x - lensCenter.x,\n y: cursorPosition.y - lensCenter.y\n };\n\n // Limit lens to be inside the image element.\n const minPositionX = 0;\n const maxPositionX = originalSize.width - lensSize.width;\n position.x = Math.min(Math.max(position.x, minPositionX), maxPositionX);\n\n const minPositionY = 0;\n const maxPositionY = originalSize.height - lensSize.height;\n position.y = Math.min(Math.max(position.y, minPositionY), maxPositionY);\n\n return position;\n}\n\n/**\n * Retrieves mouse position.\n * @param event - Mouse event.\n * @param element - Element in which the event happened.\n * @returns Mouse position inside the given element.\n */\nfunction getCursorPosition(event: React.MouseEvent, element: HTMLElement): ILocation {\n const containerBoundingRect = element.getBoundingClientRect();\n return {\n x: event.pageX - containerBoundingRect.left - window.pageXOffset,\n y: event.pageY - containerBoundingRect.top - window.pageYOffset\n };\n}\n\n/**\n * Formats number to represent pixels, e.g. 42px.\n * @param numericValue - The numeric value of pixels.\n * @returns String in pixel format.\n */\nfunction formatPixelsValue(numericValue: number): string {\n return `${numericValue}px`;\n}\n\n/**\n * Formats the given url to be a background image style value.\n * @param sourceUrl - The image source.\n * @returns Background image style value.\n */\nfunction formatBackgroundImageUrl(sourceUrl: string): string {\n return `url('${sourceUrl}')`;\n}\n\n/**\n * Get the cursor position on image click.\n * @param zoomedImage - The target image.\n * @param dataScaleText - Zoom factor for image.\n * @param event - Mouse event action.\n */\nfunction handleInlineStyles(zoomedImage: EventTarget & HTMLImageElement, dataScaleText: string, event: React.MouseEvent): void {\n zoomedImage.removeAttribute('style');\n const imageElement = zoomedImage.parentElement!.previousElementSibling!.querySelector('img')!;\n\n const dataScale = Number(dataScaleText);\n\n const imageContainerSize: ISize = {\n width: imageElement.offsetWidth,\n height: imageElement.offsetHeight\n };\n\n const zoomedImageSize: ISize = {\n width: imageContainerSize.width * dataScale,\n height: imageContainerSize.height * dataScale\n };\n\n zoomedImage.style.width = formatPixelsValue(zoomedImageSize.width);\n zoomedImage.style.height = formatPixelsValue(zoomedImageSize.height);\n zoomedImage.style.opacity = '1';\n\n const cursorPosition = getCursorPosition(event, imageElement);\n const imageCenter = getCenter(imageContainerSize);\n const offset: ILocation = {\n x: cursorPosition.x - imageCenter.x,\n y: cursorPosition.y - imageCenter.y\n };\n\n const scaledCursorPosition: ILocation = {\n x: cursorPosition.x * dataScale,\n y: cursorPosition.y * dataScale\n };\n scaledCursorPosition.x -= offset.x;\n scaledCursorPosition.y -= offset.y;\n\n const zoomedImagePosition = getLensPosition(scaledCursorPosition, imageContainerSize, zoomedImageSize);\n\n zoomedImage.style.left = formatPixelsValue(-zoomedImagePosition.x);\n zoomedImage.style.top = formatPixelsValue(-zoomedImagePosition.y);\n}\n\n/**\n * ZoomIn functionality on image click.\n * @param event -The mouse event.\n * @param dataScale -The zoom factor.\n */\nexport function inlineZoomInitClick(event: React.MouseEvent, dataScale?: string): void {\n if (event.type === 'touchmove' || event.type === 'touchstart' || event.type === 'touchend') {\n return;\n }\n\n const zoomImg = event.currentTarget.parentElement?.nextElementSibling?.querySelector('img');\n if (!zoomImg) {\n return;\n }\n\n handleInlineStyles(zoomImg, dataScale ?? '2', event);\n}\n\n/**\n * Updates lens and zoomed image positions on the page.\n * @param event - Mouse movement event.\n * @param imageElement - Original image element.\n * @param lens - The element which shows the part of the image which is zoomed.\n */\nfunction handleMouseMovementInContainerZoom(\n event: React.MouseEvent, imageElement: HTMLImageElement, lens: EventTarget & HTMLDivElement): void {\n\n let zoomedContainer = document.body.querySelector('.ms-containerZoom__result');\n if (!zoomedContainer) {\n zoomedContainer = document.createElement('div');\n zoomedContainer.setAttribute('class', 'ms-containerZoom__result');\n document.body.appendChild(zoomedContainer);\n }\n\n const lensSize: ISize = {\n width: lens.offsetWidth,\n height: lens.offsetHeight\n };\n\n const dataScale = Number(lens.getAttribute('data-scale') ?? defaultDataScale);\n\n const cursorPosition = getCursorPosition(event, imageElement);\n const displayedImageSize = getDisplayedImageSize(imageElement);\n const imageContainerSize: ISize = {\n width: imageElement.offsetWidth,\n height: imageElement.offsetHeight\n };\n\n const lensPosition = getLensPosition(cursorPosition, lensSize, imageContainerSize);\n lens.style.visibility = 'unset';\n lens.style.left = formatPixelsValue(lensPosition.x);\n lens.style.top = formatPixelsValue(lensPosition.y);\n\n const mainImageSource = imageElement.getAttribute('src')!;\n\n zoomedContainer.style.visibility = 'unset';\n zoomedContainer.style.backgroundImage = formatBackgroundImageUrl(mainImageSource);\n zoomedContainer.style.width = formatPixelsValue(lensSize.width * dataScale);\n zoomedContainer.style.height = formatPixelsValue(lensSize.width * dataScale);\n\n const offsetSize: ISize = {\n width: imageContainerSize.width - displayedImageSize.width,\n height: imageContainerSize.height - displayedImageSize.height\n };\n const offsetCenter = getCenter(offsetSize);\n const lensScaledPositionX = (offsetCenter.x - lensPosition.x) * dataScale;\n const lensScaledPositionY = (offsetCenter.y - lensPosition.y) * dataScale;\n\n zoomedContainer.style.backgroundPositionX = formatPixelsValue(lensScaledPositionX);\n zoomedContainer.style.backgroundPositionY = formatPixelsValue(lensScaledPositionY);\n\n zoomedContainer.style.backgroundSize =\n `${formatPixelsValue(displayedImageSize.width * dataScale)} ${formatPixelsValue(displayedImageSize.height * dataScale)}`;\n\n const topPosition = imageElement.getBoundingClientRect().top;\n zoomedContainer.style.top = formatPixelsValue(topPosition);\n}\n\n/**\n * Updates lens and zoomed image opacity.\n * @param event - Mouse movement event.\n */\nexport function onMouseOverImageContainer(event: React.MouseEvent): void {\n // eslint-disable-next-line xss/no-mixed-html -- Need raw HTML.\n const lens = event.currentTarget.parentElement!.previousElementSibling! as HTMLDivElement;\n lens.classList.add('ms-containerZoom__zoom-lens__opacity');\n\n const imageElement = event.currentTarget as HTMLImageElement;\n\n handleMouseMovementInContainerZoom(event, imageElement, lens);\n}\n\n/**\n * Updates lens and zoomed image positions.\n * @param event - Mouse movement event.\n */\nexport function onMouseMoveLensContainer(event: React.MouseEvent): void {\n if (event.type === 'touchmove' || event.type === 'touchstart' || event.type === 'touchend') {\n return;\n }\n\n const imageElement = event.currentTarget.nextElementSibling!.querySelector('img')!;\n const lens = event.currentTarget;\n\n handleMouseMovementInContainerZoom(event, imageElement, lens);\n}\n\n/**\n * Updates lens and zoomed image initialization.\n * @param event - Mouse movement event.\n */\nexport function onContainerZoomInit(event: React.MouseEvent): void {\n if (!document.body.querySelector('.ms-containerZoom__result')) {\n const containerDiv = document.createElement('div');\n containerDiv.setAttribute('class', 'ms-containerZoom__result');\n document.body.appendChild(containerDiv);\n }\n\n onMouseOverImageContainer(event);\n}\n\n/**\n * Updates zoomed image positions.\n * @param event - Mouse movement event.\n */\nexport function inlineZoomImageOnMouseMove(event: React.MouseEvent): void {\n if (event.type === 'touchmove' || event.type === 'touchstart' || event.type === 'touchend') {\n return;\n }\n\n const parentElement = event.currentTarget.parentElement!.parentElement!;\n const zoomImg = event.currentTarget;\n\n const dataScale = parentElement.getAttribute('data-scale') ?? `${defaultDataScale}`;\n handleInlineStyles(zoomImg, dataScale, event);\n}\n\n/**\n * Updates zoomed image positions.\n * @param event - Mouse movement event.\n */\nexport function inlineZoomImageOnMouseOut(event: React.MouseEvent): void {\n if (event.type === 'touchmove' || event.type === 'touchstart' || event.type === 'touchend') {\n return;\n }\n\n event.currentTarget.style.height = '0';\n event.currentTarget.style.width = '0';\n}\n\n/**\n * Iniline ZoomIn functionality.\n * @param event -The mouse event.\n * @param dataScale -The zoom factor.\n */\nexport function inlineZoomInit(event: React.MouseEvent, dataScale: string = '2'): void {\n if (event.type === 'touchmove' || event.type === 'touchstart' || event.type === 'touchend') {\n return;\n }\n\n const zoomedImage = event.currentTarget.parentElement?.nextElementSibling?.querySelector('img');\n if (!zoomedImage) {\n return;\n }\n\n handleInlineStyles(zoomedImage, dataScale, event);\n}\n\n/**\n * ZoomIn functionality on image Hover.\n * @param event -The mouse event.\n * @param scale -The zoom factor.\n */\nexport function inlineZoomImageOnHover(event: React.MouseEvent, scale: string = '2'): void {\n if (event.type === 'touchmove' || event.type === 'touchstart' || event.type === 'touchend') {\n return;\n }\n\n const zoomedImg = event.currentTarget.parentElement!.nextElementSibling!.querySelector('img')!;\n handleInlineStyles(zoomedImg, scale, event);\n}\n\n/**\n * Remove container zoomed image.\n */\nexport function removeContainerZoomStyle(): void {\n\n const zoomLens = document.body.querySelector('.ms-containerZoom__zoom-lens');\n if (zoomLens) {\n zoomLens.style.visibility = 'hidden';\n zoomLens.classList.remove('ms-containerZoom__zoom-lens__opacity');\n }\n\n const zoomedImageContainer = document.body.querySelector('.ms-containerZoom__result');\n if (zoomedImageContainer) {\n zoomedImageContainer.style.visibility = 'hidden';\n }\n}\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nimport { ObjectExtensions } from '@msdyn365-commerce-modules/retail-actions';\nimport classnames from 'classnames';\nimport React from 'react';\n\nimport { Button, format, KeyCodes, Node, UncontrolledPagination } from '..';\nimport CheckBoxButton from './checkbox';\n\n/**\n * Table Resources.\n */\nexport interface ITableResources {\n\n}\n\n/**\n * Table props.\n */\nexport interface IDataTableProps {\n resources: ITableResources;\n headings: (IHeadingsProperty | undefined)[];\n rows: ITableRowProps[];\n className?: string;\n editLinkText?: string;\n actionLinkText?: string;\n deleteLinkText?: string;\n viewLinkText?: string;\n editLinkTooltip?: string;\n actionLinkTooltip?: string;\n deleteLinkTooltip?: string;\n viewLinkTooltip?: string;\n enableToModify: boolean;\n showCheckBoxes?: boolean;\n isSortable?: boolean;\n showPagination?: boolean;\n paginationProperty: IPaginationProperty;\n minifyActions?: boolean;\n minifiedButtonText?: string;\n excludedColumns?: string[]; // Filled with ITableItemProps.id of columns not to show\n isSingleSelectOnly: boolean;\n businessUserSelectCheckBoxAriaLabelText?: string;\n sortByAscending?: string;\n sortByDescending?: string;\n resourcePrefix?: string;\n actions: {\n onDelete?(userData: ITableItemProps[], referenceBack?: HTMLButtonElement | null): void | undefined;\n onEdit?(userData: ITableItemProps[], referenceBack?: HTMLButtonElement | null): void | undefined;\n onView?(userData: ITableItemProps[]): void | undefined;\n };\n checkBoxCallback?(records: ITableRowProps[]): void;\n formatPrice?(price: number): string;\n}\n\n/**\n * Table IPaginationProperty props.\n */\nexport interface IPaginationProperty {\n itemPerPage: number;\n skipCount: number;\n prevText: string;\n nextText: string;\n paginationText: string;\n url: string;\n}\n\n/**\n * Table ITableItemProps props.\n */\nexport interface ITableItemProps {\n id: string;\n type: TableDataType;\n value: boolean | number | string;\n className?: string;\n}\n\n/**\n * Table IButtonReferences props.\n */\nexport interface IButtonReferences {\n edit?: React.RefObject;\n delete?: React.RefObject;\n}\n\n/**\n * Table ITableRowProps props.\n */\nexport interface ITableRowProps {\n row: ITableItemProps[];\n isSelected: boolean;\n buttonReferences?: IButtonReferences;\n}\n\n/**\n * Table IDataTableCells props.\n */\ninterface IDataTableCells {\n header: boolean;\n className: string;\n content: string | number | React.ReactNode;\n cellIndex: number;\n scope: 'col' | 'row';\n colSpan?: number;\n records?: ITableRowProps;\n}\n\n/**\n * Table IHeadingsProperty props.\n */\nexport interface IHeadingsProperty {\n name: string;\n sortable: boolean;\n ariaLabel?: string;\n}\n\n/**\n * Table ITableState props.\n */\nexport interface ITableState {\n sortingKey: string;\n ascendingOrder: boolean;\n showActions: boolean;\n selectedIndex: string;\n}\n\n/**\n * Table TableDataType props.\n */\nexport enum TableDataType {\n Number = 'Number',\n Text = 'Text',\n Price = 'Price'\n}\n\nexport default class Table extends React.PureComponent {\n public componentClassName: string = 'ms-table';\n\n private readonly headingPrefix: string = 'table';\n\n private readonly capitalizeHeadingPrefix: string = 'Table';\n\n constructor(props: IDataTableProps) {\n super(props);\n this.state = {\n ascendingOrder: true,\n sortingKey: props.headings[0] && props.headings[0].name || '',\n showActions: props.minifyActions !== undefined ? !props.minifyActions : true,\n selectedIndex: ''\n };\n }\n\n public render(): JSX.Element {\n const { className, headings, rows, isSortable, showPagination, paginationProperty } = this.props;\n const { sortingKey, ascendingOrder } = this.state;\n\n const classname = classnames(this.componentClassName, className);\n let tableRows = isSortable && sortingKey ? this._sortTableRow(rows, sortingKey, ascendingOrder) : rows;\n let paginationLinks = null;\n\n if (showPagination) {\n const { skipCount, itemPerPage, nextText, prevText, paginationText, url } = paginationProperty;\n\n paginationLinks = (\n \n );\n\n tableRows = this._getCurrentPageData(tableRows, skipCount, skipCount + itemPerPage);\n }\n\n const tableBody = this._renderRow(tableRows);\n const tableHead = this._renderHeadingRow(headings);\n\n return (\n
\n \n \n {tableHead}\n \n \n {tableBody}\n \n
\n {paginationLinks}\n
\n );\n }\n\n /**\n * Set sorting key.\n * @param event -The mouse event.\n */\n private readonly _selectSortingKey = (event: React.MouseEvent | React.KeyboardEvent) => {\n const target = event.target as HTMLElement;\n const columnName = target.getAttribute('data-sort-name') ? target.getAttribute('data-sort-name') as string : '';\n const { sortingKey, ascendingOrder } = this.state;\n let newOrder = true;\n\n if (sortingKey === columnName) {\n newOrder = !ascendingOrder;\n }\n\n this.setState({\n sortingKey: columnName,\n ascendingOrder: newOrder,\n showActions: false\n });\n };\n\n /**\n * Checkbox change.\n * @param rows -Table rows.\n * @param checkBoxCallback -Checkboxcallback function.\n * @param index -Index value for row.\n * @returns Checkbox rows.\n */\n private readonly _onCheckBoxChangeHandler = (rows: ITableRowProps[], checkBoxCallback: (records: ITableRowProps[]) => void, index?: number) => () => {\n if (ObjectExtensions.isNumber(index)) {\n rows[index].isSelected = !rows[index].isSelected;\n }\n checkBoxCallback(rows);\n };\n\n private readonly _renderHeadingRow = (columnData: (IHeadingsProperty | undefined)[]) => {\n const {\n resources, showCheckBoxes, enableToModify, minifyActions, rows,\n actionLinkText, isSortable, checkBoxCallback, resourcePrefix,\n isSingleSelectOnly, businessUserSelectCheckBoxAriaLabelText, sortByAscending, sortByDescending\n } = this.props;\n const { sortingKey, ascendingOrder } = this.state;\n\n const sortingClassName = ascendingOrder ? 'asc' : 'dsc';\n\n const sortingValue = ascendingOrder ? sortByAscending : sortByDescending;\n\n const columns = columnData.map((data, cellIndex) => {\n if (!data) {\n return;\n }\n const counterAddition = 1;\n const updatedCellIndex = cellIndex + counterAddition;\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment -- unsafe assignment.\n const heading = resources[`${this.headingPrefix}${data.name}HeadingText`] ||\n resources[`${resourcePrefix!}${this.capitalizeHeadingPrefix}${data.name}HeadingText`] ||\n resources[`${data.name}HeadingText`] || data.name;\n\n const columnSortValue = (sortingKey === data.name && sortingValue !== undefined) ? sortingValue : '';\n\n const columnAriaLabel = data.ariaLabel ? `${format(data.ariaLabel, heading)} ${columnSortValue}` : '';\n\n const content = isSortable && data.sortable && (\n \n \n {heading}\n \n \n ) || \n {heading}\n ;\n\n return (\n content\n );\n });\n\n const radioCheckBox = showCheckBoxes && checkBoxCallback && !isSingleSelectOnly && (\n \n );\n\n const actionContent = (\n \n {minifyActions ? '' : actionLinkText}\n \n );\n\n return (\n \n { showCheckBoxes && this.tableCell({\n header: true,\n className: `${this.componentClassName}__heading-row-data__checkbox checkbox`, content: radioCheckBox,\n cellIndex: -1,\n scope: 'col' }) }\n { columns }\n { enableToModify && this.tableCell({\n header: true,\n className: `${this.componentClassName}__heading-row-data action-links`,\n content: actionContent,\n cellIndex: 1,\n scope: 'col'\n }) }\n \n );\n };\n\n private readonly _renderRow = (rows: ITableRowProps[]) => {\n const {\n enableToModify, showCheckBoxes, excludedColumns, actions,\n checkBoxCallback, formatPrice, isSingleSelectOnly,\n businessUserSelectCheckBoxAriaLabelText\n } = this.props;\n\n const tableRows = rows.map((rowsData, index) => {\n let className = index % 2 ? `${this.componentClassName}__row even-row` : `${this.componentClassName}__row odd-row`;\n let showActions = false;\n\n const additionalNameAriaLabel = rowsData.row[0].value.toString();\n const columnData = rowsData.row.map(cell => {\n if (excludedColumns && excludedColumns.includes(cell.id)) {\n return;\n }\n\n // Numbers/price data types will always be right-aligned per design standards\n const extraClass = cell.type === TableDataType.Number || cell.type === TableDataType.Price ? 'num-type' : '';\n const cellContent = cell.type === TableDataType.Price && formatPrice ? formatPrice(cell.value as number) : cell.value;\n const columnSpecificClass = cell.className || '';\n return this.tableCell({ header: false, className: classnames(`${this.componentClassName}__row-data`, extraClass, columnSpecificClass), content: cellContent, cellIndex: index, scope: 'row' });\n });\n\n const radioCheckBox = showCheckBoxes && checkBoxCallback && (\n \n );\n const rowKey = `row-${index}`;\n\n if (rowKey === this.state.selectedIndex && this.state.showActions) {\n className += ' selected';\n showActions = true;\n }\n\n const actionButtons = actions && this._renderActions(rowsData.row, showActions, rowKey, rowsData.buttonReferences);\n\n return (\n \n { showCheckBoxes && this.tableCell({ header: false, className: `${this.componentClassName}__row-data`, content: radioCheckBox, cellIndex: index, scope: 'row', records: rowsData }) }\n { columnData }\n { enableToModify && this.tableCell({ header: false, className: `${this.componentClassName}__row-data`, content: actionButtons, cellIndex: index, scope: 'row', records: rowsData }) }\n \n );\n });\n\n return tableRows;\n };\n\n private readonly _renderActions = (data: ITableItemProps[], showActions: boolean, key: string, buttonReference?: IButtonReferences): React.ReactNode => {\n const { editLinkText, deleteLinkText, viewLinkText, editLinkTooltip, deleteLinkTooltip, viewLinkTooltip, actionLinkTooltip,\n minifyActions, minifiedButtonText, actionLinkText, actions: { onEdit, onDelete, onView } } = this.props;\n const handleClickEdit = onEdit !== undefined ? () => {\n onEdit(data, buttonReference?.edit?.current);\n } : undefined;\n const handleClickDelete = onDelete !== undefined ? () => {\n onDelete(data, buttonReference?.delete?.current);\n } : undefined;\n const handleClickView = onView !== undefined ? () => {\n onView(data);\n } : undefined;\n\n const actionButtons = (\n \n { handleClickView && \n {viewLinkText}\n }\n { handleClickEdit && \n {editLinkText}\n }\n { handleClickDelete && \n {deleteLinkText}\n }\n \n );\n\n if (minifyActions) {\n return (\n \n \n {minifiedButtonText ? minifiedButtonText : ''}\n \n { showActions && actionButtons }\n \n );\n }\n return actionButtons;\n\n };\n\n private readonly _toggleActions = (event: React.MouseEvent) => {\n const target = event && event.target as HTMLElement;\n const newKey = target && target.getAttribute('data-type') ? target.getAttribute('data-type') as string : '';\n this.setState({\n showActions: !this.state.showActions,\n selectedIndex: newKey\n });\n };\n\n private readonly _sortTableRow = (table: ITableRowProps[], sortingkey: string, ascendingOrder: boolean): ITableRowProps[] => {\n return table.sort((userOne: ITableRowProps, userTwo: ITableRowProps) => {\n const userOneData = userOne.row.find(cell => {\n return cell.id === sortingkey;\n });\n const userTwoData = userTwo.row.find(cell => {\n return cell.id === sortingkey;\n });\n\n if (!userOneData || !userTwoData) {\n return -1;\n }\n\n if (typeof userOneData.value === 'number' && typeof userTwoData.value === 'number') {\n return ascendingOrder ? (userOneData.value - userTwoData.value) : (userTwoData.value - userOneData.value);\n }\n\n const cleanFirst = userOneData.value as string && userOneData.value.toString().toLowerCase().trim();\n const cleanSecond = userOneData.value as string && userTwoData.value.toString().toLowerCase().trim();\n\n if (!cleanFirst || !cleanSecond) {\n return -1;\n }\n if (ascendingOrder) {\n return cleanFirst < cleanSecond ? -1 : 1;\n }\n return cleanFirst > cleanSecond ? -1 : 1;\n\n });\n };\n\n private readonly _getCurrentPageData = (tableRows: ITableRowProps[], start: number, end: number): ITableRowProps[] => {\n if (start >= end) {\n return tableRows;\n }\n\n const result = [];\n for (let i = start; i < end; i++) {\n tableRows[i] && result.push(tableRows[i]);\n }\n\n return result;\n };\n\n private readonly tableCell = (props: IDataTableCells) => {\n const { className, header, cellIndex, scope, colSpan, content } = props;\n const hiddenTabIndex = -1;\n const initialTabIndex = 0;\n return header ? (\n initialTabIndex ? initialTabIndex : hiddenTabIndex}\n >\n {content}\n \n ) : (\n \n {content}\n \n );\n };\n\n /**\n * Renders a Pagination previous text.\n * @param paginationPreviousText - Pagination previous text from resources.\n * @returns Previous text and flipper icon.\n */\n private readonly _renderPrev = (paginationPreviousText: string) => {\n return (\n
\n
\n );\n };\n\n /**\n * Renders a Pagination next text.\n * @param paginationNextText - Pagination next text from resources.\n * @returns Next text and flipper icon.\n */\n private readonly _renderNext = (paginationNextText: string) => {\n return (\n
\n \n {paginationNextText}\n \n
\n );\n };\n\n /**\n * Calls method display result.\n * @param event - Keyboard event.\n */\n private readonly _handleKeyPressPrev = (event: React.KeyboardEvent): void => {\n if (event.keyCode === KeyCodes.Enter || event.keyCode === KeyCodes.Space) {\n this._selectSortingKey(event);\n }\n };\n}\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nimport classname from 'classnames';\nimport * as React from 'react';\n\nexport interface IProgressProps {\n id?: string;\n className?: string;\n max: number;\n min?: number;\n value: number;\n ariaLabel?: string;\n}\n\nexport const Progress: React.FC = (props: IProgressProps) => {\n const { id, className, max, min, value, ariaLabel } = props;\n const percent = Math.max(0, Math.min(value * 100 / max, 100));\n const style = { width: `${percent}%` };\n\n return (\n
\n \n
\n );\n};\n\n// Set default props\nProgress.defaultProps = {\n 'aria-valuemax': 100,\n 'aria-valuenow': 0\n} as Partial;\n\nexport default Progress;\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nimport { StringExtensions } from '@msdyn365-commerce-modules/retail-actions';\nimport * as React from 'react';\n\nimport Tooltip from './Tooltip';\nimport { IUncontrolledTooltipProps } from './Tooltip.props';\n\nexport interface IUncontrolledTooltipState {\n isOpen: boolean;\n}\n\n/**\n * UncontrolledTooltip examples.\n */\nexport default class UncontrolledTooltip extends React.PureComponent {\n private _isAutoDisplayTriggered: boolean;\n\n constructor(props: IUncontrolledTooltipProps) {\n super(props);\n this.state = { isOpen: false };\n this._toggle = this._toggle.bind(this);\n this._isAutoDisplayTriggered = false;\n }\n\n public render(): JSX.Element {\n const isCartPage = !StringExtensions.isNullOrWhitespace(this.props.cartPageUrl) &&\n window.location.toString().includes(this.props.cartPageUrl!);\n\n if (this.props.shouldShowMiniCart && !isCartPage) {\n if (!this._isAutoDisplayTriggered) {\n // First time trigger auto mini cart.\n this.setState({ isOpen: true });\n this._isAutoDisplayTriggered = true;\n } else if (!this.state.isOpen) {\n // If tooptip is closed, reset the flag.\n this._isAutoDisplayTriggered = false;\n }\n }\n\n return ;\n }\n\n private _toggle(): void {\n this.setState(previousState => ({ isOpen: !previousState.isOpen }));\n }\n}\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nimport * as React from 'react';\n\nimport { UncontrolledTooltip } from '..';\nimport { ISliderThumbProps } from './SliderThumb.props';\n\n/**\n * Sliderthumb - This is a sliderthumb component this component which is\n * used to control the slider thumb.\n */\nexport default class SliderThumb extends React.PureComponent {\n\n public static defaultProps: Partial = {\n showTooltip: true,\n tooltip: {\n placement: 'top'\n }\n };\n\n public sliderButtonRef: React.RefObject = React.createRef();\n\n public render(): JSX.Element {\n const sliderThumbBaseClass = 'slider__thumb ';\n const sliderThumbClass = this.props.trackThumbClass ? `${sliderThumbBaseClass} ${this.props.trackThumbClass}` : sliderThumbBaseClass;\n\n return (\n <>\n \n { this.props.showTooltip &&\n \n {this.props.handleTooltipText ? this.props.handleTooltipText(this.props.sliderValue!) : this.props.sliderValue!.toString()}\n }\n \n );\n }\n}\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nimport MsDyn365, { IRequestContext } from '@msdyn365-commerce/core';\nimport classnames from 'classnames';\nimport * as React from 'react';\n\nimport { format, isMobile, Progress, VariantType } from '..';\nimport { clamp, toUpperCaseFirstChar } from '../common/utilities';\nimport { ISliderChangeNotification, ISliderLabel, ISliderProps, ISliderThumbProps } from './Slider.props';\nimport SliderThumb from './SliderThumb';\n\n// This maintains the min and max values for the 2 thumbs\nexport interface ISliderState {\n sliderThumbs: ISliderThumbProps[];\n limit: number;\n grab: number;\n active: boolean;\n id: string;\n}\n\nconst orientations = {\n horizontal: {\n dimension: 'width',\n direction: 'left',\n coordinate: 'x'\n },\n vertical: {\n dimension: 'height',\n direction: 'top',\n coordinate: 'y'\n }\n};\n\ninterface IFillCoordinates {\n fill: number;\n handle: number;\n label: number;\n}\n\nenum EventType {\n Start,\n End,\n Change\n}\n\nconst rangeDefaultChkValue = 0;\n\n/**\n * Slider - This is a slider component this component morphs into a range slider\n * based on flags.\n */\n\nexport default class Slider extends React.Component {\n public static defaultProps: Partial = {\n showTooltip: true,\n inForm: false,\n orientation: 'horizontal',\n min: 0,\n max: 100,\n step: 1,\n sliderThumbs: [{ id: 'slider_thumb_id', value: 50 }]\n };\n\n private static readonly sliderBaseClass: string = 'slider';\n\n public isRangeSlider: boolean;\n\n private readonly ref: React.RefObject = React.createRef();\n\n private readonly thumb1Ref: React.RefObject = React.createRef();\n\n private readonly thumb2Ref: React.RefObject = React.createRef();\n\n public static getDerivedStateFromProps(props: ISliderProps, state: ISliderState): ISliderState | null {\n if ((props.sliderThumbs.length > 0 && props.sliderThumbs[0].value !== state.sliderThumbs[0].value) ||\n (props.sliderThumbs.length > 1 && props.sliderThumbs[1].value !== state.sliderThumbs[1].value)) {\n const nextState = { ...state };\n nextState.sliderThumbs[0].value = props.sliderThumbs[0].value;\n if (props.sliderThumbs.length > 1) {\n nextState.sliderThumbs[1].value = props.sliderThumbs[1].value;\n }\n return nextState;\n }\n return null;\n }\n\n constructor(props: ISliderProps) {\n super(props);\n this.isRangeSlider = this.props.sliderThumbs.length === 2;\n this.state = {\n sliderThumbs: this.props.sliderThumbs,\n grab: 0,\n limit: 0,\n active: false,\n id: ''\n };\n this._handleUpdate = this._handleUpdate.bind(this);\n this._handleDrag = this._handleDrag.bind(this);\n this._handleEnd = this._handleEnd.bind(this);\n this._handleStart = this._handleStart.bind(this);\n this._handleOnChange = this._handleOnChange.bind(this);\n this._setSliderValue = this._setSliderValue.bind(this);\n this._getThumbFromProps = this._getThumbFromProps.bind(this);\n this._publishNotification = this._publishNotification.bind(this);\n this._getThumbAndPublishEvent = this._getThumbAndPublishEvent.bind(this);\n this._willThumbsCrossOver = this._willThumbsCrossOver.bind(this);\n this._handleOnClick = this._handleOnClick.bind(this);\n if (MsDyn365.isBrowser && document.body.parentElement && document.body.parentElement.getAttribute('dir') === 'rtl' && (this.props.shouldSliderAdjustToRTL === undefined || this.props.shouldSliderAdjustToRTL)) {\n orientations.horizontal.direction = 'right';\n }\n }\n\n public componentDidMount(): void {\n this._handleUpdate();\n MsDyn365.isBrowser && window.addEventListener('resize', this._handleUpdate);\n }\n\n public componentDidUpdate(): void {\n if (this.ref.current && this.ref.current.offsetWidth > rangeDefaultChkValue && this.state.limit === rangeDefaultChkValue) {\n this._handleUpdate();\n }\n }\n\n public shouldComponentUpdate(nextProps: ISliderProps, _nextState: ISliderState): boolean {\n let shouldRender = true;\n if (this.isRangeSlider) {\n const thumb1Position = this._getPositionFromValue(nextProps.sliderThumbs[0].value);\n const thumb2Position = this._getPositionFromValue(nextProps.sliderThumbs[1].value);\n\n /**\n * During first render the second thumb isn't positioned since handleUpdate positions it after it's mounted\n * in the componentDidMount method. This check is to make sure that the first render happens correctly and then\n * for all subsequent renders and updates, the thumb2 position cannot be 0 thanks to this condition.\n */\n shouldRender = thumb2Position > 0 ? thumb2Position >= thumb1Position + nextProps.step : true;\n }\n return shouldRender;\n }\n\n public componentWillUnmount(): void {\n window.removeEventListener('resize', this._handleUpdate);\n }\n\n public render(): JSX.Element {\n const { orientation } = this.props;\n const sliderClass = this.props.className ? `${Slider.sliderBaseClass} slider-${orientation} ${this.props.className}` : `${Slider.sliderBaseClass} slider-${orientation}`;\n\n const sliderId = this.props.id;\n const dimension = orientations[orientation].dimension;\n const direction = orientations[orientation].direction;\n const camelCasedDirection = toUpperCaseFirstChar(direction);\n const positionThumb1 = this._getPositionFromValue(this.props.sliderThumbs[0].value);\n const coordsThumb1 = this._coordinates(positionThumb1);\n let fillStyle = { [dimension]: `${coordsThumb1.fill}px` };\n const handleStyle: React.CSSProperties[] = [];\n handleStyle.push({ [direction]: `${coordsThumb1.handle}px` });\n const trackProgressClass = classnames('progress-bar', this.props.trackProgressClass ? this.props.trackProgressClass : '');\n const sliderKey = this.props.sliderKey ? `_${String(this.props.sliderKey)}` : '';\n\n if (this.isRangeSlider) {\n const positionThumb2 = this._getPositionFromValue(this.props.sliderThumbs[1].value);\n const coordsThumb2 = this._coordinates(positionThumb2);\n handleStyle.push({ [direction]: `${coordsThumb2.handle}px` });\n if (orientation === 'vertical') {\n fillStyle = {\n 'marginBottom': `${coordsThumb1.fill}px`,\n [dimension]: `${coordsThumb2.fill - coordsThumb1.fill}px`\n };\n } else {\n fillStyle = {\n [`margin${camelCasedDirection}`]: `${orientations.horizontal.direction === 'right' ? coordsThumb1.fill - this.state.grab : coordsThumb1.fill}px`,\n [dimension]: `${coordsThumb2.handle - coordsThumb1.handle}px`\n };\n }\n }\n\n return (\n
\n
\n {this.props.showProgressBar && (\n \n )}\n
\n {this._renderSliderThumbs(handleStyle)}\n
\n {this.props.showLabels ? this._renderLabels(this.props.labels!) : null}\n
\n );\n }\n\n private readonly _renderLabels = (labels: ISliderLabel[]): JSX.Element => {\n return (\n
\n {labels.map((label: ISliderLabel) => {\n return (\n
\n {label.labelString}\n
\n );\n })}\n
\n );\n };\n\n private readonly _renderSliderThumbs = (thumbStyles: React.CSSProperties[]): React.ReactFragment | JSX.Element | null => {\n // eslint-disable-next-line @typescript-eslint/consistent-type-assertions -- Added gridsetting values.\n const context = {\n gridSettings: {\n xs: { w: 767 },\n sm: { w: 991 },\n md: { w: 1199 },\n lg: { w: 1599 },\n xl: { w: 1600 }\n }\n } as IRequestContext;\n\n const isMobileCheck = isMobile({ variant: VariantType.Browser, context });\n const isMobileView = isMobileCheck === 'xs' || isMobileCheck === 'sm';\n\n const sliderAriaLabelMin = format('{0} {1}', this.props.sliderThumbs[0].ariaLabel, this.state.sliderThumbs[0].value);\n\n const sliderAriaLabelMax = this.isRangeSlider ? format('{0} {1}', this.props.sliderThumbs[1].ariaLabel, this.state.sliderThumbs[1].value) : '';\n return (\n <>\n \n \n {' '}\n {this.isRangeSlider && (\n <>\n \n \n \n )}\n \n );\n };\n\n private readonly _handleUpdate = (): void => {\n const { orientation } = this.props;\n const dimensionStr = toUpperCaseFirstChar(orientations[orientation].dimension);\n\n // To get the offsetWidth and offsetHeight of the slider element\n const sliderPos = this.ref.current![`offset${dimensionStr}`];\n const handlePos = this.thumb1Ref.current!.sliderButtonRef.current![`offset${dimensionStr}`];\n\n if (handlePos !== 0) {\n this.setState({\n limit: sliderPos - handlePos,\n grab: orientations.horizontal.direction === 'right' ? -handlePos / 2 : handlePos / 2\n });\n }\n };\n\n private readonly _handleStart = (e: React.TouchEvent | React.KeyboardEvent | React.MouseEvent): void => {\n e.stopPropagation();\n const eventType = e.type;\n document.addEventListener('mousemove', (this._handleDrag as unknown) as EventListener);\n document.addEventListener('mouseup', (this._handleEnd as unknown) as EventListener);\n const castTarget = e.target as HTMLElement;\n const thumbid = castTarget && castTarget.id;\n this.setState(\n (_prevState: ISliderState) => {\n return { active: true, id: thumbid };\n },\n () => {\n this._getThumbAndPublishEvent(castTarget, EventType.Start, eventType);\n }\n );\n };\n\n private _handleEnd(e: React.KeyboardEvent | React.MouseEvent | React.TouchEvent): void {\n e.stopPropagation();\n const eventType = e.type;\n const castTarget = e.target as HTMLElement;\n this.setState(\n (_prevState: ISliderState) => {\n return { active: false, id: '' };\n },\n () => {\n this._getThumbAndPublishEvent(castTarget, EventType.End, eventType);\n }\n );\n document.removeEventListener('mousemove', (this._handleDrag as unknown) as EventListener);\n document.removeEventListener('mouseup', (this._handleEnd as unknown) as EventListener);\n }\n\n private _handleDrag(e: React.MouseEvent | React.TouchEvent): void {\n e.stopPropagation();\n const value = this._position(e);\n const eventType = e.type;\n const castThumb = e.target as HTMLElement;\n const thumbId = this.state.id || (castThumb && castThumb.id);\n const thumbPressed = this._getThumbFromProps(thumbId);\n\n if (thumbPressed && !this._willThumbsCrossOver(thumbPressed[0], e)) {\n thumbPressed[0].value = value;\n this._setSliderValue(thumbPressed, castThumb, eventType);\n }\n }\n\n private _handleOnClick(e: React.MouseEvent | React.TouchEvent): void {\n e.stopPropagation();\n const position = this._position(e);\n const castThumb = e.target as HTMLElement;\n const eventType = e.type;\n const thumb1 = this._getThumbFromProps(this.props.sliderThumbs[0].id);\n\n if (this.isRangeSlider) {\n const thumb2 = this._getThumbFromProps(this.props.sliderThumbs[1].id);\n\n if (thumb1 && thumb2) {\n const currentMinValue = thumb1[0].value;\n const currentMaxValue = thumb2[0].value;\n const lengthToMinValue = position - currentMinValue;\n const lengthToMaxValue = currentMaxValue - position;\n\n if (lengthToMinValue < lengthToMaxValue) {\n thumb1[0].value = position;\n } else {\n thumb2[0].value = position;\n }\n\n this.setState(\n (_prevState: ISliderState) => {\n return ({ sliderThumbs: [thumb1[0], thumb2[0]] });\n },\n () => {\n this._getThumbAndPublishEvent(castThumb, EventType.Change, eventType);\n }\n );\n }\n\n } else if (thumb1) {\n thumb1[0].value = position;\n this.setState(\n (_prevState: ISliderState) => {\n return ({ sliderThumbs: thumb1 });\n },\n () => {\n this._getThumbAndPublishEvent(castThumb, EventType.Change, eventType);\n }\n );\n }\n }\n\n private readonly _position = (e: React.KeyboardEvent | React.MouseEvent | React.TouchEvent): number => {\n const { grab } = this.state;\n const { orientation } = this.props;\n const castEvent = (e as unknown) as TouchEvent;\n const node = this.ref;\n const coordinateStyle = toUpperCaseFirstChar(orientations[orientation].coordinate);\n const directionStyle = orientations[orientation].direction;\n\n // String conversion to the right property value\n const clientCoordinateStyle = `client${coordinateStyle}`;\n const coordinate = !castEvent.touches ? e[clientCoordinateStyle] : castEvent.touches[0][clientCoordinateStyle];\n const direction = node.current!.getBoundingClientRect()[directionStyle];\n const pos = orientations.horizontal.direction === 'right' ? direction - coordinate - grab : coordinate - direction - grab;\n return this._getValueFromPosition(pos);\n };\n\n private readonly _getPositionFromValue = (value: number): number => {\n const { limit } = this.state;\n const { min, max } = this.props;\n const diffMaxMin = max - min;\n const diffValMin = value - min;\n const percentage = diffValMin / diffMaxMin;\n return Math.round(percentage * limit);\n };\n\n /**\n * Translate position of slider to slider value.\n * @param {number} pos - Current position/coordinates of slider.\n * @returns {number} Value - Slider value.\n */\n private readonly _getValueFromPosition = (pos: number): number => {\n const { limit } = this.state;\n const { orientation, min, max, step } = this.props;\n\n const percentage = clamp(pos, 0, limit) / (limit || 1);\n const baseVal = step * Math.round((percentage * (max - min)) / step);\n const value = orientation === 'horizontal' ? baseVal + min : max - baseVal;\n\n return clamp(value, min, max);\n };\n\n /**\n * Grab coordinates of slider.\n * @param {Object} pos - Position object.\n * @returns {Object} - Slider fill/handle coordinates.\n */\n private readonly _coordinates = (pos: number): IFillCoordinates => {\n const { limit, grab } = this.state;\n const { orientation } = this.props;\n const value = this._getValueFromPosition(pos);\n const position = this._getPositionFromValue(value);\n const handlePos = orientation === 'horizontal' ? position + grab : position;\n const fillPos = orientation === 'horizontal' ? handlePos : limit - handlePos;\n\n return {\n fill: fillPos,\n handle: handlePos,\n label: handlePos\n };\n };\n\n private _handleOnChange(e: React.ChangeEvent): void {\n e.stopPropagation();\n const castTarget = e.target as HTMLInputElement;\n const thumbInteractedWith = castTarget && this._getThumbFromProps(castTarget.id.replace('range', ''));\n const eventType = e.type;\n thumbInteractedWith![0].value = Number.parseInt(e.target.value, 10);\n this._setSliderValue(thumbInteractedWith!, castTarget, eventType);\n }\n\n private readonly _setSliderValue = (sliderThumb: ISliderThumbProps[], castTarget: HTMLElement, eventType: string): void => {\n if (this.isRangeSlider) {\n if (this.props.sliderThumbs[0].value > this.props.sliderThumbs[1].value) {\n this.props.sliderThumbs[0].value = this.props.sliderThumbs[1].value;\n }\n this.setState((_prevState: ISliderState) => {\n return {\n sliderThumbs: { ...this.props.sliderThumbs }\n };\n }, () => {\n this._getThumbAndPublishEvent(castTarget, EventType.Change, eventType);\n });\n } else {\n this.setState((_prevState: ISliderState) => {\n return {\n sliderThumbs: sliderThumb\n };\n }, () => {\n this._getThumbAndPublishEvent(castTarget, EventType.Change, eventType);\n });\n }\n };\n\n private _getThumbFromProps(thumbId: string): ISliderThumbProps[] | null {\n let thumbFound;\n\n thumbFound = this.props.sliderThumbs.filter((thumb: ISliderThumbProps) => {\n return thumb.id === thumbId;\n });\n\n return thumbFound.length > 0 ? thumbFound : null;\n }\n\n private readonly _publishNotification = (\n thumb: ISliderThumbProps | null,\n delegate: (sliderNotification: Readonly) => void,\n eventType: string\n ): void => {\n delegate({\n id: (thumb && thumb.id) || '',\n slider: this,\n firstThumbValue: this.state.sliderThumbs[0].value,\n secondThumbValue: (this.state.sliderThumbs[1] && this.state.sliderThumbs[1].value) || Number.NaN,\n eventType\n });\n };\n\n private readonly _getThumbAndPublishEvent = (element: HTMLElement, eventType: EventType, nativeEventType: string): void => {\n let elmenentId = '';\n if (element && element.id && eventType === EventType.Change) {\n elmenentId = element.id.replace('range', '');\n }\n const thumb = element && this._getThumbFromProps(elmenentId);\n\n if (eventType === EventType.End) {\n if (this.props.onChangeEnd) {\n this._publishNotification(thumb && thumb[0], this.props.onChangeEnd, nativeEventType);\n }\n }\n if (eventType === EventType.Start) {\n if (this.props.onChangeStart) {\n this._publishNotification(thumb && thumb[0], this.props.onChangeStart, nativeEventType);\n }\n }\n if (eventType === EventType.Change) {\n if (this.props.onChange) {\n this._publishNotification(thumb && thumb[0], this.props.onChange, nativeEventType);\n }\n }\n };\n\n private _willThumbsCrossOver(\n thumbPressed: ISliderThumbProps,\n event: React.KeyboardEvent | React.MouseEvent | React.TouchEvent\n ): boolean {\n if (!this.isRangeSlider) {\n return false;\n }\n let keycode = 0;\n let checkCondition = false;\n\n if (event.type === 'keydown') {\n const castEvent = (event as unknown) as KeyboardEvent;\n keycode = castEvent.keyCode;\n if (\n (thumbPressed === this.props.sliderThumbs[1] && (keycode === 38 || keycode === 39)) ||\n (thumbPressed === this.props.sliderThumbs[0] && (keycode === 37 || keycode === 40))\n ) {\n return false;\n }\n checkCondition = true;\n\n }\n if (event.type === 'touchmove' || event.type === 'mousemove' || event.type === 'click') {\n const value = this._position(event);\n if (\n (this.state.sliderThumbs[1].value < value && thumbPressed.id === this.props.sliderThumbs[1].id) ||\n (this.state.sliderThumbs[0].value > value && thumbPressed.id === this.props.sliderThumbs[0].id)\n ) {\n return false;\n }\n checkCondition = true;\n\n }\n\n return !(checkCondition && this.props.sliderThumbs[1].value - this.props.step * 2 >= this.props.sliderThumbs[0].value);\n\n }\n}\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nimport classnames from 'classnames';\nimport * as React from 'react';\n\nexport interface IRadioButtonProps {\n isChecked?: boolean;\n value?: string;\n ariaSetSize?: number;\n ariaPosInSet?: number;\n ariaLabel?: string;\n name: string;\n className?: string;\n isSingleSelectOnly?: boolean;\n onChange(reacords: object): void;\n}\n\n/**\n * AddPaymentForm SFC.\n * @param root0\n * @param root0.isChecked\n * @param root0.value\n * @param root0.ariaLabel\n * @param root0.name\n * @param root0.className\n * @param root0.onChange\n * @param root0.isSingleSelectOnly\n * @extends {React.FC}\n */\nconst CheckBoxButton: React.FC = ({\n isChecked,\n value,\n ariaLabel,\n name,\n className,\n onChange,\n isSingleSelectOnly\n}) => {\n\n const cssClass = classnames('ms-input-radio', className ? className : '');\n return (\n \n );\n};\n\nexport default CheckBoxButton;\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nimport * as React from 'react';\n\nexport type NodeTag = React.ReactType;\n\nexport interface INodeProps {\n\n /* Wrapper class */\n className: string;\n\n /* Children node */\n children?: React.ReactNode;\n\n /* Wrapper Tag */\n tag?: NodeTag;\n\n /* Other attrributes */\n [x: string]: any;\n}\n\nexport type IComponentNodeProps = INodeProps & T & {\n\n /* Wrapper Tag */\n tag?: React.ReactType;\n};\n\nexport const Node: React.FC = React.forwardRef(({ className = '', tag: Tag = 'div', element: Element, ...restAttribute }, ref) => {\n return ();\n});\n\nexport default Node;\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nimport * as React from 'react';\n\nimport { IWaitingProps } from './Waiting.props';\n\n/**\n * Waiting - this component is a visual indication of a pre-loader.\n */\nexport default class Waiting extends React.PureComponent {\n public static defaultProps: Partial = {\n className: 'msc-waiting-circular'\n };\n\n public render(): JSX.Element {\n const { className, ...props } = this.props;\n const watingClassName = `msc-waiting ${className}`;\n\n return (
);\n }\n}\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nimport classNames from 'classnames';\nimport * as React from 'react';\n\nimport { getTargetElement, mapToCssModules } from '../common/utilities';\nimport PopperContent from '../popper-content/PopperContent';\nimport { ITooltipProps } from './Tooltip.props';\n\nconst DEFAULT_DELAYS = {\n show: 0,\n hide: 250\n};\n\n/**\n * Tooltip component.\n */\nexport default class Tooltip extends React.PureComponent {\n public static defaultProps: Partial = {\n isOpen: false,\n shouldShowMiniCart: false,\n shouldShowCloseButton: false,\n hideArrow: false,\n placement: 'top',\n placementPrefix: 'msc-bs-tooltip',\n delay: DEFAULT_DELAYS,\n toggle: () => {\n return;\n }\n };\n\n public ref: React.RefObject;\n\n public hideTimeout?: number;\n\n public showTimeout?: number;\n\n public target: HTMLElement | null;\n\n public isMobile: boolean;\n\n public tabPressed: boolean;\n\n constructor(props: ITooltipProps) {\n super(props);\n\n this.ref = React.createRef();\n this.addTargetEvents = this.addTargetEvents.bind(this);\n this.handleDocumentClick = this.handleDocumentClick.bind(this);\n this.removeTargetEvents = this.removeTargetEvents.bind(this);\n this.toggle = this.toggle.bind(this);\n this.onMouseOverTooltip = this.onMouseOverTooltip.bind(this);\n this.onMouseLeaveTooltip = this.onMouseLeaveTooltip.bind(this);\n this.onMouseOverTooltipContent = this.onMouseOverTooltipContent.bind(this);\n this.onMouseLeaveTooltipContent = this.onMouseLeaveTooltipContent.bind(this);\n this.show = this.show.bind(this);\n this.hide = this.hide.bind(this);\n this.onFocusOutTarget = this.onFocusOutTarget.bind(this);\n this.onEscKeyDown = this.onEscKeyDown.bind(this);\n this.onEscKeyDownNative = this.onEscKeyDownNative.bind(this);\n this.target = null;\n this.isMobile = false;\n this.tabPressed = false;\n }\n\n public componentDidMount(): void {\n this.target = getTargetElement(this.props.target);\n this.addTargetEvents();\n\n // Remove the attr from parent obj when tooltip is hidden\n\n const body = document.getElementsByTagName('body').item(0);\n if (body) {\n const bodyClasses = body.getAttribute('class');\n if (bodyClasses && bodyClasses.includes('mobile')) {\n this.isMobile = true;\n }\n }\n\n if (this.target !== null && this.target.attributes.getNamedItem('aria-describedby') !== null) {\n this.target.attributes.removeNamedItem('aria-describedby');\n }\n }\n\n public componentWillUnmount(): void {\n this.clearHideTimeout();\n this.clearShowTimeout();\n this.removeTargetEvents();\n }\n\n public onMouseOverTooltip(e: MouseEvent): void {\n if (this.hideTimeout) {\n this.clearHideTimeout();\n }\n this.showTimeout = window.setTimeout(this.show.bind(this, e), this.getDelay('show'));\n }\n\n public onMouseLeaveTooltip(e: MouseEvent): void {\n if (this.showTimeout) {\n this.clearShowTimeout();\n }\n this.hideTimeout = window.setTimeout(this.hide.bind(this, e), this.getDelay('hide'));\n }\n\n public onMouseOverTooltipContent(): void {\n if (this.hideTimeout) {\n this.clearHideTimeout();\n }\n }\n\n public onMouseLeaveTooltipContent(e: React.MouseEvent): void {\n if (this.showTimeout) {\n this.clearShowTimeout();\n }\n this.hideTimeout = window.setTimeout(this.hide.bind(this, e.nativeEvent), this.getDelay('hide'));\n }\n\n public onFocusOutTarget(e: Event): void {\n if (!this.props.isOpen) {\n return;\n }\n\n if (this.tabPressed) {\n this.tabPressed = false;\n setTimeout(() => {\n const nextFocus = document.activeElement;\n\n if (!this.ref || !this.ref.current || !this.ref.current.contains(nextFocus)) {\n this.hide(e);\n }\n }, 1);\n } else {\n this.hide(e);\n }\n }\n\n public onEscKeyDown(e: React.KeyboardEvent): void {\n if (e.keyCode === 9) {\n this.tabPressed = true;\n } else if (e.key === 'Escape') {\n this.hide(e.nativeEvent);\n }\n }\n\n public onEscKeyDownNative(e: KeyboardEvent): void {\n if (e.keyCode === 9) {\n this.tabPressed = true;\n } else if (e.key === 'Escape') {\n this.hide(e);\n }\n }\n\n public getDelay(key: 'show' | 'hide'): number {\n const { delay } = this.props;\n if (typeof delay === 'object') {\n return (isNaN(delay[key]) ? DEFAULT_DELAYS[key] : delay[key]);\n }\n\n return delay || 0;\n }\n\n public show(e: Event): void {\n if (!this.props.isOpen) {\n this.clearShowTimeout();\n this.toggle(e);\n\n // Create a new attr for parent obj when tooltip shown\n if (this.target !== null) {\n const ariaAttr = document.createAttribute('aria-describedby');\n ariaAttr.value = this.props.id as string;\n this.target.attributes.setNamedItem(ariaAttr);\n }\n }\n }\n\n public hide(e: Event): void {\n if (this.props.isOpen) {\n this.clearHideTimeout();\n this.toggle(e);\n\n // Remove the attr from parent obj when tooltip is hidden\n if (this.target !== null && this.target.attributes.getNamedItem('aria-describedby') !== null) {\n this.target.attributes.removeNamedItem('aria-describedby');\n }\n }\n }\n\n public clearShowTimeout(): void {\n clearTimeout(this.showTimeout);\n this.showTimeout = undefined;\n }\n\n public clearHideTimeout(): void {\n clearTimeout(this.hideTimeout);\n this.hideTimeout = undefined;\n }\n\n public handleDocumentClick(e: Event): void {\n if (!this.target) {\n return;\n }\n\n const target = e.target as HTMLElement;\n if (e.target === this.target || this.target.contains(target)) {\n if (this.hideTimeout) {\n this.clearHideTimeout();\n }\n\n if (!this.props.isOpen) {\n this.toggle(e);\n }\n } else if (this.props.isOpen && target.getAttribute('role') !== 'tooltip') {\n if (this.showTimeout) {\n this.clearShowTimeout();\n }\n this.hideTimeout = window.setTimeout(this.hide.bind(this, e), this.getDelay('hide'));\n }\n }\n\n public addTargetEvents(): void {\n if (!this.target) {\n return;\n }\n\n if (this.props.trigger) {\n const triggers = this.props.trigger.split(' ');\n if (!triggers.includes('manual')) {\n if (triggers.includes('click')) {\n ['click', 'touchstart'].forEach((event: string) => {\n document.addEventListener(event, this.handleDocumentClick, true);\n });\n }\n if (triggers.includes('hover')) {\n this.target.addEventListener('mouseover', this.onMouseOverTooltip, true);\n this.target.addEventListener('mouseout', this.onMouseLeaveTooltip, true);\n }\n if (triggers.includes('focus')) {\n this.target.addEventListener('focusin', this.show, true);\n if (this.props.displayMode === 'FLYOUT') {\n this.target.addEventListener('focusout', this.onFocusOutTarget, true);\n } else {\n this.target.addEventListener('focusout', this.hide, true);\n }\n }\n this.target.addEventListener('keydown', this.onEscKeyDownNative, true);\n }\n } else {\n this.target.addEventListener('mouseover', this.onMouseOverTooltip, true);\n this.target.addEventListener('mouseout', this.onMouseLeaveTooltip, true);\n this.target.addEventListener('keydown', this.onEscKeyDownNative, true);\n this.target.addEventListener('focusin', this.show, true);\n if (this.props.displayMode === 'FLYOUT') {\n this.target.addEventListener('focusout', this.onFocusOutTarget, true);\n } else {\n this.target.addEventListener('focusout', this.hide, true);\n }\n\n ['click', 'touchstart'].forEach((event: string) => {\n document.addEventListener(event, this.handleDocumentClick, true);\n });\n }\n }\n\n public removeTargetEvents(): void {\n if (!this.target) {\n return;\n }\n\n this.target.removeEventListener('mouseover', this.onMouseOverTooltip, true);\n this.target.removeEventListener('mouseout', this.onMouseLeaveTooltip, true);\n this.target.removeEventListener('keydown', this.onEscKeyDownNative, true);\n this.target.removeEventListener('focusin', this.show, true);\n this.target.removeEventListener('focusout', this.onFocusOutTarget, true);\n this.target.removeEventListener('focusout', this.hide, true);\n\n ['click', 'touchstart'].forEach((event: string) => {\n document.removeEventListener(event, this.handleDocumentClick, true);\n });\n }\n\n public toggle(e?: Event): void {\n if (e && this.props.disabled) {\n e.preventDefault();\n }\n\n if (this.props.toggle) {\n this.props.toggle();\n }\n }\n\n public render(): JSX.Element | null {\n if (!this.props.isOpen || this.isMobile) {\n return null;\n }\n\n const {\n cssModule,\n isOpen,\n target,\n placementPrefix,\n hideArrow,\n className,\n innerClassName,\n innerRef,\n modifiers,\n toggle,\n delay,\n placement,\n disabled,\n trigger,\n boundariesElement,\n offset,\n arrowClassName,\n displayMode,\n id,\n ...attributes\n } = this.props;\n\n const classes = mapToCssModules(classNames(\n displayMode === 'FLYOUT' ? 'msc-flyout-inner' : 'msc-tooltip-inner',\n this.props.innerClassName\n ), this.props.cssModule);\n\n const popperClasses = mapToCssModules(classNames(\n displayMode === 'FLYOUT' ? 'msc-flyout' : 'msc-tooltip',\n 'show',\n this.props.className\n ), this.props.cssModule);\n\n return (\n
\n \n {this.props.toggle && this.props.shouldShowCloseButton ? : ''}\n \n \n
\n );\n }\n}\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nimport Popover from './Popover';\n\nexport * from './Popover.props';\n\nexport {\n Popover\n};\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nimport classNames from 'classnames';\nimport * as React from 'react';\nimport Transition from 'react-transition-group/Transition';\n\nimport { mapToCssModules, TransitionStatuses, TransitionTimeouts } from '../common/utilities';\nimport { ICollapseProps } from './Collapse.props';\n\nexport interface ICollapseState {\n height: number | null;\n}\n\ntype IHash = {\n [key in TransitionStatuses]: string;\n};\n\n/**\n * This is the controlled version of a Collapse component, and as such the toggle behavior is expected to be handled in a parent component.\n * @see See [Uncontrolled Components - React](https://reactjs.org/docs/uncontrolled-components.html) to learn more.\n * @visibleName Collapse (controlled)\n */\nexport default class Collapse extends React.Component {\n public static defaultProps: Partial = {\n isOpen: false,\n tag: 'div',\n timeout: TransitionTimeouts.Collapse\n };\n\n public props: ICollapseProps;\n\n public state: ICollapseState;\n\n private readonly _transitionStatusToClassHash: IHash = {\n entering: 'collapsing',\n entered: 'collapse show',\n exiting: 'collapsing',\n exited: 'collapse'\n };\n\n private readonly _tagRef: React.RefObject = React.createRef();\n\n constructor(props: ICollapseProps) {\n super(props);\n this.props = props;\n\n this.state = {\n height: 0\n };\n\n this._onEntering = this._onEntering.bind(this);\n this._onExit = this._onExit.bind(this);\n this._onExited = this._onExited.bind(this);\n this._onExiting = this._onExiting.bind(this);\n this._reevaluateHeight = this._reevaluateHeight.bind(this);\n }\n\n public componentDidMount(): void {\n window && window.addEventListener('resize', this._reevaluateHeight);\n }\n\n public componentDidUpdate(nextProps: ICollapseProps): void {\n if (nextProps.children !== this.props.children) {\n this._reevaluateHeight();\n }\n }\n\n public componentWillUnmount(): void {\n window && window.removeEventListener('resize', this._reevaluateHeight);\n }\n\n public shouldComponentUpdate(nextProps: ICollapseProps,\n nextState: ICollapseState): boolean {\n if (this.state === nextState && this.props === nextProps) {\n return false;\n }\n return true;\n }\n\n public render(): JSX.Element | null {\n const {\n tag,\n isOpen,\n className,\n children,\n navbar,\n cssModule,\n\n in: collapseIn,\n mountOnEnter,\n unmountOnExit,\n appear,\n enter,\n exit,\n timeout,\n onEnter,\n onEntering,\n onEntered,\n onExit,\n onExiting,\n onExited,\n\n ...otherProps\n } = this.props;\n\n const Tag = tag || 'div';\n const transitionProps = {\n in: collapseIn,\n mountOnEnter,\n unmountOnExit,\n appear,\n enter,\n exit,\n onEnter,\n onEntering,\n onEntered,\n onExit,\n onExiting,\n onExited\n };\n\n const { height } = this.state;\n const style = height === null || height === 0 ? null : { minHeight: height };\n\n return (\n \n {(status: TransitionStatuses) => {\n const collapseClass = this._getTransitionClass(status);\n const classes = mapToCssModules(classNames(className, collapseClass, navbar && 'navbar-collapse'), cssModule);\n\n return (\n \n {children}\n \n );\n }}\n \n );\n }\n\n private _reevaluateHeight(): void {\n const node = this._tagRef.current;\n if (node !== null && node.firstElementChild && node.firstElementChild.scrollHeight > 0) {\n this.setState({ height: node.firstElementChild.scrollHeight });\n }\n }\n\n private _getTransitionClass(status: TransitionStatuses): string {\n return this._transitionStatusToClassHash[status] || 'collapse';\n }\n\n private _onEntering(node: HTMLElement, isAppearing: boolean): void {\n this.setState({ height: node.scrollHeight });\n\n if (this.props.onEntering) {\n this.props.onEntering(node, isAppearing);\n }\n }\n\n private _onExit(node: HTMLElement): void {\n this.setState({ height: node.scrollHeight });\n\n if (this.props.onExit) {\n this.props.onExit(node);\n }\n }\n\n private _onExiting(node: HTMLElement): void {\n this.setState({ height: 0 });\n\n if (this.props.onExiting) {\n this.props.onExiting(node);\n }\n }\n\n /**\n * Get Parent element.\n * @param node - HTML Element.\n */\n private readonly _updateParentElement = (node: HTMLElement): void => {\n const parentElement = node.parentElement;\n if (parentElement) {\n if (parentElement.classList.contains('collapse') && parentElement.classList.contains('show')) {\n parentElement.style.minHeight = 'auto';\n }\n this._updateParentElement(parentElement);\n }\n };\n\n private _onExited(node: HTMLElement): void {\n this.setState({ height: null });\n this._updateParentElement(node);\n\n if (this.props.onExited) {\n this.props.onExited(node);\n }\n }\n}\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nimport classNames from 'classnames';\nimport * as React from 'react';\n\nimport { mapToCssModules } from '../common/utilities';\nimport { IButtonProps } from './Button.props';\n\n/**\n * Button component.\n */\nexport default class Button extends React.PureComponent {\n\n public static defaultProps: Partial = {\n tag: 'button',\n outline: false\n };\n\n public props: IButtonProps;\n\n constructor(props: IButtonProps) {\n super(props);\n this.props = props;\n this.onClick = this.onClick.bind(this); // Put this in componentDidMount\n }\n\n public render(): JSX.Element {\n const {\n active,\n block,\n className,\n cssModule,\n color,\n outline,\n size,\n tag,\n innerRef,\n ...attributes\n } = this.props;\n const classes = mapToCssModules(\n classNames(\n className,\n 'msc-btn',\n outline && color ? `btn-outline-${color}` : (color && outline === false ? `btn-${color}` : color === undefined && outline === true ? 'btn-outline' : ''),\n size ? `btn-${size}` : false,\n block ? 'btn-block' : false,\n { active, disabled: this.props.disabled }\n ),\n cssModule\n );\n\n let Tag = tag || 'button';\n\n if (attributes.href && Tag === 'button') {\n Tag = 'a';\n }\n\n return (\n \n );\n }\n\n private readonly onClick = (e: React.MouseEvent) => {\n if (this.props.disabled) {\n e.preventDefault();\n\n return;\n }\n\n if (this.props.onClick) {\n this.props.onClick(e);\n }\n };\n}\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nimport Alert from './alert/Alert';\nimport { IAlertProps } from './alert/Alert.props';\nimport BackToTop from './back-to-top/BackToTop';\nimport Button from './button/Button';\nimport { IButtonProps } from './button/Button.props';\nimport Collapse from './collapse/Collapse';\nimport { ICollapseProps } from './collapse/Collapse.props';\nimport {\n getPayloadObject, getTelemetryAttributes, getTelemetryObject,\n IContentAction, IPayLoad, ITelemetryContent, onTelemetryClick, TelemetryConstant\n} from './common/telemetryHelper';\nimport ControlledDrawer from './drawer/ControlledDrawer';\nimport Drawer, { IDrawerState } from './drawer/Drawer';\nimport Fade, { IFadeState } from './fade/Fade';\nimport { IFadeProps } from './fade/Fade.props';\nimport Flipper from './flipper/Flipper';\nimport { FormBuilder } from './form-builder/form-builder';\nimport Heading from './heading/Heading';\nimport { HeadingTag, IHeadingProps } from './heading/Heading.props';\nimport { IncrementalQuantity } from './incremental-quantity';\nimport { isMobile } from './isMobile/isMobile';\nimport { VariantType } from './isMobile/isMobile.props';\nimport LabeledDropdown from './labeled-dropdown/LabeledDropdown';\nimport { ILabeledDropdownOnChangeNotification, ILabeledDropdownOption } from './labeled-dropdown/LabeledDropdown.props';\nimport Pagination from './pagination/Pagination';\nimport PaginationItem from './pagination/PaginationItem';\nimport PaginationLink from './pagination/PaginationLink';\nimport UncontrolledPagination from './pagination/UncontrolledPagination';\nimport PopperContent from './popper-content/PopperContent';\nimport Popup, { IPopupProps } from './popup/Popup';\nimport PopupProducts, { IPopupProductsProps } from './popup-products/Popup-products';\nimport Progress from './progress/Progress';\nimport SingleSlideCarousel from './single-slide-carousel/SingleSlideCarousel';\nimport { ISingleSlideCarouselProps } from './single-slide-carousel/SingleSlideCarousel.props';\nimport Slider from './slider/Slider';\nimport { ISliderChangeNotification, ISliderLabel, ISliderProps, ISliderThumbProps } from './slider/Slider.props';\nimport Table, { IDataTableProps, ITableItemProps } from './table/Table';\nimport Tooltip from './tooltip/Tooltip';\nimport UncontrolledTooltip from './tooltip/UncontrolledTooltip';\nimport Waiting from './waiting/Waiting';\nimport { ImagefullView, IModalViewProps } from './zoom-image/ImagefullView';\nimport {\n defaultDataScale, inlineZoomImageOnHover, inlineZoomImageOnMouseMove, inlineZoomImageOnMouseOut, inlineZoomInit,\n inlineZoomInitClick, onContainerZoomInit, onMouseMoveLensContainer, onMouseOutLensContainer,\n onMouseOverImageContainer, removeContainerZoomStyle, removeInlineZoomStyle\n} from './zoom-image/ZoomImage';\n\nexport * from './common/KeyCodes';\nexport * from './common/stringExtensions';\nexport * from './common/utilities';\nexport * from './modal';\nexport * from './popover';\nexport * from './price';\nexport * from './quantity';\nexport * from './table';\nexport * from './wrapper/module';\nexport * from './wrapper/node';\nexport {\n Alert,\n BackToTop,\n Button,\n Collapse,\n ControlledDrawer,\n defaultDataScale,\n Drawer,\n Fade,\n Flipper,\n FormBuilder,\n getPayloadObject,\n getTelemetryAttributes,\n getTelemetryObject,\n Heading,\n HeadingTag,\n IAlertProps,\n IButtonProps,\n ICollapseProps,\n IContentAction,\n IDataTableProps,\n IDrawerState,\n IFadeProps,\n IFadeState,\n IHeadingProps,\n ILabeledDropdownOnChangeNotification,\n ILabeledDropdownOption,\n ImagefullView,\n IModalViewProps,\n IncrementalQuantity,\n inlineZoomImageOnHover,\n inlineZoomImageOnMouseMove,\n inlineZoomImageOnMouseOut,\n inlineZoomInit,\n inlineZoomInitClick,\n IPayLoad,\n IPopupProductsProps,\n IPopupProps,\n ISingleSlideCarouselProps,\n ISliderChangeNotification,\n ISliderLabel,\n ISliderProps,\n ISliderThumbProps,\n isMobile,\n ITableItemProps,\n ITelemetryContent,\n LabeledDropdown,\n onContainerZoomInit,\n onMouseMoveLensContainer,\n onMouseOutLensContainer,\n onMouseOverImageContainer,\n onTelemetryClick,\n Pagination,\n PaginationItem,\n PaginationLink,\n PopperContent,\n Popup,\n PopupProducts,\n Progress,\n removeContainerZoomStyle,\n removeInlineZoomStyle,\n SingleSlideCarousel,\n Slider,\n Table,\n TelemetryConstant,\n Tooltip,\n UncontrolledPagination,\n UncontrolledTooltip,\n VariantType,\n Waiting\n};\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nimport classnames from 'classnames';\nimport * as React from 'react';\n\nimport { Button } from '..';\nimport { Modal, ModalBody, ModalHeader } from '../modal';\n\nexport interface IPopupProductsProps {\n dialogStrings?: {\n closeWindowButtonText: string;\n };\n\n className: string;\n processStatusClass: string;\n text: string;\n\n modalOpen: boolean | undefined;\n setModalOpen(newValue: boolean): void;\n}\n\nexport const PopupProducts = (popupProps: IPopupProductsProps) => {\n const { processStatusClass, dialogStrings, className, text, modalOpen, setModalOpen } = popupProps;\n\n const closeModal = React.useCallback(() => {\n setModalOpen(false);\n }, [setModalOpen]);\n\n if (!dialogStrings || !text) {\n return null;\n }\n\n return (\n \n \n \n
\n
\n {text}\n
\n \n \n \n );\n};\n\nexport default PopupProducts;\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nexport enum KeyCodes {\n Back = 8,\n Tab = 9,\n Enter = 13,\n Shift = 16,\n Ctrl = 17,\n Alt = 18,\n Break = 19,\n CapsLock = 20,\n Escape = 27,\n Space = 32,\n PageUp = 33,\n PageDown = 34,\n End = 35,\n Home = 36,\n ArrowLeft = 37,\n ArrowUp = 38,\n ArrowRight = 39,\n ArrowDown = 40,\n Print = 44,\n Insert = 45,\n Delete = 46,\n Colon2 = 59, // Opera and Firefox\n Equals2 = 61, // Opera\n Equals3 = 107, // Firefox\n Minus2 = 109, // Opera and Firefox\n Period = 190,\n WindowsLeft = 91,\n WindowsRight = 92,\n WindowsOpera = 219, // Opera\n Menu = 93,\n NumPad0 = 96,\n NumPad1 = 97,\n NumPad2 = 98,\n NumPad3 = 99,\n NumPad4 = 100,\n NumPad5 = 101,\n NumPad6 = 102,\n NumPad7 = 103,\n NumPad8 = 104,\n NumPad9 = 105,\n NumPadMultiply = 106,\n NumPadPlus = 107,\n NumPadMinus = 109,\n NumPadDot = 110,\n NumPadDivide = 111,\n Function1 = 112,\n Function2 = 113,\n Function3 = 114,\n Function4 = 115,\n Function5 = 116,\n Function6 = 117,\n Function7 = 118,\n Function8 = 119,\n Function9 = 120,\n Function10 = 121,\n Function11 = 122,\n Function12 = 123,\n NavigationUp = 138,\n NavigationDown = 139,\n NavigationLeft = 140,\n NavigationRight = 141,\n NavigationAccept = 142,\n NumLock = 144,\n ScrollLock = 145,\n Colon = 186,\n Equals = 187,\n Comma = 188,\n Minus = 189,\n ForwardSlash = 191,\n Tilde = 192,\n GamepadA = 195,\n GamepadB = 196,\n GamepadX = 197,\n GamepadY = 198,\n GamepadRightButton = 199,\n GamepadLeftButton = 200,\n GamepadLeftTrigger = 201,\n GamepadRightTrigger = 202,\n GamepadDPadUp = 203,\n GamepadDPadDown = 204,\n GamepadDPadLeft = 205,\n GamepadDPadRight = 206,\n GamepadSelect = 207,\n GamepadStart = 208,\n GamepadLeftThumbstick = 209,\n GamepadRightThumbstick = 210,\n GamepadLeftThumbstickUp = 211,\n GamepadLeftThumbstickDown = 212,\n GamepadLeftThumbstickRight = 213,\n GamepadLeftThumbstickLeft = 214,\n GamepadRightThumbstickUp = 215,\n GamepadRightThumbstickDown = 216,\n GamepadRightThumbstickRight = 217,\n GamepadRightThumbstickLeft = 218,\n OpenBracket = 219,\n BackSlash = 220,\n CloseBracket = 221,\n Quote = 222\n}\n\n/**\n * Here for test coverage.\n */\nexport class KeycodesClass {\n public testCoverage(): string {\n return ':(';\n }\n}\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nimport classNames from 'classnames';\nimport * as React from 'react';\n\nimport { ILabeledDropdownProps } from './LabeledDropdown.props';\n\nexport interface ILabeledDropdownState {\n selectedIndex: number;\n}\n\n/**\n * Labeled Dropdown component.\n */\nexport default class LabeledDropdown extends React.PureComponent {\n public static defaultProps: Partial = {\n toggleColor: 'link'\n };\n\n constructor(props: ILabeledDropdownProps) {\n super(props);\n this._onSelectOption = this._onSelectOption.bind(this);\n const selectedKey = this.props.selectedOption.key;\n const keys = this.props.dropdownOptions.map(option => (option.key));\n this.state = { selectedIndex: keys.indexOf(selectedKey) };\n }\n\n public render(): JSX.Element {\n const {\n labelText,\n labelClassname,\n dropdownId,\n dropdownOptions,\n dropdownClassname\n } = this.props;\n\n const labelClassNames = classNames('msc-l-dropdown__label', labelClassname);\n const dropdownClassNames = classNames('msc-l-dropdown', dropdownClassname);\n const selectedIndex = this._getSelectedIndex();\n\n return (\n <>\n \n \n \n );\n }\n\n private _getSelectedIndex(): number {\n if (this.props.controlledByParent) {\n let selectedIndex = -1;\n const selectedKey = this.props.selectedOption.key;\n for (let i = 0; i < this.props.dropdownOptions.length; i++) {\n if (this.props.dropdownOptions[i].key === selectedKey) {\n selectedIndex = i;\n break;\n }\n }\n\n return selectedIndex;\n }\n\n return this.state.selectedIndex;\n }\n\n private _onSelectOption(event: React.ChangeEvent): void {\n const {\n dropdownOptions,\n onSelectOption\n } = this.props;\n const index = event.currentTarget.selectedOptions[0].index;\n const selectedOption = dropdownOptions[index];\n this.setState({ selectedIndex: index });\n onSelectOption({ selectedOption });\n }\n}\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nimport * as Msdyn365 from '@msdyn365-commerce/core';\nimport * as React from 'react';\n\nimport { INodeProps } from './node';\n\nexport interface IModuleProps extends INodeProps {\n moduleProps: Msdyn365.IModule;\n}\n\nexport const Module: React.FC = ({ className = '', id = '', tag: Tag = 'div', moduleProps, ...restAttribute }) => (\n \n);\n\nexport default Module;\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nimport * as Msdyn365 from '@msdyn365-commerce/core';\n\nexport enum VariantType {\n Browser,\n Viewport\n}\n\n/**\n * IsMobile properties.\n */\nexport interface IMobileProps {\n\n /**\n * Contains variant i.e browser | viewport.\n */\n variant?: VariantType;\n context?: Msdyn365.IRequestContext;\n}\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nimport debounce from 'lodash/debounce';\nimport * as React from 'react';\n\nimport { IQuantityProps } from './Quantity.props';\n\ninterface IQuantityState {\n currentInput: number;\n}\n\n/**\n * Quantity Component - This component is used to allow input of quantity between a\n * range of values.\n */\n\nexport default class Quantity extends React.PureComponent {\n public static defaultProps: Partial = {\n min: 1\n };\n\n private readonly inputRef: React.RefObject = React.createRef();\n\n constructor(props: IQuantityProps) {\n super(props);\n this.state = { currentInput: props.currentCount ?? 1 };\n this._handleChange = this._handleChange.bind(this);\n }\n\n public render(): JSX.Element {\n const currentValue = this.state.currentInput;\n\n return (\n \n );\n }\n\n private _handleChange(e: React.ChangeEvent): void {\n const currentValue = Number.parseInt((e.target.value), 10);\n const minValue = this.props.min === undefined ? 1 : this.props.min;\n const inputElement = this.inputRef && this.inputRef.current && this.inputRef.current instanceof HTMLInputElement && this.inputRef.current;\n\n if (currentValue > this.props.max) {\n this.setState(\n { currentInput: this.props.max },\n () => {\n debounce(\n () => {\n this.props.onChange && this.props.onChange(this.state.currentInput);\n },\n 200)();\n }\n );\n } else {\n this.setState(\n { currentInput: currentValue },\n () => {\n debounce(\n () => {\n if (!isNaN(this.state.currentInput) && !(this.state.currentInput < minValue)) {\n this.props.onChange && this.props.onChange(this.state.currentInput);\n\n if (inputElement) {\n inputElement.setAttribute('aria-valuenow', currentValue.toString());\n inputElement.setAttribute('value', currentValue.toString());\n }\n }\n },\n 200)();\n }\n );\n }\n }\n\n private readonly _validateMin = (): void => {\n const minValue = this.props.min === undefined ? 1 : this.props.min;\n if (isNaN(this.state.currentInput) || (this.state.currentInput < minValue)) {\n this.setState({ currentInput: minValue }, () => {\n this.props.onChange && this.props.onChange(this.state.currentInput);\n });\n } else {\n this.props.onChange && this.props.onChange(this.state.currentInput);\n }\n };\n}\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nimport IncrementalQuantity from './IncrementalQuantity';\n\nexport * from './IncrementalQuantity.props';\n\nexport {\n IncrementalQuantity\n};\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nimport { EnumExtensions } from '@msdyn365-commerce-modules/retail-actions';\nimport React from 'react';\n\nimport Button from '../button/Button';\nimport { Popover } from '../popover';\n\n/**\n * Resources for the price editor mode selection.\n */\nexport interface IPriceEditorModeSelectionResources {\n specifyAmountButtonText: string;\n payFullAmountButtonText: string;\n}\n\n/**\n * Props for the price editor mode selection.\n */\nexport interface IPriceEditorModeSelectionProps {\n className: string;\n\n resources: IPriceEditorModeSelectionResources;\n\n currentState: PriceEditorModeSelectionState;\n onStateChanged(state: PriceEditorModeSelectionState): void;\n}\n\n/**\n * Defines editor modes for the amount.\n */\nexport enum PriceEditorModeSelectionState {\n full = 0,\n partial = 1\n}\n\n/**\n * Retrieves resource value based by the given mode state.\n * @param modeState - Given state.\n * @param resources - All resources.\n * @returns Resource value for the given state.\n */\nconst getPriceEditorModeSelectionStateResources = (modeState: PriceEditorModeSelectionState, resources: IPriceEditorModeSelectionResources): string => {\n switch (modeState) {\n case PriceEditorModeSelectionState.full:\n return resources.payFullAmountButtonText;\n case PriceEditorModeSelectionState.partial:\n return resources.specifyAmountButtonText;\n default:\n throw new Error('Failed to retrieve resource description for unknown price editor selection state.');\n }\n};\n\n/**\n * On click functionality.\n * @param handleStateChange - Handle change state function.\n * @param modeState - New state.\n * @returns Event handler.\n */\nconst onClickHandler = (handleStateChange: (modeState: PriceEditorModeSelectionState) => void, modeState: PriceEditorModeSelectionState) => () => {\n handleStateChange(modeState);\n};\n\n/**\n * Renders a button that allows to update the mode to the given state.\n * @param modeState - The state to render.\n * @param resources - Resource values.\n * @param className - Element class name.\n * @param handleStateChange - Event handler to update the state.\n * @returns React node.\n */\nconst renderModeStateItem = (\n modeState: PriceEditorModeSelectionState,\n resources: IPriceEditorModeSelectionResources,\n className: string,\n handleStateChange: (modeState: PriceEditorModeSelectionState) => void): React.ReactNode => {\n\n const stateStringRepresentation = PriceEditorModeSelectionState[modeState];\n\n return (\n \n );\n};\n\n/**\n * On Toggle Popover functionality.\n * @param setPopoverState -Set popover state function.\n * @param isPopoverState -Boolean value.\n * @returns Set toggle popover state functionality.\n */\nconst togglePopoverHandler = (setPopoverState: React.Dispatch>, isPopoverState: boolean) => () => {\n setPopoverState(!isPopoverState);\n};\n\n/**\n * Price editor component which handles selection modes (for instance, full or partial amount).\n * @param props - Configuration of the component.\n * @returns React element.\n */\nexport const PriceEditorModeSelectionComponent: React.FC = (props: IPriceEditorModeSelectionProps) => {\n const popoverReference = React.createRef();\n const [isPopoverShown, setIsPopoverShown] = React.useState(false);\n\n const [modeState, setModeState] = React.useState(props.currentState);\n\n /**\n * Updates component state when a selection is changed.\n * @param clickedState - New mode state.\n */\n const onChangeMode = (clickedState: PriceEditorModeSelectionState) => {\n setModeState(clickedState);\n setIsPopoverShown(false);\n props.onStateChanged(clickedState);\n };\n\n return (\n
\n \n {getPriceEditorModeSelectionStateResources(modeState, props.resources)}\n \n \n {\n EnumExtensions.getEnumValues(PriceEditorModeSelectionState).map(state => {\n return renderModeStateItem(state, props.resources, props.className, onChangeMode);\n })\n }\n \n
\n );\n};\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nimport { ObjectExtensions } from '@msdyn365-commerce-modules/retail-actions';\nimport classnames from 'classnames';\nimport * as React from 'react';\n\nimport { IPriceEditorModeSelectionResources, PriceEditorModeSelectionComponent, PriceEditorModeSelectionState } from './price-editor-mode-selection';\n\n/**\n * Resources for price editor.\n */\nexport interface IPriceEditorResources extends IPriceEditorModeSelectionResources {\n priceEditorInputAriaLabel: string;\n}\n\n/**\n * The props required to render the component.\n */\nexport interface IPriceEditorProps {\n className: string;\n\n defaultAmount: number;\n\n resources: IPriceEditorResources;\n\n minimumValue?: number;\n maximumValue?: number;\n\n handleChange?(newValue: number): void;\n}\n\n/**\n * The state of the component.\n */\nexport interface IPriceEditorState {\n currentValue?: number;\n isInputFocused: boolean;\n}\n\n/**\n * Provides an input field which allows entering a price amount.\n */\nexport class PriceEditor extends React.PureComponent {\n\n private static readonly _precision = 2;\n\n private readonly _inputRef: React.RefObject;\n\n public constructor(props: IPriceEditorProps) {\n super(props);\n\n this._inputRef = React.createRef();\n\n let defaultValue = props.defaultAmount;\n\n if (!ObjectExtensions.isNullOrUndefined(this.props.minimumValue) && defaultValue < this.props.minimumValue) {\n defaultValue = this.props.minimumValue;\n } else if (!ObjectExtensions.isNullOrUndefined(this.props.maximumValue) && defaultValue > this.props.maximumValue) {\n defaultValue = this.props.maximumValue;\n }\n\n this.state = {\n currentValue: defaultValue,\n isInputFocused: false\n };\n }\n\n public render(): JSX.Element {\n const containerClassName = 'msc-price-editor';\n\n const hasMultipleModes = !ObjectExtensions.isNullOrUndefined(this.props.maximumValue);\n\n let mode = PriceEditorModeSelectionState.partial;\n\n if (!ObjectExtensions.isNullOrUndefined(this.props.maximumValue) && this.state.currentValue === this.props.maximumValue) {\n mode = PriceEditorModeSelectionState.full;\n }\n\n const formattedValue = this.state.currentValue?.toFixed(PriceEditor._precision) ?? '';\n const editedValue = this.state.currentValue ?? '';\n\n return (\n
\n \n {\n hasMultipleModes &&
\n \n
\n }\n
\n );\n }\n\n /**\n * Handles input focus.\n */\n private readonly _handleInputFocus = () => {\n this.setState({ isInputFocused: true });\n };\n\n /**\n * Handles input blur.\n */\n private readonly _handleInputBlur = () => {\n this.setState({ isInputFocused: false });\n };\n\n /**\n * Handles editor mode state change.\n * @param newState - New selection mode state.\n */\n private readonly _handleEditorModeStateChange = (newState: PriceEditorModeSelectionState) => {\n if (newState === PriceEditorModeSelectionState.full) {\n this._updateAmount(this.props.maximumValue!);\n } else {\n this.setState({ currentValue: undefined });\n this._inputRef.current?.focus();\n }\n };\n\n /**\n * Update the price and calls corresponding callbacks.\n * @param newAmount - New price amount.\n */\n private readonly _updateAmount = (newAmount: number) => {\n this.setState({ currentValue: newAmount });\n\n if (this.props.handleChange) {\n this.props.handleChange(newAmount);\n }\n };\n\n /**\n * Handles value change.\n * @param event - React change event.\n */\n private readonly _handleChange = (event: React.ChangeEvent) => {\n let currentValue = Number.parseFloat(event.target.value);\n\n if (Number.isNaN(currentValue)) {\n this.setState({ currentValue: undefined });\n return;\n }\n\n currentValue = +currentValue.toFixed(PriceEditor._precision);\n\n if (!ObjectExtensions.isNullOrUndefined(this.props.minimumValue) && currentValue < this.props.minimumValue) {\n this._updateAmount(this.props.minimumValue);\n } else if (!ObjectExtensions.isNullOrUndefined(this.props.maximumValue) && currentValue > this.props.maximumValue) {\n this._updateAmount(this.props.maximumValue);\n } else {\n this._updateAmount(currentValue);\n }\n };\n}\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nimport classNames from 'classnames';\nimport * as React from 'react';\n\nimport { getPayloadObject, getTelemetryAttributes, IPayLoad } from '../common/telemetryHelper';\nimport { mapToCssModules } from '../common/utilities';\nimport { IPaginationLinkProps } from './PaginationLink.props';\n\n/**\n * PaginationLink component.\n */\nexport default class PaginationLink extends React.PureComponent {\n public static defaultProps: Partial = {\n tag: 'a',\n role: 'link'\n };\n\n private readonly payLoad: IPayLoad;\n\n constructor(props: IPaginationLinkProps) {\n super(props);\n this.payLoad = getPayloadObject('click', this.props.telemetryContent!, '');\n }\n\n public render(): JSX.Element {\n let { className, cssModule, next, previous, tag: Tag, children, telemetryContent, ...props }: any = this.props;\n let etext: string = children;\n const paginationLinkclasses = mapToCssModules(classNames(className, 'msc-page-link'), cssModule);\n\n let defaultCaret;\n if (previous) {\n defaultCaret = '\\u00AB';\n etext = 'previous';\n } else if (next) {\n defaultCaret = '\\u00BB';\n etext = 'next';\n }\n\n if (children && Array.isArray(children) && children.length === 0) {\n children = null;\n }\n if (!props.href && Tag === 'a') {\n Tag = 'span';\n }\n\n if (previous || next) {\n children = [\n (\n \n {children || defaultCaret}\n \n )\n ];\n }\n\n this.payLoad.contentAction.etext = etext;\n const attribute = getTelemetryAttributes(telemetryContent, this.payLoad);\n\n return (\n \n {children}\n \n );\n }\n}\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nimport classNames from 'classnames';\nimport React from 'react';\n\nimport { Modal, ModalBody, ModalHeader, Node } from '..';\n\nexport interface IModalViewProps {\n classNames?: string;\n galleryCarousel: React.ReactElement;\n modalIsOpen: boolean;\n ontoggle(): void;\n}\n\nexport const ImagefullView: React.FC = (props: IModalViewProps): React.ReactElement => {\n const body = (\n \n { props.galleryCarousel }\n \n );\n\n const modalWindow = (\n \n );\n\n const modalHeader = (\n \n );\n\n return React.cloneElement(modalWindow, {}, modalHeader, body);\n};\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nimport * as React from 'react';\n\nimport { getPayloadObject, getTelemetryAttributes, IPayLoad, UncontrolledTooltip } from '..';\nimport { IFlipperProps } from './Flipper.props';\n\nexport type FlipperSize = 'small' | 'medium' | 'large';\n\n/**\n * Flipper Component - This component is used to add\n * flippers to a carousel/jumbotron.\n */\nexport default class Flipper extends React.PureComponent {\n private readonly payLoad: IPayLoad;\n\n constructor(props: IFlipperProps) {\n super(props);\n this.payLoad = getPayloadObject('click', this.props.telemetryContent!, this.props.telemetryLabel!);\n }\n\n public render(): JSX.Element {\n const { className, glyphProps, size, displayTooltip, disabled, telemetryContent, telemetryLabel, ...props } = this.props;\n const sizeClass = size === 'small' ? 'msc-flipper__small' : (size === 'large' ? 'msc-flipper__large' : '');\n const classNames = className ? `msc-flipper ${sizeClass} ${className}` : `msc-flipper ${sizeClass}`;\n const attribute = getTelemetryAttributes(telemetryContent!, this.payLoad);\n\n // Do not flip next/previous glyphs in RTL (commonly chevron-left and chevron-right)\n glyphProps.className = `${glyphProps.className} msc-no-rtl-flip-required`;\n\n return (\n <>\n \n \n \n {displayTooltip && !disabled && \n {' '}\n {props['aria-label']}\n }\n \n );\n }\n}\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nexport * from './checkbox';\nexport * from './Table';\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nimport MsDyn365 from '@msdyn365-commerce/core';\n\nimport { IMobileProps, VariantType } from './isMobile.props';\n\n/**\n * IsMobile component.\n * @param props\n */\nexport const isMobile = (props: IMobileProps) => {\n const { variant, context } = props;\n switch (variant) {\n case VariantType.Browser:\n if (MsDyn365.isBrowser && window.innerWidth) {\n const gridSettings = context?.gridSettings;\n if (gridSettings) {\n if (gridSettings.xs && window.innerWidth <= gridSettings.xs.w) {\n return 'xs';\n } else if (gridSettings.sm && window.innerWidth <= gridSettings.sm.w) {\n return 'sm';\n } else if (gridSettings.md && window.innerWidth <= gridSettings.md.w) {\n return 'md';\n } else if (gridSettings.lg && window.innerWidth <= gridSettings.lg.w) {\n return 'lg';\n }\n return 'xl';\n\n }\n }\n\n return 'lg';\n case VariantType.Viewport:\n const viewport = context?.device?.Type === 'Mobile' ? 'xs' : 'lg';\n return viewport;\n default:\n return 'lg';\n }\n};\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nimport { IRequestContext } from '@msdyn365-commerce/core';\nimport { debounce } from 'lodash';\nimport { observer } from 'mobx-react';\nimport * as React from 'react';\n\nimport { isMobile, VariantType } from '..';\nimport { getPayloadObject, getTelemetryAttributes, IPayLoad, TelemetryConstant } from '../common/telemetryHelper';\nimport { IIncrementalQuantityProps } from './IncrementalQuantity.props';\n\n/**\n * IIncrementalQuantityState interface.\n */\ninterface IIncrementalQuantityState {\n currentInput: number;\n isUpdating: boolean;\n}\n\n/**\n * Quantity Component - This component is used to add or remove quantity.\n */\n@observer\nexport default class IncrementalQuantity extends React.PureComponent {\n public static defaultProps: Partial = {\n min: 1,\n decrementGlyphClass: 'fas fa-minus',\n incrementGlyphClass: 'fas fa-plus'\n };\n\n private readonly _minValue: number;\n\n private readonly inputRef: React.RefObject = React.createRef();\n\n private readonly payLoad: IPayLoad;\n\n constructor(props: IIncrementalQuantityProps) {\n super(props);\n this.state = { currentInput: props.currentCount ?? 1, isUpdating: false };\n this._onIncrement = this._onIncrement.bind(this);\n this._onDecrement = this._onDecrement.bind(this);\n this._handleChange = this._handleChange.bind(this);\n this.payLoad = getPayloadObject('click', this.props.telemetryContent!, '');\n this._minValue = this.props.min ?? IncrementalQuantity.defaultProps.min!;\n }\n\n public static getDerivedStateFromProps(props: Readonly, state: IIncrementalQuantityState): IIncrementalQuantityState {\n const nextState = { ...state };\n\n if (props.disabled && !state.isUpdating) {\n nextState.isUpdating = true;\n }\n\n if (!props.disabled && state.isUpdating) {\n nextState.currentInput = props.currentCount ?? 1;\n nextState.isUpdating = false;\n }\n return nextState;\n }\n\n public render(): JSX.Element {\n const {\n min,\n max\n } = this.props;\n\n const glyphMinusClassName: string = `${this.props.decrementGlyphClass!} quantity__controls-glyph`;\n const glyphPlusClassName: string = `${this.props.incrementGlyphClass!} quantity__controls-glyph`;\n const decrementDisabled = this.state.currentInput <= (min ?? 1) || this.props.isGiftCard;\n const incrementDisabled = this.state.currentInput >= max || this.props.isGiftCard;\n const currentValue = this.state.currentInput;\n this.payLoad.contentAction.etext = TelemetryConstant.DecrementQuantity;\n const decrementAttributes = getTelemetryAttributes(this.props.telemetryContent!, this.payLoad);\n this.payLoad.contentAction.etext = TelemetryConstant.IncrementQuantity;\n const incrementAttributes = getTelemetryAttributes(this.props.telemetryContent!, this.payLoad);\n const ariaLablelText = `${this.props.inputQuantityAriaLabel ?? ''} ${this.state.currentInput}`;\n\n let extraClassDecrement = '';\n if (decrementDisabled) {\n // The quantity has reached its boundaries (max or min)\n extraClassDecrement = 'disabled';\n\n } else if (this.props.disabled) {\n // This.props.disabled shows if the state is not succeded yet\n extraClassDecrement = 'transition';\n }\n let extraClassIncrement = '';\n if (incrementDisabled) {\n // The quantity has reached its boundaries (max or min)\n extraClassIncrement = 'disabled';\n } else if (this.props.disabled) {\n // This.props.disabled shows if the state is not succeded yet\n extraClassIncrement = 'transition';\n }\n\n return (\n <>\n
\n \n \n \n \n \n \n \n
\n \n );\n }\n\n /**\n * It checks if its in mobile view or not.\n * @returns Boolean.\n */\n private readonly isMobileView = (): boolean => {\n // eslint-disable-next-line @typescript-eslint/consistent-type-assertions -- Added gridsetting values.\n const context = {\n gridSettings: {\n xs: { w: 767 },\n sm: { w: 991 },\n md: { w: 1199 },\n lg: { w: 1599 },\n xl: { w: 1600 }\n }\n } as IRequestContext;\n\n const isMobileCheck = isMobile({ variant: VariantType.Browser, context });\n return isMobileCheck === 'xs' || isMobileCheck === 'sm';\n };\n\n private _onIncrement(): void {\n let invokeCallback = false;\n const currQuantity = this.state.currentInput;\n let updatedQuantity: number;\n\n if (currQuantity < this.props.max) {\n invokeCallback = true;\n updatedQuantity = currQuantity + 1;\n } else {\n invokeCallback = false;\n updatedQuantity = this.props.max;\n }\n\n if (invokeCallback && this.props.onChange) {\n if (this.props.onChange(updatedQuantity)) {\n this.setState({ currentInput: updatedQuantity });\n }\n }\n }\n\n private _onDecrement(): void {\n let invokeCallback = false;\n const currQuantity = this.state.currentInput;\n let updatedQuantity: number;\n\n if (currQuantity >= this._minValue) {\n invokeCallback = true;\n updatedQuantity = currQuantity - 1;\n } else {\n invokeCallback = false;\n updatedQuantity = this._minValue;\n }\n\n if (invokeCallback && this.props.onChange) {\n if (this.props.onChange(updatedQuantity)) {\n this.setState({ currentInput: updatedQuantity });\n }\n }\n }\n\n private _handleChange(e: React.ChangeEvent): void {\n let currentValue = Number.parseInt((e.target.value), 10);\n if (!Number.isNaN(currentValue)) {\n currentValue = Math.min(this.props.max, Math.max(this._minValue, currentValue));\n }\n this.setState(\n { currentInput: currentValue }\n );\n }\n\n /**\n * Updates html element and triggers callbacks whenever state is changed.\n */\n private readonly _handleUpdateState = () => {\n debounce(() => {\n if (Number.isNaN(this.state.currentInput)) {\n return;\n }\n\n // Due of usage debouncer, we may ignore onChange return value\n this.props.onChange && this.props.onChange(this.state.currentInput);\n\n const inputElement = this.inputRef && this.inputRef.current && this.inputRef.current instanceof HTMLInputElement && this.inputRef.current;\n if (inputElement) {\n inputElement.setAttribute('aria-valuenow', this.state.currentInput.toString());\n inputElement.setAttribute('value', this.state.currentInput.toString());\n }\n }, 200)();\n };\n\n /**\n * Validates min and updates.\n */\n private readonly _validateMin = (): void => {\n if (Number.isNaN(this.state.currentInput)) {\n this.setState(\n { currentInput: this._minValue },\n this._handleUpdateState\n );\n } else {\n const currentValue = Math.min(this.props.max, Math.max(this._minValue, this.state.currentInput));\n if (currentValue !== this.state.currentInput) {\n this.setState(\n { currentInput: currentValue },\n this._handleUpdateState\n );\n } else {\n this._handleUpdateState();\n }\n }\n };\n}\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nimport classnames from 'classnames';\nimport * as React from 'react';\n\nimport { Button } from '..';\nimport Collapse from '../collapse/Collapse';\nimport { ICollapseProps } from '../collapse/Collapse.props';\nimport { IDrawerProps } from './Drawer.props';\n\n/**\n * Drawer State Interface\n */\nexport interface IDrawerState {\n isOpen: boolean;\n buttonText?: string;\n}\n\n/**\n * Glyph placement type.\n */\nexport type GlyphPlacement = 'start' | 'end';\n\n/**\n * Drawer - This is a full width uncontrolled collapse where the button glyph changes\n * when the drawer is open and closed.\n */\n\nexport default class Drawer extends React.PureComponent {\n public state: IDrawerState;\n\n private readonly drawerOpenGlyph: string;\n\n private readonly drawerCloseGlyph: string;\n\n private readonly drawerGlyphClass: string;\n\n private isManuallyToggled: boolean;\n\n constructor(props: IDrawerProps) {\n super(props);\n this._toggle = this._toggle.bind(this);\n this.isManuallyToggled = false;\n this.state = { isOpen: (props.collapseProps?.isOpen) ?? false, buttonText: '' };\n this.drawerGlyphClass = classnames('drawer__glyph',\n\n this.props.toggleGlyphClassName ? this.props.toggleGlyphClassName : '');\n\n if (this.props.animateGlyph) {\n this.drawerOpenGlyph = classnames(this.drawerGlyphClass,\n\n this.props.openGlyph ? this.props.openGlyph : (this.props.closeGlyph ? this.props.closeGlyph : ''));\n this.drawerCloseGlyph = this.drawerOpenGlyph;\n } else {\n this.drawerOpenGlyph = classnames(this.drawerGlyphClass,\n\n this.props.openGlyph ? this.props.openGlyph : '');\n this.drawerCloseGlyph = classnames(this.drawerGlyphClass,\n\n this.props.closeGlyph ? this.props.closeGlyph : '');\n }\n }\n\n public render(): JSX.Element {\n const collapseProps = { ...this.props.collapseProps } as ICollapseProps;\n\n // If the drawer is manually toggled by pressing the button, then we use the internal state\n if (collapseProps.isOpen === undefined || this.isManuallyToggled) {\n collapseProps.isOpen = this.state.isOpen;\n } else {\n this.state.isOpen = collapseProps.isOpen;\n }\n collapseProps.children = this.props.children;\n const drawerClass = classnames('drawer',\n\n this.props.className ? this.props.className : '');\n this.isManuallyToggled = false;\n return (\n
\n \n {this._generateDrawerButtonInnerMarkup(collapseProps.isOpen)}\n \n \n
\n );\n }\n\n /**\n * Method generate drawer inner markup.\n * @param collapseState -Drawer button collapse state.\n * @returns Jsx element.\n */\n private _generateDrawerButtonInnerMarkup(collapseState: boolean): JSX.Element {\n const drawerButtonTextClass = classnames('drawer__buttontext',\n\n this.props.toggleButtonClassName ? this.props.toggleButtonClassName : '');\n if (this.props.glyphPlacement === 'end') {\n return (\n <>\n \n {this.props.toggleButtonText}\n \n {this._generateGlyphMarkup('drawer__glyph__end', collapseState)}\n \n );\n }\n\n if (this.props.glyphPlacement === 'start') {\n return (\n <>\n {this._generateGlyphMarkup('drawer__glyph__start', collapseState)}\n \n {this.props.toggleButtonText}\n \n \n );\n }\n return (\n {this.props.toggleButtonText}\n );\n\n }\n\n /**\n * Method generate glyph markup.\n * @param location -Glyph icon location.\n * @param collapseState -Drawer button collapse state.\n * @returns Jsx element.\n */\n private _generateGlyphMarkup(location: string, collapseState: boolean): JSX.Element {\n let glyphClass = collapseState ? this.drawerOpenGlyph : this.drawerCloseGlyph;\n glyphClass = `${glyphClass} ${location}`;\n return (\n \n );\n }\n\n /**\n * Method on click of drawer button.\n * @param e -Mouse event for drawer button.\n */\n private _toggle(e: React.MouseEvent | React.KeyboardEvent): void {\n e.preventDefault();\n this.isManuallyToggled = true;\n\n if (this.props.onToggle) {\n this.setState({ isOpen: !this.state.isOpen, buttonText: e.currentTarget.innerText }, () => this.props.onToggle && this.props.onToggle(this.state));\n } else {\n this.setState({ isOpen: !this.state.isOpen });\n }\n }\n}\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nimport { IComponentProps, IGridSettings, IImageSettings, Image } from '@msdyn365-commerce/core';\nimport { ProductPrice, SimpleProduct } from '@msdyn365-commerce/retail-proxy';\nimport { getFallbackImageUrl } from '@msdyn365-commerce-modules/retail-actions';\nimport * as React from 'react';\n\nimport { Button, getPayloadObject, getTelemetryAttributes, ITelemetryContent, TelemetryConstant } from '..';\nimport { Modal, ModalBody, ModalHeader } from '../modal';\n\nexport interface IPopupProps extends IComponentProps<{ product: SimpleProduct | undefined; price: ProductPrice | undefined }> {\n dialogStrings?: {\n goToCartText: string;\n continueShoppingText: string;\n headerItemOneText: string;\n headerItemFormatText: string;\n headerMessageText: string;\n freePriceText: string;\n originalPriceText: string;\n currentPriceText: string;\n };\n\n className: string;\n imageSettings?: IImageSettings;\n gridSettings: IGridSettings | undefined;\n productQuantity: number;\n priceComponent: React.ReactNode;\n navigationUrl?: string;\n modalOpen: boolean | undefined;\n telemetryContent?: ITelemetryContent;\n setModalOpen(newValue: boolean): void;\n}\n\nexport const Popup = (popupProps: IPopupProps) => {\n const { dialogStrings, className, imageSettings, gridSettings, data: { product, price }, productQuantity, priceComponent, navigationUrl, modalOpen, telemetryContent, setModalOpen, context } = popupProps;\n const closeModal = React.useCallback(() => {\n setModalOpen(false);\n }, [setModalOpen]);\n if (!dialogStrings || !product) {\n return null;\n }\n const payLoad = getPayloadObject('click', telemetryContent!, TelemetryConstant.ContinueShopping);\n const continueShoppingAttribute = getTelemetryAttributes(telemetryContent!, payLoad);\n payLoad.contentAction.etext = TelemetryConstant.ViewBagAndCheckout;\n const viewBagAttribute = getTelemetryAttributes(telemetryContent!, payLoad);\n\n const fallbackImageUrl = getFallbackImageUrl(product.ItemId, context.actionContext.requestContext.apiSettings);\n if (imageSettings) {\n imageSettings.cropFocalRegion = true;\n }\n const quantity = productQuantity !== undefined ? productQuantity : 1;\n const itemsString = quantity === 1 ? dialogStrings.headerItemOneText : dialogStrings.headerItemFormatText.replace('{0}', quantity.toString());\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access -- app configs are of generic type\n const shouldDisplayUnitOfMeasure = context.app.config?.unitOfMeasureDisplayType && context.app.config.unitOfMeasureDisplayType !== 'none';\n\n const reducedDimensions: string = product.Dimensions ? product.Dimensions.reduce(\n (str, productDimension) => {\n if (productDimension.DimensionValue && productDimension.DimensionValue.Value) {\n if (str) {\n return `${str}, ${productDimension.DimensionValue.Value}`;\n }\n\n return `${productDimension.DimensionValue.Value}`;\n }\n\n return str;\n },\n '') : '';\n\n return (\n \n \n \n {itemsString}\n \n \n {dialogStrings.headerMessageText}\n \n \n \n \n \n {product.Name}\n \n {reducedDimensions !== '' ?
\n {reducedDimensions}\n
: ''}\n {price ? (\n
\n {priceComponent}\n
\n ) : ''}\n {product.DefaultUnitOfMeasure && shouldDisplayUnitOfMeasure ? (\n
\n \n {product.DefaultUnitOfMeasure}\n \n
\n ) : ''}\n \n {dialogStrings.goToCartText}\n \n \n {dialogStrings.continueShoppingText}\n \n
\n \n );\n};\n\nexport default Popup;\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nimport classnames from 'classnames';\nimport * as React from 'react';\n\nimport { IHeadingProps } from './Heading.props';\n\n/**\n * Heading component.\n * @extends {React.PureComponent}\n */\n\nconst Heading = ({ headingTag: HTag = 'h1', tag: Tag, className, text }: IHeadingProps) => (\n Tag ? \n {text}\n : \n {text}\n \n);\n\nexport default Heading;\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nimport classNames from 'classnames';\nimport { Data } from 'popper.js';\nimport * as React from 'react';\nimport { Arrow, Popper as ReactPopper } from 'react-popper';\n\nimport { getTargetElement, mapToCssModules } from '../common/utilities';\nimport { IPopperContentProps } from './PopperContent.props';\n\nexport interface IPopperContentState {\n placement?: string;\n isOpen: boolean;\n}\n\n/**\n * Renders popper content. This is an internal helper class shared between components.\n */\nexport default class PopperContent extends React.Component {\n\n public static defaultProps: Partial = {\n boundariesElement: 'scrollParent',\n placement: 'auto',\n hideArrow: false,\n isOpen: false,\n offset: 0,\n fallbackPlacement: 'flip',\n flip: true,\n container: 'body',\n modifiers: {}\n };\n\n constructor(props: IPopperContentProps) {\n super(props);\n\n this._handlePlacementChange = this._handlePlacementChange.bind(this);\n this.state = { isOpen: props.isOpen };\n }\n\n public componentDidMount(): void {\n this._handleProps();\n }\n\n public componentDidUpdate(prevProps: IPopperContentProps): void {\n if (this.props.isOpen !== prevProps.isOpen) {\n this._handleProps();\n }\n }\n\n public shouldComponentUpdate(nextProps: IPopperContentProps,\n nextState: IPopperContentState): boolean {\n if (this.state === nextState && this.props === nextProps) {\n return false;\n }\n return true;\n }\n\n public render(): JSX.Element | null {\n return this.props.isOpen ? this._renderChildren() : null;\n }\n\n private _handlePlacementChange(data: Data): Data {\n if (this.state.placement !== data.placement) {\n this.setState({ placement: data.placement });\n }\n\n return data;\n }\n\n private _handleProps(): void {\n if (this.props.container !== 'inline') {\n if (this.props.isOpen) {\n this._show();\n } else {\n this._hide();\n }\n }\n }\n\n private _hide(): void {\n this.setState({ isOpen: false });\n }\n\n private _show(): void {\n this.setState({ isOpen: true });\n }\n\n private _renderChildren(): JSX.Element | null {\n const {\n cssModule,\n children,\n isOpen,\n flip,\n offset,\n target,\n fallbackPlacement,\n focusOut,\n placementPrefix,\n arrowClassName: arrowClassNameOrUndefined,\n hideArrow,\n className,\n tag,\n modifiers,\n boundariesElement,\n ...attrs\n } = this.props;\n\n const arrowClassName = mapToCssModules(\n classNames(\n 'msc-arrow',\n arrowClassNameOrUndefined\n ),\n cssModule\n );\n\n const placement = (this.state.placement || attrs.placement || 'auto').split('-')[0];\n const popperClassName = mapToCssModules(\n classNames(\n className,\n placementPrefix ? `${placementPrefix}-${placement}` : placement\n ),\n this.props.cssModule\n );\n\n const extendedModifiers = {\n offset: { offset },\n flip: { enabled: flip, behavior: fallbackPlacement },\n preventOverflow: { boundariesElement },\n update: {\n enabled: true,\n order: 950,\n fn: this._handlePlacementChange\n },\n ...modifiers\n };\n\n const targetElement = getTargetElement(target);\n if (targetElement === null) {\n return null;\n }\n\n return (\n \n {children}\n {!hideArrow && }\n \n );\n }\n}\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nimport classNames from 'classnames';\nimport * as React from 'react';\nimport Transition, { ENTERED, ENTERING, EXITED, EXITING, UNMOUNTED } from 'react-transition-group/Transition';\n\nimport { mapToCssModules, TransitionTimeouts } from '../common/utilities';\nimport { IFadeProps } from './Fade.props';\n\nexport interface IFadeState {\n fadeIn: boolean;\n}\n\ntype TransitionStatus =\n typeof ENTERING |\n typeof ENTERED |\n typeof EXITING |\n typeof EXITED |\n typeof UNMOUNTED;\n\n/**\n * Fade component.\n */\nexport default class Fade extends React.Component {\n\n public static defaultProps: Partial = {\n tag: 'div',\n baseClass: 'fade',\n baseClassActive: 'show',\n timeout: TransitionTimeouts.Fade,\n in: true,\n appear: true,\n enter: true,\n exit: true\n };\n\n public shouldComponentUpdate(nextProps: IFadeProps): boolean {\n if (nextProps.in || (this.props.in !== nextProps.in)) {\n return true;\n }\n return false;\n }\n\n public render(): JSX.Element | null {\n const {\n tag,\n className,\n cssModule,\n baseClass,\n baseClassActive,\n\n appear,\n enter,\n exit,\n in: fadeIn,\n mountOnEnter,\n unmountOnExit,\n timeout: timeoutOrUndefined,\n addEndListener,\n onEnter,\n onEntering,\n onEntered,\n onExit,\n onExiting,\n onExited,\n children,\n\n ...otherProps } = this.props;\n const timeout = timeoutOrUndefined !== undefined ? timeoutOrUndefined : TransitionTimeouts.Fade;\n\n const transitionProps = {\n appear,\n enter,\n exit,\n in: fadeIn,\n mountOnEnter,\n unmountOnExit,\n timeout,\n addEndListener,\n onEnter,\n onEntering,\n onEntered,\n onExit,\n onExiting,\n onExited,\n children\n };\n\n const Tag = this.props.tag ? this.props.tag : 'div';\n const baseClassAlways = baseClass || 'fade';\n const baseClassActiveAlways = baseClassActive || 'show';\n\n return (\n \n {(status: TransitionStatus) => {\n const isActive = status === 'entered';\n const classes = mapToCssModules(\n classNames([\n className,\n baseClassAlways,\n isActive && baseClassActiveAlways\n ]),\n cssModule\n );\n\n return (\n \n {children}\n \n );\n }}\n \n );\n }\n}\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nimport { IDictionary, TelemetryEvent } from '@msdyn365-commerce/core';\nimport { ITelemetry } from '@msdyn365-commerce/telemetry-internal';\n\nexport interface IContentAction {\n pgname: string;\n mname: string;\n etext?: string;\n recid?: string;\n etype?: string;\n}\n\nexport interface IPayLoad {\n contentCategory: string;\n contentAction: IContentAction;\n}\n\nexport interface ITelemetryContent {\n pageName: string;\n moduleName: string;\n telemetry?: ITelemetry;\n}\n\nexport enum TelemetryConstant {\n ShopSimliarLooks = 'shop similar looks',\n ShopSimliarDescription = 'shop similar description',\n PickupInStore = 'pick up in store',\n PreferredStore = 'set as preferred store',\n RemovePreferredStore = 'remove preferred store',\n IncrementQuantity = 'Increment quantity',\n DecrementQuantity = 'Decrement quantity',\n Checkout = 'Checkout',\n GuestCheckout = 'Guest checkout',\n BackToShopping = 'Back to shopping',\n ApplyPromoCode = 'Apply promo code',\n ViewMore = 'View more',\n OrderDetails = 'Order details',\n AvailablePoints = 'Available points',\n ExpiringPoints = 'Expiring points',\n AddUser = 'Add user',\n BuyItAgain = 'Buy it again',\n ContactNumber = 'ContactNumber',\n CheckoutChange = 'Change',\n Save = 'Save',\n SaveContinue = 'Save and Continue',\n Cancel = 'Cancel',\n DeliveryOptions = 'Delivery options',\n CheckoutTermsAndConditions = 'Checkout terms and conditions',\n ExpandAll = 'Expand all',\n CollapseAll = 'Collapse all',\n Expand = 'Expand',\n Collapse = 'Collapse',\n SignIn = 'Sign in',\n SignUp = 'Sign up',\n SignOut = 'Sign out',\n LoyaltyDetailLink = 'Loyalty detail ink',\n LoyaltyTermsLink = 'Loyalty terms link',\n LoyaltyTermsCancel = 'Loyalty terms cancel',\n LoyaltyTermsSubmit = 'Loyalty terms submit',\n LoyaltyTermsAgree = 'Loyalty terms agree',\n RemoveCartItem = 'Remove cart item',\n EditCart = 'Edit cart',\n BackToTop = 'Back to top',\n Logo = 'Logo',\n NavIcon = 'Navigation icon',\n ViewBagAndCheckout = 'View bag and checkout',\n ContinueShopping = 'Continue shopping',\n AddOrderTemplateToCart = 'Add order template to cart',\n PromoBannerClose = 'Close promo banner',\n WriteReview = 'Write Review',\n Next = 'Next',\n Previous = 'Previous',\n SubmitReview = 'Submit review',\n SuccessButton = 'Success',\n SearchStore = 'Search store',\n ShowAllStore = 'Show all store',\n ToggleMapView = 'Toggle map view',\n PrivacyPolicy = 'Privacy policy',\n ViewShoppingBag = 'View shopping bag',\n MyProfile = 'My profile',\n seeDetails = 'See Details'\n}\n\n/**\n * Returns the payload Object.\n * @param {string} contentCategory - Content Category.\n * @param {IModule} props - Module props.\n * @param pageName\n * @param {string} moduleName - Module Name.\n * @param {string} etext - Etext Name.\n * @param {string} recid - Recid Name.\n * @param telemetry\n */\nexport function getTelemetryObject(pageName: string, moduleName: string, telemetry: ITelemetry): ITelemetryContent {\n const telemetryContent: ITelemetryContent = { pageName, moduleName, telemetry };\n return telemetryContent;\n}\n\n/**\n * Returns the payload Object.\n * @param {string} contentCategory - Content Category.\n * @param {IModule} props - Module props.\n * @param {string} moduleName - Module Name.\n * @param eventType\n * @param telemetryContent\n * @param {string} etext - Etext Name.\n * @param {string} recid - Recid Name.\n */\nexport function getPayloadObject(eventType: string, telemetryContent: ITelemetryContent, etext: string, recid?: string): IPayLoad {\n const pageName = telemetryContent && telemetryContent.pageName ? telemetryContent.pageName : '';\n const moduleName = telemetryContent && telemetryContent.moduleName ? telemetryContent.moduleName : '';\n const payload: IPayLoad = {\n contentCategory: eventType,\n contentAction: {\n pgname: pageName,\n mname: moduleName,\n etext,\n recid,\n etype: eventType\n }\n };\n return payload;\n}\n\n/**\n * Returns the telemetry Attributes.\n * @param {IModule} props - Module Props.\n * @param telemetryContent\n * @param {IPayLoad} payLoad - Pay Load.\n */\nexport function getTelemetryAttributes(telemetryContent: ITelemetryContent, payLoad: IPayLoad): IDictionary | undefined {\n const contentData = payLoad.contentAction.recid ? payLoad.contentAction.recid : payLoad.contentAction.etext;\n const attributes: IDictionary | undefined = telemetryContent &&\n telemetryContent.telemetry &&\n telemetryContent.telemetry.setTelemetryAttribute &&\n telemetryContent.telemetry.setTelemetryAttribute(contentData!, payLoad.contentAction);\n return attributes;\n}\n\n/**\n * Returns the telemetry Attributes.\n * @param {IModule} props - Module Props.\n * @param {IPayLoad} payLoad - Pay Load.\n */\n\nexport const onTelemetryClick = (telemetryContent: ITelemetryContent, payLoad: IPayLoad, linkText: string) => () => {\n payLoad.contentAction.etext = linkText;\n if (telemetryContent && telemetryContent.telemetry) {\n telemetryContent.telemetry.logEvent(TelemetryEvent.Custom, payLoad);\n }\n};\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nimport classNames from 'classnames';\nimport * as React from 'react';\n\nimport { mapToCssModules } from '../common/utilities';\nimport Fade from '../fade/Fade';\nimport UncontrolledTooltip from '../tooltip/UncontrolledTooltip';\nimport { IAlertProps } from './Alert.props';\n\n/**\n * Alert component.\n */\nexport default class Alert extends React.PureComponent {\n\n public static defaultProps: Partial = {\n color: 'success',\n isOpen: true,\n tag: 'div',\n closeAriaLabel: 'Close',\n fade: true,\n assertive: false,\n includeAlertClass: true,\n transition: {\n ...Fade.defaultProps,\n unmountOnExit: true\n }\n };\n\n public render(): JSX.Element {\n const {\n id,\n className,\n closeClassName,\n cssModule,\n tag,\n toggle,\n color,\n isOpen,\n children,\n transition,\n fade,\n assertive,\n includeAlertClass,\n 'aria-label': ariaLabel\n } = this.props;\n\n const classes = includeAlertClass ? mapToCssModules(\n classNames(\n className,\n 'msc-alert',\n `msc-alert-${color}`\n ),\n cssModule\n ) : className;\n\n const closeClasses = mapToCssModules(classNames('close', closeClassName), cssModule);\n\n const alertTransition = {\n ...Fade.defaultProps,\n ...transition,\n baseClass: fade ? 'fade' : '',\n timeout: fade ? (transition ? transition.timeout : 0) : 0,\n appear: !!fade,\n enter: !!fade,\n exit: !!fade\n };\n\n const Tag = tag || 'div';\n const buttonId = fade ? 'buttonDismiss' : 'buttonFadeless';\n\n const innerContent = (\n <>\n {toggle ?
\n \n \n close\n \n
: null}\n {children}\n \n );\n\n const style = isOpen ? undefined : { display: 'none' };\n\n // When using assertive alerts, you need to have the assertive region rendered on the page from\n // the start. When using fade, the entire fade region doesn't render. So you gotta first wrap the\n // fade region in a tag, keep that tag hidden if the alert is closed.\n //\n // Note that this current approach will have some issues if tag is something like li. But that is a bridge\n // that can be crossed when/if we need to cross it this works for divs/spans so it should be good enough for now\n if (fade && assertive) {\n return (\n \n \n {innerContent}\n \n \n );\n } else if (fade) {\n return (\n \n {innerContent}\n \n );\n }\n return (\n \n {innerContent}\n \n );\n\n }\n}\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nimport * as Msdyn365 from '@msdyn365-commerce/core';\nimport * as React from 'react';\n\nimport { getPayloadObject, getTelemetryAttributes, TelemetryConstant } from '..';\nimport { IBackToTopProps } from './BackToTop.props';\n\nexport interface IBackToTopStateAttributes {\n 'aria-hidden': boolean;\n 'tabIndex': number;\n}\n\nexport interface IBackToTopState extends React.ComponentState {\n attributes: IBackToTopStateAttributes;\n}\n\n/**\n * Back To Top - This component is used to scroll to the top of the page.\n */\nexport default class BackToTop extends React.PureComponent {\n public static defaultProps: Partial = {\n className: 'btn btn-lg btn-secondary',\n delayInMs: 0,\n scrollStepInPx: 25\n };\n\n private readonly attributes?: Msdyn365.IDictionary;\n\n constructor(props: IBackToTopProps) {\n super(props);\n this.state = { attributes: { 'aria-hidden': true, tabIndex: -1 } };\n this._reevaluatePosition = this._reevaluatePosition.bind(this);\n this._scrollToTop = this._scrollToTop.bind(this);\n const payLoad = getPayloadObject('click', props.telemetryContent!, TelemetryConstant.BackToTop);\n this.attributes = getTelemetryAttributes(props.telemetryContent!, payLoad);\n }\n\n public componentDidMount(): void {\n window.addEventListener('resize', this._reevaluatePosition);\n window.addEventListener('scroll', this._reevaluatePosition);\n this._reevaluatePosition();\n }\n\n public componentWillUnmount(): void {\n window.removeEventListener('resize', this._reevaluatePosition);\n window.removeEventListener('scroll', this._reevaluatePosition);\n }\n\n public render(): JSX.Element {\n const { className, threshold, delayInMs, scrollStepInPx, ...props } = this.props;\n const children = this.props.children || ();\n if (this.props.text) {\n return (\n \n {this._renderHeading(this.props.text)}\n );\n }\n return (\n \n {children}\n );\n\n }\n\n private readonly _renderHeading = (text: string): JSX.Element | undefined => {\n return (\n \n );\n };\n\n private _scrollStep(): void {\n if ((document.documentElement.scrollTop || document.body.scrollTop) === 0) {\n clearInterval(this.state.intervalId);\n this.setState({ intervalId: 0 });\n this._reevaluatePosition();\n }\n\n if (this.state.intervalId !== 0) {\n window.scrollTo(0, document.body.scrollTop - this.props.scrollStepInPx);\n document.body.scrollTop = document.body.scrollTop > 0 ? document.body.scrollTop - this.props.scrollStepInPx : 0;\n }\n }\n\n private _scrollToTop(e: any): void {\n e.preventDefault();\n const intervalId = setInterval(this._scrollStep.bind(this), this.props.delayInMs);\n this.setState({ intervalId });\n }\n\n private _reevaluatePosition(): void {\n // TODO:\n // change the threshold minimum to zero\n // add a prop for specifying multiplier of page height instead of absolute threshold\n // add clientWidth check to hide at < 768\n const scrollTop = window.pageYOffset || document.body.scrollTop;\n const height = Math.min(window.innerHeight, document.documentElement.clientHeight);\n const threshold = Math.min(this.props.threshold !== undefined ? this.props.threshold : -1, 100);\n const hide = scrollTop > 0 && threshold >= 0 ? scrollTop < (document.documentElement.scrollHeight - height) * threshold / 100 : scrollTop < height * 2;\n const tabIndexValue = hide ? -1 : 0;\n this.setState({ attributes: { 'aria-hidden': hide, tabIndex: tabIndexValue } });\n }\n}\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nimport * as React from 'react';\n\nimport { addThrottledEvent, getCSS } from '../common/utilities';\nimport Flipper from '../flipper/Flipper';\nimport { ISingleSlideCarouselProps } from './SingleSlideCarousel.props';\n\ninterface ISingleSlideCarouselState {\n showPrevious: boolean;\n showNext: boolean;\n offset: number;\n}\n\n/**\n * SingleSlideCarousel - yup.\n */\nexport default class SingleSlideCarousel extends React.PureComponent {\n private static readonly itemsSelector: string = 'msc-ss-carousel-item';\n\n private static readonly verticalItemsSelector: string = 'msc-ss-carousel-vert-item';\n\n private direction: string;\n\n private item: HTMLElement | undefined;\n\n private slide: HTMLElement | undefined;\n\n private carousel: HTMLElement | undefined;\n\n private carouselSize: number = 0;\n\n private slideSize: number = 0;\n\n private itemSize: number = 0;\n\n private resizeThrottledEventHandler?: (event: Event) => void;\n\n private readonly ref: React.RefObject;\n\n private readonly slideRef: React.RefObject;\n\n private readonly itemRef: React.RefObject;\n\n private readonly id: string;\n\n private scrollStart: number | undefined;\n\n private readonly scrollThreshold: number;\n\n private readonly flipperNextLabel: string = 'next';\n\n private readonly flipperPrevLabel: string = 'prev';\n\n constructor(props: ISingleSlideCarouselProps) {\n super(props);\n this._nextSlide = this._nextSlide.bind(this);\n this._previousSlide = this._previousSlide.bind(this);\n this._handleTouchStart = this._handleTouchStart.bind(this);\n this._handleTouchEnd = this._handleTouchEnd.bind(this);\n this._onFocus = this._onFocus.bind(this);\n this._onResized = this._onResized.bind(this);\n this.state = { showPrevious: false, showNext: false, offset: 0 };\n this.ref = React.createRef();\n this.slideRef = React.createRef();\n this.itemRef = React.createRef();\n this.direction = 'left';\n this.id = props.parentId || '';\n this.scrollThreshold = this.props.touchScrollThreshold !== undefined ? this.props.touchScrollThreshold : 100;\n }\n\n public componentDidUpdate(): void {\n this.carousel = this.ref.current!;\n this.slide = this.slideRef.current!;\n this.item = this.itemRef.current!;\n this._setSizes();\n this._updateFlippers(this.state.offset);\n }\n\n public componentDidMount(): void {\n this.direction = this.props.vertical ? 'top' : 'left';\n this.carousel = this.ref.current!;\n this.slide = this.slideRef.current!;\n this.item = this.itemRef.current!;\n this._setSizes();\n this.resizeThrottledEventHandler =\n window && addThrottledEvent(window, 'resize', this._onResized as EventListener);\n this._updateFlippers(0);\n }\n\n public componentWillUnmount(): void {\n window && window.removeEventListener('resize', this.resizeThrottledEventHandler!, false);\n }\n\n public render(): JSX.Element {\n const isVert: boolean = this.props.vertical === true;\n const slidePositionStyle = {} as React.CSSProperties;\n const modifiedChildren = this._getClonedChildren(isVert);\n slidePositionStyle[this.direction] = `${this.state.offset}px`;\n const carouselClass = (isVert) ? 'msc-ss-carousel-vert' : 'msc-ss-carousel';\n const carouselSlideClass = (isVert) ? 'msc-ss-carousel-vert-slide' : 'msc-ss-carousel-slide';\n const overflowClass = (isVert) ? 'msc-ss-carousel-vert-strip' : 'msc-ss-carousel-strip';\n const previousFlipperGlyph = (isVert) ? 'msi-chevron-up' : 'msi-chevron-left';\n const nextFlipperGlyph = (isVert) ? 'msi-chevron-down' : 'msi-chevron-right';\n const previousFlipperClassName = (isVert) ? 'msc-ss-carousel-vert__flipper' : 'msc-ss-carousel__flipper';\n const nextFlipperClassName = (isVert) ? 'msc-ss-carousel-vert__flipper msc-ss-carousel-vert__flipper--next' : 'msc-ss-carousel__flipper msc-ss-carousel__flipper--next';\n const disableClassName = !this.state.showPrevious || !this.state.showNext ? 'disabled' : null;\n return (\n \n 0)}\n telemetryContent={this.props.telemetryContent}\n telemetryLabel={this.flipperPrevLabel}\n />\n 0)}\n telemetryContent={this.props.telemetryContent}\n telemetryLabel={this.flipperNextLabel}\n />\n
\n \n {modifiedChildren}\n \n
\n
\n );\n }\n\n private _getClonedChildren(isVert: boolean): React.DetailedReactHTMLElement, HTMLElement>[] {\n return React.Children.map(this.props.children, (child: React.ReactNode, index: number) => {\n const castChild = (child as React.ReactChild) as React.ReactElement;\n if (index === 1) {\n return React.cloneElement(castChild, {\n className: `${isVert ? SingleSlideCarousel.verticalItemsSelector : SingleSlideCarousel.itemsSelector} ${castChild.props.className}`,\n\n // @ts-expect-error\n ref: this.itemRef,\n onFocus: this._onFocus\n });\n }\n return React.cloneElement(castChild, {\n className: `${isVert ? SingleSlideCarousel.verticalItemsSelector : SingleSlideCarousel.itemsSelector} ${castChild.props.className}`,\n\n // @ts-expect-error\n onFocus: this._onFocus\n });\n });\n }\n\n private _nextSlide(): void {\n this._moveSingleSlide(true);\n }\n\n private _previousSlide(): void {\n this._moveSingleSlide(false);\n }\n\n private _handleTouchStart(evt: React.TouchEvent): void {\n if (evt.touches.length === 0) {\n this.scrollStart = undefined;\n } else {\n this.scrollStart = this.props.vertical === true ? evt.touches[0].screenY : evt.touches[0].screenX;\n }\n }\n\n private _handleTouchEnd(evt: React.TouchEvent): void {\n if (evt.changedTouches.length > 0 && this.scrollStart !== undefined) {\n const newTarget: number = this.props.vertical === true ? evt.changedTouches[0].screenY : evt.changedTouches[0].screenX;\n\n const delta = newTarget - this.scrollStart;\n\n if (delta > this.scrollThreshold) {\n this._previousSlide();\n }\n\n if (delta < -this.scrollThreshold) {\n this._nextSlide();\n }\n }\n\n this.scrollStart = undefined;\n\n return;\n }\n\n private _moveSingleSlide(next: boolean): void {\n let currentOffset = Number.parseInt(getCSS(this.slide!, this.direction), 10);\n const carouselSize = this.carouselSize;\n let maxScrollCount = Math.floor(carouselSize / (this.itemSize));\n const directionModifier = next ? -1 : 1;\n currentOffset = !isNaN(currentOffset) && typeof currentOffset === 'number' ? currentOffset : 0;\n\n if (maxScrollCount === 0) {\n maxScrollCount = 1;\n }\n\n maxScrollCount = carouselSize % (this.itemSize) === 0 ? maxScrollCount - 1 : maxScrollCount;\n maxScrollCount = Math.max(maxScrollCount, 1);\n const maxScrollDistance = maxScrollCount * (this.itemSize);\n let distanceToEdge = next ? this.slideSize - carouselSize + currentOffset : Math.abs(currentOffset);\n distanceToEdge = Math.max(0, distanceToEdge);\n\n const offset =\n maxScrollDistance <= distanceToEdge ? maxScrollDistance * directionModifier + currentOffset : distanceToEdge * directionModifier + currentOffset;\n\n this._updateFlippers(offset);\n }\n\n private _setSizes(): void {\n const item = this.item;\n if (item) {\n this.itemSize = this.props.vertical ? item.scrollHeight : item.scrollWidth;\n } else {\n this.itemSize = 0;\n }\n\n this.carouselSize = this._calculateCarouselSize();\n this.slideSize = this.slide ? (this.props.vertical ? this.slide.scrollHeight : this.slide.scrollWidth) : 0;\n }\n\n private _calculateCarouselSize(): number {\n if (!this.carousel) {\n return 0;\n }\n\n const carouselStyle = getComputedStyle(this.carousel);\n\n const padding = this.props.vertical ? Number.parseFloat(carouselStyle.paddingTop || '') + Number.parseFloat(carouselStyle.paddingBottom || '') : Number.parseFloat(carouselStyle.paddingLeft || '') + Number.parseFloat(carouselStyle.paddingRight || '');\n\n return this.props.vertical ? this.carousel.clientHeight - padding : this.carousel.clientWidth - padding;\n }\n\n private _canScrollPrevious(offset: number): boolean {\n return !isNaN(offset) && offset !== 0;\n }\n\n private _canScrollNext(offset: number): boolean {\n if (this.carouselSize + Math.abs(offset) >= this.slideSize) {\n return false;\n }\n\n return true;\n }\n\n private _updateFlippers(offset: number): void {\n this.setState({\n showPrevious: this._canScrollPrevious(offset),\n showNext: this._canScrollNext(offset),\n offset\n });\n }\n\n private _scrollItemIntoView(item: HTMLElement): void {\n const carouselSize = this.carouselSize;\n let offset = (this.props.vertical) ? item.offsetTop : item.offsetLeft;\n let updateOffset = false;\n\n const left = Number.parseInt(getCSS(this.slide!, 'left'), 10) || 0;\n const top = Number.parseInt(getCSS(this.slide!, 'top'), 10) || 0;\n\n if (this.props.vertical) {\n if (top < 0 && -top > offset) {\n if (offset !== 0) {\n offset = -offset + 1;\n }\n updateOffset = true;\n } else if (top + offset > carouselSize - this.itemSize) {\n offset = carouselSize - this.itemSize - offset - 1;\n updateOffset = true;\n }\n } else if (this.direction === 'left') {\n if (left < 0 && -left > offset) {\n if (offset !== 0) {\n offset = -offset + 1;\n }\n updateOffset = true;\n } else if (left + offset > carouselSize - this.itemSize) {\n offset = carouselSize - this.itemSize - offset + 19;\n updateOffset = true;\n }\n }\n\n if (updateOffset) {\n this._updateFlippers(offset);\n\n if (this.props.vertical) {\n setTimeout(() => {\n (this.slide as Node).parentElement!.scrollTop = 0;\n }, 0);\n } else {\n setTimeout(() => {\n (this.slide as Node).parentElement!.scrollLeft = 0;\n }, 0);\n }\n }\n }\n\n private _onFocus(event: React.FocusEvent): void {\n const target = event.currentTarget as HTMLElement;\n this._scrollItemIntoView(target);\n }\n\n private _onCarouselResized(): void {\n this._setSizes();\n let offset = Number.parseInt(getCSS(this.slide!, this.direction), 10);\n\n // Ensure the carousel slide fits across the entire alotted space\n if (!isNaN(offset) && offset < 0 && this.slideSize + offset < this.carouselSize) {\n offset = Math.min(0, this.carouselSize - this.slideSize);\n }\n\n this._updateFlippers(offset);\n }\n\n private readonly _onResized = (): void => {\n this._onCarouselResized();\n };\n}\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nimport Quantity from './Quantity';\n\nexport * from './Quantity.props';\n\nexport {\n Quantity\n};\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nimport * as Msdyn365 from '@msdyn365-commerce/core';\nimport classnames from 'classnames';\nimport * as React from 'react';\n\nimport { Button, getPayloadObject, getTelemetryAttributes, IPayLoad, TelemetryConstant } from '..';\nimport Collapse from '../collapse/Collapse';\nimport { ICollapseProps } from '../collapse/Collapse.props';\nimport { IDrawerProps } from './Drawer.props';\n\nexport interface IControlledDrawerState {\n isOpen: boolean;\n}\n\nexport type GlyphPlacement = 'start' | 'end';\n\n/**\n * ControlledDrawer - This is a full width controlled collapse where the button glyph changes\n * when the drawer is open and closed. The toggle function can be managed by the parent.\n */\n\nexport default class ControlledDrawer extends React.PureComponent {\n private readonly drawerOpenGlyph: string;\n\n private readonly drawerCloseGlyph: string;\n\n private readonly drawerGlyphClass: string;\n\n private isManuallyToggled: boolean;\n\n private isExpanded: boolean;\n\n private readonly payLoad: IPayLoad;\n\n constructor(props: IDrawerProps) {\n super(props);\n const { openGlyph, closeGlyph } = this.props;\n this._toggle = this._toggle.bind(this);\n this.isManuallyToggled = false;\n this.state = { isOpen: (props.collapseProps && props.collapseProps.isOpen) || false };\n this.isExpanded = this.state.isOpen;\n this.drawerGlyphClass = classnames('drawer__glyph', this.props.toggleGlyphClassName || '');\n this.payLoad = getPayloadObject('click', props.telemetryContent!, '');\n\n if (this.props.animateGlyph) {\n this.drawerOpenGlyph = classnames([this.drawerGlyphClass, openGlyph || closeGlyph || '']);\n this.drawerCloseGlyph = this.drawerOpenGlyph;\n } else {\n this.drawerOpenGlyph = classnames([this.drawerGlyphClass, openGlyph || '']);\n this.drawerCloseGlyph = classnames([this.drawerGlyphClass, closeGlyph || '']);\n }\n }\n\n public render(): JSX.Element {\n const collapseProps = { ...this.props.collapseProps } as ICollapseProps;\n collapseProps.isOpen = this.isManuallyToggled ? this.state.isOpen : collapseProps.isOpen || false;\n collapseProps.children = this.props.children;\n const drawerClass = classnames('drawer', this.props.className || '');\n this.isManuallyToggled = false;\n this.isExpanded = collapseProps.isOpen;\n this.state = { isOpen: collapseProps.isOpen };\n this.payLoad.contentAction.etext = collapseProps.isOpen ? TelemetryConstant.Collapse : TelemetryConstant.Expand;\n const attributes = getTelemetryAttributes(this.props.telemetryContent!, this.payLoad);\n return (\n
\n \n {this._generateDrawerButtonInnerMarkup(collapseProps.isOpen)}\n \n \n
\n );\n }\n\n private _generateDrawerButtonInnerMarkup(collapseState: boolean): JSX.Element {\n const { toggleButtonText } = this.props;\n const drawerButtonTextClass = classnames('drawer__buttontext', this.props.toggleButtonClassName || '');\n if (this.props.glyphPlacement === 'end') {\n return (\n <>\n {this._generateTitle(classnames(drawerButtonTextClass, '__start'), toggleButtonText.toString())}\n {this._generateGlyphMarkup('drawer__glyph__end', collapseState)}\n \n );\n }\n\n const isStart = this.props.glyphPlacement === 'start';\n const additionalClassName = `__${isStart ? 'end' : 'start'}`;\n return (\n <>\n {isStart && this._generateGlyphMarkup('drawer__glyph__start', collapseState)}\n {this._generateTitle(classnames(drawerButtonTextClass, additionalClassName), this.props.toggleButtonText.toString())}\n \n );\n }\n\n private _generateTitle(titleLClassName: string, title: string): JSX.Element {\n if (this.props.onTextChange && this.props.requestContext) {\n return (\n \n );\n }\n return (\n \n {title}\n \n );\n\n }\n\n private _generateGlyphMarkup(location: string, collapseState: boolean): JSX.Element {\n const glyphClass = `${collapseState ? this.drawerOpenGlyph : this.drawerCloseGlyph} ${location}`;\n return (\n \n );\n }\n\n private _toggle(e: React.MouseEvent | React.KeyboardEvent): void {\n e.preventDefault();\n this.isExpanded = !this.isExpanded;\n this.setState({ isOpen: this.isExpanded });\n this.isManuallyToggled = true;\n if (this.props.onToggle) {\n this.props.onToggle(this.state);\n }\n }\n}\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nexport interface IClientDimension {\n width: number;\n height: number;\n}\n\n/* A type safe Dictionary */\nexport interface IDictionaryStringString {\n [key: string]: string;\n}\n\n/**\n * @interface IGrid\n * @classdesc - The IGrid interface contract.\n * @export\n */\nexport interface IGrid {\n rows: number;\n columns: number;\n}\n\n/**\n * Clamp position between a range.\n * @param {number} value - Value to be clamped.\n * @param {number} min - Minimum value in range.\n * @param {number} max - Maximum value in range.\n * @returns The clap value if min passed is less than max else returns 0.\n */\nexport function clamp(value: number, min: number, max: number): number {\n if (min <= max) {\n return Math.min(Math.max(value, min), max);\n }\n return 0;\n\n}\n\n/**\n * Upper case the first letter of the string, if only one char exists on the string, uppercase it.\n * @param {string} value - Value to be upper cased.\n * @returns The upper cased string of the passed value, if it has just one char uppercase it.\n */\nexport function toUpperCaseFirstChar(value: string): string {\n if (value.length > 1) {\n return value.charAt(0).toUpperCase() + value.substr(1);\n }\n if (value.length === 1) {\n return value.charAt(0).toUpperCase();\n }\n return '';\n\n}\n\nexport function htmlCollectionToArray(nodeList: HTMLCollection): HTMLElement[] {\n return Array.prototype.slice.call(nodeList);\n}\n\nexport function getCSS(element: HTMLElement, property: string): string {\n let style = element.style[property];\n\n if (!style) {\n style = getComputedStyle(element)[property];\n }\n\n return style;\n}\n\nexport function createThrottledEvent(listener: EventListener, threshold: number):\n(event: Event) => void {\n let timer: any;\n let last = 0;\n\n return (event: Event) => {\n const now = Date.now();\n\n if (timer) {\n clearTimeout(timer);\n timer = undefined;\n }\n\n if (last && (now < last + threshold)) {\n timer = setTimeout(() => {\n last = Date.now();\n listener(event);\n },\n threshold - (now - last));\n } else {\n last = now;\n listener(event);\n }\n };\n}\n\nexport function addThrottledEvent(target: EventTarget, name: string, listener: EventListener, threshold: number = 150):\n(event: Event) => void {\n\n const throttledEventHandler = createThrottledEvent(listener, threshold);\n target.addEventListener(name, throttledEventHandler, false);\n\n return throttledEventHandler;\n}\n\n/* RTS utilities */\n/* TODO: Using any here for now, need to convert cssmodules into a dictionary in all modules */\nexport function mapToCssModules(className: string = '', cssModule: any): string {\n if (!cssModule) {\n return className;\n }\n\n return className\n .split(' ')\n .map((c: string) => cssModule[c] || c)\n .join(' ');\n}\n\nexport function isRef(target: any): boolean {\n if (!target) {\n return false;\n }\n\n return (>target).current !== undefined;\n}\n\nexport function isElement(target: any): boolean {\n if (!target) {\n return false;\n }\n\n return (target).addEventListener !== undefined;\n}\n\nexport const keyCodes = {\n esc: 27,\n space: 32,\n tab: 9,\n up: 38,\n down: 40,\n enter: 13\n};\n\ninterface IMap {\n [key: string]: T;\n}\nconst warned: IMap = {};\n\nexport function warnOnce(message: string): void {\n if (!warned[message]) {\n if (typeof console !== 'undefined') {\n throw new Error(message);\n }\n warned[message] = true;\n }\n}\n\nexport const canUseDOM = !!(\n typeof window !== 'undefined' &&\n window.document &&\n window.document.createElement\n);\n\nexport function findDOMElements(target: string): NodeListOf | string | null {\n try {\n if (typeof target === 'string' && canUseDOM) {\n let selection = document.querySelectorAll(target);\n\n if (selection.length === 0) {\n selection = document.querySelectorAll(`#${target}`);\n }\n\n if (selection.length === 0) {\n throw new Error();\n }\n return selection;\n }\n\n return target;\n } catch {\n console.error(`The target '${target}' could not be identified in the dom, tip: check spelling`);\n return null;\n }\n}\n\nexport function getTarget(target: string | HTMLElement | React.Ref): HTMLElement | React.Ref | null | string {\n const selection = findDOMElements(target);\n if (selection && selection.length > 0) {\n return selection[0];\n }\n\n return target;\n}\n\nexport function getTargetElement(target: string | HTMLElement | React.Ref): HTMLElement | null {\n const targetElement = getTarget(target);\n if (isRef(targetElement)) {\n return (>targetElement).current;\n }\n if (isElement(targetElement)) {\n return targetElement;\n }\n\n return null;\n}\n\nexport const TransitionTimeouts = {\n Fade: 150,\n Collapse: 350,\n Modal: 300,\n Carousel: 600\n};\n\nexport type TransitionStatuses = 'entering' | 'entered' | 'exiting' | 'exited';\n\nexport const focusableElements = [\n 'a[href]',\n 'area[href]',\n 'input:not([disabled]):not([type=hidden])',\n 'select:not([disabled])',\n 'textarea:not([disabled])',\n 'button:not([disabled])',\n 'iframe',\n 'object',\n 'embed',\n '[tabindex]:not(.modal)',\n 'audio[controls]',\n 'video[controls]',\n '[contenteditable]:not([contenteditable=\"false\"])'\n];\n\n/**\n * @name - extend\n * @description - extends an object with properties/values from one or more others.\n * @export\n * @public\n * @param {any[]} parameters - The objects to merge together.\n * @returns {any} - The extended object.\n */\n\nexport function extend(...parameters: any[]): any {\n if (!parameters || parameters.length === 0) {\n return null;\n }\n\n const recursive = (typeof (parameters[0]) === 'boolean') && parameters[0];\n\n if (parameters.length < 2) {\n return recursive ? null : parameters[0];\n }\n\n if (recursive && (parameters.length < 3)) {\n return parameters[1];\n }\n\n const target = recursive ? parameters[1] : parameters[0];\n\n for (let paramIndex = recursive ? 2 : 1; paramIndex < parameters.length; paramIndex++) {\n if (parameters[paramIndex] !== undefined) {\n for (const key of Object.keys(parameters[paramIndex])) {\n if (parameters[paramIndex].hasOwnProperty(key)) {\n const source = parameters[paramIndex][key];\n\n if (recursive) {\n let isSourceArray = Array.isArray ? Array.isArray(source) : ({}).toString.call(source) === '[object Array]';\n let isTargetArray = !!target[key] && (Array.isArray ? Array.isArray(target[key]) : ({}).toString.call(target[key]) === '[object Array]');\n let isSourceObject = !isSourceArray && (typeof source === 'object');\n let isTargetObject = !isTargetArray && !!target[key] && (typeof target[key] === 'object');\n\n if (isSourceArray && isTargetArray) {\n for (const [arrayIndex, element] of source.entries()) {\n isSourceArray = Array.isArray ? Array.isArray(element) : ({}).toString.call(element) === '[object Array]';\n isTargetArray = !!target[key][arrayIndex] && (Array.isArray ? Array.isArray(target[key][arrayIndex]) : ({}).toString.call(target[key][arrayIndex]) === '[object Array]');\n isSourceObject = !isSourceArray && (typeof element === 'object');\n isTargetObject = !isTargetArray && !!target[key][arrayIndex] && (typeof target[key][arrayIndex] === 'object');\n\n if (isSourceArray) {\n target[key][arrayIndex] = extend(true, isTargetArray ? target[key][arrayIndex] : [], element);\n } else if (isSourceObject) {\n target[key][arrayIndex] = extend(true, isTargetObject ? target[key][arrayIndex] : {}, element);\n } else {\n target[key][arrayIndex] = element;\n }\n }\n continue;\n } else if (isSourceArray) {\n target[key] = extend(true, [], source);\n continue;\n } else if (isSourceObject) {\n target[key] = extend(true, isTargetObject ? target[key] : {}, source);\n continue;\n }\n }\n\n target[key] = source;\n }\n }\n }\n }\n\n return target;\n}\n\n/**\n * @name - getDimensions\n * @description - Gets the dimension of an element.\n * @export\n * @param {HTMLElement} containerElement - The container element.\n * @returns {IClientDimension} - The client dimension.\n * {IClientDimension.width} - The client width\n * {IClientDimension.height} - The client height.\n */\nexport function getDimensions(containerElement: HTMLElement): IClientDimension | null {\n if (containerElement === null) {\n return null;\n }\n return {\n width: containerElement.clientWidth,\n height: containerElement.clientHeight\n };\n}\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nimport classNames from 'classnames';\nimport * as React from 'react';\n\nimport { mapToCssModules } from '../common/utilities';\nimport { IPaginationItemProps } from './PaginationItem.props';\n\n/**\n * PaginationItem component.\n */\nexport default class PaginationItem extends React.PureComponent {\n public static defaultProps: Partial = {\n tag: 'li'\n };\n\n public render(): JSX.Element {\n const { active, className, cssModule, disabled, tag: Tag, ...props }: any = this.props;\n\n const paginationItemClasses = mapToCssModules(\n classNames(className, 'msc-page-item', {\n active,\n disabled\n }),\n cssModule\n );\n\n return ;\n }\n}\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nimport { ArrayExtensions, Dictionary, ObjectExtensions } from '@msdyn365-commerce-modules/retail-actions';\nimport * as React from 'react';\n\nimport Button from '../button/Button';\nimport { IFormKeyProps } from './form-builder.props';\n\n/**\n * The state of the form builder.\n */\nexport interface IFormBuilderState {\n\n /**\n * The captured values.\n */\n values: string[];\n\n /**\n * If the form has been submitted.\n */\n isSubmitted: boolean;\n}\n\n/**\n * The properties of the form builder.\n */\nexport interface IFormBuilderProps {\n\n /**\n * The component showing confirmation after form submitted successfully.\n */\n confirmationComponent: React.ReactNode;\n\n /**\n * The heading for the component shown above the input boxes.\n */\n heading: string;\n\n /**\n * The text shown on the submit button.\n */\n submitButtonText: string;\n\n /**\n * The keys of the form values to capture, which will be shown as labels for the inputs.\n */\n keys: IFormKeyProps[];\n\n /**\n * The error message shown when submitting the form and required value is missing.\n */\n requiredValueMissingErrorMessage: string;\n\n /**\n * The action to perform when the form is submitted.\n * @param { formKey: IFormKeyProps, value: string[] } entry - The form data as key-value pairs to submit.\n */\n onSubmit(entry?: { formKey: IFormKeyProps; value: string }[]): Promise;\n}\n\n/**\n * The interface for properties of form builder error.\n */\nexport interface IFormBuilderErrorProps {\n errorMessage?: string;\n}\n\n/**\n * The error component in form builder.\n * @param errorProperties - The error properties.\n * @param errorProperties.errorMessage - The error message to show.\n * @returns The error component.\n */\nexport const FormBuilderErrorComponent: React.FC = ({\n errorMessage\n}) => {\n if (!errorMessage) {\n return null;\n }\n\n return (\n \n \n {errorMessage}\n \n \n );\n};\n\n/**\n * The component to capture form data.\n */\nexport class FormBuilder extends React.Component {\n private readonly requiredValueMissing: Dictionary;\n\n public constructor(props: IFormBuilderProps) {\n super(props);\n this.state = { values: this.props.keys.map(() => ''), isSubmitted: false };\n\n // Setup a boolean dictionary to keep track if required value is missing for every field to submit.\n this.requiredValueMissing = new Dictionary();\n for (const formKey of this.props.keys) {\n if (formKey.resourceId) {\n this.requiredValueMissing.setValue(formKey.resourceId, formKey.isRequired ?? false);\n }\n }\n }\n\n public shouldComponentUpdate(nextProps: IFormBuilderProps, nextState: IFormBuilderState): boolean {\n if (this.props.heading !== nextProps.heading ||\n this.props.confirmationComponent !== nextProps.confirmationComponent ||\n this.props.submitButtonText !== nextProps.submitButtonText ||\n this.props.requiredValueMissingErrorMessage !== nextProps.requiredValueMissingErrorMessage) {\n return true;\n }\n\n // If any form key has changed, the component should update.\n if (!this.props.keys.every((formKey: IFormKeyProps, index: number) => {\n return nextProps.keys[Number(index)].isRequired === formKey.isRequired &&\n nextProps.keys[Number(index)].resourceId === formKey.resourceId &&\n nextProps.keys[Number(index)].resourceValue === formKey.resourceValue;\n })) {\n return true;\n }\n\n // If any value has changed, the component should update.\n if (this.state.isSubmitted !== nextState.isSubmitted ||\n !this.state.values.every((value: string, index: number) => {\n return value === nextState[Number(index)];\n })) {\n return true;\n }\n\n return false;\n }\n\n public render(): JSX.Element {\n return (\n <>\n {\n !this.state.isSubmitted && ArrayExtensions.hasElements(this.props.keys) &&\n
\n

\n {this.props.heading}\n

\n
\n \n {\n this.props.keys.filter((formKey: IFormKeyProps) => {\n return !ObjectExtensions.isNullOrUndefined(formKey.resourceId) &&\n !ObjectExtensions.isNullOrUndefined(formKey.resourceValue);\n }).map((formKey: IFormKeyProps, index: number) => {\n const currentValue: string = this.state.values[Number(index)];\n return (\n
\n \n
\n );\n })\n }\n
\n \n {this.props.submitButtonText}\n \n
\n \n
\n
\n }\n {\n this.state.isSubmitted &&\n this.props.confirmationComponent\n }\n \n );\n }\n\n private get isAnyRequiredValueMissing(): boolean {\n const notFound: number = -1;\n return this.requiredValueMissing.getValues().findIndex((isMissing: boolean) => isMissing) !== notFound;\n }\n\n /**\n * The action to perform when the submit button is clicked.\n * @param event - The click event.\n * @returns The async result.\n */\n private readonly _onSubmit = async (event: React.SyntheticEvent): Promise => {\n event.preventDefault(); // Prevents form submission\n const formData: { formKey: IFormKeyProps; value: string }[] = this.props.keys.map((formKey: IFormKeyProps, index: number) => {\n const currentValue: string = this.state.values[Number(index)];\n return {\n formKey: { resourceId: formKey.resourceId!, resourceValue: formKey.resourceValue },\n value: currentValue\n };\n });\n await this.props.onSubmit(formData);\n this.setState((previousState: Readonly) => {\n return { values: previousState.values, isSubmitted: true };\n });\n };\n\n /**\n * The action to perform when any input in the form has changed.\n * @param event - The input change event.\n * @returns The async result.\n */\n private readonly _onInputChange = async (event: React.ChangeEvent): Promise => {\n event.preventDefault();\n const changedValueIndex: number = Number.parseInt(event.target.getAttribute('data-index') ?? '', 10);\n if (ObjectExtensions.isNullOrUndefined(changedValueIndex)) {\n return Promise.reject(new Error('form-builder: invalid value index.'));\n }\n const newState = {\n values: this.state.values.map((value: string, index: number) => {\n const currentKey: IFormKeyProps = this.props.keys[Number(index)];\n if (index === changedValueIndex && currentKey.resourceId) {\n this.requiredValueMissing.setValue(currentKey.resourceId, (currentKey.isRequired ?? false) && event.target.value === '');\n return event.target.value;\n }\n return value;\n })\n };\n this.setState(newState);\n return Promise.resolve();\n };\n}\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nexport function format(formatSpecifier: string, ...parameters: any[]): string {\n if (!formatSpecifier) {\n return '';\n }\n\n return formatSpecifier.replace(/{(\\d+)}/g, (match: string, index: number) => {\n\n if (index >= parameters.length) {\n return match;\n }\n\n const value = parameters[index];\n\n if (typeof value !== 'number' && !value) {\n return '';\n }\n\n if (typeof value === 'string') {\n return value;\n }\n\n return value.toString();\n });\n}\n\n/**\n * @name - isNullOrWhiteSpace\n * @description - Determines if the specified string is undefined, null, empty, or whitespace.\n * @export\n * @public\n * @param {string} value - The string to examine.\n * @returns {boolean} - True if the value is undefined, null, empty, or whitespace, otherwise false.\n */\nexport function isNullOrWhiteSpace(value: string): boolean {\n return (!value) || (typeof value !== 'string') || (!trim(value));\n}\n\n/**\n * @name - trim\n * @description - Trims leading and trailing whitespace from the string.\n * @export\n * @public\n * @param {string} value - The string to examine.\n * @returns {string} - The trimmed string.\n */\nexport function trim(value: string): string {\n // Any flavor of !value (ie. null/undefined/'') should return itself.\n if (!value || (typeof value !== 'string')) {\n return value;\n }\n\n if (value.trim) {\n return value.trim();\n }\n\n return value.replace(/^\\s+|\\s+$/g, '');\n}\n\n/**\n * @name - startsWith\n * @description - Determines if the specified string starts with the specified value.\n * @param ignoreCase\n * @export\n * @public\n * @param {string} value - The string to look in.\n * @param {string} prefix - The prefix to look for.\n * @returns {boolean} - True if the string starts with the prefix, otherwise false.\n */\nexport function startsWith(value: string, prefix: string, ignoreCase: boolean = true): boolean {\n if (!value || !prefix) {\n return false;\n }\n\n if (ignoreCase) {\n value = value.toLocaleLowerCase();\n prefix = prefix.toLocaleLowerCase();\n }\n\n // @ts-expect-error\n if ((value).startsWith) {\n return (value).startsWith(prefix);\n }\n\n return value.startsWith(prefix);\n}\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nimport classNames from 'classnames';\nimport * as React from 'react';\n\nimport { UncontrolledTooltip } from '..';\nimport { mapToCssModules } from '../common/utilities';\nimport PaginationItem from './PaginationItem';\nimport PaginationLink from './PaginationLink';\nimport { IUncontrolledPaginationProps } from './UncontrolledPagination.props';\n\n/**\n * Uncontrolled Pagination component.\n */\nexport default class UncontrolledPagination extends React.PureComponent {\n public static defaultProps: Partial = {\n tag: 'nav',\n listTag: 'ul',\n 'aria-label': 'pagination',\n items: 0,\n itemsPerPage: 25,\n startingItem: 0\n };\n\n private static readonly pagesDisplayed: number = 7;\n\n private maxPages: number;\n\n private activePage: number = 0;\n\n private qsps: { [param: string]: string };\n\n private url: string;\n\n private hash: string;\n\n constructor(props: IUncontrolledPaginationProps) {\n super(props);\n this.maxPages = this.props.items ? Math.ceil(this.props.items / this.props.itemsPerPage!) : 0;\n this.activePage = Math.floor((this.props.startingItem || 0) / this.props.itemsPerPage!);\n this.qsps = {};\n const splitUrl = this.props.url.split('?');\n\n if (splitUrl[1]) {\n this.url = splitUrl[0];\n const secondSplit = splitUrl[1].split('#');\n this.hash = secondSplit[1] ? `#${secondSplit[1]}` : '';\n const parsedQsps = secondSplit[0].split('&');\n\n for (const qsp of parsedQsps) {\n const qspPair = qsp.split('=');\n\n if (this.props.qsp !== qspPair[0]) {\n this.qsps[qspPair[0]] = qspPair[1];\n }\n }\n } else {\n const secondSplit = splitUrl[0].split('#');\n this.url = secondSplit[0];\n this.hash = secondSplit[1] ? `#${secondSplit[1]}` : '';\n }\n }\n\n public render(): JSX.Element {\n const {\n className,\n baseUrl,\n qsp,\n items,\n itemsPerPage,\n startingItem,\n previousText,\n nextText,\n previousAriaLabel,\n nextAriaLabel,\n listClassName,\n cssModule,\n children,\n size,\n tag: Tag,\n listTag: ListTag,\n 'aria-label': label,\n role,\n ...props\n\n }: any = this.props;\n\n this.maxPages = this.props.items ? Math.ceil(this.props.items / this.props.itemsPerPage!) : 0;\n this.activePage = Math.floor((this.props.startingItem || 0) / this.props.itemsPerPage!);\n this.qsps = {};\n const splitUrl = this.props.url.split('?');\n\n if (splitUrl[1]) {\n this.url = splitUrl[0];\n const secondSplit = splitUrl[1].split('#');\n this.hash = secondSplit[1] ? `#${secondSplit[1]}` : '';\n const parsedQsps = secondSplit[0].split('&');\n\n for (const activeQsp of parsedQsps) {\n const qspPair = activeQsp.split('=');\n\n if (this.props.qsp !== qspPair[0]) {\n this.qsps[qspPair[0]] = qspPair[1];\n }\n }\n } else {\n const secondSplit = splitUrl[0].split('#');\n this.url = secondSplit[0];\n this.hash = secondSplit[1] ? `#${secondSplit[1]}` : '';\n }\n\n const paginationClasses = mapToCssModules(\n classNames(\n className\n ),\n cssModule\n );\n\n const listpaginationClasses = mapToCssModules(\n classNames(\n listClassName,\n 'msc-pagination',\n {\n [`msc-pagination-${size}`]: !!size\n }\n ),\n cssModule\n );\n\n return (\n \n \n {this._generatePageLinks()}\n \n \n );\n }\n\n private _generateUrl(page: number): string {\n const items = this.props.itemsPerPage! * page;\n const keys = Object.keys(this.qsps);\n let qspUrl = page > 0 ? `?${this.props.qsp}=${items}` : '';\n\n keys.forEach((key: string) => {\n qspUrl = qspUrl ? `${qspUrl}&${key}=${this.qsps[key]}` : `?${key}=${this.qsps[key]}`;\n });\n\n return this.url + qspUrl + this.hash;\n }\n\n private _generatePaginationArrow(next: boolean, disable: boolean, className: string): React.ReactElement {\n const url = disable ? undefined : this._generateUrl(this.activePage + (next ? 1 : -1));\n const tooltipId = next ? this.props.nextId : this.props.prevId;\n const ariaDescribedBy = next ? this.props.nextAreaDescribed : this.props.prevAreaDescribed;\n const placement = next ? 'right' : 'left';\n const tag = disable ? 'span' : 'a';\n\n return (\n \n \n {next ? this.props.nextText : this.props.previousText}\n \n {tooltipId && (\n \n {next ? 'next' : 'previous'}\n \n )}\n \n );\n }\n\n private _generatePaginationItem(page: number): React.ReactElement {\n const active = this.activePage === page;\n const url = this._generateUrl(page);\n page += 1;\n\n return (\n \n \n {page}\n \n \n );\n }\n\n private _generateEllipse(): React.ReactElement {\n return (\n \n \n ...\n \n \n );\n }\n\n private _generatePageLinks(): React.ReactFragment {\n const displayCountSide = 3;\n let leftDistance = this.activePage;\n let rightDistance = this.maxPages - this.activePage - 1;\n const leftEllipse = this.maxPages > UncontrolledPagination.pagesDisplayed && leftDistance > 3;\n const rightEllipse = this.maxPages > UncontrolledPagination.pagesDisplayed && rightDistance > 3;\n\n leftDistance = Math.min(leftDistance, displayCountSide);\n rightDistance = Math.min(rightDistance, displayCountSide);\n const pages = [];\n const ellipseOffset = leftEllipse ? -1 : 0;\n const displayedPagesOnLeft = leftDistance + (displayCountSide - rightDistance) + ellipseOffset;\n const startingIndex = Math.max(this.activePage - displayedPagesOnLeft, 0);\n const endIndex = Math.min((startingIndex + 5 + (rightEllipse ? 0 : 1) + (leftEllipse ? 0 : 1)),\n (rightEllipse ? this.maxPages - 1 : this.maxPages));\n\n if (leftEllipse) {\n pages.push(this._generatePaginationItem(0));\n pages.push(this._generateEllipse());\n }\n\n for (let i = startingIndex; i < endIndex; i++) {\n pages.push(this._generatePaginationItem(i));\n }\n\n if (rightEllipse) {\n pages.push(this._generateEllipse());\n pages.push(this._generatePaginationItem(this.maxPages - 1));\n }\n\n return (\n <>\n { this._generatePaginationArrow(false, (this.activePage === 0), 'previous') }\n {pages}\n { this._generatePaginationArrow(true, (this.activePage === this.maxPages - 1), 'next') }\n \n );\n }\n}\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nimport classNames from 'classnames';\nimport * as React from 'react';\n\nimport { mapToCssModules } from '../common/utilities';\nimport { IPaginationProps } from './Pagination.props';\n\n/**\n * Pagination component.\n */\nexport default class Pagination extends React.PureComponent {\n public static defaultProps: Partial = {\n tag: 'nav',\n listTag: 'ul',\n 'aria-label': 'pagination'\n };\n\n public render(): JSX.Element {\n const {\n className,\n listClassName,\n cssModule,\n size,\n tag: Tag,\n listTag: ListTag,\n 'aria-label': label,\n role,\n ...props\n\n }: any = this.props;\n\n const paginationClasses = mapToCssModules(classNames(className), cssModule);\n\n const listpaginationClasses = mapToCssModules(\n classNames(listClassName, 'msc-pagination', {\n [`msc-pagination-${size}`]: !!size\n }),\n cssModule\n );\n\n return (\n \n \n \n );\n }\n}\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nimport classNames from 'classnames';\nimport * as React from 'react';\n\nimport { canUseDOM, getTargetElement, mapToCssModules } from '../common/utilities';\nimport PopperContent from '../popper-content/PopperContent';\nimport { IPopoverProps } from './Popover.props';\n\n/**\n * Popover component.\n */\nexport default class Popover extends React.PureComponent {\n public static defaultProps: Partial = {\n isOpen: false,\n placement: 'right',\n toggle: () => {\n return;\n }\n };\n\n public props: IPopoverProps;\n\n private target: HTMLElement | null;\n\n private popover: HTMLDivElement | null;\n\n private tabPressed: boolean = false;\n\n constructor(props: IPopoverProps) {\n super(props);\n this.props = props;\n\n this.popover = null;\n this._addTargetEvents = this._addTargetEvents.bind(this);\n this._handleDocumentClick = this._handleDocumentClick.bind(this);\n this._removeTargetEvents = this._removeTargetEvents.bind(this);\n this.getRef = this.getRef.bind(this);\n this._toggle = this._toggle.bind(this);\n this._focusOutTarget = this._focusOutTarget.bind(this);\n this._focusOutPopover = this._focusOutPopover.bind(this);\n this._keyDown = this._keyDown.bind(this);\n this._show = this._show.bind(this);\n this._hide = this._hide.bind(this);\n this.target = null;\n }\n\n public componentDidMount(): void {\n this.target = getTargetElement(this.props.target);\n this._handleProps();\n }\n\n public componentDidUpdate(): void {\n this._handleProps();\n }\n\n public componentWillUnmount(): void {\n this._removeTargetEvents();\n }\n\n public getRef(ref: HTMLDivElement | null): void {\n this.popover = ref;\n }\n\n public render(): JSX.Element | null {\n if (!this.props.isOpen) {\n return null;\n }\n\n const {\n cssModule,\n isOpen,\n target,\n placementPrefix,\n hideArrow,\n className,\n innerClassName,\n modifiers,\n placement,\n container,\n offset,\n toggle,\n boundariesElement,\n role,\n ...attributes\n } = this.props;\n\n const classes = mapToCssModules(\n classNames(\n 'msc-popover-inner',\n this.props.innerClassName\n ),\n this.props.cssModule\n );\n\n const popperClasses = mapToCssModules(\n classNames(\n 'msc-popover',\n 'show',\n this.props.className\n ),\n this.props.cssModule\n );\n\n return (\n \n \n \n );\n }\n\n private _handleProps(): void {\n if (this.props.isOpen) {\n this._show();\n } else {\n this._hide();\n }\n }\n\n private _show(): void {\n this.tabPressed = false;\n this._addTargetEvents();\n if (!this.props.isOpen) {\n this._toggle();\n }\n }\n\n private _hide(): void {\n this._removeTargetEvents();\n if (this.props.isOpen) {\n this._toggle();\n }\n }\n\n private _handleDocumentClick(e: Event): void {\n if (!this.target) {\n return;\n }\n\n const target = e.target as HTMLElement;\n\n if (e.target !== this.target &&\n !this.target.contains(target) &&\n e.target !== this.popover &&\n !(this.popover && this.popover.contains(target))\n ) {\n if (this.props.isOpen) {\n this._toggle();\n }\n }\n }\n\n private _addTargetEvents(): void {\n if (!this.target) {\n return;\n }\n if (canUseDOM) {\n ['click', 'touchstart'].forEach((event: string) => {\n document.addEventListener(event, this._handleDocumentClick, true);\n });\n this.target.addEventListener('focusout', this._focusOutTarget, true);\n this.target.addEventListener('keydown', this._keyDown, true);\n }\n }\n\n private _removeTargetEvents(): void {\n if (!this.target) {\n return;\n }\n if (canUseDOM) {\n ['click', 'touchstart'].forEach((event: string) => {\n document.removeEventListener(event, this._handleDocumentClick, true);\n });\n this.target.removeEventListener('focusout', this._focusOutTarget, true);\n this.target.removeEventListener('keydown', this._keyDown, true);\n }\n }\n\n private _focusOutPopover(): void {\n setTimeout(() => {\n const nextFocus = document.activeElement;\n if (this.popover && !this.popover.contains(nextFocus)) {\n this._hide();\n }\n }, 1);\n }\n\n private _focusOutTarget(): void {\n if (this.tabPressed) {\n this.tabPressed = false;\n setTimeout(() => {\n const nextFocus = document.activeElement;\n if (this.popover && !this.popover.contains(nextFocus)) {\n this._hide();\n }\n }, 1);\n }\n }\n\n private _keyDown(e: KeyboardEvent): void {\n if (e.keyCode === 9) {\n this.tabPressed = true;\n } else if (this.props.isOpen && e.keyCode === 27 && this.props.toggle) {\n this.props.toggle();\n }\n }\n\n private _toggle(): void {\n if (this.props.disabled) {\n return;\n }\n\n if (this.props.toggle) {\n this.props.toggle();\n }\n }\n}\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nimport * as React from 'react';\nimport { createPortal } from 'react-dom';\n\nimport { canUseDOM } from '../common/utilities';\nimport { IPortalProps } from './Portal.props';\n\nexport interface IPortalState {\n defaultNode: Element | null;\n}\n\n/**\n * Portal component.\n */\nexport default class Portal extends React.PureComponent {\n constructor(props: IPortalProps) {\n super(props);\n\n this.state = {\n defaultNode: null\n };\n }\n\n public componentWillUnmount(): void {\n if (this.state.defaultNode) {\n this.state.defaultNode.remove();\n }\n }\n\n public render(): React.ReactPortal | null {\n let node = null;\n if (!canUseDOM) {\n return null;\n }\n\n if (!this.props.node && !this.state.defaultNode) {\n node = document.createElement('div');\n document.body.appendChild(node);\n this.setState({ defaultNode: node });\n }\n return createPortal(this.props.children, this.props.node || node);\n }\n}\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nimport classNames from 'classnames';\nimport * as React from 'react';\n\nimport { focusableElements, TransitionTimeouts } from '../common/utilities';\nimport Fade from '../fade/Fade';\nimport IModalProps from './Modal.props';\nimport Portal from './Portal';\n\nexport interface IModalState {\n wasOpen: boolean;\n isOpen: boolean;\n mouseDownElement: EventTarget | null;\n}\n\nexport type ModalVerticalPosition = 'top' | 'center' | 'bottom';\nexport type ModalHorizontalPosition = 'left' | 'center' | 'right';\n\n/**\n * Modal component.\n */\nexport default class Modal extends React.PureComponent {\n public static defaultProps: Partial = {\n isOpen: false,\n autoFocus: true,\n verticalPosition: 'top', // Needs to be non-null since we use non-null assertion in getVerticalPositionClass\n horizontalPosition: 'center', // Needs to be non-null since we use non-null assertion in getHorizontalPositionClass\n role: 'dialog',\n backdrop: true,\n keyboard: true,\n zIndex: 1000,\n tabIndex: 0,\n fade: true,\n modalTransition: {\n timeout: TransitionTimeouts.Modal\n },\n backdropTransition: {\n mountOnEnter: true,\n timeout: TransitionTimeouts.Fade // Uses standard fade transition\n }\n };\n\n private static openCount: number = 0;\n\n private element: HTMLElement | null;\n\n private mounted: boolean;\n\n private readonly ref: React.RefObject;\n\n /**\n * This property is initialized in componentDidMount rather than constructor in case the dialog needs to be pre-rendered.\n */\n private applicationNode!: HTMLElement | null;\n\n constructor(props: IModalProps) {\n super(props);\n this.element = null;\n this.ref = React.createRef();\n this.mounted = false;\n\n this._getFocusableChildren = this._getFocusableChildren.bind(this);\n this._handleBackdropClick = this._handleBackdropClick.bind(this);\n this._handleBackdropMouseDown = this._handleBackdropMouseDown.bind(this);\n this._handleEscape = this._handleEscape.bind(this);\n this._handleTab = this._handleTab.bind(this);\n this._onOpened = this._onOpened.bind(this);\n this._onClosed = this._onClosed.bind(this);\n\n this.state = {\n wasOpen: false,\n isOpen: props.isOpen || false,\n mouseDownElement: null\n };\n\n if (props.isOpen) {\n this._open();\n }\n }\n\n public componentDidMount(): void {\n if (this.props.onEnter) {\n this.props.onEnter();\n }\n this.mounted = true;\n\n const element = document.createElement('div');\n element.setAttribute('tabindex', '-1');\n element.style.visibility = 'hidden';\n element.style.position = 'position';\n this.element = element;\n document.body.appendChild(element);\n\n this.applicationNode = (this.props.applicationNode instanceof HTMLElement) ? this.props.applicationNode : document.querySelector(`#${this.props.applicationNode}`);\n\n if (this.state.isOpen && !this.state.wasOpen) {\n this._open();\n }\n }\n\n public componentWillUnmount(): void {\n if (this.props.onExit) {\n this.props.onExit();\n }\n if (this.state.isOpen) {\n this._close();\n }\n this.mounted = false;\n\n if (this.element) {\n this.element.remove();\n }\n }\n\n public componentDidUpdate(_prevProps: IModalProps, prevState: IModalState): void {\n if ((this.state.isOpen && !prevState.isOpen) || (this.props.shouldUpdateFocusToFirstElement && !_prevProps.shouldUpdateFocusToFirstElement)) {\n setTimeout(() => {\n const focusableElementArr = this._getFocusableChildren();\n if (focusableElementArr && focusableElementArr.length > 0 && focusableElementArr[0]) {\n const firstFocusableElement = focusableElementArr[0] as HTMLElement;\n firstFocusableElement.focus();\n }\n }, 100);\n }\n }\n\n public componentWillReceiveProps(nextProps: IModalProps): void {\n if (nextProps.isOpen && !this.props.isOpen) {\n this.setState({ isOpen: nextProps.isOpen });\n }\n }\n\n public render(): JSX.Element | null {\n if (this.state.isOpen && !this.state.wasOpen) {\n this._open();\n }\n if (this.element !== null) {\n const {\n wrapClassName, modalClassName, backdropClassName, contentClassName, className, cssModule,\n modalTransition, backdropTransition, backdrop, isOpen, onOpened, onClosed,\n role, size, tabIndex, external, verticalPosition, horizontalPosition, keyboard, zIndex, fade, toggle,\n children, applicationNode, returnFocusRef, 'aria-labelledby': ariaLabelledbyId,\n ...dialogAttributes\n } = this.props;\n\n const modalAttributes = {\n onClick: this._handleBackdropClick,\n onMouseDown: this._handleBackdropMouseDown,\n onKeyUp: this._handleEscape,\n onKeyDown: this._handleTab,\n style: { display: 'block' }\n };\n\n const modalTransitions = {\n ...Fade.defaultProps,\n ...modalTransition,\n baseClass: fade && modalTransition ? modalTransition.baseClass : '',\n timeout: fade && modalTransition ? modalTransition.timeout : 0\n };\n const backdropTransitions = {\n ...Fade.defaultProps,\n ...backdropTransition,\n baseClass: fade && backdropTransition ? backdropTransition.baseClass : '',\n timeout: fade && backdropTransition ? backdropTransition.timeout : 0\n };\n\n const Backdrop = fade ? (\n \n ) :
;\n\n const dialogBaseClass = 'msc-modal__dialog';\n const dialogClasses =\n classNames([\n dialogBaseClass,\n className,\n size ? `msc-modal__${size}` : null\n ]);\n\n const dialog = (\n \n \n {children}\n
\n
\n );\n\n return (\n \n
\n \n {external}\n {dialog}\n \n {Backdrop}\n
\n
\n );\n }\n\n return null;\n }\n\n private _open(): void {\n if (this.element) {\n this.element.style.zIndex = `${this.props.zIndex || 1000}`;\n this.element.style.display = 'block';\n this.element.style.visibility = 'visible';\n if (Modal.openCount === 0) {\n if (window) {\n const scrollY = window.scrollY;\n const scrollbarWidth = window.innerWidth - document.body.clientWidth;\n document.body.style.position = 'fixed';\n document.body.style.top = `-${scrollY}px`;\n document.body.style.right = `${scrollbarWidth}px`;\n document.body.style.left = '0px';\n }\n\n document.body.className = classNames(\n document.body.className,\n 'modal-open'\n );\n }\n Modal.openCount += 1;\n document.body.firstElementChild?.setAttribute('aria-hidden', 'true');\n if (this.applicationNode) {\n this.applicationNode.setAttribute('aria-hidden', 'true');\n }\n\n this.setState({ ...this.state, wasOpen: true });\n }\n }\n\n private _close(): void {\n if (!this.state.isOpen) {\n return;\n }\n\n if (this.element) {\n this.element.style.display = 'none';\n setTimeout(() => {\n if (this.element) {\n this.element.style.visibility = 'hidden';\n this.element.style.removeProperty('display');\n }\n }, 0);\n\n }\n\n if (Modal.openCount <= 1) {\n const modalOpenClassName = 'modal-open';\n document.body.firstElementChild?.setAttribute('aria-hidden', 'false');\n\n // Use regex to prevent matching `modal-open` as part of a different class, e.g. `my-modal-opened`\n const modalOpenClassNameRegex = new RegExp(`(^| )${modalOpenClassName}( |$)`);\n document.body.className = document.body.className.replace(modalOpenClassNameRegex, ' ').trim();\n\n if (window) {\n const scrollY = document.body.style.top;\n document.body.style.position = '';\n document.body.style.top = '';\n document.body.style.right = '';\n document.body.style.left = '';\n window.scrollTo(0, -Number.parseInt(scrollY || '0', 10));\n }\n }\n Modal.openCount -= 1;\n\n if (this.applicationNode) {\n this.applicationNode.setAttribute('aria-hidden', 'false');\n }\n\n if (this.props.returnFocusRef && this.props.returnFocusRef.current) {\n this.props.returnFocusRef.current.focus();\n }\n\n this.setState({ ...this.state, wasOpen: false });\n }\n\n private _getFocusableChildren(): NodeListOf | null {\n if (this.element === null) {\n return null;\n }\n\n return this.element.querySelectorAll(focusableElements.join(', '));\n }\n\n private _getFocusedChild(): Element | null {\n const focusableChildren = this._getFocusableChildren();\n\n try {\n return document.activeElement;\n } catch {\n return focusableChildren === null ? null : focusableChildren[0];\n }\n }\n\n private _handleBackdropClick(e: React.MouseEvent): void {\n if (e.target === this.state.mouseDownElement) {\n e.stopPropagation();\n if (!this.props.isOpen || this.props.backdrop !== true) {\n return;\n }\n\n const container = this.ref.current;\n\n if (e.target && container && !container.contains(e.target as Node) && this.props.toggle) {\n this.props.toggle();\n }\n }\n }\n\n private _handleTab(e: React.KeyboardEvent): void {\n if (e.which !== 9) {\n return;\n }\n\n const focusableChildren = this._getFocusableChildren();\n if (focusableChildren === null) {\n return;\n }\n\n const totalFocusable = focusableChildren.length;\n const currentFocus = this._getFocusedChild();\n\n let focusedIndex = 0;\n\n for (let i = 0; i < totalFocusable; i += 1) {\n if (focusableChildren[i] === currentFocus) {\n focusedIndex = i;\n break;\n }\n }\n\n let el: HTMLElement | null = null;\n if (e.shiftKey && focusedIndex === 0) {\n e.preventDefault();\n el = focusableChildren[totalFocusable - 1] as HTMLElement;\n } else if (!e.shiftKey && focusedIndex === totalFocusable - 1) {\n e.preventDefault();\n el = focusableChildren[0] as HTMLElement;\n }\n if (el) {\n el.focus();\n }\n }\n\n private _handleBackdropMouseDown(e: React.MouseEvent): void {\n this.setState({\n mouseDownElement: e.target\n });\n }\n\n private _handleEscape(e: React.KeyboardEvent): void {\n if (this.props.isOpen && this.props.keyboard && e.keyCode === 27 && this.props.toggle) {\n this.props.toggle();\n }\n }\n\n private _onOpened(node: HTMLElement, isAppearing: boolean): void {\n if (this.props.onOpened !== undefined) {\n this.props.onOpened();\n }\n if (this.props.modalTransition !== undefined && this.props.modalTransition.onEntered !== undefined) {\n this.props.modalTransition.onEntered(node, isAppearing);\n }\n }\n\n private _onClosed(node: HTMLElement): void {\n if (this.props.onClosed !== undefined) {\n this.props.onClosed();\n }\n this._close();\n if (this.props.modalTransition !== undefined && this.props.modalTransition.onExited !== undefined) {\n this.props.modalTransition.onExited(node);\n }\n if (this.mounted) {\n this.setState({ isOpen: false });\n }\n }\n}\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nimport classNames from 'classnames';\nimport * as React from 'react';\n\nimport { mapToCssModules } from '../common/utilities';\nimport IModalBodyProps from './ModalBody.props';\n\n/**\n * ModalBody component.\n */\nexport default class ModalBody extends React.PureComponent {\n public static defaultProps: Partial = {\n tag: 'div'\n };\n\n public render(): JSX.Element {\n const { className, cssModule, tag, id, ...attributes } = this.props;\n const Tag = tag || 'div';\n const classes = mapToCssModules(classNames(className, 'msc-modal__body'), cssModule);\n return ;\n }\n}\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nimport classNames from 'classnames';\nimport * as React from 'react';\n\nimport { mapToCssModules } from '../common/utilities';\nimport IModalFooterProps from './ModalFooter.props';\n\n/**\n * ModalFooter component.\n */\nexport default class ModalFooter extends React.PureComponent {\n public static defaultProps: Partial = {\n tag: 'div'\n };\n\n public render(): JSX.Element {\n const { className, cssModule, tag, ...attributes } = this.props;\n const Tag = tag || 'div';\n const classes = mapToCssModules(classNames(className, 'msc-modal__footer'), cssModule);\n return ;\n }\n}\n","/*--------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * See License.txt in the project root for license information.\n *--------------------------------------------------------------*/\n\nimport classNames from 'classnames';\nimport * as React from 'react';\n\nimport { mapToCssModules } from '../common/utilities';\nimport IModalHeaderProps from './ModalHeader.props';\n\n/**\n * ModalHeader component.\n */\nexport default class ModalHeader extends React.PureComponent {\n public render(): JSX.Element {\n let closeButton;\n const {\n className,\n cssModule,\n children,\n toggle,\n tag,\n wrapTag,\n closeAriaLabel,\n closeButtonLabel,\n id,\n ...attributes\n } = this.props;\n\n const Tag = tag || 'h5';\n const WrapTag = wrapTag || 'div';\n const classes = mapToCssModules(classNames(className, 'msc-modal__header'), cssModule);\n\n if (toggle) {\n closeButton = (\n \n );\n }\n\n return (\n \n { children && \n {children}\n }\n {closeButton}\n \n );\n }\n}\n"],"sourceRoot":""}