@envive-ai/react-hooks 0.3.17 → 0.3.19
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/nextMessageRequestToApiRequest.cjs +3 -1
- package/dist/application/utils/nextMessageRequestToApiRequest.js +3 -1
- package/dist/application/utils/widgetTextRequestToApiRequest.cjs +2 -2
- package/dist/application/utils/widgetTextRequestToApiRequest.js +2 -2
- package/dist/atoms/app/index.d.cts +7 -7
- package/dist/atoms/app/variant.cjs +3 -2
- 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.cts +2 -2
- package/dist/atoms/chat/form.d.ts +2 -2
- package/dist/atoms/chat/index.d.cts +2 -2
- package/dist/atoms/chat/index.d.ts +2 -2
- package/dist/atoms/chat/lastMessage.d.cts +2 -2
- package/dist/atoms/chat/lastMessage.d.ts +2 -2
- package/dist/atoms/chat/messageQueue.d.cts +6 -6
- package/dist/atoms/chat/messageQueue.d.ts +6 -6
- 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 +2 -2
- 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/widget/chatPreviewLoading.d.cts +2 -2
- package/dist/atoms/widget/chatPreviewLoading.d.ts +2 -2
- package/dist/contexts/amplitudeContext/amplitudeContext.cjs +4 -3
- package/dist/contexts/amplitudeContext/amplitudeContext.js +3 -2
- 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 +34 -39
- package/dist/contexts/enviveContext/enviveContext.js +35 -40
- 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 +3 -2
- package/dist/contexts/pageContext/pageContext.js +3 -2
- 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/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/SystemSettingsContext/useSystemSettingsContext.d.cts +2 -2
- 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.js +2 -1
- package/dist/hooks/utils.d.ts +1 -1
- package/dist/services/amplitudeService/amplitudeService.cjs +8 -7
- package/dist/services/amplitudeService/amplitudeService.js +8 -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/application/utils/widgetTextRequestToApiRequest.ts +1 -2
- 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/amplitudeContext.tsx +1 -1
- 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 +40 -45
- 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 +3 -1
- 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 +3 -3
- package/src/services/amplitudeService/amplitudeService.ts +8 -6
- package/src/services/ga4ProjectionService/ga4ProjectionService.ts +3 -1
- package/src/services/userIdentityService/userIdentityService.ts +8 -8
|
@@ -2,10 +2,10 @@ 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
9
|
import { EnviveConfigService } from "../../services/enviveConfigService/enviveConfigService.js";
|
|
10
10
|
import { UserIdentityService } from "../../services/userIdentityService/userIdentityService.js";
|
|
11
11
|
import "../../services/userIdentityService/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 { useEffect, useMemo, 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 });
|
|
@@ -93,45 +91,42 @@ const EnviveProvider = ({ children, previewMode = false, overrideConfig, enabled
|
|
|
93
91
|
orgShortName: enviveServiceConfig?.org?.org?.short_name || "",
|
|
94
92
|
orgId: enviveServiceConfig?.org?.org?.id || ""
|
|
95
93
|
}), [config, enviveServiceConfig]);
|
|
96
|
-
|
|
97
|
-
|
|
94
|
+
logger.logDebug("enviveContext: enviveServiceConfig", enviveServiceConfig, config);
|
|
95
|
+
logger.logDebug("enviveContext: enviveConfig", enviveConfig);
|
|
98
96
|
const featureFlagService = useMemo(() => inputFeatureFlagService ?? new FeatureFlagService(enviveConfig.featureGates), [enviveConfig.featureGates, inputFeatureFlagService]);
|
|
99
97
|
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
|
-
children: /* @__PURE__ */ jsx(
|
|
116
|
-
|
|
117
|
-
children: /* @__PURE__ */ jsx(
|
|
118
|
-
|
|
119
|
-
children: /* @__PURE__ */ jsx(
|
|
98
|
+
return /* @__PURE__ */ jsx(EnviveConfigProvider, {
|
|
99
|
+
...enviveConfig,
|
|
100
|
+
children: /* @__PURE__ */ jsx(GraphQLProvider, {
|
|
101
|
+
mockV3ConfigToDeprecatedConfig,
|
|
102
|
+
requestV3Config,
|
|
103
|
+
children: /* @__PURE__ */ jsx(NewOrgConfigProvider, {
|
|
104
|
+
overrideConfig,
|
|
105
|
+
children: /* @__PURE__ */ jsx(LocalStorageProvider, { children: /* @__PURE__ */ jsx(FeatureFlagServiceProvider, {
|
|
106
|
+
featureFlagService,
|
|
107
|
+
children: /* @__PURE__ */ jsx(UserIdentityProvider, {
|
|
108
|
+
userIdService,
|
|
109
|
+
children: /* @__PURE__ */ jsx(AmplitudeProvider, {
|
|
110
|
+
externalAmplitudeService: inputAmplitudeService,
|
|
111
|
+
children: /* @__PURE__ */ jsx(PageProvider, {
|
|
112
|
+
previewMode,
|
|
113
|
+
children: /* @__PURE__ */ jsx(WidgetConfigProvider, { children: /* @__PURE__ */ jsx(HardcopyProvider, {
|
|
114
|
+
hardcopyOverride,
|
|
115
|
+
children: /* @__PURE__ */ jsx(EnviveCssProvider, { children: /* @__PURE__ */ jsxs(SearchAgentWrapper, {
|
|
116
|
+
enabledAgents,
|
|
117
|
+
children: [/* @__PURE__ */ jsx(WindowChatToggleBinder, {}), /* @__PURE__ */ jsx(SalesAgentWrapper, {
|
|
120
118
|
enabledAgents,
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
}) })
|
|
129
|
-
}) }) })
|
|
130
|
-
})
|
|
119
|
+
showDebugBar: config.enviveOn || false,
|
|
120
|
+
previewMode,
|
|
121
|
+
mockSalesAgentData,
|
|
122
|
+
children
|
|
123
|
+
})]
|
|
124
|
+
}) })
|
|
125
|
+
}) })
|
|
131
126
|
})
|
|
132
127
|
})
|
|
133
|
-
})
|
|
134
|
-
})
|
|
128
|
+
})
|
|
129
|
+
}) })
|
|
135
130
|
})
|
|
136
131
|
})
|
|
137
132
|
});
|
|
@@ -139,4 +134,4 @@ const EnviveProvider = ({ children, previewMode = false, overrideConfig, enabled
|
|
|
139
134
|
|
|
140
135
|
//#endregion
|
|
141
136
|
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"}
|
|
137
|
+
//# 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, 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 { WindowChatToggleBinder } from './WindowChatToggleBinder';\n\nconst logger = new Logger('enviveContext');\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    <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                    <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":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAyBA,MAAM,SAAS,IAAIA,eAAO,gBAAgB;AAqC1C,MAAMC,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,QAAO,SAAS,sCAAsC,qBAAqB,OAAO;AAClF,QAAO,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;EAAqB,GAAI;YACxB,oBAAC;GACiC;GACf;aAEjB,oBAAC;IAAqC;cACpC,oBAAC,kCACC,oBAAC;KAA+C;eAC9C,oBAAC;MAAoC;gBACnC,oBAAC;OAAkB,0BAA0B;iBAC3C,oBAAC;QAA0B;kBACzB,oBAAC,kCACC,oBAAC;SAAmC;mBAClC,oBAAC,+BACC,qBAAC;UAAkC;qBACjC,oBAAC,2BAAyB,EAC1B,oBAAC;WACgB;WACf,cAAc,OAAO,YAAY;WACpB;WACO;WAEnB;YACiB;WACD,GACH;UACH,GACE;SACV;QACG;OACC;MACI,GACR;KACF;IACP;GACG"}
|
|
@@ -7,6 +7,7 @@ let react_jsx_runtime = require("react/jsx-runtime");
|
|
|
7
7
|
|
|
8
8
|
//#region src/contexts/featureFlagServiceContext/featureFlagServiceContext.tsx
|
|
9
9
|
const FEATURE_FLAGS_STORAGE_KEY = "spiffy-feature-flags";
|
|
10
|
+
const logger = new require_logger.default("featureFlagServiceContext");
|
|
10
11
|
var FeatureFlagService = class FeatureFlagService {
|
|
11
12
|
constructor(featureGates) {
|
|
12
13
|
this.isFeatureGateEnabled = (featureGate) => {
|
|
@@ -14,7 +15,7 @@ var FeatureFlagService = class FeatureFlagService {
|
|
|
14
15
|
const featureFlagOverride = FeatureFlagService.getFeatureFlagOverride(featureGate);
|
|
15
16
|
if (featureFlagOverride !== void 0) return featureFlagOverride;
|
|
16
17
|
if (gateValue == null || gateValue.value == null) {
|
|
17
|
-
|
|
18
|
+
logger.logDebug(`isFeatureGateEnabled featureGate:${featureGate} value is undefined - returning false`);
|
|
18
19
|
return false;
|
|
19
20
|
}
|
|
20
21
|
return gateValue.value;
|
|
@@ -68,24 +69,24 @@ var FeatureFlagService = class FeatureFlagService {
|
|
|
68
69
|
if (!featureFlags) return;
|
|
69
70
|
return JSON.parse(featureFlags)[featureGate];
|
|
70
71
|
} catch (err) {
|
|
71
|
-
|
|
72
|
+
logger.logError("getStoredFeatureGateOverrides: error parsing feature flags", err);
|
|
72
73
|
return;
|
|
73
74
|
}
|
|
74
75
|
}
|
|
75
76
|
static getFeatureFlagOverride(featureGate) {
|
|
76
77
|
const queryOverride = FeatureFlagService.getQueryParamFeatureGateOverrides(featureGate);
|
|
77
78
|
if (queryOverride != null) {
|
|
78
|
-
|
|
79
|
+
logger.logDebug(`isFeatureGateEnabled featureGate:${featureGate} overridden by URL param. New value: ${queryOverride}`);
|
|
79
80
|
return queryOverride;
|
|
80
81
|
}
|
|
81
82
|
const windowOverride = FeatureFlagService.getWindowFeatureGateOverrides(featureGate);
|
|
82
83
|
if (windowOverride != null) {
|
|
83
|
-
|
|
84
|
+
logger.logDebug(`isFeatureGateEnabled featureGate:${featureGate} overridden by window param. New value: ${windowOverride}`);
|
|
84
85
|
return windowOverride;
|
|
85
86
|
}
|
|
86
87
|
const storedOverride = FeatureFlagService.getStoredFeatureGateOverrides(featureGate);
|
|
87
88
|
if (storedOverride != null) {
|
|
88
|
-
|
|
89
|
+
logger.logDebug(`isFeatureGateEnabled featureGate:${featureGate} overridden by stored value. New value: ${storedOverride}`);
|
|
89
90
|
return storedOverride;
|
|
90
91
|
}
|
|
91
92
|
}
|
|
@@ -116,4 +117,4 @@ const useFeatureFlagService = () => {
|
|
|
116
117
|
exports.FeatureFlagService = FeatureFlagService;
|
|
117
118
|
exports.FeatureFlagServiceProvider = FeatureFlagServiceProvider;
|
|
118
119
|
exports.useFeatureFlagService = useFeatureFlagService;
|
|
119
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"featureFlagServiceContext.cjs","names":["FeatureGates","featureGates","FeatureFlagServiceProvider: React.FC<FeatureFlagServiceProviderProps>"],"sources":["../../../src/contexts/featureFlagServiceContext/featureFlagServiceContext.tsx"],"sourcesContent":["import React, { ReactNode, createContext, useContext, useMemo } from 'react';\nimport { OrgConfigFeatureGate } from 'src/application/models/api/orgConfigResults';\nimport { FeatureGates } from 'src/application/models/featureGates';\nimport Logger from 'src/application/logging/logger';\n\nconst FEATURE_FLAGS_STORAGE_KEY = 'spiffy-feature-flags';\n\nexport interface FullFlagValue {\n  resolved: boolean;\n  initial: boolean | undefined;\n  query_param_override: boolean | undefined;\n  window_param_override: boolean | undefined;\n  stored_override: boolean | undefined;\n}\n\n// This is the class that was previously implicitly used or defined elsewhere\nexport class FeatureFlagService {\n  private featureGates: OrgConfigFeatureGate[];\n\n  constructor(featureGates: OrgConfigFeatureGate[]) {\n    this.featureGates = featureGates;\n  }\n\n  static getQueryParamFeatureGateOverrides(featureGate: FeatureGates): boolean | undefined {\n    const url = window.location?.href ?? '';\n    if (url.includes('?')) {\n      const urlObj = new URL(url);\n      const params = new URLSearchParams(urlObj.search);\n      const paramsObj = Object.fromEntries(params.entries());\n      const value = paramsObj[featureGate];\n\n      if (value != null) {\n        return value === 'true';\n      }\n    }\n\n    return undefined;\n  }\n\n  static getWindowFeatureGateOverrides(featureGate: FeatureGates): boolean | undefined {\n    if (typeof window === 'undefined') {\n      return undefined;\n    }\n    const windowOverride = window as Window & {\n      _envive?: { featureOverrides?: Record<string, boolean> };\n      _spiffy?: { featureOverrides?: Record<string, boolean> };\n    };\n    const featureOverrides =\n      windowOverride?._envive?.featureOverrides ?? windowOverride?._spiffy?.featureOverrides;\n    const value = featureOverrides?.[String(featureGate)];\n    if (value != null) {\n      return value;\n    }\n    return undefined;\n  }\n\n  static getStoredFeatureGateOverrides(featureGate: FeatureGates): boolean | undefined {\n    if (typeof window === 'undefined' || typeof window.localStorage === 'undefined') {\n      return undefined;\n    }\n    try {\n      const featureFlags = window.localStorage.getItem(FEATURE_FLAGS_STORAGE_KEY);\n      if (!featureFlags) {\n        return undefined;\n      }\n      const featureFlagsObj = JSON.parse(featureFlags) as Record<string, boolean>;\n      return featureFlagsObj[featureGate];\n    } catch (err) {\n      Logger.logError(\n        '[spiffy-ai] getStoredFeatureGateOverrides: error parsing feature flags',\n        err,\n      );\n      return undefined;\n    }\n  }\n\n  static getFeatureFlagOverride(featureGate: FeatureGates): boolean | undefined {\n    const queryOverride = FeatureFlagService.getQueryParamFeatureGateOverrides(featureGate);\n    if (queryOverride != null) {\n      Logger.logDebug(\n        `[spiffy-ai] isFeatureGateEnabled featureGate:${featureGate} overridden by URL param. New value: ${queryOverride}`,\n      );\n      return queryOverride;\n    }\n\n    const windowOverride = FeatureFlagService.getWindowFeatureGateOverrides(featureGate);\n    if (windowOverride != null) {\n      Logger.logDebug(\n        `[spiffy-ai] isFeatureGateEnabled featureGate:${featureGate} overridden by window param. New value: ${windowOverride}`,\n      );\n      return windowOverride;\n    }\n\n    const storedOverride = FeatureFlagService.getStoredFeatureGateOverrides(featureGate);\n    if (storedOverride != null) {\n      Logger.logDebug(\n        `[spiffy-ai] isFeatureGateEnabled featureGate:${featureGate} overridden by stored value. New value: ${storedOverride}`,\n      );\n      return storedOverride;\n    }\n\n    return undefined;\n  }\n\n  isFeatureGateEnabled = (featureGate: FeatureGates): boolean => {\n    const gateValue = this.featureGates.find(gate => gate.name === featureGate);\n\n    const featureFlagOverride = FeatureFlagService.getFeatureFlagOverride(featureGate);\n    if (featureFlagOverride !== undefined) {\n      return featureFlagOverride;\n    }\n\n    if (gateValue == null || gateValue.value == null) {\n      Logger.logDebug(\n        `[spiffy-ai] isFeatureGateEnabled featureGate:${featureGate} value is undefined - returning false`,\n      );\n      return false;\n    }\n    return gateValue.value;\n  };\n\n  // Ensure that standard overrides work as expected\n  isClientSessionEnabled = (): boolean =>\n    this.isFeatureGateEnabled(FeatureGates.IsClientSessionEnabled);\n\n  getFeatureFlags = (): Record<string, boolean> => {\n    return Object.fromEntries(\n      Object.values(FeatureGates).map((featureGate: FeatureGates) => [\n        featureGate,\n        this.isFeatureGateEnabled(featureGate),\n      ]),\n    );\n  };\n\n  getFullFlagValue = (featureGate: FeatureGates): FullFlagValue => {\n    const gateValue = this.featureGates.find(gate => gate.name === featureGate);\n    return {\n      resolved: this.isFeatureGateEnabled(featureGate),\n      initial: gateValue?.value,\n      query_param_override: FeatureFlagService.getQueryParamFeatureGateOverrides(featureGate),\n      window_param_override: FeatureFlagService.getWindowFeatureGateOverrides(featureGate),\n      stored_override: FeatureFlagService.getStoredFeatureGateOverrides(featureGate),\n    };\n  };\n\n  getFullFlagValues = (): Record<string, FullFlagValue> => {\n    const featureGates = Object.values(FeatureGates).map((featureGate: FeatureGates) => [\n      featureGate,\n      this.getFullFlagValue(featureGate),\n    ]);\n\n    return featureGates.length > 0\n      ? featureGates.reduce<Record<string, FullFlagValue>>((acc, entry) => {\n          const [name, value] = entry as [FeatureGates, FullFlagValue];\n          if (name && value != null) {\n            return { ...acc, [`feature_gate.${name}`]: value };\n          }\n          return acc;\n        }, {})\n      : {};\n  };\n\n  static persistFeatureGateOverrides(): void {\n    if (typeof window === 'undefined' || typeof window.localStorage === 'undefined') {\n      return;\n    }\n    const overrides = Object.values(FeatureGates)\n      .map(\n        featureGate =>\n          [featureGate, FeatureFlagService.getFeatureFlagOverride(featureGate)] as const,\n      )\n      .filter(([, value]) => value !== undefined)\n      .reduce<Record<string, boolean>>((acc, [key, value]) => ({ ...acc, [key]: value! }), {});\n    window.localStorage.setItem(FEATURE_FLAGS_STORAGE_KEY, JSON.stringify(overrides));\n  }\n}\n\nexport interface FeatureFlagContextType {\n  featureFlagService: FeatureFlagService | undefined;\n}\n\nconst FeatureFlagServiceContext = createContext<FeatureFlagContextType | undefined>(undefined);\n\ninterface FeatureFlagServiceProviderProps {\n  featureFlagService: FeatureFlagService;\n  children: ReactNode;\n}\n\nexport const FeatureFlagServiceProvider: React.FC<FeatureFlagServiceProviderProps> = ({\n  featureFlagService: inputService,\n  children,\n}) => {\n  const contextValue = useMemo(\n    () => ({\n      featureFlagService: inputService,\n    }),\n    [inputService],\n  );\n\n  return (\n    <FeatureFlagServiceContext.Provider value={contextValue}>\n      {children}\n    </FeatureFlagServiceContext.Provider>\n  );\n};\n\nexport const useFeatureFlagService = () => {\n  const context = useContext(FeatureFlagServiceContext);\n  if (context === undefined) {\n    throw new Error('useFeatureFlagService must be used within a FeatureFlagServiceProvider');\n  }\n  return context;\n};\n"],"mappings":"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"}
|
|
120
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"featureFlagServiceContext.cjs","names":["Logger","FeatureGates","featureGates","FeatureFlagServiceProvider: React.FC<FeatureFlagServiceProviderProps>"],"sources":["../../../src/contexts/featureFlagServiceContext/featureFlagServiceContext.tsx"],"sourcesContent":["import React, { ReactNode, createContext, useContext, useMemo } from 'react';\nimport { OrgConfigFeatureGate } from 'src/application/models/api/orgConfigResults';\nimport { FeatureGates } from 'src/application/models/featureGates';\nimport Logger from 'src/application/logging/logger';\n\nconst FEATURE_FLAGS_STORAGE_KEY = 'spiffy-feature-flags';\n\nconst logger = new Logger('featureFlagServiceContext');\n\nexport interface FullFlagValue {\n  resolved: boolean;\n  initial: boolean | undefined;\n  query_param_override: boolean | undefined;\n  window_param_override: boolean | undefined;\n  stored_override: boolean | undefined;\n}\n\n// This is the class that was previously implicitly used or defined elsewhere\nexport class FeatureFlagService {\n  private featureGates: OrgConfigFeatureGate[];\n\n  constructor(featureGates: OrgConfigFeatureGate[]) {\n    this.featureGates = featureGates;\n  }\n\n  static getQueryParamFeatureGateOverrides(featureGate: FeatureGates): boolean | undefined {\n    const url = window.location?.href ?? '';\n    if (url.includes('?')) {\n      const urlObj = new URL(url);\n      const params = new URLSearchParams(urlObj.search);\n      const paramsObj = Object.fromEntries(params.entries());\n      const value = paramsObj[featureGate];\n\n      if (value != null) {\n        return value === 'true';\n      }\n    }\n\n    return undefined;\n  }\n\n  static getWindowFeatureGateOverrides(featureGate: FeatureGates): boolean | undefined {\n    if (typeof window === 'undefined') {\n      return undefined;\n    }\n    const windowOverride = window as Window & {\n      _envive?: { featureOverrides?: Record<string, boolean> };\n      _spiffy?: { featureOverrides?: Record<string, boolean> };\n    };\n    const featureOverrides =\n      windowOverride?._envive?.featureOverrides ?? windowOverride?._spiffy?.featureOverrides;\n    const value = featureOverrides?.[String(featureGate)];\n    if (value != null) {\n      return value;\n    }\n    return undefined;\n  }\n\n  static getStoredFeatureGateOverrides(featureGate: FeatureGates): boolean | undefined {\n    if (typeof window === 'undefined' || typeof window.localStorage === 'undefined') {\n      return undefined;\n    }\n    try {\n      const featureFlags = window.localStorage.getItem(FEATURE_FLAGS_STORAGE_KEY);\n      if (!featureFlags) {\n        return undefined;\n      }\n      const featureFlagsObj = JSON.parse(featureFlags) as Record<string, boolean>;\n      return featureFlagsObj[featureGate];\n    } catch (err) {\n      logger.logError('getStoredFeatureGateOverrides: error parsing feature flags', err);\n      return undefined;\n    }\n  }\n\n  static getFeatureFlagOverride(featureGate: FeatureGates): boolean | undefined {\n    const queryOverride = FeatureFlagService.getQueryParamFeatureGateOverrides(featureGate);\n    if (queryOverride != null) {\n      logger.logDebug(\n        `isFeatureGateEnabled featureGate:${featureGate} overridden by URL param. New value: ${queryOverride}`,\n      );\n      return queryOverride;\n    }\n\n    const windowOverride = FeatureFlagService.getWindowFeatureGateOverrides(featureGate);\n    if (windowOverride != null) {\n      logger.logDebug(\n        `isFeatureGateEnabled featureGate:${featureGate} overridden by window param. New value: ${windowOverride}`,\n      );\n      return windowOverride;\n    }\n\n    const storedOverride = FeatureFlagService.getStoredFeatureGateOverrides(featureGate);\n    if (storedOverride != null) {\n      logger.logDebug(\n        `isFeatureGateEnabled featureGate:${featureGate} overridden by stored value. New value: ${storedOverride}`,\n      );\n      return storedOverride;\n    }\n\n    return undefined;\n  }\n\n  isFeatureGateEnabled = (featureGate: FeatureGates): boolean => {\n    const gateValue = this.featureGates.find(gate => gate.name === featureGate);\n\n    const featureFlagOverride = FeatureFlagService.getFeatureFlagOverride(featureGate);\n    if (featureFlagOverride !== undefined) {\n      return featureFlagOverride;\n    }\n\n    if (gateValue == null || gateValue.value == null) {\n      logger.logDebug(\n        `isFeatureGateEnabled featureGate:${featureGate} value is undefined - returning false`,\n      );\n      return false;\n    }\n    return gateValue.value;\n  };\n\n  // Ensure that standard overrides work as expected\n  isClientSessionEnabled = (): boolean =>\n    this.isFeatureGateEnabled(FeatureGates.IsClientSessionEnabled);\n\n  getFeatureFlags = (): Record<string, boolean> => {\n    return Object.fromEntries(\n      Object.values(FeatureGates).map((featureGate: FeatureGates) => [\n        featureGate,\n        this.isFeatureGateEnabled(featureGate),\n      ]),\n    );\n  };\n\n  getFullFlagValue = (featureGate: FeatureGates): FullFlagValue => {\n    const gateValue = this.featureGates.find(gate => gate.name === featureGate);\n    return {\n      resolved: this.isFeatureGateEnabled(featureGate),\n      initial: gateValue?.value,\n      query_param_override: FeatureFlagService.getQueryParamFeatureGateOverrides(featureGate),\n      window_param_override: FeatureFlagService.getWindowFeatureGateOverrides(featureGate),\n      stored_override: FeatureFlagService.getStoredFeatureGateOverrides(featureGate),\n    };\n  };\n\n  getFullFlagValues = (): Record<string, FullFlagValue> => {\n    const featureGates = Object.values(FeatureGates).map((featureGate: FeatureGates) => [\n      featureGate,\n      this.getFullFlagValue(featureGate),\n    ]);\n\n    return featureGates.length > 0\n      ? featureGates.reduce<Record<string, FullFlagValue>>((acc, entry) => {\n          const [name, value] = entry as [FeatureGates, FullFlagValue];\n          if (name && value != null) {\n            return { ...acc, [`feature_gate.${name}`]: value };\n          }\n          return acc;\n        }, {})\n      : {};\n  };\n\n  static persistFeatureGateOverrides(): void {\n    if (typeof window === 'undefined' || typeof window.localStorage === 'undefined') {\n      return;\n    }\n    const overrides = Object.values(FeatureGates)\n      .map(\n        featureGate =>\n          [featureGate, FeatureFlagService.getFeatureFlagOverride(featureGate)] as const,\n      )\n      .filter(([, value]) => value !== undefined)\n      .reduce<Record<string, boolean>>((acc, [key, value]) => ({ ...acc, [key]: value! }), {});\n    window.localStorage.setItem(FEATURE_FLAGS_STORAGE_KEY, JSON.stringify(overrides));\n  }\n}\n\nexport interface FeatureFlagContextType {\n  featureFlagService: FeatureFlagService | undefined;\n}\n\nconst FeatureFlagServiceContext = createContext<FeatureFlagContextType | undefined>(undefined);\n\ninterface FeatureFlagServiceProviderProps {\n  featureFlagService: FeatureFlagService;\n  children: ReactNode;\n}\n\nexport const FeatureFlagServiceProvider: React.FC<FeatureFlagServiceProviderProps> = ({\n  featureFlagService: inputService,\n  children,\n}) => {\n  const contextValue = useMemo(\n    () => ({\n      featureFlagService: inputService,\n    }),\n    [inputService],\n  );\n\n  return (\n    <FeatureFlagServiceContext.Provider value={contextValue}>\n      {children}\n    </FeatureFlagServiceContext.Provider>\n  );\n};\n\nexport const useFeatureFlagService = () => {\n  const context = useContext(FeatureFlagServiceContext);\n  if (context === undefined) {\n    throw new Error('useFeatureFlagService must be used within a FeatureFlagServiceProvider');\n  }\n  return context;\n};\n"],"mappings":"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"}
|
|
@@ -5,6 +5,7 @@ import { jsx } from "react/jsx-runtime";
|
|
|
5
5
|
|
|
6
6
|
//#region src/contexts/featureFlagServiceContext/featureFlagServiceContext.tsx
|
|
7
7
|
const FEATURE_FLAGS_STORAGE_KEY = "spiffy-feature-flags";
|
|
8
|
+
const logger = new logger_default("featureFlagServiceContext");
|
|
8
9
|
var FeatureFlagService = class FeatureFlagService {
|
|
9
10
|
constructor(featureGates) {
|
|
10
11
|
this.isFeatureGateEnabled = (featureGate) => {
|
|
@@ -12,7 +13,7 @@ var FeatureFlagService = class FeatureFlagService {
|
|
|
12
13
|
const featureFlagOverride = FeatureFlagService.getFeatureFlagOverride(featureGate);
|
|
13
14
|
if (featureFlagOverride !== void 0) return featureFlagOverride;
|
|
14
15
|
if (gateValue == null || gateValue.value == null) {
|
|
15
|
-
|
|
16
|
+
logger.logDebug(`isFeatureGateEnabled featureGate:${featureGate} value is undefined - returning false`);
|
|
16
17
|
return false;
|
|
17
18
|
}
|
|
18
19
|
return gateValue.value;
|
|
@@ -66,24 +67,24 @@ var FeatureFlagService = class FeatureFlagService {
|
|
|
66
67
|
if (!featureFlags) return;
|
|
67
68
|
return JSON.parse(featureFlags)[featureGate];
|
|
68
69
|
} catch (err) {
|
|
69
|
-
|
|
70
|
+
logger.logError("getStoredFeatureGateOverrides: error parsing feature flags", err);
|
|
70
71
|
return;
|
|
71
72
|
}
|
|
72
73
|
}
|
|
73
74
|
static getFeatureFlagOverride(featureGate) {
|
|
74
75
|
const queryOverride = FeatureFlagService.getQueryParamFeatureGateOverrides(featureGate);
|
|
75
76
|
if (queryOverride != null) {
|
|
76
|
-
|
|
77
|
+
logger.logDebug(`isFeatureGateEnabled featureGate:${featureGate} overridden by URL param. New value: ${queryOverride}`);
|
|
77
78
|
return queryOverride;
|
|
78
79
|
}
|
|
79
80
|
const windowOverride = FeatureFlagService.getWindowFeatureGateOverrides(featureGate);
|
|
80
81
|
if (windowOverride != null) {
|
|
81
|
-
|
|
82
|
+
logger.logDebug(`isFeatureGateEnabled featureGate:${featureGate} overridden by window param. New value: ${windowOverride}`);
|
|
82
83
|
return windowOverride;
|
|
83
84
|
}
|
|
84
85
|
const storedOverride = FeatureFlagService.getStoredFeatureGateOverrides(featureGate);
|
|
85
86
|
if (storedOverride != null) {
|
|
86
|
-
|
|
87
|
+
logger.logDebug(`isFeatureGateEnabled featureGate:${featureGate} overridden by stored value. New value: ${storedOverride}`);
|
|
87
88
|
return storedOverride;
|
|
88
89
|
}
|
|
89
90
|
}
|
|
@@ -112,4 +113,4 @@ const useFeatureFlagService = () => {
|
|
|
112
113
|
|
|
113
114
|
//#endregion
|
|
114
115
|
export { FeatureFlagService, FeatureFlagServiceProvider, useFeatureFlagService };
|
|
115
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"featureFlagServiceContext.js","names":["featureGates","FeatureFlagServiceProvider: React.FC<FeatureFlagServiceProviderProps>"],"sources":["../../../src/contexts/featureFlagServiceContext/featureFlagServiceContext.tsx"],"sourcesContent":["import React, { ReactNode, createContext, useContext, useMemo } from 'react';\nimport { OrgConfigFeatureGate } from 'src/application/models/api/orgConfigResults';\nimport { FeatureGates } from 'src/application/models/featureGates';\nimport Logger from 'src/application/logging/logger';\n\nconst FEATURE_FLAGS_STORAGE_KEY = 'spiffy-feature-flags';\n\nexport interface FullFlagValue {\n  resolved: boolean;\n  initial: boolean | undefined;\n  query_param_override: boolean | undefined;\n  window_param_override: boolean | undefined;\n  stored_override: boolean | undefined;\n}\n\n// This is the class that was previously implicitly used or defined elsewhere\nexport class FeatureFlagService {\n  private featureGates: OrgConfigFeatureGate[];\n\n  constructor(featureGates: OrgConfigFeatureGate[]) {\n    this.featureGates = featureGates;\n  }\n\n  static getQueryParamFeatureGateOverrides(featureGate: FeatureGates): boolean | undefined {\n    const url = window.location?.href ?? '';\n    if (url.includes('?')) {\n      const urlObj = new URL(url);\n      const params = new URLSearchParams(urlObj.search);\n      const paramsObj = Object.fromEntries(params.entries());\n      const value = paramsObj[featureGate];\n\n      if (value != null) {\n        return value === 'true';\n      }\n    }\n\n    return undefined;\n  }\n\n  static getWindowFeatureGateOverrides(featureGate: FeatureGates): boolean | undefined {\n    if (typeof window === 'undefined') {\n      return undefined;\n    }\n    const windowOverride = window as Window & {\n      _envive?: { featureOverrides?: Record<string, boolean> };\n      _spiffy?: { featureOverrides?: Record<string, boolean> };\n    };\n    const featureOverrides =\n      windowOverride?._envive?.featureOverrides ?? windowOverride?._spiffy?.featureOverrides;\n    const value = featureOverrides?.[String(featureGate)];\n    if (value != null) {\n      return value;\n    }\n    return undefined;\n  }\n\n  static getStoredFeatureGateOverrides(featureGate: FeatureGates): boolean | undefined {\n    if (typeof window === 'undefined' || typeof window.localStorage === 'undefined') {\n      return undefined;\n    }\n    try {\n      const featureFlags = window.localStorage.getItem(FEATURE_FLAGS_STORAGE_KEY);\n      if (!featureFlags) {\n        return undefined;\n      }\n      const featureFlagsObj = JSON.parse(featureFlags) as Record<string, boolean>;\n      return featureFlagsObj[featureGate];\n    } catch (err) {\n      Logger.logError(\n        '[spiffy-ai] getStoredFeatureGateOverrides: error parsing feature flags',\n        err,\n      );\n      return undefined;\n    }\n  }\n\n  static getFeatureFlagOverride(featureGate: FeatureGates): boolean | undefined {\n    const queryOverride = FeatureFlagService.getQueryParamFeatureGateOverrides(featureGate);\n    if (queryOverride != null) {\n      Logger.logDebug(\n        `[spiffy-ai] isFeatureGateEnabled featureGate:${featureGate} overridden by URL param. New value: ${queryOverride}`,\n      );\n      return queryOverride;\n    }\n\n    const windowOverride = FeatureFlagService.getWindowFeatureGateOverrides(featureGate);\n    if (windowOverride != null) {\n      Logger.logDebug(\n        `[spiffy-ai] isFeatureGateEnabled featureGate:${featureGate} overridden by window param. New value: ${windowOverride}`,\n      );\n      return windowOverride;\n    }\n\n    const storedOverride = FeatureFlagService.getStoredFeatureGateOverrides(featureGate);\n    if (storedOverride != null) {\n      Logger.logDebug(\n        `[spiffy-ai] isFeatureGateEnabled featureGate:${featureGate} overridden by stored value. New value: ${storedOverride}`,\n      );\n      return storedOverride;\n    }\n\n    return undefined;\n  }\n\n  isFeatureGateEnabled = (featureGate: FeatureGates): boolean => {\n    const gateValue = this.featureGates.find(gate => gate.name === featureGate);\n\n    const featureFlagOverride = FeatureFlagService.getFeatureFlagOverride(featureGate);\n    if (featureFlagOverride !== undefined) {\n      return featureFlagOverride;\n    }\n\n    if (gateValue == null || gateValue.value == null) {\n      Logger.logDebug(\n        `[spiffy-ai] isFeatureGateEnabled featureGate:${featureGate} value is undefined - returning false`,\n      );\n      return false;\n    }\n    return gateValue.value;\n  };\n\n  // Ensure that standard overrides work as expected\n  isClientSessionEnabled = (): boolean =>\n    this.isFeatureGateEnabled(FeatureGates.IsClientSessionEnabled);\n\n  getFeatureFlags = (): Record<string, boolean> => {\n    return Object.fromEntries(\n      Object.values(FeatureGates).map((featureGate: FeatureGates) => [\n        featureGate,\n        this.isFeatureGateEnabled(featureGate),\n      ]),\n    );\n  };\n\n  getFullFlagValue = (featureGate: FeatureGates): FullFlagValue => {\n    const gateValue = this.featureGates.find(gate => gate.name === featureGate);\n    return {\n      resolved: this.isFeatureGateEnabled(featureGate),\n      initial: gateValue?.value,\n      query_param_override: FeatureFlagService.getQueryParamFeatureGateOverrides(featureGate),\n      window_param_override: FeatureFlagService.getWindowFeatureGateOverrides(featureGate),\n      stored_override: FeatureFlagService.getStoredFeatureGateOverrides(featureGate),\n    };\n  };\n\n  getFullFlagValues = (): Record<string, FullFlagValue> => {\n    const featureGates = Object.values(FeatureGates).map((featureGate: FeatureGates) => [\n      featureGate,\n      this.getFullFlagValue(featureGate),\n    ]);\n\n    return featureGates.length > 0\n      ? featureGates.reduce<Record<string, FullFlagValue>>((acc, entry) => {\n          const [name, value] = entry as [FeatureGates, FullFlagValue];\n          if (name && value != null) {\n            return { ...acc, [`feature_gate.${name}`]: value };\n          }\n          return acc;\n        }, {})\n      : {};\n  };\n\n  static persistFeatureGateOverrides(): void {\n    if (typeof window === 'undefined' || typeof window.localStorage === 'undefined') {\n      return;\n    }\n    const overrides = Object.values(FeatureGates)\n      .map(\n        featureGate =>\n          [featureGate, FeatureFlagService.getFeatureFlagOverride(featureGate)] as const,\n      )\n      .filter(([, value]) => value !== undefined)\n      .reduce<Record<string, boolean>>((acc, [key, value]) => ({ ...acc, [key]: value! }), {});\n    window.localStorage.setItem(FEATURE_FLAGS_STORAGE_KEY, JSON.stringify(overrides));\n  }\n}\n\nexport interface FeatureFlagContextType {\n  featureFlagService: FeatureFlagService | undefined;\n}\n\nconst FeatureFlagServiceContext = createContext<FeatureFlagContextType | undefined>(undefined);\n\ninterface FeatureFlagServiceProviderProps {\n  featureFlagService: FeatureFlagService;\n  children: ReactNode;\n}\n\nexport const FeatureFlagServiceProvider: React.FC<FeatureFlagServiceProviderProps> = ({\n  featureFlagService: inputService,\n  children,\n}) => {\n  const contextValue = useMemo(\n    () => ({\n      featureFlagService: inputService,\n    }),\n    [inputService],\n  );\n\n  return (\n    <FeatureFlagServiceContext.Provider value={contextValue}>\n      {children}\n    </FeatureFlagServiceContext.Provider>\n  );\n};\n\nexport const useFeatureFlagService = () => {\n  const context = useContext(FeatureFlagServiceContext);\n  if (context === undefined) {\n    throw new Error('useFeatureFlagService must be used within a FeatureFlagServiceProvider');\n  }\n  return context;\n};\n"],"mappings":"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"}
|
|
116
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"featureFlagServiceContext.js","names":["Logger","featureGates","FeatureFlagServiceProvider: React.FC<FeatureFlagServiceProviderProps>"],"sources":["../../../src/contexts/featureFlagServiceContext/featureFlagServiceContext.tsx"],"sourcesContent":["import React, { ReactNode, createContext, useContext, useMemo } from 'react';\nimport { OrgConfigFeatureGate } from 'src/application/models/api/orgConfigResults';\nimport { FeatureGates } from 'src/application/models/featureGates';\nimport Logger from 'src/application/logging/logger';\n\nconst FEATURE_FLAGS_STORAGE_KEY = 'spiffy-feature-flags';\n\nconst logger = new Logger('featureFlagServiceContext');\n\nexport interface FullFlagValue {\n  resolved: boolean;\n  initial: boolean | undefined;\n  query_param_override: boolean | undefined;\n  window_param_override: boolean | undefined;\n  stored_override: boolean | undefined;\n}\n\n// This is the class that was previously implicitly used or defined elsewhere\nexport class FeatureFlagService {\n  private featureGates: OrgConfigFeatureGate[];\n\n  constructor(featureGates: OrgConfigFeatureGate[]) {\n    this.featureGates = featureGates;\n  }\n\n  static getQueryParamFeatureGateOverrides(featureGate: FeatureGates): boolean | undefined {\n    const url = window.location?.href ?? '';\n    if (url.includes('?')) {\n      const urlObj = new URL(url);\n      const params = new URLSearchParams(urlObj.search);\n      const paramsObj = Object.fromEntries(params.entries());\n      const value = paramsObj[featureGate];\n\n      if (value != null) {\n        return value === 'true';\n      }\n    }\n\n    return undefined;\n  }\n\n  static getWindowFeatureGateOverrides(featureGate: FeatureGates): boolean | undefined {\n    if (typeof window === 'undefined') {\n      return undefined;\n    }\n    const windowOverride = window as Window & {\n      _envive?: { featureOverrides?: Record<string, boolean> };\n      _spiffy?: { featureOverrides?: Record<string, boolean> };\n    };\n    const featureOverrides =\n      windowOverride?._envive?.featureOverrides ?? windowOverride?._spiffy?.featureOverrides;\n    const value = featureOverrides?.[String(featureGate)];\n    if (value != null) {\n      return value;\n    }\n    return undefined;\n  }\n\n  static getStoredFeatureGateOverrides(featureGate: FeatureGates): boolean | undefined {\n    if (typeof window === 'undefined' || typeof window.localStorage === 'undefined') {\n      return undefined;\n    }\n    try {\n      const featureFlags = window.localStorage.getItem(FEATURE_FLAGS_STORAGE_KEY);\n      if (!featureFlags) {\n        return undefined;\n      }\n      const featureFlagsObj = JSON.parse(featureFlags) as Record<string, boolean>;\n      return featureFlagsObj[featureGate];\n    } catch (err) {\n      logger.logError('getStoredFeatureGateOverrides: error parsing feature flags', err);\n      return undefined;\n    }\n  }\n\n  static getFeatureFlagOverride(featureGate: FeatureGates): boolean | undefined {\n    const queryOverride = FeatureFlagService.getQueryParamFeatureGateOverrides(featureGate);\n    if (queryOverride != null) {\n      logger.logDebug(\n        `isFeatureGateEnabled featureGate:${featureGate} overridden by URL param. New value: ${queryOverride}`,\n      );\n      return queryOverride;\n    }\n\n    const windowOverride = FeatureFlagService.getWindowFeatureGateOverrides(featureGate);\n    if (windowOverride != null) {\n      logger.logDebug(\n        `isFeatureGateEnabled featureGate:${featureGate} overridden by window param. New value: ${windowOverride}`,\n      );\n      return windowOverride;\n    }\n\n    const storedOverride = FeatureFlagService.getStoredFeatureGateOverrides(featureGate);\n    if (storedOverride != null) {\n      logger.logDebug(\n        `isFeatureGateEnabled featureGate:${featureGate} overridden by stored value. New value: ${storedOverride}`,\n      );\n      return storedOverride;\n    }\n\n    return undefined;\n  }\n\n  isFeatureGateEnabled = (featureGate: FeatureGates): boolean => {\n    const gateValue = this.featureGates.find(gate => gate.name === featureGate);\n\n    const featureFlagOverride = FeatureFlagService.getFeatureFlagOverride(featureGate);\n    if (featureFlagOverride !== undefined) {\n      return featureFlagOverride;\n    }\n\n    if (gateValue == null || gateValue.value == null) {\n      logger.logDebug(\n        `isFeatureGateEnabled featureGate:${featureGate} value is undefined - returning false`,\n      );\n      return false;\n    }\n    return gateValue.value;\n  };\n\n  // Ensure that standard overrides work as expected\n  isClientSessionEnabled = (): boolean =>\n    this.isFeatureGateEnabled(FeatureGates.IsClientSessionEnabled);\n\n  getFeatureFlags = (): Record<string, boolean> => {\n    return Object.fromEntries(\n      Object.values(FeatureGates).map((featureGate: FeatureGates) => [\n        featureGate,\n        this.isFeatureGateEnabled(featureGate),\n      ]),\n    );\n  };\n\n  getFullFlagValue = (featureGate: FeatureGates): FullFlagValue => {\n    const gateValue = this.featureGates.find(gate => gate.name === featureGate);\n    return {\n      resolved: this.isFeatureGateEnabled(featureGate),\n      initial: gateValue?.value,\n      query_param_override: FeatureFlagService.getQueryParamFeatureGateOverrides(featureGate),\n      window_param_override: FeatureFlagService.getWindowFeatureGateOverrides(featureGate),\n      stored_override: FeatureFlagService.getStoredFeatureGateOverrides(featureGate),\n    };\n  };\n\n  getFullFlagValues = (): Record<string, FullFlagValue> => {\n    const featureGates = Object.values(FeatureGates).map((featureGate: FeatureGates) => [\n      featureGate,\n      this.getFullFlagValue(featureGate),\n    ]);\n\n    return featureGates.length > 0\n      ? featureGates.reduce<Record<string, FullFlagValue>>((acc, entry) => {\n          const [name, value] = entry as [FeatureGates, FullFlagValue];\n          if (name && value != null) {\n            return { ...acc, [`feature_gate.${name}`]: value };\n          }\n          return acc;\n        }, {})\n      : {};\n  };\n\n  static persistFeatureGateOverrides(): void {\n    if (typeof window === 'undefined' || typeof window.localStorage === 'undefined') {\n      return;\n    }\n    const overrides = Object.values(FeatureGates)\n      .map(\n        featureGate =>\n          [featureGate, FeatureFlagService.getFeatureFlagOverride(featureGate)] as const,\n      )\n      .filter(([, value]) => value !== undefined)\n      .reduce<Record<string, boolean>>((acc, [key, value]) => ({ ...acc, [key]: value! }), {});\n    window.localStorage.setItem(FEATURE_FLAGS_STORAGE_KEY, JSON.stringify(overrides));\n  }\n}\n\nexport interface FeatureFlagContextType {\n  featureFlagService: FeatureFlagService | undefined;\n}\n\nconst FeatureFlagServiceContext = createContext<FeatureFlagContextType | undefined>(undefined);\n\ninterface FeatureFlagServiceProviderProps {\n  featureFlagService: FeatureFlagService;\n  children: ReactNode;\n}\n\nexport const FeatureFlagServiceProvider: React.FC<FeatureFlagServiceProviderProps> = ({\n  featureFlagService: inputService,\n  children,\n}) => {\n  const contextValue = useMemo(\n    () => ({\n      featureFlagService: inputService,\n    }),\n    [inputService],\n  );\n\n  return (\n    <FeatureFlagServiceContext.Provider value={contextValue}>\n      {children}\n    </FeatureFlagServiceContext.Provider>\n  );\n};\n\nexport const useFeatureFlagService = () => {\n  const context = useContext(FeatureFlagServiceContext);\n  if (context === undefined) {\n    throw new Error('useFeatureFlagService must be used within a FeatureFlagServiceProvider');\n  }\n  return context;\n};\n"],"mappings":"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"}
|
|
@@ -17,6 +17,7 @@ let __envive_ai_react_toolkit_v3_FloatingButton = require("@envive-ai/react-tool
|
|
|
17
17
|
|
|
18
18
|
//#region src/contexts/graphqlContext/graphqlContext.tsx
|
|
19
19
|
const GraphQLContext = (0, react.createContext)(null);
|
|
20
|
+
const logger = new require_logger.default("graphqlContext");
|
|
20
21
|
const DEFAULT_PAGE_VARIANTS = [{
|
|
21
22
|
variantId: "plp",
|
|
22
23
|
variantType: "plp",
|
|
@@ -146,7 +147,7 @@ const GraphQLProvider = ({ children, requestV3Config = false, mockV3ConfigToDepr
|
|
|
146
147
|
const isSemanticColors = !window.location.href.includes("globals=merchant");
|
|
147
148
|
const isStorybook = window.top?.location.href.includes("?path=");
|
|
148
149
|
if (!v3RootConfig && mockV3ConfigToDeprecatedConfig || isStorybook && isSemanticColors) {
|
|
149
|
-
|
|
150
|
+
logger.logDebug("GraphQLContext | Returning mock v3 config", {
|
|
150
151
|
colorsConfig: require_mockV3Config.mockV3ColorsConfig,
|
|
151
152
|
frontendConfig: require_mockV3Config.mockV3FrontendConfig
|
|
152
153
|
});
|
|
@@ -160,7 +161,7 @@ const GraphQLProvider = ({ children, requestV3Config = false, mockV3ConfigToDepr
|
|
|
160
161
|
}
|
|
161
162
|
};
|
|
162
163
|
}
|
|
163
|
-
|
|
164
|
+
logger.logDebug("GraphQLContext | Returning v3 config", {
|
|
164
165
|
colorsConfig: v3ColorsConfig,
|
|
165
166
|
frontendConfig: v3FrontendConfig,
|
|
166
167
|
orgPageConfig: {
|
|
@@ -183,7 +184,7 @@ const GraphQLProvider = ({ children, requestV3Config = false, mockV3ConfigToDepr
|
|
|
183
184
|
}
|
|
184
185
|
};
|
|
185
186
|
} catch (err) {
|
|
186
|
-
|
|
187
|
+
logger.logError("Error fetching graphql colors and frontend config", err);
|
|
187
188
|
return {
|
|
188
189
|
colorsConfig: void 0,
|
|
189
190
|
frontendConfig: void 0
|
|
@@ -210,7 +211,7 @@ const GraphQLProvider = ({ children, requestV3Config = false, mockV3ConfigToDepr
|
|
|
210
211
|
frontendConfig: require_mockV3Config.mockV3FrontendConfig
|
|
211
212
|
};
|
|
212
213
|
} catch (err) {
|
|
213
|
-
|
|
214
|
+
logger.logError("Error fetching graphql colors and frontend config", err);
|
|
214
215
|
return {
|
|
215
216
|
colorsConfig: void 0,
|
|
216
217
|
frontendConfig: void 0
|
|
@@ -219,10 +220,10 @@ const GraphQLProvider = ({ children, requestV3Config = false, mockV3ConfigToDepr
|
|
|
219
220
|
}, [executeQuery]);
|
|
220
221
|
const getConfig = (0, react.useCallback)(async () => {
|
|
221
222
|
if (requestV3Config) {
|
|
222
|
-
|
|
223
|
+
logger.logDebug("GraphQLContext | Getting v3 config", requestV3Config);
|
|
223
224
|
return getV3Config();
|
|
224
225
|
}
|
|
225
|
-
|
|
226
|
+
logger.logDebug("GraphQLContext | Getting colors and frontend config", requestV3Config);
|
|
226
227
|
return getColorsAndFrontendConfig();
|
|
227
228
|
}, [
|
|
228
229
|
getColorsAndFrontendConfig,
|
|
@@ -258,4 +259,4 @@ const useGraphQLClient = () => {
|
|
|
258
259
|
//#endregion
|
|
259
260
|
exports.GraphQLProvider = GraphQLProvider;
|
|
260
261
|
exports.useGraphQLClient = useGraphQLClient;
|
|
261
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"graphqlContext.cjs","names":["DEFAULT_PAGE_VARIANTS: PageVariantConfig[]","PageVariantTestType","FloatingButtonLocation","orgLevelApiKeyAtom","baseUrlAtom","validateGraphQLOrgId","getMerchantOrgIdQuery","getColorsAndFrontendQuery","transformSnakeToCamel","validateAndTransformMountingConfig","v3pageVariants: PageVariantConfig[]","validateAndTransformPageVariants","mockV3ColorsConfig","mockV3FrontendConfig","ConfigVersionEnum"],"sources":["../../../src/contexts/graphqlContext/graphqlContext.tsx"],"sourcesContent":["import { ReactNode, createContext, useCallback, useContext, useMemo } from 'react';\nimport { useAtomValue } from 'jotai';\nimport { baseUrlAtom, orgLevelApiKeyAtom } from 'src/atoms/envive/enviveConfig';\nimport { getMerchantOrgIdQuery } from 'src/application/models/graphql/queries/getMerchantOrgIdQuery';\nimport { validateGraphQLOrgId } from 'src/application/models/validators/validateGraphQLOrgId';\nimport { ColorMapping } from 'src/application/models/colorsConfig';\nimport { FrontendConfig } from 'src/application/models/frontendConfig';\nimport Logger from 'src/application/logging/logger';\nimport {\n  CamelCasedPropertiesDeep,\n  transformSnakeToCamel,\n  validateAndTransformMountingConfig,\n  validateAndTransformPageVariants,\n} from 'src/application/models';\nimport { getColorsAndFrontendQuery } from 'src/application/models/graphql/queries/getColorsAndFrontendQuery';\nimport { FrontendConfigV3 } from 'src/application/models/frontendConfigV3';\nimport { ColorMappingV3 } from 'src/application/models/colorsConfigV3';\nimport { FloatingButtonLocation } from '@envive-ai/react-toolkit-v3/FloatingButton';\nimport { mockV3ColorsConfig, mockV3FrontendConfig } from './mockV3Config';\nimport { ConfigVersionEnum, WidgetConfigV3 } from '../typesV3';\nimport {\n  OrgPageConfig,\n  PageVariantConfig,\n  PageVariantTestType,\n  WidgetMountingConfig,\n} from '../types';\n\nexport type ColorsConfigResponse = CamelCasedPropertiesDeep<ColorMapping>;\nexport type FrontendConfigResponse = CamelCasedPropertiesDeep<FrontendConfig>;\nexport type ColorsConfigV3Response = CamelCasedPropertiesDeep<ColorMappingV3>;\nexport type FrontendConfigV3Response = CamelCasedPropertiesDeep<FrontendConfigV3>;\n\nexport type GraphQlConfigValues = {\n  colorsConfig?: ColorsConfigResponse | ColorsConfigV3Response;\n  frontendConfig?: CamelCasedPropertiesDeep<FrontendConfig | FrontendConfigV3>;\n  orgPageConfig?: OrgPageConfig;\n};\n\ninterface GraphQLContextValue {\n  executeQuery: <T>(query: string, variables?: Record<string, unknown>) => Promise<T>;\n  getOrgId: () => Promise<string | undefined>;\n  getColorsAndFrontendConfig: () => Promise<GraphQlConfigValues>;\n  getV3Config: () => Promise<GraphQlConfigValues>;\n  getConfig: () => Promise<GraphQlConfigValues>;\n  isReady: boolean;\n}\n\nconst GraphQLContext = createContext<GraphQLContextValue | null>(null);\n\ntype GraphQLProviderProps = {\n  children: ReactNode;\n  requestV3Config?: boolean;\n  mockV3ConfigToDeprecatedConfig?: boolean;\n};\n\nconst DEFAULT_PAGE_VARIANTS: PageVariantConfig[] = [\n  {\n    variantId: 'plp',\n    variantType: 'plp',\n    plpIdExtractor: 'url-resolver-plp-id',\n    widgetMounting: [],\n    variantTests: [\n      {\n        testType: PageVariantTestType.UrlResolver,\n      },\n    ],\n  },\n  {\n    variantId: 'pdp',\n    variantType: 'pdp',\n    productIdExtractor: 'url-resolver-product-id',\n    widgetMounting: [],\n    variantTests: [\n      {\n        testType: PageVariantTestType.UrlResolver,\n      },\n    ],\n  },\n];\n\nconst mapPositionToCamelCase = (position: string): FloatingButtonLocation => {\n  if (position === 'bottom-left') {\n    return FloatingButtonLocation.BOTTOM_LEFT;\n  }\n  if (position === 'middle-left') {\n    return FloatingButtonLocation.MIDDLE_LEFT;\n  }\n  if (position === 'middle-right') {\n    return FloatingButtonLocation.MIDDLE_RIGHT;\n  }\n  if (position === 'bottom-right') {\n    return FloatingButtonLocation.BOTTOM_RIGHT;\n  }\n  throw new Error(`Invalid position: ${position}`);\n};\n\n/**\n * This function is used to do some additional cleanup of the v3 frontend config to ensure that the config is in the correct format.\n */\nconst v3FrontendConfigCleanup = (\n  v3RootConfig: FrontendConfigV3Response,\n): FrontendConfigV3Response => {\n  const { uiConfigs } = v3RootConfig;\n  if (!uiConfigs) {\n    return v3RootConfig;\n  }\n  const { floatingButton, lookAndFeel } = uiConfigs as any;\n  if (!floatingButton || !lookAndFeel) {\n    return v3RootConfig;\n  }\n  const { fontSize, lineHeight } = lookAndFeel.typography as any;\n  return {\n    ...v3RootConfig,\n    uiConfigs: {\n      ...uiConfigs,\n      floatingButton: {\n        ...floatingButton,\n        position: mapPositionToCamelCase(\n          v3RootConfig.uiConfigs?.floatingButton?.position as string,\n        ),\n      },\n      lookAndFeel: {\n        ...lookAndFeel,\n        chatHeaderLogoDarkSrc: lookAndFeel.chatHeaderLogoDarkSrc || lookAndFeel.chatHeaderLogoSrc,\n        chatHeaderLogoLightSrc: lookAndFeel.chatHeaderLogoLightSrc || lookAndFeel.chatHeaderLogoSrc,\n        typography: {\n          ...lookAndFeel.typography,\n          fontSize: {\n            // The fonts sizes are defined differently in the backend config\n            // so we need to map the values to the correct camel case keys\n            b1: fontSize?.b1 || fontSize?.b_1,\n            b2: fontSize?.b2 || fontSize?.b_2,\n            b3: fontSize?.b3 || fontSize?.b_3,\n            b4: fontSize?.b4 || fontSize?.b_4,\n            b5: fontSize?.b5 || fontSize?.b_5,\n            h1: fontSize?.h1 || fontSize?.h_1,\n            h2: fontSize?.h2 || fontSize?.h_2,\n            h3: fontSize?.h3 || fontSize?.h_3,\n            l1: fontSize?.l1 || fontSize?.l_1,\n            l2: fontSize?.l2 || fontSize?.l_2,\n            t1: fontSize?.t1 || fontSize?.t_1,\n            t2: fontSize?.t2 || fontSize?.t_2,\n            t3: fontSize?.t3 || fontSize?.t_3,\n          },\n          lineHeight: {\n            ...lookAndFeel.typography.lineHeight,\n            '114': lineHeight?.lh_114 || lineHeight?.[114],\n            '116': lineHeight?.lh_116 || lineHeight?.[116],\n            '118': lineHeight?.lh_118 || lineHeight?.[118],\n            '120': lineHeight?.lh_120 || lineHeight?.[120],\n            '124': lineHeight?.lh_124 || lineHeight?.[124],\n            '128': lineHeight?.lh_128 || lineHeight?.[128],\n            '130': lineHeight?.lh_130 || lineHeight?.[130],\n            '133': lineHeight?.lh_133 || lineHeight?.[133],\n            '140': lineHeight?.lh_140 || lineHeight?.[140],\n            '148': lineHeight?.lh_148 || lineHeight?.[148],\n          },\n        },\n      },\n    },\n  };\n};\n\nexport const GraphQLProvider = ({\n  children,\n  requestV3Config = false,\n  mockV3ConfigToDeprecatedConfig = false,\n}: GraphQLProviderProps) => {\n  const apiKey = useAtomValue(orgLevelApiKeyAtom);\n  const baseUrl = useAtomValue(baseUrlAtom);\n  const isReady = useMemo(() => Boolean(apiKey && baseUrl), [apiKey, baseUrl]);\n\n  const executeQuery = useCallback(\n    async (query: string, variables?: Record<string, unknown>) => {\n      if (!isReady) {\n        throw new Error('GraphQL client not ready - missing apiKey or baseUrl');\n      }\n\n      const response = await fetch(`${baseUrl}/v1/graphql`, {\n        method: 'POST',\n        headers: {\n          'Content-Type': 'application/json',\n          Authorization: `Bearer ${apiKey}`,\n        },\n        body: JSON.stringify({ query, variables }),\n      });\n\n      if (!response.ok) {\n        throw new Error(`GraphQL request failed: ${response.statusText}`);\n      }\n\n      const result = await response.json();\n      if (result.errors) {\n        throw new Error(`GraphQL errors: ${JSON.stringify(result.errors)}`);\n      }\n\n      return result.data;\n    },\n    [apiKey, baseUrl, isReady],\n  );\n\n  const getOrgId = useCallback(async () => {\n    const response = await executeQuery(getMerchantOrgIdQuery);\n    return validateGraphQLOrgId(response.me.org?.id);\n  }, [executeQuery]);\n\n  const getV3Config = useCallback(async (): Promise<GraphQlConfigValues> => {\n    try {\n      const query = await getColorsAndFrontendQuery();\n      if (!query) {\n        throw new Error('Colors and frontend config query is not defined');\n      }\n      const response = await executeQuery(query);\n\n      // We may update this root config location in the future\n      const v3RootConfig = response.me.getProductsConfigByVersion?.v_three_config?.values;\n      const frontendValues = response.me.getProductsConfigByVersion?.frontend?.values;\n\n      const v3FrontendConfig = v3FrontendConfigCleanup(\n        transformSnakeToCamel(v3RootConfig) as FrontendConfigV3Response,\n      );\n\n      // Get merchant_override_css from frontend.values if v3RootConfig is not available\n      const frontendMerchantOverrideCss = frontendValues?.merchant_override_css;\n      const v3MerchantOverrideCss = v3FrontendConfig.uiConfigs?.merchantOverrideCss;\n      const merchantOverrideCss = v3MerchantOverrideCss || frontendMerchantOverrideCss;\n\n      const v3MountingConfigsArray = (transformSnakeToCamel(v3RootConfig?.mounting_configs) ??\n        []) as unknown as { key: string; config: WidgetMountingConfig }[];\n\n      const v3MountingConfigs = v3MountingConfigsArray.reduce(\n        (acc, { key, config }) => {\n          acc[key] = validateAndTransformMountingConfig(config, key);\n          return acc;\n        },\n        {} as Record<string, WidgetMountingConfig>,\n      );\n\n      const v3widgetConfigsArray = (transformSnakeToCamel(v3RootConfig?.widget_configs) ??\n        []) as unknown as WidgetConfigV3[];\n      const v3WidgetConfigs = Object.fromEntries(\n        v3widgetConfigsArray?.map(({ widgetConfigId, ...rest }: WidgetConfigV3) => [\n          widgetConfigId,\n          { widgetConfigId, ...rest } as WidgetConfigV3,\n        ]),\n      ) as Record<string, WidgetConfigV3>;\n      const v3pageVariants: PageVariantConfig[] = Array.isArray(v3RootConfig?.page_variants)\n        ? v3RootConfig?.page_variants.map(validateAndTransformPageVariants)\n        : DEFAULT_PAGE_VARIANTS;\n\n      const v3ColorsConfig = transformSnakeToCamel(v3RootConfig?.colors?.values);\n      const isSemanticColors = !window.location.href.includes('globals=merchant');\n      const isStorybook = window.top?.location.href.includes('?path=');\n\n      // If the v3 root config is not found and we are configured to return the deprecated config, we will return the mocked config\n      if ((!v3RootConfig && mockV3ConfigToDeprecatedConfig) || (isStorybook && isSemanticColors)) {\n        Logger.logInfo('GraphQLContext | Returning mock v3 config', {\n          colorsConfig: mockV3ColorsConfig as ColorsConfigV3Response,\n          frontendConfig: mockV3FrontendConfig as FrontendConfigV3Response,\n        });\n        const colorsConfig = mockV3ColorsConfig;\n        const frontendConfig = mockV3FrontendConfig;\n        return {\n          colorsConfig: isSemanticColors\n            ? (colorsConfig as ColorsConfigV3Response)\n            : (v3ColorsConfig as ColorsConfigV3Response),\n          frontendConfig: frontendConfig as FrontendConfigV3Response,\n          orgPageConfig: {\n            pageVariants: [],\n            widgetConfigs: {},\n            mountingConfigs: {},\n          },\n        };\n      }\n\n      Logger.logInfo('GraphQLContext | Returning v3 config', {\n        colorsConfig: v3ColorsConfig as ColorsConfigV3Response,\n        frontendConfig: v3FrontendConfig as FrontendConfigV3Response,\n        orgPageConfig: {\n          pageVariants: v3pageVariants,\n          widgetConfigs: v3WidgetConfigs,\n          mountingConfigs: v3MountingConfigs,\n        },\n      });\n\n      return {\n        colorsConfig: v3ColorsConfig as ColorsConfigV3Response,\n        frontendConfig: {\n          ...(v3FrontendConfig as FrontendConfigV3Response),\n          merchantOverrideCss,\n          // Need to replace the automatic widget configs with the object based ones\n          widgetConfigs: v3WidgetConfigs,\n        },\n        orgPageConfig: {\n          pageVariants: v3pageVariants,\n          widgetConfigs: v3WidgetConfigs,\n          mountingConfigs: v3MountingConfigs,\n        },\n        // TODO: Add widgets and other config here\n      };\n    } catch (err) {\n      Logger.logError('Error fetching graphql colors and frontend config', err);\n      return { colorsConfig: undefined, frontendConfig: undefined };\n    }\n  }, [executeQuery, mockV3ConfigToDeprecatedConfig]);\n\n  const getColorsAndFrontendConfig = useCallback(async (): Promise<GraphQlConfigValues> => {\n    try {\n      const query = await getColorsAndFrontendQuery();\n      if (!query) {\n        throw new Error('Colors and frontend config query is not defined');\n      }\n      const response = await executeQuery(query);\n      if (\n        response.me.getProductsConfigByVersion?.version !== ConfigVersionEnum.V3 &&\n        !mockV3ConfigToDeprecatedConfig\n      ) {\n        const colorsConfig = response.me.getProductsConfigByVersion?.colors?.values;\n        const frontendConfig = response.me.getProductsConfigByVersion?.frontend?.values;\n        const transformedColorConfig = transformSnakeToCamel(colorsConfig);\n        const transformedFrontendConfig = transformSnakeToCamel(frontendConfig);\n        return {\n          colorsConfig: transformedColorConfig as ColorsConfigResponse,\n          frontendConfig: transformedFrontendConfig as FrontendConfigResponse,\n        };\n      }\n      // TODO: REMOVE MOCKED CONFIG ONCE WE HAVE THE NEW CONFIG IMPLEMENTED ON BACKEND\n      const merchantColorsConfig = response.me.getProductsConfigByVersion?.colors?.values;\n      const transformedMerchantColorConfig = transformSnakeToCamel(merchantColorsConfig);\n\n      const isSemanticColors = !window.location.href.includes('globals=merchant');\n\n      const colorsConfig = mockV3ColorsConfig;\n      const frontendConfig = mockV3FrontendConfig;\n\n      return {\n        colorsConfig: isSemanticColors\n          ? (colorsConfig as ColorsConfigV3Response)\n          : (transformedMerchantColorConfig as ColorsConfigV3Response),\n        frontendConfig: frontendConfig as FrontendConfigV3Response,\n      };\n    } catch (err) {\n      Logger.logError('Error fetching graphql colors and frontend config', err);\n      return { colorsConfig: undefined, frontendConfig: undefined };\n    }\n  }, [executeQuery]);\n\n  const getConfig = useCallback(async (): Promise<GraphQlConfigValues> => {\n    if (requestV3Config) {\n      Logger.logInfo('GraphQLContext | Getting v3 config', requestV3Config);\n      return getV3Config();\n    }\n    Logger.logInfo('GraphQLContext | Getting colors and frontend config', requestV3Config);\n    return getColorsAndFrontendConfig();\n  }, [getColorsAndFrontendConfig, getV3Config, requestV3Config]);\n\n  const value = useMemo(\n    () => ({\n      executeQuery,\n      getOrgId,\n      getColorsAndFrontendConfig,\n      getV3Config,\n      getConfig,\n      isReady,\n    }),\n    [executeQuery, getOrgId, getColorsAndFrontendConfig, getV3Config, getConfig, isReady],\n  );\n\n  return <GraphQLContext.Provider value={value}>{children}</GraphQLContext.Provider>;\n};\n\nexport const useGraphQLClient = () => {\n  const context = useContext(GraphQLContext);\n  if (!context) {\n    throw new Error('useGraphQLClient must be used within a GraphQLProvider');\n  }\n  return context;\n};\n"],"mappings":"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"}
|
|
262
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"graphqlContext.cjs","names":["Logger","DEFAULT_PAGE_VARIANTS: PageVariantConfig[]","PageVariantTestType","FloatingButtonLocation","orgLevelApiKeyAtom","baseUrlAtom","validateGraphQLOrgId","getMerchantOrgIdQuery","getColorsAndFrontendQuery","transformSnakeToCamel","validateAndTransformMountingConfig","v3pageVariants: PageVariantConfig[]","validateAndTransformPageVariants","mockV3ColorsConfig","mockV3FrontendConfig","ConfigVersionEnum"],"sources":["../../../src/contexts/graphqlContext/graphqlContext.tsx"],"sourcesContent":["import { ReactNode, createContext, useCallback, useContext, useMemo } from 'react';\nimport { useAtomValue } from 'jotai';\nimport { baseUrlAtom, orgLevelApiKeyAtom } from 'src/atoms/envive/enviveConfig';\nimport { getMerchantOrgIdQuery } from 'src/application/models/graphql/queries/getMerchantOrgIdQuery';\nimport { validateGraphQLOrgId } from 'src/application/models/validators/validateGraphQLOrgId';\nimport { ColorMapping } from 'src/application/models/colorsConfig';\nimport { FrontendConfig } from 'src/application/models/frontendConfig';\nimport Logger from 'src/application/logging/logger';\nimport {\n  CamelCasedPropertiesDeep,\n  transformSnakeToCamel,\n  validateAndTransformMountingConfig,\n  validateAndTransformPageVariants,\n} from 'src/application/models';\nimport { getColorsAndFrontendQuery } from 'src/application/models/graphql/queries/getColorsAndFrontendQuery';\nimport { FrontendConfigV3 } from 'src/application/models/frontendConfigV3';\nimport { ColorMappingV3 } from 'src/application/models/colorsConfigV3';\nimport { FloatingButtonLocation } from '@envive-ai/react-toolkit-v3/FloatingButton';\nimport { mockV3ColorsConfig, mockV3FrontendConfig } from './mockV3Config';\nimport { ConfigVersionEnum, WidgetConfigV3 } from '../typesV3';\nimport {\n  OrgPageConfig,\n  PageVariantConfig,\n  PageVariantTestType,\n  WidgetMountingConfig,\n} from '../types';\n\nexport type ColorsConfigResponse = CamelCasedPropertiesDeep<ColorMapping>;\nexport type FrontendConfigResponse = CamelCasedPropertiesDeep<FrontendConfig>;\nexport type ColorsConfigV3Response = CamelCasedPropertiesDeep<ColorMappingV3>;\nexport type FrontendConfigV3Response = CamelCasedPropertiesDeep<FrontendConfigV3>;\n\nexport type GraphQlConfigValues = {\n  colorsConfig?: ColorsConfigResponse | ColorsConfigV3Response;\n  frontendConfig?: CamelCasedPropertiesDeep<FrontendConfig | FrontendConfigV3>;\n  orgPageConfig?: OrgPageConfig;\n};\n\ninterface GraphQLContextValue {\n  executeQuery: <T>(query: string, variables?: Record<string, unknown>) => Promise<T>;\n  getOrgId: () => Promise<string | undefined>;\n  getColorsAndFrontendConfig: () => Promise<GraphQlConfigValues>;\n  getV3Config: () => Promise<GraphQlConfigValues>;\n  getConfig: () => Promise<GraphQlConfigValues>;\n  isReady: boolean;\n}\n\nconst GraphQLContext = createContext<GraphQLContextValue | null>(null);\n\nconst logger = new Logger('graphqlContext');\n\ntype GraphQLProviderProps = {\n  children: ReactNode;\n  requestV3Config?: boolean;\n  mockV3ConfigToDeprecatedConfig?: boolean;\n};\n\nconst DEFAULT_PAGE_VARIANTS: PageVariantConfig[] = [\n  {\n    variantId: 'plp',\n    variantType: 'plp',\n    plpIdExtractor: 'url-resolver-plp-id',\n    widgetMounting: [],\n    variantTests: [\n      {\n        testType: PageVariantTestType.UrlResolver,\n      },\n    ],\n  },\n  {\n    variantId: 'pdp',\n    variantType: 'pdp',\n    productIdExtractor: 'url-resolver-product-id',\n    widgetMounting: [],\n    variantTests: [\n      {\n        testType: PageVariantTestType.UrlResolver,\n      },\n    ],\n  },\n];\n\nconst mapPositionToCamelCase = (position: string): FloatingButtonLocation => {\n  if (position === 'bottom-left') {\n    return FloatingButtonLocation.BOTTOM_LEFT;\n  }\n  if (position === 'middle-left') {\n    return FloatingButtonLocation.MIDDLE_LEFT;\n  }\n  if (position === 'middle-right') {\n    return FloatingButtonLocation.MIDDLE_RIGHT;\n  }\n  if (position === 'bottom-right') {\n    return FloatingButtonLocation.BOTTOM_RIGHT;\n  }\n  throw new Error(`Invalid position: ${position}`);\n};\n\n/**\n * This function is used to do some additional cleanup of the v3 frontend config to ensure that the config is in the correct format.\n */\nconst v3FrontendConfigCleanup = (\n  v3RootConfig: FrontendConfigV3Response,\n): FrontendConfigV3Response => {\n  const { uiConfigs } = v3RootConfig;\n  if (!uiConfigs) {\n    return v3RootConfig;\n  }\n  const { floatingButton, lookAndFeel } = uiConfigs as any;\n  if (!floatingButton || !lookAndFeel) {\n    return v3RootConfig;\n  }\n  const { fontSize, lineHeight } = lookAndFeel.typography as any;\n  return {\n    ...v3RootConfig,\n    uiConfigs: {\n      ...uiConfigs,\n      floatingButton: {\n        ...floatingButton,\n        position: mapPositionToCamelCase(\n          v3RootConfig.uiConfigs?.floatingButton?.position as string,\n        ),\n      },\n      lookAndFeel: {\n        ...lookAndFeel,\n        chatHeaderLogoDarkSrc: lookAndFeel.chatHeaderLogoDarkSrc || lookAndFeel.chatHeaderLogoSrc,\n        chatHeaderLogoLightSrc: lookAndFeel.chatHeaderLogoLightSrc || lookAndFeel.chatHeaderLogoSrc,\n        typography: {\n          ...lookAndFeel.typography,\n          fontSize: {\n            // The fonts sizes are defined differently in the backend config\n            // so we need to map the values to the correct camel case keys\n            b1: fontSize?.b1 || fontSize?.b_1,\n            b2: fontSize?.b2 || fontSize?.b_2,\n            b3: fontSize?.b3 || fontSize?.b_3,\n            b4: fontSize?.b4 || fontSize?.b_4,\n            b5: fontSize?.b5 || fontSize?.b_5,\n            h1: fontSize?.h1 || fontSize?.h_1,\n            h2: fontSize?.h2 || fontSize?.h_2,\n            h3: fontSize?.h3 || fontSize?.h_3,\n            l1: fontSize?.l1 || fontSize?.l_1,\n            l2: fontSize?.l2 || fontSize?.l_2,\n            t1: fontSize?.t1 || fontSize?.t_1,\n            t2: fontSize?.t2 || fontSize?.t_2,\n            t3: fontSize?.t3 || fontSize?.t_3,\n          },\n          lineHeight: {\n            ...lookAndFeel.typography.lineHeight,\n            '114': lineHeight?.lh_114 || lineHeight?.[114],\n            '116': lineHeight?.lh_116 || lineHeight?.[116],\n            '118': lineHeight?.lh_118 || lineHeight?.[118],\n            '120': lineHeight?.lh_120 || lineHeight?.[120],\n            '124': lineHeight?.lh_124 || lineHeight?.[124],\n            '128': lineHeight?.lh_128 || lineHeight?.[128],\n            '130': lineHeight?.lh_130 || lineHeight?.[130],\n            '133': lineHeight?.lh_133 || lineHeight?.[133],\n            '140': lineHeight?.lh_140 || lineHeight?.[140],\n            '148': lineHeight?.lh_148 || lineHeight?.[148],\n          },\n        },\n      },\n    },\n  };\n};\n\nexport const GraphQLProvider = ({\n  children,\n  requestV3Config = false,\n  mockV3ConfigToDeprecatedConfig = false,\n}: GraphQLProviderProps) => {\n  const apiKey = useAtomValue(orgLevelApiKeyAtom);\n  const baseUrl = useAtomValue(baseUrlAtom);\n  const isReady = useMemo(() => Boolean(apiKey && baseUrl), [apiKey, baseUrl]);\n\n  const executeQuery = useCallback(\n    async (query: string, variables?: Record<string, unknown>) => {\n      if (!isReady) {\n        throw new Error('GraphQL client not ready - missing apiKey or baseUrl');\n      }\n\n      const response = await fetch(`${baseUrl}/v1/graphql`, {\n        method: 'POST',\n        headers: {\n          'Content-Type': 'application/json',\n          Authorization: `Bearer ${apiKey}`,\n        },\n        body: JSON.stringify({ query, variables }),\n      });\n\n      if (!response.ok) {\n        throw new Error(`GraphQL request failed: ${response.statusText}`);\n      }\n\n      const result = await response.json();\n      if (result.errors) {\n        throw new Error(`GraphQL errors: ${JSON.stringify(result.errors)}`);\n      }\n\n      return result.data;\n    },\n    [apiKey, baseUrl, isReady],\n  );\n\n  const getOrgId = useCallback(async () => {\n    const response = await executeQuery(getMerchantOrgIdQuery);\n    return validateGraphQLOrgId(response.me.org?.id);\n  }, [executeQuery]);\n\n  const getV3Config = useCallback(async (): Promise<GraphQlConfigValues> => {\n    try {\n      const query = await getColorsAndFrontendQuery();\n      if (!query) {\n        throw new Error('Colors and frontend config query is not defined');\n      }\n      const response = await executeQuery(query);\n\n      // We may update this root config location in the future\n      const v3RootConfig = response.me.getProductsConfigByVersion?.v_three_config?.values;\n      const frontendValues = response.me.getProductsConfigByVersion?.frontend?.values;\n\n      const v3FrontendConfig = v3FrontendConfigCleanup(\n        transformSnakeToCamel(v3RootConfig) as FrontendConfigV3Response,\n      );\n\n      // Get merchant_override_css from frontend.values if v3RootConfig is not available\n      const frontendMerchantOverrideCss = frontendValues?.merchant_override_css;\n      const v3MerchantOverrideCss = v3FrontendConfig.uiConfigs?.merchantOverrideCss;\n      const merchantOverrideCss = v3MerchantOverrideCss || frontendMerchantOverrideCss;\n\n      const v3MountingConfigsArray = (transformSnakeToCamel(v3RootConfig?.mounting_configs) ??\n        []) as unknown as { key: string; config: WidgetMountingConfig }[];\n\n      const v3MountingConfigs = v3MountingConfigsArray.reduce(\n        (acc, { key, config }) => {\n          acc[key] = validateAndTransformMountingConfig(config, key);\n          return acc;\n        },\n        {} as Record<string, WidgetMountingConfig>,\n      );\n\n      const v3widgetConfigsArray = (transformSnakeToCamel(v3RootConfig?.widget_configs) ??\n        []) as unknown as WidgetConfigV3[];\n      const v3WidgetConfigs = Object.fromEntries(\n        v3widgetConfigsArray?.map(({ widgetConfigId, ...rest }: WidgetConfigV3) => [\n          widgetConfigId,\n          { widgetConfigId, ...rest } as WidgetConfigV3,\n        ]),\n      ) as Record<string, WidgetConfigV3>;\n      const v3pageVariants: PageVariantConfig[] = Array.isArray(v3RootConfig?.page_variants)\n        ? v3RootConfig?.page_variants.map(validateAndTransformPageVariants)\n        : DEFAULT_PAGE_VARIANTS;\n\n      const v3ColorsConfig = transformSnakeToCamel(v3RootConfig?.colors?.values);\n      const isSemanticColors = !window.location.href.includes('globals=merchant');\n      const isStorybook = window.top?.location.href.includes('?path=');\n\n      // If the v3 root config is not found and we are configured to return the deprecated config, we will return the mocked config\n      if ((!v3RootConfig && mockV3ConfigToDeprecatedConfig) || (isStorybook && isSemanticColors)) {\n        logger.logDebug('GraphQLContext | Returning mock v3 config', {\n          colorsConfig: mockV3ColorsConfig as ColorsConfigV3Response,\n          frontendConfig: mockV3FrontendConfig as FrontendConfigV3Response,\n        });\n        const colorsConfig = mockV3ColorsConfig;\n        const frontendConfig = mockV3FrontendConfig;\n        return {\n          colorsConfig: isSemanticColors\n            ? (colorsConfig as ColorsConfigV3Response)\n            : (v3ColorsConfig as ColorsConfigV3Response),\n          frontendConfig: frontendConfig as FrontendConfigV3Response,\n          orgPageConfig: {\n            pageVariants: [],\n            widgetConfigs: {},\n            mountingConfigs: {},\n          },\n        };\n      }\n\n      logger.logDebug('GraphQLContext | Returning v3 config', {\n        colorsConfig: v3ColorsConfig as ColorsConfigV3Response,\n        frontendConfig: v3FrontendConfig as FrontendConfigV3Response,\n        orgPageConfig: {\n          pageVariants: v3pageVariants,\n          widgetConfigs: v3WidgetConfigs,\n          mountingConfigs: v3MountingConfigs,\n        },\n      });\n\n      return {\n        colorsConfig: v3ColorsConfig as ColorsConfigV3Response,\n        frontendConfig: {\n          ...(v3FrontendConfig as FrontendConfigV3Response),\n          merchantOverrideCss,\n          // Need to replace the automatic widget configs with the object based ones\n          widgetConfigs: v3WidgetConfigs,\n        },\n        orgPageConfig: {\n          pageVariants: v3pageVariants,\n          widgetConfigs: v3WidgetConfigs,\n          mountingConfigs: v3MountingConfigs,\n        },\n        // TODO: Add widgets and other config here\n      };\n    } catch (err) {\n      logger.logError('Error fetching graphql colors and frontend config', err);\n      return { colorsConfig: undefined, frontendConfig: undefined };\n    }\n  }, [executeQuery, mockV3ConfigToDeprecatedConfig]);\n\n  const getColorsAndFrontendConfig = useCallback(async (): Promise<GraphQlConfigValues> => {\n    try {\n      const query = await getColorsAndFrontendQuery();\n      if (!query) {\n        throw new Error('Colors and frontend config query is not defined');\n      }\n      const response = await executeQuery(query);\n      if (\n        response.me.getProductsConfigByVersion?.version !== ConfigVersionEnum.V3 &&\n        !mockV3ConfigToDeprecatedConfig\n      ) {\n        const colorsConfig = response.me.getProductsConfigByVersion?.colors?.values;\n        const frontendConfig = response.me.getProductsConfigByVersion?.frontend?.values;\n        const transformedColorConfig = transformSnakeToCamel(colorsConfig);\n        const transformedFrontendConfig = transformSnakeToCamel(frontendConfig);\n        return {\n          colorsConfig: transformedColorConfig as ColorsConfigResponse,\n          frontendConfig: transformedFrontendConfig as FrontendConfigResponse,\n        };\n      }\n      // TODO: REMOVE MOCKED CONFIG ONCE WE HAVE THE NEW CONFIG IMPLEMENTED ON BACKEND\n      const merchantColorsConfig = response.me.getProductsConfigByVersion?.colors?.values;\n      const transformedMerchantColorConfig = transformSnakeToCamel(merchantColorsConfig);\n\n      const isSemanticColors = !window.location.href.includes('globals=merchant');\n\n      const colorsConfig = mockV3ColorsConfig;\n      const frontendConfig = mockV3FrontendConfig;\n\n      return {\n        colorsConfig: isSemanticColors\n          ? (colorsConfig as ColorsConfigV3Response)\n          : (transformedMerchantColorConfig as ColorsConfigV3Response),\n        frontendConfig: frontendConfig as FrontendConfigV3Response,\n      };\n    } catch (err) {\n      logger.logError('Error fetching graphql colors and frontend config', err);\n      return { colorsConfig: undefined, frontendConfig: undefined };\n    }\n  }, [executeQuery]);\n\n  const getConfig = useCallback(async (): Promise<GraphQlConfigValues> => {\n    if (requestV3Config) {\n      logger.logDebug('GraphQLContext | Getting v3 config', requestV3Config);\n      return getV3Config();\n    }\n    logger.logDebug('GraphQLContext | Getting colors and frontend config', requestV3Config);\n    return getColorsAndFrontendConfig();\n  }, [getColorsAndFrontendConfig, getV3Config, requestV3Config]);\n\n  const value = useMemo(\n    () => ({\n      executeQuery,\n      getOrgId,\n      getColorsAndFrontendConfig,\n      getV3Config,\n      getConfig,\n      isReady,\n    }),\n    [executeQuery, getOrgId, getColorsAndFrontendConfig, getV3Config, getConfig, isReady],\n  );\n\n  return <GraphQLContext.Provider value={value}>{children}</GraphQLContext.Provider>;\n};\n\nexport const useGraphQLClient = () => {\n  const context = useContext(GraphQLContext);\n  if (!context) {\n    throw new Error('useGraphQLClient must be used within a GraphQLProvider');\n  }\n  return context;\n};\n"],"mappings":"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"}
|