{"version":3,"file":"main.c842116e7c84e1b2.js","sources":["webpack://storefronts/./rspack/polyfills.js","webpack://storefronts/./src/State.tsx","webpack://storefronts/./src/appsource/components/HiddenComponentWrapper/HiddenComponentWrapper.tsx","webpack://storefronts/./src/appsource/components/RecommendationsRibbonWrapper/RecommendationsRibbonWrapper.tsx","webpack://storefronts/./src/appsource/components/UsefulInfo.tsx","webpack://storefronts/./src/appsource/components/billingFrequencyChoiceGroup/billingFrequencyChoiceGroup.tsx","webpack://storefronts/./src/appsource/components/billingTermChoiceGroup/billingTermChoiceGroup.tsx","webpack://storefronts/./src/appsource/components/saasPricingTable/saasPricingTable.tsx","webpack://storefronts/./src/appsource/components/orderLoading/orderLoading.tsx","webpack://storefronts/./src/appsource/components/redirectModal/redirectModal.tsx","webpack://storefronts/./src/appsource/components/busyLoader/busyLoader.tsx","webpack://storefronts/./src/appsource/components/MSuserErrorBanner/MSuserErrorBanner.tsx","webpack://storefronts/./src/appsource/components/thumbsUpDown/thumbsUpDown.tsx","webpack://storefronts/./src/appsource/containers/LegacyCheckoutHydration.tsx","webpack://storefronts/./src/shared/utils/popupDisplayManager.ts","webpack://storefronts/./src/appsource/containers/appDetails.tsx","webpack://storefronts/./src/shared/components/longContent.tsx","webpack://storefronts/./src/shared/components/reviewQAContent.tsx","webpack://storefronts/./src/shared/components/appReviewItem/appReviewItem.tsx","webpack://storefronts/./src/shared/components/ratingPercentages.tsx","webpack://storefronts/./src/shared/components/ratingSummary.tsx","webpack://storefronts/./src/shared/components/reviewsDropDowns.tsx","webpack://storefronts/./src/shared/components/noReviewsToShow.tsx","webpack://storefronts/./src/shared/components/externalRatingSummary.tsx","webpack://storefronts/./src/shared/components/externalRatingSummaries.tsx","webpack://storefronts/./src/shared/containers/externalRatingSummaries.tsx","webpack://storefronts/./src/appsource/components/userTerms/userTerms.tsx","webpack://storefronts/./src/appsource/components/appReviewCollection.tsx","webpack://storefronts/./src/appsource/containers/appReviewCollection.tsx","webpack://storefronts/./src/shared/components/sortedTable/sortedTableColumn.tsx","webpack://storefronts/./src/shared/components/sortedTable/sortedTable.tsx","webpack://storefronts/./src/shared/components/sortedTable/sortedTH.tsx","webpack://storefronts/./src/shared/components/simplePriceCell.tsx","webpack://storefronts/./src/shared/components/simplePlanPricing.tsx","webpack://storefronts/./src/shared/components/microsoftManagedIndicatorWrapper.tsx","webpack://storefronts/./src/shared/utils/localeUtils.ts","webpack://storefronts/./src/appsource/components/linkedin/linkedinProductGroupBar.tsx","webpack://storefronts/./src/appsource/components/linkedin/linkedinUpcomingEvent.tsx","webpack://storefronts/./src/appsource/components/linkedin/linkedinFeaturedCustomer.tsx","webpack://storefronts/./src/shared/components/featureFeedback.tsx","webpack://storefronts/./src/appsource/components/linkedin/linkedinProductGroup.tsx","webpack://storefronts/./src/appsource/components/Badge.tsx","webpack://storefronts/./src/appsource/components/appDetails.tsx","webpack://storefronts/./src/shared/utils/capabilities.tsx","webpack://storefronts/./src/shared/utils/autoruns.tsx","webpack://storefronts/./src/appsource/components/overview.tsx","webpack://storefronts/./src/appsource/containers/overview.tsx","webpack://storefronts/./src/appsource/containers/serviceDetails.tsx","webpack://storefronts/./src/appsource/components/serviceDetails.tsx","webpack://storefronts/./src/shared/actions/tileDataThunkActions.tsx","webpack://storefronts/./src/shared/msal/loginRedirect.ts","webpack://storefronts/./src/shared/msal/logout.ts","webpack://storefronts/./src/shared/components/FederatedModules/RestClient.tsx","webpack://storefronts/./src/appsource/refreshTokenHandler.tsx","webpack://storefronts/./src/shared/msal/postRedirect.ts","webpack://storefronts/./src/appsource/App.tsx","webpack://storefronts/./src/shared/handlers/recoverableHydrationError.ts","webpack://storefronts/./src/shared/utils/pltUtils.ts","webpack://storefronts/./src/shared/actions/tileDataActions.tsx","webpack://storefronts/./src/shared/actions/queryActions.tsx","webpack://storefronts/./src/shared/components/LoadingSpinner.tsx","webpack://storefronts/./src/shared/hooks/useClientRoutes.tsx","webpack://storefronts/./src/appsource/pathsViewMap.ts","webpack://storefronts/./src/shared/utils/signin.tsx","webpack://storefronts/./src/shared/components/modals/signInModal.tsx","webpack://storefronts/./src/shared/components/modals/mediaModal.tsx","webpack://storefronts/./src/shared/components/modals/videoModal.tsx","webpack://storefronts/./src/shared/components/modals/driveModal.tsx","webpack://storefronts/./src/shared/utils/fieldHubUtils.ts","webpack://storefronts/./src/shared/components/modals/fieldHubModal.tsx","webpack://storefronts/./src/shared/containers/modals/fieldHubModal.tsx","webpack://storefronts/./src/shared/components/modals/errorModal.tsx","webpack://storefronts/./src/shared/containers/modals/errorModal.tsx","webpack://storefronts/./src/shared/components/modals/animationModal.tsx","webpack://storefronts/./src/shared/components/modals/disclaimerModal.tsx","webpack://storefronts/./src/shared/components/modals/npsModal.tsx","webpack://storefronts/./src/shared/components/modals/instructionsModalBody.tsx","webpack://storefronts/./src/shared/components/modals/instructionsModal.tsx","webpack://storefronts/./src/shared/components/modals/downloadSampleModal.tsx","webpack://storefronts/./src/shared/store/createStore.ts","webpack://storefronts/./src/shared/reducers/searchReducer.tsx","webpack://storefronts/./src/shared/reducers/modalReducer.tsx","webpack://storefronts/./src/shared/reducers/commonEntityDataReducer.tsx","webpack://storefronts/./src/embed/reducers/pbiAppDataReducer.tsx","webpack://storefronts/./src/embed/reducers/partnerAppDataReducer.tsx","webpack://storefronts/./src/shared/reducers/appDataReducer.tsx","webpack://storefronts/./src/shared/reducers/userDataReducer.tsx","webpack://storefronts/./src/shared/reducers/checkoutReducer.ts","webpack://storefronts/./src/shared/reducers/partnersReducer.ts","webpack://storefronts/./src/shared/reducers/serviceDataReducer.tsx","webpack://storefronts/./src/shared/reducers/reducers.tsx","webpack://storefronts/./src/shared/reducers/cloudsIndustryDataReducer.tsx","webpack://storefronts/./src/shared/reducers/configReducer.tsx","webpack://storefronts/./src/shared/reducers/dynamicCampaignReducer.tsx","webpack://storefronts/./src/shared/reducers/userFavouriteReducer.tsx","webpack://storefronts/./src/shared/utils/errorHandlerUtil.tsx","webpack://storefronts/./src/embed/actions/embedThunks.tsx","webpack://storefronts/./src/embed/embedMessaging.tsx","webpack://storefronts/./src/appsource/components/modals/userProfileModal/userProfileModal.tsx","webpack://storefronts/./src/appsource/containers/modals/userProfileModal/userProfileModal.tsx","webpack://storefronts/./src/appsource/components/modals/successConsentModal/successConsentModal.tsx","webpack://storefronts/./src/appsource/components/modals/failureConsentModal/failureConsentModal.tsx","webpack://storefronts/./src/appsource/components/modals/consentModal/consentModalContent.tsx","webpack://storefronts/./src/shared/utils/InputValidationUtils.tsx","webpack://storefronts/./src/appsource/components/modals/consentModal/consentModal.tsx","webpack://storefronts/./src/appsource/containers/modals/consentModal/consentModal.tsx","webpack://storefronts/./src/shared/components/modals/reviewActionModal.tsx","webpack://storefronts/./src/shared/components/modals/submitReviewResponseModal.tsx","webpack://storefronts/./src/shared/components/modals/ratingModal.tsx","webpack://storefronts/./src/shared/containers/modals/ratingModal.tsx","webpack://storefronts/./src/shared/components/modals/reportAbuseModal.tsx","webpack://storefronts/./src/shared/containers/modals/reportAbuseModal.tsx","webpack://storefronts/./src/shared/components/modals/reviewCommentModal/reviewCommentModal.tsx","webpack://storefronts/./src/shared/containers/modals/reviewCommentModal.tsx","webpack://storefronts/./src/shared/components/modals/reviewMarkAsHelpfulModal/reviewMarkAsHelpfulModalErrorDialog.tsx","webpack://storefronts/./src/shared/components/modals/reviewMarkAsHelpfulModal/reviewMarkAsHelpfulModal.tsx","webpack://storefronts/./src/shared/components/modals/modal.tsx","webpack://storefronts/./src/shared/handlers/reportAbuseModalHandler.tsx","webpack://storefronts/./src/shared/handlers/consentModalHandler.tsx","webpack://storefronts/./src/shared/handlers/ratingModalHandler.tsx","webpack://storefronts/./src/shared/containers/modals/modal.tsx","webpack://storefronts/./src/shared/components/footer.tsx","webpack://storefronts/./src/shared/containers/footer.tsx","webpack://storefronts/./src/shared/utils/appViewUtils.tsx","webpack://storefronts/./src/appsource/components/modals/npsPreviewModal.tsx","webpack://storefronts/./src/appsource/components/modals/npsSubmittedModal.tsx","webpack://storefronts/./src/appsource/components/modals/npsSurveyModal.tsx","webpack://storefronts/./src/appsource/components/modals/npsModal/npsModal.tsx","webpack://storefronts/./src/appsource/components/nps.tsx","webpack://storefronts/./src/shared/components/cookieBanner.tsx","webpack://storefronts/./src/shared/containers/cookieBanner.tsx","webpack://storefronts/./src/shared/components/loader.tsx","webpack://storefronts/./src/shared/msal/user.ts","webpack://storefronts/./src/shared/components/SilentClientLogin.tsx","webpack://storefronts/./src/shared/components/appView.tsx","webpack://storefronts/./src/shared/utils/cookieBannerUtils.ts","webpack://storefronts/./src/shared/handlers/appViewHandler.tsx","webpack://storefronts/./src/shared/containers/AppView.tsx","webpack://storefronts/./src/shared/actions/queryThunkActions.tsx","webpack://storefronts/./src/appsource/Router.tsx","webpack://storefronts/./src/shared/hooks/useLocationChange.tsx","webpack://storefronts/./src/shared/handlers/rootHandler.tsx","webpack://storefronts/./src/shared/components/scrollToTopButton.tsx","webpack://storefronts/./src/shared/services/http/tokenRestClient.ts","webpack://storefronts/./src/shared/utils/locales.tsx","webpack://storefronts/./src/shared/utils/debug.ts","webpack://storefronts/./src/shared/i18n/client.ts","webpack://storefronts/./src/shared/handlers/onError.ts","webpack://storefronts/./src/shared/handlers/seo.ts","webpack://storefronts/./src/appsource/mainClientHookup.tsx","webpack://storefronts/./src/shared/services/init/initBrowser.ts","webpack://storefronts/./src/appsource/utils/comscore.ts","webpack://storefronts/./src/appsource/utils/consultingServicesUtils.ts","webpack://storefronts/./src/appsource/utils/feedback.ts","webpack://storefronts/./src/appsource/utils/nps/nps.ts","webpack://storefronts/./src/embed/constants.tsx","webpack://storefronts/./src/embed/embedHostUtils.tsx","webpack://storefronts/./src/logger/logger.ts","webpack://storefronts/./src/logger/index.ts","webpack://storefronts/./src/server/LogHelper.tsx","webpack://storefronts/./rspack/paths.ts","webpack://storefronts/./src/server/api/ApiVersion.ts","webpack://storefronts/./src/server/Utils.ts","webpack://storefronts/./src/server/serverLogger/serverLogger.ts","webpack://storefronts/./src/shared/AzureEnvironmentSettings.tsx","webpack://storefronts/./src/shared/Models.tsx","webpack://storefronts/./src/shared/actions/actions.tsx","webpack://storefronts/./src/shared/actions/checkoutActions.ts","webpack://storefronts/./src/shared/actions/partnersActions.ts","webpack://storefronts/./src/shared/actions/privateOffersThunkActions.tsx","webpack://storefronts/./src/interfaces/IBilling.tsx","webpack://storefronts/./src/shared/utils/leadsUtils.tsx","webpack://storefronts/./src/shared/services/http/leadgenRestClient.ts","webpack://storefronts/./src/shared/services/http/reviewRestClient.ts","webpack://storefronts/./src/shared/services/http/fieldHubRestClient.ts","webpack://storefronts/./src/shared/services/http/dynamicCampaignRestClient.ts","webpack://storefronts/./src/shared/services/http/purchaseRestClient.ts","webpack://storefronts/./src/shared/services/http/commerceApiRestClient.ts","webpack://storefronts/./src/shared/services/http/reviewCommentsRestClient.ts","webpack://storefronts/./src/shared/services/http/reviewMarkAsHelpfulRestClient.ts","webpack://storefronts/./src/shared/services/http/reviewsCatalogRestClient.ts","webpack://storefronts/./src/shared/services/http/linkedInRestClient.ts","webpack://storefronts/./src/shared/services/http/reportReviewRestClient.ts","webpack://storefronts/./src/shared/services/http/graphRestClient.ts","webpack://storefronts/./src/shared/services/http/reviewAppReviewsRestClient.ts","webpack://storefronts/./src/shared/services/http/userReviewRestClient.ts","webpack://storefronts/./src/shared/services/http/authRestClient.ts","webpack://storefronts/./src/shared/services/product/product.ts","webpack://storefronts/./src/shared/actions/thunkActions.tsx","webpack://storefronts/./src/shared/services/http/catalogApiRestClient.ts","webpack://storefronts/./src/shared/utils/thunkActionUtils.tsx","webpack://storefronts/./src/shared/services/http/userRestClient.ts","webpack://storefronts/./src/shared/actions/userFavouriteActions.tsx","webpack://storefronts/./src/shared/services/http/userFavouriteRestClient.ts","webpack://storefronts/./src/shared/actions/userFavouriteThunkActions.tsx","webpack://storefronts/./src/shared/utils/userFavouriteThunkActionUtils.tsx","webpack://storefronts/./src/shared/components/ButtonLink.tsx","webpack://storefronts/./src/appsource/components/ShowingResultsFor/ShowingResultsFor.tsx","webpack://storefronts/./src/shared/components/FilteredGalleryHeader/FilteredGalleryHeader.tsx","webpack://storefronts/./src/shared/components/ItemsTooltip.tsx","webpack://storefronts/./src/shared/components/successStory.tsx","webpack://storefronts/./src/shared/components/Testimonials/Testimonials.data.ts","webpack://storefronts/./src/shared/components/Testimonials/Testimonials.tsx","webpack://storefronts/./src/shared/components/animation.tsx","webpack://storefronts/./src/shared/components/appDetailsHeaderRatingBar/appDetailsHeaderRatingBar.tsx","webpack://storefronts/./src/shared/components/appDetailsLinkedItems/appDetailsLinkedItems.tsx","webpack://storefronts/./src/shared/components/appReviewCommentCollection/appReviewItemCommentPagination/appReviewItemCommentPagination.tsx","webpack://storefronts/./src/shared/components/appReviewCommentCollection/appReviewItemCommentEmptyMessage/appReviewItemCommentEmptyMessage.tsx","webpack://storefronts/./src/shared/components/appReviewCommentCollection/appReviewItemCommentCollectionListSection/appReviewItemCommentCollectionListSection.tsx","webpack://storefronts/./src/shared/components/appReviewCommentCollection/appReviewCommentCollection.tsx","webpack://storefronts/./src/shared/components/appReviewCommentCollection/appReviewCommentCollectionPaginationButton/appReviewCommentCollectionPaginationButton.tsx","webpack://storefronts/./src/shared/components/appReviewCommentItem/appReviewCommentItem.tsx","webpack://storefronts/./src/shared/components/appReviewCommentItemToolbar/appReviewCommentItemToolbar.tsx","webpack://storefronts/./src/shared/components/appReviewItemCommentComposer.tsx","webpack://storefronts/./src/shared/components/appReviewItemToolbar/appReviewItemToolbar.tsx","webpack://storefronts/./src/shared/components/reviewIsvReply.tsx","webpack://storefronts/./src/shared/containers/appReviewCommentCollection.tsx","webpack://storefronts/./src/shared/components/appReviewSocialContent/appReviewSocialContent.tsx","webpack://storefronts/./src/shared/components/appTile/appTile.tsx","webpack://storefronts/./src/shared/components/appTileLinkedItems/appTileLinkedItems.tsx","webpack://storefronts/./src/shared/components/baseCtaButton.tsx","webpack://storefronts/./src/shared/components/breadcrumbUrl.tsx","webpack://storefronts/./src/shared/components/card.tsx","webpack://storefronts/./src/shared/components/commonTile.tsx","webpack://storefronts/./src/shared/components/contentStyles.ts","webpack://storefronts/./src/shared/components/ctaButtons/ctaButtons.tsx","webpack://storefronts/./src/shared/components/customMeterPricing/customMeterPricing.tsx","webpack://storefronts/./src/shared/components/externalLink.tsx","webpack://storefronts/./src/shared/utils/externalLinkUtils.tsx","webpack://storefronts/./src/shared/components/futurePriceTooltip.tsx","webpack://storefronts/./src/shared/components/futurePriceWarning.tsx","webpack://storefronts/./src/shared/components/iconLink.tsx","webpack://storefronts/./src/shared/components/badges/freeTrialBadge.tsx","webpack://storefronts/./src/shared/components/badges/privatePlanBadge.tsx","webpack://storefronts/./src/shared/components/saasPricingTableBase/saasPlanNameCell.tsx","webpack://storefronts/./src/shared/components/saasPricingTableBase/saasPricingCell.tsx","webpack://storefronts/./src/shared/components/saasPricingTableBase/saasSubtotalCell/saasSubtotalCell.tsx","webpack://storefronts/./src/shared/components/saasPricingTableBase/saasPricingTableColumns/saasPricingTableColumns.tsx","webpack://storefronts/./src/shared/components/saasPricingTableBase/saasPricingRow/saasPricingRow.tsx","webpack://storefronts/./src/shared/components/saasPricingTableBase/saasPricingTableBase/saasPricingTableBase.tsx","webpack://storefronts/./src/shared/components/internalLink.tsx","webpack://storefronts/./src/shared/components/itemsContainer.tsx","webpack://storefronts/./src/shared/components/linkedItem/linkedItem.tsx","webpack://storefronts/./src/shared/components/modals/submittedModal.tsx","webpack://storefronts/./src/shared/components/msClarity/msClarity.tsx","webpack://storefronts/./src/shared/components/products.tsx","webpack://storefronts/./src/shared/components/pureSpzaComponent.tsx","webpack://storefronts/./src/shared/components/ratings/ratingsInfo.tsx","webpack://storefronts/./src/shared/components/ribbon.tsx","webpack://storefronts/./src/shared/utils/richTextDropDownUtils.tsx","webpack://storefronts/./src/shared/components/richTextDropDown.tsx","webpack://storefronts/./src/shared/components/safeHtmlWrapper/safeHtmlWrapper.tsx","webpack://storefronts/./src/shared/components/sortingDropdown/sortingDropdown.tsx","webpack://storefronts/./src/shared/components/spzaComponent.tsx","webpack://storefronts/./src/shared/components/stickyCard.tsx","webpack://storefronts/./src/shared/components/tabs.tsx","webpack://storefronts/./src/shared/components/telemetryImage.tsx","webpack://storefronts/./src/shared/components/tooltip.tsx","webpack://storefronts/./src/shared/containers/appTile.tsx","webpack://storefronts/./src/shared/components/userFavouriteTileButton.tsx","webpack://storefronts/./src/shared/containers/userFavouriteTileButton.tsx","webpack://storefronts/./src/shared/components/baseTile.tsx","webpack://storefronts/./src/shared/containers/baseTile.tsx","webpack://storefronts/./src/shared/components/dynamicCampaign.tsx","webpack://storefronts/./src/shared/containers/dynamicCampaign.tsx","webpack://storefronts/./src/shared/components/serviceTile.tsx","webpack://storefronts/./src/shared/containers/serviceTile.tsx","webpack://storefronts/./src/shared/components/userFavouriteTileDetailButton.tsx","webpack://storefronts/./src/shared/containers/userFavouriteTileDetailButton.tsx","webpack://storefronts/./src/shared/hooks/useMsClarity.tsx","webpack://storefronts/./src/shared/hooks/useHydration.tsx","webpack://storefronts/./src/shared/hooks/useSpzaInstrumentService.tsx","webpack://storefronts/./src/shared/services/telemetry/1DSClient.tsx","webpack://storefronts/./src/shared/hooks/useTelemetry.tsx","webpack://storefronts/./src/shared/logger/client.ts","webpack://storefronts/./src/shared/logger/base.ts","webpack://storefronts/./src/shared/logger/system.ts","webpack://storefronts/./src/shared/logger/config.ts","webpack://storefronts/./src/shared/msal/client.ts","webpack://storefronts/./src/shared/msal/config.ts","webpack://storefronts/./src/shared/msal/scopes.ts","webpack://storefronts/./src/shared/msal/tokens.ts","webpack://storefronts/./src/shared/msal/windowUtils.ts","webpack://storefronts/./src/shared/oneTaxonomy/utils.ts","webpack://storefronts/./src/shared/utils/xssUtils.ts","webpack://storefronts/./src/shared/routerHistory.tsx","webpack://storefronts/./src/shared/services/feedback/index.ts","webpack://storefronts/./src/shared/services/http/armRestClient.ts","webpack://storefronts/./src/shared/services/http/entityRestClient.ts","webpack://storefronts/./src/shared/services/http/httpProtocol.ts","webpack://storefronts/./src/server/errors/httpError.tsx","webpack://storefronts/./src/shared/services/init/appConfig.ts","webpack://storefronts/./src/shared/services/telemetry/core/action.ts","webpack://storefronts/./src/shared/services/telemetry/core/buffer.ts","webpack://storefronts/./src/shared/services/telemetry/core/consumer.ts","webpack://storefronts/./src/shared/services/telemetry/core/instrument.ts","webpack://storefronts/./src/shared/services/telemetry/core/provider.ts","webpack://storefronts/./src/shared/services/telemetry/providers/staticProvider.ts","webpack://storefronts/./src/shared/services/telemetry/shared/sharedTelemetry.ts","webpack://storefronts/./src/shared/services/telemetry/shared/sharedInstrument.ts","webpack://storefronts/./src/shared/services/telemetry/spza/spzaTelemetry.ts","webpack://storefronts/./src/shared/services/telemetry/spza/spzaInstrument.ts","webpack://storefronts/./src/shared/services/window.tsx","webpack://storefronts/./src/shared/specifics.tsx","webpack://storefronts/./src/shared/utils/accessToken/accessToken.ts","webpack://storefronts/./src/shared/utils/countryCodeMap.ts","webpack://storefronts/./src/shared/utils/optimizeUrlHelper.ts","webpack://storefronts/./src/server/utils/func.ts","webpack://storefronts/./src/shared/services/http/urlUtils.ts","webpack://storefronts/./src/shared/utils/appUtils.tsx","webpack://storefronts/./src/shared/utils/browserStorageUtils.tsx","webpack://storefronts/./src/shared/utils/cookieUtils.tsx","webpack://storefronts/./src/shared/utils/businessConstants.ts","webpack://storefronts/./src/shared/utils/checkoutUtils.tsx","webpack://storefronts/./src/shared/utils/constants.tsx","webpack://storefronts/./src/shared/utils/dataMappingConstants.ts","webpack://storefronts/./src/shared/utils/consultingServicesUtils.ts","webpack://storefronts/./src/shared/utils/dataMapping.tsx","webpack://storefronts/./src/shared/utils/dataMappingUtils.tsx","webpack://storefronts/./src/shared/utils/datamappingHelpers.tsx","webpack://storefronts/./src/shared/utils/detailUtils.tsx","webpack://storefronts/./src/shared/utils/entityRegistration.tsx","webpack://storefronts/./src/shared/utils/errorUtils.ts","webpack://storefronts/./src/shared/utils/filterHelpers.tsx","webpack://storefronts/./src/shared/utils/filterModule.tsx","webpack://storefronts/./src/shared/utils/futurePricesUtils/futurePricesUtils.ts","webpack://storefronts/./src/shared/utils/hashMapUtils.tsx","webpack://storefronts/./src/shared/utils/httpClientUtil.tsx","webpack://storefronts/./src/shared/utils/modals.tsx","webpack://storefronts/./src/shared/utils/npsUtils.tsx","webpack://storefronts/./src/shared/utils/objectUtils.tsx","webpack://storefronts/./src/shared/utils/onetimepaymentoffers/oneTimePaymentOffers.tsx","webpack://storefronts/./src/shared/utils/partnerManifestLoader.ts","webpack://storefronts/./src/shared/utils/pricing/pricing.tsx","webpack://storefronts/./src/shared/utils/privacyUtils.ts","webpack://storefronts/./src/shared/utils/reactUtils.tsx","webpack://storefronts/./src/shared/utils/reviewsUtils.tsx","webpack://storefronts/./src/shared/utils/routeUtils.ts","webpack://storefronts/./src/shared/utils/search.tsx","webpack://storefronts/./src/shared/utils/seoUtils.ts","webpack://storefronts/./src/shared/utils/serviceOffersSupportedStatesCodes.ts","webpack://storefronts/./src/shared/utils/silentLogInUtils.tsx","webpack://storefronts/./src/shared/utils/stringUtils.tsx","webpack://storefronts/./src/shared/utils/telemetryUtils.tsx","webpack://storefronts/./src/shared/utils/urlUtils.tsx","webpack://storefronts/./src/shared/utils/userFavouriteDedicatedUtils.tsx","webpack://storefronts/./src/shared/utils/userFavouriteUtils.tsx","webpack://storefronts/./src/shared/utils/userUtils.tsx"],"sourcesContent":["module.exports = ()=>{};\n","function _define_property(obj, key, value) {\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n return obj;\n}\nimport { UserSegment } from '@shared/Models';\nimport { Constants } from '@shared/utils/constants';\nimport { enrichReviewCommentsApiVersion } from '@shared/specifics';\nconst initialAppReviewsDataState = {\n entityId: '',\n reviews: [],\n isPurchased: false,\n reviewComments: {},\n markedAsHelpful: {\n userReviewIdsMarkedAsHelpful: [],\n userReviewIdsLoading: {}\n }\n};\n// add your feature flags here\n// for now the type should be string\n// we can explore other types in the future\n// DON'T FORGET to initialize it in the constructor\n// ALSO DON'T FORGET to initialize it in the initial state\n// your new feature flag value will be automatically update in\n// state.config.featureFlags.myNewFeatureFlag\nexport class IFeatureFlags {\n constructor(){\n // i.e. myNewFeatureFlag: string;\n _define_property(this, \"AppReviews\", void 0);\n _define_property(this, \"ProfileExp\", void 0);\n _define_property(this, \"AltAuth\", void 0);\n _define_property(this, \"SaasLinkingEnabled\", void 0);\n _define_property(this, \"RedesignEnabled\", void 0);\n _define_property(this, \"ShowPopularity\", void 0);\n _define_property(this, \"UseSecondarySearch\", void 0);\n _define_property(this, \"privateOffers\", void 0);\n _define_property(this, \"purchaseBlends\", void 0);\n _define_property(this, \"newCustomerFlow\", void 0);\n _define_property(this, \"PartnersEnabled\", void 0);\n _define_property(this, \"forceCompletePurchase\", void 0);\n _define_property(this, \"allowAdminUser\", void 0);\n _define_property(this, \"showConsent\", void 0);\n _define_property(this, \"ensureprewarm\", void 0);\n _define_property(this, \"useSearchV2\", void 0);\n _define_property(this, \"ReviewsMyCommentsFilter\", void 0);\n _define_property(this, \"sortByRecentlyUpdatedEnabled\", void 0);\n _define_property(this, \"sortByRatingEnabled\", void 0);\n _define_property(this, \"allNewSortsEnabled\", void 0);\n _define_property(this, \"I18nextEnabled\", void 0);\n _define_property(this, \"cloudMarketplaceModeOn\", void 0);\n _define_property(this, \"recommendations\", void 0);\n _define_property(this, \"openInNewWindowButton\", void 0);\n _define_property(this, \"logToConsole\", void 0);\n _define_property(this, \"expredirect\", void 0);\n _define_property(this, \"partnersTestMode\", void 0);\n _define_property(this, \"cloudMarketplaceModeFF\", [\n 'newHeader'\n ]);\n _define_property(this, \"activeCloudMarketplaceFeatures\", ()=>{\n if (this.cloudMarketplaceModeOn) {\n this.cloudMarketplaceModeFF.forEach((ff)=>{\n this[`${ff}`] = true;\n });\n }\n });\n // i.e. this.myNewFeatureFlag = 'false';\n this.AppReviews = 'false';\n this.ProfileExp = 'false';\n this.AltAuth = 'false';\n this.SaasLinkingEnabled = 'false';\n this.RedesignEnabled = 'false';\n this.ShowPopularity = 'false';\n this.UseSecondarySearch = 'false';\n this.privateOffers = 'false';\n this.purchaseBlends = 'false';\n this.newCustomerFlow = 'false';\n this.PartnersEnabled = 'false';\n this.forceCompletePurchase = 'false';\n this.allowAdminUser = 'false';\n this.showConsent = 'false';\n this.ensureprewarm = 'false';\n this.useSearchV2 = 'false';\n this.ReviewsMyCommentsFilter = 'true';\n this.sortByRecentlyUpdatedEnabled = 'false';\n this.sortByRatingEnabled = 'false';\n this.allNewSortsEnabled = 'false';\n this.I18nextEnabled = 'false';\n this.cloudMarketplaceModeOn = false;\n this.recommendations = true;\n this.openInNewWindowButton = false;\n this.logToConsole = false;\n this.expredirect = false;\n this.partnersTestMode = false;\n }\n}\nconst initialRecommendedSizesState = {\n loading: false,\n entityId: '',\n planId: '',\n recommendedSizes: []\n};\nexport const initialUserFavouriteState = {\n fetchDataStatus: Constants.UserFavourite.FetchDataStatus.Invalid,\n apps: [],\n services: []\n};\nexport const initialDynamicCampaignState = {\n html: ''\n};\nexport const initialSearchState = {\n searchText: '',\n searchSortingOption: Constants.SearchSortingOption.BestMatch,\n appSearchResults: [],\n servicesSearchResults: [],\n filteredAppSearchResults: [],\n filteredServicesSearchResults: [],\n filteredCloudsIndustrySearchResults: [],\n appsCount: 0,\n servicesCount: 0,\n cloudsIndustryCount: 0,\n searchIdCurrentlyOngoing: 0,\n partnerSearchResults: [],\n requestId: Constants.ReservedCorrelationIds.EmptyId\n};\nexport const initialModalState = {\n appId: '',\n parnerId: '',\n modalId: 0,\n isSignedIn: false,\n showModal: false,\n payload: null,\n entityType: Constants.EntityType.App,\n isOpenedFromPDP: false\n};\nexport const initialEntityDataState = {\n idMap: {},\n dataList: [],\n dataMap: {},\n dataMapLoaded: false,\n entityIdFailed: '',\n entityIdLoading: '',\n activeFilters: [],\n count: 0,\n curatedData: {},\n dataLoaded: {},\n curatedDataLoaded: {},\n subsetData: [],\n subsetSearchQuery: '',\n tileDataRequestId: '',\n relatedAppsItems: {\n entityId: '',\n items: {\n suggestedItems: [],\n saasLinkingItems: [],\n linkedAddIns: []\n }\n },\n appReviewsData: initialAppReviewsDataState,\n linkedInProductGroup: null\n};\nexport const initialAppDataState = {\n idMap: {},\n dataList: [],\n recommendedApps: {\n whatsNewApps: [],\n trendingApps: [],\n microsoft365WhatsNewApps: [],\n microsoft365TrendingApps: []\n },\n dataMap: {},\n dataMapLoaded: false,\n entityIdFailed: '',\n entityIdLoading: '',\n activeFilters: [],\n count: 0,\n curatedData: {},\n dataLoaded: {},\n pricingPayload: null,\n partnerAppDataLoaded: false,\n curatedDataLoaded: {},\n subsetData: [],\n subsetSearchQuery: '',\n tileDataRequestId: '',\n relatedAppsItems: {\n entityId: '',\n items: {\n suggestedItems: [],\n saasLinkingItems: [],\n linkedAddIns: []\n }\n },\n appReviewsData: initialAppReviewsDataState,\n recommendedSizesState: initialRecommendedSizesState,\n linkedInProductGroup: null\n};\nexport const initialCloudsIndustryDataState = {\n idMap: {},\n dataList: [],\n dataMap: {},\n dataMapLoaded: false,\n entityIdFailed: '',\n entityIdLoading: '',\n activeFilters: [],\n count: 0,\n curatedData: {},\n dataLoaded: {},\n pricingPayload: null,\n curatedDataLoaded: {},\n subsetData: [],\n subsetSearchQuery: '',\n tileDataRequestId: '',\n relatedAppsItems: {\n entityId: '',\n items: {\n suggestedItems: [],\n saasLinkingItems: [],\n linkedAddIns: []\n }\n },\n appReviewsData: initialAppReviewsDataState,\n linkedInProductGroup: null\n};\nexport const initialUserDataState = {\n assignmentContext: '',\n id: '',\n group: [\n ''\n ],\n signedIn: false,\n idToken: '',\n idTokenPayload: '',\n accessToken: {},\n refreshToken: '',\n firstName: '',\n lastName: '',\n uniqueName: '',\n displayName: '',\n oid: '',\n tid: '',\n puid: '',\n email: '',\n graphApi: process.env.graphApi,\n alternateEmail: '',\n isMSAUser: false,\n userSegment: UserSegment.unauthenticated,\n hasReview: false,\n fieldHubUserType: Constants.FieldHubUserType.None,\n isLoadingUserProfile: false,\n loading: true,\n givenName: '',\n familyName: '',\n profile: {\n firstName: '',\n lastName: '',\n email: '',\n phone: '',\n country: '',\n company: '',\n title: '',\n updateRequired: null,\n isLatestProfile: false,\n uiRole: null,\n managedLicenses: []\n },\n tenantsDetails: {\n details: {\n countryCode: null,\n defaultDomain: null,\n displayName: null,\n domains: null,\n id: null,\n tenantCategory: null,\n tenantId: null,\n tenantType: null,\n azureSubscriptions: {}\n },\n status: {\n hasError: false,\n isLoading: false\n }\n },\n purchases: {},\n privateOffers: {\n dataList: [],\n loading: true\n },\n roleDefinitions: [],\n accounts: {\n isEAAccount: false,\n isLoading: false,\n accounts: null,\n hasError: false\n },\n isMaccTenant: false\n};\nexport const initialExperimentState = {\n abTestingVersion_AMP: Constants.VaritionKey.Default,\n abTestingVersion_newFilterAMP: Constants.VaritionKey.Default\n};\nexport const initialConfigState = {\n initLoading: true,\n isEmbedded: false,\n experiment: initialExperimentState,\n embedHost: null,\n locStrings: '',\n locale: 'en-us',\n user: '',\n flightCodes: null,\n partnersIframeUrl: '',\n partnersApiHost: '',\n partnersIframeUrlTest: '',\n correlationId: '',\n currentView: 'home',\n landingView: '',\n currentGalleryViewIsCurated: false,\n breadcrumbUrl: null,\n appViewTelemetryLoggedCount: 0,\n nationalCloud: '',\n billingCountryCode: 'us',\n pricingDataLoaded: false,\n featureFlags: new IFeatureFlags(),\n marketplaceApiHost: '',\n saasRPHost: '',\n MPRPHost: '',\n armApiHost: '',\n isMobile: false,\n isAppSource: process.env ? process.env.applicationTarget === Constants.appSourceApplicationTargetName : false,\n pidlEnv: '',\n query: {},\n requestFilteredLoading: false,\n requestFilteredEntityType: Constants.TileDataEntityType.All,\n requestFilteredQuery: {},\n responseFilteredQuery: {},\n cookiesConsent: {\n isManageModalOpen: false,\n WCPConsent: {\n Advertising: false,\n Analytics: false,\n Required: true,\n SocialMedia: false\n },\n isConsentRequired: false\n },\n siteEnvironment: '',\n newNpsEnabled: false,\n pcaInstanceInitialized: false,\n npsLogicVerified: false,\n reviewsAPIVersion: enrichReviewCommentsApiVersion,\n showContextPanel: false,\n commerceApiHost: '',\n storefrontName: null,\n marketplaceLeadsHost: '',\n marketplaceLeadsAudienceId: '',\n agreementAppId: ''\n};\nexport const initialServiceDataState = {\n idMap: {},\n dataList: [],\n recommendedServices: {\n whatsNewService: [],\n trendingService: []\n },\n countriesList: {},\n dataMap: {},\n dataMapLoaded: false,\n entityIdFailed: '',\n entityIdLoading: '',\n activeFilters: [],\n count: 0,\n curatedData: {},\n dataLoaded: {},\n curatedDataLoaded: {},\n subsetData: [],\n subsetSearchQuery: '',\n tileDataRequestId: '',\n entityType: Constants.EntityType.Service,\n selectedCountry: Constants.usCountryCode.toUpperCase(),\n selectedRegion: Constants.allStatesCode.toUpperCase(),\n relatedAppsItems: {\n entityId: '',\n items: {\n suggestedItems: [],\n saasLinkingItems: [],\n linkedAddIns: []\n }\n },\n appReviewsData: initialAppReviewsDataState,\n linkedInProductGroup: null\n};\nexport const initialCheckoutState = {\n items: [],\n customers: null,\n activeCustomer: null,\n publisherToken: null,\n error: false,\n currentStep: 0,\n purchaseAttempt: 0,\n billingAddress: null,\n checkoutId: ''\n};\nexport const initialPartnersState = {\n filterLocation: null,\n contactDetails: null\n};\nexport const initialState = {\n search: initialSearchState,\n modal: initialModalState,\n apps: initialAppDataState,\n cloudsIndustry: initialCloudsIndustryDataState,\n users: initialUserDataState,\n config: initialConfigState,\n services: initialServiceDataState,\n dynamicCampaign: initialDynamicCampaignState,\n userFavourite: initialUserFavouriteState,\n checkout: initialCheckoutState,\n partners: initialPartnersState\n};\n// This function does a deep copy a 'DataMap' object\n// It is sometimes used (in the server code) after calling 'performFilter' to\n// ignore objects that have a 'count' property set to '0'. This removes 'filters'\n// from the filter pane that aren't applicable to a specific group of data\nexport function deepCopyDataMap(DataMap) {\n const newDataMap = {};\n if (DataMap == null || typeof DataMap !== 'object') {\n return DataMap;\n } else if (DataMap.count === 0) {\n return null;\n }\n for(const k in DataMap){\n const prop = DataMap[`${k}`];\n const copy = deepCopyDataMap(prop);\n if (copy) {\n newDataMap[`${k}`] = copy;\n }\n }\n return newDataMap;\n}\nexport function copyState(oldState) {\n const newState = {};\n for(const k in oldState){\n newState[`${k}`] = oldState[`${k}`];\n }\n return newState;\n}\n","import { jsx as _jsx } from \"react/jsx-runtime\";\nimport React from 'react';\nimport { mergeStyleSets } from '@fluentui/react';\nimport classNames from 'classnames';\nconst contentStyles = mergeStyleSets({\n hiddenClass: {\n display: 'none'\n }\n});\nexport const HiddenComponentWrapper = ({ className, hide, children })=>{\n const containerClass = classNames({\n [className]: (className === null || className === void 0 ? void 0 : className.length) > 0,\n [contentStyles.hiddenClass]: hide\n });\n return /*#__PURE__*/ _jsx(\"div\", {\n className: containerClass,\n children: children\n });\n};\n","function _define_property(obj, key, value) {\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n return obj;\n}\nfunction _object_spread(target) {\n for(var i = 1; i < arguments.length; i++){\n var source = arguments[i] != null ? arguments[i] : {};\n var ownKeys = Object.keys(source);\n if (typeof Object.getOwnPropertySymbols === \"function\") {\n ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {\n return Object.getOwnPropertyDescriptor(source, sym).enumerable;\n }));\n }\n ownKeys.forEach(function(key) {\n _define_property(target, key, source[key]);\n });\n }\n return target;\n}\nfunction ownKeys(object, enumerableOnly) {\n var keys = Object.keys(object);\n if (Object.getOwnPropertySymbols) {\n var symbols = Object.getOwnPropertySymbols(object);\n if (enumerableOnly) {\n symbols = symbols.filter(function(sym) {\n return Object.getOwnPropertyDescriptor(object, sym).enumerable;\n });\n }\n keys.push.apply(keys, symbols);\n }\n return keys;\n}\nfunction _object_spread_props(target, source) {\n source = source != null ? source : {};\n if (Object.getOwnPropertyDescriptors) {\n Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));\n } else {\n ownKeys(Object(source)).forEach(function(key) {\n Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));\n });\n }\n return target;\n}\nimport { jsx as _jsx, Fragment as _Fragment } from \"react/jsx-runtime\";\nimport { createElement as _createElement } from \"react\";\nimport React from 'react';\nimport Ribbon from '@shared/components/ribbon';\nimport NewBadge from '@shared/images/NewBadge.svg';\nconst maxRibbonItems = 5;\nexport const RecommendationsRibbon = ({ recommendedItems = [], title, ribbonKey, selectedCountry, selectedLocale, tileType: TileType })=>{\n return /*#__PURE__*/ _jsx(_Fragment, {\n children: recommendedItems.length >= maxRibbonItems && /*#__PURE__*/ _jsx(Ribbon, {\n title: title,\n imgSource: NewBadge,\n children: recommendedItems.map((item, index)=>{\n return /*#__PURE__*/ _createElement(TileType, _object_spread_props(_object_spread({}, item), {\n item: item,\n key: item.entityId,\n customCSSClass: 'tile' + index,\n tileIndex: index,\n totalTiles: recommendedItems.length,\n selectedLocale: selectedLocale,\n countryContext: selectedCountry,\n ribbonKey: `Recommended_${ribbonKey}`\n }));\n })\n })\n });\n};\n","function _define_property(obj, key, value) {\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n return obj;\n}\nfunction _object_spread(target) {\n for(var i = 1; i < arguments.length; i++){\n var source = arguments[i] != null ? arguments[i] : {};\n var ownKeys = Object.keys(source);\n if (typeof Object.getOwnPropertySymbols === \"function\") {\n ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {\n return Object.getOwnPropertyDescriptor(source, sym).enumerable;\n }));\n }\n ownKeys.forEach(function(key) {\n _define_property(target, key, source[key]);\n });\n }\n return target;\n}\nfunction ownKeys(object, enumerableOnly) {\n var keys = Object.keys(object);\n if (Object.getOwnPropertySymbols) {\n var symbols = Object.getOwnPropertySymbols(object);\n if (enumerableOnly) {\n symbols = symbols.filter(function(sym) {\n return Object.getOwnPropertyDescriptor(object, sym).enumerable;\n });\n }\n keys.push.apply(keys, symbols);\n }\n return keys;\n}\nfunction _object_spread_props(target, source) {\n source = source != null ? source : {};\n if (Object.getOwnPropertyDescriptors) {\n Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));\n } else {\n ownKeys(Object(source)).forEach(function(key) {\n Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));\n });\n }\n return target;\n}\nimport { jsx as _jsx, jsxs as _jsxs } from \"react/jsx-runtime\";\nimport * as React from 'react';\nimport * as PropTypes from 'prop-types';\nimport SpzaComponent from '../../shared/components/spzaComponent';\nimport { Constants } from '../../shared/utils/constants';\nimport { InternalLink } from '../../shared/components/internalLink';\nimport * as DetailUtils from '../../shared/utils/detailUtils';\nimport { urlPush } from '../../shared/routerHistory';\nexport var UsefulInfoMetadataCellItemType = /*#__PURE__*/ function(UsefulInfoMetadataCellItemType) {\n UsefulInfoMetadataCellItemType[UsefulInfoMetadataCellItemType[\"Filter\"] = 0] = \"Filter\";\n UsefulInfoMetadataCellItemType[UsefulInfoMetadataCellItemType[\"Label\"] = 1] = \"Label\";\n UsefulInfoMetadataCellItemType[UsefulInfoMetadataCellItemType[\"Link\"] = 2] = \"Link\";\n UsefulInfoMetadataCellItemType[UsefulInfoMetadataCellItemType[\"Modal\"] = 3] = \"Modal\";\n UsefulInfoMetadataCellItemType[UsefulInfoMetadataCellItemType[\"InternalLink\"] = 4] = \"InternalLink\";\n return UsefulInfoMetadataCellItemType;\n}({});\nconst isUsefulInfoMetadataCellItemFilter = (object)=>{\n return object.type === 0;\n};\nconst isUsefulInfoMetadataCellItemInternalLink = (object)=>{\n return object.type === 4;\n};\nconst isUsefulInfoMetadataCellItemLink = (object)=>{\n return object.type === 2;\n};\nconst isUsefulInfoMetadataCellItemModal = (object)=>{\n return object.type === 3;\n};\nexport class UsefulInfo extends SpzaComponent {\n getLinkElement(item) {\n if (item.information) {\n return /*#__PURE__*/ _jsx(\"a\", _object_spread_props(_object_spread({\n className: \"c-hyperlink\",\n rel: \"noreferrer\",\n target: \"_blank\",\n href: item.information,\n title: this.context.loc(item.text),\n onClick: ()=>{\n DetailUtils.generateLinkPayloadAndLogTelemetry(this.props.ownerType, item.entityId, item.id, item.information, 'Default');\n }\n }, item.props), {\n children: this.context.loc(item.text)\n }));\n } else {\n return null;\n }\n }\n getInternalLinkElement(item) {\n return /*#__PURE__*/ _jsx(InternalLink, _object_spread_props(_object_spread({\n className: \"c-hyperlink\",\n href: item.information,\n onClick: item.onClick\n }, item.props), {\n children: this.context.loc(item.text)\n }));\n }\n getFilterElement(item) {\n const filter = item.filter;\n if (item.nationalCloud) {\n return /*#__PURE__*/ _jsx(\"div\", {\n children: this.context.loc(filter.locKey, filter.title)\n }, filter.title);\n } else {\n return /*#__PURE__*/ _jsxs(InternalLink, _object_spread_props(_object_spread({\n className: \"c-hyperlink detailsCategories\",\n href: filter.newPath,\n title: this.context.loc(filter.locKey, filter.title),\n onClick: (e)=>{\n DetailUtils.generateLinkPayloadAndLogTelemetry(DetailUtils.OwnerType.App, item.entityId, filter.filterItem, filter.newPath, 'Default');\n // The embedded app needs to open these links in a new window\n if (item.isEmbedded) {\n // eslint-disable-next-line security/detect-non-literal-fs-filename\n window.open(window.location.origin + filter.newPath, '_blank');\n } else {\n urlPush(filter.newPath);\n window.scrollTo(0, 0);\n }\n // The preventDefault prevents the route from transitioning and thus refreshing the page.\n e.preventDefault();\n },\n accEnabled: true\n }, item.props), {\n children: [\n /*#__PURE__*/ _jsx(\"span\", {\n children: this.context.loc(filter.locKey, filter.title)\n }),\n filter.filterItem === Constants.filterMaps.categories ? /*#__PURE__*/ _jsx(\"meta\", {\n itemProp: \"applicationCategory\",\n content: this.context.loc(filter.locKey, filter.title)\n }) : null\n ]\n }), filter.title);\n }\n }\n renderImpl() {\n return /*#__PURE__*/ _jsx(\"div\", {\n className: \"usefulInfo \",\n children: this.props.metadata.map((col)=>{\n return /*#__PURE__*/ _jsxs(\"div\", {\n className: \"usefulInfoColumn\",\n children: [\n /*#__PURE__*/ _jsx(\"h3\", {\n className: \"columnTitle\",\n children: this.context.loc(col.title, col.titleFallback || col.title)\n }),\n /*#__PURE__*/ _jsx(\"div\", {\n className: \"columnCells\",\n children: col.cells.map((cell)=>{\n return /*#__PURE__*/ _jsxs(\"div\", {\n className: \"cell\",\n itemProp: cell.id,\n children: [\n cell.title && /*#__PURE__*/ _jsx(\"header\", {\n \"aria-label\": cell.title,\n children: this.context.loc(cell.title, cell.titleFallback || cell.title)\n }),\n cell.cellItems.map((item)=>{\n if (isUsefulInfoMetadataCellItemFilter(item)) {\n return this.getFilterElement(item);\n } else if (isUsefulInfoMetadataCellItemLink(item)) {\n return this.getLinkElement(item);\n } else if (isUsefulInfoMetadataCellItemModal(item)) {\n return item.getContent();\n } else if (isUsefulInfoMetadataCellItemInternalLink(item)) {\n return this.getInternalLinkElement(item);\n } else {\n return /*#__PURE__*/ _jsx(\"span\", _object_spread_props(_object_spread({\n className: \"cellLabel\"\n }, item.props), {\n children: this.context.loc(item.text)\n }), item.text);\n }\n })\n ]\n }, cell.id);\n }).filter(Boolean)\n })\n ]\n }, col.id);\n })\n });\n }\n constructor(...args){\n super(...args), _define_property(this, \"context\", void 0);\n }\n}\nUsefulInfo.contextTypes = {\n loc: PropTypes.func,\n locParams: PropTypes.func,\n renderErrorModal: PropTypes.func\n};\n","import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from \"react/jsx-runtime\";\nimport React, { useCallback } from 'react';\nimport * as PropTypes from 'prop-types';\nimport { Text, Icon, Label, Stack, ChoiceGroup } from '@fluentui/react';\nimport { Constants } from '@shared/utils/constants';\nimport { IAvailabilityActions } from '@shared/Models';\nimport { convertTermToString } from '@shared/utils/checkoutUtils';\nimport Tooltip from '@shared/components/tooltip';\nimport { addFuturePricing } from '@shared/utils/pricing';\nconst pbTelemetry = Constants.Telemetry.PurchaseBlendsTelemetry;\nexport const GenerateLabelAndTooltip = ({ context })=>{\n return /*#__PURE__*/ _jsx(Label, {\n className: \"mt-20\",\n children: /*#__PURE__*/ _jsx(Stack, {\n horizontal: true,\n verticalAlign: \"center\",\n wrap: false,\n children: /*#__PURE__*/ _jsxs(Text, {\n className: \"ms-fontWeight-semibold \",\n children: [\n `${context.loc('Checkout_PriceAndPaymentOptions', 'Price/payment options')} `,\n /*#__PURE__*/ _jsx(Tooltip, {\n tooltipHostProps: {\n content: context.loc('Checkout_PriceAndBilling_Tooltip_PaymentOptions', \"The plan's price and payment frequency\"),\n calloutProps: {\n gapSpace: 0\n }\n },\n children: /*#__PURE__*/ _jsx(Icon, {\n iconName: \"Info\",\n ariaLabel: context.loc('Checkout_PriceAndBilling_Tooltip_PaymentOptions', \"The plan's price and payment frequency\")\n })\n }),\n /*#__PURE__*/ _jsx(Text, {\n className: \"requiredColor\",\n children: ` *`\n })\n ]\n })\n })\n });\n};\nexport const getBillingFrequencyOptions = ({ billingCountryCode, items, futurePriceMonthly, futurePriceYearly, locale }, context)=>{\n const { product, id, termDuration, hasFreeTrial } = items[0];\n const plan = product.getPlanByPlanId(id);\n const availability = plan.availabilities.find((availability)=>{\n const { actions } = availability;\n return actions.includes(IAvailabilityActions.Renew) && actions.includes(IAvailabilityActions.Browse);\n });\n const termsByBillingTermDuration = availability.terms.filter((term)=>term.termUnits === termDuration);\n const billingFrequencyOptions = termsByBillingTermDuration.map((term)=>{\n const termEntity = product.getTermByTermId({\n planId: id,\n termId: term.termId\n });\n if (!termEntity) {\n return null;\n }\n return {\n // If there's no free trial termId, assign the renew termId\n key: termEntity.freeTrialTermId || termEntity.renewTermId,\n // This value isn't displayed, but rather used to pass in the relevant contract term in the case there's only one option\n value: termEntity.renewTermUnits,\n text: convertTermToString({\n context,\n term: termEntity,\n countryCode: billingCountryCode,\n isQuantifiable: items[0].isQuantifiable,\n hasFreeTrial,\n locale\n }),\n onRenderLabel: (option, defaultRender)=>/*#__PURE__*/ _jsxs(_Fragment, {\n children: [\n defaultRender(option),\n addFuturePricing(term.renewTermUnits, futurePriceMonthly, futurePriceYearly)\n ]\n })\n };\n }).filter(Boolean);\n return billingFrequencyOptions;\n};\nexport const getDefaultOrSelectedBillingFrequency = ({ items }, options)=>{\n var _items_, _items_1;\n const availableTermFrequencies = options === null || options === void 0 ? void 0 : options.map((option)=>option.key);\n const defaultBillingFrequency = (availableTermFrequencies === null || availableTermFrequencies === void 0 ? void 0 : availableTermFrequencies.includes((_items_ = items[0]) === null || _items_ === void 0 ? void 0 : _items_.termId)) ? (_items_1 = items[0]) === null || _items_1 === void 0 ? void 0 : _items_1.termId : availableTermFrequencies[0];\n return defaultBillingFrequency || '';\n};\nexport const BillingFrequencyChoiceGroup = (props, context)=>{\n const { setSelectedTerm, futurePriceMonthly, futurePriceYearly, billingCountryCode, items, locale } = props;\n const { termId, id } = items[0];\n const options = useCallback(()=>getBillingFrequencyOptions({\n billingCountryCode,\n items,\n futurePriceMonthly,\n futurePriceYearly,\n locale\n }, context), [\n billingCountryCode,\n items,\n futurePriceMonthly,\n futurePriceYearly,\n context,\n locale\n ]);\n const { text, value } = options()[0];\n return /*#__PURE__*/ _jsxs(_Fragment, {\n children: [\n /*#__PURE__*/ _jsx(GenerateLabelAndTooltip, {\n context: context\n }),\n /*#__PURE__*/ _jsx(Stack, {\n horizontal: true,\n tokens: {\n childrenGap: 10\n },\n children: /*#__PURE__*/ _jsx(Stack.Item, {\n children: options().length > 1 ? /*#__PURE__*/ _jsx(ChoiceGroup, {\n \"data-bi-id\": pbTelemetry.PickBillingFrequency,\n \"data-bi-name\": pbTelemetry.BillingFrequencyComponent,\n options: options(),\n onChange: (_, option)=>setSelectedTerm({\n id,\n termId: option.key\n }),\n selectedKey: termId,\n defaultSelectedKey: getDefaultOrSelectedBillingFrequency(props, options()),\n ariaLabelledBy: 'billTermSelection'\n }) : /*#__PURE__*/ _jsxs(_Fragment, {\n children: [\n /*#__PURE__*/ _jsx(Text, {\n children: text\n }),\n addFuturePricing(value, futurePriceMonthly, futurePriceYearly)\n ]\n })\n })\n })\n ]\n });\n};\nBillingFrequencyChoiceGroup.contextTypes = {\n locParams: PropTypes.func,\n loc: PropTypes.func\n};\n","import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from \"react/jsx-runtime\";\nimport React, { useMemo } from 'react';\nimport * as PropTypes from 'prop-types';\nimport { Constants } from '@shared/utils/constants';\nimport { Text, Icon, Label, Stack, ChoiceGroup } from '@fluentui/react';\nimport Tooltip from '@shared/components/tooltip';\nimport { TermsStrings } from '@shared/Models';\nimport { getBillingTermTranslated } from '@shared/utils/pricing';\nconst pbTelemetry = Constants.Telemetry.PurchaseBlendsTelemetry;\nexport const BillingTermChoiceGroup = ({ setSelectedTerm, setBillingTerm, items }, context)=>{\n const { id: planId, product, hasFreeTrial, termDuration } = items[0];\n const handleBillingTermChanges = ({ setSelectedTerm, setBillingTerm, planId, product, hasFreeTrial, option })=>{\n const firstTerm = product.getTermByPlanAndBillingTermDuration({\n planId,\n billingTermDuration: option.key\n });\n setBillingTerm({\n id: planId,\n termDuration: option.key\n });\n setSelectedTerm({\n id: planId,\n termId: hasFreeTrial ? firstTerm.freeTrialTermId : firstTerm.termId\n });\n };\n const generateBillingOption = (term, context)=>{\n return {\n key: term,\n text: `${getBillingTermTranslated({\n context,\n term,\n isSubscription: true\n })}`\n };\n };\n const getTermMapping = (context)=>{\n return {\n [TermsStrings.MonthString.toLowerCase()]: generateBillingOption(TermsStrings.Term1MString, context),\n [TermsStrings.Term1MString.toLowerCase()]: generateBillingOption(TermsStrings.Term1MString, context),\n [TermsStrings.YearString.toLowerCase()]: generateBillingOption(TermsStrings.Term1YString, context),\n [TermsStrings.Term1YString.toLowerCase()]: generateBillingOption(TermsStrings.Term1YString, context),\n [TermsStrings.Term2YString.toLowerCase()]: generateBillingOption(TermsStrings.Term2YString, context),\n [TermsStrings.Term3YString.toLowerCase()]: generateBillingOption(TermsStrings.Term3YString, context)\n };\n };\n const getBillingOptions = (items, context)=>{\n // Since sort happens in place, cloning list instead of messing up redux.\n const listOfTerms = [\n ...items[0].product.getTermDurationsByPlanId(items[0].id)\n ];\n return listOfTerms.sort().map((term)=>{\n const billingOptionsMap = getTermMapping(context);\n return billingOptionsMap[term.toLowerCase()];\n });\n };\n const options = useMemo(()=>getBillingOptions(items, context), [\n items,\n context\n ]);\n return /*#__PURE__*/ _jsxs(_Fragment, {\n children: [\n /*#__PURE__*/ _jsx(Label, {\n children: /*#__PURE__*/ _jsx(Stack, {\n horizontal: true,\n verticalAlign: \"center\",\n wrap: false,\n children: /*#__PURE__*/ _jsxs(Text, {\n className: \"ms-fontWeight-semibold\",\n children: [\n `${context.loc('Checkout_PriceAndBilling_BillingTerm', 'Billing term')} `,\n /*#__PURE__*/ _jsx(Tooltip, {\n tooltipHostProps: {\n content: context.loc('Checkout_PriceAndBilling_Tooltip_BillingTerm', \"This is the plan's subscription period.\"),\n calloutProps: {\n gapSpace: 0\n }\n },\n children: /*#__PURE__*/ _jsx(Icon, {\n iconName: \"Info\",\n ariaLabel: context.loc('Checkout_PriceAndBilling_Tooltip_BillingTerm', \"This is the plan's subscription period.\")\n })\n }),\n /*#__PURE__*/ _jsx(Text, {\n className: \"requiredColor\",\n children: ` *`\n })\n ]\n })\n })\n }),\n /*#__PURE__*/ _jsx(Stack, {\n horizontal: true,\n tokens: {\n childrenGap: 10\n },\n children: /*#__PURE__*/ _jsx(Stack.Item, {\n children: (options === null || options === void 0 ? void 0 : options.length) > 1 ? /*#__PURE__*/ _jsx(ChoiceGroup, {\n \"data-bi-id\": pbTelemetry.PickBillingTerm,\n \"data-bi-name\": pbTelemetry.BillingTermComponent,\n options: options,\n onChange: (_, option)=>handleBillingTermChanges({\n product,\n planId,\n setBillingTerm,\n setSelectedTerm,\n hasFreeTrial,\n option\n }),\n defaultSelectedKey: termDuration || ''\n }) : /*#__PURE__*/ _jsx(Text, {\n children: options === null || options === void 0 ? void 0 : options[0].text\n })\n })\n })\n ]\n });\n};\nBillingTermChoiceGroup.contextTypes = {\n locParams: PropTypes.func,\n loc: PropTypes.func\n};\n","import { jsx as _jsx, jsxs as _jsxs } from \"react/jsx-runtime\";\nimport React, { useRef, useState } from 'react';\nimport FuturePriceWarning from '@shared/components/futurePriceWarning';\nimport { SaasPricingTableBase } from '@shared/components';\nimport { connect } from 'react-redux';\nimport { mergeStyleSets } from '@fluentui/react';\nimport classNames from 'classnames';\nconst classes = mergeStyleSets({\n limitHeight: {\n height: '70vh'\n }\n});\nexport const SaasPricingTableComponent = ({ app, billingCountry, onGetInNowClicked, shouldBlockPrices, config: { locale } })=>{\n var _globalThis_document;\n const [isHorizontalScrollbarPresent, setIsHorizontalScrollbarPresent] = useState(false);\n const containerRef = useRef();\n const { futurePricesInformation: futurePrices } = app;\n // In SSR context there's no body\n const bodyElement = (_globalThis_document = globalThis.document) === null || _globalThis_document === void 0 ? void 0 : _globalThis_document.body;\n const isDocumentScrollableVertically = (bodyElement === null || bodyElement === void 0 ? void 0 : bodyElement.scrollHeight) > (bodyElement === null || bodyElement === void 0 ? void 0 : bodyElement.clientHeight);\n return /*#__PURE__*/ _jsxs(\"div\", {\n ref: containerRef,\n className: classNames({\n [classes.limitHeight]: isDocumentScrollableVertically && isHorizontalScrollbarPresent\n }),\n children: [\n /*#__PURE__*/ _jsx(FuturePriceWarning, {\n futurePrices: futurePrices\n }),\n /*#__PURE__*/ _jsx(SaasPricingTableBase, {\n app: app,\n billingCountry: billingCountry,\n locale: locale,\n onGetInNowClicked: onGetInNowClicked,\n shouldBlockPrices: shouldBlockPrices\n })\n ]\n });\n};\nconst mapStateToProps = ({ config })=>({\n config\n });\nexport const SaasPricingTable = connect(mapStateToProps)(SaasPricingTableComponent);\n","import { jsx as _jsx, jsxs as _jsxs } from \"react/jsx-runtime\";\nimport React, { useEffect } from 'react';\nimport { mergeStyleSets, Stack, Text, FontSizes, ProgressIndicator, ScreenWidthMinXLarge } from '@fluentui/react';\nimport OptimizingImage from '@shared/images/optimizingImage.svg';\nimport { TelemetryImage } from '@shared/components/telemetryImage';\nconst OrderLoadingStyles = {\n itemDescription: {\n textAlign: 'center'\n }\n};\nconst contentStyles = mergeStyleSets({\n itemName: {\n fontSize: FontSizes.size28,\n fontWeight: 900,\n marginTop: '20px',\n textAlign: 'center'\n },\n progressContainer: {\n width: '640px',\n height: '680px',\n zIndex: '101',\n backgroundColor: '#FFFFFF',\n position: 'absolute',\n margin: 'auto',\n top: '0',\n right: '0',\n bottom: '0',\n left: '0',\n padding: '120px 80px',\n [`@media (max-width: ${ScreenWidthMinXLarge}px)`]: {\n width: '320px',\n height: '440px',\n padding: '60px 40px'\n }\n }\n});\nexport const OrderLoading = ({ context })=>{\n const progressMessages = [\n 'Loader_Starting',\n 'Loader_Verifiying',\n 'Loader_Processing'\n ];\n const intervalDelay = 2500;\n const intervalIncrement = 0.1;\n const [progressMessage, setProgressMessage] = React.useState(progressMessages[0]);\n const [percentComplete, setPercentComplete] = React.useState(0);\n useEffect(()=>{\n if (percentComplete <= 0.9) {\n const id = setInterval(()=>{\n setPercentComplete((intervalIncrement + percentComplete) % 1);\n switch(Math.round(percentComplete * 10 / 2)){\n case 0:\n case 1:\n setProgressMessage(progressMessages[0]);\n break;\n case 2:\n setProgressMessage(progressMessages[1]);\n break;\n case 3:\n setProgressMessage(progressMessages[2]);\n break;\n }\n }, intervalDelay);\n return ()=>{\n clearInterval(id);\n };\n }\n }, [\n percentComplete,\n progressMessages\n ]);\n return /*#__PURE__*/ _jsxs(Stack, {\n className: contentStyles.progressContainer,\n tokens: {\n childrenGap: 20\n },\n children: [\n /*#__PURE__*/ _jsx(Stack.Item, {\n align: \"center\",\n children: /*#__PURE__*/ _jsx(TelemetryImage, {\n alt: \"placeOrderImage\",\n src: OptimizingImage\n })\n }),\n /*#__PURE__*/ _jsx(Text, {\n title: context.loc(progressMessage),\n className: contentStyles.itemName,\n children: context.loc(progressMessage)\n }),\n /*#__PURE__*/ _jsx(ProgressIndicator, {\n description: context.loc('Loader_Description'),\n percentComplete: percentComplete,\n barHeight: 2,\n styles: OrderLoadingStyles\n })\n ]\n });\n};\n","import { jsx as _jsx, jsxs as _jsxs } from \"react/jsx-runtime\";\nimport React, { useEffect } from 'react';\nimport { useSelector } from 'react-redux';\nimport { FontSizes, FontWeights, mergeStyleSets, PrimaryButton, ScreenWidthMinXLarge, Stack, Text } from '@fluentui/react';\nimport { Constants } from '@shared/utils/constants';\nimport { logger } from '@src/logger';\nimport { SpzaInstrumentService } from '@shared/services/telemetry/spza/spzaInstrument';\nconst contentStyles = mergeStyleSets({\n title: {\n fontSize: FontSizes.size20,\n fontWeight: FontWeights.semibold\n },\n container: {\n width: '560px',\n height: '216px',\n zIndex: '101',\n backgroundColor: '#FFFFFF',\n position: 'absolute',\n margin: 'auto',\n top: '0',\n right: '0',\n bottom: '0',\n left: '0',\n padding: '24px',\n [`@media (max-width: ${ScreenWidthMinXLarge}px)`]: {\n width: '90%'\n }\n }\n});\nconst logClickEvent = ({ userType, checkoutId })=>{\n const payload = {\n page: location.pathname,\n action: Constants.Telemetry.Action.Checkout,\n actionModifier: Constants.Telemetry.ActionModifier.RedirectButton,\n details: JSON.stringify({\n userType,\n checkoutId\n })\n };\n SpzaInstrumentService.getProvider().probe('logTelemetryInfo', payload);\n logger.info(payload.details, {\n action: payload.action,\n actionModifier: payload.actionModifier,\n appName: payload.appName\n });\n};\nexport const RedirectModal = ({ onClick, context, userType })=>{\n const checkoutId = useSelector(({ checkout })=>checkout.checkoutId);\n useEffect(()=>{\n const payload = {\n page: location.pathname,\n action: Constants.Telemetry.Action.Checkout,\n actionModifier: Constants.Telemetry.ActionModifier.RedirectModal,\n details: JSON.stringify({\n userType,\n checkoutId\n })\n };\n SpzaInstrumentService.getProvider().probe('logTelemetryInfo', payload);\n logger.info(payload.details, {\n action: payload.action,\n actionModifier: payload.actionModifier,\n page: payload.page\n });\n }, []);\n return /*#__PURE__*/ _jsxs(Stack, {\n className: contentStyles.container,\n verticalAlign: \"space-between\",\n children: [\n /*#__PURE__*/ _jsx(Stack.Item, {\n align: \"start\",\n children: /*#__PURE__*/ _jsx(Text, {\n className: contentStyles.title,\n children: context.loc('Checkout_Error_Title')\n })\n }),\n /*#__PURE__*/ _jsx(Stack.Item, {\n align: \"start\",\n children: /*#__PURE__*/ _jsx(Text, {\n children: context.loc('Checkout_Error_Description')\n })\n }),\n /*#__PURE__*/ _jsx(Stack.Item, {\n align: \"end\",\n children: /*#__PURE__*/ _jsx(PrimaryButton, {\n \"data-bi-id\": Constants.JsllCheckout.RedirectButton,\n onClick: ()=>{\n onClick();\n logClickEvent(userType);\n },\n children: context.loc('Checkout_Error_Button')\n })\n })\n ]\n });\n};\n","import { jsx as _jsx, jsxs as _jsxs } from \"react/jsx-runtime\";\nimport React, { useEffect } from 'react';\n// eslint-disable-next-line import/named\nimport { mergeStyleSets, Stack, Text, FontSizes, ScreenWidthMinXLarge, Spinner } from '@fluentui/react';\nconst contentStyles = mergeStyleSets({\n itemName: {\n fontSize: FontSizes.size28,\n fontWeight: 600,\n marginTop: '20px',\n textAlign: 'center'\n },\n progressContainer: {\n width: '560px',\n height: '280px',\n zIndex: '101',\n backgroundColor: '#FFFFFF',\n position: 'absolute',\n margin: 'auto',\n top: '0',\n right: '0',\n bottom: '0',\n left: '0',\n padding: '120px 80px',\n [`@media (max-width: ${ScreenWidthMinXLarge}px)`]: {\n width: '90%',\n height: '280px'\n }\n }\n});\nconst spinnerStyles = {\n circle: {\n width: '56px',\n height: '56px'\n }\n};\nexport const BusyLoader = ({ context })=>{\n const progressMessages = [\n 'Loading_Selection',\n 'Working',\n 'Updating'\n ];\n const intervalDelay = 2500;\n const intervalIncrement = 0.1;\n const [progressMessage, setProgressMessage] = React.useState(progressMessages[0]);\n const [percentComplete, setPercentComplete] = React.useState(0);\n useEffect(()=>{\n if (percentComplete <= 0.9) {\n const id = setInterval(()=>{\n setPercentComplete((intervalIncrement + percentComplete) % 1);\n switch(Math.round(percentComplete * 10 / 2)){\n case 0:\n case 1:\n setProgressMessage(progressMessages[0]);\n break;\n case 2:\n setProgressMessage(progressMessages[1]);\n break;\n case 3:\n setProgressMessage(progressMessages[2]);\n break;\n }\n }, intervalDelay);\n return ()=>{\n clearInterval(id);\n };\n }\n }, [\n percentComplete,\n progressMessages\n ]);\n return /*#__PURE__*/ _jsxs(Stack, {\n className: contentStyles.progressContainer,\n tokens: {\n childrenGap: 20\n },\n verticalAlign: \"center\",\n children: [\n /*#__PURE__*/ _jsx(Spinner, {\n styles: spinnerStyles\n }),\n /*#__PURE__*/ _jsx(Text, {\n title: context.loc(progressMessage),\n className: contentStyles.itemName,\n children: context.loc(progressMessage)\n })\n ]\n });\n};\n","import { jsx as _jsx } from \"react/jsx-runtime\";\nimport React from 'react';\nimport { mergeStyleSets, MessageBar, MessageBarType } from '@fluentui/react';\nimport { Constants } from '@shared/utils/constants';\nconst contentStyles = mergeStyleSets({\n root: {\n marginBottom: '10px'\n }\n});\nexport const MSuserErrorBanner = ({ context, tenantId })=>{\n return tenantId === Constants.MSTenantId && /*#__PURE__*/ _jsx(\"div\", {\n className: contentStyles.root,\n children: /*#__PURE__*/ _jsx(MessageBar, {\n role: \"status\",\n messageBarType: MessageBarType.error,\n children: context.loc('MSuser_Banner', 'As a Microsoft Employee, you are not allowed to complete a purchase in AppSource')\n })\n });\n};\n","import { jsx as _jsx, jsxs as _jsxs } from \"react/jsx-runtime\";\nimport React, { useState } from 'react';\nimport * as PropTypes from 'prop-types';\nimport { Text, mergeStyleSets, Stack, Icon } from '@fluentui/react';\nimport classNames from 'classnames';\nimport { isNil } from 'lodash-es';\nimport { useSelector } from 'react-redux';\nimport { NeutralColors, SharedColors } from '@fluentui/theme';\nimport { storeFeedback } from 'services/feedback';\nimport { Constants } from '@shared/utils/constants';\nimport { logTelemetry } from '@shared/utils/telemetryUtils';\nconst contentStyles = mergeStyleSets({\n containerClass: {\n paddingTop: 8\n },\n feedbackButtons: {\n color: NeutralColors.gray160,\n '&:hover': {\n color: SharedColors.cyanBlue10\n }\n },\n feedbackButtonsSelected: {\n color: SharedColors.cyanBlue10,\n cursor: 'default'\n },\n defaultCursor: {\n cursor: 'default'\n },\n pointerCursor: {\n cursor: 'pointer'\n }\n});\nconst Negative = 'Negative';\nconst Positive = 'Positive';\nconst getAriaLabel = ({ isFeedbackNull, isFeedbackPositive, feedbackNoun, context })=>{\n const isPositiveFeedbackSelected = !isFeedbackNull && isFeedbackPositive;\n const isNegativeFeedbackSelected = !isFeedbackNull && !isFeedbackPositive;\n const selectionCondition = feedbackNoun === Negative ? isPositiveFeedbackSelected : isNegativeFeedbackSelected;\n const feedbackText = feedbackNoun === Positive ? Positive : Negative;\n return isFeedbackNull || selectionCondition ? context.loc(`Feedback_ShowingResultsFor_${feedbackText}Feedback`, `${feedbackText} feedback`) : context.loc(`Feedback_ShowingResultsFor_${feedbackText}FeedbackProvided`, `Provided ${feedbackText} feedback`);\n};\nexport const sendFeedback = ({ isPositive, requestId, showingResultsFor, didYouMean, previousSearchText })=>{\n const details = {\n positiveFeedBack: isPositive,\n requestId,\n showingResultsFor,\n didYouMean,\n searchTerm: previousSearchText\n };\n logTelemetry(Constants.Telemetry.Action.Feedback, Constants.Telemetry.ActionModifier.ShowingResultsForFeedback, JSON.stringify(details), true);\n storeFeedback({\n action: Constants.Telemetry.Action.Click,\n actionModifier: Constants.Telemetry.ActionModifier.ShowingResultsForFeedback,\n details: JSON.stringify(details)\n });\n};\nconst likeIconName = 'Like';\nconst solidLikeIconName = 'LikeSolid';\nconst dislikeIconName = 'Dislike';\nconst solidDislikeIconName = 'DislikeSolid';\nexport const ThumbsUpDown = ({ localizedQuestion = '' }, context)=>{\n const { containerClass, feedbackButtons, feedbackButtonsSelected, defaultCursor, pointerCursor } = contentStyles;\n const [isFeedbackPositive, setFeedback] = useState(null);\n const { requestId, showingResultsFor, didYouMean, previousSearchText } = useSelector(({ search: { requestId, showingResultsFor, didYouMean, previousSearchText } })=>({\n requestId,\n showingResultsFor,\n didYouMean,\n previousSearchText\n }));\n const isFeedbackNull = isNil(isFeedbackPositive);\n const likeAria = getAriaLabel({\n isFeedbackNull,\n feedbackNoun: Positive,\n isFeedbackPositive,\n context\n });\n const dislikeAria = getAriaLabel({\n isFeedbackNull,\n feedbackNoun: Negative,\n isFeedbackPositive,\n context\n });\n const handleFeedbackClick = ({ isPositive })=>{\n if (isFeedbackNull) {\n setFeedback(isPositive);\n sendFeedback({\n isPositive,\n requestId,\n showingResultsFor,\n didYouMean,\n previousSearchText\n });\n }\n };\n const detectKeyboardClick = ({ event: { key }, isPositive })=>{\n if (key === Constants.SystemKeyAsString.Enter || key === Constants.SystemKeyAsString.Space) {\n handleFeedbackClick({\n isPositive\n });\n }\n };\n const positiveIconName = isFeedbackNull ? likeIconName : isFeedbackPositive ? solidLikeIconName : likeIconName;\n const negativeIconName = isFeedbackNull ? dislikeIconName : !isFeedbackPositive ? solidDislikeIconName : dislikeIconName;\n const thumbsUpClass = classNames({\n [defaultCursor]: !isFeedbackNull && !isFeedbackPositive,\n [feedbackButtons]: isFeedbackNull,\n [pointerCursor]: isFeedbackNull,\n [feedbackButtonsSelected]: !isFeedbackNull && isFeedbackPositive\n });\n const thumbsDownClass = classNames({\n [defaultCursor]: !isFeedbackNull && isFeedbackPositive,\n [feedbackButtons]: isFeedbackNull,\n [pointerCursor]: isFeedbackNull,\n [feedbackButtonsSelected]: !isFeedbackNull && !isFeedbackPositive\n });\n return /*#__PURE__*/ _jsx(\"div\", {\n children: /*#__PURE__*/ _jsxs(Stack, {\n horizontal: true,\n className: containerClass,\n tokens: {\n childrenGap: 6\n },\n children: [\n /*#__PURE__*/ _jsx(Stack.Item, {\n children: /*#__PURE__*/ _jsx(Text, {\n children: localizedQuestion\n })\n }),\n /*#__PURE__*/ _jsx(Stack.Item, {\n children: /*#__PURE__*/ _jsx(Icon, {\n role: 'button',\n \"aria-label\": likeAria,\n tabIndex: 0,\n onClick: ()=>handleFeedbackClick({\n isPositive: true\n }),\n onKeyDown: (event)=>detectKeyboardClick({\n event,\n isPositive: true\n }),\n iconName: positiveIconName,\n className: thumbsUpClass\n })\n }),\n /*#__PURE__*/ _jsx(Stack.Item, {\n children: /*#__PURE__*/ _jsx(Icon, {\n role: 'button',\n \"aria-label\": dislikeAria,\n tabIndex: 0,\n onClick: ()=>handleFeedbackClick({\n isPositive: false\n }),\n onKeyDown: (event)=>detectKeyboardClick({\n event,\n isPositive: false\n }),\n iconName: negativeIconName,\n className: thumbsDownClass\n })\n })\n ]\n })\n });\n};\nThumbsUpDown.contextTypes = {\n loc: PropTypes.func\n};\n","function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {\n try {\n var info = gen[key](arg);\n var value = info.value;\n } catch (error) {\n reject(error);\n return;\n }\n if (info.done) {\n resolve(value);\n } else {\n Promise.resolve(value).then(_next, _throw);\n }\n}\nfunction _async_to_generator(fn) {\n return function() {\n var self = this, args = arguments;\n return new Promise(function(resolve, reject) {\n var gen = fn.apply(self, args);\n function _next(value) {\n asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"next\", value);\n }\n function _throw(err) {\n asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"throw\", err);\n }\n _next(undefined);\n });\n };\n}\nfunction _define_property(obj, key, value) {\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n return obj;\n}\nfunction _object_spread(target) {\n for(var i = 1; i < arguments.length; i++){\n var source = arguments[i] != null ? arguments[i] : {};\n var ownKeys = Object.keys(source);\n if (typeof Object.getOwnPropertySymbols === \"function\") {\n ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {\n return Object.getOwnPropertyDescriptor(source, sym).enumerable;\n }));\n }\n ownKeys.forEach(function(key) {\n _define_property(target, key, source[key]);\n });\n }\n return target;\n}\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nimport React, { Suspense, useCallback, useEffect, useRef, useState } from 'react';\nimport { render, unmountComponentAtNode } from 'react-dom';\nimport { Provider, useStore } from 'react-redux';\nimport { unstable_HistoryRouter as HistoryRouter, Routes, Route } from 'react-router-dom';\nimport PropTypes from 'prop-types';\nimport { appHistory } from '@shared/routerHistory';\nimport { useHydration } from '@shared/hooks/useHydration';\nimport { ensureCheckoutApp } from '@shared/actions/thunkActions';\nconst Checkout = /*#__PURE__*/ React.lazy(()=>import('./checkout'));\n/**\n * This component is in charge of hydrating only the PurchaseBlends Checkout wrapper by using React 17's hydrate function\n * on a pre-defined
root because The PurchaseBlends UI does not support React 18.\n * @param _ props is never used\n * @param context React.context inherited by