@envive-ai/react-hooks 0.3.5 → 0.3.7
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/models/api/userEvent.d.cts +4 -2
- package/dist/application/models/api/userEvent.d.ts +4 -2
- package/dist/application/models/graphql/queries/getColorsAndFrontendQuery.cjs +18 -0
- package/dist/application/models/graphql/queries/getColorsAndFrontendQuery.js +18 -0
- package/dist/application/models/guards/api/isApiQueryTypedEventAttributes.cjs +2 -2
- package/dist/application/models/guards/api/isApiQueryTypedEventAttributes.js +2 -2
- package/dist/atoms/app/index.d.ts +1 -1
- package/dist/atoms/app/variant.d.cts +6 -6
- package/dist/atoms/app/variant.d.ts +6 -6
- package/dist/atoms/chat/chatState.d.cts +17 -17
- 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.cjs +1 -3
- package/dist/atoms/chat/index.d.cts +4 -5
- package/dist/atoms/chat/index.d.ts +4 -5
- package/dist/atoms/chat/index.js +2 -3
- package/dist/atoms/chat/lastMessage.d.cts +2 -2
- package/dist/atoms/chat/lastMessage.d.ts +2 -2
- package/dist/atoms/chat/performanceMetrics.d.cts +6 -6
- package/dist/atoms/chat/performanceMetrics.d.ts +6 -6
- package/dist/atoms/chat/renderedWidgetRefs.d.cts +2 -2
- package/dist/atoms/chat/renderedWidgetRefs.d.ts +2 -2
- package/dist/atoms/chat/suggestions.d.cts +2 -2
- package/dist/atoms/chat/suggestions.d.ts +2 -2
- 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.ts +17 -17
- package/dist/atoms/search/searchAPI.d.ts +13 -13
- package/dist/atoms/search/types.d.ts +1 -1
- package/dist/atoms/search/utils.d.ts +1 -1
- package/dist/atoms/widget/chatPreviewLoading.d.cts +2 -2
- package/dist/atoms/widget/chatPreviewLoading.d.ts +2 -2
- package/dist/contexts/enviveContext/enviveContext.cjs +20 -17
- package/dist/contexts/enviveContext/enviveContext.d.cts +3 -1
- package/dist/contexts/enviveContext/enviveContext.d.ts +3 -1
- package/dist/contexts/enviveContext/enviveContext.js +20 -17
- package/dist/contexts/enviveContext/types.d.ts +1 -1
- package/dist/contexts/graphqlContext/graphqlContext.cjs +40 -26
- package/dist/contexts/graphqlContext/graphqlContext.js +41 -26
- package/dist/contexts/graphqlContext/mockV3Config.cjs +47 -45
- package/dist/contexts/graphqlContext/mockV3Config.js +5 -3
- package/dist/contexts/newOrgConfigContext/newOrgConfigContext.cjs +10 -9
- package/dist/contexts/newOrgConfigContext/newOrgConfigContext.d.cts +2 -1
- package/dist/contexts/newOrgConfigContext/newOrgConfigContext.d.ts +2 -1
- package/dist/contexts/newOrgConfigContext/newOrgConfigContext.js +10 -9
- package/dist/contexts/salesAgentContext/chatAPI.cjs +26 -5
- package/dist/contexts/salesAgentContext/chatAPI.d.cts +7 -3
- package/dist/contexts/salesAgentContext/chatAPI.d.ts +7 -3
- package/dist/contexts/salesAgentContext/chatAPI.js +26 -5
- package/dist/contexts/salesAgentContext/salesAgentContext.cjs +4 -7
- package/dist/contexts/salesAgentContext/salesAgentContext.js +4 -7
- package/dist/contexts/salesAgentContext/salesAgentService.cjs +42 -17
- package/dist/contexts/salesAgentContext/salesAgentService.js +42 -17
- package/dist/contexts/types.d.cts +1 -1
- package/dist/contexts/types.d.ts +1 -1
- package/dist/contexts/typesV3.cjs +1 -1
- package/dist/contexts/typesV3.d.cts +4 -4
- package/dist/contexts/typesV3.d.ts +4 -4
- package/dist/contexts/typesV3.js +1 -1
- package/dist/contexts/userIdentityContext/userIdentityContext.cjs +1 -2
- package/dist/contexts/userIdentityContext/userIdentityContext.js +1 -2
- package/dist/hooks/GrabAndScroll/useGrabAndScroll.d.cts +2 -2
- package/dist/hooks/GraphQLConfig/useGraphQLConfig.cjs +1 -2
- package/dist/hooks/GraphQLConfig/useGraphQLConfig.js +1 -2
- package/dist/hooks/Search/useSearch.cjs +1 -1
- package/dist/hooks/Search/useSearch.js +1 -1
- package/dist/hooks/Search/useSearchInput.cjs +1 -1
- package/dist/hooks/Search/useSearchInput.js +1 -1
- package/dist/hooks/utils.d.cts +1 -1
- package/dist/packages/components-v3/dist/ChatHeader/hooks/useGetCloseButtonProperties.cjs +1 -1
- package/dist/packages/components-v3/dist/ChatHeader/hooks/useGetCloseButtonProperties.js +1 -1
- package/dist/packages/components-v3/dist/Container/Container.cjs +1 -1
- package/dist/packages/components-v3/dist/Container/Container.js +1 -1
- package/dist/packages/components-v3/dist/FloatingButton/FloatingButton.cjs +2 -0
- package/dist/packages/components-v3/dist/FloatingButton/FloatingButton.js +4 -0
- package/dist/packages/components-v3/dist/FloatingButton/components/Button.cjs +9 -0
- package/dist/packages/components-v3/dist/FloatingButton/components/Button.js +10 -0
- package/dist/packages/components-v3/dist/FloatingButton/components/Container.cjs +9 -0
- package/dist/packages/components-v3/dist/FloatingButton/components/Container.js +10 -0
- package/dist/packages/components-v3/dist/FloatingButton/components/Icon.cjs +3 -0
- package/dist/packages/components-v3/dist/FloatingButton/components/Icon.js +5 -0
- package/dist/packages/components-v3/dist/FloatingButton/components/Wrapper.cjs +9 -0
- package/dist/packages/components-v3/dist/FloatingButton/components/Wrapper.js +10 -0
- package/dist/packages/components-v3/dist/FloatingButton/components/index.cjs +4 -0
- package/dist/packages/components-v3/dist/FloatingButton/components/index.js +6 -0
- package/dist/packages/components-v3/dist/FloatingButton/index.cjs +2 -0
- package/dist/packages/components-v3/dist/FloatingButton/index.js +4 -0
- package/dist/packages/components-v3/dist/FloatingButton/types/types.cjs +17 -0
- package/dist/packages/components-v3/dist/FloatingButton/types/types.js +16 -0
- package/dist/packages/components-v3/dist/ImageGallery/components/Layout.cjs +3 -3
- package/dist/packages/components-v3/dist/ImageGallery/components/Layout.js +3 -3
- package/dist/packages/components-v3/dist/WelcomeMessage/components/Container.cjs +1 -1
- package/dist/packages/components-v3/dist/WelcomeMessage/components/Container.js +1 -1
- package/dist/packages/components-v3/dist/WelcomeMessage/components/SparkleIcon.cjs +1 -1
- package/dist/packages/components-v3/dist/WelcomeMessage/components/SparkleIcon.js +1 -1
- package/dist/packages/components-v3/dist/utils/CustomIcon.cjs +2 -0
- package/dist/packages/components-v3/dist/utils/CustomIcon.js +4 -0
- package/dist/services/amplitudeService/amplitudeService.cjs +5 -2
- package/dist/services/amplitudeService/amplitudeService.js +5 -2
- package/package.json +1 -5
- package/src/application/models/api/userEvent.ts +3 -1
- package/src/application/models/graphql/queries/getColorsAndFrontendQuery.ts +13 -0
- package/src/application/models/guards/api/isApiQueryTypedEventAttributes.ts +6 -1
- package/src/atoms/chat/index.ts +0 -1
- package/src/contexts/enviveContext/enviveContext.tsx +4 -2
- package/src/contexts/graphqlContext/graphqlContext.tsx +32 -41
- package/src/contexts/graphqlContext/mockV3Config.ts +3 -2
- package/src/contexts/newOrgConfigContext/__tests__/newOrgConfigContext.test.tsx +234 -0
- package/src/contexts/newOrgConfigContext/newOrgConfigContext.tsx +14 -8
- package/src/contexts/salesAgentContext/chatAPI.ts +21 -4
- package/src/contexts/salesAgentContext/salesAgentContext.tsx +3 -7
- package/src/contexts/salesAgentContext/salesAgentService.ts +36 -11
- package/src/contexts/typesV3.ts +3 -4
- package/src/contexts/uiConfigContext/__tests__/uiConfigContext.test.tsx +3 -2
- package/src/contexts/userIdentityContext/userIdentityContext.tsx +0 -1
- package/src/hooks/GraphQLConfig/useGraphQLConfig.ts +0 -1
- package/src/services/amplitudeService/__tests__/amplitudeService.test.ts +0 -15
- package/src/services/amplitudeService/amplitudeService.ts +2 -1
- package/dist/atoms/chat/replies.cjs +0 -46
- package/dist/atoms/chat/replies.d.cts +0 -14
- package/dist/atoms/chat/replies.d.ts +0 -14
- package/dist/atoms/chat/replies.js +0 -45
- package/src/atoms/chat/replies.ts +0 -56
|
@@ -6,8 +6,8 @@ const require_enviveConfigContext = require('../enviveConfigContext/enviveConfig
|
|
|
6
6
|
const require_featureFlagServiceContext = require('../featureFlagServiceContext/featureFlagServiceContext.cjs');
|
|
7
7
|
const require_amplitudeContext = require('../amplitudeContext/amplitudeContext.cjs');
|
|
8
8
|
require('../amplitudeContext/index.cjs');
|
|
9
|
-
const require_enviveConfigService = require('../../services/enviveConfigService/enviveConfigService.cjs');
|
|
10
9
|
require('../enviveConfigContext/index.cjs');
|
|
10
|
+
const require_enviveConfigService = require('../../services/enviveConfigService/enviveConfigService.cjs');
|
|
11
11
|
const require_graphqlContext = require('../graphqlContext/graphqlContext.cjs');
|
|
12
12
|
const require_newOrgConfigContext = require('../newOrgConfigContext/newOrgConfigContext.cjs');
|
|
13
13
|
const require_enviveCssContext = require('../enviveCssContext/enviveCssContext.cjs');
|
|
@@ -44,7 +44,7 @@ const SalesAgentWrapper = ({ children, enabledAgents }) => {
|
|
|
44
44
|
if (!enabledAgents.includes(require_contexts_enviveContext_types.EnviveAgent.SalesAgent)) return children;
|
|
45
45
|
return /* @__PURE__ */ (0, react_jsx_runtime.jsx)(require_systemSettingsContext.SystemSettingsContextProvider, { children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(require_salesAgentContext.SalesAgentProvider, { children }) });
|
|
46
46
|
};
|
|
47
|
-
const EnviveProvider = ({ children, previewMode = false, enabledAgents, enviveConfigService: inputEnviveConfigService, featureFlagService: inputFeatureFlagService, amplitudeService: inputAmplitudeService, mockV3ConfigToDeprecatedConfig = false, requestV3Config = false, ...config }) => {
|
|
47
|
+
const EnviveProvider = ({ children, previewMode = false, overrideConfig, enabledAgents, enviveConfigService: inputEnviveConfigService, featureFlagService: inputFeatureFlagService, amplitudeService: inputAmplitudeService, mockV3ConfigToDeprecatedConfig = false, requestV3Config = false, ...config }) => {
|
|
48
48
|
const userId = "spiffy-user-id-0b64d781-e1c2-4b6d-9cf5-32b4f7c1e3f2";
|
|
49
49
|
const namespace = "spiffy-react-components";
|
|
50
50
|
const source = "app";
|
|
@@ -84,22 +84,25 @@ const EnviveProvider = ({ children, previewMode = false, enabledAgents, enviveCo
|
|
|
84
84
|
children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(require_graphqlContext.GraphQLProvider, {
|
|
85
85
|
mockV3ConfigToDeprecatedConfig,
|
|
86
86
|
requestV3Config,
|
|
87
|
-
children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(require_newOrgConfigContext.NewOrgConfigProvider, {
|
|
88
|
-
|
|
89
|
-
children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(
|
|
90
|
-
|
|
91
|
-
children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(
|
|
92
|
-
|
|
93
|
-
children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(
|
|
94
|
-
|
|
95
|
-
children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(
|
|
87
|
+
children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(require_newOrgConfigContext.NewOrgConfigProvider, {
|
|
88
|
+
overrideConfig,
|
|
89
|
+
children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(require_localStorageContext.LocalStorageProvider, { children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(require_featureFlagServiceContext.FeatureFlagServiceProvider, {
|
|
90
|
+
featureFlagService,
|
|
91
|
+
children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(require_userIdentityContext.UserIdentityProvider, { children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(require_amplitudeContext.AmplitudeProvider, {
|
|
92
|
+
externalAmplitudeService: inputAmplitudeService,
|
|
93
|
+
children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(require_pageContext.PageProvider, {
|
|
94
|
+
previewMode,
|
|
95
|
+
children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(require_uiConfigContext.UiConfigProvider, { children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(require_widgetConfigContext.WidgetConfigProvider, { children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(require_hardcopyContext.HardcopyProvider, { children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(require_enviveCssContext.EnviveCssProvider, { children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(SearchAgentWrapper, {
|
|
96
96
|
enabledAgents,
|
|
97
|
-
children
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
97
|
+
children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(SalesAgentWrapper, {
|
|
98
|
+
enabledAgents,
|
|
99
|
+
children
|
|
100
|
+
})
|
|
101
|
+
}) }) }) }) })
|
|
102
|
+
})
|
|
103
|
+
}) })
|
|
101
104
|
}) })
|
|
102
|
-
})
|
|
105
|
+
})
|
|
103
106
|
})
|
|
104
107
|
})
|
|
105
108
|
});
|
|
@@ -107,4 +110,4 @@ const EnviveProvider = ({ children, previewMode = false, enabledAgents, enviveCo
|
|
|
107
110
|
|
|
108
111
|
//#endregion
|
|
109
112
|
exports.EnviveProvider = EnviveProvider;
|
|
110
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"enviveContext.cjs","names":["SearchAgentWrapper: React.FC<AgentWrapperProps>","EnviveAgent","SearchProvider","SalesAgentWrapper: React.FC<AgentWrapperProps>","SystemSettingsContextProvider","SalesAgentProvider","EnviveProvider: React.FC<EnviveProviderProps>","EnviveConfigService","FeatureFlagService","EnviveConfigProvider","GraphQLProvider","NewOrgConfigProvider","LocalStorageProvider","FeatureFlagServiceProvider","UserIdentityProvider","AmplitudeProvider","PageProvider","UiConfigProvider","WidgetConfigProvider","HardcopyProvider","EnviveCssProvider"],"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 { AmplitudeProvider } from '../amplitudeContext';\nimport { EnviveConfigProvider } from '../enviveConfigContext';\nimport { EnviveCssProvider } from '../enviveCssContext';\nimport { FeatureFlagService, FeatureFlagServiceProvider } from '../featureFlagServiceContext';\nimport { GraphQLProvider } 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 } from '../hardcopyContext';\nimport { WidgetConfigProvider } from '../widgetConfigContext';\nimport { PageProvider } from '../pageContext';\nimport { UiConfigProvider } from '../uiConfigContext';\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  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  previewMode?: boolean;\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\nconst SalesAgentWrapper: React.FC<AgentWrapperProps> = ({ children, enabledAgents }) => {\n  if (!enabledAgents.includes(EnviveAgent.SalesAgent)) {\n    return children;\n  }\n  return (\n    <SystemSettingsContextProvider>\n      <SalesAgentProvider>{children}</SalesAgentProvider>\n    </SystemSettingsContextProvider>\n  );\n};\n\nexport const EnviveProvider: React.FC<EnviveProviderProps> = ({\n  children,\n  previewMode = false,\n  enabledAgents,\n  enviveConfigService: inputEnviveConfigService,\n  featureFlagService: inputFeatureFlagService,\n  amplitudeService: inputAmplitudeService,\n  mockV3ConfigToDeprecatedConfig = false,\n  requestV3Config = false,\n  ...config\n}) => {\n  const userId = 'spiffy-user-id-0b64d781-e1c2-4b6d-9cf5-32b4f7c1e3f2'; // TODO: How should this be derived?\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: 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>\n            <LocalStorageProvider>\n              <FeatureFlagServiceProvider featureFlagService={featureFlagService}>\n                <UserIdentityProvider>\n                  <AmplitudeProvider externalAmplitudeService={inputAmplitudeService}>\n                    <PageProvider previewMode={previewMode}>\n                      <UiConfigProvider>\n                        <WidgetConfigProvider>\n                          <HardcopyProvider>\n                            <EnviveCssProvider>\n                              <SearchAgentWrapper enabledAgents={enabledAgents}>\n                                <SalesAgentWrapper enabledAgents={enabledAgents}>\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":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAuBA,MAAM,yCAAoC,KAAK;AAgC/C,MAAMA,sBAAmD,EAAE,UAAU,oBAAoB;AACvF,KAAI,CAAC,cAAc,SAASC,iDAAY,YAAY,CAClD,QAAO;AAET,QAAO,2CAACC,wCAAgB,WAA0B;;AAGpD,MAAMC,qBAAkD,EAAE,UAAU,oBAAoB;AACtF,KAAI,CAAC,cAAc,SAASF,iDAAY,WAAW,CACjD,QAAO;AAET,QACE,2CAACG,yEACC,2CAACC,gDAAoB,WAA8B,GACrB;;AAIpC,MAAaC,kBAAiD,EAC5D,UACA,cAAc,OACd,eACA,qBAAqB,0BACrB,oBAAoB,yBACpB,kBAAkB,uBAClB,iCAAiC,OACjC,kBAAkB,OAClB,GAAG,aACC;CACJ,MAAM,SAAS;CACf,MAAM,YAAY;CAClB,MAAM,SAAS;CACf,MAAM,CAAC,qBAAqB,8CAA+D,KAAK;AAEhG,4BAAgB;AAYd,GARE,4BACA,IAAIC,gDAAoB;GACtB,SAAS,QAAQ,WAAW;GAC5B,QAAQ,QAAQ,kBAAkB;GAC1B;GACG;GACH;GACT,CAAC,EACgB,iBAAiB,CAAC,MAAK,cAAa;AACtD,0BAAuB,UAAU;AACjC,UAAO;IACP;IACD;EAAC;EAAQ;EAAQ;EAAW;EAAQ;EAAyB,CAAC;CAEjE,MAAM,yCACG;EACL,GAAG;EACH,cAAc,qBAAqB,SAAS,EAAE;EAC9C,cAAc,qBAAqB,KAAK,KAAK,cAAc;EAC3D,OAAO,qBAAqB,KAAK,KAAK,MAAM;EAC7C,GACD,CAAC,QAAQ,oBAAoB,CAC9B;AACD,wBAAO,SAAS,sCAAsC,qBAAqB,OAAO;AAClF,wBAAO,SAAS,+BAA+B,aAAa;CAE5D,MAAM,8CACE,2BAA2B,IAAIC,qDAAmB,aAAa,aAAa,EAClF,CAAC,aAAa,cAAc,wBAAwB,CACrD;AAED,KAAI,wBAAwB,QAAQ,iBAAiB,KACnD,QAAO;AAGT,QACE,2CAAC,cAAc;EAAS,OAAO;YAC7B,2CAACC;GAAqB,GAAI;aACxB,2CAACC;IACiC;IACf;cAEjB,2CAACC,8DACC,2CAACC,8DACC,2CAACC;KAA+C;eAC9C,2CAACC,8DACC,2CAACC;MAAkB,0BAA0B;gBAC3C,2CAACC;OAA0B;iBACzB,2CAACC,sDACC,2CAACC,8DACC,2CAACC,sDACC,2CAACC,wDACC,2CAAC;QAAkC;kBACjC,2CAAC;SAAiC;SAC/B;UACiB;SACD,GACH,GACH,GACE,GACN;QACN;OACG,GACC;MACI,GACR,GACF;KACP;IACG;GACA"}
|
|
113
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"enviveContext.cjs","names":["SearchAgentWrapper: React.FC<AgentWrapperProps>","EnviveAgent","SearchProvider","SalesAgentWrapper: React.FC<AgentWrapperProps>","SystemSettingsContextProvider","SalesAgentProvider","EnviveProvider: React.FC<EnviveProviderProps>","EnviveConfigService","FeatureFlagService","EnviveConfigProvider","GraphQLProvider","NewOrgConfigProvider","LocalStorageProvider","FeatureFlagServiceProvider","UserIdentityProvider","AmplitudeProvider","PageProvider","UiConfigProvider","WidgetConfigProvider","HardcopyProvider","EnviveCssProvider"],"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 { AmplitudeProvider } from '../amplitudeContext';\nimport { EnviveConfigProvider } from '../enviveConfigContext';\nimport { EnviveCssProvider } from '../enviveCssContext';\nimport { FeatureFlagService, FeatureFlagServiceProvider } from '../featureFlagServiceContext';\nimport { GraphQlConfigValues, GraphQLProvider } 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 } from '../hardcopyContext';\nimport { WidgetConfigProvider } from '../widgetConfigContext';\nimport { PageProvider } from '../pageContext';\nimport { UiConfigProvider } from '../uiConfigContext';\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  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  previewMode?: boolean;\n  overrideConfig?: GraphQlConfigValues;\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\nconst SalesAgentWrapper: React.FC<AgentWrapperProps> = ({ children, enabledAgents }) => {\n  if (!enabledAgents.includes(EnviveAgent.SalesAgent)) {\n    return children;\n  }\n  return (\n    <SystemSettingsContextProvider>\n      <SalesAgentProvider>{children}</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  mockV3ConfigToDeprecatedConfig = false,\n  requestV3Config = false,\n  ...config\n}) => {\n  const userId = 'spiffy-user-id-0b64d781-e1c2-4b6d-9cf5-32b4f7c1e3f2'; // TODO: How should this be derived?\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: 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>\n                  <AmplitudeProvider externalAmplitudeService={inputAmplitudeService}>\n                    <PageProvider previewMode={previewMode}>\n                      <UiConfigProvider>\n                        <WidgetConfigProvider>\n                          <HardcopyProvider>\n                            <EnviveCssProvider>\n                              <SearchAgentWrapper enabledAgents={enabledAgents}>\n                                <SalesAgentWrapper enabledAgents={enabledAgents}>\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":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAuBA,MAAM,yCAAoC,KAAK;AAiC/C,MAAMA,sBAAmD,EAAE,UAAU,oBAAoB;AACvF,KAAI,CAAC,cAAc,SAASC,iDAAY,YAAY,CAClD,QAAO;AAET,QAAO,2CAACC,wCAAgB,WAA0B;;AAGpD,MAAMC,qBAAkD,EAAE,UAAU,oBAAoB;AACtF,KAAI,CAAC,cAAc,SAASF,iDAAY,WAAW,CACjD,QAAO;AAET,QACE,2CAACG,yEACC,2CAACC,gDAAoB,WAA8B,GACrB;;AAIpC,MAAaC,kBAAiD,EAC5D,UACA,cAAc,OACd,gBACA,eACA,qBAAqB,0BACrB,oBAAoB,yBACpB,kBAAkB,uBAClB,iCAAiC,OACjC,kBAAkB,OAClB,GAAG,aACC;CACJ,MAAM,SAAS;CACf,MAAM,YAAY;CAClB,MAAM,SAAS;CACf,MAAM,CAAC,qBAAqB,8CAA+D,KAAK;AAEhG,4BAAgB;AAYd,GARE,4BACA,IAAIC,gDAAoB;GACtB,SAAS,QAAQ,WAAW;GAC5B,QAAQ,QAAQ,kBAAkB;GAC1B;GACG;GACH;GACT,CAAC,EACgB,iBAAiB,CAAC,MAAK,cAAa;AACtD,0BAAuB,UAAU;AACjC,UAAO;IACP;IACD;EAAC;EAAQ;EAAQ;EAAW;EAAQ;EAAyB,CAAC;CAEjE,MAAM,yCACG;EACL,GAAG;EACH,cAAc,qBAAqB,SAAS,EAAE;EAC9C,cAAc,qBAAqB,KAAK,KAAK,cAAc;EAC3D,OAAO,qBAAqB,KAAK,KAAK,MAAM;EAC7C,GACD,CAAC,QAAQ,oBAAoB,CAC9B;AACD,wBAAO,SAAS,sCAAsC,qBAAqB,OAAO;AAClF,wBAAO,SAAS,+BAA+B,aAAa;CAE5D,MAAM,8CACE,2BAA2B,IAAIC,qDAAmB,aAAa,aAAa,EAClF,CAAC,aAAa,cAAc,wBAAwB,CACrD;AAED,KAAI,wBAAwB,QAAQ,iBAAiB,KACnD,QAAO;AAGT,QACE,2CAAC,cAAc;EAAS,OAAO;YAC7B,2CAACC;GAAqB,GAAI;aACxB,2CAACC;IACiC;IACf;cAEjB,2CAACC;KAAqC;eACpC,2CAACC,8DACC,2CAACC;MAA+C;gBAC9C,2CAACC,8DACC,2CAACC;OAAkB,0BAA0B;iBAC3C,2CAACC;QAA0B;kBACzB,2CAACC,sDACC,2CAACC,8DACC,2CAACC,sDACC,2CAACC,wDACC,2CAAC;SAAkC;mBACjC,2CAAC;UAAiC;UAC/B;WACiB;UACD,GACH,GACH,GACE,GACN;SACN;QACG,GACC;OACI,GACR;MACF;KACP;IACG;GACA"}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { OrgConfigFeatureGate } from "../../application/models/api/orgConfigResults.cjs";
|
|
2
2
|
import { FeatureFlagService } from "../featureFlagServiceContext/featureFlagServiceContext.cjs";
|
|
3
3
|
import { AmplitudeService } from "../../services/amplitudeService/amplitudeService.cjs";
|
|
4
|
+
import { GraphQlConfigValues } from "../graphqlContext/graphqlContext.cjs";
|
|
4
5
|
import { EnviveConfigService } from "../../services/enviveConfigService/enviveConfigService.cjs";
|
|
5
6
|
import { EnviveAgent } from "./types.cjs";
|
|
6
7
|
import { ReactNode } from "react";
|
|
@@ -33,8 +34,9 @@ interface EnviveProviderProps extends AgentWrapperProps {
|
|
|
33
34
|
mockV3ConfigToDeprecatedConfig?: boolean;
|
|
34
35
|
requestV3Config?: boolean;
|
|
35
36
|
previewMode?: boolean;
|
|
37
|
+
overrideConfig?: GraphQlConfigValues;
|
|
36
38
|
}
|
|
37
39
|
declare const EnviveProvider: React.FC<EnviveProviderProps>;
|
|
38
40
|
//#endregion
|
|
39
41
|
export { EnviveProvider };
|
|
40
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
42
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW52aXZlQ29udGV4dC5kLmN0cyIsIm5hbWVzIjpbXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29udGV4dHMvZW52aXZlQ29udGV4dC9lbnZpdmVDb250ZXh0LmQudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgT3JnQ29uZmlnRmVhdHVyZUdhdGUgfSBmcm9tICdzcmMvYXBwbGljYXRpb24vbW9kZWxzL2FwaS9vcmdDb25maWdSZXN1bHRzJztcbmltcG9ydCB7IEVudml2ZUNvbmZpZ1NlcnZpY2UgfSBmcm9tICdzcmMvc2VydmljZXMvZW52aXZlQ29uZmlnU2VydmljZSc7XG5pbXBvcnQgeyBBbXBsaXR1ZGVTZXJ2aWNlIH0gZnJvbSAnc3JjL3NlcnZpY2VzL2FtcGxpdHVkZVNlcnZpY2UvYW1wbGl0dWRlU2VydmljZSc7XG5pbXBvcnQgeyBGZWF0dXJlRmxhZ1NlcnZpY2UgfSBmcm9tICcuLi9mZWF0dXJlRmxhZ1NlcnZpY2VDb250ZXh0JztcbmltcG9ydCB7IEdyYXBoUWxDb25maWdWYWx1ZXMgfSBmcm9tICcuLi9ncmFwaHFsQ29udGV4dCc7XG5pbXBvcnQgeyBFbnZpdmVBZ2VudCB9IGZyb20gJy4vdHlwZXMnO1xuaW50ZXJmYWNlIEFnZW50V3JhcHBlclByb3BzIHtcbiAgICBjaGlsZHJlbjogUmVhY3ROb2RlO1xuICAgIGVuYWJsZWRBZ2VudHM6IEVudml2ZUFnZW50W107XG59XG5pbnRlcmZhY2UgRW52aXZlUHJvdmlkZXJQcm9wcyBleHRlbmRzIEFnZW50V3JhcHBlclByb3BzIHtcbiAgICBhbXBsaXR1ZGVBcGlLZXk/OiBzdHJpbmc7XG4gICAgZGF0YVJlc2lkZW5jeT86IHN0cmluZztcbiAgICBlbnY/OiBzdHJpbmc7XG4gICAgYmFzZVVybD86IHN0cmluZztcbiAgICByZWFjdEFwcE5hbWU/OiBzdHJpbmc7XG4gICAgY2RuVXJsPzogc3RyaW5nO1xuICAgIGNvbnRleHRTb3VyY2U/OiBzdHJpbmc7XG4gICAgb3JnTGV2ZWxBcGlLZXk/OiBzdHJpbmc7XG4gICAgb3JnU2hvcnROYW1lPzogc3RyaW5nO1xuICAgIGlkZW50aWZ5aW5nUHJlZml4OiBzdHJpbmc7XG4gICAgZmVhdHVyZU92ZXJyaWRlcz86IFJlY29yZDxzdHJpbmcsIGJvb2xlYW4+O1xuICAgIHZhcmlhbnRVcmxPdmVycmlkZT86IHN0cmluZztcbiAgICB2YXJpYW50SW5mb092ZXJyaWRlPzogYW55O1xuICAgIHNob3c/OiBib29sZWFuO1xuICAgIHB1YmxpY0tleT86IHN0cmluZztcbiAgICBmZWF0dXJlR2F0ZXM/OiBPcmdDb25maWdGZWF0dXJlR2F0ZVtdO1xuICAgIGZlYXR1cmVGbGFnU2VydmljZT86IEZlYXR1cmVGbGFnU2VydmljZTtcbiAgICBlbnZpdmVDb25maWdTZXJ2aWNlPzogRW52aXZlQ29uZmlnU2VydmljZTtcbiAgICBhbXBsaXR1ZGVTZXJ2aWNlPzogQW1wbGl0dWRlU2VydmljZTtcbiAgICBtb2NrVjNDb25maWdUb0RlcHJlY2F0ZWRDb25maWc/OiBib29sZWFuO1xuICAgIHJlcXVlc3RWM0NvbmZpZz86IGJvb2xlYW47XG4gICAgcHJldmlld01vZGU/OiBib29sZWFuO1xuICAgIG92ZXJyaWRlQ29uZmlnPzogR3JhcGhRbENvbmZpZ1ZhbHVlcztcbn1cbmV4cG9ydCBkZWNsYXJlIGNvbnN0IEVudml2ZVByb3ZpZGVyOiBSZWFjdC5GQzxFbnZpdmVQcm92aWRlclByb3BzPjtcbmV4cG9ydCB7fTtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7O0FBT0EsSUFBSSxvQkFBb0I7Q0FBQztPQUFHO09BQUE7Q0FBQTtBQUM1QixJQUFJLHNCQUFtQjtDQUFBO09BQUE7T0FBQTtPQUFBO09BQUE7T0FBQTtPQUFBO09BQUE7Q0FBQTtBQUN2QixJQUFXLGlCQUFpQjtDQUFDO09BQUc7T0FBQSxNQUFBO0NBQUEifQ==
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { OrgConfigFeatureGate } from "../../application/models/api/orgConfigResults.js";
|
|
2
2
|
import { FeatureFlagService } from "../featureFlagServiceContext/featureFlagServiceContext.js";
|
|
3
3
|
import { AmplitudeService } from "../../services/amplitudeService/amplitudeService.js";
|
|
4
|
+
import { GraphQlConfigValues } from "../graphqlContext/graphqlContext.js";
|
|
4
5
|
import { EnviveConfigService } from "../../services/enviveConfigService/enviveConfigService.js";
|
|
5
6
|
import { EnviveAgent } from "./types.js";
|
|
6
7
|
import { ReactNode } from "react";
|
|
@@ -33,8 +34,9 @@ interface EnviveProviderProps extends AgentWrapperProps {
|
|
|
33
34
|
mockV3ConfigToDeprecatedConfig?: boolean;
|
|
34
35
|
requestV3Config?: boolean;
|
|
35
36
|
previewMode?: boolean;
|
|
37
|
+
overrideConfig?: GraphQlConfigValues;
|
|
36
38
|
}
|
|
37
39
|
declare const EnviveProvider: React.FC<EnviveProviderProps>;
|
|
38
40
|
//#endregion
|
|
39
41
|
export { EnviveProvider };
|
|
40
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
42
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW52aXZlQ29udGV4dC5kLnRzIiwibmFtZXMiOltdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb250ZXh0cy9lbnZpdmVDb250ZXh0L2Vudml2ZUNvbnRleHQuZC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBPcmdDb25maWdGZWF0dXJlR2F0ZSB9IGZyb20gJ3NyYy9hcHBsaWNhdGlvbi9tb2RlbHMvYXBpL29yZ0NvbmZpZ1Jlc3VsdHMnO1xuaW1wb3J0IHsgRW52aXZlQ29uZmlnU2VydmljZSB9IGZyb20gJ3NyYy9zZXJ2aWNlcy9lbnZpdmVDb25maWdTZXJ2aWNlJztcbmltcG9ydCB7IEFtcGxpdHVkZVNlcnZpY2UgfSBmcm9tICdzcmMvc2VydmljZXMvYW1wbGl0dWRlU2VydmljZS9hbXBsaXR1ZGVTZXJ2aWNlJztcbmltcG9ydCB7IEZlYXR1cmVGbGFnU2VydmljZSB9IGZyb20gJy4uL2ZlYXR1cmVGbGFnU2VydmljZUNvbnRleHQnO1xuaW1wb3J0IHsgR3JhcGhRbENvbmZpZ1ZhbHVlcyB9IGZyb20gJy4uL2dyYXBocWxDb250ZXh0JztcbmltcG9ydCB7IEVudml2ZUFnZW50IH0gZnJvbSAnLi90eXBlcyc7XG5pbnRlcmZhY2UgQWdlbnRXcmFwcGVyUHJvcHMge1xuICAgIGNoaWxkcmVuOiBSZWFjdE5vZGU7XG4gICAgZW5hYmxlZEFnZW50czogRW52aXZlQWdlbnRbXTtcbn1cbmludGVyZmFjZSBFbnZpdmVQcm92aWRlclByb3BzIGV4dGVuZHMgQWdlbnRXcmFwcGVyUHJvcHMge1xuICAgIGFtcGxpdHVkZUFwaUtleT86IHN0cmluZztcbiAgICBkYXRhUmVzaWRlbmN5Pzogc3RyaW5nO1xuICAgIGVudj86IHN0cmluZztcbiAgICBiYXNlVXJsPzogc3RyaW5nO1xuICAgIHJlYWN0QXBwTmFtZT86IHN0cmluZztcbiAgICBjZG5Vcmw/OiBzdHJpbmc7XG4gICAgY29udGV4dFNvdXJjZT86IHN0cmluZztcbiAgICBvcmdMZXZlbEFwaUtleT86IHN0cmluZztcbiAgICBvcmdTaG9ydE5hbWU/OiBzdHJpbmc7XG4gICAgaWRlbnRpZnlpbmdQcmVmaXg6IHN0cmluZztcbiAgICBmZWF0dXJlT3ZlcnJpZGVzPzogUmVjb3JkPHN0cmluZywgYm9vbGVhbj47XG4gICAgdmFyaWFudFVybE92ZXJyaWRlPzogc3RyaW5nO1xuICAgIHZhcmlhbnRJbmZvT3ZlcnJpZGU/OiBhbnk7XG4gICAgc2hvdz86IGJvb2xlYW47XG4gICAgcHVibGljS2V5Pzogc3RyaW5nO1xuICAgIGZlYXR1cmVHYXRlcz86IE9yZ0NvbmZpZ0ZlYXR1cmVHYXRlW107XG4gICAgZmVhdHVyZUZsYWdTZXJ2aWNlPzogRmVhdHVyZUZsYWdTZXJ2aWNlO1xuICAgIGVudml2ZUNvbmZpZ1NlcnZpY2U/OiBFbnZpdmVDb25maWdTZXJ2aWNlO1xuICAgIGFtcGxpdHVkZVNlcnZpY2U/OiBBbXBsaXR1ZGVTZXJ2aWNlO1xuICAgIG1vY2tWM0NvbmZpZ1RvRGVwcmVjYXRlZENvbmZpZz86IGJvb2xlYW47XG4gICAgcmVxdWVzdFYzQ29uZmlnPzogYm9vbGVhbjtcbiAgICBwcmV2aWV3TW9kZT86IGJvb2xlYW47XG4gICAgb3ZlcnJpZGVDb25maWc/OiBHcmFwaFFsQ29uZmlnVmFsdWVzO1xufVxuZXhwb3J0IGRlY2xhcmUgY29uc3QgRW52aXZlUHJvdmlkZXI6IFJlYWN0LkZDPEVudml2ZVByb3ZpZGVyUHJvcHM+O1xuZXhwb3J0IHt9O1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7QUFPQSxJQUFJLG9CQUFvQjtDQUFDO09BQUc7T0FBQTtDQUFBO0FBQzVCLElBQUksc0JBQW1CO0NBQUE7T0FBQTtPQUFBO09BQUE7T0FBQTtPQUFBO09BQUE7T0FBQTtDQUFBO0FBQ3ZCLElBQVcsaUJBQWlCO0NBQUM7T0FBRztPQUFBLE1BQUE7Q0FBQSJ9
|
|
@@ -5,8 +5,8 @@ import { EnviveConfigProvider } from "../enviveConfigContext/enviveConfigContext
|
|
|
5
5
|
import { FeatureFlagService, FeatureFlagServiceProvider } from "../featureFlagServiceContext/featureFlagServiceContext.js";
|
|
6
6
|
import { AmplitudeProvider } from "../amplitudeContext/amplitudeContext.js";
|
|
7
7
|
import "../amplitudeContext/index.js";
|
|
8
|
-
import { EnviveConfigService } from "../../services/enviveConfigService/enviveConfigService.js";
|
|
9
8
|
import "../enviveConfigContext/index.js";
|
|
9
|
+
import { EnviveConfigService } from "../../services/enviveConfigService/enviveConfigService.js";
|
|
10
10
|
import { GraphQLProvider } from "../graphqlContext/graphqlContext.js";
|
|
11
11
|
import { NewOrgConfigProvider } from "../newOrgConfigContext/newOrgConfigContext.js";
|
|
12
12
|
import { EnviveCssProvider } from "../enviveCssContext/enviveCssContext.js";
|
|
@@ -43,7 +43,7 @@ const SalesAgentWrapper = ({ children, enabledAgents }) => {
|
|
|
43
43
|
if (!enabledAgents.includes(EnviveAgent.SalesAgent)) return children;
|
|
44
44
|
return /* @__PURE__ */ jsx(SystemSettingsContextProvider, { children: /* @__PURE__ */ jsx(SalesAgentProvider, { children }) });
|
|
45
45
|
};
|
|
46
|
-
const EnviveProvider = ({ children, previewMode = false, enabledAgents, enviveConfigService: inputEnviveConfigService, featureFlagService: inputFeatureFlagService, amplitudeService: inputAmplitudeService, mockV3ConfigToDeprecatedConfig = false, requestV3Config = false, ...config }) => {
|
|
46
|
+
const EnviveProvider = ({ children, previewMode = false, overrideConfig, enabledAgents, enviveConfigService: inputEnviveConfigService, featureFlagService: inputFeatureFlagService, amplitudeService: inputAmplitudeService, mockV3ConfigToDeprecatedConfig = false, requestV3Config = false, ...config }) => {
|
|
47
47
|
const userId = "spiffy-user-id-0b64d781-e1c2-4b6d-9cf5-32b4f7c1e3f2";
|
|
48
48
|
const namespace = "spiffy-react-components";
|
|
49
49
|
const source = "app";
|
|
@@ -83,22 +83,25 @@ const EnviveProvider = ({ children, previewMode = false, enabledAgents, enviveCo
|
|
|
83
83
|
children: /* @__PURE__ */ jsx(GraphQLProvider, {
|
|
84
84
|
mockV3ConfigToDeprecatedConfig,
|
|
85
85
|
requestV3Config,
|
|
86
|
-
children: /* @__PURE__ */ jsx(NewOrgConfigProvider, {
|
|
87
|
-
|
|
88
|
-
children: /* @__PURE__ */ jsx(
|
|
89
|
-
|
|
90
|
-
children: /* @__PURE__ */ jsx(
|
|
91
|
-
|
|
92
|
-
children: /* @__PURE__ */ jsx(
|
|
93
|
-
|
|
94
|
-
children: /* @__PURE__ */ jsx(
|
|
86
|
+
children: /* @__PURE__ */ jsx(NewOrgConfigProvider, {
|
|
87
|
+
overrideConfig,
|
|
88
|
+
children: /* @__PURE__ */ jsx(LocalStorageProvider, { children: /* @__PURE__ */ jsx(FeatureFlagServiceProvider, {
|
|
89
|
+
featureFlagService,
|
|
90
|
+
children: /* @__PURE__ */ jsx(UserIdentityProvider, { children: /* @__PURE__ */ jsx(AmplitudeProvider, {
|
|
91
|
+
externalAmplitudeService: inputAmplitudeService,
|
|
92
|
+
children: /* @__PURE__ */ jsx(PageProvider, {
|
|
93
|
+
previewMode,
|
|
94
|
+
children: /* @__PURE__ */ jsx(UiConfigProvider, { children: /* @__PURE__ */ jsx(WidgetConfigProvider, { children: /* @__PURE__ */ jsx(HardcopyProvider, { children: /* @__PURE__ */ jsx(EnviveCssProvider, { children: /* @__PURE__ */ jsx(SearchAgentWrapper, {
|
|
95
95
|
enabledAgents,
|
|
96
|
-
children
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
96
|
+
children: /* @__PURE__ */ jsx(SalesAgentWrapper, {
|
|
97
|
+
enabledAgents,
|
|
98
|
+
children
|
|
99
|
+
})
|
|
100
|
+
}) }) }) }) })
|
|
101
|
+
})
|
|
102
|
+
}) })
|
|
100
103
|
}) })
|
|
101
|
-
})
|
|
104
|
+
})
|
|
102
105
|
})
|
|
103
106
|
})
|
|
104
107
|
});
|
|
@@ -106,4 +109,4 @@ const EnviveProvider = ({ children, previewMode = false, enabledAgents, enviveCo
|
|
|
106
109
|
|
|
107
110
|
//#endregion
|
|
108
111
|
export { EnviveProvider };
|
|
109
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"enviveContext.js","names":["SearchAgentWrapper: React.FC<AgentWrapperProps>","SalesAgentWrapper: React.FC<AgentWrapperProps>","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 { AmplitudeProvider } from '../amplitudeContext';\nimport { EnviveConfigProvider } from '../enviveConfigContext';\nimport { EnviveCssProvider } from '../enviveCssContext';\nimport { FeatureFlagService, FeatureFlagServiceProvider } from '../featureFlagServiceContext';\nimport { GraphQLProvider } 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 } from '../hardcopyContext';\nimport { WidgetConfigProvider } from '../widgetConfigContext';\nimport { PageProvider } from '../pageContext';\nimport { UiConfigProvider } from '../uiConfigContext';\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  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  previewMode?: boolean;\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\nconst SalesAgentWrapper: React.FC<AgentWrapperProps> = ({ children, enabledAgents }) => {\n  if (!enabledAgents.includes(EnviveAgent.SalesAgent)) {\n    return children;\n  }\n  return (\n    <SystemSettingsContextProvider>\n      <SalesAgentProvider>{children}</SalesAgentProvider>\n    </SystemSettingsContextProvider>\n  );\n};\n\nexport const EnviveProvider: React.FC<EnviveProviderProps> = ({\n  children,\n  previewMode = false,\n  enabledAgents,\n  enviveConfigService: inputEnviveConfigService,\n  featureFlagService: inputFeatureFlagService,\n  amplitudeService: inputAmplitudeService,\n  mockV3ConfigToDeprecatedConfig = false,\n  requestV3Config = false,\n  ...config\n}) => {\n  const userId = 'spiffy-user-id-0b64d781-e1c2-4b6d-9cf5-32b4f7c1e3f2'; // TODO: How should this be derived?\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: 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>\n            <LocalStorageProvider>\n              <FeatureFlagServiceProvider featureFlagService={featureFlagService}>\n                <UserIdentityProvider>\n                  <AmplitudeProvider externalAmplitudeService={inputAmplitudeService}>\n                    <PageProvider previewMode={previewMode}>\n                      <UiConfigProvider>\n                        <WidgetConfigProvider>\n                          <HardcopyProvider>\n                            <EnviveCssProvider>\n                              <SearchAgentWrapper enabledAgents={enabledAgents}>\n                                <SalesAgentWrapper enabledAgents={enabledAgents}>\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":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAuBA,MAAM,gBAAgB,cAAoB,KAAK;AAgC/C,MAAMA,sBAAmD,EAAE,UAAU,oBAAoB;AACvF,KAAI,CAAC,cAAc,SAAS,YAAY,YAAY,CAClD,QAAO;AAET,QAAO,oBAAC,kBAAgB,WAA0B;;AAGpD,MAAMC,qBAAkD,EAAE,UAAU,oBAAoB;AACtF,KAAI,CAAC,cAAc,SAAS,YAAY,WAAW,CACjD,QAAO;AAET,QACE,oBAAC,2CACC,oBAAC,sBAAoB,WAA8B,GACrB;;AAIpC,MAAaC,kBAAiD,EAC5D,UACA,cAAc,OACd,eACA,qBAAqB,0BACrB,oBAAoB,yBACpB,kBAAkB,uBAClB,iCAAiC,OACjC,kBAAkB,OAClB,GAAG,aACC;CACJ,MAAM,SAAS;CACf,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;GAC1B;GACG;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,kCACC,oBAAC,kCACC,oBAAC;KAA+C;eAC9C,oBAAC,kCACC,oBAAC;MAAkB,0BAA0B;gBAC3C,oBAAC;OAA0B;iBACzB,oBAAC,8BACC,oBAAC,kCACC,oBAAC,8BACC,oBAAC,+BACC,oBAAC;QAAkC;kBACjC,oBAAC;SAAiC;SAC/B;UACiB;SACD,GACH,GACH,GACE,GACN;QACN;OACG,GACC;MACI,GACR,GACF;KACP;IACG;GACA"}
|
|
112
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"enviveContext.js","names":["SearchAgentWrapper: React.FC<AgentWrapperProps>","SalesAgentWrapper: React.FC<AgentWrapperProps>","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 { AmplitudeProvider } from '../amplitudeContext';\nimport { EnviveConfigProvider } from '../enviveConfigContext';\nimport { EnviveCssProvider } from '../enviveCssContext';\nimport { FeatureFlagService, FeatureFlagServiceProvider } from '../featureFlagServiceContext';\nimport { GraphQlConfigValues, GraphQLProvider } 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 } from '../hardcopyContext';\nimport { WidgetConfigProvider } from '../widgetConfigContext';\nimport { PageProvider } from '../pageContext';\nimport { UiConfigProvider } from '../uiConfigContext';\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  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  previewMode?: boolean;\n  overrideConfig?: GraphQlConfigValues;\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\nconst SalesAgentWrapper: React.FC<AgentWrapperProps> = ({ children, enabledAgents }) => {\n  if (!enabledAgents.includes(EnviveAgent.SalesAgent)) {\n    return children;\n  }\n  return (\n    <SystemSettingsContextProvider>\n      <SalesAgentProvider>{children}</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  mockV3ConfigToDeprecatedConfig = false,\n  requestV3Config = false,\n  ...config\n}) => {\n  const userId = 'spiffy-user-id-0b64d781-e1c2-4b6d-9cf5-32b4f7c1e3f2'; // TODO: How should this be derived?\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: 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>\n                  <AmplitudeProvider externalAmplitudeService={inputAmplitudeService}>\n                    <PageProvider previewMode={previewMode}>\n                      <UiConfigProvider>\n                        <WidgetConfigProvider>\n                          <HardcopyProvider>\n                            <EnviveCssProvider>\n                              <SearchAgentWrapper enabledAgents={enabledAgents}>\n                                <SalesAgentWrapper enabledAgents={enabledAgents}>\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":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAuBA,MAAM,gBAAgB,cAAoB,KAAK;AAiC/C,MAAMA,sBAAmD,EAAE,UAAU,oBAAoB;AACvF,KAAI,CAAC,cAAc,SAAS,YAAY,YAAY,CAClD,QAAO;AAET,QAAO,oBAAC,kBAAgB,WAA0B;;AAGpD,MAAMC,qBAAkD,EAAE,UAAU,oBAAoB;AACtF,KAAI,CAAC,cAAc,SAAS,YAAY,WAAW,CACjD,QAAO;AAET,QACE,oBAAC,2CACC,oBAAC,sBAAoB,WAA8B,GACrB;;AAIpC,MAAaC,kBAAiD,EAC5D,UACA,cAAc,OACd,gBACA,eACA,qBAAqB,0BACrB,oBAAoB,yBACpB,kBAAkB,uBAClB,iCAAiC,OACjC,kBAAkB,OAClB,GAAG,aACC;CACJ,MAAM,SAAS;CACf,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;GAC1B;GACG;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,kCACC,oBAAC;OAAkB,0BAA0B;iBAC3C,oBAAC;QAA0B;kBACzB,oBAAC,8BACC,oBAAC,kCACC,oBAAC,8BACC,oBAAC,+BACC,oBAAC;SAAkC;mBACjC,oBAAC;UAAiC;UAC/B;WACiB;UACD,GACH,GACH,GACE,GACN;SACN;QACG,GACC;OACI,GACR;MACF;KACP;IACG;GACA"}
|
|
@@ -5,4 +5,4 @@ declare enum EnviveAgent {
|
|
|
5
5
|
}
|
|
6
6
|
//#endregion
|
|
7
7
|
export { EnviveAgent };
|
|
8
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
8
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuZC50cyIsIm5hbWVzIjpbXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29udGV4dHMvZW52aXZlQ29udGV4dC90eXBlcy5kLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBkZWNsYXJlIGVudW0gRW52aXZlQWdlbnQge1xuICAgIFNhbGVzQWdlbnQgPSBcInNhbGVzXCIsXG4gICAgU2VhcmNoQWdlbnQgPSBcInNlYXJjaFwiXG59XG4iXSwibWFwcGluZ3MiOiI7QUFBQSxJQUFXLGNBQWMsQ0FBQyxJQUFJIn0=
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
const require_rolldown_runtime = require('../../_virtual/rolldown_runtime.cjs');
|
|
2
2
|
const require_contexts_types = require('../types.cjs');
|
|
3
3
|
const require_contexts_typesV3 = require('../typesV3.cjs');
|
|
4
|
-
const require_config_versions = require('../../types/config-versions.cjs');
|
|
5
4
|
const require_getMerchantOrgIdQuery = require('../../application/models/graphql/queries/getMerchantOrgIdQuery.cjs');
|
|
6
5
|
const require_logger = require('../../application/logging/logger.cjs');
|
|
7
6
|
const require_snakeToCamelTransformer = require('../../application/models/utils/snakeToCamelTransformer.cjs');
|
|
@@ -9,25 +8,16 @@ const require_validateGraphQLFrontendConfig = require('../../application/models/
|
|
|
9
8
|
const require_validateGraphQLOrgId = require('../../application/models/validators/validateGraphQLOrgId.cjs');
|
|
10
9
|
require('../../application/models/index.cjs');
|
|
11
10
|
const require_enviveConfig = require('../../atoms/envive/enviveConfig.cjs');
|
|
11
|
+
const require_getColorsAndFrontendQuery = require('../../application/models/graphql/queries/getColorsAndFrontendQuery.cjs');
|
|
12
|
+
const require_types = require('../../packages/components-v3/dist/FloatingButton/types/types.cjs');
|
|
13
|
+
require('../../packages/components-v3/dist/FloatingButton/index.cjs');
|
|
12
14
|
const require_mockV3Config = require('./mockV3Config.cjs');
|
|
13
15
|
let react = require("react");
|
|
14
|
-
react = require_rolldown_runtime.__toESM(react);
|
|
15
16
|
let jotai = require("jotai");
|
|
16
17
|
let react_jsx_runtime = require("react/jsx-runtime");
|
|
17
18
|
|
|
18
19
|
//#region src/contexts/graphqlContext/graphqlContext.tsx
|
|
19
20
|
const GraphQLContext = (0, react.createContext)(null);
|
|
20
|
-
const colorsAndFrontendConfigQuery = () => `
|
|
21
|
-
query ($version: String = "${require_config_versions.configVersion()}") {
|
|
22
|
-
me {
|
|
23
|
-
getProductsConfigByVersion(version: $version) {
|
|
24
|
-
frontend { values }
|
|
25
|
-
colors { values }
|
|
26
|
-
v_three_config { values }
|
|
27
|
-
}
|
|
28
|
-
}
|
|
29
|
-
}
|
|
30
|
-
`;
|
|
31
21
|
const DEFAULT_PAGE_VARIANTS = [{
|
|
32
22
|
variantId: "plp",
|
|
33
23
|
variantType: "plp",
|
|
@@ -42,10 +32,10 @@ const DEFAULT_PAGE_VARIANTS = [{
|
|
|
42
32
|
variantTests: [{ testType: require_contexts_types.PageVariantTestType.UrlResolver }]
|
|
43
33
|
}];
|
|
44
34
|
const mapPositionToCamelCase = (position) => {
|
|
45
|
-
if (position === "bottom-left") return
|
|
46
|
-
if (position === "middle-left") return
|
|
47
|
-
if (position === "middle-right") return
|
|
48
|
-
if (position === "bottom-right") return
|
|
35
|
+
if (position === "bottom-left") return require_types.FloatingButtonLocation.BOTTOM_LEFT;
|
|
36
|
+
if (position === "middle-left") return require_types.FloatingButtonLocation.MIDDLE_LEFT;
|
|
37
|
+
if (position === "middle-right") return require_types.FloatingButtonLocation.MIDDLE_RIGHT;
|
|
38
|
+
if (position === "bottom-right") return require_types.FloatingButtonLocation.BOTTOM_RIGHT;
|
|
49
39
|
throw new Error(`Invalid position: ${position}`);
|
|
50
40
|
};
|
|
51
41
|
/**
|
|
@@ -135,7 +125,7 @@ const GraphQLProvider = ({ children, requestV3Config = false, mockV3ConfigToDepr
|
|
|
135
125
|
}, [executeQuery]);
|
|
136
126
|
const getV3Config = (0, react.useCallback)(async () => {
|
|
137
127
|
try {
|
|
138
|
-
const query = await
|
|
128
|
+
const query = await require_getColorsAndFrontendQuery.getColorsAndFrontendQuery();
|
|
139
129
|
if (!query) throw new Error("Colors and frontend config query is not defined");
|
|
140
130
|
const v3RootConfig = (await executeQuery(query)).me.getProductsConfigByVersion?.v_three_config?.values;
|
|
141
131
|
const v3FrontendConfig = v3FrontendConfigCleanup(require_snakeToCamelTransformer.transformSnakeToCamel(v3RootConfig));
|
|
@@ -150,10 +140,31 @@ const GraphQLProvider = ({ children, requestV3Config = false, mockV3ConfigToDepr
|
|
|
150
140
|
}]));
|
|
151
141
|
const v3pageVariants = Array.isArray(v3RootConfig?.page_variants) ? v3RootConfig?.page_variants.map(require_validateGraphQLFrontendConfig.validateAndTransformPageVariants) : DEFAULT_PAGE_VARIANTS;
|
|
152
142
|
const v3ColorsConfig = require_snakeToCamelTransformer.transformSnakeToCamel(v3RootConfig?.colors?.values);
|
|
153
|
-
if (!v3RootConfig && mockV3ConfigToDeprecatedConfig)
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
143
|
+
if (!v3RootConfig && mockV3ConfigToDeprecatedConfig) {
|
|
144
|
+
const isSemanticColors = !window.location.href.includes("globals=merchant");
|
|
145
|
+
require_logger.default.logInfo("GraphQLContext | Returning mock v3 config", {
|
|
146
|
+
colorsConfig: require_mockV3Config.mockV3ColorsConfig,
|
|
147
|
+
frontendConfig: require_mockV3Config.mockV3FrontendConfig
|
|
148
|
+
});
|
|
149
|
+
return {
|
|
150
|
+
colorsConfig: isSemanticColors ? require_mockV3Config.mockV3ColorsConfig : v3ColorsConfig,
|
|
151
|
+
frontendConfig: require_mockV3Config.mockV3FrontendConfig,
|
|
152
|
+
orgPageConfig: {
|
|
153
|
+
pageVariants: [],
|
|
154
|
+
widgetConfigs: {},
|
|
155
|
+
mountingConfigs: {}
|
|
156
|
+
}
|
|
157
|
+
};
|
|
158
|
+
}
|
|
159
|
+
require_logger.default.logInfo("GraphQLContext | Returning v3 config", {
|
|
160
|
+
colorsConfig: v3ColorsConfig,
|
|
161
|
+
frontendConfig: v3FrontendConfig,
|
|
162
|
+
orgPageConfig: {
|
|
163
|
+
pageVariants: v3pageVariants,
|
|
164
|
+
widgetConfigs: v3WidgetConfigs,
|
|
165
|
+
mountingConfigs: v3MountingConfigs
|
|
166
|
+
}
|
|
167
|
+
});
|
|
157
168
|
return {
|
|
158
169
|
colorsConfig: v3ColorsConfig,
|
|
159
170
|
frontendConfig: {
|
|
@@ -176,7 +187,7 @@ const GraphQLProvider = ({ children, requestV3Config = false, mockV3ConfigToDepr
|
|
|
176
187
|
}, [executeQuery, mockV3ConfigToDeprecatedConfig]);
|
|
177
188
|
const getColorsAndFrontendConfig = (0, react.useCallback)(async () => {
|
|
178
189
|
try {
|
|
179
|
-
const query = await
|
|
190
|
+
const query = await require_getColorsAndFrontendQuery.getColorsAndFrontendQuery();
|
|
180
191
|
if (!query) throw new Error("Colors and frontend config query is not defined");
|
|
181
192
|
const response = await executeQuery(query);
|
|
182
193
|
if (response.me.getProductsConfigByVersion?.version !== require_contexts_typesV3.ConfigVersionEnum.V3 && !mockV3ConfigToDeprecatedConfig) {
|
|
@@ -202,8 +213,11 @@ const GraphQLProvider = ({ children, requestV3Config = false, mockV3ConfigToDepr
|
|
|
202
213
|
}
|
|
203
214
|
}, [executeQuery]);
|
|
204
215
|
const getConfig = (0, react.useCallback)(async () => {
|
|
205
|
-
|
|
206
|
-
|
|
216
|
+
if (requestV3Config) {
|
|
217
|
+
require_logger.default.logInfo("GraphQLContext | Getting v3 config", requestV3Config);
|
|
218
|
+
return getV3Config();
|
|
219
|
+
}
|
|
220
|
+
require_logger.default.logInfo("GraphQLContext | Getting colors and frontend config", requestV3Config);
|
|
207
221
|
return getColorsAndFrontendConfig();
|
|
208
222
|
}, [
|
|
209
223
|
getColorsAndFrontendConfig,
|
|
@@ -239,4 +253,4 @@ const useGraphQLClient = () => {
|
|
|
239
253
|
//#endregion
|
|
240
254
|
exports.GraphQLProvider = GraphQLProvider;
|
|
241
255
|
exports.useGraphQLClient = useGraphQLClient;
|
|
242
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"graphqlContext.cjs","names":["configVersion","DEFAULT_PAGE_VARIANTS: PageVariantConfig[]","PageVariantTestType","orgLevelApiKeyAtom","baseUrlAtom","validateGraphQLOrgId","getMerchantOrgIdQuery","transformSnakeToCamel","validateAndTransformMountingConfig","v3pageVariants: PageVariantConfig[]","validateAndTransformPageVariants","mockV3ColorsConfig","mockV3FrontendConfig","ConfigVersionEnum"],"sources":["../../../src/contexts/graphqlContext/graphqlContext.tsx"],"sourcesContent":["import React, { 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 {\n  GetMerchantColorsQueryData,\n  GetMerchantFrontendConfigQueryData,\n} from 'src/application/models/graphql';\nimport { ColorMapping } from 'src/application/models/colorsConfig';\nimport { FrontendConfig } from 'src/application/models/frontendConfig';\nimport Logger from 'src/application/logging/logger';\nimport { configVersion } from 'src/types/config-versions';\nimport {\n  CamelCasedPropertiesDeep,\n  transformSnakeToCamel,\n  validateAndTransformMountingConfig,\n  validateAndTransformPageVariants,\n} from 'src/application/models';\nimport { FrontendConfigV3 } from 'src/application/models/frontendConfigV3';\nimport { ColorMappingV3 } from 'src/application/models/colorsConfigV3';\nimport { mockV3ColorsConfig, mockV3FrontendConfig } from './mockV3Config';\nimport { ConfigVersionEnum, Position, WidgetConfigV3 } from '../typesV3';\nimport {\n  OrgPageConfig,\n  PageVariantConfig,\n  PageVariantTestType,\n  WidgetMountingConfig,\n} from '../types';\n\ninterface BaseMeConfigQueryResponse {\n  me: {\n    org?: {\n      id: string;\n    };\n    getProductsConfigByVersion?: {\n      frontend?: {\n        values: CamelCasedPropertiesDeep<GetMerchantFrontendConfigQueryData>;\n      };\n      colors?: { values: CamelCasedPropertiesDeep<GetMerchantColorsQueryData> };\n    };\n  };\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 colorsAndFrontendConfigQuery = () => `\n  query ($version: String = \"${configVersion()}\") {\n    me {\n      getProductsConfigByVersion(version: $version) {\n        frontend { values }\n        colors { values }\n        v_three_config { values }\n      }\n    }\n  }\n`;\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): Position => {\n  if (position === 'bottom-left') {\n    return 'bottomLeft';\n  }\n  if (position === 'middle-left') {\n    return 'middleLeft';\n  }\n  if (position === 'middle-right') {\n    return 'middleRight';\n  }\n  if (position === 'bottom-right') {\n    return 'bottomRight';\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 colorsAndFrontendConfigQuery();\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\n      const v3FrontendConfig = v3FrontendConfigCleanup(\n        transformSnakeToCamel(v3RootConfig) as FrontendConfigV3Response,\n      );\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\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) {\n        const isSemanticColors = !window.location.href.includes('globals=merchant');\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        };\n      }\n\n      return {\n        colorsConfig: v3ColorsConfig as ColorsConfigV3Response,\n        frontendConfig: {\n          ...(v3FrontendConfig as FrontendConfigV3Response),\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 colorsAndFrontendConfigQuery();\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    console.log('GraphQLProvider: getConfig: requestV3Config', requestV3Config);\n    if (requestV3Config) {\n      return getV3Config();\n    }\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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"}
|
|
256
|
+
//# 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\n      const v3FrontendConfig = v3FrontendConfigCleanup(\n        transformSnakeToCamel(v3RootConfig) as FrontendConfigV3Response,\n      );\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      // 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) {\n        const isSemanticColors = !window.location.href.includes('globals=merchant');\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          // 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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"}
|