@envive-ai/react-hooks 0.3.18 → 0.3.19-alpha-marlo-1
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/dist/application/commerce-api.cjs +14 -13
- package/dist/application/commerce-api.js +14 -13
- package/dist/application/logging/logger.cjs +16 -10
- package/dist/application/logging/logger.js +16 -10
- package/dist/application/models/guards/api/isApiFormResponse.cjs +9 -8
- package/dist/application/models/guards/api/isApiFormResponse.js +9 -8
- package/dist/application/models/guards/api/isApiFormSubmittedResponseAttributes.cjs +6 -5
- package/dist/application/models/guards/api/isApiFormSubmittedResponseAttributes.js +6 -5
- package/dist/application/models/guards/api/isApiOrderResponseAttributes.cjs +19 -18
- package/dist/application/models/guards/api/isApiOrderResponseAttributes.js +19 -18
- package/dist/application/models/guards/api/isApiOrgConfigResults.cjs +27 -26
- package/dist/application/models/guards/api/isApiOrgConfigResults.js +27 -26
- package/dist/application/models/guards/api/isApiOrganizationConfig.cjs +23 -22
- package/dist/application/models/guards/api/isApiOrganizationConfig.js +23 -22
- package/dist/application/models/guards/api/isApiProductResponseAttributes.cjs +12 -11
- package/dist/application/models/guards/api/isApiProductResponseAttributes.js +12 -11
- package/dist/application/models/guards/api/isApiResponse.cjs +7 -6
- package/dist/application/models/guards/api/isApiResponse.js +7 -6
- package/dist/application/models/guards/graphQL/isGraphQLColorsConfig.cjs +5 -4
- package/dist/application/models/guards/graphQL/isGraphQLColorsConfig.js +5 -4
- package/dist/application/models/validators/validateGraphQLFrontendConfig.cjs +15 -14
- package/dist/application/models/validators/validateGraphQLFrontendConfig.js +15 -14
- package/dist/application/utils/analyticsUtils.cjs +4 -3
- package/dist/application/utils/analyticsUtils.js +4 -3
- package/dist/application/utils/elementObserver.d.cts +2 -2
- package/dist/application/utils/elementObserver.d.ts +2 -2
- package/dist/application/utils/nextMessageRequestToApiRequest.cjs +3 -1
- package/dist/application/utils/nextMessageRequestToApiRequest.js +3 -1
- package/dist/atoms/app/index.d.ts +7 -7
- package/dist/atoms/app/variant.cjs +3 -2
- package/dist/atoms/app/variant.d.ts +6 -6
- package/dist/atoms/app/variant.js +3 -2
- package/dist/atoms/chat/chatState.d.cts +18 -18
- package/dist/atoms/chat/chatState.d.ts +18 -18
- package/dist/atoms/chat/form.d.ts +3 -3
- package/dist/atoms/chat/index.d.cts +2 -2
- package/dist/atoms/chat/index.d.ts +3 -3
- package/dist/atoms/chat/lastMessage.d.cts +2 -2
- package/dist/atoms/chat/lastMessage.d.ts +2 -2
- package/dist/atoms/chat/messageQueue.d.ts +7 -7
- package/dist/atoms/chat/performanceMetrics.cjs +3 -2
- package/dist/atoms/chat/performanceMetrics.d.cts +6 -6
- package/dist/atoms/chat/performanceMetrics.d.ts +6 -6
- package/dist/atoms/chat/performanceMetrics.js +3 -2
- package/dist/atoms/chat/renderedWidgetRefs.d.cts +2 -2
- package/dist/atoms/chat/renderedWidgetRefs.d.ts +2 -2
- package/dist/atoms/chat/replies.d.cts +2 -2
- package/dist/atoms/chat/replies.d.ts +3 -3
- package/dist/atoms/chat/suggestions.d.cts +2 -2
- package/dist/atoms/chat/suggestions.d.ts +3 -3
- package/dist/atoms/envive/enviveConfig.cjs +5 -4
- package/dist/atoms/envive/enviveConfig.d.cts +13 -13
- package/dist/atoms/envive/enviveConfig.d.ts +13 -13
- package/dist/atoms/envive/enviveConfig.js +5 -4
- package/dist/atoms/globalSearch/globalSearch.d.cts +5 -5
- package/dist/atoms/globalSearch/globalSearch.d.ts +5 -5
- package/dist/atoms/org/customerService.d.cts +6 -6
- package/dist/atoms/org/customerService.d.ts +6 -6
- package/dist/atoms/org/graphqlConfig.d.cts +4 -4
- package/dist/atoms/org/graphqlConfig.d.ts +4 -4
- package/dist/atoms/org/newOrgConfigAtom.d.cts +2 -2
- package/dist/atoms/org/newOrgConfigAtom.d.ts +2 -2
- package/dist/atoms/org/orgAnalyticsConfig.d.cts +5 -5
- package/dist/atoms/org/orgAnalyticsConfig.d.ts +5 -5
- package/dist/atoms/search/chatSearch.d.cts +17 -17
- package/dist/atoms/search/chatSearch.d.ts +17 -17
- package/dist/atoms/search/searchAPI.d.cts +13 -13
- package/dist/atoms/search/searchAPI.d.ts +13 -13
- package/dist/atoms/search/types.d.cts +1 -1
- package/dist/atoms/search/types.d.ts +1 -1
- package/dist/atoms/search/utils.d.ts +1 -1
- package/dist/atoms/widget/chatPreviewLoading.d.ts +2 -2
- package/dist/contexts/amplitudeContext/amplitudeContext.cjs +4 -4
- package/dist/contexts/amplitudeContext/amplitudeContext.js +3 -3
- package/dist/contexts/enviveConfigContext/enviveConfigContext.cjs +26 -15
- package/dist/contexts/enviveConfigContext/enviveConfigContext.d.cts +2 -4
- package/dist/contexts/enviveConfigContext/enviveConfigContext.d.ts +2 -4
- package/dist/contexts/enviveConfigContext/enviveConfigContext.js +29 -16
- package/dist/contexts/enviveConfigContext/index.cjs +2 -1
- package/dist/contexts/enviveConfigContext/index.d.cts +2 -1
- package/dist/contexts/enviveConfigContext/index.d.ts +2 -1
- package/dist/contexts/enviveConfigContext/index.js +2 -1
- package/dist/contexts/enviveConfigContext/useEnviveConfig.cjs +12 -0
- package/dist/contexts/enviveConfigContext/useEnviveConfig.d.cts +7 -0
- package/dist/contexts/enviveConfigContext/useEnviveConfig.d.ts +7 -0
- package/dist/contexts/enviveConfigContext/useEnviveConfig.js +11 -0
- package/dist/contexts/enviveContext/WindowChatToggleBinder.cjs +7 -5
- package/dist/contexts/enviveContext/WindowChatToggleBinder.js +6 -4
- package/dist/contexts/enviveContext/enviveContext.cjs +77 -48
- package/dist/contexts/enviveContext/enviveContext.d.cts +8 -2
- package/dist/contexts/enviveContext/enviveContext.d.ts +8 -2
- package/dist/contexts/enviveContext/enviveContext.js +78 -49
- package/dist/contexts/enviveContext/index.d.cts +2 -2
- package/dist/contexts/enviveContext/index.d.ts +2 -2
- package/dist/contexts/featureFlagServiceContext/featureFlagServiceContext.cjs +7 -6
- package/dist/contexts/featureFlagServiceContext/featureFlagServiceContext.js +7 -6
- package/dist/contexts/graphqlContext/graphqlContext.cjs +8 -7
- package/dist/contexts/graphqlContext/graphqlContext.js +8 -7
- package/dist/contexts/hardcopyContext/hardcopyContext.cjs +9 -8
- package/dist/contexts/hardcopyContext/hardcopyContext.js +9 -8
- package/dist/contexts/localStorageContext/localStorageContext.cjs +4 -3
- package/dist/contexts/localStorageContext/localStorageContext.js +4 -3
- package/dist/contexts/pageContext/pageContext.cjs +23 -4
- package/dist/contexts/pageContext/pageContext.d.cts +3 -1
- package/dist/contexts/pageContext/pageContext.d.ts +3 -1
- package/dist/contexts/pageContext/pageContext.js +24 -5
- package/dist/contexts/pageContext/types.d.ts +1 -1
- package/dist/contexts/salesAgentContext/chatAPI.cjs +3 -2
- package/dist/contexts/salesAgentContext/chatAPI.js +3 -2
- package/dist/contexts/salesAgentContext/salesAgentContext.cjs +4 -3
- package/dist/contexts/salesAgentContext/salesAgentContext.js +4 -3
- package/dist/contexts/salesAgentContext/salesAgentService.cjs +3 -2
- package/dist/contexts/salesAgentContext/salesAgentService.js +3 -2
- package/dist/contexts/searchContext/searchContext.cjs +8 -6
- package/dist/contexts/searchContext/searchContext.js +7 -5
- package/dist/contexts/sessionStorageContext/sessionStorageContext.cjs +3 -2
- package/dist/contexts/sessionStorageContext/sessionStorageContext.js +3 -2
- package/dist/contexts/systemSettingsContext/systemSettingsContext.d.cts +2 -2
- package/dist/contexts/systemSettingsContext/systemSettingsContext.d.ts +2 -2
- package/dist/contexts/types.d.cts +1 -1
- package/dist/contexts/types.d.ts +1 -1
- package/dist/contexts/typesV3.d.cts +1 -1
- package/dist/contexts/typesV3.d.ts +1 -1
- package/dist/contexts/uiConfigContext/index.cjs +0 -1
- package/dist/contexts/uiConfigContext/index.d.cts +2 -2
- package/dist/contexts/uiConfigContext/index.d.ts +2 -2
- package/dist/contexts/uiConfigContext/index.js +2 -2
- package/dist/contexts/uiConfigContext/uiConfigContext.cjs +13 -30
- package/dist/contexts/uiConfigContext/uiConfigContext.d.cts +5 -9
- package/dist/contexts/uiConfigContext/uiConfigContext.d.ts +5 -9
- package/dist/contexts/uiConfigContext/uiConfigContext.js +14 -29
- package/dist/contexts/userIdentityContext/userIdentityContext.cjs +7 -7
- package/dist/contexts/userIdentityContext/userIdentityContext.js +7 -7
- package/dist/contexts/widgetConfigContext/widgetConfigContext.cjs +4 -3
- package/dist/contexts/widgetConfigContext/widgetConfigContext.js +4 -3
- package/dist/hooks/CustomerSupportHandoff/useCustomerSupportHandoff.cjs +4 -3
- package/dist/hooks/CustomerSupportHandoff/useCustomerSupportHandoff.js +4 -3
- package/dist/hooks/GrabAndScroll/useGrabAndScroll.d.cts +2 -2
- package/dist/hooks/GrabAndScroll/useGrabAndScroll.d.ts +2 -2
- package/dist/hooks/WidgetInteraction/types.d.ts +1 -1
- package/dist/hooks/WidgetInteraction/useWidgetInteraction.cjs +2 -2
- package/dist/hooks/WidgetInteraction/useWidgetInteraction.js +2 -2
- package/dist/hooks/WidgetInteraction/utils.cjs +2 -1
- package/dist/hooks/WidgetInteraction/utils.d.ts +1 -1
- package/dist/hooks/WidgetInteraction/utils.js +2 -1
- package/dist/hooks/utils.d.ts +1 -1
- package/dist/services/amplitudeService/amplitudeService.cjs +20 -7
- package/dist/services/amplitudeService/amplitudeService.d.cts +4 -1
- package/dist/services/amplitudeService/amplitudeService.d.ts +4 -1
- package/dist/services/amplitudeService/amplitudeService.js +20 -7
- package/dist/services/ga4ProjectionService/ga4ProjectionService.cjs +3 -2
- package/dist/services/ga4ProjectionService/ga4ProjectionService.js +3 -2
- package/dist/services/userIdentityService/userIdentityService.cjs +8 -7
- package/dist/services/userIdentityService/userIdentityService.js +8 -7
- package/package.json +2 -2
- package/src/application/commerce-api.ts +14 -12
- package/src/application/logging/logger.ts +33 -8
- package/src/application/models/guards/api/isApiFormResponse.ts +9 -7
- package/src/application/models/guards/api/isApiFormSubmittedResponseAttributes.ts +6 -4
- package/src/application/models/guards/api/isApiOrderResponseAttributes.ts +19 -17
- package/src/application/models/guards/api/isApiOrgConfigResults.ts +40 -48
- package/src/application/models/guards/api/isApiOrganizationConfig.ts +25 -38
- package/src/application/models/guards/api/isApiProductResponseAttributes.ts +12 -10
- package/src/application/models/guards/api/isApiResponse.ts +7 -5
- package/src/application/models/guards/graphQL/isGraphQLColorsConfig.ts +5 -3
- package/src/application/models/validators/validateGraphQLFrontendConfig.ts +15 -13
- package/src/application/utils/analyticsUtils.ts +4 -4
- package/src/application/utils/nextMessageRequestToApiRequest.ts +2 -0
- package/src/atoms/app/variant.ts +3 -1
- package/src/atoms/chat/performanceMetrics.ts +3 -1
- package/src/atoms/envive/enviveConfig.ts +5 -3
- package/src/contexts/amplitudeContext/__tests__/amplitudeContext.test.tsx +5 -4
- package/src/contexts/amplitudeContext/amplitudeContext.tsx +1 -5
- package/src/contexts/enviveConfigContext/__tests__/enviveConfigContext.test.tsx +4 -3
- package/src/contexts/enviveConfigContext/enviveConfigContext.tsx +50 -35
- package/src/contexts/enviveConfigContext/index.ts +1 -0
- package/src/contexts/enviveConfigContext/useEnviveConfig.ts +9 -0
- package/src/contexts/enviveContext/WindowChatToggleBinder.tsx +6 -4
- package/src/contexts/enviveContext/enviveContext.tsx +109 -50
- package/src/contexts/featureFlagServiceContext/featureFlagServiceContext.tsx +11 -12
- package/src/contexts/graphqlContext/__tests__/graphqlContext.test.tsx +4 -4
- package/src/contexts/graphqlContext/graphqlContext.tsx +8 -6
- package/src/contexts/hardcopyContext/hardcopyContext.tsx +9 -7
- package/src/contexts/localStorageContext/__tests__/localStorageContext.test.tsx +6 -6
- package/src/contexts/localStorageContext/localStorageContext.tsx +4 -2
- package/src/contexts/pageContext/__tests__/pageContext.test.tsx +5 -5
- package/src/contexts/pageContext/pageContext.tsx +22 -2
- package/src/contexts/salesAgentContext/chatAPI.ts +5 -5
- package/src/contexts/salesAgentContext/salesAgentContext.tsx +4 -2
- package/src/contexts/salesAgentContext/salesAgentService.ts +4 -2
- package/src/contexts/searchContext/__tests__/searchContext.test.tsx +15 -12
- package/src/contexts/searchContext/searchContext.tsx +6 -4
- package/src/contexts/sessionStorageContext/sessionStorageContext.tsx +3 -1
- package/src/contexts/uiConfigContext/__tests__/uiConfigContext.test.tsx +7 -32
- package/src/contexts/uiConfigContext/uiConfigContext.tsx +17 -29
- package/src/contexts/userIdentityContext/__tests__/userIdentityContext.test.tsx +5 -5
- package/src/contexts/userIdentityContext/userIdentityContext.tsx +7 -6
- package/src/contexts/widgetConfigContext/__tests__/widgetConfigContext.test.tsx +7 -7
- package/src/contexts/widgetConfigContext/widgetConfigContext.tsx +4 -2
- package/src/hooks/CustomerSupportHandoff/useCustomerSupportHandoff.ts +4 -2
- package/src/hooks/Search/__tests__/useSearch.test.tsx +14 -8
- package/src/hooks/WidgetInteraction/useWidgetInteraction.ts +3 -2
- package/src/hooks/WidgetInteraction/utils.ts +3 -1
- package/src/services/amplitudeService/__tests__/amplitudeService.test.ts +59 -9
- package/src/services/amplitudeService/amplitudeService.ts +27 -6
- package/src/services/ga4ProjectionService/ga4ProjectionService.ts +3 -1
- package/src/services/userIdentityService/userIdentityService.ts +8 -8
|
@@ -3,17 +3,17 @@ const require_logger = require('../../application/logging/logger.cjs');
|
|
|
3
3
|
const require_localStorageContext = require('../localStorageContext/localStorageContext.cjs');
|
|
4
4
|
require('../localStorageContext/index.cjs');
|
|
5
5
|
const require_enviveConfigContext = require('../enviveConfigContext/enviveConfigContext.cjs');
|
|
6
|
+
require('../enviveConfigContext/index.cjs');
|
|
6
7
|
const require_featureFlagServiceContext = require('../featureFlagServiceContext/featureFlagServiceContext.cjs');
|
|
7
8
|
const require_amplitudeContext = require('../amplitudeContext/amplitudeContext.cjs');
|
|
8
9
|
require('../amplitudeContext/index.cjs');
|
|
9
|
-
require('../enviveConfigContext/index.cjs');
|
|
10
|
-
const require_enviveConfigService = require('../../services/enviveConfigService/enviveConfigService.cjs');
|
|
11
|
-
const require_userIdentityService = require('../../services/userIdentityService/userIdentityService.cjs');
|
|
12
|
-
require('../../services/userIdentityService/index.cjs');
|
|
13
10
|
const require_graphqlContext = require('../graphqlContext/graphqlContext.cjs');
|
|
14
11
|
const require_newOrgConfigContext = require('../newOrgConfigContext/newOrgConfigContext.cjs');
|
|
15
12
|
const require_enviveCssContext = require('../enviveCssContext/enviveCssContext.cjs');
|
|
16
13
|
require('../enviveCssContext/index.cjs');
|
|
14
|
+
const require_enviveConfigService = require('../../services/enviveConfigService/enviveConfigService.cjs');
|
|
15
|
+
const require_userIdentityService = require('../../services/userIdentityService/userIdentityService.cjs');
|
|
16
|
+
require('../../services/userIdentityService/index.cjs');
|
|
17
17
|
require('../featureFlagServiceContext/index.cjs');
|
|
18
18
|
require('../graphqlContext/index.cjs');
|
|
19
19
|
require('../newOrgConfigContext/index.cjs');
|
|
@@ -31,14 +31,12 @@ const require_widgetConfigContext = require('../widgetConfigContext/widgetConfig
|
|
|
31
31
|
require('../widgetConfigContext/index.cjs');
|
|
32
32
|
const require_pageContext = require('../pageContext/pageContext.cjs');
|
|
33
33
|
require('../pageContext/index.cjs');
|
|
34
|
-
const require_uiConfigContext = require('../uiConfigContext/uiConfigContext.cjs');
|
|
35
|
-
require('../uiConfigContext/index.cjs');
|
|
36
34
|
const require_WindowChatToggleBinder = require('./WindowChatToggleBinder.cjs');
|
|
37
35
|
let react = require("react");
|
|
38
36
|
let react_jsx_runtime = require("react/jsx-runtime");
|
|
39
37
|
|
|
40
38
|
//#region src/contexts/enviveContext/enviveContext.tsx
|
|
41
|
-
const
|
|
39
|
+
const logger = new require_logger.default("enviveContext");
|
|
42
40
|
const SearchAgentWrapper = ({ children, enabledAgents }) => {
|
|
43
41
|
if (!enabledAgents.includes(require_contexts_enviveContext_types.EnviveAgent.SearchAgent)) return children;
|
|
44
42
|
return /* @__PURE__ */ (0, react_jsx_runtime.jsx)(require_searchContext.SearchProvider, { children });
|
|
@@ -54,8 +52,21 @@ const SalesAgentWrapper = ({ children, enabledAgents, previewMode, showDebugBar,
|
|
|
54
52
|
})
|
|
55
53
|
});
|
|
56
54
|
};
|
|
57
|
-
const EnviveProvider = ({ children, previewMode = false, overrideConfig, enabledAgents, enviveConfigService: inputEnviveConfigService, featureFlagService: inputFeatureFlagService, amplitudeService: inputAmplitudeService, userIdentityService: inputUserIdentityService, mockV3ConfigToDeprecatedConfig = false, requestV3Config = false, mockSalesAgentData, hardcopyOverride, ...config }) => {
|
|
55
|
+
const EnviveProvider = ({ children, previewMode = false, overrideConfig, enabledAgents, enviveConfigService: inputEnviveConfigService, featureFlagService: inputFeatureFlagService, amplitudeService: inputAmplitudeService, userIdentityService: inputUserIdentityService, mockV3ConfigToDeprecatedConfig = false, requestV3Config = false, mockSalesAgentData, hardcopyOverride, extensionService, ...config }) => {
|
|
58
56
|
const [userId, setUserId] = (0, react.useState)("");
|
|
57
|
+
const didReportSuccessRef = (0, react.useRef)(false);
|
|
58
|
+
const invokeExtensionCallback = (0, react.useCallback)((callback) => {
|
|
59
|
+
if (!callback) return;
|
|
60
|
+
Promise.resolve(callback()).catch((error) => {
|
|
61
|
+
logger.logDebug("Extension status callback failed", error);
|
|
62
|
+
});
|
|
63
|
+
}, []);
|
|
64
|
+
const invokeExtensionErrorCallback = (0, react.useCallback)((error) => {
|
|
65
|
+
if (!extensionService?.onInjectionError) return;
|
|
66
|
+
Promise.resolve(extensionService.onInjectionError(error)).catch((callbackError) => {
|
|
67
|
+
logger.logDebug("Extension error callback failed", callbackError);
|
|
68
|
+
});
|
|
69
|
+
}, [extensionService]);
|
|
59
70
|
const userIdService = (0, react.useMemo)(() => inputUserIdentityService ?? new require_userIdentityService.UserIdentityService({ apiKey: config?.amplitudeApiKey || "" }), [config?.amplitudeApiKey, inputUserIdentityService]);
|
|
60
71
|
(0, react.useEffect)(() => {
|
|
61
72
|
const fetchUserId = async () => {
|
|
@@ -71,22 +82,42 @@ const EnviveProvider = ({ children, previewMode = false, overrideConfig, enabled
|
|
|
71
82
|
const source = "app";
|
|
72
83
|
const [enviveServiceConfig, setEnviveServiceConfig] = (0, react.useState)(null);
|
|
73
84
|
(0, react.useEffect)(() => {
|
|
74
|
-
(
|
|
85
|
+
invokeExtensionCallback(extensionService?.onInjectionLoading);
|
|
86
|
+
const enviveConfigService = inputEnviveConfigService ?? new require_enviveConfigService.EnviveConfigService({
|
|
75
87
|
baseUrl: config?.baseUrl || "",
|
|
76
88
|
apiKey: config?.orgLevelApiKey || "",
|
|
77
89
|
userId,
|
|
78
90
|
namespace,
|
|
79
91
|
source
|
|
80
|
-
})).getEnviveConfig().then((newConfig) => {
|
|
81
|
-
setEnviveServiceConfig(newConfig);
|
|
82
|
-
return newConfig;
|
|
83
92
|
});
|
|
93
|
+
const fetchEnviveConfig = async () => {
|
|
94
|
+
try {
|
|
95
|
+
setEnviveServiceConfig(await enviveConfigService.getEnviveConfig());
|
|
96
|
+
} catch (error) {
|
|
97
|
+
const resolvedError = error instanceof Error ? error : /* @__PURE__ */ new Error("Failed to load envive config");
|
|
98
|
+
logger.logError("Failed to initialize EnviveProvider", resolvedError);
|
|
99
|
+
invokeExtensionErrorCallback(resolvedError);
|
|
100
|
+
}
|
|
101
|
+
};
|
|
102
|
+
fetchEnviveConfig();
|
|
84
103
|
}, [
|
|
85
104
|
config,
|
|
86
105
|
userId,
|
|
87
106
|
namespace,
|
|
88
107
|
source,
|
|
89
|
-
inputEnviveConfigService
|
|
108
|
+
inputEnviveConfigService,
|
|
109
|
+
extensionService,
|
|
110
|
+
invokeExtensionCallback,
|
|
111
|
+
invokeExtensionErrorCallback
|
|
112
|
+
]);
|
|
113
|
+
(0, react.useEffect)(() => {
|
|
114
|
+
if (!enviveServiceConfig || didReportSuccessRef.current) return;
|
|
115
|
+
didReportSuccessRef.current = true;
|
|
116
|
+
invokeExtensionCallback(extensionService?.onInjectionSuccess);
|
|
117
|
+
}, [
|
|
118
|
+
enviveServiceConfig,
|
|
119
|
+
extensionService,
|
|
120
|
+
invokeExtensionCallback
|
|
90
121
|
]);
|
|
91
122
|
const enviveConfig = (0, react.useMemo)(() => ({
|
|
92
123
|
...config,
|
|
@@ -94,45 +125,43 @@ const EnviveProvider = ({ children, previewMode = false, overrideConfig, enabled
|
|
|
94
125
|
orgShortName: enviveServiceConfig?.org?.org?.short_name || "",
|
|
95
126
|
orgId: enviveServiceConfig?.org?.org?.id || ""
|
|
96
127
|
}), [config, enviveServiceConfig]);
|
|
97
|
-
|
|
98
|
-
|
|
128
|
+
logger.logDebug("enviveContext: enviveServiceConfig", enviveServiceConfig, config);
|
|
129
|
+
logger.logDebug("enviveContext: enviveConfig", enviveConfig);
|
|
99
130
|
const featureFlagService = (0, react.useMemo)(() => inputFeatureFlagService ?? new require_featureFlagServiceContext.FeatureFlagService(enviveConfig.featureGates), [enviveConfig.featureGates, inputFeatureFlagService]);
|
|
100
131
|
if (enviveServiceConfig === null || enviveConfig === null) return null;
|
|
101
|
-
return /* @__PURE__ */ (0, react_jsx_runtime.jsx)(
|
|
102
|
-
|
|
103
|
-
children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(
|
|
109
|
-
|
|
110
|
-
children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(
|
|
111
|
-
|
|
112
|
-
children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(
|
|
113
|
-
|
|
114
|
-
children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
132
|
+
return /* @__PURE__ */ (0, react_jsx_runtime.jsx)(require_enviveConfigContext.EnviveConfigProvider, {
|
|
133
|
+
...enviveConfig,
|
|
134
|
+
children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(require_graphqlContext.GraphQLProvider, {
|
|
135
|
+
mockV3ConfigToDeprecatedConfig,
|
|
136
|
+
requestV3Config,
|
|
137
|
+
children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(require_newOrgConfigContext.NewOrgConfigProvider, {
|
|
138
|
+
overrideConfig,
|
|
139
|
+
children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(require_localStorageContext.LocalStorageProvider, { children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(require_featureFlagServiceContext.FeatureFlagServiceProvider, {
|
|
140
|
+
featureFlagService,
|
|
141
|
+
children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(require_userIdentityContext.UserIdentityProvider, {
|
|
142
|
+
userIdService,
|
|
143
|
+
children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(require_amplitudeContext.AmplitudeProvider, {
|
|
144
|
+
externalAmplitudeService: inputAmplitudeService,
|
|
145
|
+
children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(require_pageContext.PageProvider, {
|
|
146
|
+
previewMode,
|
|
147
|
+
onUrlResolverNotReady: extensionService?.onInjectionError,
|
|
148
|
+
children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(require_widgetConfigContext.WidgetConfigProvider, { children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(require_hardcopyContext.HardcopyProvider, {
|
|
149
|
+
hardcopyOverride,
|
|
150
|
+
children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(require_enviveCssContext.EnviveCssProvider, { children: /* @__PURE__ */ (0, react_jsx_runtime.jsxs)(SearchAgentWrapper, {
|
|
151
|
+
enabledAgents,
|
|
152
|
+
children: [/* @__PURE__ */ (0, react_jsx_runtime.jsx)(require_WindowChatToggleBinder.WindowChatToggleBinder, {}), /* @__PURE__ */ (0, react_jsx_runtime.jsx)(SalesAgentWrapper, {
|
|
121
153
|
enabledAgents,
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
}) })
|
|
130
|
-
}) }) })
|
|
131
|
-
})
|
|
154
|
+
showDebugBar: config.enviveOn || false,
|
|
155
|
+
previewMode,
|
|
156
|
+
mockSalesAgentData,
|
|
157
|
+
children
|
|
158
|
+
})]
|
|
159
|
+
}) })
|
|
160
|
+
}) })
|
|
132
161
|
})
|
|
133
162
|
})
|
|
134
|
-
})
|
|
135
|
-
})
|
|
163
|
+
})
|
|
164
|
+
}) })
|
|
136
165
|
})
|
|
137
166
|
})
|
|
138
167
|
});
|
|
@@ -140,4 +169,4 @@ const EnviveProvider = ({ children, previewMode = false, overrideConfig, enabled
|
|
|
140
169
|
|
|
141
170
|
//#endregion
|
|
142
171
|
exports.EnviveProvider = EnviveProvider;
|
|
143
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"enviveContext.cjs","names":["SearchAgentWrapper: React.FC<AgentWrapperProps>","EnviveAgent","SearchProvider","SalesAgentWrapper: React.FC<SalesAgentWrapperProps>","SystemSettingsContextProvider","SalesAgentProvider","EnviveProvider: React.FC<EnviveProviderProps>","UserIdentityService","EnviveConfigService","FeatureFlagService","EnviveConfigProvider","GraphQLProvider","NewOrgConfigProvider","LocalStorageProvider","FeatureFlagServiceProvider","UserIdentityProvider","AmplitudeProvider","PageProvider","UiConfigProvider","WidgetConfigProvider","HardcopyProvider","EnviveCssProvider","WindowChatToggleBinder"],"sources":["../../../src/contexts/enviveContext/enviveContext.tsx"],"sourcesContent":["import { ReactNode, createContext, useEffect, useMemo, useState } from 'react';\n\nimport { OrgConfigFeatureGate } from 'src/application/models/api/orgConfigResults';\nimport { EnviveConfigService, EnviveServiceConfig } from 'src/services/enviveConfigService';\nimport { AmplitudeService } from 'src/services/amplitudeService/amplitudeService';\nimport Logger from 'src/application/logging/logger';\nimport { UserIdentityService } from 'src/services/userIdentityService';\nimport { AmplitudeProvider } from '../amplitudeContext';\nimport { EnviveConfigProvider } from '../enviveConfigContext';\nimport { EnviveCssProvider } from '../enviveCssContext';\nimport { FeatureFlagService, FeatureFlagServiceProvider } from '../featureFlagServiceContext';\nimport { GraphQLProvider, GraphQlConfigValues } from '../graphqlContext';\nimport { LocalStorageProvider } from '../localStorageContext';\nimport { NewOrgConfigProvider } from '../newOrgConfigContext';\nimport { UserIdentityProvider } from '../userIdentityContext';\nimport { EnviveAgent } from './types';\nimport { SearchProvider } from '../searchContext';\nimport { SalesAgentProvider } from '../salesAgentContext/salesAgentContext';\nimport { SystemSettingsContextProvider } from '../systemSettingsContext';\nimport { HardcopyProvider, HardcopyResponse } from '../hardcopyContext';\nimport { WidgetTypeV3 } from '../typesV3';\nimport { WidgetConfigProvider } from '../widgetConfigContext';\nimport { PageProvider } from '../pageContext';\nimport { UiConfigProvider } from '../uiConfigContext';\nimport { WindowChatToggleBinder } from './WindowChatToggleBinder';\n\nconst EnviveContext = createContext<null>(null);\n\ninterface AgentWrapperProps {\n  children: ReactNode;\n  enabledAgents: EnviveAgent[];\n}\n\ninterface EnviveProviderProps extends AgentWrapperProps {\n  amplitudeApiKey?: string;\n  dataResidency?: string;\n  env?: string;\n  baseUrl?: string;\n  reactAppName?: string;\n  cdnUrl?: string;\n  contextSource?: string;\n  orgLevelApiKey?: string;\n  orgShortName?: string;\n  identifyingPrefix: string;\n  featureOverrides?: Record<string, boolean>;\n  variantUrlOverride?: string;\n  variantInfoOverride?: any;\n  show?: boolean;\n  enviveOn?: boolean;\n  publicKey?: string;\n  featureGates?: OrgConfigFeatureGate[]; // New prop for feature gates\n  featureFlagService?: FeatureFlagService;\n  enviveConfigService?: EnviveConfigService;\n  amplitudeService?: AmplitudeService;\n  mockV3ConfigToDeprecatedConfig?: boolean;\n  requestV3Config?: boolean;\n  userIdentityService?: UserIdentityService;\n  previewMode?: boolean;\n  overrideConfig?: GraphQlConfigValues;\n  mockSalesAgentData?: any;\n  hardcopyOverride?: Partial<Record<WidgetTypeV3, HardcopyResponse>>;\n}\n\nconst SearchAgentWrapper: React.FC<AgentWrapperProps> = ({ children, enabledAgents }) => {\n  if (!enabledAgents.includes(EnviveAgent.SearchAgent)) {\n    return children;\n  }\n  return <SearchProvider>{children}</SearchProvider>;\n};\n\ninterface SalesAgentWrapperProps extends AgentWrapperProps {\n  previewMode?: boolean;\n  showDebugBar: boolean;\n  mockSalesAgentData?: any;\n}\n\nconst SalesAgentWrapper: React.FC<SalesAgentWrapperProps> = ({\n  children,\n  enabledAgents,\n  previewMode,\n  showDebugBar,\n  mockSalesAgentData,\n}) => {\n  if (!enabledAgents.includes(EnviveAgent.SalesAgent)) {\n    return children;\n  }\n  return (\n    <SystemSettingsContextProvider showDebugBar={showDebugBar}>\n      <SalesAgentProvider\n        previewMode={previewMode}\n        mockData={mockSalesAgentData}\n      >\n        {children}\n      </SalesAgentProvider>\n    </SystemSettingsContextProvider>\n  );\n};\n\nexport const EnviveProvider: React.FC<EnviveProviderProps> = ({\n  children,\n  previewMode = false,\n  overrideConfig,\n  enabledAgents,\n  enviveConfigService: inputEnviveConfigService,\n  featureFlagService: inputFeatureFlagService,\n  amplitudeService: inputAmplitudeService,\n  userIdentityService: inputUserIdentityService,\n  mockV3ConfigToDeprecatedConfig = false,\n  requestV3Config = false,\n  mockSalesAgentData,\n  hardcopyOverride,\n  ...config\n}) => {\n  const [userId, setUserId] = useState<string>('');\n\n  const userIdService = useMemo(\n    () =>\n      inputUserIdentityService ??\n      new UserIdentityService({ apiKey: config?.amplitudeApiKey || '' }),\n    [config?.amplitudeApiKey, inputUserIdentityService],\n  );\n\n  useEffect(() => {\n    const fetchUserId = async () => {\n      const id = await userIdService.getUserIdOrDefault();\n      setUserId(id);\n    };\n\n    fetchUserId();\n  }, [config.amplitudeApiKey, inputUserIdentityService, userIdService]);\n\n  const namespace = 'spiffy-react-components'; // TODO: Should this be different from the current namespace?\n  const source = 'app'; // TODO: Make this dependent upon the \"spiffy_on\" query param\n  const [enviveServiceConfig, setEnviveServiceConfig] = useState<EnviveServiceConfig | null>(null);\n\n  useEffect(() => {\n    // Really not happy with this approach, but I'm seeing 429 errors in the tests\n    // because of the rate limiting on the API.\n    const enviveConfigService =\n      inputEnviveConfigService ??\n      new EnviveConfigService({\n        baseUrl: config?.baseUrl || '',\n        apiKey: config?.orgLevelApiKey || '',\n        userId,\n        namespace: namespace || '',\n        source: source || '',\n      });\n    enviveConfigService.getEnviveConfig().then(newConfig => {\n      setEnviveServiceConfig(newConfig);\n      return newConfig;\n    });\n  }, [config, userId, namespace, source, inputEnviveConfigService]);\n\n  const enviveConfig = useMemo(\n    () => ({\n      ...config,\n      featureGates: enviveServiceConfig?.gates || [],\n      orgShortName: enviveServiceConfig?.org?.org?.short_name || '',\n      orgId: enviveServiceConfig?.org?.org?.id || '',\n    }),\n    [config, enviveServiceConfig],\n  );\n  Logger.logDebug('enviveContext: enviveServiceConfig', enviveServiceConfig, config);\n  Logger.logDebug('enviveContext: enviveConfig', enviveConfig);\n\n  const featureFlagService = useMemo(\n    () => inputFeatureFlagService ?? new FeatureFlagService(enviveConfig.featureGates),\n    [enviveConfig.featureGates, inputFeatureFlagService],\n  );\n\n  if (enviveServiceConfig === null || enviveConfig === null) {\n    return null;\n  }\n\n  return (\n    <EnviveContext.Provider value={null}>\n      <EnviveConfigProvider {...enviveConfig}>\n        <GraphQLProvider\n          mockV3ConfigToDeprecatedConfig={mockV3ConfigToDeprecatedConfig}\n          requestV3Config={requestV3Config}\n        >\n          <NewOrgConfigProvider overrideConfig={overrideConfig}>\n            <LocalStorageProvider>\n              <FeatureFlagServiceProvider featureFlagService={featureFlagService}>\n                <UserIdentityProvider userIdService={userIdService}>\n                  <AmplitudeProvider externalAmplitudeService={inputAmplitudeService}>\n                    <PageProvider previewMode={previewMode}>\n                      <UiConfigProvider>\n                        <WidgetConfigProvider>\n                          <HardcopyProvider hardcopyOverride={hardcopyOverride}>\n                            <EnviveCssProvider>\n                              <SearchAgentWrapper enabledAgents={enabledAgents}>\n                                <WindowChatToggleBinder />\n                                <SalesAgentWrapper\n                                  enabledAgents={enabledAgents}\n                                  showDebugBar={config.enviveOn || false}\n                                  previewMode={previewMode}\n                                  mockSalesAgentData={mockSalesAgentData}\n                                >\n                                  {children}\n                                </SalesAgentWrapper>\n                              </SearchAgentWrapper>\n                            </EnviveCssProvider>\n                          </HardcopyProvider>\n                        </WidgetConfigProvider>\n                      </UiConfigProvider>\n                    </PageProvider>\n                  </AmplitudeProvider>\n                </UserIdentityProvider>\n              </FeatureFlagServiceProvider>\n            </LocalStorageProvider>\n          </NewOrgConfigProvider>\n        </GraphQLProvider>\n      </EnviveConfigProvider>\n    </EnviveContext.Provider>\n  );\n};\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA0BA,MAAM,yCAAoC,KAAK;AAqC/C,MAAMA,sBAAmD,EAAE,UAAU,oBAAoB;AACvF,KAAI,CAAC,cAAc,SAASC,iDAAY,YAAY,CAClD,QAAO;AAET,QAAO,2CAACC,wCAAgB,WAA0B;;AASpD,MAAMC,qBAAuD,EAC3D,UACA,eACA,aACA,cACA,yBACI;AACJ,KAAI,CAAC,cAAc,SAASF,iDAAY,WAAW,CACjD,QAAO;AAET,QACE,2CAACG;EAA4C;YAC3C,2CAACC;GACc;GACb,UAAU;GAET;IACkB;GACS;;AAIpC,MAAaC,kBAAiD,EAC5D,UACA,cAAc,OACd,gBACA,eACA,qBAAqB,0BACrB,oBAAoB,yBACpB,kBAAkB,uBAClB,qBAAqB,0BACrB,iCAAiC,OACjC,kBAAkB,OAClB,oBACA,kBACA,GAAG,aACC;CACJ,MAAM,CAAC,QAAQ,iCAA8B,GAAG;CAEhD,MAAM,yCAEF,4BACA,IAAIC,gDAAoB,EAAE,QAAQ,QAAQ,mBAAmB,IAAI,CAAC,EACpE,CAAC,QAAQ,iBAAiB,yBAAyB,CACpD;AAED,4BAAgB;EACd,MAAM,cAAc,YAAY;AAE9B,aADW,MAAM,cAAc,oBAAoB,CACtC;;AAGf,eAAa;IACZ;EAAC,OAAO;EAAiB;EAA0B;EAAc,CAAC;CAErE,MAAM,YAAY;CAClB,MAAM,SAAS;CACf,MAAM,CAAC,qBAAqB,8CAA+D,KAAK;AAEhG,4BAAgB;AAYd,GARE,4BACA,IAAIC,gDAAoB;GACtB,SAAS,QAAQ,WAAW;GAC5B,QAAQ,QAAQ,kBAAkB;GAClC;GACW;GACH;GACT,CAAC,EACgB,iBAAiB,CAAC,MAAK,cAAa;AACtD,0BAAuB,UAAU;AACjC,UAAO;IACP;IACD;EAAC;EAAQ;EAAQ;EAAW;EAAQ;EAAyB,CAAC;CAEjE,MAAM,yCACG;EACL,GAAG;EACH,cAAc,qBAAqB,SAAS,EAAE;EAC9C,cAAc,qBAAqB,KAAK,KAAK,cAAc;EAC3D,OAAO,qBAAqB,KAAK,KAAK,MAAM;EAC7C,GACD,CAAC,QAAQ,oBAAoB,CAC9B;AACD,wBAAO,SAAS,sCAAsC,qBAAqB,OAAO;AAClF,wBAAO,SAAS,+BAA+B,aAAa;CAE5D,MAAM,8CACE,2BAA2B,IAAIC,qDAAmB,aAAa,aAAa,EAClF,CAAC,aAAa,cAAc,wBAAwB,CACrD;AAED,KAAI,wBAAwB,QAAQ,iBAAiB,KACnD,QAAO;AAGT,QACE,2CAAC,cAAc;EAAS,OAAO;YAC7B,2CAACC;GAAqB,GAAI;aACxB,2CAACC;IACiC;IACf;cAEjB,2CAACC;KAAqC;eACpC,2CAACC,8DACC,2CAACC;MAA+C;gBAC9C,2CAACC;OAAoC;iBACnC,2CAACC;QAAkB,0BAA0B;kBAC3C,2CAACC;SAA0B;mBACzB,2CAACC,sDACC,2CAACC,8DACC,2CAACC;UAAmC;oBAClC,2CAACC,wDACC,4CAAC;WAAkC;sBACjC,2CAACC,0DAAyB,EAC1B,2CAAC;YACgB;YACf,cAAc,OAAO,YAAY;YACpB;YACO;YAEnB;aACiB;YACD,GACH;WACH,GACE,GACN;UACN;SACG;QACC;OACI,GACR;MACF;KACP;IACG;GACA"}
|
|
172
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"enviveContext.cjs","names":["Logger","SearchAgentWrapper: React.FC<AgentWrapperProps>","EnviveAgent","SearchProvider","SalesAgentWrapper: React.FC<SalesAgentWrapperProps>","SystemSettingsContextProvider","SalesAgentProvider","EnviveProvider: React.FC<EnviveProviderProps>","UserIdentityService","EnviveConfigService","FeatureFlagService","EnviveConfigProvider","GraphQLProvider","NewOrgConfigProvider","LocalStorageProvider","FeatureFlagServiceProvider","UserIdentityProvider","AmplitudeProvider","PageProvider","WidgetConfigProvider","HardcopyProvider","EnviveCssProvider","WindowChatToggleBinder"],"sources":["../../../src/contexts/enviveContext/enviveContext.tsx"],"sourcesContent":["import { ReactNode, useCallback, useEffect, useMemo, useRef, useState } from 'react';\n\nimport { OrgConfigFeatureGate } from 'src/application/models/api/orgConfigResults';\nimport { EnviveConfigService, EnviveServiceConfig } from 'src/services/enviveConfigService';\nimport { AmplitudeService } from 'src/services/amplitudeService/amplitudeService';\nimport Logger from 'src/application/logging/logger';\nimport { UserIdentityService } from 'src/services/userIdentityService';\nimport { AmplitudeProvider } from '../amplitudeContext';\nimport { EnviveConfigProvider } from '../enviveConfigContext';\nimport { EnviveCssProvider } from '../enviveCssContext';\nimport { FeatureFlagService, FeatureFlagServiceProvider } from '../featureFlagServiceContext';\nimport { GraphQLProvider, GraphQlConfigValues } from '../graphqlContext';\nimport { LocalStorageProvider } from '../localStorageContext';\nimport { NewOrgConfigProvider } from '../newOrgConfigContext';\nimport { UserIdentityProvider } from '../userIdentityContext';\nimport { EnviveAgent } from './types';\nimport { SearchProvider } from '../searchContext';\nimport { SalesAgentProvider } from '../salesAgentContext/salesAgentContext';\nimport { SystemSettingsContextProvider } from '../systemSettingsContext';\nimport { HardcopyProvider, HardcopyResponse } from '../hardcopyContext';\nimport { WidgetTypeV3 } from '../typesV3';\nimport { WidgetConfigProvider } from '../widgetConfigContext';\nimport { PageProvider } from '../pageContext';\nimport { WindowChatToggleBinder } from './WindowChatToggleBinder';\n\nconst logger = new Logger('enviveContext');\n\ninterface AgentWrapperProps {\n  children: ReactNode;\n  enabledAgents: EnviveAgent[];\n}\n\nexport interface ExtensionStatusCallbacks {\n  onInjectionLoading?: () => Promise<unknown> | void;\n  onInjectionSuccess?: () => Promise<unknown> | void;\n  onInjectionError?: (error: Error) => Promise<unknown> | void;\n}\n\ninterface EnviveProviderProps extends AgentWrapperProps {\n  amplitudeApiKey?: string;\n  dataResidency?: string;\n  env?: string;\n  baseUrl?: string;\n  reactAppName?: string;\n  cdnUrl?: string;\n  contextSource?: string;\n  orgLevelApiKey?: string;\n  orgShortName?: string;\n  identifyingPrefix: string;\n  featureOverrides?: Record<string, boolean>;\n  variantUrlOverride?: string;\n  variantInfoOverride?: any;\n  show?: boolean;\n  enviveOn?: boolean;\n  publicKey?: string;\n  featureGates?: OrgConfigFeatureGate[]; // New prop for feature gates\n  featureFlagService?: FeatureFlagService;\n  enviveConfigService?: EnviveConfigService;\n  amplitudeService?: AmplitudeService;\n  mockV3ConfigToDeprecatedConfig?: boolean;\n  requestV3Config?: boolean;\n  userIdentityService?: UserIdentityService;\n  previewMode?: boolean;\n  overrideConfig?: GraphQlConfigValues;\n  mockSalesAgentData?: any;\n  hardcopyOverride?: Partial<Record<WidgetTypeV3, HardcopyResponse>>;\n  extensionService?: ExtensionStatusCallbacks;\n}\n\nconst SearchAgentWrapper: React.FC<AgentWrapperProps> = ({ children, enabledAgents }) => {\n  if (!enabledAgents.includes(EnviveAgent.SearchAgent)) {\n    return children;\n  }\n  return <SearchProvider>{children}</SearchProvider>;\n};\n\ninterface SalesAgentWrapperProps extends AgentWrapperProps {\n  previewMode?: boolean;\n  showDebugBar: boolean;\n  mockSalesAgentData?: any;\n}\n\nconst SalesAgentWrapper: React.FC<SalesAgentWrapperProps> = ({\n  children,\n  enabledAgents,\n  previewMode,\n  showDebugBar,\n  mockSalesAgentData,\n}) => {\n  if (!enabledAgents.includes(EnviveAgent.SalesAgent)) {\n    return children;\n  }\n  return (\n    <SystemSettingsContextProvider showDebugBar={showDebugBar}>\n      <SalesAgentProvider\n        previewMode={previewMode}\n        mockData={mockSalesAgentData}\n      >\n        {children}\n      </SalesAgentProvider>\n    </SystemSettingsContextProvider>\n  );\n};\n\nexport const EnviveProvider: React.FC<EnviveProviderProps> = ({\n  children,\n  previewMode = false,\n  overrideConfig,\n  enabledAgents,\n  enviveConfigService: inputEnviveConfigService,\n  featureFlagService: inputFeatureFlagService,\n  amplitudeService: inputAmplitudeService,\n  userIdentityService: inputUserIdentityService,\n  mockV3ConfigToDeprecatedConfig = false,\n  requestV3Config = false,\n  mockSalesAgentData,\n  hardcopyOverride,\n  extensionService,\n  ...config\n}) => {\n  const [userId, setUserId] = useState<string>('');\n  const didReportSuccessRef = useRef(false);\n\n  const invokeExtensionCallback = useCallback((callback?: () => Promise<unknown> | void) => {\n    if (!callback) {\n      return;\n    }\n\n    Promise.resolve(callback()).catch(error => {\n      logger.logDebug('Extension status callback failed', error);\n    });\n  }, []);\n\n  const invokeExtensionErrorCallback = useCallback(\n    (error: Error) => {\n      if (!extensionService?.onInjectionError) {\n        return;\n      }\n\n      Promise.resolve(extensionService.onInjectionError(error)).catch(callbackError => {\n        logger.logDebug('Extension error callback failed', callbackError);\n      });\n    },\n    [extensionService],\n  );\n\n  const userIdService = useMemo(\n    () =>\n      inputUserIdentityService ??\n      new UserIdentityService({ apiKey: config?.amplitudeApiKey || '' }),\n    [config?.amplitudeApiKey, inputUserIdentityService],\n  );\n\n  useEffect(() => {\n    const fetchUserId = async () => {\n      const id = await userIdService.getUserIdOrDefault();\n      setUserId(id);\n    };\n\n    fetchUserId();\n  }, [config.amplitudeApiKey, inputUserIdentityService, userIdService]);\n\n  const namespace = 'spiffy-react-components'; // TODO: Should this be different from the current namespace?\n  const source = 'app'; // TODO: Make this dependent upon the \"spiffy_on\" query param\n  const [enviveServiceConfig, setEnviveServiceConfig] = useState<EnviveServiceConfig | null>(null);\n\n  useEffect(() => {\n    invokeExtensionCallback(extensionService?.onInjectionLoading);\n\n    // Really not happy with this approach, but I'm seeing 429 errors in the tests\n    // because of the rate limiting on the API.\n    const enviveConfigService =\n      inputEnviveConfigService ??\n      new EnviveConfigService({\n        baseUrl: config?.baseUrl || '',\n        apiKey: config?.orgLevelApiKey || '',\n        userId,\n        namespace: namespace || '',\n        source: source || '',\n      });\n    const fetchEnviveConfig = async () => {\n      try {\n        const newConfig = await enviveConfigService.getEnviveConfig();\n        setEnviveServiceConfig(newConfig);\n      } catch (error) {\n        const resolvedError =\n          error instanceof Error ? error : new Error('Failed to load envive config');\n        logger.logError('Failed to initialize EnviveProvider', resolvedError);\n        invokeExtensionErrorCallback(resolvedError);\n      }\n    };\n\n    fetchEnviveConfig();\n  }, [\n    config,\n    userId,\n    namespace,\n    source,\n    inputEnviveConfigService,\n    extensionService,\n    invokeExtensionCallback,\n    invokeExtensionErrorCallback,\n  ]);\n\n  useEffect(() => {\n    if (!enviveServiceConfig || didReportSuccessRef.current) {\n      return;\n    }\n\n    didReportSuccessRef.current = true;\n    invokeExtensionCallback(extensionService?.onInjectionSuccess);\n  }, [enviveServiceConfig, extensionService, invokeExtensionCallback]);\n\n  const enviveConfig = useMemo(\n    () => ({\n      ...config,\n      featureGates: enviveServiceConfig?.gates || [],\n      orgShortName: enviveServiceConfig?.org?.org?.short_name || '',\n      orgId: enviveServiceConfig?.org?.org?.id || '',\n    }),\n    [config, enviveServiceConfig],\n  );\n  logger.logDebug('enviveContext: enviveServiceConfig', enviveServiceConfig, config);\n  logger.logDebug('enviveContext: enviveConfig', enviveConfig);\n\n  const featureFlagService = useMemo(\n    () => inputFeatureFlagService ?? new FeatureFlagService(enviveConfig.featureGates),\n    [enviveConfig.featureGates, inputFeatureFlagService],\n  );\n\n  if (enviveServiceConfig === null || enviveConfig === null) {\n    return null;\n  }\n\n  return (\n    <EnviveConfigProvider {...enviveConfig}>\n      <GraphQLProvider\n        mockV3ConfigToDeprecatedConfig={mockV3ConfigToDeprecatedConfig}\n        requestV3Config={requestV3Config}\n      >\n        <NewOrgConfigProvider overrideConfig={overrideConfig}>\n          <LocalStorageProvider>\n            <FeatureFlagServiceProvider featureFlagService={featureFlagService}>\n              <UserIdentityProvider userIdService={userIdService}>\n                <AmplitudeProvider externalAmplitudeService={inputAmplitudeService}>\n                  <PageProvider\n                    previewMode={previewMode}\n                    onUrlResolverNotReady={extensionService?.onInjectionError}\n                  >\n                    <WidgetConfigProvider>\n                      <HardcopyProvider hardcopyOverride={hardcopyOverride}>\n                        <EnviveCssProvider>\n                          <SearchAgentWrapper enabledAgents={enabledAgents}>\n                            <WindowChatToggleBinder />\n                            <SalesAgentWrapper\n                              enabledAgents={enabledAgents}\n                              showDebugBar={config.enviveOn || false}\n                              previewMode={previewMode}\n                              mockSalesAgentData={mockSalesAgentData}\n                            >\n                              {children}\n                            </SalesAgentWrapper>\n                          </SearchAgentWrapper>\n                        </EnviveCssProvider>\n                      </HardcopyProvider>\n                    </WidgetConfigProvider>\n                  </PageProvider>\n                </AmplitudeProvider>\n              </UserIdentityProvider>\n            </FeatureFlagServiceProvider>\n          </LocalStorageProvider>\n        </NewOrgConfigProvider>\n      </GraphQLProvider>\n    </EnviveConfigProvider>\n  );\n};\n"],"mappings":"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"}
|
|
@@ -14,6 +14,11 @@ interface AgentWrapperProps {
|
|
|
14
14
|
children: ReactNode;
|
|
15
15
|
enabledAgents: EnviveAgent[];
|
|
16
16
|
}
|
|
17
|
+
interface ExtensionStatusCallbacks {
|
|
18
|
+
onInjectionLoading?: () => Promise<unknown> | void;
|
|
19
|
+
onInjectionSuccess?: () => Promise<unknown> | void;
|
|
20
|
+
onInjectionError?: (error: Error) => Promise<unknown> | void;
|
|
21
|
+
}
|
|
17
22
|
interface EnviveProviderProps extends AgentWrapperProps {
|
|
18
23
|
amplitudeApiKey?: string;
|
|
19
24
|
dataResidency?: string;
|
|
@@ -42,8 +47,9 @@ interface EnviveProviderProps extends AgentWrapperProps {
|
|
|
42
47
|
overrideConfig?: GraphQlConfigValues;
|
|
43
48
|
mockSalesAgentData?: any;
|
|
44
49
|
hardcopyOverride?: Partial<Record<WidgetTypeV3, HardcopyResponse>>;
|
|
50
|
+
extensionService?: ExtensionStatusCallbacks;
|
|
45
51
|
}
|
|
46
52
|
declare const EnviveProvider: React.FC<EnviveProviderProps>;
|
|
47
53
|
//#endregion
|
|
48
|
-
export { EnviveProvider };
|
|
49
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
54
|
+
export { EnviveProvider, ExtensionStatusCallbacks };
|
|
55
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW52aXZlQ29udGV4dC5kLmN0cyIsIm5hbWVzIjpbXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29udGV4dHMvZW52aXZlQ29udGV4dC9lbnZpdmVDb250ZXh0LmQudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgT3JnQ29uZmlnRmVhdHVyZUdhdGUgfSBmcm9tICdzcmMvYXBwbGljYXRpb24vbW9kZWxzL2FwaS9vcmdDb25maWdSZXN1bHRzJztcbmltcG9ydCB7IEVudml2ZUNvbmZpZ1NlcnZpY2UgfSBmcm9tICdzcmMvc2VydmljZXMvZW52aXZlQ29uZmlnU2VydmljZSc7XG5pbXBvcnQgeyBBbXBsaXR1ZGVTZXJ2aWNlIH0gZnJvbSAnc3JjL3NlcnZpY2VzL2FtcGxpdHVkZVNlcnZpY2UvYW1wbGl0dWRlU2VydmljZSc7XG5pbXBvcnQgeyBVc2VySWRlbnRpdHlTZXJ2aWNlIH0gZnJvbSAnc3JjL3NlcnZpY2VzL3VzZXJJZGVudGl0eVNlcnZpY2UnO1xuaW1wb3J0IHsgRmVhdHVyZUZsYWdTZXJ2aWNlIH0gZnJvbSAnLi4vZmVhdHVyZUZsYWdTZXJ2aWNlQ29udGV4dCc7XG5pbXBvcnQgeyBHcmFwaFFsQ29uZmlnVmFsdWVzIH0gZnJvbSAnLi4vZ3JhcGhxbENvbnRleHQnO1xuaW1wb3J0IHsgRW52aXZlQWdlbnQgfSBmcm9tICcuL3R5cGVzJztcbmltcG9ydCB7IEhhcmRjb3B5UmVzcG9uc2UgfSBmcm9tICcuLi9oYXJkY29weUNvbnRleHQnO1xuaW1wb3J0IHsgV2lkZ2V0VHlwZVYzIH0gZnJvbSAnLi4vdHlwZXNWMyc7XG5pbnRlcmZhY2UgQWdlbnRXcmFwcGVyUHJvcHMge1xuICAgIGNoaWxkcmVuOiBSZWFjdE5vZGU7XG4gICAgZW5hYmxlZEFnZW50czogRW52aXZlQWdlbnRbXTtcbn1cbmV4cG9ydCBpbnRlcmZhY2UgRXh0ZW5zaW9uU3RhdHVzQ2FsbGJhY2tzIHtcbiAgICBvbkluamVjdGlvbkxvYWRpbmc/OiAoKSA9PiBQcm9taXNlPHVua25vd24+IHwgdm9pZDtcbiAgICBvbkluamVjdGlvblN1Y2Nlc3M/OiAoKSA9PiBQcm9taXNlPHVua25vd24+IHwgdm9pZDtcbiAgICBvbkluamVjdGlvbkVycm9yPzogKGVycm9yOiBFcnJvcikgPT4gUHJvbWlzZTx1bmtub3duPiB8IHZvaWQ7XG59XG5pbnRlcmZhY2UgRW52aXZlUHJvdmlkZXJQcm9wcyBleHRlbmRzIEFnZW50V3JhcHBlclByb3BzIHtcbiAgICBhbXBsaXR1ZGVBcGlLZXk/OiBzdHJpbmc7XG4gICAgZGF0YVJlc2lkZW5jeT86IHN0cmluZztcbiAgICBlbnY/OiBzdHJpbmc7XG4gICAgYmFzZVVybD86IHN0cmluZztcbiAgICByZWFjdEFwcE5hbWU/OiBzdHJpbmc7XG4gICAgY2RuVXJsPzogc3RyaW5nO1xuICAgIGNvbnRleHRTb3VyY2U/OiBzdHJpbmc7XG4gICAgb3JnTGV2ZWxBcGlLZXk/OiBzdHJpbmc7XG4gICAgb3JnU2hvcnROYW1lPzogc3RyaW5nO1xuICAgIGlkZW50aWZ5aW5nUHJlZml4OiBzdHJpbmc7XG4gICAgZmVhdHVyZU92ZXJyaWRlcz86IFJlY29yZDxzdHJpbmcsIGJvb2xlYW4+O1xuICAgIHZhcmlhbnRVcmxPdmVycmlkZT86IHN0cmluZztcbiAgICB2YXJpYW50SW5mb092ZXJyaWRlPzogYW55O1xuICAgIHNob3c/OiBib29sZWFuO1xuICAgIGVudml2ZU9uPzogYm9vbGVhbjtcbiAgICBwdWJsaWNLZXk/OiBzdHJpbmc7XG4gICAgZmVhdHVyZUdhdGVzPzogT3JnQ29uZmlnRmVhdHVyZUdhdGVbXTtcbiAgICBmZWF0dXJlRmxhZ1NlcnZpY2U/OiBGZWF0dXJlRmxhZ1NlcnZpY2U7XG4gICAgZW52aXZlQ29uZmlnU2VydmljZT86IEVudml2ZUNvbmZpZ1NlcnZpY2U7XG4gICAgYW1wbGl0dWRlU2VydmljZT86IEFtcGxpdHVkZVNlcnZpY2U7XG4gICAgbW9ja1YzQ29uZmlnVG9EZXByZWNhdGVkQ29uZmlnPzogYm9vbGVhbjtcbiAgICByZXF1ZXN0VjNDb25maWc/OiBib29sZWFuO1xuICAgIHVzZXJJZGVudGl0eVNlcnZpY2U/OiBVc2VySWRlbnRpdHlTZXJ2aWNlO1xuICAgIHByZXZpZXdNb2RlPzogYm9vbGVhbjtcbiAgICBvdmVycmlkZUNvbmZpZz86IEdyYXBoUWxDb25maWdWYWx1ZXM7XG4gICAgbW9ja1NhbGVzQWdlbnREYXRhPzogYW55O1xuICAgIGhhcmRjb3B5T3ZlcnJpZGU/OiBQYXJ0aWFsPFJlY29yZDxXaWRnZXRUeXBlVjMsIEhhcmRjb3B5UmVzcG9uc2U+PjtcbiAgICBleHRlbnNpb25TZXJ2aWNlPzogRXh0ZW5zaW9uU3RhdHVzQ2FsbGJhY2tzO1xufVxuZXhwb3J0IGRlY2xhcmUgY29uc3QgRW52aXZlUHJvdmlkZXI6IFJlYWN0LkZDPEVudml2ZVByb3ZpZGVyUHJvcHM+O1xuZXhwb3J0IHt9O1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7QUFVQSxJQUFJLG9CQUFvQjtDQUFDO09BQUc7T0FBQTtDQUFBO0FBQzVCLElBQVcsMkJBQVk7Q0FBQTtPQUFBO09BQUE7T0FBQTtPQUFBO0NBQUE7QUFDdkIsSUFBSSxzQkFBc0I7Q0FBQztPQUFLO09BQUE7T0FBQTtPQUFBO09BQUE7T0FBQTtPQUFBO09BQUE7T0FBQTtPQUFBO09BQUE7T0FBQTtPQUFBO0NBQUE7QUFDaEMsSUFBQSxpQkFBQTtDQUFBO09BQUE7T0FBQSxNQUFBO0NBQUEifQ==
|
|
@@ -14,6 +14,11 @@ interface AgentWrapperProps {
|
|
|
14
14
|
children: ReactNode;
|
|
15
15
|
enabledAgents: EnviveAgent[];
|
|
16
16
|
}
|
|
17
|
+
interface ExtensionStatusCallbacks {
|
|
18
|
+
onInjectionLoading?: () => Promise<unknown> | void;
|
|
19
|
+
onInjectionSuccess?: () => Promise<unknown> | void;
|
|
20
|
+
onInjectionError?: (error: Error) => Promise<unknown> | void;
|
|
21
|
+
}
|
|
17
22
|
interface EnviveProviderProps extends AgentWrapperProps {
|
|
18
23
|
amplitudeApiKey?: string;
|
|
19
24
|
dataResidency?: string;
|
|
@@ -42,8 +47,9 @@ interface EnviveProviderProps extends AgentWrapperProps {
|
|
|
42
47
|
overrideConfig?: GraphQlConfigValues;
|
|
43
48
|
mockSalesAgentData?: any;
|
|
44
49
|
hardcopyOverride?: Partial<Record<WidgetTypeV3, HardcopyResponse>>;
|
|
50
|
+
extensionService?: ExtensionStatusCallbacks;
|
|
45
51
|
}
|
|
46
52
|
declare const EnviveProvider: React.FC<EnviveProviderProps>;
|
|
47
53
|
//#endregion
|
|
48
|
-
export { EnviveProvider };
|
|
49
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
54
|
+
export { EnviveProvider, ExtensionStatusCallbacks };
|
|
55
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW52aXZlQ29udGV4dC5kLnRzIiwibmFtZXMiOltdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb250ZXh0cy9lbnZpdmVDb250ZXh0L2Vudml2ZUNvbnRleHQuZC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBPcmdDb25maWdGZWF0dXJlR2F0ZSB9IGZyb20gJ3NyYy9hcHBsaWNhdGlvbi9tb2RlbHMvYXBpL29yZ0NvbmZpZ1Jlc3VsdHMnO1xuaW1wb3J0IHsgRW52aXZlQ29uZmlnU2VydmljZSB9IGZyb20gJ3NyYy9zZXJ2aWNlcy9lbnZpdmVDb25maWdTZXJ2aWNlJztcbmltcG9ydCB7IEFtcGxpdHVkZVNlcnZpY2UgfSBmcm9tICdzcmMvc2VydmljZXMvYW1wbGl0dWRlU2VydmljZS9hbXBsaXR1ZGVTZXJ2aWNlJztcbmltcG9ydCB7IFVzZXJJZGVudGl0eVNlcnZpY2UgfSBmcm9tICdzcmMvc2VydmljZXMvdXNlcklkZW50aXR5U2VydmljZSc7XG5pbXBvcnQgeyBGZWF0dXJlRmxhZ1NlcnZpY2UgfSBmcm9tICcuLi9mZWF0dXJlRmxhZ1NlcnZpY2VDb250ZXh0JztcbmltcG9ydCB7IEdyYXBoUWxDb25maWdWYWx1ZXMgfSBmcm9tICcuLi9ncmFwaHFsQ29udGV4dCc7XG5pbXBvcnQgeyBFbnZpdmVBZ2VudCB9IGZyb20gJy4vdHlwZXMnO1xuaW1wb3J0IHsgSGFyZGNvcHlSZXNwb25zZSB9IGZyb20gJy4uL2hhcmRjb3B5Q29udGV4dCc7XG5pbXBvcnQgeyBXaWRnZXRUeXBlVjMgfSBmcm9tICcuLi90eXBlc1YzJztcbmludGVyZmFjZSBBZ2VudFdyYXBwZXJQcm9wcyB7XG4gICAgY2hpbGRyZW46IFJlYWN0Tm9kZTtcbiAgICBlbmFibGVkQWdlbnRzOiBFbnZpdmVBZ2VudFtdO1xufVxuZXhwb3J0IGludGVyZmFjZSBFeHRlbnNpb25TdGF0dXNDYWxsYmFja3Mge1xuICAgIG9uSW5qZWN0aW9uTG9hZGluZz86ICgpID0+IFByb21pc2U8dW5rbm93bj4gfCB2b2lkO1xuICAgIG9uSW5qZWN0aW9uU3VjY2Vzcz86ICgpID0+IFByb21pc2U8dW5rbm93bj4gfCB2b2lkO1xuICAgIG9uSW5qZWN0aW9uRXJyb3I/OiAoZXJyb3I6IEVycm9yKSA9PiBQcm9taXNlPHVua25vd24+IHwgdm9pZDtcbn1cbmludGVyZmFjZSBFbnZpdmVQcm92aWRlclByb3BzIGV4dGVuZHMgQWdlbnRXcmFwcGVyUHJvcHMge1xuICAgIGFtcGxpdHVkZUFwaUtleT86IHN0cmluZztcbiAgICBkYXRhUmVzaWRlbmN5Pzogc3RyaW5nO1xuICAgIGVudj86IHN0cmluZztcbiAgICBiYXNlVXJsPzogc3RyaW5nO1xuICAgIHJlYWN0QXBwTmFtZT86IHN0cmluZztcbiAgICBjZG5Vcmw/OiBzdHJpbmc7XG4gICAgY29udGV4dFNvdXJjZT86IHN0cmluZztcbiAgICBvcmdMZXZlbEFwaUtleT86IHN0cmluZztcbiAgICBvcmdTaG9ydE5hbWU/OiBzdHJpbmc7XG4gICAgaWRlbnRpZnlpbmdQcmVmaXg6IHN0cmluZztcbiAgICBmZWF0dXJlT3ZlcnJpZGVzPzogUmVjb3JkPHN0cmluZywgYm9vbGVhbj47XG4gICAgdmFyaWFudFVybE92ZXJyaWRlPzogc3RyaW5nO1xuICAgIHZhcmlhbnRJbmZvT3ZlcnJpZGU/OiBhbnk7XG4gICAgc2hvdz86IGJvb2xlYW47XG4gICAgZW52aXZlT24/OiBib29sZWFuO1xuICAgIHB1YmxpY0tleT86IHN0cmluZztcbiAgICBmZWF0dXJlR2F0ZXM/OiBPcmdDb25maWdGZWF0dXJlR2F0ZVtdO1xuICAgIGZlYXR1cmVGbGFnU2VydmljZT86IEZlYXR1cmVGbGFnU2VydmljZTtcbiAgICBlbnZpdmVDb25maWdTZXJ2aWNlPzogRW52aXZlQ29uZmlnU2VydmljZTtcbiAgICBhbXBsaXR1ZGVTZXJ2aWNlPzogQW1wbGl0dWRlU2VydmljZTtcbiAgICBtb2NrVjNDb25maWdUb0RlcHJlY2F0ZWRDb25maWc/OiBib29sZWFuO1xuICAgIHJlcXVlc3RWM0NvbmZpZz86IGJvb2xlYW47XG4gICAgdXNlcklkZW50aXR5U2VydmljZT86IFVzZXJJZGVudGl0eVNlcnZpY2U7XG4gICAgcHJldmlld01vZGU/OiBib29sZWFuO1xuICAgIG92ZXJyaWRlQ29uZmlnPzogR3JhcGhRbENvbmZpZ1ZhbHVlcztcbiAgICBtb2NrU2FsZXNBZ2VudERhdGE/OiBhbnk7XG4gICAgaGFyZGNvcHlPdmVycmlkZT86IFBhcnRpYWw8UmVjb3JkPFdpZGdldFR5cGVWMywgSGFyZGNvcHlSZXNwb25zZT4+O1xuICAgIGV4dGVuc2lvblNlcnZpY2U/OiBFeHRlbnNpb25TdGF0dXNDYWxsYmFja3M7XG59XG5leHBvcnQgZGVjbGFyZSBjb25zdCBFbnZpdmVQcm92aWRlcjogUmVhY3QuRkM8RW52aXZlUHJvdmlkZXJQcm9wcz47XG5leHBvcnQge307XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7OztBQVVBLElBQUksb0JBQW9CO0NBQUM7T0FBRztPQUFBO0NBQUE7QUFDNUIsSUFBVywyQkFBWTtDQUFBO09BQUE7T0FBQTtPQUFBO09BQUE7Q0FBQTtBQUN2QixJQUFJLHNCQUFzQjtDQUFDO09BQUs7T0FBQTtPQUFBO09BQUE7T0FBQTtPQUFBO09BQUE7T0FBQTtPQUFBO09BQUE7T0FBQTtPQUFBO09BQUE7Q0FBQTtBQUNoQyxJQUFBLGlCQUFBO0NBQUE7T0FBQTtPQUFBLE1BQUE7Q0FBQSJ9
|
|
@@ -2,17 +2,17 @@ import logger_default from "../../application/logging/logger.js";
|
|
|
2
2
|
import { LocalStorageProvider } from "../localStorageContext/localStorageContext.js";
|
|
3
3
|
import "../localStorageContext/index.js";
|
|
4
4
|
import { EnviveConfigProvider } from "../enviveConfigContext/enviveConfigContext.js";
|
|
5
|
+
import "../enviveConfigContext/index.js";
|
|
5
6
|
import { FeatureFlagService, FeatureFlagServiceProvider } from "../featureFlagServiceContext/featureFlagServiceContext.js";
|
|
6
7
|
import { AmplitudeProvider } from "../amplitudeContext/amplitudeContext.js";
|
|
7
8
|
import "../amplitudeContext/index.js";
|
|
8
|
-
import "../enviveConfigContext/index.js";
|
|
9
|
-
import { EnviveConfigService } from "../../services/enviveConfigService/enviveConfigService.js";
|
|
10
|
-
import { UserIdentityService } from "../../services/userIdentityService/userIdentityService.js";
|
|
11
|
-
import "../../services/userIdentityService/index.js";
|
|
12
9
|
import { GraphQLProvider } from "../graphqlContext/graphqlContext.js";
|
|
13
10
|
import { NewOrgConfigProvider } from "../newOrgConfigContext/newOrgConfigContext.js";
|
|
14
11
|
import { EnviveCssProvider } from "../enviveCssContext/enviveCssContext.js";
|
|
15
12
|
import "../enviveCssContext/index.js";
|
|
13
|
+
import { EnviveConfigService } from "../../services/enviveConfigService/enviveConfigService.js";
|
|
14
|
+
import { UserIdentityService } from "../../services/userIdentityService/userIdentityService.js";
|
|
15
|
+
import "../../services/userIdentityService/index.js";
|
|
16
16
|
import "../featureFlagServiceContext/index.js";
|
|
17
17
|
import "../graphqlContext/index.js";
|
|
18
18
|
import "../newOrgConfigContext/index.js";
|
|
@@ -30,14 +30,12 @@ import { WidgetConfigProvider } from "../widgetConfigContext/widgetConfigContext
|
|
|
30
30
|
import "../widgetConfigContext/index.js";
|
|
31
31
|
import { PageProvider } from "../pageContext/pageContext.js";
|
|
32
32
|
import "../pageContext/index.js";
|
|
33
|
-
import { UiConfigProvider } from "../uiConfigContext/uiConfigContext.js";
|
|
34
|
-
import "../uiConfigContext/index.js";
|
|
35
33
|
import { WindowChatToggleBinder } from "./WindowChatToggleBinder.js";
|
|
36
|
-
import {
|
|
34
|
+
import { useCallback, useEffect, useMemo, useRef, useState } from "react";
|
|
37
35
|
import { jsx, jsxs } from "react/jsx-runtime";
|
|
38
36
|
|
|
39
37
|
//#region src/contexts/enviveContext/enviveContext.tsx
|
|
40
|
-
const
|
|
38
|
+
const logger = new logger_default("enviveContext");
|
|
41
39
|
const SearchAgentWrapper = ({ children, enabledAgents }) => {
|
|
42
40
|
if (!enabledAgents.includes(EnviveAgent.SearchAgent)) return children;
|
|
43
41
|
return /* @__PURE__ */ jsx(SearchProvider, { children });
|
|
@@ -53,8 +51,21 @@ const SalesAgentWrapper = ({ children, enabledAgents, previewMode, showDebugBar,
|
|
|
53
51
|
})
|
|
54
52
|
});
|
|
55
53
|
};
|
|
56
|
-
const EnviveProvider = ({ children, previewMode = false, overrideConfig, enabledAgents, enviveConfigService: inputEnviveConfigService, featureFlagService: inputFeatureFlagService, amplitudeService: inputAmplitudeService, userIdentityService: inputUserIdentityService, mockV3ConfigToDeprecatedConfig = false, requestV3Config = false, mockSalesAgentData, hardcopyOverride, ...config }) => {
|
|
54
|
+
const EnviveProvider = ({ children, previewMode = false, overrideConfig, enabledAgents, enviveConfigService: inputEnviveConfigService, featureFlagService: inputFeatureFlagService, amplitudeService: inputAmplitudeService, userIdentityService: inputUserIdentityService, mockV3ConfigToDeprecatedConfig = false, requestV3Config = false, mockSalesAgentData, hardcopyOverride, extensionService, ...config }) => {
|
|
57
55
|
const [userId, setUserId] = useState("");
|
|
56
|
+
const didReportSuccessRef = useRef(false);
|
|
57
|
+
const invokeExtensionCallback = useCallback((callback) => {
|
|
58
|
+
if (!callback) return;
|
|
59
|
+
Promise.resolve(callback()).catch((error) => {
|
|
60
|
+
logger.logDebug("Extension status callback failed", error);
|
|
61
|
+
});
|
|
62
|
+
}, []);
|
|
63
|
+
const invokeExtensionErrorCallback = useCallback((error) => {
|
|
64
|
+
if (!extensionService?.onInjectionError) return;
|
|
65
|
+
Promise.resolve(extensionService.onInjectionError(error)).catch((callbackError) => {
|
|
66
|
+
logger.logDebug("Extension error callback failed", callbackError);
|
|
67
|
+
});
|
|
68
|
+
}, [extensionService]);
|
|
58
69
|
const userIdService = useMemo(() => inputUserIdentityService ?? new UserIdentityService({ apiKey: config?.amplitudeApiKey || "" }), [config?.amplitudeApiKey, inputUserIdentityService]);
|
|
59
70
|
useEffect(() => {
|
|
60
71
|
const fetchUserId = async () => {
|
|
@@ -70,22 +81,42 @@ const EnviveProvider = ({ children, previewMode = false, overrideConfig, enabled
|
|
|
70
81
|
const source = "app";
|
|
71
82
|
const [enviveServiceConfig, setEnviveServiceConfig] = useState(null);
|
|
72
83
|
useEffect(() => {
|
|
73
|
-
(
|
|
84
|
+
invokeExtensionCallback(extensionService?.onInjectionLoading);
|
|
85
|
+
const enviveConfigService = inputEnviveConfigService ?? new EnviveConfigService({
|
|
74
86
|
baseUrl: config?.baseUrl || "",
|
|
75
87
|
apiKey: config?.orgLevelApiKey || "",
|
|
76
88
|
userId,
|
|
77
89
|
namespace,
|
|
78
90
|
source
|
|
79
|
-
})).getEnviveConfig().then((newConfig) => {
|
|
80
|
-
setEnviveServiceConfig(newConfig);
|
|
81
|
-
return newConfig;
|
|
82
91
|
});
|
|
92
|
+
const fetchEnviveConfig = async () => {
|
|
93
|
+
try {
|
|
94
|
+
setEnviveServiceConfig(await enviveConfigService.getEnviveConfig());
|
|
95
|
+
} catch (error) {
|
|
96
|
+
const resolvedError = error instanceof Error ? error : /* @__PURE__ */ new Error("Failed to load envive config");
|
|
97
|
+
logger.logError("Failed to initialize EnviveProvider", resolvedError);
|
|
98
|
+
invokeExtensionErrorCallback(resolvedError);
|
|
99
|
+
}
|
|
100
|
+
};
|
|
101
|
+
fetchEnviveConfig();
|
|
83
102
|
}, [
|
|
84
103
|
config,
|
|
85
104
|
userId,
|
|
86
105
|
namespace,
|
|
87
106
|
source,
|
|
88
|
-
inputEnviveConfigService
|
|
107
|
+
inputEnviveConfigService,
|
|
108
|
+
extensionService,
|
|
109
|
+
invokeExtensionCallback,
|
|
110
|
+
invokeExtensionErrorCallback
|
|
111
|
+
]);
|
|
112
|
+
useEffect(() => {
|
|
113
|
+
if (!enviveServiceConfig || didReportSuccessRef.current) return;
|
|
114
|
+
didReportSuccessRef.current = true;
|
|
115
|
+
invokeExtensionCallback(extensionService?.onInjectionSuccess);
|
|
116
|
+
}, [
|
|
117
|
+
enviveServiceConfig,
|
|
118
|
+
extensionService,
|
|
119
|
+
invokeExtensionCallback
|
|
89
120
|
]);
|
|
90
121
|
const enviveConfig = useMemo(() => ({
|
|
91
122
|
...config,
|
|
@@ -93,45 +124,43 @@ const EnviveProvider = ({ children, previewMode = false, overrideConfig, enabled
|
|
|
93
124
|
orgShortName: enviveServiceConfig?.org?.org?.short_name || "",
|
|
94
125
|
orgId: enviveServiceConfig?.org?.org?.id || ""
|
|
95
126
|
}), [config, enviveServiceConfig]);
|
|
96
|
-
|
|
97
|
-
|
|
127
|
+
logger.logDebug("enviveContext: enviveServiceConfig", enviveServiceConfig, config);
|
|
128
|
+
logger.logDebug("enviveContext: enviveConfig", enviveConfig);
|
|
98
129
|
const featureFlagService = useMemo(() => inputFeatureFlagService ?? new FeatureFlagService(enviveConfig.featureGates), [enviveConfig.featureGates, inputFeatureFlagService]);
|
|
99
130
|
if (enviveServiceConfig === null || enviveConfig === null) return null;
|
|
100
|
-
return /* @__PURE__ */ jsx(
|
|
101
|
-
|
|
102
|
-
children: /* @__PURE__ */ jsx(
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
children: /* @__PURE__ */ jsx(
|
|
108
|
-
|
|
109
|
-
children: /* @__PURE__ */ jsx(
|
|
110
|
-
|
|
111
|
-
children: /* @__PURE__ */ jsx(
|
|
112
|
-
|
|
113
|
-
children: /* @__PURE__ */ jsx(
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
131
|
+
return /* @__PURE__ */ jsx(EnviveConfigProvider, {
|
|
132
|
+
...enviveConfig,
|
|
133
|
+
children: /* @__PURE__ */ jsx(GraphQLProvider, {
|
|
134
|
+
mockV3ConfigToDeprecatedConfig,
|
|
135
|
+
requestV3Config,
|
|
136
|
+
children: /* @__PURE__ */ jsx(NewOrgConfigProvider, {
|
|
137
|
+
overrideConfig,
|
|
138
|
+
children: /* @__PURE__ */ jsx(LocalStorageProvider, { children: /* @__PURE__ */ jsx(FeatureFlagServiceProvider, {
|
|
139
|
+
featureFlagService,
|
|
140
|
+
children: /* @__PURE__ */ jsx(UserIdentityProvider, {
|
|
141
|
+
userIdService,
|
|
142
|
+
children: /* @__PURE__ */ jsx(AmplitudeProvider, {
|
|
143
|
+
externalAmplitudeService: inputAmplitudeService,
|
|
144
|
+
children: /* @__PURE__ */ jsx(PageProvider, {
|
|
145
|
+
previewMode,
|
|
146
|
+
onUrlResolverNotReady: extensionService?.onInjectionError,
|
|
147
|
+
children: /* @__PURE__ */ jsx(WidgetConfigProvider, { children: /* @__PURE__ */ jsx(HardcopyProvider, {
|
|
148
|
+
hardcopyOverride,
|
|
149
|
+
children: /* @__PURE__ */ jsx(EnviveCssProvider, { children: /* @__PURE__ */ jsxs(SearchAgentWrapper, {
|
|
150
|
+
enabledAgents,
|
|
151
|
+
children: [/* @__PURE__ */ jsx(WindowChatToggleBinder, {}), /* @__PURE__ */ jsx(SalesAgentWrapper, {
|
|
120
152
|
enabledAgents,
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
}) })
|
|
129
|
-
}) }) })
|
|
130
|
-
})
|
|
153
|
+
showDebugBar: config.enviveOn || false,
|
|
154
|
+
previewMode,
|
|
155
|
+
mockSalesAgentData,
|
|
156
|
+
children
|
|
157
|
+
})]
|
|
158
|
+
}) })
|
|
159
|
+
}) })
|
|
131
160
|
})
|
|
132
161
|
})
|
|
133
|
-
})
|
|
134
|
-
})
|
|
162
|
+
})
|
|
163
|
+
}) })
|
|
135
164
|
})
|
|
136
165
|
})
|
|
137
166
|
});
|
|
@@ -139,4 +168,4 @@ const EnviveProvider = ({ children, previewMode = false, overrideConfig, enabled
|
|
|
139
168
|
|
|
140
169
|
//#endregion
|
|
141
170
|
export { EnviveProvider };
|
|
142
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"enviveContext.js","names":["SearchAgentWrapper: React.FC<AgentWrapperProps>","SalesAgentWrapper: React.FC<SalesAgentWrapperProps>","EnviveProvider: React.FC<EnviveProviderProps>"],"sources":["../../../src/contexts/enviveContext/enviveContext.tsx"],"sourcesContent":["import { ReactNode, createContext, useEffect, useMemo, useState } from 'react';\n\nimport { OrgConfigFeatureGate } from 'src/application/models/api/orgConfigResults';\nimport { EnviveConfigService, EnviveServiceConfig } from 'src/services/enviveConfigService';\nimport { AmplitudeService } from 'src/services/amplitudeService/amplitudeService';\nimport Logger from 'src/application/logging/logger';\nimport { UserIdentityService } from 'src/services/userIdentityService';\nimport { AmplitudeProvider } from '../amplitudeContext';\nimport { EnviveConfigProvider } from '../enviveConfigContext';\nimport { EnviveCssProvider } from '../enviveCssContext';\nimport { FeatureFlagService, FeatureFlagServiceProvider } from '../featureFlagServiceContext';\nimport { GraphQLProvider, GraphQlConfigValues } from '../graphqlContext';\nimport { LocalStorageProvider } from '../localStorageContext';\nimport { NewOrgConfigProvider } from '../newOrgConfigContext';\nimport { UserIdentityProvider } from '../userIdentityContext';\nimport { EnviveAgent } from './types';\nimport { SearchProvider } from '../searchContext';\nimport { SalesAgentProvider } from '../salesAgentContext/salesAgentContext';\nimport { SystemSettingsContextProvider } from '../systemSettingsContext';\nimport { HardcopyProvider, HardcopyResponse } from '../hardcopyContext';\nimport { WidgetTypeV3 } from '../typesV3';\nimport { WidgetConfigProvider } from '../widgetConfigContext';\nimport { PageProvider } from '../pageContext';\nimport { UiConfigProvider } from '../uiConfigContext';\nimport { WindowChatToggleBinder } from './WindowChatToggleBinder';\n\nconst EnviveContext = createContext<null>(null);\n\ninterface AgentWrapperProps {\n  children: ReactNode;\n  enabledAgents: EnviveAgent[];\n}\n\ninterface EnviveProviderProps extends AgentWrapperProps {\n  amplitudeApiKey?: string;\n  dataResidency?: string;\n  env?: string;\n  baseUrl?: string;\n  reactAppName?: string;\n  cdnUrl?: string;\n  contextSource?: string;\n  orgLevelApiKey?: string;\n  orgShortName?: string;\n  identifyingPrefix: string;\n  featureOverrides?: Record<string, boolean>;\n  variantUrlOverride?: string;\n  variantInfoOverride?: any;\n  show?: boolean;\n  enviveOn?: boolean;\n  publicKey?: string;\n  featureGates?: OrgConfigFeatureGate[]; // New prop for feature gates\n  featureFlagService?: FeatureFlagService;\n  enviveConfigService?: EnviveConfigService;\n  amplitudeService?: AmplitudeService;\n  mockV3ConfigToDeprecatedConfig?: boolean;\n  requestV3Config?: boolean;\n  userIdentityService?: UserIdentityService;\n  previewMode?: boolean;\n  overrideConfig?: GraphQlConfigValues;\n  mockSalesAgentData?: any;\n  hardcopyOverride?: Partial<Record<WidgetTypeV3, HardcopyResponse>>;\n}\n\nconst SearchAgentWrapper: React.FC<AgentWrapperProps> = ({ children, enabledAgents }) => {\n  if (!enabledAgents.includes(EnviveAgent.SearchAgent)) {\n    return children;\n  }\n  return <SearchProvider>{children}</SearchProvider>;\n};\n\ninterface SalesAgentWrapperProps extends AgentWrapperProps {\n  previewMode?: boolean;\n  showDebugBar: boolean;\n  mockSalesAgentData?: any;\n}\n\nconst SalesAgentWrapper: React.FC<SalesAgentWrapperProps> = ({\n  children,\n  enabledAgents,\n  previewMode,\n  showDebugBar,\n  mockSalesAgentData,\n}) => {\n  if (!enabledAgents.includes(EnviveAgent.SalesAgent)) {\n    return children;\n  }\n  return (\n    <SystemSettingsContextProvider showDebugBar={showDebugBar}>\n      <SalesAgentProvider\n        previewMode={previewMode}\n        mockData={mockSalesAgentData}\n      >\n        {children}\n      </SalesAgentProvider>\n    </SystemSettingsContextProvider>\n  );\n};\n\nexport const EnviveProvider: React.FC<EnviveProviderProps> = ({\n  children,\n  previewMode = false,\n  overrideConfig,\n  enabledAgents,\n  enviveConfigService: inputEnviveConfigService,\n  featureFlagService: inputFeatureFlagService,\n  amplitudeService: inputAmplitudeService,\n  userIdentityService: inputUserIdentityService,\n  mockV3ConfigToDeprecatedConfig = false,\n  requestV3Config = false,\n  mockSalesAgentData,\n  hardcopyOverride,\n  ...config\n}) => {\n  const [userId, setUserId] = useState<string>('');\n\n  const userIdService = useMemo(\n    () =>\n      inputUserIdentityService ??\n      new UserIdentityService({ apiKey: config?.amplitudeApiKey || '' }),\n    [config?.amplitudeApiKey, inputUserIdentityService],\n  );\n\n  useEffect(() => {\n    const fetchUserId = async () => {\n      const id = await userIdService.getUserIdOrDefault();\n      setUserId(id);\n    };\n\n    fetchUserId();\n  }, [config.amplitudeApiKey, inputUserIdentityService, userIdService]);\n\n  const namespace = 'spiffy-react-components'; // TODO: Should this be different from the current namespace?\n  const source = 'app'; // TODO: Make this dependent upon the \"spiffy_on\" query param\n  const [enviveServiceConfig, setEnviveServiceConfig] = useState<EnviveServiceConfig | null>(null);\n\n  useEffect(() => {\n    // Really not happy with this approach, but I'm seeing 429 errors in the tests\n    // because of the rate limiting on the API.\n    const enviveConfigService =\n      inputEnviveConfigService ??\n      new EnviveConfigService({\n        baseUrl: config?.baseUrl || '',\n        apiKey: config?.orgLevelApiKey || '',\n        userId,\n        namespace: namespace || '',\n        source: source || '',\n      });\n    enviveConfigService.getEnviveConfig().then(newConfig => {\n      setEnviveServiceConfig(newConfig);\n      return newConfig;\n    });\n  }, [config, userId, namespace, source, inputEnviveConfigService]);\n\n  const enviveConfig = useMemo(\n    () => ({\n      ...config,\n      featureGates: enviveServiceConfig?.gates || [],\n      orgShortName: enviveServiceConfig?.org?.org?.short_name || '',\n      orgId: enviveServiceConfig?.org?.org?.id || '',\n    }),\n    [config, enviveServiceConfig],\n  );\n  Logger.logDebug('enviveContext: enviveServiceConfig', enviveServiceConfig, config);\n  Logger.logDebug('enviveContext: enviveConfig', enviveConfig);\n\n  const featureFlagService = useMemo(\n    () => inputFeatureFlagService ?? new FeatureFlagService(enviveConfig.featureGates),\n    [enviveConfig.featureGates, inputFeatureFlagService],\n  );\n\n  if (enviveServiceConfig === null || enviveConfig === null) {\n    return null;\n  }\n\n  return (\n    <EnviveContext.Provider value={null}>\n      <EnviveConfigProvider {...enviveConfig}>\n        <GraphQLProvider\n          mockV3ConfigToDeprecatedConfig={mockV3ConfigToDeprecatedConfig}\n          requestV3Config={requestV3Config}\n        >\n          <NewOrgConfigProvider overrideConfig={overrideConfig}>\n            <LocalStorageProvider>\n              <FeatureFlagServiceProvider featureFlagService={featureFlagService}>\n                <UserIdentityProvider userIdService={userIdService}>\n                  <AmplitudeProvider externalAmplitudeService={inputAmplitudeService}>\n                    <PageProvider previewMode={previewMode}>\n                      <UiConfigProvider>\n                        <WidgetConfigProvider>\n                          <HardcopyProvider hardcopyOverride={hardcopyOverride}>\n                            <EnviveCssProvider>\n                              <SearchAgentWrapper enabledAgents={enabledAgents}>\n                                <WindowChatToggleBinder />\n                                <SalesAgentWrapper\n                                  enabledAgents={enabledAgents}\n                                  showDebugBar={config.enviveOn || false}\n                                  previewMode={previewMode}\n                                  mockSalesAgentData={mockSalesAgentData}\n                                >\n                                  {children}\n                                </SalesAgentWrapper>\n                              </SearchAgentWrapper>\n                            </EnviveCssProvider>\n                          </HardcopyProvider>\n                        </WidgetConfigProvider>\n                      </UiConfigProvider>\n                    </PageProvider>\n                  </AmplitudeProvider>\n                </UserIdentityProvider>\n              </FeatureFlagServiceProvider>\n            </LocalStorageProvider>\n          </NewOrgConfigProvider>\n        </GraphQLProvider>\n      </EnviveConfigProvider>\n    </EnviveContext.Provider>\n  );\n};\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA0BA,MAAM,gBAAgB,cAAoB,KAAK;AAqC/C,MAAMA,sBAAmD,EAAE,UAAU,oBAAoB;AACvF,KAAI,CAAC,cAAc,SAAS,YAAY,YAAY,CAClD,QAAO;AAET,QAAO,oBAAC,kBAAgB,WAA0B;;AASpD,MAAMC,qBAAuD,EAC3D,UACA,eACA,aACA,cACA,yBACI;AACJ,KAAI,CAAC,cAAc,SAAS,YAAY,WAAW,CACjD,QAAO;AAET,QACE,oBAAC;EAA4C;YAC3C,oBAAC;GACc;GACb,UAAU;GAET;IACkB;GACS;;AAIpC,MAAaC,kBAAiD,EAC5D,UACA,cAAc,OACd,gBACA,eACA,qBAAqB,0BACrB,oBAAoB,yBACpB,kBAAkB,uBAClB,qBAAqB,0BACrB,iCAAiC,OACjC,kBAAkB,OAClB,oBACA,kBACA,GAAG,aACC;CACJ,MAAM,CAAC,QAAQ,aAAa,SAAiB,GAAG;CAEhD,MAAM,gBAAgB,cAElB,4BACA,IAAI,oBAAoB,EAAE,QAAQ,QAAQ,mBAAmB,IAAI,CAAC,EACpE,CAAC,QAAQ,iBAAiB,yBAAyB,CACpD;AAED,iBAAgB;EACd,MAAM,cAAc,YAAY;AAE9B,aADW,MAAM,cAAc,oBAAoB,CACtC;;AAGf,eAAa;IACZ;EAAC,OAAO;EAAiB;EAA0B;EAAc,CAAC;CAErE,MAAM,YAAY;CAClB,MAAM,SAAS;CACf,MAAM,CAAC,qBAAqB,0BAA0B,SAAqC,KAAK;AAEhG,iBAAgB;AAYd,GARE,4BACA,IAAI,oBAAoB;GACtB,SAAS,QAAQ,WAAW;GAC5B,QAAQ,QAAQ,kBAAkB;GAClC;GACW;GACH;GACT,CAAC,EACgB,iBAAiB,CAAC,MAAK,cAAa;AACtD,0BAAuB,UAAU;AACjC,UAAO;IACP;IACD;EAAC;EAAQ;EAAQ;EAAW;EAAQ;EAAyB,CAAC;CAEjE,MAAM,eAAe,eACZ;EACL,GAAG;EACH,cAAc,qBAAqB,SAAS,EAAE;EAC9C,cAAc,qBAAqB,KAAK,KAAK,cAAc;EAC3D,OAAO,qBAAqB,KAAK,KAAK,MAAM;EAC7C,GACD,CAAC,QAAQ,oBAAoB,CAC9B;AACD,gBAAO,SAAS,sCAAsC,qBAAqB,OAAO;AAClF,gBAAO,SAAS,+BAA+B,aAAa;CAE5D,MAAM,qBAAqB,cACnB,2BAA2B,IAAI,mBAAmB,aAAa,aAAa,EAClF,CAAC,aAAa,cAAc,wBAAwB,CACrD;AAED,KAAI,wBAAwB,QAAQ,iBAAiB,KACnD,QAAO;AAGT,QACE,oBAAC,cAAc;EAAS,OAAO;YAC7B,oBAAC;GAAqB,GAAI;aACxB,oBAAC;IACiC;IACf;cAEjB,oBAAC;KAAqC;eACpC,oBAAC,kCACC,oBAAC;MAA+C;gBAC9C,oBAAC;OAAoC;iBACnC,oBAAC;QAAkB,0BAA0B;kBAC3C,oBAAC;SAA0B;mBACzB,oBAAC,8BACC,oBAAC,kCACC,oBAAC;UAAmC;oBAClC,oBAAC,+BACC,qBAAC;WAAkC;sBACjC,oBAAC,2BAAyB,EAC1B,oBAAC;YACgB;YACf,cAAc,OAAO,YAAY;YACpB;YACO;YAEnB;aACiB;YACD,GACH;WACH,GACE,GACN;UACN;SACG;QACC;OACI,GACR;MACF;KACP;IACG;GACA"}
|
|
171
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"enviveContext.js","names":["Logger","SearchAgentWrapper: React.FC<AgentWrapperProps>","SalesAgentWrapper: React.FC<SalesAgentWrapperProps>","EnviveProvider: React.FC<EnviveProviderProps>"],"sources":["../../../src/contexts/enviveContext/enviveContext.tsx"],"sourcesContent":["import { ReactNode, useCallback, useEffect, useMemo, useRef, useState } from 'react';\n\nimport { OrgConfigFeatureGate } from 'src/application/models/api/orgConfigResults';\nimport { EnviveConfigService, EnviveServiceConfig } from 'src/services/enviveConfigService';\nimport { AmplitudeService } from 'src/services/amplitudeService/amplitudeService';\nimport Logger from 'src/application/logging/logger';\nimport { UserIdentityService } from 'src/services/userIdentityService';\nimport { AmplitudeProvider } from '../amplitudeContext';\nimport { EnviveConfigProvider } from '../enviveConfigContext';\nimport { EnviveCssProvider } from '../enviveCssContext';\nimport { FeatureFlagService, FeatureFlagServiceProvider } from '../featureFlagServiceContext';\nimport { GraphQLProvider, GraphQlConfigValues } from '../graphqlContext';\nimport { LocalStorageProvider } from '../localStorageContext';\nimport { NewOrgConfigProvider } from '../newOrgConfigContext';\nimport { UserIdentityProvider } from '../userIdentityContext';\nimport { EnviveAgent } from './types';\nimport { SearchProvider } from '../searchContext';\nimport { SalesAgentProvider } from '../salesAgentContext/salesAgentContext';\nimport { SystemSettingsContextProvider } from '../systemSettingsContext';\nimport { HardcopyProvider, HardcopyResponse } from '../hardcopyContext';\nimport { WidgetTypeV3 } from '../typesV3';\nimport { WidgetConfigProvider } from '../widgetConfigContext';\nimport { PageProvider } from '../pageContext';\nimport { WindowChatToggleBinder } from './WindowChatToggleBinder';\n\nconst logger = new Logger('enviveContext');\n\ninterface AgentWrapperProps {\n  children: ReactNode;\n  enabledAgents: EnviveAgent[];\n}\n\nexport interface ExtensionStatusCallbacks {\n  onInjectionLoading?: () => Promise<unknown> | void;\n  onInjectionSuccess?: () => Promise<unknown> | void;\n  onInjectionError?: (error: Error) => Promise<unknown> | void;\n}\n\ninterface EnviveProviderProps extends AgentWrapperProps {\n  amplitudeApiKey?: string;\n  dataResidency?: string;\n  env?: string;\n  baseUrl?: string;\n  reactAppName?: string;\n  cdnUrl?: string;\n  contextSource?: string;\n  orgLevelApiKey?: string;\n  orgShortName?: string;\n  identifyingPrefix: string;\n  featureOverrides?: Record<string, boolean>;\n  variantUrlOverride?: string;\n  variantInfoOverride?: any;\n  show?: boolean;\n  enviveOn?: boolean;\n  publicKey?: string;\n  featureGates?: OrgConfigFeatureGate[]; // New prop for feature gates\n  featureFlagService?: FeatureFlagService;\n  enviveConfigService?: EnviveConfigService;\n  amplitudeService?: AmplitudeService;\n  mockV3ConfigToDeprecatedConfig?: boolean;\n  requestV3Config?: boolean;\n  userIdentityService?: UserIdentityService;\n  previewMode?: boolean;\n  overrideConfig?: GraphQlConfigValues;\n  mockSalesAgentData?: any;\n  hardcopyOverride?: Partial<Record<WidgetTypeV3, HardcopyResponse>>;\n  extensionService?: ExtensionStatusCallbacks;\n}\n\nconst SearchAgentWrapper: React.FC<AgentWrapperProps> = ({ children, enabledAgents }) => {\n  if (!enabledAgents.includes(EnviveAgent.SearchAgent)) {\n    return children;\n  }\n  return <SearchProvider>{children}</SearchProvider>;\n};\n\ninterface SalesAgentWrapperProps extends AgentWrapperProps {\n  previewMode?: boolean;\n  showDebugBar: boolean;\n  mockSalesAgentData?: any;\n}\n\nconst SalesAgentWrapper: React.FC<SalesAgentWrapperProps> = ({\n  children,\n  enabledAgents,\n  previewMode,\n  showDebugBar,\n  mockSalesAgentData,\n}) => {\n  if (!enabledAgents.includes(EnviveAgent.SalesAgent)) {\n    return children;\n  }\n  return (\n    <SystemSettingsContextProvider showDebugBar={showDebugBar}>\n      <SalesAgentProvider\n        previewMode={previewMode}\n        mockData={mockSalesAgentData}\n      >\n        {children}\n      </SalesAgentProvider>\n    </SystemSettingsContextProvider>\n  );\n};\n\nexport const EnviveProvider: React.FC<EnviveProviderProps> = ({\n  children,\n  previewMode = false,\n  overrideConfig,\n  enabledAgents,\n  enviveConfigService: inputEnviveConfigService,\n  featureFlagService: inputFeatureFlagService,\n  amplitudeService: inputAmplitudeService,\n  userIdentityService: inputUserIdentityService,\n  mockV3ConfigToDeprecatedConfig = false,\n  requestV3Config = false,\n  mockSalesAgentData,\n  hardcopyOverride,\n  extensionService,\n  ...config\n}) => {\n  const [userId, setUserId] = useState<string>('');\n  const didReportSuccessRef = useRef(false);\n\n  const invokeExtensionCallback = useCallback((callback?: () => Promise<unknown> | void) => {\n    if (!callback) {\n      return;\n    }\n\n    Promise.resolve(callback()).catch(error => {\n      logger.logDebug('Extension status callback failed', error);\n    });\n  }, []);\n\n  const invokeExtensionErrorCallback = useCallback(\n    (error: Error) => {\n      if (!extensionService?.onInjectionError) {\n        return;\n      }\n\n      Promise.resolve(extensionService.onInjectionError(error)).catch(callbackError => {\n        logger.logDebug('Extension error callback failed', callbackError);\n      });\n    },\n    [extensionService],\n  );\n\n  const userIdService = useMemo(\n    () =>\n      inputUserIdentityService ??\n      new UserIdentityService({ apiKey: config?.amplitudeApiKey || '' }),\n    [config?.amplitudeApiKey, inputUserIdentityService],\n  );\n\n  useEffect(() => {\n    const fetchUserId = async () => {\n      const id = await userIdService.getUserIdOrDefault();\n      setUserId(id);\n    };\n\n    fetchUserId();\n  }, [config.amplitudeApiKey, inputUserIdentityService, userIdService]);\n\n  const namespace = 'spiffy-react-components'; // TODO: Should this be different from the current namespace?\n  const source = 'app'; // TODO: Make this dependent upon the \"spiffy_on\" query param\n  const [enviveServiceConfig, setEnviveServiceConfig] = useState<EnviveServiceConfig | null>(null);\n\n  useEffect(() => {\n    invokeExtensionCallback(extensionService?.onInjectionLoading);\n\n    // Really not happy with this approach, but I'm seeing 429 errors in the tests\n    // because of the rate limiting on the API.\n    const enviveConfigService =\n      inputEnviveConfigService ??\n      new EnviveConfigService({\n        baseUrl: config?.baseUrl || '',\n        apiKey: config?.orgLevelApiKey || '',\n        userId,\n        namespace: namespace || '',\n        source: source || '',\n      });\n    const fetchEnviveConfig = async () => {\n      try {\n        const newConfig = await enviveConfigService.getEnviveConfig();\n        setEnviveServiceConfig(newConfig);\n      } catch (error) {\n        const resolvedError =\n          error instanceof Error ? error : new Error('Failed to load envive config');\n        logger.logError('Failed to initialize EnviveProvider', resolvedError);\n        invokeExtensionErrorCallback(resolvedError);\n      }\n    };\n\n    fetchEnviveConfig();\n  }, [\n    config,\n    userId,\n    namespace,\n    source,\n    inputEnviveConfigService,\n    extensionService,\n    invokeExtensionCallback,\n    invokeExtensionErrorCallback,\n  ]);\n\n  useEffect(() => {\n    if (!enviveServiceConfig || didReportSuccessRef.current) {\n      return;\n    }\n\n    didReportSuccessRef.current = true;\n    invokeExtensionCallback(extensionService?.onInjectionSuccess);\n  }, [enviveServiceConfig, extensionService, invokeExtensionCallback]);\n\n  const enviveConfig = useMemo(\n    () => ({\n      ...config,\n      featureGates: enviveServiceConfig?.gates || [],\n      orgShortName: enviveServiceConfig?.org?.org?.short_name || '',\n      orgId: enviveServiceConfig?.org?.org?.id || '',\n    }),\n    [config, enviveServiceConfig],\n  );\n  logger.logDebug('enviveContext: enviveServiceConfig', enviveServiceConfig, config);\n  logger.logDebug('enviveContext: enviveConfig', enviveConfig);\n\n  const featureFlagService = useMemo(\n    () => inputFeatureFlagService ?? new FeatureFlagService(enviveConfig.featureGates),\n    [enviveConfig.featureGates, inputFeatureFlagService],\n  );\n\n  if (enviveServiceConfig === null || enviveConfig === null) {\n    return null;\n  }\n\n  return (\n    <EnviveConfigProvider {...enviveConfig}>\n      <GraphQLProvider\n        mockV3ConfigToDeprecatedConfig={mockV3ConfigToDeprecatedConfig}\n        requestV3Config={requestV3Config}\n      >\n        <NewOrgConfigProvider overrideConfig={overrideConfig}>\n          <LocalStorageProvider>\n            <FeatureFlagServiceProvider featureFlagService={featureFlagService}>\n              <UserIdentityProvider userIdService={userIdService}>\n                <AmplitudeProvider externalAmplitudeService={inputAmplitudeService}>\n                  <PageProvider\n                    previewMode={previewMode}\n                    onUrlResolverNotReady={extensionService?.onInjectionError}\n                  >\n                    <WidgetConfigProvider>\n                      <HardcopyProvider hardcopyOverride={hardcopyOverride}>\n                        <EnviveCssProvider>\n                          <SearchAgentWrapper enabledAgents={enabledAgents}>\n                            <WindowChatToggleBinder />\n                            <SalesAgentWrapper\n                              enabledAgents={enabledAgents}\n                              showDebugBar={config.enviveOn || false}\n                              previewMode={previewMode}\n                              mockSalesAgentData={mockSalesAgentData}\n                            >\n                              {children}\n                            </SalesAgentWrapper>\n                          </SearchAgentWrapper>\n                        </EnviveCssProvider>\n                      </HardcopyProvider>\n                    </WidgetConfigProvider>\n                  </PageProvider>\n                </AmplitudeProvider>\n              </UserIdentityProvider>\n            </FeatureFlagServiceProvider>\n          </LocalStorageProvider>\n        </NewOrgConfigProvider>\n      </GraphQLProvider>\n    </EnviveConfigProvider>\n  );\n};\n"],"mappings":"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"}
|
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
import { EnviveAgent } from "./types.cjs";
|
|
2
|
-
import { EnviveProvider } from "./enviveContext.cjs";
|
|
3
|
-
export { EnviveAgent, EnviveProvider };
|
|
2
|
+
import { EnviveProvider, ExtensionStatusCallbacks } from "./enviveContext.cjs";
|
|
3
|
+
export { EnviveAgent, EnviveProvider, ExtensionStatusCallbacks };
|
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
import { EnviveAgent } from "./types.js";
|
|
2
|
-
import { EnviveProvider } from "./enviveContext.js";
|
|
3
|
-
export { EnviveAgent, EnviveProvider };
|
|
2
|
+
import { EnviveProvider, ExtensionStatusCallbacks } from "./enviveContext.js";
|
|
3
|
+
export { EnviveAgent, EnviveProvider, ExtensionStatusCallbacks };
|