@envive-ai/react-hooks 0.2.10-arthur-3 → 0.2.11
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +0 -33
- package/dist/{chunk-CUT6urMc.cjs → _virtual/rolldown_runtime.cjs} +11 -12
- package/dist/application/commerce-api.cjs +319 -0
- package/dist/application/commerce-api.js +318 -0
- package/dist/application/logging/logger.cjs +21 -0
- package/dist/application/logging/logger.js +20 -0
- package/dist/application/models/api/context.d.cts +8 -0
- package/dist/application/models/api/context.d.ts +8 -0
- package/dist/application/models/api/generationParams.d.cts +8 -0
- package/dist/application/models/api/generationParams.d.ts +8 -0
- package/dist/application/models/api/nextMessageRequest.d.cts +15 -0
- package/dist/application/models/api/nextMessageRequest.d.ts +15 -0
- package/dist/application/models/api/orgAnalyticsConfig.d.cts +20 -0
- package/dist/application/models/api/orgAnalyticsConfig.d.ts +20 -0
- package/dist/application/models/api/orgConfigResults.d.cts +43 -0
- package/dist/application/models/api/orgConfigResults.d.ts +43 -0
- package/dist/application/models/api/organizationConfig.d.cts +16 -0
- package/dist/application/models/api/organizationConfig.d.ts +16 -0
- package/dist/application/models/api/response.d.cts +94 -0
- package/dist/application/models/api/response.d.ts +94 -0
- package/dist/application/models/api/responseGenerics.d.cts +60 -0
- package/dist/application/models/api/responseGenerics.d.ts +60 -0
- package/dist/{search-6RrxBXD6.d.cts → application/models/api/search.d.cts} +2 -2
- package/dist/{search-DrJiCT7d.d.ts → application/models/api/search.d.ts} +2 -2
- package/dist/application/models/api/suggestion.d.cts +8 -0
- package/dist/application/models/api/suggestion.d.ts +8 -0
- package/dist/application/models/api/supportedEventRequest.d.cts +12 -0
- package/dist/application/models/api/supportedEventRequest.d.ts +12 -0
- package/dist/application/models/api/userEvent.d.cts +57 -0
- package/dist/application/models/api/userEvent.d.ts +57 -0
- package/dist/application/models/cachedValue.d.cts +8 -0
- package/dist/application/models/cachedValue.d.ts +8 -0
- package/dist/application/models/chatElementDisplayLocation.cjs +29 -0
- package/dist/application/models/chatElementDisplayLocation.d.cts +26 -0
- package/dist/application/models/chatElementDisplayLocation.d.ts +26 -0
- package/dist/application/models/chatElementDisplayLocation.js +28 -0
- package/dist/application/models/clientDetails.d.cts +18 -0
- package/dist/application/models/clientDetails.d.ts +18 -0
- package/dist/application/models/colorsConfig.cjs +29 -0
- package/dist/application/models/colorsConfig.d.cts +26 -0
- package/dist/application/models/colorsConfig.d.ts +26 -0
- package/dist/application/models/colorsConfig.js +27 -0
- package/dist/application/models/conversationalSearchIds.d.cts +9 -0
- package/dist/application/models/conversationalSearchIds.d.ts +9 -0
- package/dist/application/models/dataLayer.d.cts +45 -0
- package/dist/application/models/dataLayer.d.ts +45 -0
- package/dist/application/models/events.cjs +11 -0
- package/dist/application/models/events.d.cts +8 -0
- package/dist/application/models/events.d.ts +8 -0
- package/dist/application/models/events.js +10 -0
- package/dist/application/models/featureGates.cjs +27 -0
- package/dist/application/models/featureGates.d.cts +24 -0
- package/dist/application/models/featureGates.d.ts +24 -0
- package/dist/application/models/featureGates.js +26 -0
- package/dist/application/models/frontendConfig.d.cts +13 -0
- package/dist/application/models/frontendConfig.d.ts +13 -0
- package/dist/application/models/googleAnalyticsEvents.cjs +11 -0
- package/dist/application/models/googleAnalyticsEvents.d.cts +8 -0
- package/dist/application/models/googleAnalyticsEvents.d.ts +8 -0
- package/dist/application/models/googleAnalyticsEvents.js +10 -0
- package/dist/application/models/graphql/index.cjs +6 -5
- package/dist/application/models/graphql/index.d.cts +3 -1
- package/dist/application/models/graphql/index.d.ts +3 -1
- package/dist/application/models/graphql/index.js +3 -2
- package/dist/application/models/graphql/queries/getMerchantColorsQuery.cjs +18 -0
- package/dist/application/models/graphql/queries/getMerchantColorsQuery.d.cts +25 -0
- package/dist/application/models/graphql/queries/getMerchantColorsQuery.d.ts +25 -0
- package/dist/application/models/graphql/queries/getMerchantColorsQuery.js +18 -0
- package/dist/application/models/graphql/queries/getMerchantFrontendConfigQuery.cjs +18 -0
- package/dist/application/models/graphql/queries/getMerchantFrontendConfigQuery.d.cts +75 -0
- package/dist/application/models/graphql/queries/getMerchantFrontendConfigQuery.d.ts +75 -0
- package/dist/application/models/graphql/queries/getMerchantFrontendConfigQuery.js +18 -0
- package/dist/application/models/graphql/queries/getMerchantOrgIdQuery.cjs +15 -0
- package/dist/application/models/graphql/queries/getMerchantOrgIdQuery.d.cts +5 -0
- package/dist/application/models/graphql/queries/getMerchantOrgIdQuery.d.ts +5 -0
- package/dist/application/models/graphql/queries/getMerchantOrgIdQuery.js +14 -0
- package/dist/application/models/guards/api/index.cjs +24 -15
- package/dist/application/models/guards/api/index.d.cts +12 -3
- package/dist/application/models/guards/api/index.d.ts +12 -3
- package/dist/application/models/guards/api/index.js +12 -3
- package/dist/application/models/guards/api/isApiFormResponse.cjs +51 -0
- package/dist/application/models/guards/api/isApiFormResponse.d.cts +16 -0
- package/dist/application/models/guards/api/isApiFormResponse.d.ts +16 -0
- package/dist/application/models/guards/api/isApiFormResponse.js +50 -0
- package/dist/application/models/guards/api/isApiFormSubmittedResponseAttributes.cjs +29 -0
- package/dist/application/models/guards/api/isApiFormSubmittedResponseAttributes.d.cts +7 -0
- package/dist/application/models/guards/api/isApiFormSubmittedResponseAttributes.d.ts +7 -0
- package/dist/application/models/guards/api/isApiFormSubmittedResponseAttributes.js +28 -0
- package/dist/application/models/guards/api/isApiOrderResponseAttributes.cjs +82 -0
- package/dist/application/models/guards/api/isApiOrderResponseAttributes.d.cts +17 -0
- package/dist/application/models/guards/api/isApiOrderResponseAttributes.d.ts +17 -0
- package/dist/application/models/guards/api/isApiOrderResponseAttributes.js +82 -0
- package/dist/application/models/guards/api/isApiOrgConfigResults.cjs +130 -0
- package/dist/application/models/guards/api/isApiOrgConfigResults.d.cts +19 -0
- package/dist/application/models/guards/api/isApiOrgConfigResults.d.ts +19 -0
- package/dist/application/models/guards/api/isApiOrgConfigResults.js +129 -0
- package/dist/application/models/guards/api/isApiOrganizationConfig.cjs +116 -0
- package/dist/application/models/guards/api/isApiOrganizationConfig.d.cts +31 -0
- package/dist/application/models/guards/api/isApiOrganizationConfig.d.ts +31 -0
- package/dist/application/models/guards/api/isApiOrganizationConfig.js +116 -0
- package/dist/application/models/guards/api/isApiPDPEventAttributes.cjs +13 -0
- package/dist/application/models/guards/api/isApiPDPEventAttributes.d.cts +7 -0
- package/dist/application/models/guards/api/isApiPDPEventAttributes.d.ts +7 -0
- package/dist/application/models/guards/api/isApiPDPEventAttributes.js +12 -0
- package/dist/application/models/guards/api/isApiPLPEventAttributes.cjs +20 -0
- package/dist/application/models/guards/api/isApiPLPEventAttributes.d.cts +8 -0
- package/dist/application/models/guards/api/isApiPLPEventAttributes.d.ts +8 -0
- package/dist/application/models/guards/api/isApiPLPEventAttributes.js +18 -0
- package/dist/application/models/guards/api/isApiPageResponseAttributes.cjs +13 -0
- package/dist/application/models/guards/api/isApiPageResponseAttributes.d.cts +7 -0
- package/dist/application/models/guards/api/isApiPageResponseAttributes.d.ts +7 -0
- package/dist/application/models/guards/api/isApiPageResponseAttributes.js +12 -0
- package/dist/application/models/guards/api/isApiProductResponseAttributes.cjs +51 -0
- package/dist/application/models/guards/api/isApiProductResponseAttributes.d.cts +7 -0
- package/dist/application/models/guards/api/isApiProductResponseAttributes.d.ts +7 -0
- package/dist/application/models/guards/api/isApiProductResponseAttributes.js +51 -0
- package/dist/application/models/guards/api/isApiProductSearchAttributes.cjs +12 -0
- package/dist/application/models/guards/api/isApiProductSearchAttributes.d.cts +7 -0
- package/dist/application/models/guards/api/isApiProductSearchAttributes.d.ts +7 -0
- package/dist/application/models/guards/api/isApiProductSearchAttributes.js +11 -0
- package/dist/application/models/guards/api/isApiProductSearchFilterAttributes.cjs +11 -0
- package/dist/application/models/guards/api/isApiProductSearchFilterAttributes.d.cts +7 -0
- package/dist/application/models/guards/api/isApiProductSearchFilterAttributes.d.ts +7 -0
- package/dist/application/models/guards/api/isApiProductSearchFilterAttributes.js +10 -0
- package/dist/application/models/guards/api/isApiQueryTypedEventAttributes.cjs +7 -0
- package/dist/application/models/guards/api/isApiQueryTypedEventAttributes.d.cts +7 -0
- package/dist/application/models/guards/api/isApiQueryTypedEventAttributes.d.ts +7 -0
- package/dist/application/models/guards/api/isApiQueryTypedEventAttributes.js +6 -0
- package/dist/application/models/guards/api/isApiResponse.cjs +33 -0
- package/dist/application/models/guards/api/isApiResponse.d.cts +7 -0
- package/dist/application/models/guards/api/isApiResponse.d.ts +7 -0
- package/dist/application/models/guards/api/isApiResponse.js +32 -0
- package/dist/application/models/guards/api/isApiReviewResponseAttributes.cjs +16 -0
- package/dist/application/models/guards/api/isApiReviewResponseAttributes.d.cts +7 -0
- package/dist/application/models/guards/api/isApiReviewResponseAttributes.d.ts +7 -0
- package/dist/application/models/guards/api/isApiReviewResponseAttributes.js +16 -0
- package/dist/application/models/guards/api/isApiReviewRichInformation.cjs +15 -0
- package/dist/application/models/guards/api/isApiReviewRichInformation.d.cts +7 -0
- package/dist/application/models/guards/api/isApiReviewRichInformation.d.ts +7 -0
- package/dist/application/models/guards/api/isApiReviewRichInformation.js +14 -0
- package/dist/application/models/guards/api/isApiSearchEventAttributes.cjs +14 -0
- package/dist/application/models/guards/api/isApiSearchEventAttributes.d.cts +7 -0
- package/dist/application/models/guards/api/isApiSearchEventAttributes.d.ts +7 -0
- package/dist/application/models/guards/api/isApiSearchEventAttributes.js +13 -0
- package/dist/application/models/guards/api/isApiSuggestion.cjs +17 -0
- package/dist/application/models/guards/api/isApiSuggestion.d.cts +7 -0
- package/dist/application/models/guards/api/isApiSuggestion.d.ts +7 -0
- package/dist/application/models/guards/api/isApiSuggestion.js +16 -0
- package/dist/application/models/guards/api/isApiSuggestionClickedEventAttributes.cjs +7 -0
- package/dist/application/models/guards/api/isApiSuggestionClickedEventAttributes.d.cts +7 -0
- package/dist/application/models/guards/api/isApiSuggestionClickedEventAttributes.d.ts +7 -0
- package/dist/application/models/guards/api/isApiSuggestionClickedEventAttributes.js +6 -0
- package/dist/application/models/guards/api/isApiTextResponseAttributes.cjs +7 -0
- package/dist/application/models/guards/api/isApiTextResponseAttributes.d.cts +7 -0
- package/dist/application/models/guards/api/isApiTextResponseAttributes.d.ts +7 -0
- package/dist/application/models/guards/api/isApiTextResponseAttributes.js +6 -0
- package/dist/application/models/guards/api/isApiUserEvent.cjs +15 -0
- package/dist/application/models/guards/api/isApiUserEvent.d.cts +7 -0
- package/dist/application/models/guards/api/isApiUserEvent.d.ts +7 -0
- package/dist/application/models/guards/api/isApiUserEvent.js +14 -0
- package/dist/application/models/guards/graphQL/isGraphQLColorsConfig.cjs +46 -0
- package/dist/application/models/guards/graphQL/isGraphQLColorsConfig.d.cts +7 -0
- package/dist/application/models/guards/graphQL/isGraphQLColorsConfig.d.ts +7 -0
- package/dist/application/models/guards/graphQL/isGraphQLColorsConfig.js +46 -0
- package/dist/application/models/guards/isBaseEcommerceEvent.cjs +14 -0
- package/dist/application/models/guards/isBaseEcommerceEvent.d.cts +15 -0
- package/dist/application/models/guards/isBaseEcommerceEvent.d.ts +15 -0
- package/dist/application/models/guards/isBaseEcommerceEvent.js +13 -0
- package/dist/application/models/guards/isGA4EcommerceEvent.cjs +14 -0
- package/dist/application/models/guards/isGA4EcommerceEvent.d.cts +15 -0
- package/dist/application/models/guards/isGA4EcommerceEvent.d.ts +15 -0
- package/dist/application/models/guards/isGA4EcommerceEvent.js +13 -0
- package/dist/application/models/guards/isLegacyUAEcommerceEvent.cjs +14 -0
- package/dist/application/models/guards/isLegacyUAEcommerceEvent.d.cts +15 -0
- package/dist/application/models/guards/isLegacyUAEcommerceEvent.d.ts +15 -0
- package/dist/application/models/guards/isLegacyUAEcommerceEvent.js +13 -0
- package/dist/application/models/guards/isMobilePLPChatPlacementParameter.cjs +7 -0
- package/dist/application/models/guards/isMobilePLPChatPlacementParameter.d.cts +8 -0
- package/dist/application/models/guards/isMobilePLPChatPlacementParameter.d.ts +8 -0
- package/dist/application/models/guards/isMobilePLPChatPlacementParameter.js +6 -0
- package/dist/application/models/guards/isSpanxTakeAQuizCtaParameter.cjs +7 -0
- package/dist/application/models/guards/isSpanxTakeAQuizCtaParameter.d.cts +7 -0
- package/dist/application/models/guards/isSpanxTakeAQuizCtaParameter.d.ts +7 -0
- package/dist/application/models/guards/isSpanxTakeAQuizCtaParameter.js +6 -0
- package/dist/application/models/guards/isVariantInfo.cjs +19 -0
- package/dist/application/models/guards/isVariantInfo.d.cts +15 -0
- package/dist/application/models/guards/isVariantInfo.d.ts +15 -0
- package/dist/application/models/guards/isVariantInfo.js +18 -0
- package/dist/application/models/guards/utils.cjs +27 -2
- package/dist/application/models/guards/utils.d.cts +15 -2
- package/dist/application/models/guards/utils.d.ts +15 -2
- package/dist/application/models/guards/utils.js +26 -2
- package/dist/application/models/index.cjs +111 -67
- package/dist/application/models/index.d.cts +84 -12
- package/dist/application/models/index.d.ts +84 -12
- package/dist/application/models/index.js +54 -10
- package/dist/application/models/localStorageEventListener.d.cts +8 -0
- package/dist/application/models/localStorageEventListener.d.ts +8 -0
- package/dist/application/models/message.cjs +29 -0
- package/dist/application/models/message.d.cts +107 -0
- package/dist/application/models/message.d.ts +107 -0
- package/dist/application/models/message.js +27 -0
- package/dist/application/models/mobilePLPChatPlacementParameter.d.cts +7 -0
- package/dist/application/models/mobilePLPChatPlacementParameter.d.ts +7 -0
- package/dist/application/models/orgsEnum.cjs +41 -0
- package/dist/application/models/orgsEnum.d.cts +39 -0
- package/dist/application/models/orgsEnum.d.ts +39 -0
- package/dist/application/models/orgsEnum.js +40 -0
- package/dist/application/models/productExperiment.cjs +10 -0
- package/dist/application/models/productExperiment.d.cts +7 -0
- package/dist/application/models/productExperiment.d.ts +7 -0
- package/dist/application/models/productExperiment.js +9 -0
- package/dist/application/models/spanxTakeAQuizCtaParameter.d.cts +8 -0
- package/dist/application/models/spanxTakeAQuizCtaParameter.d.ts +8 -0
- package/dist/application/models/spiffyWidgets.cjs +24 -0
- package/dist/application/models/spiffyWidgets.d.cts +21 -0
- package/dist/application/models/spiffyWidgets.d.ts +21 -0
- package/dist/application/models/spiffyWidgets.js +23 -0
- package/dist/application/models/utilityTypes/camelCase.d.cts +70 -0
- package/dist/application/models/utilityTypes/camelCase.d.ts +70 -0
- package/dist/application/models/utilityTypes/camelCasedPropertiesDeep.d.cts +56 -0
- package/dist/application/models/utilityTypes/camelCasedPropertiesDeep.d.ts +56 -0
- package/dist/application/models/utilityTypes/delimiterCase.d.cts +67 -0
- package/dist/application/models/utilityTypes/delimiterCase.d.ts +67 -0
- package/dist/application/models/utilityTypes/delimiterCasedPropertiesDeep.d.cts +55 -0
- package/dist/application/models/utilityTypes/delimiterCasedPropertiesDeep.d.ts +55 -0
- package/dist/application/models/utilityTypes/index.cjs +0 -1
- package/dist/application/models/utilityTypes/index.d.cts +1 -1
- package/dist/application/models/utilityTypes/index.d.ts +1 -1
- package/dist/application/models/utilityTypes/index.js +0 -2
- package/dist/application/models/utilityTypes/internal.d.cts +33 -0
- package/dist/application/models/utilityTypes/internal.d.ts +33 -0
- package/dist/application/models/utilityTypes/primitive.d.cts +10 -0
- package/dist/application/models/utilityTypes/primitive.d.ts +10 -0
- package/dist/application/models/utilityTypes/snakeCasedPropertiesDeep.d.cts +52 -0
- package/dist/application/models/utilityTypes/snakeCasedPropertiesDeep.d.ts +52 -0
- package/dist/application/models/utilityTypes/splitWords.d.cts +29 -0
- package/dist/application/models/utilityTypes/splitWords.d.ts +29 -0
- package/dist/application/models/utilityTypes/trim.d.cts +29 -0
- package/dist/application/models/utilityTypes/trim.d.ts +29 -0
- package/dist/application/models/utilityTypes/unknownArray.d.cts +29 -0
- package/dist/application/models/utilityTypes/unknownArray.d.ts +29 -0
- package/dist/application/models/utils/snakeToCamelTransformer.cjs +66 -0
- package/dist/application/models/utils/snakeToCamelTransformer.d.cts +16 -0
- package/dist/application/models/utils/snakeToCamelTransformer.d.ts +16 -0
- package/dist/application/models/utils/snakeToCamelTransformer.js +64 -0
- package/dist/application/models/utils/stringToFulfillmentDisplayStatusEnumValue.cjs +46 -0
- package/dist/application/models/utils/stringToFulfillmentDisplayStatusEnumValue.d.cts +16 -0
- package/dist/application/models/utils/stringToFulfillmentDisplayStatusEnumValue.d.ts +16 -0
- package/dist/application/models/utils/stringToFulfillmentDisplayStatusEnumValue.js +45 -0
- package/dist/application/models/validators/validateGraphQLColorsConfig.cjs +10 -0
- package/dist/application/models/validators/validateGraphQLColorsConfig.d.cts +7 -0
- package/dist/application/models/validators/validateGraphQLColorsConfig.d.ts +7 -0
- package/dist/application/models/validators/validateGraphQLColorsConfig.js +10 -0
- package/dist/application/models/validators/validateGraphQLFrontendConfig.cjs +231 -0
- package/dist/application/models/validators/validateGraphQLFrontendConfig.d.cts +11 -0
- package/dist/application/models/validators/validateGraphQLFrontendConfig.d.ts +11 -0
- package/dist/application/models/validators/validateGraphQLFrontendConfig.js +228 -0
- package/dist/application/models/validators/validateGraphQLOrgId.cjs +10 -0
- package/dist/application/models/validators/validateGraphQLOrgId.d.cts +5 -0
- package/dist/application/models/validators/validateGraphQLOrgId.d.ts +5 -0
- package/dist/application/models/validators/validateGraphQLOrgId.js +9 -0
- package/dist/application/models/validators/validateMobilePLPChatPlacementParameter.cjs +11 -0
- package/dist/application/models/validators/validateMobilePLPChatPlacementParameter.d.cts +7 -0
- package/dist/application/models/validators/validateMobilePLPChatPlacementParameter.d.ts +7 -0
- package/dist/application/models/validators/validateMobilePLPChatPlacementParameter.js +11 -0
- package/dist/application/models/validators/validateOrgConfigResults.cjs +44 -0
- package/dist/application/models/validators/validateOrgConfigResults.d.cts +13 -0
- package/dist/application/models/validators/validateOrgConfigResults.d.ts +13 -0
- package/dist/application/models/validators/validateOrgConfigResults.js +44 -0
- package/dist/application/models/validators/validateOrganizationConfig.cjs +28 -0
- package/dist/application/models/validators/validateOrganizationConfig.d.cts +7 -0
- package/dist/application/models/validators/validateOrganizationConfig.d.ts +7 -0
- package/dist/application/models/validators/validateOrganizationConfig.js +28 -0
- package/dist/application/models/validators/validateResponse.cjs +136 -0
- package/dist/application/models/validators/validateResponse.d.cts +7 -0
- package/dist/application/models/validators/validateResponse.d.ts +7 -0
- package/dist/application/models/validators/validateResponse.js +135 -0
- package/dist/application/models/validators/validateSuggestion.cjs +17 -0
- package/dist/application/models/validators/validateSuggestion.d.cts +7 -0
- package/dist/application/models/validators/validateSuggestion.d.ts +7 -0
- package/dist/application/models/validators/validateSuggestion.js +17 -0
- package/dist/application/models/validators/validateUserEvent.cjs +75 -0
- package/dist/application/models/validators/validateUserEvent.d.cts +7 -0
- package/dist/application/models/validators/validateUserEvent.d.ts +7 -0
- package/dist/application/models/validators/validateUserEvent.js +74 -0
- package/dist/application/models/variantInfo/index.cjs +1 -1
- package/dist/application/models/variantInfo/index.d.cts +1 -1
- package/dist/application/models/variantInfo/index.d.ts +1 -1
- package/dist/application/models/variantInfo/index.js +1 -1
- package/dist/application/models/variantInfo/pageVisitInfo.d.cts +10 -0
- package/dist/application/models/variantInfo/pageVisitInfo.d.ts +10 -0
- package/dist/application/models/variantInfo/plpInfo.d.cts +7 -0
- package/dist/application/models/variantInfo/plpInfo.d.ts +7 -0
- package/dist/application/models/variantInfo/productInfo.d.cts +9 -0
- package/dist/application/models/variantInfo/productInfo.d.ts +9 -0
- package/dist/{variantInfo-DpLn4nHz.cjs → application/models/variantInfo/variantInfo.cjs} +2 -7
- package/dist/application/models/variantInfo/variantInfo.d.cts +28 -0
- package/dist/application/models/variantInfo/variantInfo.d.ts +28 -0
- package/dist/{variantInfo-BfKlkaWU.js → application/models/variantInfo/variantInfo.js} +1 -1
- package/dist/application/utils/analyticsUtils.cjs +88 -0
- package/dist/application/utils/analyticsUtils.d.cts +17 -0
- package/dist/application/utils/analyticsUtils.d.ts +17 -0
- package/dist/application/utils/analyticsUtils.js +87 -0
- package/dist/application/utils/coreContextToApiContext.cjs +14 -0
- package/dist/application/utils/coreContextToApiContext.d.cts +8 -0
- package/dist/application/utils/coreContextToApiContext.d.ts +8 -0
- package/dist/application/utils/coreContextToApiContext.js +13 -0
- package/dist/application/utils/coreUserEventToApiUserEvent.cjs +74 -0
- package/dist/application/utils/coreUserEventToApiUserEvent.d.cts +8 -0
- package/dist/application/utils/coreUserEventToApiUserEvent.d.ts +8 -0
- package/dist/application/utils/coreUserEventToApiUserEvent.js +73 -0
- package/dist/application/utils/divideArray.cjs +11 -0
- package/dist/application/utils/divideArray.d.cts +5 -0
- package/dist/application/utils/divideArray.d.ts +5 -0
- package/dist/application/utils/divideArray.js +10 -0
- package/dist/application/utils/domObserver.cjs +87 -0
- package/dist/application/utils/domObserver.d.cts +39 -0
- package/dist/application/utils/domObserver.d.ts +39 -0
- package/dist/application/utils/domObserver.js +87 -0
- package/dist/application/utils/elementObserver.cjs +176 -0
- package/dist/application/utils/elementObserver.d.cts +68 -0
- package/dist/application/utils/elementObserver.d.ts +68 -0
- package/dist/application/utils/elementObserver.js +175 -0
- package/dist/application/utils/imageFilter.cjs +12 -0
- package/dist/application/utils/imageFilter.d.cts +7 -0
- package/dist/application/utils/imageFilter.d.ts +7 -0
- package/dist/application/utils/imageFilter.js +12 -0
- package/dist/application/utils/index.cjs +40 -41
- package/dist/application/utils/index.d.cts +22 -264
- package/dist/application/utils/index.d.ts +22 -264
- package/dist/application/utils/index.js +20 -21
- package/dist/application/utils/merchantUtils.cjs +18 -0
- package/dist/application/utils/merchantUtils.d.cts +5 -0
- package/dist/application/utils/merchantUtils.d.ts +5 -0
- package/dist/application/utils/merchantUtils.js +17 -0
- package/dist/application/utils/messageFromFormSubmittedEvent.cjs +21 -0
- package/dist/application/utils/messageFromFormSubmittedEvent.d.cts +9 -0
- package/dist/application/utils/messageFromFormSubmittedEvent.d.ts +9 -0
- package/dist/application/utils/messageFromFormSubmittedEvent.js +20 -0
- package/dist/application/utils/messageFromQueryEvent.cjs +36 -0
- package/dist/application/utils/messageFromQueryEvent.d.cts +16 -0
- package/dist/application/utils/messageFromQueryEvent.d.ts +16 -0
- package/dist/application/utils/messageFromQueryEvent.js +35 -0
- package/dist/application/utils/messageFromResponse.cjs +97 -0
- package/dist/application/utils/messageFromResponse.d.cts +16 -0
- package/dist/application/utils/messageFromResponse.d.ts +16 -0
- package/dist/application/utils/messageFromResponse.js +96 -0
- package/dist/application/utils/messageFromSuggestionEvent.cjs +33 -0
- package/dist/application/utils/messageFromSuggestionEvent.d.cts +18 -0
- package/dist/application/utils/messageFromSuggestionEvent.d.ts +18 -0
- package/dist/application/utils/messageFromSuggestionEvent.js +32 -0
- package/dist/application/utils/mouseEventTypes.d.cts +5 -0
- package/dist/application/utils/mouseEventTypes.d.ts +5 -0
- package/dist/application/utils/mutationHelper.cjs +31 -0
- package/dist/application/utils/mutationHelper.d.cts +12 -0
- package/dist/application/utils/mutationHelper.d.ts +12 -0
- package/dist/application/utils/mutationHelper.js +30 -0
- package/dist/application/utils/nextMessageRequestToApiRequest.cjs +32 -0
- package/dist/application/utils/nextMessageRequestToApiRequest.d.cts +8 -0
- package/dist/application/utils/nextMessageRequestToApiRequest.d.ts +8 -0
- package/dist/application/utils/nextMessageRequestToApiRequest.js +32 -0
- package/dist/application/utils/nodeSelector.cjs +92 -0
- package/dist/application/utils/nodeSelector.d.cts +28 -0
- package/dist/application/utils/nodeSelector.d.ts +28 -0
- package/dist/application/utils/nodeSelector.js +90 -0
- package/dist/application/utils/overrides.cjs +95 -0
- package/dist/application/utils/overrides.d.cts +37 -0
- package/dist/application/utils/overrides.d.ts +37 -0
- package/dist/application/utils/overrides.js +94 -0
- package/dist/application/utils/stringUtils.cjs +35 -0
- package/dist/application/utils/stringUtils.d.cts +18 -0
- package/dist/application/utils/stringUtils.d.ts +18 -0
- package/dist/application/utils/stringUtils.js +34 -0
- package/dist/application/utils/supportedEventRequestToApiRequest.cjs +13 -0
- package/dist/application/utils/supportedEventRequestToApiRequest.d.cts +8 -0
- package/dist/application/utils/supportedEventRequestToApiRequest.d.ts +8 -0
- package/dist/application/utils/supportedEventRequestToApiRequest.js +13 -0
- package/dist/application/utils/urlsParser.cjs +47 -0
- package/dist/application/utils/urlsParser.d.cts +23 -0
- package/dist/application/utils/urlsParser.d.ts +23 -0
- package/dist/application/utils/urlsParser.js +41 -0
- package/dist/application/utils/validation.cjs +7 -0
- package/dist/application/utils/validation.d.cts +5 -0
- package/dist/application/utils/validation.d.ts +5 -0
- package/dist/application/utils/validation.js +6 -0
- package/dist/atoms/amplitude/amplitudeTrackEventAtom.cjs +9 -0
- package/dist/atoms/amplitude/amplitudeTrackEventAtom.js +8 -0
- package/dist/atoms/app/index.cjs +27 -19
- package/dist/atoms/app/index.d.cts +10 -24
- package/dist/atoms/app/index.d.ts +10 -24
- package/dist/atoms/app/index.js +22 -15
- package/dist/atoms/app/variant.cjs +98 -0
- package/dist/atoms/app/variant.d.cts +10 -0
- package/dist/atoms/app/variant.d.ts +10 -0
- package/dist/atoms/app/variant.js +95 -0
- package/dist/atoms/atomStore/atomStore.cjs +36 -0
- package/dist/atoms/atomStore/atomStore.d.cts +24 -0
- package/dist/atoms/atomStore/atomStore.d.ts +24 -0
- package/dist/atoms/atomStore/atomStore.js +32 -0
- package/dist/atoms/atomStore/index.cjs +1 -1
- package/dist/atoms/atomStore/index.d.cts +2 -24
- package/dist/atoms/atomStore/index.d.ts +2 -24
- package/dist/atoms/atomStore/index.js +1 -1
- package/dist/atoms/chat/chatState.cjs +48 -0
- package/dist/atoms/chat/chatState.d.cts +54 -0
- package/dist/atoms/chat/chatState.d.ts +54 -0
- package/dist/atoms/chat/chatState.js +34 -0
- package/dist/atoms/chat/form.cjs +23 -0
- package/dist/atoms/chat/form.d.cts +10 -0
- package/dist/atoms/chat/form.d.ts +10 -0
- package/dist/atoms/chat/form.js +22 -0
- package/dist/atoms/chat/index.cjs +43 -38
- package/dist/atoms/chat/index.d.cts +13 -146
- package/dist/atoms/chat/index.d.ts +13 -146
- package/dist/atoms/chat/index.js +27 -23
- package/dist/atoms/chat/lastMessage.cjs +16 -0
- package/dist/atoms/chat/lastMessage.d.cts +8 -0
- package/dist/atoms/chat/lastMessage.d.ts +8 -0
- package/dist/atoms/chat/lastMessage.js +15 -0
- package/dist/atoms/chat/messageQueue.cjs +75 -0
- package/dist/atoms/chat/messageQueue.js +69 -0
- package/dist/atoms/chat/performanceMetrics.cjs +74 -0
- package/dist/atoms/chat/performanceMetrics.d.cts +50 -0
- package/dist/atoms/chat/performanceMetrics.d.ts +50 -0
- package/dist/atoms/chat/performanceMetrics.js +65 -0
- package/dist/atoms/chat/renderedWidgetRefs.cjs +32 -0
- package/dist/atoms/chat/renderedWidgetRefs.d.cts +21 -0
- package/dist/atoms/chat/renderedWidgetRefs.d.ts +21 -0
- package/dist/atoms/chat/renderedWidgetRefs.js +30 -0
- package/dist/atoms/chat/replies.cjs +45 -0
- package/dist/atoms/chat/replies.d.cts +14 -0
- package/dist/atoms/chat/replies.d.ts +14 -0
- package/dist/atoms/chat/replies.js +44 -0
- package/dist/atoms/chat/suggestions.cjs +36 -0
- package/dist/atoms/chat/suggestions.d.cts +10 -0
- package/dist/atoms/chat/suggestions.d.ts +10 -0
- package/dist/atoms/chat/suggestions.js +35 -0
- package/dist/atoms/envive/enviveConfig.cjs +74 -0
- package/dist/atoms/envive/enviveConfig.js +63 -0
- package/dist/atoms/globalSearch/globalSearch.cjs +18 -0
- package/dist/atoms/globalSearch/globalSearch.d.cts +24 -0
- package/dist/atoms/globalSearch/globalSearch.d.ts +24 -0
- package/dist/atoms/globalSearch/globalSearch.js +14 -0
- package/dist/atoms/globalSearch/index.cjs +1 -1
- package/dist/atoms/globalSearch/index.d.cts +2 -24
- package/dist/atoms/globalSearch/index.d.ts +2 -24
- package/dist/atoms/globalSearch/index.js +1 -1
- package/dist/atoms/org/customerService.cjs +17 -0
- package/dist/atoms/org/customerService.d.cts +23 -0
- package/dist/atoms/org/customerService.d.ts +23 -0
- package/dist/atoms/org/customerService.js +12 -0
- package/dist/atoms/org/graphqlConfig.cjs +18 -0
- package/dist/atoms/org/graphqlConfig.d.cts +19 -0
- package/dist/atoms/org/graphqlConfig.d.ts +19 -0
- package/dist/atoms/org/graphqlConfig.js +14 -0
- package/dist/atoms/org/index.cjs +9 -9
- package/dist/atoms/org/index.d.cts +5 -60
- package/dist/atoms/org/index.d.ts +5 -60
- package/dist/atoms/org/index.js +4 -4
- package/dist/atoms/org/newOrgConfigAtom.cjs +9 -0
- package/dist/atoms/org/newOrgConfigAtom.d.cts +10 -0
- package/dist/atoms/org/newOrgConfigAtom.d.ts +10 -0
- package/dist/atoms/org/newOrgConfigAtom.js +8 -0
- package/dist/atoms/org/orgAnalyticsConfig.cjs +18 -0
- package/dist/atoms/org/orgAnalyticsConfig.d.cts +11 -0
- package/dist/atoms/org/orgAnalyticsConfig.d.ts +11 -0
- package/dist/atoms/org/orgAnalyticsConfig.js +14 -0
- package/dist/atoms/search/chatSearch.cjs +208 -0
- package/dist/atoms/search/chatSearch.d.cts +115 -0
- package/dist/atoms/search/chatSearch.d.ts +115 -0
- package/dist/atoms/search/chatSearch.js +190 -0
- package/dist/atoms/search/index.cjs +15 -42
- package/dist/atoms/search/index.d.cts +2 -14
- package/dist/atoms/search/index.d.ts +2 -14
- package/dist/atoms/search/index.js +2 -29
- package/dist/atoms/search/productFilters.cjs +99 -0
- package/dist/atoms/search/productFilters.js +99 -0
- package/dist/atoms/search/productRetrievalAPI.cjs +50 -0
- package/dist/atoms/search/productRetrievalAPI.js +47 -0
- package/dist/atoms/search/productRetrievalAdapter.cjs +11 -0
- package/dist/atoms/search/productRetrievalAdapter.js +10 -0
- package/dist/atoms/search/productSorter.cjs +16 -0
- package/dist/atoms/search/productSorter.js +16 -0
- package/dist/atoms/search/searchAPI.cjs +135 -0
- package/dist/atoms/search/searchAPI.d.cts +76 -0
- package/dist/atoms/search/searchAPI.d.ts +76 -0
- package/dist/atoms/search/searchAPI.js +122 -0
- package/dist/atoms/search/searchServiceAdapter.cjs +19 -0
- package/dist/atoms/search/searchServiceAdapter.js +16 -0
- package/dist/atoms/search/types.cjs +32 -4
- package/dist/atoms/search/types.d.cts +60 -4
- package/dist/atoms/search/types.d.ts +60 -4
- package/dist/atoms/search/types.js +29 -2
- package/dist/atoms/search/utils.cjs +23 -2
- package/dist/atoms/search/utils.js +22 -2
- package/dist/config/index.cjs +74 -70
- package/dist/config/index.d.cts +8 -4
- package/dist/config/index.d.ts +8 -4
- package/dist/config/index.js +8 -4
- package/dist/config/locators/components/chat/index.cjs +44 -21
- package/dist/config/locators/components/chat/index.d.cts +24 -2
- package/dist/config/locators/components/chat/index.d.ts +24 -2
- package/dist/config/locators/components/chat/index.js +24 -2
- package/dist/config/locators/components/chat/variants/index.cjs +1 -1
- package/dist/config/locators/components/chat/variants/index.js +1 -1
- package/dist/config/locators/components/common/buttons.cjs +17 -0
- package/dist/config/locators/components/common/buttons.d.cts +10 -0
- package/dist/config/locators/components/common/buttons.d.ts +10 -0
- package/dist/config/locators/components/common/buttons.js +11 -0
- package/dist/config/locators/components/common/cards.cjs +39 -0
- package/dist/config/locators/components/common/cards.d.cts +21 -0
- package/dist/config/locators/components/common/cards.d.ts +21 -0
- package/dist/config/locators/components/common/cards.js +22 -0
- package/dist/config/locators/components/common/index.cjs +29 -26
- package/dist/config/locators/components/common/index.d.cts +4 -1
- package/dist/config/locators/components/common/index.d.ts +4 -1
- package/dist/config/locators/components/common/index.js +4 -1
- package/dist/config/locators/components/common/links.cjs +7 -0
- package/dist/config/locators/components/common/links.d.cts +5 -0
- package/dist/config/locators/components/common/links.d.ts +5 -0
- package/dist/config/locators/components/common/links.js +6 -0
- package/dist/config/locators/components/common/tables.cjs +7 -0
- package/dist/config/locators/components/common/tables.d.cts +5 -0
- package/dist/config/locators/components/common/tables.d.ts +5 -0
- package/dist/config/locators/components/common/tables.js +6 -0
- package/dist/config/locators/components/floating-button.cjs +9 -0
- package/dist/config/locators/components/floating-button.d.cts +6 -0
- package/dist/config/locators/components/floating-button.d.ts +6 -0
- package/dist/config/locators/components/floating-button.js +7 -0
- package/dist/config/locators/components/index.cjs +5 -4
- package/dist/config/locators/components/index.d.cts +2 -1
- package/dist/config/locators/components/index.d.ts +2 -1
- package/dist/config/locators/components/index.js +2 -1
- package/dist/config/locators/components/shadow-dom.cjs +7 -0
- package/dist/config/locators/components/shadow-dom.d.cts +5 -0
- package/dist/config/locators/components/shadow-dom.d.ts +5 -0
- package/dist/config/locators/components/shadow-dom.js +6 -0
- package/dist/config/locators/embedded.cjs +41 -0
- package/dist/{index-COXkY78t.d.cts → config/locators/embedded.d.cts} +1 -1
- package/dist/{index-BKvFVPUX.d.ts → config/locators/embedded.d.ts} +1 -1
- package/dist/{locators-BMQGmGLq.js → config/locators/embedded.js} +1 -1
- package/dist/config/locators/index.cjs +74 -70
- package/dist/config/locators/index.d.cts +8 -4
- package/dist/config/locators/index.d.ts +8 -4
- package/dist/config/locators/index.js +8 -4
- package/dist/contexts/amplitudeContext/amplitudeContext.cjs +275 -0
- package/dist/contexts/amplitudeContext/amplitudeContext.d.cts +52 -0
- package/dist/contexts/amplitudeContext/amplitudeContext.d.ts +52 -0
- package/dist/contexts/amplitudeContext/amplitudeContext.js +271 -0
- package/dist/contexts/amplitudeContext/index.cjs +1 -20
- package/dist/contexts/amplitudeContext/index.d.cts +1 -1
- package/dist/contexts/amplitudeContext/index.d.ts +1 -1
- package/dist/contexts/amplitudeContext/index.js +1 -20
- package/dist/contexts/cdnContext/cdnContext.cjs +41 -0
- package/dist/contexts/cdnContext/cdnContext.d.cts +15 -0
- package/dist/contexts/cdnContext/cdnContext.d.ts +15 -0
- package/dist/contexts/cdnContext/cdnContext.js +38 -0
- package/dist/contexts/cdnContext/index.cjs +1 -4
- package/dist/contexts/cdnContext/index.d.cts +2 -15
- package/dist/contexts/cdnContext/index.d.ts +2 -15
- package/dist/contexts/cdnContext/index.js +1 -4
- package/dist/contexts/chatContext/chatContext.cjs +306 -0
- package/dist/contexts/chatContext/chatContext.d.cts +15 -0
- package/dist/contexts/chatContext/chatContext.d.ts +15 -0
- package/dist/contexts/chatContext/chatContext.js +304 -0
- package/dist/contexts/chatContext/index.cjs +3 -330
- package/dist/contexts/chatContext/index.d.cts +2 -15
- package/dist/contexts/chatContext/index.d.ts +2 -15
- package/dist/contexts/chatContext/index.js +2 -323
- package/dist/contexts/enviveConfigContext/enviveConfigContext.cjs +48 -0
- package/dist/contexts/enviveConfigContext/enviveConfigContext.d.cts +29 -0
- package/dist/contexts/enviveConfigContext/enviveConfigContext.d.ts +29 -0
- package/dist/contexts/enviveConfigContext/enviveConfigContext.js +45 -0
- package/dist/contexts/enviveConfigContext/index.cjs +1 -4
- package/dist/contexts/enviveConfigContext/index.d.cts +2 -30
- package/dist/contexts/enviveConfigContext/index.d.ts +2 -30
- package/dist/contexts/enviveConfigContext/index.js +1 -4
- package/dist/contexts/enviveCssContext/enviveCssContext.cjs +49 -0
- package/dist/contexts/enviveCssContext/enviveCssContext.d.cts +10 -0
- package/dist/contexts/enviveCssContext/enviveCssContext.d.ts +10 -0
- package/dist/contexts/enviveCssContext/enviveCssContext.js +47 -0
- package/dist/contexts/enviveCssContext/index.cjs +2 -65
- package/dist/contexts/enviveCssContext/index.d.cts +2 -10
- package/dist/contexts/enviveCssContext/index.d.ts +2 -10
- package/dist/contexts/enviveCssContext/index.js +2 -62
- package/dist/contexts/featureFlagContext/featureFlagContext.cjs +105 -0
- package/dist/contexts/featureFlagContext/featureFlagContext.d.cts +19 -0
- package/dist/contexts/featureFlagContext/featureFlagContext.d.ts +19 -0
- package/dist/contexts/featureFlagContext/featureFlagContext.js +102 -0
- package/dist/contexts/featureFlagContext/index.cjs +3 -106
- package/dist/contexts/featureFlagContext/index.d.cts +2 -20
- package/dist/contexts/featureFlagContext/index.d.ts +2 -20
- package/dist/contexts/featureFlagContext/index.js +2 -102
- package/dist/contexts/featureFlagServiceContext/featureFlagServiceContext.cjs +46 -0
- package/dist/contexts/featureFlagServiceContext/featureFlagServiceContext.d.cts +24 -0
- package/dist/contexts/featureFlagServiceContext/featureFlagServiceContext.d.ts +24 -0
- package/dist/contexts/featureFlagServiceContext/featureFlagServiceContext.js +42 -0
- package/dist/contexts/featureFlagServiceContext/index.cjs +1 -3
- package/dist/contexts/featureFlagServiceContext/index.d.cts +1 -4
- package/dist/contexts/featureFlagServiceContext/index.d.ts +1 -4
- package/dist/contexts/featureFlagServiceContext/index.js +1 -3
- package/dist/contexts/graphqlContext/graphqlContext.cjs +99 -0
- package/dist/contexts/graphqlContext/graphqlContext.d.cts +29 -0
- package/dist/contexts/graphqlContext/graphqlContext.d.ts +29 -0
- package/dist/contexts/graphqlContext/graphqlContext.js +96 -0
- package/dist/contexts/graphqlContext/index.cjs +1 -13
- package/dist/contexts/graphqlContext/index.d.cts +1 -14
- package/dist/contexts/graphqlContext/index.d.ts +1 -14
- package/dist/contexts/graphqlContext/index.js +1 -13
- package/dist/contexts/localStorageContext/index.cjs +1 -2
- package/dist/contexts/localStorageContext/index.d.cts +2 -30
- package/dist/contexts/localStorageContext/index.d.ts +2 -30
- package/dist/contexts/localStorageContext/index.js +1 -2
- package/dist/contexts/localStorageContext/localStorageContext.cjs +99 -0
- package/dist/contexts/localStorageContext/localStorageContext.d.cts +25 -0
- package/dist/contexts/localStorageContext/localStorageContext.d.ts +25 -0
- package/dist/contexts/localStorageContext/localStorageContext.js +95 -0
- package/dist/contexts/newOrgConfigContext/index.cjs +1 -17
- package/dist/contexts/newOrgConfigContext/index.d.cts +1 -15
- package/dist/contexts/newOrgConfigContext/index.d.ts +1 -15
- package/dist/contexts/newOrgConfigContext/index.js +1 -17
- package/dist/contexts/newOrgConfigContext/newOrgConfigContext.cjs +56 -0
- package/dist/contexts/newOrgConfigContext/newOrgConfigContext.d.cts +16 -0
- package/dist/contexts/newOrgConfigContext/newOrgConfigContext.d.ts +16 -0
- package/dist/contexts/newOrgConfigContext/newOrgConfigContext.js +53 -0
- package/dist/contexts/searchContext/index.cjs +1 -21
- package/dist/contexts/searchContext/index.d.cts +2 -16
- package/dist/contexts/searchContext/index.d.ts +2 -16
- package/dist/contexts/searchContext/index.js +1 -21
- package/dist/contexts/searchContext/searchContext.cjs +132 -0
- package/dist/contexts/searchContext/searchContext.d.cts +15 -0
- package/dist/contexts/searchContext/searchContext.d.ts +15 -0
- package/dist/contexts/searchContext/searchContext.js +129 -0
- package/dist/contexts/sessionStorageContext/index.cjs +1 -2
- package/dist/contexts/sessionStorageContext/index.d.cts +2 -15
- package/dist/contexts/sessionStorageContext/index.d.ts +2 -15
- package/dist/contexts/sessionStorageContext/index.js +1 -2
- package/dist/contexts/sessionStorageContext/sessionStorageContext.cjs +55 -0
- package/dist/contexts/sessionStorageContext/sessionStorageContext.d.cts +15 -0
- package/dist/contexts/sessionStorageContext/sessionStorageContext.d.ts +15 -0
- package/dist/contexts/sessionStorageContext/sessionStorageContext.js +52 -0
- package/dist/contexts/shopifyUrlContext/index.cjs +1 -2
- package/dist/contexts/shopifyUrlContext/index.d.cts +2 -20
- package/dist/contexts/shopifyUrlContext/index.d.ts +2 -20
- package/dist/contexts/shopifyUrlContext/index.js +1 -2
- package/dist/contexts/shopifyUrlContext/shopifyUrlContext.cjs +64 -0
- package/dist/contexts/shopifyUrlContext/shopifyUrlContext.d.cts +18 -0
- package/dist/contexts/shopifyUrlContext/shopifyUrlContext.d.ts +18 -0
- package/dist/contexts/shopifyUrlContext/shopifyUrlContext.js +61 -0
- package/dist/contexts/systemSettingsContext/index.cjs +1 -4
- package/dist/contexts/systemSettingsContext/index.d.cts +2 -38
- package/dist/contexts/systemSettingsContext/index.d.ts +2 -38
- package/dist/contexts/systemSettingsContext/index.js +1 -4
- package/dist/contexts/systemSettingsContext/systemSettingsContext.cjs +42 -0
- package/dist/contexts/systemSettingsContext/systemSettingsContext.d.cts +27 -0
- package/dist/contexts/systemSettingsContext/systemSettingsContext.d.ts +27 -0
- package/dist/contexts/systemSettingsContext/systemSettingsContext.js +39 -0
- package/dist/contexts/types.cjs +56 -6
- package/dist/contexts/types.d.cts +696 -4
- package/dist/contexts/types.d.ts +696 -4
- package/dist/contexts/types.js +52 -2
- package/dist/contexts/userIdentityContext/index.cjs +1 -25
- package/dist/contexts/userIdentityContext/index.d.cts +1 -1
- package/dist/contexts/userIdentityContext/index.d.ts +1 -1
- package/dist/contexts/userIdentityContext/index.js +1 -25
- package/dist/contexts/userIdentityContext/userIdentityContext.cjs +131 -0
- package/dist/contexts/userIdentityContext/userIdentityContext.d.cts +20 -0
- package/dist/contexts/userIdentityContext/userIdentityContext.d.ts +20 -0
- package/dist/contexts/userIdentityContext/userIdentityContext.js +127 -0
- package/dist/events/event-types.cjs +18 -0
- package/dist/events/event-types.d.cts +15 -0
- package/dist/events/event-types.d.ts +15 -0
- package/dist/events/event-types.js +17 -0
- package/dist/events/index.cjs +65 -3
- package/dist/events/index.d.cts +4 -14
- package/dist/events/index.d.ts +4 -14
- package/dist/events/index.js +64 -2
- package/dist/hooks/AmplitudeOperations/index.cjs +1 -21
- package/dist/hooks/AmplitudeOperations/index.d.cts +2 -12
- package/dist/hooks/AmplitudeOperations/index.d.ts +2 -12
- package/dist/hooks/AmplitudeOperations/index.js +1 -21
- package/dist/hooks/AmplitudeOperations/useAmplitudeOperations.cjs +35 -0
- package/dist/hooks/AmplitudeOperations/useAmplitudeOperations.d.cts +12 -0
- package/dist/hooks/AmplitudeOperations/useAmplitudeOperations.d.ts +12 -0
- package/dist/hooks/AmplitudeOperations/useAmplitudeOperations.js +34 -0
- package/dist/hooks/AppDetails/index.cjs +1 -17
- package/dist/hooks/AppDetails/index.d.cts +2 -28
- package/dist/hooks/AppDetails/index.d.ts +2 -28
- package/dist/hooks/AppDetails/index.js +1 -17
- package/dist/hooks/AppDetails/useAppDetails.cjs +25 -0
- package/dist/hooks/AppDetails/useAppDetails.d.cts +17 -0
- package/dist/hooks/AppDetails/useAppDetails.d.ts +17 -0
- package/dist/hooks/AppDetails/useAppDetails.js +24 -0
- package/dist/hooks/BlockBackButton/index.cjs +2 -28
- package/dist/hooks/BlockBackButton/index.d.cts +2 -5
- package/dist/hooks/BlockBackButton/index.d.ts +2 -5
- package/dist/hooks/BlockBackButton/index.js +2 -26
- package/dist/hooks/BlockBackButton/useBlockBackButton.cjs +28 -0
- package/dist/hooks/BlockBackButton/useBlockBackButton.d.cts +5 -0
- package/dist/hooks/BlockBackButton/useBlockBackButton.d.ts +5 -0
- package/dist/hooks/BlockBackButton/useBlockBackButton.js +27 -0
- package/dist/hooks/CdnOperations/index.cjs +4 -23
- package/dist/hooks/CdnOperations/index.d.cts +2 -7
- package/dist/hooks/CdnOperations/index.d.ts +2 -7
- package/dist/hooks/CdnOperations/index.js +2 -21
- package/dist/hooks/CdnOperations/useCdnOperations.cjs +22 -0
- package/dist/hooks/CdnOperations/useCdnOperations.d.cts +7 -0
- package/dist/hooks/CdnOperations/useCdnOperations.d.ts +7 -0
- package/dist/hooks/CdnOperations/useCdnOperations.js +20 -0
- package/dist/hooks/ChatToggle/index.cjs +2 -64
- package/dist/hooks/ChatToggle/index.d.cts +2 -12
- package/dist/hooks/ChatToggle/index.d.ts +2 -12
- package/dist/hooks/ChatToggle/index.js +2 -62
- package/dist/hooks/ChatToggle/useChatToggle.cjs +45 -0
- package/dist/hooks/ChatToggle/useChatToggle.d.cts +12 -0
- package/dist/hooks/ChatToggle/useChatToggle.d.ts +12 -0
- package/dist/hooks/ChatToggle/useChatToggle.js +44 -0
- package/dist/hooks/ChatToggleAnalytics/index.cjs +2 -38
- package/dist/hooks/ChatToggleAnalytics/index.d.cts +2 -9
- package/dist/hooks/ChatToggleAnalytics/index.d.ts +2 -9
- package/dist/hooks/ChatToggleAnalytics/index.js +2 -36
- package/dist/hooks/ChatToggleAnalytics/useChatToggleAnalytics.cjs +19 -0
- package/dist/hooks/ChatToggleAnalytics/useChatToggleAnalytics.d.cts +9 -0
- package/dist/hooks/ChatToggleAnalytics/useChatToggleAnalytics.d.ts +9 -0
- package/dist/hooks/ChatToggleAnalytics/useChatToggleAnalytics.js +18 -0
- package/dist/hooks/CustomerSupportHandoff/index.cjs +2 -35
- package/dist/hooks/CustomerSupportHandoff/index.d.cts +2 -16
- package/dist/hooks/CustomerSupportHandoff/index.d.ts +2 -16
- package/dist/hooks/CustomerSupportHandoff/index.js +2 -33
- package/dist/hooks/CustomerSupportHandoff/useCustomerSupportHandoff.cjs +35 -0
- package/dist/hooks/CustomerSupportHandoff/useCustomerSupportHandoff.d.cts +16 -0
- package/dist/hooks/CustomerSupportHandoff/useCustomerSupportHandoff.d.ts +16 -0
- package/dist/hooks/CustomerSupportHandoff/useCustomerSupportHandoff.js +34 -0
- package/dist/hooks/Debounce/index.cjs +2 -20
- package/dist/hooks/Debounce/index.d.cts +2 -5
- package/dist/hooks/Debounce/index.d.ts +2 -5
- package/dist/hooks/Debounce/index.js +2 -18
- package/dist/hooks/Debounce/useDebounce.cjs +20 -0
- package/dist/hooks/Debounce/useDebounce.d.cts +5 -0
- package/dist/hooks/Debounce/useDebounce.d.ts +5 -0
- package/dist/hooks/Debounce/useDebounce.js +19 -0
- package/dist/hooks/ElementObserver/index.cjs +2 -178
- package/dist/hooks/ElementObserver/index.d.cts +2 -29
- package/dist/hooks/ElementObserver/index.d.ts +2 -29
- package/dist/hooks/ElementObserver/index.js +2 -176
- package/dist/hooks/ElementObserver/useElementObserver.cjs +178 -0
- package/dist/hooks/ElementObserver/useElementObserver.d.cts +30 -0
- package/dist/hooks/ElementObserver/useElementObserver.d.ts +30 -0
- package/dist/hooks/ElementObserver/useElementObserver.js +177 -0
- package/dist/hooks/GrabAndScroll/index.cjs +2 -98
- package/dist/hooks/GrabAndScroll/index.d.cts +2 -14
- package/dist/hooks/GrabAndScroll/index.d.ts +2 -14
- package/dist/hooks/GrabAndScroll/index.js +2 -96
- package/dist/hooks/GrabAndScroll/useGrabAndScroll.cjs +96 -0
- package/dist/hooks/GrabAndScroll/useGrabAndScroll.d.cts +14 -0
- package/dist/hooks/GrabAndScroll/useGrabAndScroll.d.ts +14 -0
- package/dist/hooks/GrabAndScroll/useGrabAndScroll.js +95 -0
- package/dist/hooks/GraphQLConfig/index.cjs +1 -14
- package/dist/hooks/GraphQLConfig/index.d.cts +2 -29
- package/dist/hooks/GraphQLConfig/index.d.ts +2 -29
- package/dist/hooks/GraphQLConfig/index.js +1 -14
- package/dist/hooks/GraphQLConfig/useGraphQLConfig.cjs +63 -0
- package/dist/hooks/GraphQLConfig/useGraphQLConfig.d.cts +17 -0
- package/dist/hooks/GraphQLConfig/useGraphQLConfig.d.ts +17 -0
- package/dist/hooks/GraphQLConfig/useGraphQLConfig.js +61 -0
- package/dist/hooks/IdentifyUser/index.cjs +2 -60
- package/dist/hooks/IdentifyUser/index.d.cts +2 -10
- package/dist/hooks/IdentifyUser/index.d.ts +2 -10
- package/dist/hooks/IdentifyUser/index.js +2 -58
- package/dist/hooks/IdentifyUser/useIdentifyUser.cjs +35 -0
- package/dist/hooks/IdentifyUser/useIdentifyUser.d.cts +10 -0
- package/dist/hooks/IdentifyUser/useIdentifyUser.d.ts +10 -0
- package/dist/hooks/IdentifyUser/useIdentifyUser.js +34 -0
- package/dist/hooks/ImageResolver/index.cjs +2 -54
- package/dist/hooks/ImageResolver/index.d.cts +2 -7
- package/dist/hooks/ImageResolver/index.d.ts +2 -7
- package/dist/hooks/ImageResolver/index.js +2 -52
- package/dist/hooks/ImageResolver/useImageResolver.cjs +45 -0
- package/dist/hooks/ImageResolver/useImageResolver.d.cts +7 -0
- package/dist/hooks/ImageResolver/useImageResolver.d.ts +7 -0
- package/dist/hooks/ImageResolver/useImageResolver.js +44 -0
- package/dist/hooks/Intersection/index.cjs +1 -1
- package/dist/hooks/Intersection/index.d.cts +2 -7
- package/dist/hooks/Intersection/index.d.ts +2 -7
- package/dist/hooks/Intersection/index.js +1 -1
- package/dist/hooks/Intersection/useIntersection.cjs +22 -0
- package/dist/hooks/Intersection/useIntersection.d.cts +7 -0
- package/dist/hooks/Intersection/useIntersection.d.ts +7 -0
- package/dist/hooks/Intersection/useIntersection.js +21 -0
- package/dist/hooks/IsSmallScreen/index.cjs +2 -21
- package/dist/hooks/IsSmallScreen/index.d.cts +2 -5
- package/dist/hooks/IsSmallScreen/index.d.ts +2 -5
- package/dist/hooks/IsSmallScreen/index.js +2 -19
- package/dist/hooks/IsSmallScreen/useIsSmallScreen.cjs +21 -0
- package/dist/hooks/IsSmallScreen/useIsSmallScreen.d.cts +5 -0
- package/dist/hooks/IsSmallScreen/useIsSmallScreen.d.ts +5 -0
- package/dist/hooks/IsSmallScreen/useIsSmallScreen.js +20 -0
- package/dist/hooks/LocalStorageOperations/index.cjs +5 -78
- package/dist/hooks/LocalStorageOperations/index.d.cts +2 -17
- package/dist/hooks/LocalStorageOperations/index.d.ts +2 -17
- package/dist/hooks/LocalStorageOperations/index.js +2 -73
- package/dist/hooks/LocalStorageOperations/useLocalStorageOperations.cjs +77 -0
- package/dist/hooks/LocalStorageOperations/useLocalStorageOperations.d.cts +17 -0
- package/dist/hooks/LocalStorageOperations/useLocalStorageOperations.d.ts +17 -0
- package/dist/hooks/LocalStorageOperations/useLocalStorageOperations.js +73 -0
- package/dist/hooks/MessageFilter/index.cjs +2 -53
- package/dist/hooks/MessageFilter/index.d.cts +2 -31
- package/dist/hooks/MessageFilter/index.d.ts +2 -31
- package/dist/hooks/MessageFilter/index.js +2 -53
- package/dist/hooks/MessageFilter/useMessageFilter.cjs +43 -0
- package/dist/hooks/MessageFilter/useMessageFilter.d.cts +20 -0
- package/dist/hooks/MessageFilter/useMessageFilter.d.ts +20 -0
- package/dist/hooks/MessageFilter/useMessageFilter.js +43 -0
- package/dist/hooks/MessageScrollObserver/index.cjs +2 -35
- package/dist/hooks/MessageScrollObserver/index.d.cts +2 -5
- package/dist/hooks/MessageScrollObserver/index.d.ts +2 -5
- package/dist/hooks/MessageScrollObserver/index.js +2 -33
- package/dist/hooks/MessageScrollObserver/useMessageScrollObserver.cjs +33 -0
- package/dist/hooks/MessageScrollObserver/useMessageScrollObserver.d.cts +5 -0
- package/dist/hooks/MessageScrollObserver/useMessageScrollObserver.d.ts +5 -0
- package/dist/hooks/MessageScrollObserver/useMessageScrollObserver.js +32 -0
- package/dist/hooks/NewOrgConfig/index.cjs +2 -19
- package/dist/hooks/NewOrgConfig/index.d.cts +2 -21
- package/dist/hooks/NewOrgConfig/index.d.ts +2 -21
- package/dist/hooks/NewOrgConfig/index.js +1 -18
- package/dist/hooks/NewOrgConfig/useNewOrgConfig.cjs +10 -0
- package/dist/hooks/NewOrgConfig/useNewOrgConfig.d.cts +7 -0
- package/dist/hooks/NewOrgConfig/useNewOrgConfig.d.ts +7 -0
- package/dist/hooks/NewOrgConfig/useNewOrgConfig.js +10 -0
- package/dist/hooks/Search/index.cjs +2 -503
- package/dist/hooks/Search/index.d.cts +2 -72
- package/dist/hooks/Search/index.d.ts +2 -72
- package/dist/hooks/Search/index.js +2 -499
- package/dist/hooks/Search/useRecommendedProducts.cjs +41 -0
- package/dist/hooks/Search/useRecommendedProducts.js +40 -0
- package/dist/hooks/Search/useSearch.cjs +232 -0
- package/dist/hooks/Search/useSearch.d.cts +62 -0
- package/dist/hooks/Search/useSearch.d.ts +62 -0
- package/dist/hooks/Search/useSearch.js +231 -0
- package/dist/hooks/Search/useSearchInput.cjs +173 -0
- package/dist/hooks/Search/useSearchInput.js +171 -0
- package/dist/hooks/SearchOperations/index.cjs +3 -101
- package/dist/hooks/SearchOperations/index.d.cts +2 -22
- package/dist/hooks/SearchOperations/index.d.ts +2 -22
- package/dist/hooks/SearchOperations/index.js +2 -98
- package/dist/hooks/SearchOperations/useSearchOperations.cjs +77 -0
- package/dist/hooks/SearchOperations/useSearchOperations.d.cts +21 -0
- package/dist/hooks/SearchOperations/useSearchOperations.d.ts +21 -0
- package/dist/hooks/SearchOperations/useSearchOperations.js +75 -0
- package/dist/hooks/SessionStorageOperations/index.cjs +2 -29
- package/dist/hooks/SessionStorageOperations/index.d.cts +2 -8
- package/dist/hooks/SessionStorageOperations/index.d.ts +2 -8
- package/dist/hooks/SessionStorageOperations/index.js +2 -27
- package/dist/hooks/SessionStorageOperations/useSessionStorageOperations.cjs +28 -0
- package/dist/hooks/SessionStorageOperations/useSessionStorageOperations.d.cts +8 -0
- package/dist/hooks/SessionStorageOperations/useSessionStorageOperations.d.ts +8 -0
- package/dist/hooks/SessionStorageOperations/useSessionStorageOperations.js +27 -0
- package/dist/hooks/ShopifyUrlOperations/index.cjs +4 -52
- package/dist/hooks/ShopifyUrlOperations/index.d.cts +2 -23
- package/dist/hooks/ShopifyUrlOperations/index.d.ts +2 -23
- package/dist/hooks/ShopifyUrlOperations/index.js +2 -48
- package/dist/hooks/ShopifyUrlOperations/useShopifyUrlOperations.cjs +51 -0
- package/dist/hooks/ShopifyUrlOperations/useShopifyUrlOperations.d.cts +21 -0
- package/dist/hooks/ShopifyUrlOperations/useShopifyUrlOperations.d.ts +21 -0
- package/dist/hooks/ShopifyUrlOperations/useShopifyUrlOperations.js +48 -0
- package/dist/hooks/SnapCalculator/index.cjs +2 -28
- package/dist/hooks/SnapCalculator/index.d.cts +2 -12
- package/dist/hooks/SnapCalculator/index.d.ts +2 -12
- package/dist/hooks/SnapCalculator/index.js +2 -26
- package/dist/hooks/SnapCalculator/useSnapCalculator.cjs +28 -0
- package/dist/hooks/SnapCalculator/useSnapCalculator.d.cts +12 -0
- package/dist/hooks/SnapCalculator/useSnapCalculator.d.ts +12 -0
- package/dist/hooks/SnapCalculator/useSnapCalculator.js +27 -0
- package/dist/hooks/SystemSettingsContext/index.cjs +2 -6
- package/dist/hooks/SystemSettingsContext/index.d.cts +2 -24
- package/dist/hooks/SystemSettingsContext/index.d.ts +2 -24
- package/dist/hooks/SystemSettingsContext/index.js +1 -5
- package/dist/hooks/SystemSettingsContext/useSystemSettingsContext.cjs +15 -0
- package/dist/hooks/SystemSettingsContext/useSystemSettingsContext.d.cts +13 -0
- package/dist/hooks/SystemSettingsContext/useSystemSettingsContext.d.ts +13 -0
- package/dist/hooks/SystemSettingsContext/useSystemSettingsContext.js +14 -0
- package/dist/hooks/TrackComponentVisibleEvent/index.cjs +2 -22
- package/dist/hooks/TrackComponentVisibleEvent/index.d.cts +2 -18
- package/dist/hooks/TrackComponentVisibleEvent/index.d.ts +2 -18
- package/dist/hooks/TrackComponentVisibleEvent/index.js +1 -21
- package/dist/hooks/TrackComponentVisibleEvent/useTrackComponentVisibleEvent.cjs +53 -0
- package/dist/hooks/TrackComponentVisibleEvent/useTrackComponentVisibleEvent.d.cts +18 -0
- package/dist/hooks/TrackComponentVisibleEvent/useTrackComponentVisibleEvent.d.ts +18 -0
- package/dist/hooks/TrackComponentVisibleEvent/useTrackComponentVisibleEvent.js +52 -0
- package/dist/hooks/UpdateAnalyticsProps/index.cjs +2 -62
- package/dist/hooks/UpdateAnalyticsProps/index.d.cts +2 -9
- package/dist/hooks/UpdateAnalyticsProps/index.d.ts +2 -9
- package/dist/hooks/UpdateAnalyticsProps/index.js +2 -59
- package/dist/hooks/UpdateAnalyticsProps/useUpdateAnalyticsProps.cjs +44 -0
- package/dist/hooks/UpdateAnalyticsProps/useUpdateAnalyticsProps.d.cts +9 -0
- package/dist/hooks/UpdateAnalyticsProps/useUpdateAnalyticsProps.d.ts +9 -0
- package/dist/hooks/UpdateAnalyticsProps/useUpdateAnalyticsProps.js +43 -0
- package/dist/hooks/utils.cjs +97 -7
- package/dist/hooks/utils.d.cts +22 -14
- package/dist/hooks/utils.d.ts +22 -14
- package/dist/hooks/utils.js +91 -2
- package/dist/interceptors/index.cjs +1 -2
- package/dist/interceptors/index.d.cts +3 -21
- package/dist/interceptors/index.d.ts +3 -21
- package/dist/interceptors/index.js +1 -2
- package/dist/interceptors/types.cjs +0 -1
- package/dist/interceptors/types.d.cts +10 -14
- package/dist/interceptors/types.d.ts +10 -14
- package/dist/interceptors/types.js +0 -2
- package/dist/interceptors/useMessageInterceptor.cjs +26 -0
- package/dist/interceptors/useMessageInterceptor.d.cts +9 -0
- package/dist/interceptors/useMessageInterceptor.d.ts +9 -0
- package/dist/interceptors/useMessageInterceptor.js +25 -0
- package/dist/merchants/domInsertion.cjs +17 -0
- package/dist/merchants/domInsertion.d.cts +14 -0
- package/dist/merchants/domInsertion.d.ts +14 -0
- package/dist/merchants/domInsertion.js +16 -0
- package/dist/merchants/gridInsertion.cjs +24 -0
- package/dist/merchants/gridInsertion.d.cts +21 -0
- package/dist/merchants/gridInsertion.d.ts +21 -0
- package/dist/merchants/gridInsertion.js +23 -0
- package/dist/types/OrgInfo.d.cts +13 -0
- package/dist/types/OrgInfo.d.ts +13 -0
- package/dist/types/config-versions.cjs +8 -0
- package/dist/types/config-versions.js +8 -0
- package/dist/types/customerService.d.cts +22 -0
- package/dist/types/customerService.d.ts +24 -0
- package/dist/types/custservice-types.cjs +25 -0
- package/dist/types/custservice-types.d.cts +29 -0
- package/dist/types/custservice-types.d.ts +29 -0
- package/dist/types/custservice-types.js +23 -0
- package/dist/types/exceptions/sessionExceptions.cjs +12 -0
- package/dist/types/exceptions/sessionExceptions.js +11 -0
- package/dist/types/exceptions/unsupportedProductExceptions.cjs +12 -0
- package/dist/types/exceptions/unsupportedProductExceptions.js +11 -0
- package/dist/types/index.cjs +5 -33
- package/dist/types/index.d.cts +6 -3
- package/dist/types/index.d.ts +6 -3
- package/dist/types/index.js +3 -30
- package/dist/types/search-filter-types.d.cts +102 -0
- package/dist/types/search-filter-types.d.ts +102 -0
- package/dist/types/suggestionBarV2-types.cjs +11 -0
- package/dist/types/suggestionBarV2-types.d.cts +8 -0
- package/dist/types/suggestionBarV2-types.d.ts +8 -0
- package/dist/types/suggestionBarV2-types.js +10 -0
- package/dist/types/test-types.d.cts +7 -0
- package/dist/types/test-types.d.ts +7 -0
- package/package.json +4 -5
- package/src/application/commerce-api.ts +123 -176
- package/src/application/logging/logger.ts +2 -10
- package/src/application/models/api/orgConfigResults.ts +4 -4
- package/src/application/models/cachedValue.ts +1 -3
- package/src/application/models/clientDetails.ts +1 -3
- package/src/application/models/colorsConfig.ts +18 -18
- package/src/application/models/frontendConfig.ts +2 -2
- package/src/application/models/googleAnalyticsEvents.ts +1 -3
- package/src/application/models/graphql/index.ts +1 -1
- package/src/application/models/graphql/queries/getMerchantColorsQuery.ts +1 -1
- package/src/application/models/graphql/queries/getMerchantFrontendConfigQuery.ts +1 -1
- package/src/application/models/guards/api/isApiOrgConfigResults.ts +3 -3
- package/src/application/models/guards/api/isApiOrganizationConfig.ts +1 -4
- package/src/application/models/guards/api/isApiProductResponseAttributes.ts +1 -3
- package/src/application/models/guards/api/isApiReviewRichInformation.ts +2 -2
- package/src/application/models/guards/api/isApiSearchEventAttributes.ts +1 -1
- package/src/application/models/guards/graphQL/isGraphQLColorsConfig.ts +1 -1
- package/src/application/models/guards/isSpanxTakeAQuizCtaParameter.ts +1 -1
- package/src/application/models/index.ts +87 -87
- package/src/application/models/spanxTakeAQuizCtaParameter.ts +1 -1
- package/src/application/models/spiffyWidgets.ts +0 -1
- package/src/application/models/utils/snakeToCamelTransformer.ts +10 -10
- package/src/application/models/validators/validateGraphQLColorsConfig.ts +3 -5
- package/src/application/models/validators/validateOrgConfigResults.ts +3 -3
- package/src/application/models/validators/validateResponse.ts +1 -1
- package/src/application/utils/analyticsUtils.ts +17 -33
- package/src/application/utils/cdnUtils.ts +4 -7
- package/src/application/utils/domObserver.ts +8 -8
- package/src/application/utils/elementObserver.ts +3 -3
- package/src/application/utils/imageFilter.ts +9 -6
- package/src/application/utils/index.ts +21 -21
- package/src/application/utils/merchantUtils.ts +8 -8
- package/src/application/utils/messageFromSuggestionEvent.ts +1 -1
- package/src/application/utils/mutationHelper.ts +3 -3
- package/src/application/utils/nextMessageRequestToApiRequest.ts +1 -1
- package/src/application/utils/stringUtils.ts +0 -2
- package/src/application/utils/urlsParser.ts +1 -1
- package/src/atoms/amplitude/amplitudeTrackEventAtom.ts +5 -5
- package/src/atoms/app/index.ts +21 -26
- package/src/atoms/app/variant.ts +8 -8
- package/src/atoms/atomStore/index.ts +1 -1
- package/src/atoms/chat/chatState.ts +9 -19
- package/src/atoms/chat/index.ts +1 -1
- package/src/atoms/chat/lastMessage.ts +1 -1
- package/src/atoms/chat/messageQueue.ts +27 -52
- package/src/atoms/chat/performanceMetrics.ts +38 -51
- package/src/atoms/chat/renderedWidgetRefs.ts +3 -3
- package/src/atoms/chat/replies.ts +40 -43
- package/src/atoms/envive/enviveConfig.ts +27 -32
- package/src/atoms/globalSearch/index.ts +1 -1
- package/src/atoms/org/customerService.ts +4 -8
- package/src/atoms/org/graphqlConfig.ts +10 -16
- package/src/atoms/org/index.ts +4 -4
- package/src/atoms/org/newOrgConfigAtom.ts +2 -2
- package/src/atoms/org/orgAnalyticsConfig.ts +4 -4
- package/src/atoms/search/chatSearch.ts +74 -101
- package/src/atoms/search/productFilters.ts +15 -15
- package/src/atoms/search/productRetrievalAPI.ts +9 -11
- package/src/atoms/search/productRetrievalAdapter.ts +4 -4
- package/src/atoms/search/searchAPI.ts +46 -64
- package/src/atoms/search/searchServiceAdapter.ts +4 -8
- package/src/atoms/search/types.ts +2 -2
- package/src/atoms/search/utils.ts +1 -1
- package/src/config/divIds.ts +8 -4
- package/src/config/index.ts +1 -1
- package/src/config/locators/components/chat/variants/index.ts +12 -13
- package/src/config/locators/components/floating-button.ts +2 -2
- package/src/config/locators/components/shadow-dom.ts +1 -1
- package/src/config/locators/embedded.ts +2 -1
- package/src/config/socialProofClasses.ts +9 -14
- package/src/contexts/amplitudeContext/__tests__/amplitudeContext.test.tsx +107 -122
- package/src/contexts/amplitudeContext/amplitudeContext.tsx +112 -143
- package/src/contexts/amplitudeContext/index.ts +1 -1
- package/src/contexts/cdnContext/cdnContext.tsx +8 -10
- package/src/contexts/cdnContext/index.ts +1 -1
- package/src/contexts/chatContext/chatContext.tsx +77 -123
- package/src/contexts/chatContext/index.ts +1 -1
- package/src/contexts/enviveConfigContext/__tests__/enviveConfigContext.test.tsx +125 -153
- package/src/contexts/enviveConfigContext/enviveConfigContext.tsx +7 -7
- package/src/contexts/enviveConfigContext/index.ts +1 -1
- package/src/contexts/enviveCssContext/enviveCssContext.tsx +4 -8
- package/src/contexts/enviveCssContext/index.ts +1 -1
- package/src/contexts/featureFlagContext/featureFlagContext.tsx +28 -41
- package/src/contexts/featureFlagContext/index.ts +1 -1
- package/src/contexts/featureFlagServiceContext/featureFlagServiceContext.tsx +15 -25
- package/src/contexts/featureFlagServiceContext/index.ts +1 -1
- package/src/contexts/graphqlContext/__tests__/graphqlContext.test.tsx +142 -170
- package/src/contexts/graphqlContext/graphqlContext.tsx +40 -60
- package/src/contexts/graphqlContext/index.ts +1 -1
- package/src/contexts/localStorageContext/__tests__/localStorageContext.test.tsx +155 -161
- package/src/contexts/localStorageContext/index.ts +1 -1
- package/src/contexts/localStorageContext/localStorageContext.tsx +25 -47
- package/src/contexts/newOrgConfigContext/__tests__/newOrgConfigContext.test.tsx +119 -153
- package/src/contexts/newOrgConfigContext/index.ts +1 -1
- package/src/contexts/newOrgConfigContext/newOrgConfigContext.tsx +11 -17
- package/src/contexts/searchContext/__tests__/searchContext.test.tsx +290 -227
- package/src/contexts/searchContext/index.ts +1 -1
- package/src/contexts/searchContext/searchContext.tsx +31 -45
- package/src/contexts/sessionStorageContext/index.ts +1 -1
- package/src/contexts/sessionStorageContext/sessionStorageContext.tsx +11 -27
- package/src/contexts/shopifyUrlContext/index.ts +1 -1
- package/src/contexts/shopifyUrlContext/shopifyUrlContext.tsx +21 -30
- package/src/contexts/systemSettingsContext/__tests__/systemSettingsContext.test.tsx +130 -133
- package/src/contexts/systemSettingsContext/index.ts +1 -1
- package/src/contexts/systemSettingsContext/systemSettingsContext.tsx +8 -21
- package/src/contexts/types.ts +166 -221
- package/src/contexts/userIdentityContext/__tests__/userIdentityContext.test.tsx +116 -130
- package/src/contexts/userIdentityContext/index.ts +1 -1
- package/src/contexts/userIdentityContext/userIdentityContext.tsx +29 -64
- package/src/events/index.ts +7 -3
- package/src/events/registerAnalyticsListeners.ts +10 -13
- package/src/hooks/AmplitudeOperations/index.ts +1 -1
- package/src/hooks/AmplitudeOperations/useAmplitudeOperations.ts +5 -8
- package/src/hooks/AppDetails/index.ts +1 -1
- package/src/hooks/AppDetails/useAppDetails.ts +10 -14
- package/src/hooks/BlockBackButton/index.ts +1 -1
- package/src/hooks/BlockBackButton/useBlockBackButton.ts +10 -13
- package/src/hooks/CdnOperations/index.ts +1 -1
- package/src/hooks/CdnOperations/useCdnOperations.ts +1 -1
- package/src/hooks/ChatToggle/index.ts +1 -1
- package/src/hooks/ChatToggle/useChatToggle.ts +7 -16
- package/src/hooks/ChatToggleAnalytics/index.ts +1 -1
- package/src/hooks/ChatToggleAnalytics/useChatToggleAnalytics.ts +4 -4
- package/src/hooks/CustomerSupportHandoff/index.ts +1 -1
- package/src/hooks/Debounce/index.ts +1 -1
- package/src/hooks/ElementObserver/index.ts +1 -1
- package/src/hooks/GrabAndScroll/index.ts +1 -1
- package/src/hooks/GrabAndScroll/useGrabAndScroll.ts +131 -119
- package/src/hooks/GraphQLConfig/index.ts +1 -1
- package/src/hooks/GraphQLConfig/useGraphQLConfig.ts +4 -7
- package/src/hooks/IdentifyUser/index.ts +1 -1
- package/src/hooks/IdentifyUser/useIdentifyUser.ts +4 -8
- package/src/hooks/ImageResolver/index.ts +1 -1
- package/src/hooks/ImageResolver/useImageResolver.ts +7 -16
- package/src/hooks/Intersection/index.ts +1 -1
- package/src/hooks/IsSmallScreen/index.ts +1 -1
- package/src/hooks/LocalStorageOperations/index.ts +1 -1
- package/src/hooks/LocalStorageOperations/useLocalStorageOperations.ts +12 -19
- package/src/hooks/MessageFilter/index.ts +1 -1
- package/src/hooks/MessageFilter/useMessageFilter.ts +1 -1
- package/src/hooks/MessageScrollObserver/index.ts +1 -1
- package/src/hooks/MessageScrollObserver/useMessageScrollObserver.ts +35 -37
- package/src/hooks/NewOrgConfig/index.ts +1 -1
- package/src/hooks/NewOrgConfig/useNewOrgConfig.ts +1 -1
- package/src/hooks/Search/__tests__/useSearch.test.tsx +214 -247
- package/src/hooks/Search/index.ts +1 -1
- package/src/hooks/Search/useRecommendedProducts.ts +27 -33
- package/src/hooks/Search/useSearch.tsx +65 -53
- package/src/hooks/Search/useSearchInput.ts +23 -34
- package/src/hooks/SearchOperations/index.ts +1 -1
- package/src/hooks/SearchOperations/useSearchOperations.ts +8 -12
- package/src/hooks/SessionStorageOperations/index.ts +1 -1
- package/src/hooks/SessionStorageOperations/useSessionStorageOperations.ts +5 -5
- package/src/hooks/ShopifyUrlOperations/index.ts +1 -1
- package/src/hooks/ShopifyUrlOperations/useShopifyUrlOperations.ts +8 -14
- package/src/hooks/SnapCalculator/index.ts +1 -1
- package/src/hooks/SnapCalculator/useSnapCalculator.ts +1 -1
- package/src/hooks/SystemSettingsContext/index.ts +1 -1
- package/src/hooks/SystemSettingsContext/useSystemSettingsContext.ts +3 -5
- package/src/hooks/TrackComponentVisibleEvent/index.ts +1 -1
- package/src/hooks/TrackComponentVisibleEvent/useTrackComponentVisibleEvent.ts +6 -6
- package/src/hooks/UpdateAnalyticsProps/index.ts +1 -1
- package/src/hooks/UpdateAnalyticsProps/useUpdateAnalyticsProps.ts +10 -22
- package/src/hooks/utils.ts +20 -29
- package/src/interceptors/index.ts +2 -2
- package/src/interceptors/useMessageInterceptor.ts +4 -4
- package/src/merchants/domInsertion.ts +13 -15
- package/src/merchants/gridInsertion.ts +15 -15
- package/src/types/FilterAttribute.ts +7 -10
- package/src/{types.ts → types/OrgInfo.ts} +1 -3
- package/src/types/config-versions.ts +2 -4
- package/src/types/customerService.ts +15 -15
- package/src/types/custservice-types.ts +2 -2
- package/src/types/exceptions/unsupportedProductExceptions.ts +1 -1
- package/src/types/index.ts +5 -4
- package/src/types/search-filter-types.ts +2 -2
- package/src/types/suggestionBarV2-types.ts +3 -3
- package/dist/AmplitudeOperations-ChZWcSsc.js +0 -1
- package/dist/AmplitudeOperations-JggIc1zD.cjs +0 -0
- package/dist/NewOrgConfig-BYo4V8-u.cjs +0 -15
- package/dist/NewOrgConfig-kYrS59aR.js +0 -10
- package/dist/SystemSettingsContext-BY1BFgAQ.js +0 -13
- package/dist/SystemSettingsContext-EDpRMMt2.cjs +0 -20
- package/dist/TrackComponentVisibleEvent-BHVBHQhu.js +0 -52
- package/dist/TrackComponentVisibleEvent-B_2kXqvV.cjs +0 -59
- package/dist/amplitudeContext-BItT9HmT.js +0 -1
- package/dist/amplitudeContext-CCVyp5RU.d.cts +0 -52
- package/dist/amplitudeContext-CjkMpI_a.cjs +0 -290
- package/dist/amplitudeContext-D58WY1aS.js +0 -268
- package/dist/amplitudeContext-DPtyVv3Q.cjs +0 -0
- package/dist/amplitudeContext-DcRur97Z.d.ts +0 -52
- package/dist/api-BWSsazAG.js +0 -166
- package/dist/api-DeW6rHj3.cjs +0 -239
- package/dist/app-BbPSHefQ.cjs +0 -156
- package/dist/app-CflxT_xI.js +0 -110
- package/dist/atomStore-CmZbgQHc.cjs +0 -58
- package/dist/atomStore-DEcDhiLp.js +0 -32
- package/dist/cdnContext-CaDyQ_5p.cjs +0 -53
- package/dist/cdnContext-CtrIlAqX.js +0 -38
- package/dist/chat-CLo8FBCb.cjs +0 -400
- package/dist/chat-ClvJ9xEj.js +0 -25
- package/dist/chat-DCGriB7h.cjs +0 -145
- package/dist/chat-Qkx5llOV.js +0 -258
- package/dist/chatElementDisplayLocation-BO3fY4hq.d.ts +0 -26
- package/dist/chatElementDisplayLocation-Igta1TL1.d.cts +0 -26
- package/dist/chatSearch-CP7QtVyA.cjs +0 -418
- package/dist/chatSearch-CjMcB3fG.js +0 -295
- package/dist/chatState-BUN8ehpy.js +0 -34
- package/dist/chatState-BUlDJ4NK.cjs +0 -120
- package/dist/commerce-api-CxnUXpTq.js +0 -312
- package/dist/commerce-api-DNnrOYWX.cjs +0 -319
- package/dist/common-DQPvV_S_.cjs +0 -189
- package/dist/common-c_4eX0qn.js +0 -39
- package/dist/components-CDpaMUjK.js +0 -11
- package/dist/components-DKwVHIjq.cjs +0 -29
- package/dist/domObserver-COKvTfZV.cjs +0 -304
- package/dist/domObserver-DEiUh0qg.js +0 -285
- package/dist/enviveConfig-DZBohDpc.js +0 -62
- package/dist/enviveConfig-Dv9-esGV.cjs +0 -130
- package/dist/enviveConfigContext-D2OELZDR.cjs +0 -60
- package/dist/enviveConfigContext-DrDjCems.js +0 -45
- package/dist/events-DYY4l817.cjs +0 -90
- package/dist/events-DyUix-Bn.js +0 -78
- package/dist/featureFlagServiceContext-CJyYItqu.cjs +0 -62
- package/dist/featureFlagServiceContext-CPqbnfe3.d.cts +0 -23
- package/dist/featureFlagServiceContext-FBM6DdMJ.js +0 -42
- package/dist/featureFlagServiceContext-mFEI_SIk.d.ts +0 -23
- package/dist/featureGates-KEwAL8p_.js +0 -26
- package/dist/featureGates-qU_ulhpC.cjs +0 -32
- package/dist/frontendConfig-DPpzM5cz.d.cts +0 -860
- package/dist/frontendConfig-msK69LYN.d.ts +0 -860
- package/dist/globalSearch-BOG3wmck.cjs +0 -39
- package/dist/globalSearch-BQEX-2Ml.js +0 -14
- package/dist/graphql-CkxgqsXP.js +0 -48
- package/dist/graphql-i3dtpVTl.cjs +0 -71
- package/dist/graphqlConfig-BnfE0ql5.cjs +0 -39
- package/dist/graphqlConfig-CZGjJ8hP.js +0 -14
- package/dist/graphqlContext-1BkFjchL.d.cts +0 -28
- package/dist/graphqlContext-B1vmNkWT.d.ts +0 -28
- package/dist/graphqlContext-C0hG5Uer.js +0 -96
- package/dist/graphqlContext-Dddy7mr7.cjs +0 -111
- package/dist/index--9_c4tze.d.ts +0 -9
- package/dist/index-A0HvA68Y.d.cts +0 -1
- package/dist/index-BEpDGqnz.d.cts +0 -41
- package/dist/index-BNHIIgYk.d.ts +0 -24
- package/dist/index-Bb3zXP0P.d.ts +0 -673
- package/dist/index-Bq0xKgFw.d.cts +0 -186
- package/dist/index-CCboEuTO.d.cts +0 -24
- package/dist/index-CESxqFso.d.cts +0 -228
- package/dist/index-D7htGSQC.d.ts +0 -44
- package/dist/index-DM_5fh8c.d.ts +0 -101
- package/dist/index-DNVvRcKu.d.ts +0 -1
- package/dist/index-DU7uw0ba.d.cts +0 -101
- package/dist/index-DXTWZLEm.d.cts +0 -673
- package/dist/index-DZtnHhlr.d.cts +0 -9
- package/dist/index-DeLfV7w5.d.ts +0 -186
- package/dist/index-Dtw-hJdt.d.ts +0 -35
- package/dist/index-Dxpscrvz.d.ts +0 -228
- package/dist/index-ErVcwUnR.d.ts +0 -41
- package/dist/index-OkKEOL6H.d.cts +0 -44
- package/dist/index-hAqp0oYb.d.cts +0 -35
- package/dist/localStorageContext-BPZ82q-G.js +0 -95
- package/dist/localStorageContext-NRP-CdmF.cjs +0 -115
- package/dist/locators-DxYdak1F.cjs +0 -131
- package/dist/logger-TBIl4uIH.cjs +0 -26
- package/dist/logger-W3lqg-4b.js +0 -20
- package/dist/models-CE5YjbzE.js +0 -1286
- package/dist/models-CJy0mOoW.cjs +0 -1521
- package/dist/newOrgConfigAtom-CPA6Gp6n.cjs +0 -15
- package/dist/newOrgConfigAtom-DEUj6H-p.js +0 -8
- package/dist/newOrgConfigContext-CmQ-7Trc.d.ts +0 -16
- package/dist/newOrgConfigContext-Deofb8_o.d.cts +0 -16
- package/dist/newOrgConfigContext-Dg2gtrwB.cjs +0 -68
- package/dist/newOrgConfigContext-P4xkie1E.js +0 -53
- package/dist/nodeSelector-B5NfnUHv.d.ts +0 -31
- package/dist/nodeSelector-vKB44CDB.d.cts +0 -31
- package/dist/org-B_cWn2bt.cjs +0 -43
- package/dist/org-h32_LSEb.js +0 -12
- package/dist/orgAnalyticsConfig-Bm23fw4s.cjs +0 -39
- package/dist/orgAnalyticsConfig-CpBmga08.js +0 -14
- package/dist/responseGenerics-D9bS-Dd6.d.ts +0 -148
- package/dist/responseGenerics-DWLV09cQ.d.cts +0 -148
- package/dist/search-BRBqhum7.js +0 -126
- package/dist/search-Bpd_wxaK.cjs +0 -205
- package/dist/search-filter-types-BItKtezf.d.cts +0 -102
- package/dist/search-filter-types-CGFhksO3.d.ts +0 -102
- package/dist/searchContext-CitUyTLP.js +0 -129
- package/dist/searchContext-D5_iwZ0f.cjs +0 -145
- package/dist/searchServiceAdapter-BGlvoZFE.cjs +0 -34
- package/dist/searchServiceAdapter-Db6jEcJs.js +0 -16
- package/dist/sessionStorageContext-B6FsNKjj.cjs +0 -66
- package/dist/sessionStorageContext-CLYCm83p.js +0 -52
- package/dist/shopifyUrlContext-CxjV3qvH.cjs +0 -75
- package/dist/shopifyUrlContext-D2btP_lY.js +0 -61
- package/dist/spiffyWidgets-DK7Ekcy7.d.cts +0 -21
- package/dist/spiffyWidgets-MTUAQq_u.d.ts +0 -21
- package/dist/systemSettingsContext-DF0jSq9m.js +0 -39
- package/dist/systemSettingsContext-dmE1v6w8.cjs +0 -60
- package/dist/test-types-BEml_bm3.d.ts +0 -40
- package/dist/test-types-Dsu8RJZu.d.cts +0 -40
- package/dist/types-4LQ7LUCk.d.ts +0 -10
- package/dist/types-BegmH0S1.d.ts +0 -60
- package/dist/types-BuvXXGxE.cjs +0 -48
- package/dist/types-CKPddlfS.cjs +0 -0
- package/dist/types-CtUb63bt.js +0 -76
- package/dist/types-DFsSqmWx.d.cts +0 -10
- package/dist/types-DWorwfS-.d.cts +0 -60
- package/dist/types-DXnG1tV0.js +0 -30
- package/dist/types-Dc6hx6ei.js +0 -1
- package/dist/types-UUvB6h05.cjs +0 -106
- package/dist/types.cjs +0 -0
- package/dist/types.d.cts +0 -15
- package/dist/types.d.ts +0 -15
- package/dist/types.js +0 -1
- package/dist/unsupportedProductExceptions-DGENUnEA.cjs +0 -32
- package/dist/unsupportedProductExceptions-uQuuelOs.js +0 -20
- package/dist/urlsParser-COzMdJaX.cjs +0 -78
- package/dist/urlsParser-DxjoLj98.js +0 -42
- package/dist/useAmplitudeOperations-Cr03Hlk6.js +0 -34
- package/dist/useAmplitudeOperations-DzFMBUU_.cjs +0 -41
- package/dist/useAppDetails-BCvirEDu.cjs +0 -38
- package/dist/useAppDetails-CiBg_ni5.js +0 -30
- package/dist/useGraphQLConfig-8oeOwWRP.js +0 -63
- package/dist/useGraphQLConfig-CO9lCk8b.cjs +0 -76
- package/dist/useIntersection-CZSEBUbv.js +0 -21
- package/dist/useIntersection-DSDREfj6.cjs +0 -28
- package/dist/useMessageInterceptor-BjGP_uXm.js +0 -25
- package/dist/useMessageInterceptor-arAqUq1Q.cjs +0 -33
- package/dist/userIdentityContext-BgbcZ_P2.js +0 -126
- package/dist/userIdentityContext-C6kApbuk.d.ts +0 -20
- package/dist/userIdentityContext-CrWUNCrF.cjs +0 -143
- package/dist/userIdentityContext-kU1PIo8K.d.cts +0 -20
- package/dist/utilityTypes-B2KuRn37.js +0 -1
- package/dist/utilityTypes-BGbL2WTP.cjs +0 -0
- package/dist/utils-BRkGP1eb.d.ts +0 -15
- package/dist/utils-BXfzt6tu.cjs +0 -715
- package/dist/utils-C2HshI4X.d.cts +0 -22
- package/dist/utils-CDw74BCO.cjs +0 -33
- package/dist/utils-Cv772xzd.js +0 -606
- package/dist/utils-CvLmSsUj.cjs +0 -29
- package/dist/utils-D82gfbgU.js +0 -23
- package/dist/utils-DCrwX6FT.d.cts +0 -15
- package/dist/utils-DIvMgPe8.js +0 -27
- package/dist/utils-D_kATUj6.js +0 -92
- package/dist/utils-aa1jK0Xe.d.ts +0 -22
- package/dist/utils-hYTjy7hJ.cjs +0 -130
package/README.md
CHANGED
|
@@ -2,36 +2,3 @@
|
|
|
2
2
|
# envive-react-hooks
|
|
3
3
|
|
|
4
4
|
State and data providers for intergrating with Envive.
|
|
5
|
-
|
|
6
|
-
## Local Development
|
|
7
|
-
|
|
8
|
-
In order to develop packages in tandem, we use npm link. Due to a limitation around react hooks and link, you will receive an error unless you follow these steps.
|
|
9
|
-
|
|
10
|
-
The following example assumes a file system where all your repos share a top level directory. If you organize your code differently, you will need to change the paths accordingly.
|
|
11
|
-
|
|
12
|
-
```md
|
|
13
|
-
my-code/
|
|
14
|
-
├── envive-app-blocks/
|
|
15
|
-
├── envive-react-hooks/
|
|
16
|
-
├── envive-react-toolkit/
|
|
17
|
-
│ ├──packages/
|
|
18
|
-
│ ├── components/
|
|
19
|
-
│ ├── icons/
|
|
20
|
-
│ ├── storybook/
|
|
21
|
-
```
|
|
22
|
-
|
|
23
|
-
For the hooks library:
|
|
24
|
-
|
|
25
|
-
1. Starting from /envive-app-blocks `npm i`
|
|
26
|
-
2. `cd ../envive-react-hooks`
|
|
27
|
-
3. `npm link ../envive-app-blocks/node_modules/react`
|
|
28
|
-
4. `npm run build:watch`
|
|
29
|
-
5. `cd ../envive-app-blocks`
|
|
30
|
-
6. `npm link ../envive-react-hooks`
|
|
31
|
-
7. `npm run dev:local`
|
|
32
|
-
|
|
33
|
-
### Troubleshooting link
|
|
34
|
-
|
|
35
|
-
* If you see an error such as this, something may have not been linked correctly.
|
|
36
|
-
`Hooks can only be called inside the body of a function component.`, there is likely nothing wrong with your code.
|
|
37
|
-
* If you run `npm i` in either package, you will get unlinked, if you are doing a lot of testing around your dependencies, you can use `npm link --save`. This will add a file reference to your package.json that you will need to correct before merge.
|
|
@@ -6,12 +6,16 @@ var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
|
6
6
|
var __getProtoOf = Object.getPrototypeOf;
|
|
7
7
|
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
8
|
var __copyProps = (to, from, except, desc) => {
|
|
9
|
-
if (from && typeof from === "object" || typeof from === "function")
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
9
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
10
|
+
for (var keys = __getOwnPropNames(from), i = 0, n = keys.length, key; i < n; i++) {
|
|
11
|
+
key = keys[i];
|
|
12
|
+
if (!__hasOwnProp.call(to, key) && key !== except) {
|
|
13
|
+
__defProp(to, key, {
|
|
14
|
+
get: ((k) => from[k]).bind(null, key),
|
|
15
|
+
enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable
|
|
16
|
+
});
|
|
17
|
+
}
|
|
18
|
+
}
|
|
15
19
|
}
|
|
16
20
|
return to;
|
|
17
21
|
};
|
|
@@ -22,9 +26,4 @@ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__ge
|
|
|
22
26
|
|
|
23
27
|
//#endregion
|
|
24
28
|
|
|
25
|
-
|
|
26
|
-
enumerable: true,
|
|
27
|
-
get: function () {
|
|
28
|
-
return __toESM;
|
|
29
|
-
}
|
|
30
|
-
});
|
|
29
|
+
exports.__toESM = __toESM;
|
|
@@ -0,0 +1,319 @@
|
|
|
1
|
+
const require_rolldown_runtime = require('../_virtual/rolldown_runtime.cjs');
|
|
2
|
+
const require_productExperiment = require('./models/productExperiment.cjs');
|
|
3
|
+
const require_logger = require('./logging/logger.cjs');
|
|
4
|
+
const require_validateOrgConfigResults = require('./models/validators/validateOrgConfigResults.cjs');
|
|
5
|
+
const require_validateResponse = require('./models/validators/validateResponse.cjs');
|
|
6
|
+
const require_validateSuggestion = require('./models/validators/validateSuggestion.cjs');
|
|
7
|
+
const require_validateUserEvent = require('./models/validators/validateUserEvent.cjs');
|
|
8
|
+
const require_enviveConfig = require('../atoms/envive/enviveConfig.cjs');
|
|
9
|
+
const require_atomStore = require('../atoms/atomStore/atomStore.cjs');
|
|
10
|
+
const require_atoms_app_index = require('../atoms/app/index.cjs');
|
|
11
|
+
const require_messageFromFormSubmittedEvent = require('./utils/messageFromFormSubmittedEvent.cjs');
|
|
12
|
+
const require_messageFromQueryEvent = require('./utils/messageFromQueryEvent.cjs');
|
|
13
|
+
const require_messageFromResponse = require('./utils/messageFromResponse.cjs');
|
|
14
|
+
const require_messageFromSuggestionEvent = require('./utils/messageFromSuggestionEvent.cjs');
|
|
15
|
+
const require_nextMessageRequestToApiRequest = require('./utils/nextMessageRequestToApiRequest.cjs');
|
|
16
|
+
const require_supportedEventRequestToApiRequest = require('./utils/supportedEventRequestToApiRequest.cjs');
|
|
17
|
+
require('./utils/index.cjs');
|
|
18
|
+
const require_graphqlConfig = require('../atoms/org/graphqlConfig.cjs');
|
|
19
|
+
const require_sessionExceptions = require('../types/exceptions/sessionExceptions.cjs');
|
|
20
|
+
const require_unsupportedProductExceptions = require('../types/exceptions/unsupportedProductExceptions.cjs');
|
|
21
|
+
let __spiffy_ai_commerce_api_client = require("@spiffy-ai/commerce-api-client");
|
|
22
|
+
|
|
23
|
+
//#region src/application/commerce-api.ts
|
|
24
|
+
async function errorResponseBody(error) {
|
|
25
|
+
try {
|
|
26
|
+
return await error.response.json();
|
|
27
|
+
} catch {
|
|
28
|
+
return {};
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
async function throwSessionRestartRequiredIf(errorMsg, error) {
|
|
32
|
+
if (!(error instanceof __spiffy_ai_commerce_api_client.ResponseError)) {
|
|
33
|
+
require_logger.default.logInfo(errorMsg, error);
|
|
34
|
+
throw error;
|
|
35
|
+
}
|
|
36
|
+
const errorResponse = await errorResponseBody(error);
|
|
37
|
+
if (errorResponse?.message?.toLowerCase() === "unsupported product" || errorResponse?.app_code?.toUpperCase() === "PRODUCT_NOT_FOUND") throw new require_unsupportedProductExceptions.UnsupportedProductException();
|
|
38
|
+
else if (errorResponse?.app_code?.toUpperCase() === "RESTART_SESSION" || errorResponse?.sub_code?.toUpperCase() === "NOT_FOUND") {
|
|
39
|
+
require_logger.default.logInfo("Session does not exist. Re-start session", error, error.response, errorResponse);
|
|
40
|
+
throw new require_sessionExceptions.SessionRestartRequired();
|
|
41
|
+
}
|
|
42
|
+
require_logger.default.logInfo(errorMsg, error);
|
|
43
|
+
throw error;
|
|
44
|
+
}
|
|
45
|
+
var CommerceApiClient = class CommerceApiClient {
|
|
46
|
+
static {
|
|
47
|
+
this.getInstance = () => {
|
|
48
|
+
if (!CommerceApiClient.instance) CommerceApiClient.instance = new CommerceApiClient();
|
|
49
|
+
return CommerceApiClient.instance;
|
|
50
|
+
};
|
|
51
|
+
}
|
|
52
|
+
constructor(basePath) {
|
|
53
|
+
this.suggestionsAbortController = new AbortController();
|
|
54
|
+
this.responsesAbortController = new AbortController();
|
|
55
|
+
const baseUrl = require_atomStore.getAtomStore().get(require_enviveConfig.baseUrlAtom);
|
|
56
|
+
const config = new __spiffy_ai_commerce_api_client.Configuration({
|
|
57
|
+
basePath: basePath || baseUrl,
|
|
58
|
+
headers: {
|
|
59
|
+
"Content-Type": "application/json",
|
|
60
|
+
Accept: "application/json"
|
|
61
|
+
}
|
|
62
|
+
});
|
|
63
|
+
this.defaultApi = new __spiffy_ai_commerce_api_client.DefaultApi(config);
|
|
64
|
+
this.inferenceApi = new __spiffy_ai_commerce_api_client.InferenceApi(config);
|
|
65
|
+
this.customerServiceApi = new __spiffy_ai_commerce_api_client.CustomerServiceApi(config);
|
|
66
|
+
}
|
|
67
|
+
static {
|
|
68
|
+
this.resolveUrl = async (url) => {
|
|
69
|
+
const atomStore = require_atomStore.getAtomStore();
|
|
70
|
+
const orgShortName = atomStore.get(require_enviveConfig.orgShortNameAtom);
|
|
71
|
+
const orgId = atomStore.get(require_graphqlConfig.orgIdAtom);
|
|
72
|
+
const userId = atomStore.get(require_atoms_app_index.userIdAtom);
|
|
73
|
+
const chatId = atomStore.get(require_atoms_app_index.chatIdAtom);
|
|
74
|
+
const source = atomStore.get(require_enviveConfig.contextSourceAtom);
|
|
75
|
+
const env = atomStore.get(require_enviveConfig.envAtom);
|
|
76
|
+
const featureFlagService = atomStore.get(require_graphqlConfig.featureFlagServiceAtom);
|
|
77
|
+
const urlResolvingRequest = {
|
|
78
|
+
url,
|
|
79
|
+
context: {
|
|
80
|
+
user_id: userId ?? "",
|
|
81
|
+
org_id: orgId ?? "",
|
|
82
|
+
org_short_name: orgShortName ?? "",
|
|
83
|
+
chat_id: chatId ?? "",
|
|
84
|
+
source: source ?? __spiffy_ai_commerce_api_client.ContextSourceEnum.App,
|
|
85
|
+
env: env ?? __spiffy_ai_commerce_api_client.ContextEnvEnum.Dev
|
|
86
|
+
},
|
|
87
|
+
feature_gates: featureFlagService?.featureFlagService?.getFeatureFlags() || {}
|
|
88
|
+
};
|
|
89
|
+
return await (await CommerceApiClient.getInstance().inferenceApi.v1UrlResolvingPostRaw({ UrlResolvingRequest: urlResolvingRequest })).raw.json();
|
|
90
|
+
};
|
|
91
|
+
}
|
|
92
|
+
static {
|
|
93
|
+
this.reportSession = async (reportRequest) => {
|
|
94
|
+
await CommerceApiClient.getInstance().defaultApi.v1ChatsReportSessionIdPost({ ReportSessionRequest: reportRequest });
|
|
95
|
+
};
|
|
96
|
+
}
|
|
97
|
+
static {
|
|
98
|
+
this.getNextResponses = async (payload) => {
|
|
99
|
+
try {
|
|
100
|
+
return (await CommerceApiClient.getInstance().inferenceApi.v1NextResponsesPost({ NextMessageRequest: require_nextMessageRequestToApiRequest.messageRequestToCommerceMessageRequest(payload) })).map((resp) => require_validateResponse.validateResponse(resp)).map((resp) => require_messageFromResponse.messageFromResponse(resp)).filter((m) => m != null);
|
|
101
|
+
} catch (err) {
|
|
102
|
+
require_logger.default.logInfo("Failed to get next responses", err, {
|
|
103
|
+
payloadContext: payload?.context,
|
|
104
|
+
userEvents: payload?.userEvents
|
|
105
|
+
});
|
|
106
|
+
await throwSessionRestartRequiredIf("Failed to get next responses", err);
|
|
107
|
+
return [];
|
|
108
|
+
}
|
|
109
|
+
};
|
|
110
|
+
}
|
|
111
|
+
static {
|
|
112
|
+
this.getNextResponseStreaming = (payload) => {
|
|
113
|
+
async function* generate(inferenceApi, abortController) {
|
|
114
|
+
try {
|
|
115
|
+
const response = await inferenceApi.v1NextResponsesPostRaw({ NextMessageRequest: require_nextMessageRequestToApiRequest.messageRequestToCommerceMessageRequest(payload) }, { signal: abortController.signal });
|
|
116
|
+
if (!response.raw.body) {
|
|
117
|
+
require_logger.default.logError("[spiffy-ai] No body in the streamed response", void 0, { response: response.raw });
|
|
118
|
+
return;
|
|
119
|
+
}
|
|
120
|
+
const reader = response.raw.body.getReader();
|
|
121
|
+
const decoder = new TextDecoder("utf-8");
|
|
122
|
+
let partial = "";
|
|
123
|
+
const safeParse = (line) => {
|
|
124
|
+
try {
|
|
125
|
+
return JSON.parse(line);
|
|
126
|
+
} catch (err) {
|
|
127
|
+
require_logger.default.logError("[spiffy-ai] Error parsing streamed line", err, {
|
|
128
|
+
line,
|
|
129
|
+
partial
|
|
130
|
+
});
|
|
131
|
+
partial = line;
|
|
132
|
+
return partial;
|
|
133
|
+
}
|
|
134
|
+
};
|
|
135
|
+
const processChunk = (chunk) => {
|
|
136
|
+
return `${partial}${chunk}`.split("\n").map((line) => line.replace(/^data: /, "").trim()).filter((line) => line !== "" && line !== "[DONE]").map(safeParse).filter((v) => v);
|
|
137
|
+
};
|
|
138
|
+
while (true) {
|
|
139
|
+
const { done, value } = await reader.read();
|
|
140
|
+
if (done) break;
|
|
141
|
+
const parsedLines = processChunk(decoder.decode(value));
|
|
142
|
+
for (const parsedLine of parsedLines) {
|
|
143
|
+
const validatedResponse = require_validateResponse.validateResponse(parsedLine);
|
|
144
|
+
if (validatedResponse) yield validatedResponse;
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
} catch (error) {
|
|
148
|
+
require_logger.default.logError("[spiffy-ai] Failed to get next streaming responses", error, {
|
|
149
|
+
payloadContext: payload?.context,
|
|
150
|
+
userEvents: payload?.userEvents
|
|
151
|
+
});
|
|
152
|
+
await throwSessionRestartRequiredIf("Failed to get next streaming responses", error);
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
CommerceApiClient.getInstance().responsesAbortController.abort();
|
|
156
|
+
CommerceApiClient.getInstance().responsesAbortController = new AbortController();
|
|
157
|
+
return generate(CommerceApiClient.getInstance().inferenceApi, CommerceApiClient.getInstance().responsesAbortController);
|
|
158
|
+
};
|
|
159
|
+
}
|
|
160
|
+
static {
|
|
161
|
+
this.getNextSuggestions = async (payload) => {
|
|
162
|
+
try {
|
|
163
|
+
CommerceApiClient.getInstance().suggestionsAbortController.abort();
|
|
164
|
+
CommerceApiClient.getInstance().suggestionsAbortController = new AbortController();
|
|
165
|
+
return (await CommerceApiClient.getInstance().inferenceApi.v1NextSuggestionsPost({ NextMessageRequest: require_nextMessageRequestToApiRequest.messageRequestToCommerceMessageRequest(payload) }, { signal: CommerceApiClient.getInstance().suggestionsAbortController.signal })).map((resp) => require_validateSuggestion.validateSuggestion(resp)).filter((suggestion) => suggestion != null);
|
|
166
|
+
} catch (error) {
|
|
167
|
+
require_logger.default.logInfo("Failed to get suggestions", error, {
|
|
168
|
+
payloadContext: payload?.context,
|
|
169
|
+
userEvents: payload?.userEvents
|
|
170
|
+
});
|
|
171
|
+
await throwSessionRestartRequiredIf("Failed to get suggestions", error);
|
|
172
|
+
return [];
|
|
173
|
+
}
|
|
174
|
+
};
|
|
175
|
+
}
|
|
176
|
+
static {
|
|
177
|
+
this.getResponses = async (orgId, chatId, userId) => {
|
|
178
|
+
let data = {
|
|
179
|
+
responses: [],
|
|
180
|
+
suggestions: [],
|
|
181
|
+
user_events: []
|
|
182
|
+
};
|
|
183
|
+
const request = {
|
|
184
|
+
org_id: orgId,
|
|
185
|
+
chat_id: chatId,
|
|
186
|
+
user_id: userId
|
|
187
|
+
};
|
|
188
|
+
try {
|
|
189
|
+
data = await CommerceApiClient.getInstance().defaultApi.v1GetSessionMessages(request);
|
|
190
|
+
} catch (error) {
|
|
191
|
+
await throwSessionRestartRequiredIf("Failed to get chat responses", error);
|
|
192
|
+
}
|
|
193
|
+
const responses = data?.responses?.map((turn) => turn.map((response) => require_validateResponse.validateResponse(response)).filter((response) => response != null));
|
|
194
|
+
const suggestions = data?.suggestions.map((suggestion) => require_validateSuggestion.validateSuggestion(suggestion)).filter((suggestion) => suggestion != null);
|
|
195
|
+
const userEvents = data?.user_events.map((event) => require_validateUserEvent.validateUserEvent(event)).filter((event) => event != null);
|
|
196
|
+
const formSubmittedUserEventsFormIds = userEvents.filter((event) => event.category === __spiffy_ai_commerce_api_client.UserEventCategory.FormSubmitted).map((event) => event.attributes.formResponseId);
|
|
197
|
+
const assistantMessages = responses.map((turn) => turn.filter((response) => !(response.category === __spiffy_ai_commerce_api_client.ResponseCategory.Form && formSubmittedUserEventsFormIds.includes(response.id))).map((response) => require_messageFromResponse.messageFromResponse(response)).filter((message) => message != null)).filter((turn) => turn.length > 0);
|
|
198
|
+
const userMessages = userEvents.map((event) => {
|
|
199
|
+
if ([__spiffy_ai_commerce_api_client.UserEventCategory.QueryTyped, __spiffy_ai_commerce_api_client.UserEventCategory.Search].includes(event.category)) return [require_messageFromQueryEvent.messageFromQueryEvent(event)];
|
|
200
|
+
if (event.category === __spiffy_ai_commerce_api_client.UserEventCategory.SuggestionClicked) return [require_messageFromSuggestionEvent.messageFromSuggestionEvent(event, suggestions)];
|
|
201
|
+
if (event.category === __spiffy_ai_commerce_api_client.UserEventCategory.FormSubmitted) {
|
|
202
|
+
const formResponse = responses.flat().find((response) => response.id === event.attributes.formResponseId && event.attributes.formType !== __spiffy_ai_commerce_api_client.FormType.Escalation);
|
|
203
|
+
if (formResponse && formResponse.category === __spiffy_ai_commerce_api_client.ResponseCategory.Form) return [require_messageFromFormSubmittedEvent.messageFromFormSubmittedEvent(event, formResponse.attributes)];
|
|
204
|
+
}
|
|
205
|
+
return [];
|
|
206
|
+
}).filter((message) => message.length > 0);
|
|
207
|
+
return {
|
|
208
|
+
responses,
|
|
209
|
+
userEvents,
|
|
210
|
+
suggestions,
|
|
211
|
+
messages: [...assistantMessages, ...userMessages].sort((a, b) => new Date(a[0].createdAt).getTime() - new Date(b[0].createdAt).getTime())
|
|
212
|
+
};
|
|
213
|
+
};
|
|
214
|
+
}
|
|
215
|
+
static {
|
|
216
|
+
this.isSupportedEvent = async (payload) => {
|
|
217
|
+
try {
|
|
218
|
+
const httpResponseText = await (await CommerceApiClient.getInstance().inferenceApi.v1SupportedEventPostRaw({ SupportedEventRequest: require_supportedEventRequestToApiRequest.coreSupportedEventRequestToApiRequest(payload) })).raw.text();
|
|
219
|
+
const httpResponseJson = JSON.parse(httpResponseText);
|
|
220
|
+
return {
|
|
221
|
+
...httpResponseJson,
|
|
222
|
+
numberOfReviews: httpResponseJson.num_of_reviews,
|
|
223
|
+
merchant_tags: httpResponseJson.merchant_tags || []
|
|
224
|
+
};
|
|
225
|
+
} catch (err) {
|
|
226
|
+
require_logger.default.logError("Failed to get response for v1SupportedEventPost", { err });
|
|
227
|
+
return {
|
|
228
|
+
supported: false,
|
|
229
|
+
ready: false,
|
|
230
|
+
category: void 0,
|
|
231
|
+
collections: [],
|
|
232
|
+
numberOfReviews: void 0,
|
|
233
|
+
top_category: void 0,
|
|
234
|
+
merchant_tags: []
|
|
235
|
+
};
|
|
236
|
+
}
|
|
237
|
+
};
|
|
238
|
+
}
|
|
239
|
+
static {
|
|
240
|
+
this.identifyUser = async (spiffyUserId, merchantUserId, uaDetails) => {
|
|
241
|
+
try {
|
|
242
|
+
await CommerceApiClient.getInstance().defaultApi.v1AnalyticsIdentifyPost({ AnalyticsIdentifyRequest: {
|
|
243
|
+
user_id: spiffyUserId,
|
|
244
|
+
os_name: uaDetails.os,
|
|
245
|
+
os_version: uaDetails.osVersion,
|
|
246
|
+
platform: uaDetails.os,
|
|
247
|
+
device_id: uaDetails.deviceModel,
|
|
248
|
+
device_brand: uaDetails.deviceBrand,
|
|
249
|
+
device_manufacturer: uaDetails.deviceManufacturer,
|
|
250
|
+
device_model: uaDetails.deviceModel,
|
|
251
|
+
user_properties: {
|
|
252
|
+
cdp_user_id: merchantUserId,
|
|
253
|
+
browser: uaDetails.browser,
|
|
254
|
+
browser_version: uaDetails.browserVersion,
|
|
255
|
+
user_agent: uaDetails.userAgent
|
|
256
|
+
}
|
|
257
|
+
} });
|
|
258
|
+
} catch (err) {
|
|
259
|
+
require_logger.default.logError("Failed to identify user", err);
|
|
260
|
+
}
|
|
261
|
+
};
|
|
262
|
+
}
|
|
263
|
+
static {
|
|
264
|
+
this.mapContextSourceToV1OrgConfigGetSource = (source) => {
|
|
265
|
+
if (source === void 0) return void 0;
|
|
266
|
+
switch (source) {
|
|
267
|
+
case __spiffy_ai_commerce_api_client.ContextSourceEnum.Fork: return __spiffy_ai_commerce_api_client.V1OrgConfigGetSourceEnum.Fork;
|
|
268
|
+
case __spiffy_ai_commerce_api_client.ContextSourceEnum.Playground: return __spiffy_ai_commerce_api_client.V1OrgConfigGetSourceEnum.Playground;
|
|
269
|
+
case __spiffy_ai_commerce_api_client.ContextSourceEnum.App: return __spiffy_ai_commerce_api_client.V1OrgConfigGetSourceEnum.App;
|
|
270
|
+
case __spiffy_ai_commerce_api_client.ContextSourceEnum.Test: return __spiffy_ai_commerce_api_client.V1OrgConfigGetSourceEnum.Test;
|
|
271
|
+
case __spiffy_ai_commerce_api_client.ContextSourceEnum.Eval: return __spiffy_ai_commerce_api_client.V1OrgConfigGetSourceEnum.Test;
|
|
272
|
+
default: return source;
|
|
273
|
+
}
|
|
274
|
+
};
|
|
275
|
+
}
|
|
276
|
+
static {
|
|
277
|
+
this.getOrgConfig = async (user_id) => {
|
|
278
|
+
try {
|
|
279
|
+
const atomStore = require_atomStore.getAtomStore();
|
|
280
|
+
const reactAppName = atomStore.get(require_enviveConfig.reactAppNameAtom);
|
|
281
|
+
const contextSource = atomStore.get(require_enviveConfig.contextSourceAtom);
|
|
282
|
+
const featureFlagService = atomStore.get(require_graphqlConfig.featureFlagServiceAtom);
|
|
283
|
+
const request = {
|
|
284
|
+
namespace: reactAppName,
|
|
285
|
+
user_id,
|
|
286
|
+
source: this.mapContextSourceToV1OrgConfigGetSource(contextSource),
|
|
287
|
+
include_experiments: Object.values(require_productExperiment.ProductExperiment),
|
|
288
|
+
include_feature_gates: Object.entries(featureFlagService?.featureFlagService?.getFeatureFlags() || {}).filter(([, isEnabled]) => isEnabled).map(([featureGateName]) => featureGateName)
|
|
289
|
+
};
|
|
290
|
+
return require_validateOrgConfigResults.validateOrgConfigResults(await CommerceApiClient.getInstance().defaultApi.v1OrgConfigGet(request));
|
|
291
|
+
} catch (err) {
|
|
292
|
+
require_logger.default.logError(`Failed to get org config`, err, { err });
|
|
293
|
+
return;
|
|
294
|
+
}
|
|
295
|
+
};
|
|
296
|
+
}
|
|
297
|
+
static {
|
|
298
|
+
this.addNoteToLatestConversation = async (spiffyUserId, email, customerServiceProvider) => {
|
|
299
|
+
require_logger.default.logInfo(`addNoteToLatestConversation - user_id=${spiffyUserId} email=${email} customer_service_provider=${customerServiceProvider}`);
|
|
300
|
+
try {
|
|
301
|
+
await CommerceApiClient.getInstance().customerServiceApi.v1CustserviceAddNoteToLatestConversationPost({ AddNoteToLatestConversationRequest: {
|
|
302
|
+
spiffy_user_id: spiffyUserId,
|
|
303
|
+
email,
|
|
304
|
+
customer_service_provider: customerServiceProvider
|
|
305
|
+
} });
|
|
306
|
+
} catch (err) {
|
|
307
|
+
require_logger.default.logError("Failed to add note to latest conversation", { err });
|
|
308
|
+
}
|
|
309
|
+
};
|
|
310
|
+
}
|
|
311
|
+
static {
|
|
312
|
+
this.getCustomerServiceApi = () => CommerceApiClient.getInstance().customerServiceApi;
|
|
313
|
+
}
|
|
314
|
+
};
|
|
315
|
+
var commerce_api_default = CommerceApiClient;
|
|
316
|
+
|
|
317
|
+
//#endregion
|
|
318
|
+
exports.default = commerce_api_default;
|
|
319
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbWVyY2UtYXBpLmNqcyIsIm5hbWVzIjpbIlJlc3BvbnNlRXJyb3IiLCJVbnN1cHBvcnRlZFByb2R1Y3RFeGNlcHRpb24iLCJTZXNzaW9uUmVzdGFydFJlcXVpcmVkIiwiZ2V0QXRvbVN0b3JlIiwiYmFzZVVybEF0b20iLCJjb25maWc6IENvbmZpZ3VyYXRpb24iLCJDb25maWd1cmF0aW9uIiwiRGVmYXVsdEFwaSIsIkluZmVyZW5jZUFwaSIsIkN1c3RvbWVyU2VydmljZUFwaSIsIm9yZ1Nob3J0TmFtZUF0b20iLCJvcmdJZEF0b20iLCJ1c2VySWRBdG9tIiwiY2hhdElkQXRvbSIsImNvbnRleHRTb3VyY2VBdG9tIiwiZW52QXRvbSIsImZlYXR1cmVGbGFnU2VydmljZUF0b20iLCJDb250ZXh0U291cmNlRW51bSIsIkNvbnRleHRFbnZFbnVtIiwibWVzc2FnZVJlcXVlc3RUb0NvbW1lcmNlTWVzc2FnZVJlcXVlc3QiLCJ2YWxpZGF0ZVJlc3BvbnNlIiwibWVzc2FnZUZyb21SZXNwb25zZSIsImVycjogdW5rbm93biIsImVycm9yOiB1bmtub3duIiwidmFsaWRhdGVTdWdnZXN0aW9uIiwiZGF0YTogVjFHZXRTZXNzaW9uTWVzc2FnZXMyMDBSZXNwb25zZSIsInJlc3BvbnNlczogUmVzcG9uc2VbXVtdIiwic3VnZ2VzdGlvbnM6IFN1Z2dlc3Rpb25bXSIsInVzZXJFdmVudHM6IFVzZXJFdmVudFtdIiwidmFsaWRhdGVVc2VyRXZlbnQiLCJVc2VyRXZlbnRDYXRlZ29yeSIsImFzc2lzdGFudE1lc3NhZ2VzOiBNZXNzYWdlW11bXSIsIlJlc3BvbnNlQ2F0ZWdvcnkiLCJ1c2VyTWVzc2FnZXM6IE1lc3NhZ2VbXVtdIiwibWVzc2FnZUZyb21RdWVyeUV2ZW50IiwibWVzc2FnZUZyb21TdWdnZXN0aW9uRXZlbnQiLCJGb3JtVHlwZSIsIm1lc3NhZ2VGcm9tRm9ybVN1Ym1pdHRlZEV2ZW50IiwiY29yZVN1cHBvcnRlZEV2ZW50UmVxdWVzdFRvQXBpUmVxdWVzdCIsIlYxT3JnQ29uZmlnR2V0U291cmNlRW51bSIsInJlYWN0QXBwTmFtZUF0b20iLCJyZXF1ZXN0OiBWMU9yZ0NvbmZpZ0dldFJlcXVlc3QiLCJQcm9kdWN0RXhwZXJpbWVudCIsInZhbGlkYXRlT3JnQ29uZmlnUmVzdWx0cyJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9hcHBsaWNhdGlvbi9jb21tZXJjZS1hcGkudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IExvZ2dlciBmcm9tICdzcmMvYXBwbGljYXRpb24vbG9nZ2luZy9sb2dnZXInO1xuaW1wb3J0IHtcbiAgQ29uZmlndXJhdGlvbixcbiAgQ3VzdG9tZXJTZXJ2aWNlQXBpLFxuICBEZWZhdWx0QXBpLFxuICBJbmZlcmVuY2VBcGksXG4gIFJlcG9ydFNlc3Npb25SZXF1ZXN0LFxuICBSZXNwb25zZUVycm9yLFxuICBVc2VyRXZlbnRDYXRlZ29yeSxcbiAgVjFHZXRTZXNzaW9uTWVzc2FnZXMyMDBSZXNwb25zZSxcbiAgVjFPcmdDb25maWdHZXRSZXF1ZXN0LFxuICBDb250ZXh0U291cmNlRW51bSxcbiAgVjFPcmdDb25maWdHZXRTb3VyY2VFbnVtLFxuICBDdXN0b21lclNlcnZpY2VQcm92aWRlcixcbiAgUmVzcG9uc2VDYXRlZ29yeSxcbiAgRm9ybVR5cGUsXG59IGZyb20gJ0BzcGlmZnktYWkvY29tbWVyY2UtYXBpLWNsaWVudCc7XG5pbXBvcnQgeyB2YWxpZGF0ZVN1Z2dlc3Rpb24gfSBmcm9tICdzcmMvYXBwbGljYXRpb24vbW9kZWxzL3ZhbGlkYXRvcnMvdmFsaWRhdGVTdWdnZXN0aW9uJztcbmltcG9ydCB7IHZhbGlkYXRlVXNlckV2ZW50IH0gZnJvbSAnc3JjL2FwcGxpY2F0aW9uL21vZGVscy92YWxpZGF0b3JzL3ZhbGlkYXRlVXNlckV2ZW50JztcbmltcG9ydCB7XG4gIG1lc3NhZ2VGcm9tUXVlcnlFdmVudCxcbiAgbWVzc2FnZUZyb21SZXNwb25zZSxcbiAgbWVzc2FnZUZyb21TdWdnZXN0aW9uRXZlbnQsXG59IGZyb20gJ3NyYy9hcHBsaWNhdGlvbi91dGlscyc7XG5pbXBvcnQge1xuICBNZXNzYWdlLFxuICBOZXh0TWVzc2FnZVJlcXVlc3QsXG4gIFJlc3BvbnNlLFxuICBTdWdnZXN0aW9uLFxuICBTdXBwb3J0ZWRFdmVudFJlcXVlc3QsXG4gIFVzZXJFdmVudCxcbn0gZnJvbSAnc3JjL2FwcGxpY2F0aW9uL21vZGVscyc7XG5pbXBvcnQgeyBtZXNzYWdlUmVxdWVzdFRvQ29tbWVyY2VNZXNzYWdlUmVxdWVzdCB9IGZyb20gJ3NyYy9hcHBsaWNhdGlvbi91dGlscy9uZXh0TWVzc2FnZVJlcXVlc3RUb0FwaVJlcXVlc3QnO1xuaW1wb3J0IHsgdmFsaWRhdGVSZXNwb25zZSB9IGZyb20gJ3NyYy9hcHBsaWNhdGlvbi9tb2RlbHMvdmFsaWRhdG9ycy92YWxpZGF0ZVJlc3BvbnNlJztcbmltcG9ydCB7IGNvcmVTdXBwb3J0ZWRFdmVudFJlcXVlc3RUb0FwaVJlcXVlc3QgfSBmcm9tICdzcmMvYXBwbGljYXRpb24vdXRpbHMvc3VwcG9ydGVkRXZlbnRSZXF1ZXN0VG9BcGlSZXF1ZXN0JztcbmltcG9ydCB7IFNlc3Npb25SZXN0YXJ0UmVxdWlyZWQgfSBmcm9tICdzcmMvdHlwZXMvZXhjZXB0aW9ucy9zZXNzaW9uRXhjZXB0aW9ucyc7XG5pbXBvcnQgeyBVbnN1cHBvcnRlZFByb2R1Y3RFeGNlcHRpb24gfSBmcm9tICdzcmMvdHlwZXMvZXhjZXB0aW9ucy91bnN1cHBvcnRlZFByb2R1Y3RFeGNlcHRpb25zJztcbmltcG9ydCB7IENsaWVudERldGFpbHMgfSBmcm9tICdzcmMvYXBwbGljYXRpb24vbW9kZWxzL2NsaWVudERldGFpbHMnO1xuaW1wb3J0IHsgZ2V0QXRvbVN0b3JlIH0gZnJvbSAnc3JjL2F0b21zL2F0b21TdG9yZS9hdG9tU3RvcmUnO1xuaW1wb3J0IHsgUHJvZHVjdEV4cGVyaW1lbnQgfSBmcm9tICdzcmMvYXBwbGljYXRpb24vbW9kZWxzL3Byb2R1Y3RFeHBlcmltZW50JztcbmltcG9ydCB7IEZlYXR1cmVHYXRlcyB9IGZyb20gJ3NyYy9hcHBsaWNhdGlvbi9tb2RlbHMvZmVhdHVyZUdhdGVzJztcbmltcG9ydCB7IHZhbGlkYXRlT3JnQ29uZmlnUmVzdWx0cyB9IGZyb20gJ3NyYy9hcHBsaWNhdGlvbi9tb2RlbHMvdmFsaWRhdG9ycy92YWxpZGF0ZU9yZ0NvbmZpZ1Jlc3VsdHMnO1xuaW1wb3J0IHsgT3JnQ29uZmlnIH0gZnJvbSAnc3JjL2FwcGxpY2F0aW9uL21vZGVscy9hcGkvb3JnQ29uZmlnUmVzdWx0cyc7XG5pbXBvcnQgeyBTdXBwb3J0ZWRFdmVudCB9IGZyb20gJ3NyYy9hdG9tcy9hcHAvdmFyaWFudCc7XG5pbXBvcnQgeyBtZXNzYWdlRnJvbUZvcm1TdWJtaXR0ZWRFdmVudCB9IGZyb20gJ3NyYy9hcHBsaWNhdGlvbi91dGlscy9tZXNzYWdlRnJvbUZvcm1TdWJtaXR0ZWRFdmVudCc7XG5pbXBvcnQgdHlwZSB7IENvbnRleHQgfSBmcm9tICdAc3BpZmZ5LWFpL2NvbW1lcmNlLWFwaS1jbGllbnQvZGlzdC9tb2RlbHMvQ29udGV4dCc7XG5pbXBvcnQgeyBDb250ZXh0RW52RW51bSB9IGZyb20gJ0BzcGlmZnktYWkvY29tbWVyY2UtYXBpLWNsaWVudCc7IC8vIEltcG9ydCBDb250ZXh0RW52RW51bVxuaW1wb3J0IHtcbiAgYmFzZVVybEF0b20sXG4gIHJlYWN0QXBwTmFtZUF0b20sXG4gIGNvbnRleHRTb3VyY2VBdG9tLFxuICBvcmdTaG9ydE5hbWVBdG9tLFxuICBlbnZBdG9tLCAvLyBJbXBvcnQgZW52QXRvbVxufSBmcm9tICdzcmMvYXRvbXMvZW52aXZlL2Vudml2ZUNvbmZpZyc7XG5pbXBvcnQgeyB1c2VySWRBdG9tLCBjaGF0SWRBdG9tIH0gZnJvbSAnc3JjL2F0b21zL2FwcCc7IC8vIEltcG9ydCB1c2VySWRBdG9tIGFuZCBjaGF0SWRBdG9tXG5pbXBvcnQgeyBvcmdJZEF0b20sIGZlYXR1cmVGbGFnU2VydmljZUF0b20gfSBmcm9tICdzcmMvYXRvbXMvb3JnL2dyYXBocWxDb25maWcnOyAvLyBJbXBvcnQgbmV3IG9yZ0lkQXRvbSBhbmQgZmVhdHVyZUZsYWdTZXJ2aWNlQXRvbVxuXG5hc3luYyBmdW5jdGlvbiBlcnJvclJlc3BvbnNlQm9keShlcnJvcjogUmVzcG9uc2VFcnJvcikge1xuICB0cnkge1xuICAgIHJldHVybiBhd2FpdCBlcnJvci5yZXNwb25zZS5qc29uKCk7XG4gIH0gY2F0Y2gge1xuICAgIHJldHVybiB7fTtcbiAgfVxufVxuXG5hc3luYyBmdW5jdGlvbiB0aHJvd1Nlc3Npb25SZXN0YXJ0UmVxdWlyZWRJZihlcnJvck1zZzogc3RyaW5nLCBlcnJvcjogdW5rbm93bikge1xuICBpZiAoIShlcnJvciBpbnN0YW5jZW9mIFJlc3BvbnNlRXJyb3IpKSB7XG4gICAgTG9nZ2VyLmxvZ0luZm8oZXJyb3JNc2csIGVycm9yKTtcbiAgICB0aHJvdyBlcnJvcjtcbiAgfVxuXG4gIGNvbnN0IGVycm9yUmVzcG9uc2UgPSBhd2FpdCBlcnJvclJlc3BvbnNlQm9keShlcnJvcik7XG4gIGlmIChcbiAgICBlcnJvclJlc3BvbnNlPy5tZXNzYWdlPy50b0xvd2VyQ2FzZSgpID09PSAndW5zdXBwb3J0ZWQgcHJvZHVjdCcgfHwgLy8gZm9yIGJhY2t3YXJkIGNvbXBhdGliaWxpdHkuIG5ld2VyIHZlcnNpb25zIG9mIHRoZSBBUEkgcmV0dXJuIHN1Yl9jb2RlIGluc3RlYWQgb2YgbWVzc2FnZVxuICAgIGVycm9yUmVzcG9uc2U/LmFwcF9jb2RlPy50b1VwcGVyQ2FzZSgpID09PSAnUFJPRFVDVF9OT1RfRk9VTkQnXG4gICkge1xuICAgIHRocm93IG5ldyBVbnN1cHBvcnRlZFByb2R1Y3RFeGNlcHRpb24oKTtcbiAgfSBlbHNlIGlmIChcbiAgICBlcnJvclJlc3BvbnNlPy5hcHBfY29kZT8udG9VcHBlckNhc2UoKSA9PT0gJ1JFU1RBUlRfU0VTU0lPTicgfHxcbiAgICBlcnJvclJlc3BvbnNlPy5zdWJfY29kZT8udG9VcHBlckNhc2UoKSA9PT0gJ05PVF9GT1VORCcgLy8gZm9yIGJhY2t3YXJkIGNvbXBhdGliaWxpdHkuIG5ldyBBUEkgcmVzcG9uc2VzIHdpbGwgY29udGFpbiBcImFwcF9jb2RlXCJcbiAgKSB7XG4gICAgTG9nZ2VyLmxvZ0luZm8oXG4gICAgICAnU2Vzc2lvbiBkb2VzIG5vdCBleGlzdC4gUmUtc3RhcnQgc2Vzc2lvbicsXG4gICAgICBlcnJvcixcbiAgICAgIGVycm9yLnJlc3BvbnNlLFxuICAgICAgZXJyb3JSZXNwb25zZSxcbiAgICApO1xuICAgIHRocm93IG5ldyBTZXNzaW9uUmVzdGFydFJlcXVpcmVkKCk7XG4gIH1cblxuICBMb2dnZXIubG9nSW5mbyhlcnJvck1zZywgZXJyb3IpO1xuICB0aHJvdyBlcnJvcjtcbn1cblxuY2xhc3MgQ29tbWVyY2VBcGlDbGllbnQge1xuICBwcml2YXRlIHJlYWRvbmx5IGRlZmF1bHRBcGk6IERlZmF1bHRBcGk7XG5cbiAgcHJpdmF0ZSByZWFkb25seSBjdXN0b21lclNlcnZpY2VBcGk6IEN1c3RvbWVyU2VydmljZUFwaTtcblxuICBwcml2YXRlIHJlYWRvbmx5IGluZmVyZW5jZUFwaTogSW5mZXJlbmNlQXBpO1xuXG4gIHByaXZhdGUgc3RhdGljIGluc3RhbmNlOiBDb21tZXJjZUFwaUNsaWVudCB8IHVuZGVmaW5lZDtcblxuICBwcml2YXRlIHN1Z2dlc3Rpb25zQWJvcnRDb250cm9sbGVyID0gbmV3IEFib3J0Q29udHJvbGxlcigpO1xuXG4gIHByaXZhdGUgcmVzcG9uc2VzQWJvcnRDb250cm9sbGVyID0gbmV3IEFib3J0Q29udHJvbGxlcigpO1xuXG4gIHByaXZhdGUgc3RhdGljIGdldEluc3RhbmNlID0gKCk6IENvbW1lcmNlQXBpQ2xpZW50ID0+IHtcbiAgICBpZiAoIUNvbW1lcmNlQXBpQ2xpZW50Lmluc3RhbmNlKSB7XG4gICAgICBDb21tZXJjZUFwaUNsaWVudC5pbnN0YW5jZSA9IG5ldyBDb21tZXJjZUFwaUNsaWVudCgpO1xuICAgIH1cblxuICAgIHJldHVybiBDb21tZXJjZUFwaUNsaWVudC5pbnN0YW5jZTtcbiAgfTtcblxuICBwcml2YXRlIGNvbnN0cnVjdG9yKGJhc2VQYXRoPzogc3RyaW5nKSB7XG4gICAgY29uc3QgYXRvbVN0b3JlID0gZ2V0QXRvbVN0b3JlKCk7XG4gICAgY29uc3QgYmFzZVVybCA9IGF0b21TdG9yZS5nZXQoYmFzZVVybEF0b20pO1xuICAgIGNvbnN0IHBhdGggPSBiYXNlUGF0aCB8fCBiYXNlVXJsO1xuICAgIC8vIEFQSSBLZXkgaXMgbm93IGhhbmRsZWQgYXQgdGhlIEVudml2ZUNvbmZpZ1Byb3ZpZGVyIGxldmVsXG4gICAgY29uc3QgY29uZmlnOiBDb25maWd1cmF0aW9uID0gbmV3IENvbmZpZ3VyYXRpb24oe1xuICAgICAgYmFzZVBhdGg6IHBhdGgsXG4gICAgICBoZWFkZXJzOiB7XG4gICAgICAgICdDb250ZW50LVR5cGUnOiAnYXBwbGljYXRpb24vanNvbicsXG4gICAgICAgIEFjY2VwdDogJ2FwcGxpY2F0aW9uL2pzb24nLFxuICAgICAgfSxcbiAgICB9KTtcbiAgICB0aGlzLmRlZmF1bHRBcGkgPSBuZXcgRGVmYXVsdEFwaShjb25maWcpO1xuICAgIHRoaXMuaW5mZXJlbmNlQXBpID0gbmV3IEluZmVyZW5jZUFwaShjb25maWcpO1xuICAgIHRoaXMuY3VzdG9tZXJTZXJ2aWNlQXBpID0gbmV3IEN1c3RvbWVyU2VydmljZUFwaShjb25maWcpO1xuICB9XG5cbiAgc3RhdGljIHJlc29sdmVVcmwgPSBhc3luYyAodXJsOiBzdHJpbmcpID0+IHtcbiAgICBjb25zdCBhdG9tU3RvcmUgPSBnZXRBdG9tU3RvcmUoKTtcbiAgICBjb25zdCBvcmdTaG9ydE5hbWUgPSBhdG9tU3RvcmUuZ2V0KG9yZ1Nob3J0TmFtZUF0b20pO1xuICAgIGNvbnN0IG9yZ0lkID0gYXRvbVN0b3JlLmdldChvcmdJZEF0b20pO1xuICAgIGNvbnN0IHVzZXJJZCA9IGF0b21TdG9yZS5nZXQodXNlcklkQXRvbSk7XG4gICAgY29uc3QgY2hhdElkID0gYXRvbVN0b3JlLmdldChjaGF0SWRBdG9tKTtcbiAgICBjb25zdCBzb3VyY2UgPSBhdG9tU3RvcmUuZ2V0KGNvbnRleHRTb3VyY2VBdG9tKTtcbiAgICBjb25zdCBlbnYgPSBhdG9tU3RvcmUuZ2V0KGVudkF0b20pO1xuXG4gICAgY29uc3QgZmVhdHVyZUZsYWdTZXJ2aWNlID0gYXRvbVN0b3JlLmdldChmZWF0dXJlRmxhZ1NlcnZpY2VBdG9tKTtcblxuICAgIGNvbnN0IGNvbnRleHQ6IENvbnRleHQgPSB7XG4gICAgICB1c2VyX2lkOiB1c2VySWQgPz8gJycsXG4gICAgICBvcmdfaWQ6IG9yZ0lkID8/ICcnLFxuICAgICAgb3JnX3Nob3J0X25hbWU6IG9yZ1Nob3J0TmFtZSA/PyAnJyxcbiAgICAgIGNoYXRfaWQ6IGNoYXRJZCA/PyAnJyxcbiAgICAgIHNvdXJjZTogc291cmNlID8/IENvbnRleHRTb3VyY2VFbnVtLkFwcCxcbiAgICAgIGVudjogKGVudiBhcyBDb250ZXh0RW52RW51bSkgPz8gQ29udGV4dEVudkVudW0uRGV2LCAvLyBDYXN0IGVudiB0byBDb250ZXh0RW52RW51bVxuICAgIH07XG5cbiAgICBjb25zdCBmZWF0dXJlR2F0ZXMgPSBmZWF0dXJlRmxhZ1NlcnZpY2U/LmZlYXR1cmVGbGFnU2VydmljZT8uZ2V0RmVhdHVyZUZsYWdzKCkgfHwge307XG4gICAgY29uc3QgdXJsUmVzb2x2aW5nUmVxdWVzdCA9IHtcbiAgICAgIHVybCxcbiAgICAgIGNvbnRleHQsXG4gICAgICBmZWF0dXJlX2dhdGVzOiBmZWF0dXJlR2F0ZXMsXG4gICAgfTtcblxuICAgIGNvbnN0IHJhd1Jlc3BvbnNlID0gYXdhaXQgQ29tbWVyY2VBcGlDbGllbnQuZ2V0SW5zdGFuY2UoKS5pbmZlcmVuY2VBcGkudjFVcmxSZXNvbHZpbmdQb3N0UmF3KHtcbiAgICAgIFVybFJlc29sdmluZ1JlcXVlc3Q6IHVybFJlc29sdmluZ1JlcXVlc3QsXG4gICAgfSk7XG5cbiAgICBjb25zdCByZXNwb25zZUJvZHkgPSBhd2FpdCByYXdSZXNwb25zZS5yYXcuanNvbigpO1xuXG4gICAgcmV0dXJuIHJlc3BvbnNlQm9keTtcbiAgfTtcblxuICBzdGF0aWMgcmVwb3J0U2Vzc2lvbiA9IGFzeW5jIChyZXBvcnRSZXF1ZXN0OiBSZXBvcnRTZXNzaW9uUmVxdWVzdCk6IFByb21pc2U8dm9pZD4gPT4ge1xuICAgIGF3YWl0IENvbW1lcmNlQXBpQ2xpZW50LmdldEluc3RhbmNlKCkuZGVmYXVsdEFwaS52MUNoYXRzUmVwb3J0U2Vzc2lvbklkUG9zdCh7XG4gICAgICBSZXBvcnRTZXNzaW9uUmVxdWVzdDogcmVwb3J0UmVxdWVzdCxcbiAgICB9KTtcbiAgfTtcblxuICBzdGF0aWMgZ2V0TmV4dFJlc3BvbnNlcyA9IGFzeW5jIChwYXlsb2FkOiBOZXh0TWVzc2FnZVJlcXVlc3QpOiBQcm9taXNlPE1lc3NhZ2VbXT4gPT4ge1xuICAgIHRyeSB7XG4gICAgICBjb25zdCByZXNwb25zZSA9IGF3YWl0IENvbW1lcmNlQXBpQ2xpZW50LmdldEluc3RhbmNlKCkuaW5mZXJlbmNlQXBpLnYxTmV4dFJlc3BvbnNlc1Bvc3Qoe1xuICAgICAgICBOZXh0TWVzc2FnZVJlcXVlc3Q6IG1lc3NhZ2VSZXF1ZXN0VG9Db21tZXJjZU1lc3NhZ2VSZXF1ZXN0KHBheWxvYWQpLFxuICAgICAgfSk7XG4gICAgICBjb25zdCBtZXNzYWdlcyA9IHJlc3BvbnNlXG4gICAgICAgIC5tYXAocmVzcCA9PiB2YWxpZGF0ZVJlc3BvbnNlKHJlc3ApKVxuICAgICAgICAubWFwKHJlc3AgPT4gbWVzc2FnZUZyb21SZXNwb25zZShyZXNwKSk7XG5cbiAgICAgIHJldHVybiBtZXNzYWdlcy5maWx0ZXIoKG0pOiBtIGlzIE1lc3NhZ2UgPT4gbSAhPSBudWxsKTtcbiAgICB9IGNhdGNoIChlcnI6IHVua25vd24pIHtcbiAgICAgIExvZ2dlci5sb2dJbmZvKCdGYWlsZWQgdG8gZ2V0IG5leHQgcmVzcG9uc2VzJywgZXJyLCB7XG4gICAgICAgIHBheWxvYWRDb250ZXh0OiBwYXlsb2FkPy5jb250ZXh0LFxuICAgICAgICB1c2VyRXZlbnRzOiBwYXlsb2FkPy51c2VyRXZlbnRzLFxuICAgICAgfSk7XG4gICAgICBhd2FpdCB0aHJvd1Nlc3Npb25SZXN0YXJ0UmVxdWlyZWRJZignRmFpbGVkIHRvIGdldCBuZXh0IHJlc3BvbnNlcycsIGVycik7XG4gICAgICByZXR1cm4gW107XG4gICAgfVxuICB9O1xuXG4gIHN0YXRpYyBnZXROZXh0UmVzcG9uc2VTdHJlYW1pbmcgPSAoXG4gICAgcGF5bG9hZDogTmV4dE1lc3NhZ2VSZXF1ZXN0LFxuICApOiBBc3luY0dlbmVyYXRvcjxSZXNwb25zZSwgdm9pZCwgdW5rbm93bj4gPT4ge1xuICAgIGFzeW5jIGZ1bmN0aW9uKiBnZW5lcmF0ZShpbmZlcmVuY2VBcGk6IEluZmVyZW5jZUFwaSwgYWJvcnRDb250cm9sbGVyOiBBYm9ydENvbnRyb2xsZXIpIHtcbiAgICAgIC8vIG1ha2Ugc3VyZSBzdHJlYW1pbmcgaXMgZW5hYmxlZFxuICAgICAgdHJ5IHtcbiAgICAgICAgY29uc3QgcmVzcG9uc2UgPSBhd2FpdCBpbmZlcmVuY2VBcGkudjFOZXh0UmVzcG9uc2VzUG9zdFJhdyhcbiAgICAgICAgICB7XG4gICAgICAgICAgICBOZXh0TWVzc2FnZVJlcXVlc3Q6IG1lc3NhZ2VSZXF1ZXN0VG9Db21tZXJjZU1lc3NhZ2VSZXF1ZXN0KHBheWxvYWQpLFxuICAgICAgICAgIH0sXG4gICAgICAgICAgeyBzaWduYWw6IGFib3J0Q29udHJvbGxlci5zaWduYWwgfSxcbiAgICAgICAgKTtcblxuICAgICAgICAvLyBSZWFkIHRoZSByZXNwb25zZSBhcyBhIHN0cmVhbSBvZiBkYXRhXG4gICAgICAgIGlmICghcmVzcG9uc2UucmF3LmJvZHkpIHtcbiAgICAgICAgICBMb2dnZXIubG9nRXJyb3IoJ1tzcGlmZnktYWldIE5vIGJvZHkgaW4gdGhlIHN0cmVhbWVkIHJlc3BvbnNlJywgdW5kZWZpbmVkLCB7XG4gICAgICAgICAgICByZXNwb25zZTogcmVzcG9uc2UucmF3LFxuICAgICAgICAgIH0pO1xuICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuXG4gICAgICAgIGNvbnN0IHJlYWRlciA9IHJlc3BvbnNlLnJhdy5ib2R5LmdldFJlYWRlcigpO1xuICAgICAgICBjb25zdCBkZWNvZGVyID0gbmV3IFRleHREZWNvZGVyKCd1dGYtOCcpO1xuXG4gICAgICAgIGxldCBwYXJ0aWFsID0gJyc7XG4gICAgICAgIC8vIFRPRE8gdGhpcyBmdW5jdGlvbiBpcyByZWNyZWF0ZWQgZXZlcnkgdGltZSBuZXcgZGF0YSBjb21lcyBmcm9tIHRoZSBzdHJlYW0gLSBkZWZpbmUgaXQgb3V0c2lkZSBvZiB0aGUgZ2VuZXJhdG9yXG4gICAgICAgIGNvbnN0IHNhZmVQYXJzZSA9IChsaW5lOiBzdHJpbmcpOiB1bmtub3duID0+IHtcbiAgICAgICAgICB0cnkge1xuICAgICAgICAgICAgcmV0dXJuIEpTT04ucGFyc2UobGluZSk7IC8vIFBhcnNlIHRoZSBKU09OIHN0cmluZ1xuICAgICAgICAgIH0gY2F0Y2ggKGVycikge1xuICAgICAgICAgICAgTG9nZ2VyLmxvZ0Vycm9yKCdbc3BpZmZ5LWFpXSBFcnJvciBwYXJzaW5nIHN0cmVhbWVkIGxpbmUnLCBlcnIsIHtcbiAgICAgICAgICAgICAgbGluZSxcbiAgICAgICAgICAgICAgcGFydGlhbCxcbiAgICAgICAgICAgIH0pO1xuICAgICAgICAgICAgLy8gc3dhbGxvdyB0aGUgZXJyb3IgYW5kIHNldCB0aGUgcGFydGlhbCB0byBvdXIgY3VycmVudCBjaHVua1xuICAgICAgICAgICAgcGFydGlhbCA9IGxpbmU7XG4gICAgICAgICAgICByZXR1cm4gcGFydGlhbDtcbiAgICAgICAgICB9XG4gICAgICAgIH07XG5cbiAgICAgICAgLy8gVE9ETyB0aGlzIGZ1bmN0aW9uIGlzIHJlY3JlYXRlZCBldmVyeSB0aW1lIG5ldyBkYXRhIGNvbWVzIGZyb20gdGhlIHN0cmVhbSAtIGRlZmluZSBpdCBvdXRzaWRlIG9mIHRoZSBnZW5lcmF0b3JcbiAgICAgICAgY29uc3QgcHJvY2Vzc0NodW5rID0gKGNodW5rOiBzdHJpbmcpOiB1bmtub3duW10gPT4ge1xuICAgICAgICAgIC8vIG1lcmdlIHRoZSBwYXJ0aWFsIHdpdGggdGhlIGluY29taW5nIGNodW5rXG4gICAgICAgICAgY29uc3QgbGluZXMgPSBgJHtwYXJ0aWFsfSR7Y2h1bmt9YC5zcGxpdCgnXFxuJyk7XG5cbiAgICAgICAgICBjb25zdCBwYXJzZWRMaW5lcyA9IGxpbmVzXG4gICAgICAgICAgICAubWFwKGxpbmUgPT4gbGluZS5yZXBsYWNlKC9eZGF0YTogLywgJycpLnRyaW0oKSkgLy8gUmVtb3ZlIHRoZSBcImRhdGE6IFwiIHByZWZpeFxuICAgICAgICAgICAgLmZpbHRlcihsaW5lID0+IGxpbmUgIT09ICcnICYmIGxpbmUgIT09ICdbRE9ORV0nKSAvLyBSZW1vdmUgZW1wdHkgbGluZXMgYW5kIFwiW0RPTkVdXCJcbiAgICAgICAgICAgIC5tYXAoc2FmZVBhcnNlKVxuICAgICAgICAgICAgLmZpbHRlcih2ID0+IHYpOyAvLyBhbmQgZmlsdGVyIG91dCB0aGUgdW5kZWZpbmVkIHZhbHVlc1xuICAgICAgICAgIHJldHVybiBwYXJzZWRMaW5lcztcbiAgICAgICAgfTtcblxuICAgICAgICB3aGlsZSAodHJ1ZSkge1xuICAgICAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby1hd2FpdC1pbi1sb29wXG4gICAgICAgICAgY29uc3QgeyBkb25lLCB2YWx1ZSB9ID0gYXdhaXQgcmVhZGVyLnJlYWQoKTtcblxuICAgICAgICAgIGlmIChkb25lKSB7XG4gICAgICAgICAgICBicmVhaztcbiAgICAgICAgICB9XG5cbiAgICAgICAgICAvLyBNYXNzYWdlIGFuZCBwYXJzZSB0aGUgY2h1bmsgb2YgZGF0YVxuICAgICAgICAgIGNvbnN0IGNodW5rID0gZGVjb2Rlci5kZWNvZGUodmFsdWUpO1xuICAgICAgICAgIGNvbnN0IHBhcnNlZExpbmVzID0gcHJvY2Vzc0NodW5rKGNodW5rKTtcblxuICAgICAgICAgIGZvciAoY29uc3QgcGFyc2VkTGluZSBvZiBwYXJzZWRMaW5lcykge1xuICAgICAgICAgICAgY29uc3QgdmFsaWRhdGVkUmVzcG9uc2UgPSB2YWxpZGF0ZVJlc3BvbnNlKHBhcnNlZExpbmUpO1xuXG4gICAgICAgICAgICBpZiAodmFsaWRhdGVkUmVzcG9uc2UpIHtcbiAgICAgICAgICAgICAgeWllbGQgdmFsaWRhdGVkUmVzcG9uc2U7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICB9IGNhdGNoIChlcnJvcjogdW5rbm93bikge1xuICAgICAgICBMb2dnZXIubG9nRXJyb3IoJ1tzcGlmZnktYWldIEZhaWxlZCB0byBnZXQgbmV4dCBzdHJlYW1pbmcgcmVzcG9uc2VzJywgZXJyb3IsIHtcbiAgICAgICAgICBwYXlsb2FkQ29udGV4dDogcGF5bG9hZD8uY29udGV4dCxcbiAgICAgICAgICB1c2VyRXZlbnRzOiBwYXlsb2FkPy51c2VyRXZlbnRzLFxuICAgICAgICB9KTtcbiAgICAgICAgYXdhaXQgdGhyb3dTZXNzaW9uUmVzdGFydFJlcXVpcmVkSWYoJ0ZhaWxlZCB0byBnZXQgbmV4dCBzdHJlYW1pbmcgcmVzcG9uc2VzJywgZXJyb3IpO1xuICAgICAgfVxuICAgIH1cblxuICAgIENvbW1lcmNlQXBpQ2xpZW50LmdldEluc3RhbmNlKCkucmVzcG9uc2VzQWJvcnRDb250cm9sbGVyLmFib3J0KCk7XG4gICAgQ29tbWVyY2VBcGlDbGllbnQuZ2V0SW5zdGFuY2UoKS5yZXNwb25zZXNBYm9ydENvbnRyb2xsZXIgPSBuZXcgQWJvcnRDb250cm9sbGVyKCk7XG5cbiAgICByZXR1cm4gZ2VuZXJhdGUoXG4gICAgICBDb21tZXJjZUFwaUNsaWVudC5nZXRJbnN0YW5jZSgpLmluZmVyZW5jZUFwaSxcbiAgICAgIENvbW1lcmNlQXBpQ2xpZW50LmdldEluc3RhbmNlKCkucmVzcG9uc2VzQWJvcnRDb250cm9sbGVyLFxuICAgICk7XG4gIH07XG5cbiAgc3RhdGljIGdldE5leHRTdWdnZXN0aW9ucyA9IGFzeW5jIChwYXlsb2FkOiBOZXh0TWVzc2FnZVJlcXVlc3QpOiBQcm9taXNlPFN1Z2dlc3Rpb25bXT4gPT4ge1xuICAgIHRyeSB7XG4gICAgICBDb21tZXJjZUFwaUNsaWVudC5nZXRJbnN0YW5jZSgpLnN1Z2dlc3Rpb25zQWJvcnRDb250cm9sbGVyLmFib3J0KCk7XG4gICAgICBDb21tZXJjZUFwaUNsaWVudC5nZXRJbnN0YW5jZSgpLnN1Z2dlc3Rpb25zQWJvcnRDb250cm9sbGVyID0gbmV3IEFib3J0Q29udHJvbGxlcigpO1xuXG4gICAgICBjb25zdCByZXNwb25zZSA9IGF3YWl0IENvbW1lcmNlQXBpQ2xpZW50LmdldEluc3RhbmNlKCkuaW5mZXJlbmNlQXBpLnYxTmV4dFN1Z2dlc3Rpb25zUG9zdChcbiAgICAgICAge1xuICAgICAgICAgIE5leHRNZXNzYWdlUmVxdWVzdDogbWVzc2FnZVJlcXVlc3RUb0NvbW1lcmNlTWVzc2FnZVJlcXVlc3QocGF5bG9hZCksXG4gICAgICAgIH0sXG4gICAgICAgIHtcbiAgICAgICAgICBzaWduYWw6IENvbW1lcmNlQXBpQ2xpZW50LmdldEluc3RhbmNlKCkuc3VnZ2VzdGlvbnNBYm9ydENvbnRyb2xsZXIuc2lnbmFsLFxuICAgICAgICB9LFxuICAgICAgKTtcblxuICAgICAgY29uc3Qgc3VnZ2VzdGlvbnMgPSByZXNwb25zZVxuICAgICAgICAubWFwKHJlc3AgPT4gdmFsaWRhdGVTdWdnZXN0aW9uKHJlc3ApKVxuICAgICAgICAuZmlsdGVyKChzdWdnZXN0aW9uKTogc3VnZ2VzdGlvbiBpcyBTdWdnZXN0aW9uID0+IHN1Z2dlc3Rpb24gIT0gbnVsbCk7XG5cbiAgICAgIHJldHVybiBzdWdnZXN0aW9ucztcbiAgICB9IGNhdGNoIChlcnJvcjogdW5rbm93bikge1xuICAgICAgTG9nZ2VyLmxvZ0luZm8oJ0ZhaWxlZCB0byBnZXQgc3VnZ2VzdGlvbnMnLCBlcnJvciwge1xuICAgICAgICBwYXlsb2FkQ29udGV4dDogcGF5bG9hZD8uY29udGV4dCxcbiAgICAgICAgdXNlckV2ZW50czogcGF5bG9hZD8udXNlckV2ZW50cyxcbiAgICAgIH0pO1xuXG4gICAgICBhd2FpdCB0aHJvd1Nlc3Npb25SZXN0YXJ0UmVxdWlyZWRJZignRmFpbGVkIHRvIGdldCBzdWdnZXN0aW9ucycsIGVycm9yKTtcbiAgICAgIHJldHVybiBbXTtcbiAgICB9XG4gIH07XG5cbiAgLyoqXG4gICAqIEZldGNoZXMgdGhlIGV4aXN0aW5nIGNoYXQgZGF0YSBmb3IgYSBnaXZlbiBzZXNzaW9uIGFuZCB0cmFuc2Zvcm1zIHRoZW0gdG8gcmVjb25zdHJ1Y3QgdGhlIGNoYXQgaGlzdG9yeS5cbiAgICpcbiAgICogQHBhcmFtIG9yZ0lkIFRoZSBvcmdhbml6YXRpb24gSWRcbiAgICogQHBhcmFtIGNoYXRJZCBUaGUgZXhpc3RpbmcgY2hhdCBJZFxuICAgKiBAcGFyYW0gdXNlcklkIFRoZSB1c2VyIElkXG4gICAqXG4gICAqIEByZXR1cm5zIEEgbGlzdCBvZiBtZXNzYWdlcyB0aGF0IHdlcmUgZXhjaGFuZ2VkIGluIHRoZSBjaGF0LCB0aHJvd3MgYW4gZXJyb3IgaWYgdGhlIGNoYXQgc2Vzc2lvbiBoYXMgZXhwaXJlZC5cbiAgICovXG4gIHN0YXRpYyBnZXRSZXNwb25zZXMgPSBhc3luYyAoXG4gICAgb3JnSWQ6IHN0cmluZyxcbiAgICBjaGF0SWQ6IHN0cmluZyxcbiAgICB1c2VySWQ6IHN0cmluZyxcbiAgKTogUHJvbWlzZTx7XG4gICAgcmVzcG9uc2VzOiBSZXNwb25zZVtdW107XG4gICAgdXNlckV2ZW50czogVXNlckV2ZW50W107XG4gICAgc3VnZ2VzdGlvbnM6IFN1Z2dlc3Rpb25bXTtcbiAgICBtZXNzYWdlczogTWVzc2FnZVtdW107XG4gIH0+ID0+IHtcbiAgICBsZXQgZGF0YTogVjFHZXRTZXNzaW9uTWVzc2FnZXMyMDBSZXNwb25zZSA9IHtcbiAgICAgIHJlc3BvbnNlczogW10sXG4gICAgICBzdWdnZXN0aW9uczogW10sXG4gICAgICB1c2VyX2V2ZW50czogW10sXG4gICAgfTtcbiAgICBjb25zdCByZXF1ZXN0ID0ge1xuICAgICAgb3JnX2lkOiBvcmdJZCxcbiAgICAgIGNoYXRfaWQ6IGNoYXRJZCxcbiAgICAgIHVzZXJfaWQ6IHVzZXJJZCxcbiAgICB9O1xuICAgIHRyeSB7XG4gICAgICBkYXRhID0gYXdhaXQgQ29tbWVyY2VBcGlDbGllbnQuZ2V0SW5zdGFuY2UoKS5kZWZhdWx0QXBpLnYxR2V0U2Vzc2lvbk1lc3NhZ2VzKHJlcXVlc3QpO1xuICAgIH0gY2F0Y2ggKGVycm9yOiB1bmtub3duKSB7XG4gICAgICBhd2FpdCB0aHJvd1Nlc3Npb25SZXN0YXJ0UmVxdWlyZWRJZignRmFpbGVkIHRvIGdldCBjaGF0IHJlc3BvbnNlcycsIGVycm9yKTtcbiAgICB9XG5cbiAgICBjb25zdCByZXNwb25zZXM6IFJlc3BvbnNlW11bXSA9IGRhdGE/LnJlc3BvbnNlcz8ubWFwKHR1cm4gPT5cbiAgICAgIHR1cm5cbiAgICAgICAgLm1hcChyZXNwb25zZSA9PiB2YWxpZGF0ZVJlc3BvbnNlKHJlc3BvbnNlKSlcbiAgICAgICAgLmZpbHRlcigocmVzcG9uc2UpOiByZXNwb25zZSBpcyBSZXNwb25zZSA9PiByZXNwb25zZSAhPSBudWxsKSxcbiAgICApO1xuXG4gICAgY29uc3Qgc3VnZ2VzdGlvbnM6IFN1Z2dlc3Rpb25bXSA9IGRhdGE/LnN1Z2dlc3Rpb25zXG4gICAgICAubWFwKHN1Z2dlc3Rpb24gPT4gdmFsaWRhdGVTdWdnZXN0aW9uKHN1Z2dlc3Rpb24pKVxuICAgICAgLmZpbHRlcigoc3VnZ2VzdGlvbik6IHN1Z2dlc3Rpb24gaXMgU3VnZ2VzdGlvbiA9PiBzdWdnZXN0aW9uICE9IG51bGwpO1xuXG4gICAgY29uc3QgdXNlckV2ZW50czogVXNlckV2ZW50W10gPSBkYXRhPy51c2VyX2V2ZW50c1xuICAgICAgLm1hcChldmVudCA9PiB2YWxpZGF0ZVVzZXJFdmVudChldmVudCkpXG4gICAgICAuZmlsdGVyKChldmVudCk6IGV2ZW50IGlzIFVzZXJFdmVudCA9PiBldmVudCAhPSBudWxsKTtcblxuICAgIC8vIGlmIGEgZm9ybSBoYXMgYWxyZWFkeSBiZWVuIHN1Ym1pdHRlZCwgZG9uJ3Qgc2hvdyBpdCBpbiB0aGUgY2hhdCBoaXN0b3J5XG4gICAgY29uc3QgZm9ybVN1Ym1pdHRlZFVzZXJFdmVudHNGb3JtSWRzID0gdXNlckV2ZW50c1xuICAgICAgLmZpbHRlcihldmVudCA9PiBldmVudC5jYXRlZ29yeSA9PT0gVXNlckV2ZW50Q2F0ZWdvcnkuRm9ybVN1Ym1pdHRlZClcbiAgICAgIC5tYXAoZXZlbnQgPT4gZXZlbnQuYXR0cmlidXRlcy5mb3JtUmVzcG9uc2VJZCk7XG5cbiAgICBjb25zdCBhc3Npc3RhbnRNZXNzYWdlczogTWVzc2FnZVtdW10gPSByZXNwb25zZXNcbiAgICAgIC5tYXAodHVybiA9PlxuICAgICAgICB0dXJuXG4gICAgICAgICAgLmZpbHRlcihcbiAgICAgICAgICAgIHJlc3BvbnNlID0+XG4gICAgICAgICAgICAgICEoXG4gICAgICAgICAgICAgICAgcmVzcG9uc2UuY2F0ZWdvcnkgPT09IFJlc3BvbnNlQ2F0ZWdvcnkuRm9ybSAmJlxuICAgICAgICAgICAgICAgIGZvcm1TdWJtaXR0ZWRVc2VyRXZlbnRzRm9ybUlkcy5pbmNsdWRlcyhyZXNwb25zZS5pZClcbiAgICAgICAgICAgICAgKSxcbiAgICAgICAgICApXG4gICAgICAgICAgLm1hcChyZXNwb25zZSA9PiBtZXNzYWdlRnJvbVJlc3BvbnNlKHJlc3BvbnNlKSlcbiAgICAgICAgICAuZmlsdGVyKChtZXNzYWdlKTogbWVzc2FnZSBpcyBNZXNzYWdlID0+IG1lc3NhZ2UgIT0gbnVsbCksXG4gICAgICApXG4gICAgICAuZmlsdGVyKHR1cm4gPT4gdHVybi5sZW5ndGggPiAwKTtcblxuICAgIGNvbnN0IHVzZXJNZXNzYWdlczogTWVzc2FnZVtdW10gPSB1c2VyRXZlbnRzXG4gICAgICAubWFwKGV2ZW50ID0+IHtcbiAgICAgICAgaWYgKFtVc2VyRXZlbnRDYXRlZ29yeS5RdWVyeVR5cGVkLCBVc2VyRXZlbnRDYXRlZ29yeS5TZWFyY2hdLmluY2x1ZGVzKGV2ZW50LmNhdGVnb3J5KSkge1xuICAgICAgICAgIHJldHVybiBbbWVzc2FnZUZyb21RdWVyeUV2ZW50KGV2ZW50KV07XG4gICAgICAgIH1cblxuICAgICAgICBpZiAoZXZlbnQuY2F0ZWdvcnkgPT09IFVzZXJFdmVudENhdGVnb3J5LlN1Z2dlc3Rpb25DbGlja2VkKSB7XG4gICAgICAgICAgcmV0dXJuIFttZXNzYWdlRnJvbVN1Z2dlc3Rpb25FdmVudChldmVudCwgc3VnZ2VzdGlvbnMpXTtcbiAgICAgICAgfVxuXG4gICAgICAgIGlmIChldmVudC5jYXRlZ29yeSA9PT0gVXNlckV2ZW50Q2F0ZWdvcnkuRm9ybVN1Ym1pdHRlZCkge1xuICAgICAgICAgIGNvbnN0IGZvcm1SZXNwb25zZSA9IHJlc3BvbnNlc1xuICAgICAgICAgICAgLmZsYXQoKVxuICAgICAgICAgICAgLmZpbmQoXG4gICAgICAgICAgICAgIHJlc3BvbnNlID0+XG4gICAgICAgICAgICAgICAgcmVzcG9uc2UuaWQgPT09IGV2ZW50LmF0dHJpYnV0ZXMuZm9ybVJlc3BvbnNlSWQgJiZcbiAgICAgICAgICAgICAgICBldmVudC5hdHRyaWJ1dGVzLmZvcm1UeXBlICE9PSBGb3JtVHlwZS5Fc2NhbGF0aW9uLFxuICAgICAgICAgICAgKTtcblxuICAgICAgICAgIGlmIChmb3JtUmVzcG9uc2UgJiYgZm9ybVJlc3BvbnNlLmNhdGVnb3J5ID09PSBSZXNwb25zZUNhdGVnb3J5LkZvcm0pIHtcbiAgICAgICAgICAgIHJldHVybiBbbWVzc2FnZUZyb21Gb3JtU3VibWl0dGVkRXZlbnQoZXZlbnQsIGZvcm1SZXNwb25zZS5hdHRyaWJ1dGVzKV07XG4gICAgICAgICAgfVxuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIFtdO1xuICAgICAgfSlcbiAgICAgIC5maWx0ZXIoKG1lc3NhZ2UpOiBtZXNzYWdlIGlzIE1lc3NhZ2VbXSA9PiBtZXNzYWdlLmxlbmd0aCA+IDApO1xuXG4gICAgLy8gU29ydCB0aGUgbWVzc2FnZXMgY2hyb25vbG9naWNhbGx5IHRvIHJlY29uc3RydWN0IHRoZSBjaGF0IGhpc3RvcnlcbiAgICBjb25zdCBzb3J0ZWRNZXNzYWdlcyA9IFsuLi5hc3Npc3RhbnRNZXNzYWdlcywgLi4udXNlck1lc3NhZ2VzXS5zb3J0KFxuICAgICAgKGEsIGIpID0+IG5ldyBEYXRlKGFbMF0uY3JlYXRlZEF0KS5nZXRUaW1lKCkgLSBuZXcgRGF0ZShiWzBdLmNyZWF0ZWRBdCkuZ2V0VGltZSgpLFxuICAgICk7XG5cbiAgICByZXR1cm4geyByZXNwb25zZXMsIHVzZXJFdmVudHMsIHN1Z2dlc3Rpb25zLCBtZXNzYWdlczogc29ydGVkTWVzc2FnZXMgfTtcbiAgfTtcblxuICAvKipcbiAgICpcbiAgICogQHBhcmFtIHBheWxvYWRcbiAgICogQHJldHVybnNcbiAgICovXG4gIHN0YXRpYyBpc1N1cHBvcnRlZEV2ZW50ID0gYXN5bmMgKHBheWxvYWQ6IFN1cHBvcnRlZEV2ZW50UmVxdWVzdCk6IFByb21pc2U8U3VwcG9ydGVkRXZlbnQ+ID0+IHtcbiAgICB0cnkge1xuICAgICAgY29uc3QgcmF3UmVzcG9uc2UgPVxuICAgICAgICBhd2FpdCBDb21tZXJjZUFwaUNsaWVudC5nZXRJbnN0YW5jZSgpLmluZmVyZW5jZUFwaS52MVN1cHBvcnRlZEV2ZW50UG9zdFJhdyh7XG4gICAgICAgICAgU3VwcG9ydGVkRXZlbnRSZXF1ZXN0OiBjb3JlU3VwcG9ydGVkRXZlbnRSZXF1ZXN0VG9BcGlSZXF1ZXN0KHBheWxvYWQpLFxuICAgICAgICB9KTtcblxuICAgICAgLy8gR2V0IHRoZSBhY3R1YWwgSFRUUCByZXNwb25zZSBKU09OXG4gICAgICBjb25zdCBodHRwUmVzcG9uc2VUZXh0ID0gYXdhaXQgcmF3UmVzcG9uc2UucmF3LnRleHQoKTtcbiAgICAgIGNvbnN0IGh0dHBSZXNwb25zZUpzb24gPSBKU09OLnBhcnNlKGh0dHBSZXNwb25zZVRleHQpO1xuXG4gICAgICByZXR1cm4ge1xuICAgICAgICAuLi5odHRwUmVzcG9uc2VKc29uLFxuICAgICAgICBudW1iZXJPZlJldmlld3M6IGh0dHBSZXNwb25zZUpzb24ubnVtX29mX3Jldmlld3MsXG4gICAgICAgIG1lcmNoYW50X3RhZ3M6IGh0dHBSZXNwb25zZUpzb24ubWVyY2hhbnRfdGFncyB8fCBbXSxcbiAgICAgIH07XG4gICAgfSBjYXRjaCAoZXJyKSB7XG4gICAgICBMb2dnZXIubG9nRXJyb3IoJ0ZhaWxlZCB0byBnZXQgcmVzcG9uc2UgZm9yIHYxU3VwcG9ydGVkRXZlbnRQb3N0Jywge1xuICAgICAgICBlcnIsXG4gICAgICB9KTtcbiAgICAgIHJldHVybiB7XG4gICAgICAgIHN1cHBvcnRlZDogZmFsc2UsXG4gICAgICAgIHJlYWR5OiBmYWxzZSxcbiAgICAgICAgY2F0ZWdvcnk6IHVuZGVmaW5lZCxcbiAgICAgICAgY29sbGVjdGlvbnM6IFtdLFxuICAgICAgICBudW1iZXJPZlJldmlld3M6IHVuZGVmaW5lZCxcbiAgICAgICAgdG9wX2NhdGVnb3J5OiB1bmRlZmluZWQsXG4gICAgICAgIG1lcmNoYW50X3RhZ3M6IFtdLFxuICAgICAgfTtcbiAgICB9XG4gIH07XG5cbiAgc3RhdGljIGlkZW50aWZ5VXNlciA9IGFzeW5jIChcbiAgICBzcGlmZnlVc2VySWQ6IHN0cmluZyxcbiAgICBtZXJjaGFudFVzZXJJZDogc3RyaW5nLFxuICAgIHVhRGV0YWlsczogQ2xpZW50RGV0YWlscyxcbiAgKTogUHJvbWlzZTx2b2lkPiA9PiB7XG4gICAgdHJ5IHtcbiAgICAgIGF3YWl0IENvbW1lcmNlQXBpQ2xpZW50LmdldEluc3RhbmNlKCkuZGVmYXVsdEFwaS52MUFuYWx5dGljc0lkZW50aWZ5UG9zdCh7XG4gICAgICAgIEFuYWx5dGljc0lkZW50aWZ5UmVxdWVzdDoge1xuICAgICAgICAgIHVzZXJfaWQ6IHNwaWZmeVVzZXJJZCxcbiAgICAgICAgICBvc19uYW1lOiB1YURldGFpbHMub3MsXG4gICAgICAgICAgb3NfdmVyc2lvbjogdWFEZXRhaWxzLm9zVmVyc2lvbixcbiAgICAgICAgICBwbGF0Zm9ybTogdWFEZXRhaWxzLm9zLFxuICAgICAgICAgIGRldmljZV9pZDogdWFEZXRhaWxzLmRldmljZU1vZGVsLFxuICAgICAgICAgIGRldmljZV9icmFuZDogdWFEZXRhaWxzLmRldmljZUJyYW5kLFxuICAgICAgICAgIGRldmljZV9tYW51ZmFjdHVyZXI6IHVhRGV0YWlscy5kZXZpY2VNYW51ZmFjdHVyZXIsXG4gICAgICAgICAgZGV2aWNlX21vZGVsOiB1YURldGFpbHMuZGV2aWNlTW9kZWwsXG4gICAgICAgICAgdXNlcl9wcm9wZXJ0aWVzOiB7XG4gICAgICAgICAgICBjZHBfdXNlcl9pZDogbWVyY2hhbnRVc2VySWQsXG4gICAgICAgICAgICBicm93c2VyOiB1YURldGFpbHMuYnJvd3NlcixcbiAgICAgICAgICAgIGJyb3dzZXJfdmVyc2lvbjogdWFEZXRhaWxzLmJyb3dzZXJWZXJzaW9uLFxuICAgICAgICAgICAgdXNlcl9hZ2VudDogdWFEZXRhaWxzLnVzZXJBZ2VudCxcbiAgICAgICAgICB9LFxuICAgICAgICB9LFxuICAgICAgfSk7XG4gICAgfSBjYXRjaCAoZXJyKSB7XG4gICAgICBMb2dnZXIubG9nRXJyb3IoJ0ZhaWxlZCB0byBpZGVudGlmeSB1c2VyJywgZXJyKTtcbiAgICB9XG4gIH07XG5cbiAgcHJpdmF0ZSBzdGF0aWMgbWFwQ29udGV4dFNvdXJjZVRvVjFPcmdDb25maWdHZXRTb3VyY2UgPSAoXG4gICAgc291cmNlOiBDb250ZXh0U291cmNlRW51bSB8IHVuZGVmaW5lZCxcbiAgKTogVjFPcmdDb25maWdHZXRTb3VyY2VFbnVtIHwgdW5kZWZpbmVkID0+IHtcbiAgICBpZiAoc291cmNlID09PSB1bmRlZmluZWQpIHJldHVybiB1bmRlZmluZWQ7XG4gICAgc3dpdGNoIChzb3VyY2UpIHtcbiAgICAgIGNhc2UgQ29udGV4dFNvdXJjZUVudW0uRm9yazpcbiAgICAgICAgcmV0dXJuIFYxT3JnQ29uZmlnR2V0U291cmNlRW51bS5Gb3JrO1xuICAgICAgY2FzZSBDb250ZXh0U291cmNlRW51bS5QbGF5Z3JvdW5kOlxuICAgICAgICByZXR1cm4gVjFPcmdDb25maWdHZXRTb3VyY2VFbnVtLlBsYXlncm91bmQ7XG4gICAgICBjYXNlIENvbnRleHRTb3VyY2VFbnVtLkFwcDpcbiAgICAgICAgcmV0dXJuIFYxT3JnQ29uZmlnR2V0U291cmNlRW51bS5BcHA7XG4gICAgICBjYXNlIENvbnRleHRTb3VyY2VFbnVtLlRlc3Q6XG4gICAgICAgIHJldHVybiBWMU9yZ0NvbmZpZ0dldFNvdXJjZUVudW0uVGVzdDtcbiAgICAgIGNhc2UgQ29udGV4dFNvdXJjZUVudW0uRXZhbDpcbiAgICAgICAgcmV0dXJuIFYxT3JnQ29uZmlnR2V0U291cmNlRW51bS5UZXN0O1xuICAgICAgZGVmYXVsdDoge1xuICAgICAgICAvLyBUaGlzIGVuc3VyZXMgdGhhdCBpZiBuZXcgdmFsdWVzIGFyZSBhZGRlZCB0byBDb250ZXh0U291cmNlRW51bSwgd2UgY2F0Y2ggaXRcbiAgICAgICAgY29uc3QgZXhoYXVzdGl2ZUNoZWNrOiBuZXZlciA9IHNvdXJjZTtcbiAgICAgICAgcmV0dXJuIGV4aGF1c3RpdmVDaGVjaztcbiAgICAgIH1cbiAgICB9XG4gIH07XG5cbiAgc3RhdGljIGdldE9yZ0NvbmZpZyA9IGFzeW5jICh1c2VyX2lkOiBzdHJpbmcpOiBQcm9taXNlPE9yZ0NvbmZpZyB8IHVuZGVmaW5lZD4gPT4ge1xuICAgIHRyeSB7XG4gICAgICBjb25zdCBhdG9tU3RvcmUgPSBnZXRBdG9tU3RvcmUoKTtcbiAgICAgIGNvbnN0IHJlYWN0QXBwTmFtZSA9IGF0b21TdG9yZS5nZXQocmVhY3RBcHBOYW1lQXRvbSk7XG4gICAgICBjb25zdCBjb250ZXh0U291cmNlID0gYXRvbVN0b3JlLmdldChjb250ZXh0U291cmNlQXRvbSk7XG4gICAgICBjb25zdCBmZWF0dXJlRmxhZ1NlcnZpY2UgPSBhdG9tU3RvcmUuZ2V0KGZlYXR1cmVGbGFnU2VydmljZUF0b20pOyAvLyBHZXQgZmVhdHVyZUZsYWdTZXJ2aWNlXG4gICAgICBjb25zdCByZXF1ZXN0OiBWMU9yZ0NvbmZpZ0dldFJlcXVlc3QgPSB7XG4gICAgICAgIG5hbWVzcGFjZTogcmVhY3RBcHBOYW1lLFxuICAgICAgICB1c2VyX2lkLFxuICAgICAgICBzb3VyY2U6IHRoaXMubWFwQ29udGV4dFNvdXJjZVRvVjFPcmdDb25maWdHZXRTb3VyY2UoY29udGV4dFNvdXJjZSksXG4gICAgICAgIGluY2x1ZGVfZXhwZXJpbWVudHM6IE9iamVjdC52YWx1ZXMoUHJvZHVjdEV4cGVyaW1lbnQpLFxuICAgICAgICBpbmNsdWRlX2ZlYXR1cmVfZ2F0ZXM6IE9iamVjdC5lbnRyaWVzKFxuICAgICAgICAgIGZlYXR1cmVGbGFnU2VydmljZT8uZmVhdHVyZUZsYWdTZXJ2aWNlPy5nZXRGZWF0dXJlRmxhZ3MoKSB8fCB7fSxcbiAgICAgICAgKVxuICAgICAgICAgIC5maWx0ZXIoKFssIGlzRW5hYmxlZF0pID0+IGlzRW5hYmxlZClcbiAgICAgICAgICAubWFwKChbZmVhdHVyZUdhdGVOYW1lXSkgPT4gZmVhdHVyZUdhdGVOYW1lKSwgLy8gVXNlIGZlYXR1cmVGbGFnU2VydmljZVxuICAgICAgfTtcbiAgICAgIGNvbnN0IHJlc3BvbnNlID0gYXdhaXQgQ29tbWVyY2VBcGlDbGllbnQuZ2V0SW5zdGFuY2UoKS5kZWZhdWx0QXBpLnYxT3JnQ29uZmlnR2V0KHJlcXVlc3QpO1xuXG4gICAgICByZXR1cm4gdmFsaWRhdGVPcmdDb25maWdSZXN1bHRzKHJlc3BvbnNlKTtcbiAgICB9IGNhdGNoIChlcnIpIHtcbiAgICAgIExvZ2dlci5sb2dFcnJvcihgRmFpbGVkIHRvIGdldCBvcmcgY29uZmlnYCwgZXJyLCB7IGVyciB9KTtcbiAgICAgIHJldHVybiB1bmRlZmluZWQ7XG4gICAgfVxuICB9O1xuXG4gIHN0YXRpYyBhZGROb3RlVG9MYXRlc3RDb252ZXJzYXRpb24gPSBhc3luYyAoXG4gICAgc3BpZmZ5VXNlcklkOiBzdHJpbmcsXG4gICAgZW1haWw6IHN0cmluZyxcbiAgICBjdXN0b21lclNlcnZpY2VQcm92aWRlcjogQ3VzdG9tZXJTZXJ2aWNlUHJvdmlkZXIsXG4gICkgPT4ge1xuICAgIExvZ2dlci5sb2dJbmZvKFxuICAgICAgYGFkZE5vdGVUb0xhdGVzdENvbnZlcnNhdGlvbiAtIHVzZXJfaWQ9JHtzcGlmZnlVc2VySWR9IGVtYWlsPSR7ZW1haWx9IGN1c3RvbWVyX3NlcnZpY2VfcHJvdmlkZXI9JHtjdXN0b21lclNlcnZpY2VQcm92aWRlcn1gLFxuICAgICk7XG4gICAgdHJ5IHtcbiAgICAgIGF3YWl0IENvbW1lcmNlQXBpQ2xpZW50LmdldEluc3RhbmNlKCkuY3VzdG9tZXJTZXJ2aWNlQXBpLnYxQ3VzdHNlcnZpY2VBZGROb3RlVG9MYXRlc3RDb252ZXJzYXRpb25Qb3N0KFxuICAgICAgICB7XG4gICAgICAgICAgQWRkTm90ZVRvTGF0ZXN0Q29udmVyc2F0aW9uUmVxdWVzdDoge1xuICAgICAgICAgICAgc3BpZmZ5X3VzZXJfaWQ6IHNwaWZmeVVzZXJJZCxcbiAgICAgICAgICAgIGVtYWlsLFxuICAgICAgICAgICAgY3VzdG9tZXJfc2VydmljZV9wcm92aWRlcjogY3VzdG9tZXJTZXJ2aWNlUHJvdmlkZXIsXG4gICAgICAgICAgfSxcbiAgICAgICAgfSxcbiAgICAgICk7XG4gICAgfSBjYXRjaCAoZXJyKSB7XG4gICAgICBMb2dnZXIubG9nRXJyb3IoJ0ZhaWxlZCB0byBhZGQgbm90ZSB0byBsYXRlc3QgY29udmVyc2F0aW9uJywgeyBlcnIgfSk7XG4gICAgfVxuICB9O1xuXG4gIHN0YXRpYyBnZXRDdXN0b21lclNlcnZpY2VBcGkgPSAoKSA9PiBDb21tZXJjZUFwaUNsaWVudC5nZXRJbnN0YW5jZSgpLmN1c3RvbWVyU2VydmljZUFwaTtcbn1cblxuZXhwb3J0IGRlZmF1bHQgQ29tbWVyY2VBcGlDbGllbnQ7XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBeURBLGVBQWUsa0JBQWtCLE9BQXNCO0FBQ3JELEtBQUk7QUFDRixTQUFPLE1BQU0sTUFBTSxTQUFTLE1BQU07U0FDNUI7QUFDTixTQUFPLEVBQUU7OztBQUliLGVBQWUs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
|