@envive-ai/react-hooks 0.2.10 → 0.3.0
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.d.ts +1 -1
- 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 -502
- 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 -498
- 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 -33
- 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-C-ieCm9m.js +0 -1
- package/dist/AmplitudeOperations-p7APchq9.cjs +0 -0
- package/dist/NewOrgConfig-Ch7rrfDH.js +0 -10
- package/dist/NewOrgConfig-D9hNf1kf.cjs +0 -15
- package/dist/SystemSettingsContext-BEDKzEGs.js +0 -13
- package/dist/SystemSettingsContext-SsZBLhYl.cjs +0 -20
- package/dist/TrackComponentVisibleEvent-C04P7hRs.js +0 -52
- package/dist/TrackComponentVisibleEvent-CypK1zy3.cjs +0 -59
- package/dist/amplitudeContext-BlCtIx5s.js +0 -268
- package/dist/amplitudeContext-BmuAesXk.cjs +0 -290
- package/dist/amplitudeContext-CCVyp5RU.d.cts +0 -52
- package/dist/amplitudeContext-DbicJUzl.js +0 -1
- package/dist/amplitudeContext-DcRur97Z.d.ts +0 -52
- package/dist/amplitudeContext-q3mggFSE.cjs +0 -0
- package/dist/api-BvygKEiX.cjs +0 -239
- package/dist/api-bHEYmSiT.js +0 -166
- package/dist/app-Aqkm_SlS.js +0 -110
- package/dist/app-BQw_-JGl.cjs +0 -156
- package/dist/atomStore-CmZbgQHc.cjs +0 -58
- package/dist/atomStore-DEcDhiLp.js +0 -32
- package/dist/cdnContext-CU9G_o-7.js +0 -38
- package/dist/cdnContext-Cjj2MuO-.cjs +0 -53
- package/dist/chat-Bxd6htvi.js +0 -258
- package/dist/chat-ClvJ9xEj.js +0 -25
- package/dist/chat-DCGriB7h.cjs +0 -145
- package/dist/chat-RYAkvBFh.cjs +0 -400
- package/dist/chatElementDisplayLocation-BO3fY4hq.d.ts +0 -26
- package/dist/chatElementDisplayLocation-Igta1TL1.d.cts +0 -26
- package/dist/chatSearch-BGLT3jWO.js +0 -295
- package/dist/chatSearch-Bqv73Oy0.cjs +0 -418
- package/dist/chatState-C8aDBHkl.js +0 -34
- package/dist/chatState-CACif3VJ.cjs +0 -120
- package/dist/commerce-api-B7smzE4o.cjs +0 -319
- package/dist/commerce-api-BSbzeNTu.js +0 -312
- 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-B42OJ8bK.cjs +0 -130
- package/dist/enviveConfig-BlIkxiAF.js +0 -62
- package/dist/enviveConfigContext-1_EivtCa.js +0 -45
- package/dist/enviveConfigContext-Y1ahEAMe.cjs +0 -60
- package/dist/events-DYY4l817.cjs +0 -90
- package/dist/events-DyUix-Bn.js +0 -78
- package/dist/featureFlagServiceContext-CAPrb4e_.js +0 -42
- package/dist/featureFlagServiceContext-CPqbnfe3.d.cts +0 -23
- package/dist/featureFlagServiceContext-D3Ge8GH5.cjs +0 -62
- package/dist/featureFlagServiceContext-mFEI_SIk.d.ts +0 -23
- package/dist/featureGates-Bt_Y3kZ7.cjs +0 -32
- package/dist/featureGates-D4Me_IZH.js +0 -26
- 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-CbI_HNEp.js +0 -48
- package/dist/graphql-Cqoo1D4M.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-CIeJ0GDP.cjs +0 -111
- package/dist/graphqlContext-CoU6L9PE.js +0 -96
- 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-BVsXKN48.d.ts +0 -186
- package/dist/index-Bb3zXP0P.d.ts +0 -673
- 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-DUrfTeD5.d.cts +0 -186
- package/dist/index-DXTWZLEm.d.cts +0 -673
- package/dist/index-DZtnHhlr.d.cts +0 -9
- 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-C5giszHn.cjs +0 -115
- package/dist/localStorageContext-DAOJ4be4.js +0 -95
- package/dist/locators-DxYdak1F.cjs +0 -131
- package/dist/logger-0D_8Ip2L.cjs +0 -26
- package/dist/logger-Co0IA3k5.js +0 -20
- package/dist/models-C9_O47X4.js +0 -1286
- package/dist/models-DRGfA-sZ.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-DsAwdL0_.js +0 -53
- package/dist/newOrgConfigContext-eP_nDi0L.cjs +0 -68
- 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-Bxfp3AFT.js +0 -126
- package/dist/search-filter-types-BItKtezf.d.cts +0 -102
- package/dist/search-filter-types-CGFhksO3.d.ts +0 -102
- package/dist/search-tl23J__F.cjs +0 -205
- package/dist/searchContext-C-HQBmeN.cjs +0 -145
- package/dist/searchContext-CRvkE-WU.js +0 -129
- package/dist/searchServiceAdapter-BGlvoZFE.cjs +0 -34
- package/dist/searchServiceAdapter-Db6jEcJs.js +0 -16
- package/dist/sessionStorageContext-BUXBfp0L.js +0 -52
- package/dist/sessionStorageContext-Da06rhJB.cjs +0 -66
- package/dist/shopifyUrlContext-DaQ9rbqf.js +0 -61
- package/dist/shopifyUrlContext-oIgAbTOi.cjs +0 -75
- package/dist/spiffyWidgets-DK7Ekcy7.d.cts +0 -21
- package/dist/spiffyWidgets-MTUAQq_u.d.ts +0 -21
- package/dist/systemSettingsContext-BlaM8-wy.js +0 -39
- package/dist/systemSettingsContext-CTVhmhcx.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-DLCzibqU.js +0 -42
- package/dist/urlsParser-DhcEZLc_.cjs +0 -78
- package/dist/useAmplitudeOperations-DvnS1WZZ.cjs +0 -41
- package/dist/useAmplitudeOperations-Z6Jguzf_.js +0 -34
- package/dist/useAppDetails-BqJdML4I.cjs +0 -38
- package/dist/useAppDetails-DBFaMyZB.js +0 -30
- package/dist/useGraphQLConfig-BBiJnTYh.js +0 -63
- package/dist/useGraphQLConfig-CV43KcMj.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-BCW4iWmh.cjs +0 -143
- package/dist/userIdentityContext-BhK_ukpI.js +0 -126
- package/dist/userIdentityContext-C6kApbuk.d.ts +0 -20
- 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-C2HshI4X.d.cts +0 -22
- package/dist/utils-C4ci_t0-.js +0 -27
- package/dist/utils-C6imnLBo.cjs +0 -33
- package/dist/utils-CmGOtSiO.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-D_kATUj6.js +0 -92
- package/dist/utils-aa1jK0Xe.d.ts +0 -22
- package/dist/utils-hYTjy7hJ.cjs +0 -130
- package/dist/utils-oPSGYptn.cjs +0 -715
|
@@ -0,0 +1,190 @@
|
|
|
1
|
+
import { MessageRole, MessageType } from "../../application/models/message.js";
|
|
2
|
+
import "../../application/models/index.js";
|
|
3
|
+
import { messagesAtom, replyEventCategoryAtom, userHasRepliedAtom, userQueryAtom } from "../chat/chatState.js";
|
|
4
|
+
import { queueUserEventAtom } from "../chat/messageQueue.js";
|
|
5
|
+
import "../chat/index.js";
|
|
6
|
+
import { newOrgConfigAtom } from "../org/newOrgConfigAtom.js";
|
|
7
|
+
import "../org/index.js";
|
|
8
|
+
import { ProductFilters } from "./productFilters.js";
|
|
9
|
+
import { ProductSorting } from "./types.js";
|
|
10
|
+
import { ProductSorter } from "./productSorter.js";
|
|
11
|
+
import { UserEventCategory } from "@spiffy-ai/commerce-api-client";
|
|
12
|
+
import { v4 } from "uuid";
|
|
13
|
+
import { atom } from "jotai";
|
|
14
|
+
|
|
15
|
+
//#region src/atoms/search/chatSearch.ts
|
|
16
|
+
const chatSearchStateAtom = atom("entrypoint");
|
|
17
|
+
const chatSearchHasProductsAtom = atom(false);
|
|
18
|
+
const chatSearchProductSortingAtom = atom(ProductSorting.FEATURED);
|
|
19
|
+
const filterProductList = (message) => message.type === MessageType.Product && message.metadata.isForGrid === true;
|
|
20
|
+
const filterFilterList = (message) => message.type === MessageType.ProductSearchFilter;
|
|
21
|
+
const chatSearchIsLoadingAtom = atom(false);
|
|
22
|
+
const buildChatSearchTurn = (messages) => {
|
|
23
|
+
const queryMessage = messages.find((message) => message.type === MessageType.ProductSearch);
|
|
24
|
+
if (!queryMessage) return null;
|
|
25
|
+
const { generatedQuery, productCount } = queryMessage.metadata ?? {};
|
|
26
|
+
const productList = messages.filter(filterProductList).map((message) => message.metadata);
|
|
27
|
+
const filterList = messages.filter(filterFilterList).map((message) => message.metadata.filterName);
|
|
28
|
+
return [queryMessage.id, {
|
|
29
|
+
id: queryMessage.id,
|
|
30
|
+
generatedQuery,
|
|
31
|
+
productCount: productCount || productList.length,
|
|
32
|
+
productList,
|
|
33
|
+
filterList,
|
|
34
|
+
messages
|
|
35
|
+
}];
|
|
36
|
+
};
|
|
37
|
+
const chatSearchFilterConfigAtom = atom((get) => {
|
|
38
|
+
return get(newOrgConfigAtom)?.frontendConfig?.uiConfigs?.searchConfig?.searchFilterConfig || [];
|
|
39
|
+
});
|
|
40
|
+
const searchMapAtom = atom((get) => {
|
|
41
|
+
const messages = get(messagesAtom);
|
|
42
|
+
return Object.fromEntries(messages.map(buildChatSearchTurn).filter((v) => v !== null));
|
|
43
|
+
});
|
|
44
|
+
const internalChatSearchParamsAtom = atom({
|
|
45
|
+
id: null,
|
|
46
|
+
query: null
|
|
47
|
+
});
|
|
48
|
+
const selectedFilterOptionsAtom = atom([]);
|
|
49
|
+
const additiveDynamicFiltersAtom = atom((get) => {
|
|
50
|
+
return get(newOrgConfigAtom)?.frontendConfig?.uiConfigs?.searchConfig?.additiveDynamicFilters ?? false;
|
|
51
|
+
});
|
|
52
|
+
const createChatSearchFilterOption = (filterId, filterItemId, displayName) => ({
|
|
53
|
+
id: `${filterId}:${filterItemId}`,
|
|
54
|
+
displayName,
|
|
55
|
+
filterId,
|
|
56
|
+
filterItemId
|
|
57
|
+
});
|
|
58
|
+
const handleSearchAtom = atom(null, (get, set, message) => {
|
|
59
|
+
if (message.type !== MessageType.Search) return;
|
|
60
|
+
const querySearch = message.metadata.searchTerm;
|
|
61
|
+
set(replyEventCategoryAtom, UserEventCategory.Search);
|
|
62
|
+
set(userQueryAtom, querySearch);
|
|
63
|
+
set(messagesAtom, [...get(messagesAtom), [message]]);
|
|
64
|
+
set(userHasRepliedAtom, true);
|
|
65
|
+
set(queueUserEventAtom, {
|
|
66
|
+
eventId: message.id,
|
|
67
|
+
category: UserEventCategory.Search,
|
|
68
|
+
createdAt: message.createdAt,
|
|
69
|
+
attributes: {
|
|
70
|
+
searchTerm: message.metadata.searchTerm,
|
|
71
|
+
selectedFilters: message.metadata.selectedFilters
|
|
72
|
+
}
|
|
73
|
+
});
|
|
74
|
+
});
|
|
75
|
+
const chatSearchParamsAtom = atom((get) => get(internalChatSearchParamsAtom), (_, set, value) => {
|
|
76
|
+
set(internalChatSearchParamsAtom, value);
|
|
77
|
+
});
|
|
78
|
+
const chatSearchQueryAtom = atom((get) => get(chatSearchParamsAtom)?.query ?? null, (get, set, value) => {
|
|
79
|
+
set(chatSearchParamsAtom, {
|
|
80
|
+
id: get(chatSearchParamsAtom).id,
|
|
81
|
+
query: value
|
|
82
|
+
});
|
|
83
|
+
});
|
|
84
|
+
const chatSearchIdAtom = atom((get) => get(chatSearchParamsAtom)?.id ?? null, (get, set, value) => {
|
|
85
|
+
set(chatSearchParamsAtom, {
|
|
86
|
+
id: value,
|
|
87
|
+
query: get(chatSearchParamsAtom).query
|
|
88
|
+
});
|
|
89
|
+
});
|
|
90
|
+
const ChatSearchTurnAtom = atom((get) => {
|
|
91
|
+
const searchFilterConfig = get(chatSearchFilterConfigAtom);
|
|
92
|
+
const searchMap = get(searchMapAtom);
|
|
93
|
+
const chatSearchId = get(chatSearchIdAtom);
|
|
94
|
+
if (!chatSearchId) return null;
|
|
95
|
+
const ChatSearchTurn = searchMap[chatSearchId];
|
|
96
|
+
if (!ChatSearchTurn) return null;
|
|
97
|
+
const productSorting = get(chatSearchProductSortingAtom);
|
|
98
|
+
const selectedFilterOptions = get(selectedFilterOptionsAtom);
|
|
99
|
+
const additiveDynamicFilters = get(additiveDynamicFiltersAtom);
|
|
100
|
+
const filteredProducts = ProductFilters.filterProducts(ChatSearchTurn.productList, searchFilterConfig, selectedFilterOptions, additiveDynamicFilters);
|
|
101
|
+
const filteredAndSortedProducts = ProductSorter.sort(filteredProducts, productSorting);
|
|
102
|
+
return {
|
|
103
|
+
...searchMap[chatSearchId],
|
|
104
|
+
productList: filteredAndSortedProducts,
|
|
105
|
+
productCount: filteredAndSortedProducts.length
|
|
106
|
+
};
|
|
107
|
+
});
|
|
108
|
+
const chatSearchProducts = atom((get) => {
|
|
109
|
+
return get(ChatSearchTurnAtom)?.productList ?? [];
|
|
110
|
+
});
|
|
111
|
+
const chatSearchFiltersAtom = atom((get) => {
|
|
112
|
+
const searchFilterConfig = get(chatSearchFilterConfigAtom);
|
|
113
|
+
const searchMap = get(searchMapAtom);
|
|
114
|
+
const chatSearchId = get(chatSearchIdAtom);
|
|
115
|
+
if (chatSearchId && searchMap[chatSearchId]) {
|
|
116
|
+
const products = searchMap[chatSearchId].productList;
|
|
117
|
+
const selectedFilterOptions = get(selectedFilterOptionsAtom);
|
|
118
|
+
return ProductFilters.getFiltersForProducts(products, searchFilterConfig, selectedFilterOptions);
|
|
119
|
+
}
|
|
120
|
+
return [];
|
|
121
|
+
});
|
|
122
|
+
const setSearchParams = (query) => {
|
|
123
|
+
const url = new URL(window.location.href);
|
|
124
|
+
url.searchParams.set("es", "true");
|
|
125
|
+
url.searchParams.set("esq", query);
|
|
126
|
+
window.history.pushState({}, "", url);
|
|
127
|
+
};
|
|
128
|
+
const getSearchParamsAtom = atom(() => {
|
|
129
|
+
const params = new URLSearchParams(window.location.search);
|
|
130
|
+
return {
|
|
131
|
+
es: params.get("es"),
|
|
132
|
+
esq: params.get("esq")
|
|
133
|
+
};
|
|
134
|
+
});
|
|
135
|
+
const initiateChatSearchAtom = atom(null, (_, set, query) => {
|
|
136
|
+
set(chatSearchIsLoadingAtom, true);
|
|
137
|
+
const url = new URL(window.location.href);
|
|
138
|
+
url.searchParams.set("es", "true");
|
|
139
|
+
url.searchParams.set("esq", query);
|
|
140
|
+
window.history.pushState({}, "", url);
|
|
141
|
+
window.dispatchEvent(new PopStateEvent("popstate", { state: {} }));
|
|
142
|
+
set(chatSearchParamsAtom, {
|
|
143
|
+
id: null,
|
|
144
|
+
query
|
|
145
|
+
});
|
|
146
|
+
set(handleSearchAtom, {
|
|
147
|
+
id: v4(),
|
|
148
|
+
role: MessageRole.User,
|
|
149
|
+
type: MessageType.Search,
|
|
150
|
+
createdAt: (/* @__PURE__ */ new Date()).toISOString(),
|
|
151
|
+
metadata: {
|
|
152
|
+
searchTerm: query,
|
|
153
|
+
selectedFilters: []
|
|
154
|
+
}
|
|
155
|
+
});
|
|
156
|
+
});
|
|
157
|
+
const handleSearchResultsAtom = atom(null, (get, set, message) => {
|
|
158
|
+
if (!message || message.type !== MessageType.ProductSearch) return;
|
|
159
|
+
const { productCount, generatedQuery } = message.metadata;
|
|
160
|
+
if (productCount !== 0) {
|
|
161
|
+
set(selectedFilterOptionsAtom, []);
|
|
162
|
+
set(chatSearchStateAtom, "product-page");
|
|
163
|
+
const currentSearchParams = get(chatSearchParamsAtom);
|
|
164
|
+
const url = new URL(window.location.href);
|
|
165
|
+
url.searchParams.set("es", "true");
|
|
166
|
+
url.searchParams.set("esq", generatedQuery);
|
|
167
|
+
url.searchParams.set("esi", message.id);
|
|
168
|
+
window.history.pushState({}, "", url);
|
|
169
|
+
if (currentSearchParams.id === null) window.history.replaceState(null, "", url);
|
|
170
|
+
else window.history.pushState(null, "", url);
|
|
171
|
+
set(chatSearchParamsAtom, {
|
|
172
|
+
id: message.id,
|
|
173
|
+
query: generatedQuery
|
|
174
|
+
});
|
|
175
|
+
}
|
|
176
|
+
});
|
|
177
|
+
const setChatSearchParamsAtom = atom(null, (_, set, query) => {
|
|
178
|
+
const url = new URL(window.location.href);
|
|
179
|
+
url.searchParams.set("es", "true");
|
|
180
|
+
url.searchParams.set("esq", query);
|
|
181
|
+
window.history.pushState({}, "", url);
|
|
182
|
+
set(chatSearchParamsAtom, {
|
|
183
|
+
id: null,
|
|
184
|
+
query
|
|
185
|
+
});
|
|
186
|
+
});
|
|
187
|
+
|
|
188
|
+
//#endregion
|
|
189
|
+
export { ChatSearchTurnAtom, additiveDynamicFiltersAtom, chatSearchFiltersAtom, chatSearchHasProductsAtom, chatSearchIdAtom, chatSearchIsLoadingAtom, chatSearchParamsAtom, chatSearchProductSortingAtom, chatSearchProducts, chatSearchQueryAtom, chatSearchStateAtom, createChatSearchFilterOption, getSearchParamsAtom, handleSearchResultsAtom, initiateChatSearchAtom, selectedFilterOptionsAtom, setChatSearchParamsAtom, setSearchParams };
|
|
190
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhdFNlYXJjaC5qcyIsIm5hbWVzIjpbInV1aWQiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXRvbXMvc2VhcmNoL2NoYXRTZWFyY2gudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVXNlckV2ZW50Q2F0ZWdvcnkgfSBmcm9tICdAc3BpZmZ5LWFpL2NvbW1lcmNlLWFwaS1jbGllbnQnO1xuaW1wb3J0IHsgdjQgYXMgdXVpZCB9IGZyb20gJ3V1aWQnO1xuaW1wb3J0IHsgYXRvbSB9IGZyb20gJ2pvdGFpJztcbmltcG9ydCB7XG4gIE1lc3NhZ2UsXG4gIE1lc3NhZ2VSb2xlLFxuICBNZXNzYWdlVHlwZSxcbiAgUHJvZHVjdFJlc3BvbnNlQXR0cmlidXRlcyxcbn0gZnJvbSAnc3JjL2FwcGxpY2F0aW9uL21vZGVscyc7XG5pbXBvcnQge1xuICBtZXNzYWdlc0F0b20sXG4gIHJlcGx5RXZlbnRDYXRlZ29yeUF0b20sXG4gIHVzZXJIYXNSZXBsaWVkQXRvbSxcbiAgdXNlclF1ZXJ5QXRvbSxcbn0gZnJvbSAnc3JjL2F0b21zL2NoYXQnO1xuaW1wb3J0IHsgcXVldWVVc2VyRXZlbnRBdG9tIH0gZnJvbSAnLi4vY2hhdC9tZXNzYWdlUXVldWUnO1xuaW1wb3J0IHsgbmV3T3JnQ29uZmlnQXRvbSB9IGZyb20gJy4uL29yZyc7XG5pbXBvcnQgeyBQcm9kdWN0RmlsdGVycyB9IGZyb20gJy4vcHJvZHVjdEZpbHRlcnMnO1xuaW1wb3J0IHsgUHJvZHVjdFNvcnRlciB9IGZyb20gJy4vcHJvZHVjdFNvcnRlcic7XG5pbXBvcnQgeyBDaGF0U2VhcmNoU3RhdGVUeXBlLCBQcm9kdWN0U29ydGluZyB9IGZyb20gJy4vdHlwZXMnO1xuXG4vLyBOT1RFOlxuLy8gVGhpcyBpcyBhIGxlZ2FjeSB2ZXJzaW9uIG9mIHNlYXJjaCB0aGF0IG5lZWRzIHRvIGJlIGRlY291cGxlZCBhbmQgcmVtb3ZlZC5cbi8vIHRoZSBuZXcgc2VhcmNoLnRzIGZpbGUgaW4gdGhpcyBkaXJlY3RvcnkgaXMgbGlrZWx5IHdoYXQgeW91J3JlIGxvb2tpbmcgZm9yLlxuXG5leHBvcnQgY29uc3QgY2hhdFNlYXJjaFN0YXRlQXRvbSA9IGF0b208Q2hhdFNlYXJjaFN0YXRlVHlwZT4oJ2VudHJ5cG9pbnQnKTtcbmV4cG9ydCBjb25zdCBjaGF0U2VhcmNoSGFzUHJvZHVjdHNBdG9tID0gYXRvbTxib29sZWFuPihmYWxzZSk7XG5leHBvcnQgY29uc3QgY2hhdFNlYXJjaFByb2R1Y3RTb3J0aW5nQXRvbSA9IGF0b208UHJvZHVjdFNvcnRpbmc+KFByb2R1Y3RTb3J0aW5nLkZFQVRVUkVEKTtcblxuY29uc3QgZmlsdGVyUHJvZHVjdExpc3QgPSAobWVzc2FnZTogTWVzc2FnZSkgPT5cbiAgbWVzc2FnZS50eXBlID09PSBNZXNzYWdlVHlwZS5Qcm9kdWN0ICYmIG1lc3NhZ2UubWV0YWRhdGEuaXNGb3JHcmlkID09PSB0cnVlO1xuY29uc3QgZmlsdGVyRmlsdGVyTGlzdCA9IChtZXNzYWdlOiBNZXNzYWdlKSA9PiBtZXNzYWdlLnR5cGUgPT09IE1lc3NhZ2VUeXBlLlByb2R1Y3RTZWFyY2hGaWx0ZXI7XG5cbmV4cG9ydCB0eXBlIENoYXRTZWFyY2hUdXJuID0ge1xuICBpZDogc3RyaW5nO1xuICBnZW5lcmF0ZWRRdWVyeT86IHN0cmluZztcbiAgcHJvZHVjdENvdW50OiBudW1iZXI7XG4gIHByb2R1Y3RMaXN0OiBQcm9kdWN0UmVzcG9uc2VBdHRyaWJ1dGVzWydhdHRyaWJ1dGVzJ11bXTtcbiAgZmlsdGVyTGlzdDogc3RyaW5nW107XG4gIG1lc3NhZ2VzOiBNZXNzYWdlW107XG59O1xuXG5leHBvcnQgY29uc3QgY2hhdFNlYXJjaElzTG9hZGluZ0F0b20gPSBhdG9tKGZhbHNlKTtcblxuY29uc3QgYnVpbGRDaGF0U2VhcmNoVHVybiA9IChtZXNzYWdlczogTWVzc2FnZVtdKTogW3N0cmluZywgQ2hhdFNlYXJjaFR1cm5dIHwgbnVsbCA9PiB7XG4gIGNvbnN0IHF1ZXJ5TWVzc2FnZSA9IG1lc3NhZ2VzLmZpbmQobWVzc2FnZSA9PiBtZXNzYWdlLnR5cGUgPT09IE1lc3NhZ2VUeXBlLlByb2R1Y3RTZWFyY2gpO1xuICBpZiAoIXF1ZXJ5TWVzc2FnZSkge1xuICAgIHJldHVybiBudWxsO1xuICB9XG4gIGNvbnN0IHsgZ2VuZXJhdGVkUXVlcnksIHByb2R1Y3RDb3VudCB9ID0gcXVlcnlNZXNzYWdlLm1ldGFkYXRhID8/IHt9O1xuICBjb25zdCBwcm9kdWN0TGlzdCA9IG1lc3NhZ2VzLmZpbHRlcihmaWx0ZXJQcm9kdWN0TGlzdCkubWFwKG1lc3NhZ2UgPT4gKG1lc3NhZ2UgYXMgYW55KS5tZXRhZGF0YSk7XG4gIGNvbnN0IGZpbHRlckxpc3QgPSBtZXNzYWdlcy5maWx0ZXIoZmlsdGVyRmlsdGVyTGlzdCkubWFwKG1lc3NhZ2UgPT4gbWVzc2FnZS5tZXRhZGF0YS5maWx0ZXJOYW1lKTtcbiAgcmV0dXJuIFtcbiAgICBxdWVyeU1lc3NhZ2UuaWQsXG4gICAge1xuICAgICAgaWQ6IHF1ZXJ5TWVzc2FnZS5pZCxcbiAgICAgIGdlbmVyYXRlZFF1ZXJ5LFxuICAgICAgcHJvZHVjdENvdW50OiBwcm9kdWN0Q291bnQgfHwgcHJvZHVjdExpc3QubGVuZ3RoLFxuICAgICAgcHJvZHVjdExpc3QsXG4gICAgICBmaWx0ZXJMaXN0LFxuICAgICAgbWVzc2FnZXMsXG4gICAgfSxcbiAgXTtcbn07XG5cbmNvbnN0IGNoYXRTZWFyY2hGaWx0ZXJDb25maWdBdG9tID0gYXRvbShnZXQgPT4ge1xuICBjb25zdCBuZXdPcmdDb25maWcgPSBnZXQobmV3T3JnQ29uZmlnQXRvbSk7XG4gIHJldHVybiBuZXdPcmdDb25maWc/LmZyb250ZW5kQ29uZmlnPy51aUNvbmZpZ3M/LnNlYXJjaENvbmZpZz8uc2VhcmNoRmlsdGVyQ29uZmlnIHx8IFtdO1xufSk7XG5cbmNvbnN0IHNlYXJjaE1hcEF0b20gPSBhdG9tKGdldCA9PiB7XG4gIGNvbnN0IG1lc3NhZ2VzID0gZ2V0KG1lc3NhZ2VzQXRvbSk7XG4gIHJldHVybiBPYmplY3QuZnJvbUVudHJpZXMobWVzc2FnZXMubWFwKGJ1aWxkQ2hhdFNlYXJjaFR1cm4pLmZpbHRlcih2ID0+IHYgIT09IG51bGwpKTtcbn0pO1xuXG5jb25zdCBpbnRlcm5hbENoYXRTZWFyY2hQYXJhbXNBdG9tID0gYXRvbTx7XG4gIGlkOiBzdHJpbmcgfCBudWxsO1xuICBxdWVyeTogc3RyaW5nIHwgbnVsbDtcbn0+KHtcbiAgaWQ6IG51bGwsXG4gIHF1ZXJ5OiBudWxsLFxufSk7XG5cbi8vIFNlbGVjdGVkIGZpbHRlciBvcHRpb25zIHdpdGggY29tcG91bmQgb2JqZWN0cyBmb3IgYmV0dGVyIHR5cGUgc2FmZXR5IGFuZCBkaXNwbGF5XG5leHBvcnQgdHlwZSBTZWxlY3RlZENoYXRTZWFyY2hGaWx0ZXJPcHRpb24gPSB7XG4gIGlkOiBzdHJpbmc7IC8vIFwiZmlsdGVySWQ6ZmlsdGVySXRlbUlkXCIgLSBtYWludGFpbnMgYmFja3dhcmQgY29tcGF0aWJpbGl0eSBmb3IgY29tcGFyaXNvbnNcbiAgZGlzcGxheU5hbWU6IHN0cmluZztcbiAgZmlsdGVySWQ6IHN0cmluZzsgLy8gRmlsdGVyIGNhdGVnb3J5XG4gIGZpbHRlckl0ZW1JZDogc3RyaW5nOyAvLyBGaWx0ZXIgdmFsdWVcbn07XG5cbmV4cG9ydCBjb25zdCBzZWxlY3RlZEZpbHRlck9wdGlvbnNBdG9tID0gYXRvbTxTZWxlY3RlZENoYXRTZWFyY2hGaWx0ZXJPcHRpb25bXT4oW10pO1xuXG5leHBvcnQgY29uc3QgYWRkaXRpdmVEeW5hbWljRmlsdGVyc0F0b20gPSBhdG9tKGdldCA9PiB7XG4gIGNvbnN0IG5ld09yZ0NvbmZpZyA9IGdldChuZXdPcmdDb25maWdBdG9tKTtcbiAgcmV0dXJuIG5ld09yZ0NvbmZpZz8uZnJvbnRlbmRDb25maWc/LnVpQ29uZmlncz8uc2VhcmNoQ29uZmlnPy5hZGRpdGl2ZUR5bmFtaWNGaWx0ZXJzID8/IGZhbHNlO1xufSk7XG5cbmV4cG9ydCBjb25zdCBjcmVhdGVDaGF0U2VhcmNoRmlsdGVyT3B0aW9uID0gKFxuICBmaWx0ZXJJZDogc3RyaW5nLFxuICBmaWx0ZXJJdGVtSWQ6IHN0cmluZyxcbiAgZGlzcGxheU5hbWU6IHN0cmluZyxcbik6IFNlbGVjdGVkQ2hhdFNlYXJjaEZpbHRlck9wdGlvbiA9PiAoe1xuICBpZDogYCR7ZmlsdGVySWR9OiR7ZmlsdGVySXRlbUlkfWAsXG4gIGRpc3BsYXlOYW1lLFxuICBmaWx0ZXJJZCxcbiAgZmlsdGVySXRlbUlkLFxufSk7XG5cbmNvbnN0IGhhbmRsZVNlYXJjaEF0b20gPSBhdG9tKG51bGwsIChnZXQsIHNldCwgbWVzc2FnZTogTWVzc2FnZSkgPT4ge1xuICBpZiAobWVzc2FnZS50eXBlICE9PSBNZXNzYWdlVHlwZS5TZWFyY2gpIHtcbiAgICByZXR1cm47XG4gIH1cblxuICBjb25zdCBxdWVyeVNlYXJjaCA9IG1lc3NhZ2UubWV0YWRhdGEuc2VhcmNoVGVybTtcblxuICBzZXQocmVwbHlFdmVudENhdGVnb3J5QXRvbSwgVXNlckV2ZW50Q2F0ZWdvcnkuU2VhcmNoKTtcbiAgc2V0KHVzZXJRdWVyeUF0b20sIHF1ZXJ5U2VhcmNoKTtcbiAgc2V0KG1lc3NhZ2VzQXRvbSwgWy4uLmdldChtZXNzYWdlc0F0b20pLCBbbWVzc2FnZV1dKTtcbiAgc2V0KHVzZXJIYXNSZXBsaWVkQXRvbSwgdHJ1ZSk7XG5cbiAgc2V0KHF1ZXVlVXNlckV2ZW50QXRvbSwge1xuICAgIGV2ZW50SWQ6IG1lc3NhZ2UuaWQsXG4gICAgY2F0ZWdvcnk6IFVzZXJFdmVudENhdGVnb3J5LlNlYXJjaCxcbiAgICBjcmVhdGVkQXQ6IG1lc3NhZ2UuY3JlYXRlZEF0LFxuICAgIGF0dHJpYnV0ZXM6IHtcbiAgICAgIHNlYXJjaFRlcm06IG1lc3NhZ2UubWV0YWRhdGEuc2VhcmNoVGVybSxcbiAgICAgIHNlbGVjdGVkRmlsdGVyczogbWVzc2FnZS5tZXRhZGF0YS5zZWxlY3RlZEZpbHRlcnMsXG4gICAgfSxcbiAgfSk7XG59KTtcblxuLy8gVGhpcyBpbnRlcm5hbCBhdG9tIGlzIHVzZWQgdG8gc3RvcmUgdGhlIHNlYXJjaCBwYXJhbXNcbmV4cG9ydCBjb25zdCBjaGF0U2VhcmNoUGFyYW1zQXRvbSA9IGF0b20oXG4gIGdldCA9PiBnZXQoaW50ZXJuYWxDaGF0U2VhcmNoUGFyYW1zQXRvbSksXG4gIChfLCBzZXQsIHZhbHVlOiB7IGlkOiBzdHJpbmcgfCBudWxsOyBxdWVyeTogc3RyaW5nIHwgbnVsbCB9KSA9PiB7XG4gICAgc2V0KGludGVybmFsQ2hhdFNlYXJjaFBhcmFtc0F0b20sIHZhbHVlKTtcbiAgfSxcbik7XG5cbmV4cG9ydCBjb25zdCBjaGF0U2VhcmNoUXVlcnlBdG9tID0gYXRvbShcbiAgZ2V0ID0+IGdldChjaGF0U2VhcmNoUGFyYW1zQXRvbSk/LnF1ZXJ5ID8/IG51bGwsXG4gIChnZXQsIHNldCwgdmFsdWU6IHN0cmluZyB8IG51bGwpID0+IHtcbiAgICBjb25zdCBzZWFyY2hQYXJhbXMgPSBnZXQoY2hhdFNlYXJjaFBhcmFtc0F0b20pO1xuICAgIHNldChjaGF0U2VhcmNoUGFyYW1zQXRvbSwgeyBpZDogc2VhcmNoUGFyYW1zLmlkLCBxdWVyeTogdmFsdWUgfSk7XG4gIH0sXG4pO1xuXG5leHBvcnQgY29uc3QgY2hhdFNlYXJjaElkQXRvbSA9IGF0b20oXG4gIGdldCA9PiBnZXQoY2hhdFNlYXJjaFBhcmFtc0F0b20pPy5pZCA/PyBudWxsLFxuICAoZ2V0LCBzZXQsIHZhbHVlOiBzdHJpbmcgfCBudWxsKSA9PiB7XG4gICAgY29uc3Qgc2VhcmNoUGFyYW1zID0gZ2V0KGNoYXRTZWFyY2hQYXJhbXNBdG9tKTtcbiAgICBzZXQoY2hhdFNlYXJjaFBhcmFtc0F0b20sIHsgaWQ6IHZhbHVlLCBxdWVyeTogc2VhcmNoUGFyYW1zLnF1ZXJ5IH0pO1xuICB9LFxuKTtcblxuZXhwb3J0IGNvbnN0IENoYXRTZWFyY2hUdXJuQXRvbSA9IGF0b20oZ2V0ID0+IHtcbiAgY29uc3Qgc2VhcmNoRmlsdGVyQ29uZmlnID0gZ2V0KGNoYXRTZWFyY2hGaWx0ZXJDb25maWdBdG9tKTtcbiAgY29uc3Qgc2VhcmNoTWFwID0gZ2V0KHNlYXJjaE1hcEF0b20pO1xuICBjb25zdCBjaGF0U2VhcmNoSWQgPSBnZXQoY2hhdFNlYXJjaElkQXRvbSk7XG4gIGlmICghY2hhdFNlYXJjaElkKSB7XG4gICAgcmV0dXJuIG51bGw7XG4gIH1cbiAgY29uc3QgQ2hhdFNlYXJjaFR1cm4gPSBzZWFyY2hNYXBbY2hhdFNlYXJjaElkXTtcbiAgaWYgKCFDaGF0U2VhcmNoVHVybikge1xuICAgIHJldHVybiBudWxsO1xuICB9XG4gIGNvbnN0IHByb2R1Y3RTb3J0aW5nID0gZ2V0KGNoYXRTZWFyY2hQcm9kdWN0U29ydGluZ0F0b20pO1xuICBjb25zdCBzZWxlY3RlZEZpbHRlck9wdGlvbnMgPSBnZXQoc2VsZWN0ZWRGaWx0ZXJPcHRpb25zQXRvbSk7XG4gIGNvbnN0IGFkZGl0aXZlRHluYW1pY0ZpbHRlcnMgPSBnZXQoYWRkaXRpdmVEeW5hbWljRmlsdGVyc0F0b20pO1xuICBjb25zdCBmaWx0ZXJlZFByb2R1Y3RzID0gUHJvZHVjdEZpbHRlcnMuZmlsdGVyUHJvZHVjdHMoXG4gICAgQ2hhdFNlYXJjaFR1cm4ucHJvZHVjdExpc3QsXG4gICAgc2VhcmNoRmlsdGVyQ29uZmlnLFxuICAgIHNlbGVjdGVkRmlsdGVyT3B0aW9ucyxcbiAgICBhZGRpdGl2ZUR5bmFtaWNGaWx0ZXJzLFxuICApO1xuXG4gIGNvbnN0IGZpbHRlcmVkQW5kU29ydGVkUHJvZHVjdHMgPSBQcm9kdWN0U29ydGVyLnNvcnQoZmlsdGVyZWRQcm9kdWN0cywgcHJvZHVjdFNvcnRpbmcpO1xuXG4gIHJldHVybiB7XG4gICAgLi4uc2VhcmNoTWFwW2NoYXRTZWFyY2hJZF0sXG4gICAgcHJvZHVjdExpc3Q6IGZpbHRlcmVkQW5kU29ydGVkUHJvZHVjdHMsXG4gICAgcHJvZHVjdENvdW50OiBmaWx0ZXJlZEFuZFNvcnRlZFByb2R1Y3RzLmxlbmd0aCxcbiAgfTtcbn0pO1xuXG4vLyBUT0RPOiBXb3JrIG9uIGRlcHJlY2F0aW5nIHRoaXMgYXRvbSBpbiBmYXZvciBvZiB1c2luZyBDaGF0U2VhcmNoVHVybkF0b20gZGlyZWN0bHlcbmV4cG9ydCBjb25zdCBjaGF0U2VhcmNoUHJvZHVjdHMgPSBhdG9tKGdldCA9PiB7XG4gIGNvbnN0IENoYXRTZWFyY2hUdXJuID0gZ2V0KENoYXRTZWFyY2hUdXJuQXRvbSk7XG4gIHJldHVybiBDaGF0U2VhcmNoVHVybj8ucHJvZHVjdExpc3QgPz8gW107XG59KTtcblxuZXhwb3J0IGNvbnN0IGNoYXRTZWFyY2hGaWx0ZXJzQXRvbSA9IGF0b20oZ2V0ID0+IHtcbiAgY29uc3Qgc2VhcmNoRmlsdGVyQ29uZmlnID0gZ2V0KGNoYXRTZWFyY2hGaWx0ZXJDb25maWdBdG9tKTtcbiAgY29uc3Qgc2VhcmNoTWFwID0gZ2V0KHNlYXJjaE1hcEF0b20pO1xuICBjb25zdCBjaGF0U2VhcmNoSWQgPSBnZXQoY2hhdFNlYXJjaElkQXRvbSk7XG5cbiAgaWYgKGNoYXRTZWFyY2hJZCAmJiBzZWFyY2hNYXBbY2hhdFNlYXJjaElkXSkge1xuICAgIGNvbnN0IHByb2R1Y3RzID0gc2VhcmNoTWFwW2NoYXRTZWFyY2hJZF0ucHJvZHVjdExpc3Q7XG4gICAgY29uc3Qgc2VsZWN0ZWRGaWx0ZXJPcHRpb25zID0gZ2V0KHNlbGVjdGVkRmlsdGVyT3B0aW9uc0F0b20pO1xuICAgIHJldHVybiBQcm9kdWN0RmlsdGVycy5nZXRGaWx0ZXJzRm9yUHJvZHVjdHMoXG4gICAgICBwcm9kdWN0cyxcbiAgICAgIHNlYXJjaEZpbHRlckNvbmZpZyxcbiAgICAgIHNlbGVjdGVkRmlsdGVyT3B0aW9ucyxcbiAgICApO1xuICB9XG4gIHJldHVybiBbXTtcbn0pO1xuXG4vLyBGb3Igc2VhcmNoIHdlIHVzZSB0aGUgZm9sbG93aW5nIHF1ZXJ5IHBhcmFtczpcbi8vIGVzOiB0cnVlIC0gdGhpcyBpbmRpY2F0ZXMgdGhhdCB3ZSBhcmUgaW4gYSBzZWFyY2ggc3RhdGVcbi8vIGVzcTogcXVlcnkgLSB0aGlzIGlzIHRoZSBjdXJyZW50IHNlYXJjaCBxdWVyeVxuLy8gZXNpOiBzZWFyY2ggaWQgLSB0aGlzIGlzIHRoZSB1bmlxdWUgaWQgZm9yIHRoZSBzZWFyY2ggcmVzdWx0cyB0aGF0IHdlIGFyZSBkaXNwbGF5aW5nLiBJdCBpcyBwdWxsZWQgZnJvbSB0aGUgbWVzc2FnZSBpZCBmcm9tIHRoZSB0dXJuIHRoYXQgaW5jbHVkZXMgdGhlIHNlYXJjaCByZXN1bHRzXG5cbmV4cG9ydCBjb25zdCBzZXRTZWFyY2hQYXJhbXMgPSAocXVlcnk6IHN0cmluZykgPT4ge1xuICBjb25zdCB1cmwgPSBuZXcgVVJMKHdpbmRvdy5sb2NhdGlvbi5ocmVmKTtcbiAgdXJsLnNlYXJjaFBhcmFtcy5zZXQoJ2VzJywgJ3RydWUnKTtcbiAgdXJsLnNlYXJjaFBhcmFtcy5zZXQoJ2VzcScsIHF1ZXJ5KTtcbiAgd2luZG93Lmhpc3RvcnkucHVzaFN0YXRlKHt9LCAnJywgdXJsKTtcbn07XG5cbmV4cG9ydCBjb25zdCBnZXRTZWFyY2hQYXJhbXNBdG9tID0gYXRvbSgoKSA9PiB7XG4gIGNvbnN0IHBhcmFtcyA9IG5ldyBVUkxTZWFyY2hQYXJhbXMod2luZG93LmxvY2F0aW9uLnNlYXJjaCk7XG4gIHJldHVybiB7XG4gICAgZXM6IHBhcmFtcy5nZXQoJ2VzJyksXG4gICAgZXNxOiBwYXJhbXMuZ2V0KCdlc3EnKSxcbiAgfTtcbn0pO1xuXG5leHBvcnQgY29uc3QgaW5pdGlhdGVDaGF0U2VhcmNoQXRvbSA9IGF0b20obnVsbCwgKF8sIHNldCwgcXVlcnk6IHN0cmluZykgPT4ge1xuICBzZXQoY2hhdFNlYXJjaElzTG9hZGluZ0F0b20sIHRydWUpO1xuICAvLyBVcGRhdGUgVVJMIGFuZCBtYW51YWxseSB0cmlnZ2VyIHN0YXRlIGNoYW5nZSAoc2luY2UgcHVzaFN0YXRlIGRvZXNuJ3QgdHJpZ2dlciBwb3BzdGF0ZSlcbiAgY29uc3QgdXJsID0gbmV3IFVSTCh3aW5kb3cubG9jYXRpb24uaHJlZik7XG4gIHVybC5zZWFyY2hQYXJhbXMuc2V0KCdlcycsICd0cnVlJyk7XG4gIHVybC5zZWFyY2hQYXJhbXMuc2V0KCdlc3EnLCBxdWVyeSk7XG4gIHdpbmRvdy5oaXN0b3J5LnB1c2hTdGF0ZSh7fSwgJycsIHVybCk7XG5cbiAgLy8gTWFudWFsbHkgdHJpZ2dlciBwYWdlIHZhcmlhbnQgcmUtZXZhbHVhdGlvbiBieSBkaXNwYXRjaGluZyBhIHBvcHN0YXRlIGV2ZW50XG4gIC8vIFRoaXMgZW5zdXJlcyB0aGUgcGFnZSB2YXJpYW50IHN5c3RlbSBkZXRlY3RzIHRoZSBVUkwgY2hhbmdlIGFuZCBtb3VudHMgc2VhcmNoIHJlc3VsdHNcbiAgd2luZG93LmRpc3BhdGNoRXZlbnQobmV3IFBvcFN0YXRlRXZlbnQoJ3BvcHN0YXRlJywgeyBzdGF0ZToge30gfSkpO1xuXG4gIHNldChjaGF0U2VhcmNoUGFyYW1zQXRvbSwgeyBpZDogbnVsbCwgcXVlcnkgfSk7XG4gIHNldChoYW5kbGVTZWFyY2hBdG9tLCB7XG4gICAgaWQ6IHV1aWQoKSxcbiAgICByb2xlOiBNZXNzYWdlUm9sZS5Vc2VyLFxuICAgIHR5cGU6IE1lc3NhZ2VUeXBlLlNlYXJjaCxcbiAgICBjcmVhdGVkQXQ6IG5ldyBEYXRlKCkudG9JU09TdHJpbmcoKSxcbiAgICBtZXRhZGF0YToge1xuICAgICAgc2VhcmNoVGVybTogcXVlcnksXG4gICAgICAvLyBFbmFibGluZyB0aGlzIHdpbGwgZW5hYmxlIHRoZSBuZXcgYmFja2VuZCBzZWFyY2hcbiAgICAgIHNlbGVjdGVkRmlsdGVyczogW10sXG4gICAgfSxcbiAgfSk7XG59KTtcblxuZXhwb3J0IGNvbnN0IGhhbmRsZVNlYXJjaFJlc3VsdHNBdG9tID0gYXRvbShudWxsLCAoZ2V0LCBzZXQsIG1lc3NhZ2U6IE1lc3NhZ2UgfCB1bmRlZmluZWQpID0+IHtcbiAgaWYgKCFtZXNzYWdlIHx8IG1lc3NhZ2UudHlwZSAhPT0gTWVzc2FnZVR5cGUuUHJvZHVjdFNlYXJjaCkge1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGNvbnN0IHsgcHJvZHVjdENvdW50LCBnZW5lcmF0ZWRRdWVyeSB9ID0gbWVzc2FnZS5tZXRhZGF0YTtcbiAgaWYgKHByb2R1Y3RDb3VudCAhPT0gMCkge1xuICAgIC8vIENsZWFyIHRoZSBmaWx0ZXIgb3B0aW9ucyB3aGVuIHdlIGdldCBuZXcgcHJvZHVjdHNcbiAgICBzZXQoc2VsZWN0ZWRGaWx0ZXJPcHRpb25zQXRvbSwgW10pO1xuICAgIC8vIFRPRE86IFNob3VsZCB3ZSBzdGlsbCBkbyBhbnkgb2YgdGhlc2UgdGhpbmdzP1xuICAgIHNldChjaGF0U2VhcmNoU3RhdGVBdG9tLCAncHJvZHVjdC1wYWdlJyk7XG4gICAgY29uc3QgY3VycmVudFNlYXJjaFBhcmFtcyA9IGdldChjaGF0U2VhcmNoUGFyYW1zQXRvbSk7XG4gICAgY29uc3QgdXJsID0gbmV3IFVSTCh3aW5kb3cubG9jYXRpb24uaHJlZik7XG4gICAgdXJsLnNlYXJjaFBhcmFtcy5zZXQoJ2VzJywgJ3RydWUnKTtcbiAgICB1cmwuc2VhcmNoUGFyYW1zLnNldCgnZXNxJywgZ2VuZXJhdGVkUXVlcnkpO1xuICAgIHVybC5zZWFyY2hQYXJhbXMuc2V0KCdlc2knLCBtZXNzYWdlLmlkKTtcbiAgICB3aW5kb3cuaGlzdG9yeS5wdXNoU3RhdGUoe30sICcnLCB1cmwpO1xuICAgIGlmIChjdXJyZW50U2VhcmNoUGFyYW1zLmlkID09PSBudWxsKSB7XG4gICAgICAvLyBJZiB0aGUgaWQgaXMgbnVsbCwgd2UgbmVlZCB0byByZXBsYWNlIHRoZSBzdGF0ZVxuICAgICAgd2luZG93Lmhpc3RvcnkucmVwbGFjZVN0YXRlKG51bGwsICcnLCB1cmwpO1xuICAgIH0gZWxzZSB7XG4gICAgICAvLyBJZiB0aGUgcXVlcnkgaXMgZGlmZmVyZW50LCB3ZSBuZWVkIHRvIHB1c2ggYSBuZXcgc3RhdGVcbiAgICAgIHdpbmRvdy5oaXN0b3J5LnB1c2hTdGF0ZShudWxsLCAnJywgdXJsKTtcbiAgICB9XG4gICAgc2V0KGNoYXRTZWFyY2hQYXJhbXNBdG9tLCB7IGlkOiBtZXNzYWdlLmlkLCBxdWVyeTogZ2VuZXJhdGVkUXVlcnkgfSk7XG4gIH1cbn0pO1xuXG5leHBvcnQgY29uc3Qgc2V0Q2hhdFNlYXJjaFBhcmFtc0F0b20gPSBhdG9tKG51bGwsIChfLCBzZXQsIHF1ZXJ5OiBzdHJpbmcpID0+IHtcbiAgY29uc3QgdXJsID0gbmV3IFVSTCh3aW5kb3cubG9jYXRpb24uaHJlZik7XG4gIHVybC5zZWFyY2hQYXJhbXMuc2V0KCdlcycsICd0cnVlJyk7XG4gIHVybC5zZWFyY2hQYXJhbXMuc2V0KCdlc3EnLCBxdWVyeSk7XG4gIHdpbmRvdy5oaXN0b3J5LnB1c2hTdGF0ZSh7fSwgJycsIHVybCk7XG4gIHNldChjaGF0U2VhcmNoUGFyYW1zQXRvbSwgeyBpZDogbnVsbCwgcXVlcnkgfSk7XG59KTtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7O0FBeUJBLE1BQWEsc0JBQXNCLEtBQTBCLGFBQWE7QUFDMUUsTUFBYSw0QkFBNEIsS0FBYyxNQUFNO0FBQzdELE1BQWEsK0JBQStCLEtBQXFCLGVBQWUsU0FBUztBQUV6RixNQUFNLHFCQUFxQixZQUN6QixRQUFRLFNBQVMsWUFBWSxXQUFXLFFBQVEsU0FBUyxjQUFjO0FBQ3pFLE1BQU0sb0JBQW9CLFlBQXFCLFFBQVEsU0FBUyxZQUFZO0FBVzVFLE1BQWEsMEJBQTBCLEtBQUssTUFBTTtBQUVsRCxNQUFNLHVCQUF1QixhQUF5RDtDQUNwRixNQUFNLGVBQWUsU0FBUyxNQUFLLFlBQVcsUUFBUSxTQUFTLFlBQVksY0FBYztBQUN6RixLQUFJLENBQUMsYUFDSCxRQUFPO0NBRVQsTUFBTSxFQUFFLGdCQUFnQixpQkFBaUIsYUFBYSxZQUFZLEVBQUU7Q0FDcEUsTUFBTSxjQUFjLFNBQVMsT0FBTyxrQkFBa0IsQ0FBQyxLQUFJLFlBQVksUUFBZ0IsU0FBUztDQUNoRyxNQUFNLGFBQWEsU0FBUyxPQUFPLGlCQUFpQixDQUFDLEtBQUksWUFBVyxRQUFRLFNBQVMsV0FBVztBQUNoRyxRQUFPLENBQ0wsYUFBYSxJQUNiO0VBQ0UsSUFBSSxhQUFhO0VBQ2pCO0VBQ0EsY0FBYyxnQkFBZ0IsWUFBWTtFQUMxQztFQUNBO0VBQ0E7RUFDRCxDQUNGOztBQUdILE1BQU0sNkJBQTZC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
|
|
@@ -1,35 +1,8 @@
|
|
|
1
|
-
require('
|
|
2
|
-
require('
|
|
3
|
-
require('../../logger-0D_8Ip2L.cjs');
|
|
4
|
-
require('../../models-DRGfA-sZ.cjs');
|
|
5
|
-
require('../../featureGates-Bt_Y3kZ7.cjs');
|
|
6
|
-
require('../../urlsParser-DhcEZLc_.cjs');
|
|
7
|
-
require('../../graphql-Cqoo1D4M.cjs');
|
|
8
|
-
require('../../utils-C6imnLBo.cjs');
|
|
9
|
-
require('../../api-BvygKEiX.cjs');
|
|
10
|
-
require('../../utilityTypes-BGbL2WTP.cjs');
|
|
11
|
-
require('../../variantInfo-DpLn4nHz.cjs');
|
|
12
|
-
require('../../localStorageContext-C5giszHn.cjs');
|
|
13
|
-
require('../../enviveConfig-B42OJ8bK.cjs');
|
|
14
|
-
require('../../orgAnalyticsConfig-Bm23fw4s.cjs');
|
|
15
|
-
require('../../atomStore-CmZbgQHc.cjs');
|
|
16
|
-
require('../../app-BQw_-JGl.cjs');
|
|
17
|
-
require('../../enviveConfigContext-Y1ahEAMe.cjs');
|
|
18
|
-
require('../../featureFlagServiceContext-D3Ge8GH5.cjs');
|
|
19
|
-
require('../../amplitudeContext-BmuAesXk.cjs');
|
|
20
|
-
require('../../chatState-CACif3VJ.cjs');
|
|
21
|
-
require('../../graphqlConfig-BnfE0ql5.cjs');
|
|
22
|
-
require('../../chat-RYAkvBFh.cjs');
|
|
23
|
-
require('../../org-B_cWn2bt.cjs');
|
|
24
|
-
require('../../newOrgConfigAtom-CPA6Gp6n.cjs');
|
|
25
|
-
require('../../utils-CvLmSsUj.cjs');
|
|
26
|
-
const require_chatSearch = require('../../chatSearch-Bqv73Oy0.cjs');
|
|
27
|
-
require('../../types-BuvXXGxE.cjs');
|
|
28
|
-
require('../../searchServiceAdapter-BGlvoZFE.cjs');
|
|
29
|
-
const require_search = require('../../search-tl23J__F.cjs');
|
|
1
|
+
const require_chatSearch = require('./chatSearch.cjs');
|
|
2
|
+
const require_searchAPI = require('./searchAPI.cjs');
|
|
30
3
|
|
|
31
4
|
exports.ChatSearchTurnAtom = require_chatSearch.ChatSearchTurnAtom;
|
|
32
|
-
exports.addSearchFilterAtom =
|
|
5
|
+
exports.addSearchFilterAtom = require_searchAPI.addSearchFilterAtom;
|
|
33
6
|
exports.additiveDynamicFiltersAtom = require_chatSearch.additiveDynamicFiltersAtom;
|
|
34
7
|
exports.chatSearchFiltersAtom = require_chatSearch.chatSearchFiltersAtom;
|
|
35
8
|
exports.chatSearchHasProductsAtom = require_chatSearch.chatSearchHasProductsAtom;
|
|
@@ -40,22 +13,22 @@ exports.chatSearchProductSortingAtom = require_chatSearch.chatSearchProductSorti
|
|
|
40
13
|
exports.chatSearchProducts = require_chatSearch.chatSearchProducts;
|
|
41
14
|
exports.chatSearchQueryAtom = require_chatSearch.chatSearchQueryAtom;
|
|
42
15
|
exports.chatSearchStateAtom = require_chatSearch.chatSearchStateAtom;
|
|
43
|
-
exports.clearSearchFiltersAtom =
|
|
16
|
+
exports.clearSearchFiltersAtom = require_searchAPI.clearSearchFiltersAtom;
|
|
44
17
|
exports.createChatSearchFilterOption = require_chatSearch.createChatSearchFilterOption;
|
|
45
|
-
exports.createFilterOption =
|
|
46
|
-
exports.filteredSearchProductsAtom =
|
|
18
|
+
exports.createFilterOption = require_searchAPI.createFilterOption;
|
|
19
|
+
exports.filteredSearchProductsAtom = require_searchAPI.filteredSearchProductsAtom;
|
|
47
20
|
exports.getSearchParamsAtom = require_chatSearch.getSearchParamsAtom;
|
|
48
21
|
exports.handleSearchResultsAtom = require_chatSearch.handleSearchResultsAtom;
|
|
49
22
|
exports.initiateChatSearchAtom = require_chatSearch.initiateChatSearchAtom;
|
|
50
|
-
exports.internalSearchSystemStateAtom =
|
|
51
|
-
exports.performSearchAtom =
|
|
52
|
-
exports.removeSearchFilterAtom =
|
|
53
|
-
exports.searchAtom =
|
|
54
|
-
exports.searchFiltersAtom =
|
|
55
|
-
exports.searchParamsAtom =
|
|
56
|
-
exports.searchProductSortingAtom =
|
|
57
|
-
exports.searchSelectedFiltersAtom =
|
|
58
|
-
exports.searchSystemAtom =
|
|
23
|
+
exports.internalSearchSystemStateAtom = require_searchAPI.internalSearchSystemStateAtom;
|
|
24
|
+
exports.performSearchAtom = require_searchAPI.performSearchAtom;
|
|
25
|
+
exports.removeSearchFilterAtom = require_searchAPI.removeSearchFilterAtom;
|
|
26
|
+
exports.searchAtom = require_searchAPI.searchAtom;
|
|
27
|
+
exports.searchFiltersAtom = require_searchAPI.searchFiltersAtom;
|
|
28
|
+
exports.searchParamsAtom = require_searchAPI.searchParamsAtom;
|
|
29
|
+
exports.searchProductSortingAtom = require_searchAPI.searchProductSortingAtom;
|
|
30
|
+
exports.searchSelectedFiltersAtom = require_searchAPI.searchSelectedFiltersAtom;
|
|
31
|
+
exports.searchSystemAtom = require_searchAPI.searchSystemAtom;
|
|
59
32
|
exports.selectedFilterOptionsAtom = require_chatSearch.selectedFilterOptionsAtom;
|
|
60
33
|
exports.setChatSearchParamsAtom = require_chatSearch.setChatSearchParamsAtom;
|
|
61
34
|
exports.setSearchParams = require_chatSearch.setSearchParams;
|
|
@@ -1,15 +1,3 @@
|
|
|
1
|
-
import "
|
|
2
|
-
import "
|
|
3
|
-
import "../../index-CESxqFso.cjs";
|
|
4
|
-
import "../../responseGenerics-DWLV09cQ.cjs";
|
|
5
|
-
import "../../utils-DCrwX6FT.cjs";
|
|
6
|
-
import "../../index-DXTWZLEm.cjs";
|
|
7
|
-
import "../../chatElementDisplayLocation-Igta1TL1.cjs";
|
|
8
|
-
import "../../frontendConfig-DPpzM5cz.cjs";
|
|
9
|
-
import "../../test-types-Dsu8RJZu.cjs";
|
|
10
|
-
import "../../spiffyWidgets-DK7Ekcy7.cjs";
|
|
11
|
-
import "../../search-6RrxBXD6.cjs";
|
|
12
|
-
import "../../index-OkKEOL6H.cjs";
|
|
13
|
-
import "../../types-DWorwfS-.cjs";
|
|
14
|
-
import { ChatSearchTurn, ChatSearchTurnAtom, SelectedChatSearchFilterOption, SelectedFilterOption, addSearchFilterAtom, additiveDynamicFiltersAtom, chatSearchFiltersAtom, chatSearchHasProductsAtom, chatSearchIdAtom, chatSearchIsLoadingAtom, chatSearchParamsAtom, chatSearchProductSortingAtom, chatSearchProducts, chatSearchQueryAtom, chatSearchStateAtom, clearSearchFiltersAtom, createChatSearchFilterOption, createFilterOption, filteredSearchProductsAtom, getSearchParamsAtom, handleSearchResultsAtom, initiateChatSearchAtom, internalSearchSystemStateAtom, performSearchAtom, removeSearchFilterAtom, searchAtom, searchFiltersAtom, searchParamsAtom, searchProductSortingAtom, searchSelectedFiltersAtom, searchSystemAtom, selectedFilterOptionsAtom, setChatSearchParamsAtom, setSearchParams } from "../../index-DUrfTeD5.cjs";
|
|
1
|
+
import { ChatSearchTurn, ChatSearchTurnAtom, SelectedChatSearchFilterOption, additiveDynamicFiltersAtom, chatSearchFiltersAtom, chatSearchHasProductsAtom, chatSearchIdAtom, chatSearchIsLoadingAtom, chatSearchParamsAtom, chatSearchProductSortingAtom, chatSearchProducts, chatSearchQueryAtom, chatSearchStateAtom, createChatSearchFilterOption, getSearchParamsAtom, handleSearchResultsAtom, initiateChatSearchAtom, selectedFilterOptionsAtom, setChatSearchParamsAtom, setSearchParams } from "./chatSearch.cjs";
|
|
2
|
+
import { SelectedFilterOption, addSearchFilterAtom, clearSearchFiltersAtom, createFilterOption, filteredSearchProductsAtom, internalSearchSystemStateAtom, performSearchAtom, removeSearchFilterAtom, searchAtom, searchFiltersAtom, searchParamsAtom, searchProductSortingAtom, searchSelectedFiltersAtom, searchSystemAtom } from "./searchAPI.cjs";
|
|
15
3
|
export { ChatSearchTurn, ChatSearchTurnAtom, SelectedChatSearchFilterOption, SelectedFilterOption, addSearchFilterAtom, additiveDynamicFiltersAtom, chatSearchFiltersAtom, chatSearchHasProductsAtom, chatSearchIdAtom, chatSearchIsLoadingAtom, chatSearchParamsAtom, chatSearchProductSortingAtom, chatSearchProducts, chatSearchQueryAtom, chatSearchStateAtom, clearSearchFiltersAtom, createChatSearchFilterOption, createFilterOption, filteredSearchProductsAtom, getSearchParamsAtom, handleSearchResultsAtom, initiateChatSearchAtom, internalSearchSystemStateAtom, performSearchAtom, removeSearchFilterAtom, searchAtom, searchFiltersAtom, searchParamsAtom, searchProductSortingAtom, searchSelectedFiltersAtom, searchSystemAtom, selectedFilterOptionsAtom, setChatSearchParamsAtom, setSearchParams };
|
|
@@ -1,15 +1,3 @@
|
|
|
1
|
-
import "
|
|
2
|
-
import "
|
|
3
|
-
import "../../index-Dxpscrvz.js";
|
|
4
|
-
import "../../responseGenerics-D9bS-Dd6.js";
|
|
5
|
-
import "../../utils-BRkGP1eb.js";
|
|
6
|
-
import "../../index-Bb3zXP0P.js";
|
|
7
|
-
import "../../chatElementDisplayLocation-BO3fY4hq.js";
|
|
8
|
-
import "../../frontendConfig-msK69LYN.js";
|
|
9
|
-
import "../../test-types-BEml_bm3.js";
|
|
10
|
-
import "../../spiffyWidgets-MTUAQq_u.js";
|
|
11
|
-
import "../../search-DrJiCT7d.js";
|
|
12
|
-
import "../../index-D7htGSQC.js";
|
|
13
|
-
import "../../types-BegmH0S1.js";
|
|
14
|
-
import { ChatSearchTurn, ChatSearchTurnAtom, SelectedChatSearchFilterOption, SelectedFilterOption, addSearchFilterAtom, additiveDynamicFiltersAtom, chatSearchFiltersAtom, chatSearchHasProductsAtom, chatSearchIdAtom, chatSearchIsLoadingAtom, chatSearchParamsAtom, chatSearchProductSortingAtom, chatSearchProducts, chatSearchQueryAtom, chatSearchStateAtom, clearSearchFiltersAtom, createChatSearchFilterOption, createFilterOption, filteredSearchProductsAtom, getSearchParamsAtom, handleSearchResultsAtom, initiateChatSearchAtom, internalSearchSystemStateAtom, performSearchAtom, removeSearchFilterAtom, searchAtom, searchFiltersAtom, searchParamsAtom, searchProductSortingAtom, searchSelectedFiltersAtom, searchSystemAtom, selectedFilterOptionsAtom, setChatSearchParamsAtom, setSearchParams } from "../../index-BVsXKN48.js";
|
|
1
|
+
import { ChatSearchTurn, ChatSearchTurnAtom, SelectedChatSearchFilterOption, additiveDynamicFiltersAtom, chatSearchFiltersAtom, chatSearchHasProductsAtom, chatSearchIdAtom, chatSearchIsLoadingAtom, chatSearchParamsAtom, chatSearchProductSortingAtom, chatSearchProducts, chatSearchQueryAtom, chatSearchStateAtom, createChatSearchFilterOption, getSearchParamsAtom, handleSearchResultsAtom, initiateChatSearchAtom, selectedFilterOptionsAtom, setChatSearchParamsAtom, setSearchParams } from "./chatSearch.js";
|
|
2
|
+
import { SelectedFilterOption, addSearchFilterAtom, clearSearchFiltersAtom, createFilterOption, filteredSearchProductsAtom, internalSearchSystemStateAtom, performSearchAtom, removeSearchFilterAtom, searchAtom, searchFiltersAtom, searchParamsAtom, searchProductSortingAtom, searchSelectedFiltersAtom, searchSystemAtom } from "./searchAPI.js";
|
|
15
3
|
export { ChatSearchTurn, ChatSearchTurnAtom, SelectedChatSearchFilterOption, SelectedFilterOption, addSearchFilterAtom, additiveDynamicFiltersAtom, chatSearchFiltersAtom, chatSearchHasProductsAtom, chatSearchIdAtom, chatSearchIsLoadingAtom, chatSearchParamsAtom, chatSearchProductSortingAtom, chatSearchProducts, chatSearchQueryAtom, chatSearchStateAtom, clearSearchFiltersAtom, createChatSearchFilterOption, createFilterOption, filteredSearchProductsAtom, getSearchParamsAtom, handleSearchResultsAtom, initiateChatSearchAtom, internalSearchSystemStateAtom, performSearchAtom, removeSearchFilterAtom, searchAtom, searchFiltersAtom, searchParamsAtom, searchProductSortingAtom, searchSelectedFiltersAtom, searchSystemAtom, selectedFilterOptionsAtom, setChatSearchParamsAtom, setSearchParams };
|
|
@@ -1,31 +1,4 @@
|
|
|
1
|
-
import "
|
|
2
|
-
import "
|
|
3
|
-
import "../../logger-Co0IA3k5.js";
|
|
4
|
-
import "../../models-C9_O47X4.js";
|
|
5
|
-
import "../../featureGates-D4Me_IZH.js";
|
|
6
|
-
import "../../urlsParser-DLCzibqU.js";
|
|
7
|
-
import "../../graphql-CbI_HNEp.js";
|
|
8
|
-
import "../../utils-C4ci_t0-.js";
|
|
9
|
-
import "../../api-bHEYmSiT.js";
|
|
10
|
-
import "../../utilityTypes-B2KuRn37.js";
|
|
11
|
-
import "../../variantInfo-BfKlkaWU.js";
|
|
12
|
-
import "../../localStorageContext-DAOJ4be4.js";
|
|
13
|
-
import "../../enviveConfig-BlIkxiAF.js";
|
|
14
|
-
import "../../orgAnalyticsConfig-CpBmga08.js";
|
|
15
|
-
import "../../atomStore-DEcDhiLp.js";
|
|
16
|
-
import "../../app-Aqkm_SlS.js";
|
|
17
|
-
import "../../enviveConfigContext-1_EivtCa.js";
|
|
18
|
-
import "../../featureFlagServiceContext-CAPrb4e_.js";
|
|
19
|
-
import "../../amplitudeContext-BlCtIx5s.js";
|
|
20
|
-
import "../../chatState-C8aDBHkl.js";
|
|
21
|
-
import "../../graphqlConfig-CZGjJ8hP.js";
|
|
22
|
-
import "../../chat-Bxd6htvi.js";
|
|
23
|
-
import "../../org-h32_LSEb.js";
|
|
24
|
-
import "../../newOrgConfigAtom-DEUj6H-p.js";
|
|
25
|
-
import "../../utils-D82gfbgU.js";
|
|
26
|
-
import { ChatSearchTurnAtom, additiveDynamicFiltersAtom, chatSearchFiltersAtom, chatSearchHasProductsAtom, chatSearchIdAtom, chatSearchIsLoadingAtom, chatSearchParamsAtom, chatSearchProductSortingAtom, chatSearchProducts, chatSearchQueryAtom, chatSearchStateAtom, createChatSearchFilterOption, getSearchParamsAtom, handleSearchResultsAtom, initiateChatSearchAtom, selectedFilterOptionsAtom, setChatSearchParamsAtom, setSearchParams } from "../../chatSearch-BGLT3jWO.js";
|
|
27
|
-
import "../../types-DXnG1tV0.js";
|
|
28
|
-
import "../../searchServiceAdapter-Db6jEcJs.js";
|
|
29
|
-
import { addSearchFilterAtom, clearSearchFiltersAtom, createFilterOption, filteredSearchProductsAtom, internalSearchSystemStateAtom, performSearchAtom, removeSearchFilterAtom, searchAtom, searchFiltersAtom, searchParamsAtom, searchProductSortingAtom, searchSelectedFiltersAtom, searchSystemAtom } from "../../search-Bxfp3AFT.js";
|
|
1
|
+
import { ChatSearchTurnAtom, additiveDynamicFiltersAtom, chatSearchFiltersAtom, chatSearchHasProductsAtom, chatSearchIdAtom, chatSearchIsLoadingAtom, chatSearchParamsAtom, chatSearchProductSortingAtom, chatSearchProducts, chatSearchQueryAtom, chatSearchStateAtom, createChatSearchFilterOption, getSearchParamsAtom, handleSearchResultsAtom, initiateChatSearchAtom, selectedFilterOptionsAtom, setChatSearchParamsAtom, setSearchParams } from "./chatSearch.js";
|
|
2
|
+
import { addSearchFilterAtom, clearSearchFiltersAtom, createFilterOption, filteredSearchProductsAtom, internalSearchSystemStateAtom, performSearchAtom, removeSearchFilterAtom, searchAtom, searchFiltersAtom, searchParamsAtom, searchProductSortingAtom, searchSelectedFiltersAtom, searchSystemAtom } from "./searchAPI.js";
|
|
30
3
|
|
|
31
4
|
export { ChatSearchTurnAtom, addSearchFilterAtom, additiveDynamicFiltersAtom, chatSearchFiltersAtom, chatSearchHasProductsAtom, chatSearchIdAtom, chatSearchIsLoadingAtom, chatSearchParamsAtom, chatSearchProductSortingAtom, chatSearchProducts, chatSearchQueryAtom, chatSearchStateAtom, clearSearchFiltersAtom, createChatSearchFilterOption, createFilterOption, filteredSearchProductsAtom, getSearchParamsAtom, handleSearchResultsAtom, initiateChatSearchAtom, internalSearchSystemStateAtom, performSearchAtom, removeSearchFilterAtom, searchAtom, searchFiltersAtom, searchParamsAtom, searchProductSortingAtom, searchSelectedFiltersAtom, searchSystemAtom, selectedFilterOptionsAtom, setChatSearchParamsAtom, setSearchParams };
|
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
const require_atoms_search_utils = require('./utils.cjs');
|
|
2
|
+
|
|
3
|
+
//#region src/atoms/search/productFilters.ts
|
|
4
|
+
const getPriceBucket = (price, bucketSize) => {
|
|
5
|
+
return Math.floor(price / bucketSize) * bucketSize;
|
|
6
|
+
};
|
|
7
|
+
const isStringArray = (value) => {
|
|
8
|
+
if (!Array.isArray(value)) return false;
|
|
9
|
+
return value.every((item) => typeof item === "string");
|
|
10
|
+
};
|
|
11
|
+
const sortFilter = (filterConfig) => {
|
|
12
|
+
if (filterConfig.type === "price") return (a, b) => Number(a.filterItemId) - Number(b.filterItemId);
|
|
13
|
+
if (filterConfig.type === "dynamic") {
|
|
14
|
+
if (filterConfig.sorting.type === "alphabetic") return (a, b) => a.displayName.localeCompare(b.displayName);
|
|
15
|
+
if (filterConfig.sorting.type === "productCount") return (a, b) => a.productCount === b.productCount ? a.displayName.localeCompare(b.displayName) : b.productCount - a.productCount;
|
|
16
|
+
if (filterConfig.sorting.type === "custom") {
|
|
17
|
+
const sortedKeys = filterConfig.sorting.map;
|
|
18
|
+
return (a, b) => {
|
|
19
|
+
if (sortedKeys[a.displayName] && sortedKeys[b.displayName]) return sortedKeys[a.displayName] - sortedKeys[b.displayName];
|
|
20
|
+
if (sortedKeys[a.displayName]) return -1;
|
|
21
|
+
if (sortedKeys[b.displayName]) return 1;
|
|
22
|
+
return b.productCount - a.productCount;
|
|
23
|
+
};
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
throw new Error("Invaalid search filter configuration");
|
|
27
|
+
};
|
|
28
|
+
var ProductFilters = class {
|
|
29
|
+
static getFiltersForProducts(products, filterConfigs, selectedFilterOptions) {
|
|
30
|
+
if (!products || products.length === 0) return [];
|
|
31
|
+
return [...filterConfigs.map((filterConfig) => products.reduce((acc, product) => {
|
|
32
|
+
if (filterConfig.type === "price") {
|
|
33
|
+
const priceBucket = getPriceBucket(product.salePrice ?? product.originalPrice ?? 0, filterConfig.bucketSize);
|
|
34
|
+
const current = acc.map[priceBucket] ?? {
|
|
35
|
+
filterItemId: priceBucket,
|
|
36
|
+
displayName: `$${priceBucket}-$${priceBucket + filterConfig.bucketSize}`,
|
|
37
|
+
productCount: 0
|
|
38
|
+
};
|
|
39
|
+
acc.map[priceBucket] = {
|
|
40
|
+
...current,
|
|
41
|
+
productCount: current.productCount + 1
|
|
42
|
+
};
|
|
43
|
+
return acc;
|
|
44
|
+
}
|
|
45
|
+
const attributeValues = (product.filters && product.filters?.[filterConfig.attribute]) ?? [];
|
|
46
|
+
if (isStringArray(attributeValues)) attributeValues.forEach((val) => {
|
|
47
|
+
const normalizedVal = val.toLowerCase();
|
|
48
|
+
const current = acc.map[normalizedVal] ?? {
|
|
49
|
+
filterItemId: normalizedVal,
|
|
50
|
+
displayName: require_atoms_search_utils.formatFilterDisplayName(val),
|
|
51
|
+
productCount: 0
|
|
52
|
+
};
|
|
53
|
+
acc.map[normalizedVal] = {
|
|
54
|
+
...current,
|
|
55
|
+
productCount: current.productCount + 1
|
|
56
|
+
};
|
|
57
|
+
});
|
|
58
|
+
return acc;
|
|
59
|
+
}, {
|
|
60
|
+
filterConfig,
|
|
61
|
+
map: {}
|
|
62
|
+
})).map(({ filterConfig, map }) => ({
|
|
63
|
+
filterId: filterConfig.filterId,
|
|
64
|
+
displayName: filterConfig.displayName,
|
|
65
|
+
items: Object.values(map).map((filter) => ({
|
|
66
|
+
filterItemId: filter.filterItemId,
|
|
67
|
+
displayName: filter.displayName,
|
|
68
|
+
productCount: filter.productCount,
|
|
69
|
+
isSelected: selectedFilterOptions.some((option) => option.id === `${filterConfig.filterId}:${filter.filterItemId}`) ?? false
|
|
70
|
+
})).sort(sortFilter(filterConfig))
|
|
71
|
+
}))];
|
|
72
|
+
}
|
|
73
|
+
static filterProducts(products, filterConfigs, selectedFilterOptions, additiveDynamicFilters = false) {
|
|
74
|
+
const selectedFilters = filterConfigs.map((filterConfig) => ({
|
|
75
|
+
filterConfig,
|
|
76
|
+
hasSelectedOptions: selectedFilterOptions.some((option) => option.filterId === filterConfig.filterId)
|
|
77
|
+
})).filter(({ hasSelectedOptions }) => hasSelectedOptions);
|
|
78
|
+
return selectedFilterOptions.length === 0 ? products : products.filter((product) => selectedFilters.reduce((acc, selectedFilter) => {
|
|
79
|
+
if (!acc) return acc;
|
|
80
|
+
if (selectedFilter.filterConfig.type === "price") {
|
|
81
|
+
const priceBucket = getPriceBucket(product.salePrice ?? product.originalPrice ?? 0, selectedFilter.filterConfig.bucketSize);
|
|
82
|
+
if (!selectedFilterOptions.some((option) => option.id === `price:${priceBucket}`)) return false;
|
|
83
|
+
}
|
|
84
|
+
if (selectedFilter.filterConfig.type === "dynamic") {
|
|
85
|
+
const { filterId, attribute } = selectedFilter.filterConfig;
|
|
86
|
+
const attributeValues = product.filters?.[attribute];
|
|
87
|
+
if (!isStringArray(attributeValues)) return false;
|
|
88
|
+
if (selectedFilter.filterConfig.attribute === "dynamic" && !additiveDynamicFilters) {
|
|
89
|
+
if (!selectedFilterOptions.filter((option) => option.filterId === filterId).map((option) => option.filterItemId.toLowerCase()).every((selectedValue) => attributeValues.some((val) => val.toLowerCase() === selectedValue))) return false;
|
|
90
|
+
} else if (!attributeValues.some((val) => selectedFilterOptions.some((option) => option.id === `${filterId}:${val.toLowerCase()}`))) return false;
|
|
91
|
+
}
|
|
92
|
+
return true;
|
|
93
|
+
}, true));
|
|
94
|
+
}
|
|
95
|
+
};
|
|
96
|
+
|
|
97
|
+
//#endregion
|
|
98
|
+
exports.ProductFilters = ProductFilters;
|
|
99
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZHVjdEZpbHRlcnMuY2pzIiwibmFtZXMiOlsiZm9ybWF0RmlsdGVyRGlzcGxheU5hbWUiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXRvbXMvc2VhcmNoL3Byb2R1Y3RGaWx0ZXJzLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFByb2R1Y3RSZXNwb25zZUF0dHJpYnV0ZXMgfSBmcm9tICdzcmMvYXBwbGljYXRpb24vbW9kZWxzJztcbmltcG9ydCB7IEZpbHRlckF0dHJpYnV0ZSB9IGZyb20gJ3NyYy9jb250ZXh0cy90eXBlcyc7XG5pbXBvcnQgeyBTZWxlY3RlZEZpbHRlck9wdGlvbiB9IGZyb20gJ3NyYy9hdG9tcy9zZWFyY2gvc2VhcmNoQVBJJztcbmltcG9ydCB7IENoYXRTZWFyY2hGaWx0ZXIsIENoYXRTZWFyY2hGaWx0ZXJJdGVtIH0gZnJvbSAnLi90eXBlcyc7XG5pbXBvcnQgeyBmb3JtYXRGaWx0ZXJEaXNwbGF5TmFtZSB9IGZyb20gJy4vdXRpbHMnO1xuXG5jb25zdCBnZXRQcmljZUJ1Y2tldCA9IChwcmljZTogbnVtYmVyLCBidWNrZXRTaXplOiBudW1iZXIpID0+IHtcbiAgY29uc3QgYnVja2V0ID0gTWF0aC5mbG9vcihwcmljZSAvIGJ1Y2tldFNpemUpO1xuICByZXR1cm4gYnVja2V0ICogYnVja2V0U2l6ZTtcbn07XG5cbmNvbnN0IGlzU3RyaW5nQXJyYXkgPSAodmFsdWU6IHVua25vd24pOiB2YWx1ZSBpcyBzdHJpbmdbXSA9PiB7XG4gIGlmICghQXJyYXkuaXNBcnJheSh2YWx1ZSkpIHtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cbiAgcmV0dXJuIHZhbHVlLmV2ZXJ5KGl0ZW0gPT4gdHlwZW9mIGl0ZW0gPT09ICdzdHJpbmcnKTtcbn07XG5cbnR5cGUgRmlsdGVyU29ydEZ1bmN0aW9uID0gKGE6IENoYXRTZWFyY2hGaWx0ZXJJdGVtLCBiOiBDaGF0U2VhcmNoRmlsdGVySXRlbSkgPT4gbnVtYmVyO1xuXG5jb25zdCBzb3J0RmlsdGVyID0gKGZpbHRlckNvbmZpZzogRmlsdGVyQXR0cmlidXRlKTogRmlsdGVyU29ydEZ1bmN0aW9uID0+IHtcbiAgaWYgKGZpbHRlckNvbmZpZy50eXBlID09PSAncHJpY2UnKSB7XG4gICAgcmV0dXJuIChhLCBiKSA9PiBOdW1iZXIoYS5maWx0ZXJJdGVtSWQpIC0gTnVtYmVyKGIuZmlsdGVySXRlbUlkKTtcbiAgfVxuICBpZiAoZmlsdGVyQ29uZmlnLnR5cGUgPT09ICdkeW5hbWljJykge1xuICAgIGlmIChmaWx0ZXJDb25maWcuc29ydGluZy50eXBlID09PSAnYWxwaGFiZXRpYycpIHtcbiAgICAgIHJldHVybiAoYSwgYikgPT4gYS5kaXNwbGF5TmFtZS5sb2NhbGVDb21wYXJlKGIuZGlzcGxheU5hbWUpO1xuICAgIH1cbiAgICAvLyBTb3J0IGJ5IHRoZSBudW1iZXIgb2YgcHJvZHVjdHMsIGlmIHRoZXkgbWF0Y2gsIHNvcnQgYnkgYWxwaGFiZXRpY2FsXG4gICAgaWYgKGZpbHRlckNvbmZpZy5zb3J0aW5nLnR5cGUgPT09ICdwcm9kdWN0Q291bnQnKSB7XG4gICAgICByZXR1cm4gKGEsIGIpID0+XG4gICAgICAgIGEucHJvZHVjdENvdW50ID09PSBiLnByb2R1Y3RDb3VudFxuICAgICAgICAgID8gYS5kaXNwbGF5TmFtZS5sb2NhbGVDb21wYXJlKGIuZGlzcGxheU5hbWUpXG4gICAgICAgICAgOiBiLnByb2R1Y3RDb3VudCAtIGEucHJvZHVjdENvdW50O1xuICAgIH1cbiAgICBpZiAoZmlsdGVyQ29uZmlnLnNvcnRpbmcudHlwZSA9PT0gJ2N1c3RvbScpIHtcbiAgICAgIGNvbnN0IHNvcnRlZEtleXMgPSBmaWx0ZXJDb25maWcuc29ydGluZy5tYXA7XG4gICAgICByZXR1cm4gKGEsIGIpID0+IHtcbiAgICAgICAgaWYgKHNvcnRlZEtleXNbYS5kaXNwbGF5TmFtZV0gJiYgc29ydGVkS2V5c1tiLmRpc3BsYXlOYW1lXSkge1xuICAgICAgICAgIC8vIElmIGJvdGggYXJlIGluIHRoZSBzb3J0ZWRLZXlzLCBzb3J0IGJ5IHRoZSBpbmRleFxuICAgICAgICAgIHJldHVybiBzb3J0ZWRLZXlzW2EuZGlzcGxheU5hbWVdIC0gc29ydGVkS2V5c1tiLmRpc3BsYXlOYW1lXTtcbiAgICAgICAgfVxuICAgICAgICAvLyBJZiBvbmx5ICdhJyBpcyBpbiB0aGUgc29ydGVkS2V5cywgcHV0IGl0IGJlZm9yZSB0aGUgb3RoZXJcbiAgICAgICAgaWYgKHNvcnRlZEtleXNbYS5kaXNwbGF5TmFtZV0pIHtcbiAgICAgICAgICByZXR1cm4gLTE7XG4gICAgICAgIH1cbiAgICAgICAgLy8gSWYgb25seSAnYicgaXMgaW4gdGhlIHNvcnRlZEtleXMsIHB1dCBpdCBiZWZvcmUgdGhlIG90aGVyXG4gICAgICAgIGlmIChzb3J0ZWRLZXlzW2IuZGlzcGxheU5hbWVdKSB7XG4gICAgICAgICAgcmV0dXJuIDE7XG4gICAgICAgIH1cbiAgICAgICAgLy8gSWYgbmVpdGhlciBhcmUgaW4gdGhlIHNvcnRlZEtleXMsIHNvcnQgYnkgcHJvZHVjdENvdW50XG4gICAgICAgIHJldHVybiBiLnByb2R1Y3RDb3VudCAtIGEucHJvZHVjdENvdW50O1xuICAgICAgfTtcbiAgICB9XG4gIH1cbiAgdGhyb3cgbmV3IEVycm9yKCdJbnZhYWxpZCBzZWFyY2ggZmlsdGVyIGNvbmZpZ3VyYXRpb24nKTtcbn07XG5cbmV4cG9ydCBjbGFzcyBQcm9kdWN0RmlsdGVycyB7XG4gIHN0YXRpYyBnZXRGaWx0ZXJzRm9yUHJvZHVjdHMoXG4gICAgcHJvZHVjdHM6IFByb2R1Y3RSZXNwb25zZUF0dHJpYnV0ZXNbJ2F0dHJpYnV0ZXMnXVtdLFxuICAgIGZpbHRlckNvbmZpZ3M6IEZpbHRlckF0dHJpYnV0ZVtdLFxuICAgIHNlbGVjdGVkRmlsdGVyT3B0aW9uczogU2VsZWN0ZWRGaWx0ZXJPcHRpb25bXSxcbiAgKTogQ2hhdFNlYXJjaEZpbHRlcltdIHtcbiAgICBpZiAoIXByb2R1Y3RzIHx8IHByb2R1Y3RzLmxlbmd0aCA9PT0gMCkge1xuICAgICAgcmV0dXJuIFtdO1xuICAgIH1cblxuICAgIGNvbnN0IGZpbHRlcnMgPSBmaWx0ZXJDb25maWdzLm1hcChmaWx0ZXJDb25maWcgPT5cbiAgICAgIHByb2R1Y3RzLnJlZHVjZShcbiAgICAgICAgKGFjYywgcHJvZHVjdCkgPT4ge1xuICAgICAgICAgIC8vIFByaWNlIGhhcyBzcGVjaWFsIGhhbmRsaW5nIGZvciB0aGUgZmlsdGVyc1xuICAgICAgICAgIGlmIChmaWx0ZXJDb25maWcudHlwZSA9PT0gJ3ByaWNlJykge1xuICAgICAgICAgICAgY29uc3QgcHJpY2VCdWNrZXQgPSBnZXRQcmljZUJ1Y2tldChcbiAgICAgICAgICAgICAgcHJvZHVjdC5zYWxlUHJpY2UgPz8gcHJvZHVjdC5vcmlnaW5hbFByaWNlID8/IDAsXG4gICAgICAgICAgICAgIGZpbHRlckNvbmZpZy5idWNrZXRTaXplLFxuICAgICAgICAgICAgKTtcbiAgICAgICAgICAgIGNvbnN0IGN1cnJlbnQgPSBhY2MubWFwW3ByaWNlQnVja2V0XSA/PyB7XG4gICAgICAgICAgICAgIGZpbHRlckl0ZW1JZDogcHJpY2VCdWNrZXQsXG4gICAgICAgICAgICAgIGRpc3BsYXlOYW1lOiBgJCR7cHJpY2VCdWNrZXR9LSQke3ByaWNlQnVja2V0ICsgZmlsdGVyQ29uZmlnLmJ1Y2tldFNpemV9YCxcbiAgICAgICAgICAgICAgcHJvZHVjdENvdW50OiAwLFxuICAgICAgICAgICAgfTtcbiAgICAgICAgICAgIGFjYy5tYXBbcHJpY2VCdWNrZXRdID0geyAuLi5jdXJyZW50LCBwcm9kdWN0Q291bnQ6IGN1cnJlbnQucHJvZHVjdENvdW50ICsgMSB9O1xuICAgICAgICAgICAgcmV0dXJuIGFjYztcbiAgICAgICAgICB9XG5cbiAgICAgICAgICAvLyBBc3N1bWUgdGhhdCB0aGUgXCJhdHRyaWJ1dGVcIiBpcyBhbiBhcnJheSBvZiB2YWx1ZXNcbiAgICAgICAgICBjb25zdCBhdHRyaWJ1dGVWYWx1ZXMgPVxuICAgICAgICAgICAgKHByb2R1Y3QuZmlsdGVycyAmJiBwcm9kdWN0LmZpbHRlcnM/LltmaWx0ZXJDb25maWcuYXR0cmlidXRlXSkgPz8gW107XG4gICAgICAgICAgaWYgKGlzU3RyaW5nQXJyYXkoYXR0cmlidXRlVmFsdWVzKSkge1xuICAgICAgICAgICAgYXR0cmlidXRlVmFsdWVzLmZvckVhY2godmFsID0+IHtcbiAgICAgICAgICAgICAgY29uc3Qgbm9ybWFsaXplZFZhbCA9IHZhbC50b0xvd2VyQ2FzZSgpO1xuICAgICAgICAgICAgICBjb25zdCBjdXJyZW50ID0gYWNjLm1hcFtub3JtYWxpemVkVmFsXSA/PyB7XG4gICAgICAgICAgICAgICAgZmlsdGVySXRlbUlkOiBub3JtYWxpemVkVmFsLFxuICAgICAgICAgICAgICAgIGRpc3BsYXlOYW1lOiBmb3JtYXRGaWx0ZXJEaXNwbGF5TmFtZSh2YWwpLCAvLyBLZWVwIG9yaWdpbmFsIGNhc2UgZm9yIGRpc3BsYXlcbiAgICAgICAgICAgICAgICBwcm9kdWN0Q291bnQ6IDAsXG4gICAgICAgICAgICAgIH07XG4gICAgICAgICAgICAgIGFjYy5tYXBbbm9ybWFsaXplZFZhbF0gPSB7IC4uLmN1cnJlbnQsIHByb2R1Y3RDb3VudDogY3VycmVudC5wcm9kdWN0Q291bnQgKyAxIH07XG4gICAgICAgICAgICB9KTtcbiAgICAgICAgICB9XG5cbiAgICAgICAgICByZXR1cm4gYWNjO1xuICAgICAgICB9LFxuICAgICAgICB7XG4gICAgICAgICAgZmlsdGVyQ29uZmlnLFxuICAgICAgICAgIG1hcDoge30gYXMgUmVjb3JkPHN0cmluZywgQ2hhdFNlYXJjaEZpbHRlckl0ZW0+LFxuICAgICAgICB9LFxuICAgICAgKSxcbiAgICApO1xuXG4gICAgY29uc3QgdHJhbnNmb3JtZWRGaWx0ZXJzOiBDaGF0U2VhcmNoRmlsdGVyW10gPSBmaWx0ZXJzLm1hcCgoeyBmaWx0ZXJDb25maWcsIG1hcCB9KSA9PiAoe1xuICAgICAgZmlsdGVySWQ6IGZpbHRlckNvbmZpZy5maWx0ZXJJZCxcbiAgICAgIGRpc3BsYXlOYW1lOiBmaWx0ZXJDb25maWcuZGlzcGxheU5hbWUsXG4gICAgICBpdGVtczogT2JqZWN0LnZhbHVlcyhtYXApXG4gICAgICAgIC5tYXAoZmlsdGVyID0+ICh7XG4gICAgICAgICAgZmlsdGVySXRlbUlkOiBmaWx0ZXIuZmlsdGVySXRlbUlkLFxuICAgICAgICAgIGRpc3BsYXlOYW1lOiBmaWx0ZXIuZGlzcGxheU5hbWUsXG4gICAgICAgICAgcHJvZHVjdENvdW50OiBmaWx0ZXIucHJvZHVjdENvdW50LFxuICAgICAgICAgIGlzU2VsZWN0ZWQ6XG4gICAgICAgICAgICBzZWxlY3RlZEZpbHRlck9wdGlvbnMuc29tZShcbiAgICAgICAgICAgICAgb3B0aW9uID0+IG9wdGlvbi5pZCA9PT0gYCR7ZmlsdGVyQ29uZmlnLmZpbHRlcklkfToke2ZpbHRlci5maWx0ZXJJdGVtSWR9YCxcbiAgICAgICAgICAgICkgPz8gZmFsc2UsXG4gICAgICAgIH0pKVxuICAgICAgICAuc29ydChzb3J0RmlsdGVyKGZpbHRlckNvbmZpZykpLFxuICAgIH0pKTtcblxuICAgIHJldHVybiBbLi4udHJhbnNmb3JtZWRGaWx0ZXJzXTtcbiAgfVxuXG4gIHN0YXRpYyBmaWx0ZXJQcm9kdWN0cyhcbiAgICBwcm9kdWN0czogUHJvZHVjdFJlc3BvbnNlQXR0cmlidXRlc1snYXR0cmlidXRlcyddW10sXG4gICAgZmlsdGVyQ29uZmlnczogRmlsdGVyQXR0cmlidXRlW10sXG4gICAgc2VsZWN0ZWRGaWx0ZXJPcHRpb25zOiBTZWxlY3RlZEZpbHRlck9wdGlvbltdLFxuICAgIGFkZGl0aXZlRHluYW1pY0ZpbHRlcnMgPSBmYWxzZSwgLy8gU2V0IHRoaXMgdG8gdHJ1ZSB0byByZXN0b3JlIHRoZSBvcmlnaW5hbCBiZWhhdmlvciB3aGVyZSBzdGFja2luZyBmaWx0ZXJzIGhhcyBPUiBsb2dpYy5cbiAgKSB7XG4gICAgY29uc3Qgc2VsZWN0ZWRGaWx0ZXJzID0gZmlsdGVyQ29uZmlnc1xuICAgICAgLm1hcChmaWx0ZXJDb25maWcgPT4gKHtcbiAgICAgICAgZmlsdGVyQ29uZmlnLFxuICAgICAgICBoYXNTZWxlY3RlZE9wdGlvbnM6IHNlbGVjdGVkRmlsdGVyT3B0aW9ucy5zb21lKFxuICAgICAgICAgIG9wdGlvbiA9PiBvcHRpb24uZmlsdGVySWQgPT09IGZpbHRlckNvbmZpZy5maWx0ZXJJZCxcbiAgICAgICAgKSxcbiAgICAgIH0pKVxuICAgICAgLmZpbHRlcigoeyBoYXNTZWxlY3RlZE9wdGlvbnMgfSkgPT4gaGFzU2VsZWN0ZWRPcHRpb25zKTtcbiAgICByZXR1cm4gc2VsZWN0ZWRGaWx0ZXJPcHRpb25zLmxlbmd0aCA9PT0gMFxuICAgICAgPyBwcm9kdWN0c1xuICAgICAgOiBwcm9kdWN0cy5maWx0ZXIocHJvZHVjdCA9PlxuICAgICAgICAgIHNlbGVjdGVkRmlsdGVycy5yZWR1Y2UoKGFjYywgc2VsZWN0ZWRGaWx0ZXIpID0+IHtcbiAgICAgICAgICAgIC8vIEZpbmRpbmcgb25lIGZhbHNlIHJlbW92ZXMgdGhlIHByb2R1Y3RcbiAgICAgICAgICAgIGlmICghYWNjKSB7XG4gICAgICAgICAgICAgIHJldHVybiBhY2M7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICAvLyBQcmljZSBpcyBzcGVjaWFsXG4gICAgICAgICAgICBpZiAoc2VsZWN0ZWRGaWx0ZXIuZmlsdGVyQ29uZmlnLnR5cGUgPT09ICdwcmljZScpIHtcbiAgICAgICAgICAgICAgY29uc3QgcHJpY2VCdWNrZXQgPSBnZXRQcmljZUJ1Y2tldChcbiAgICAgICAgICAgICAgICBwcm9kdWN0LnNhbGVQcmljZSA/PyBwcm9kdWN0Lm9yaWdpbmFsUHJpY2UgPz8gMCxcbiAgICAgICAgICAgICAgICBzZWxlY3RlZEZpbHRlci5maWx0ZXJDb25maWcuYnVja2V0U2l6ZSxcbiAgICAgICAgICAgICAgKTtcbiAgICAgICAgICAgICAgY29uc3QgbWF0Y2hlc1ByaWNlRmlsdGVyID0gc2VsZWN0ZWRGaWx0ZXJPcHRpb25zLnNvbWUoXG4gICAgICAgICAgICAgICAgb3B0aW9uID0+IG9wdGlvbi5pZCA9PT0gYHByaWNlOiR7cHJpY2VCdWNrZXR9YCxcbiAgICAgICAgICAgICAgKTtcbiAgICAgICAgICAgICAgaWYgKCFtYXRjaGVzUHJpY2VGaWx0ZXIpIHtcbiAgICAgICAgICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgaWYgKHNlbGVjdGVkRmlsdGVyLmZpbHRlckNvbmZpZy50eXBlID09PSAnZHluYW1pYycpIHtcbiAgICAgICAgICAgICAgLy8gZHluYW1pYyBpcyBtaXNsZWFkaW5nIGhlcmUuIEl0cyBub3QganVzdCBkeW5hbWljIGZpbHRlcnMsIGJ1dCBzdGF0aWMgZmlsdGVycyBiZWNhdXNlIHRoZSBjb25maWcgY291bnRzIHN0YXRpYyBmaWx0ZXJzIGFzIHR5cGU6IGR5bmFtaWMuXG4gICAgICAgICAgICAgIGNvbnN0IHsgZmlsdGVySWQsIGF0dHJpYnV0ZSB9ID0gc2VsZWN0ZWRGaWx0ZXIuZmlsdGVyQ29uZmlnO1xuICAgICAgICAgICAgICBjb25zdCBhdHRyaWJ1dGVWYWx1ZXMgPSBwcm9kdWN0LmZpbHRlcnM/LlthdHRyaWJ1dGVdO1xuXG4gICAgICAgICAgICAgIGlmICghaXNTdHJpbmdBcnJheShhdHRyaWJ1dGVWYWx1ZXMpKSB7XG4gICAgICAgICAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgICAgICAgICAgICB9XG5cbiAgICAgICAgICAgICAgY29uc3QgaXNEeW5hbWljRmlsdGVyID0gc2VsZWN0ZWRGaWx0ZXIuZmlsdGVyQ29uZmlnLmF0dHJpYnV0ZSA9PT0gJ2R5bmFtaWMnOyAvLyBUcnVlIGR5bmFtaWMgZmlsdGVycyAodGhlIG9uZXMgdGhhdCBhcHBlYXIgYmVuZWF0aCB0aGUgc2VhcmNoIGlucHV0KVxuICAgICAgICAgICAgICBjb25zdCBpc1N1YnRyYWN0aXZlTG9naWMgPSBpc0R5bmFtaWNGaWx0ZXIgJiYgIWFkZGl0aXZlRHluYW1pY0ZpbHRlcnM7XG5cbiAgICAgICAgICAgICAgaWYgKGlzU3VidHJhY3RpdmVMb2dpYykge1xuICAgICAgICAgICAgICAgIC8vIEFORCBsb2dpYyBmb3Igc3VidHJhY3RpdmUgZHluYW1pYyBmaWx0ZXJzIGFuZCBiZXR3ZWVuIHN0YXRpYyBmaWx0ZXIgY2F0ZWdvcmllc1xuICAgICAgICAgICAgICAgIGNvbnN0IHNlbGVjdGVkT3B0aW9uc0ZvclRoaXNGaWx0ZXIgPSBzZWxlY3RlZEZpbHRlck9wdGlvbnNcbiAgICAgICAgICAgICAgICAgIC5maWx0ZXIob3B0aW9uID0+IG9wdGlvbi5maWx0ZXJJZCA9PT0gZmlsdGVySWQpXG4gICAgICAgICAgICAgICAgICAubWFwKG9wdGlvbiA9PiBvcHRpb24uZmlsdGVySXRlbUlkLnRvTG93ZXJDYXNlKCkpO1xuXG4gICAgICAgICAgICAgICAgY29uc3QgaGFzQWxsU2VsZWN0ZWRWYWx1ZXMgPSBzZWxlY3RlZE9wdGlvbnNGb3JUaGlzRmlsdGVyLmV2ZXJ5KHNlbGVjdGVkVmFsdWUgPT5cbiAgICAgICAgICAgICAgICAgIGF0dHJpYnV0ZVZhbHVlcy5zb21lKHZhbCA9PiB2YWwudG9Mb3dlckNhc2UoKSA9PT0gc2VsZWN0ZWRWYWx1ZSksXG4gICAgICAgICAgICAgICAgKTtcblxuICAgICAgICAgICAgICAgIGlmICghaGFzQWxsU2VsZWN0ZWRWYWx1ZXMpIHtcbiAgICAgICAgICAgICAgICAgIHJldHVybiBmYWxzZTtcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgLy8gT1IgbG9naWMgZm9yIHN0YXRpYyBmaWx0ZXJzIGluIHRoZSBzaWRlYmFyIHdpdGhpbiBhIGNhdGVnb3J5LlxuICAgICAgICAgICAgICAgIGNvbnN0IG1hdGNoZXMgPSBhdHRyaWJ1dGVWYWx1ZXMuc29tZSh2YWwgPT5cbiAgICAgICAgICAgICAgICAgIHNlbGVjdGVkRmlsdGVyT3B0aW9ucy5zb21lKFxuICAgICAgICAgICAgICAgICAgICBvcHRpb24gPT4gb3B0aW9uLmlkID09PSBgJHtmaWx0ZXJJZH06JHt2YWwudG9Mb3dlckNhc2UoKX1gLFxuICAgICAgICAgICAgICAgICAgKSxcbiAgICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgICAgIGlmICghbWF0Y2hlcykge1xuICAgICAgICAgICAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfVxuICAgICAgICAgICAgcmV0dXJuIHRydWU7XG4gICAgICAgICAgfSwgdHJ1ZSksXG4gICAgICAgICk7XG4gIH1cbn1cbiJdLCJtYXBwaW5ncyI6Ijs7O0FBTUEsTUFBTSxrQkFBa0IsT0FBZSxlQUF1QjtBQUU1RCxRQURlLEtBQUssTUFBTSxRQUFRLFdBQVcsR0FDN0I7O0FBR2xCLE1BQU0saUJBQWlCLFVBQXNDO0FBQzNELEtBQUksQ0FBQyxNQUFNLFFBQVEsTUFBTSxDQUN2QixRQUFPO0FBRVQsUUFBTyxNQUFNLE9BQU0sU0FBUSxPQUFPLFNBQVMsU0FBUzs7QUFLdEQsTUFBTSxjQUFjLGlCQUFzRDtBQUN4RSxLQUFJLGFBQWEsU0FBUyxRQUN4QixTQUFRLEdBQUcsTUFBTSxPQUFPLEVBQUUsYUFBYSxHQUFHLE9BQU8sRUFBRSxhQUFhO0FBRWxFLEtBQUksYUFBYSxTQUFTLFdBQVc7QUFDbkMsTUFBSSxhQUFhLFFBQVEsU0FBUyxhQUNoQyxTQUFRLEdBQUcsTUFBTSxFQUFFLFlBQVksY0FBYyxFQUFFLFlBQVk7QUFHN0QsTUFBSSxhQUFhLFFBQVEsU0FBUyxlQUNoQyxTQUFRLEdBQUcsTUFDVCxFQUFFLGlCQUFpQixFQUFFLGVBQ2pCLEVBQUUsWUFBWSxjQUFjLEVBQUUsWUFBWSxHQUMxQyxFQUFFLGVBQWUsRUFBRTtBQUUzQixNQUFJLGFBQWEsUUFBUSxTQUFTLFVBQVU7R0FDMUMsTUFBTSxhQUFhLGFBQWEsUUFBUTtBQUN4QyxXQUFRLEdBQUcsTUFBTTtBQUNmLFFBQUksV0FBVyxFQUFFLGdCQUFnQixXQUFXLEVBQUUsYUFFNUMsUUFBTyxXQUFXLEVB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
|