@envive-ai/react-hooks 0.2.6-alpha-8 → 0.2.6-alpha-9

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.
Files changed (111) hide show
  1. package/dist/{AmplitudeOperations-jbYI0Gt9.js → AmplitudeOperations-D2r56Ptr.js} +2 -2
  2. package/dist/{AmplitudeOperations-DgBejCXT.cjs → AmplitudeOperations-SkndCrhj.cjs} +2 -2
  3. package/dist/{NewOrgConfig-CUQGpmw9.js → NewOrgConfig-C9aQqGsb.js} +2 -2
  4. package/dist/{NewOrgConfig-DD0oloeK.cjs → NewOrgConfig-CHkHRqHx.cjs} +2 -2
  5. package/dist/{TrackComponentVisibleEvent-BTDRmqYu.js → TrackComponentVisibleEvent-BIGvzk4f.js} +2 -2
  6. package/dist/{TrackComponentVisibleEvent-BmM2CED5.cjs → TrackComponentVisibleEvent-DjZUt7LR.cjs} +2 -2
  7. package/dist/amplitudeContext-B3DsV6IO.cjs +248 -0
  8. package/dist/amplitudeContext-S3JYCxr4.js +232 -0
  9. package/dist/{amplitudeTrackEventAtom-DXnFiWnV.js → amplitudeTrackEventAtom-D66l5oFp.js} +1 -1
  10. package/dist/{amplitudeTrackEventAtom-UVBKhOuI.cjs → amplitudeTrackEventAtom-f22P2U0u.cjs} +1 -1
  11. package/dist/application/utils/index.d.ts +2 -2
  12. package/dist/atoms/app/index.d.cts +7 -7
  13. package/dist/atoms/app/index.d.ts +6 -6
  14. package/dist/atoms/chat/index.cjs +3 -3
  15. package/dist/atoms/chat/index.d.cts +27 -27
  16. package/dist/atoms/chat/index.d.ts +32 -32
  17. package/dist/atoms/chat/index.js +3 -3
  18. package/dist/atoms/globalSearch/index.cjs +1 -1
  19. package/dist/atoms/globalSearch/index.d.cts +5 -5
  20. package/dist/atoms/globalSearch/index.d.ts +5 -5
  21. package/dist/atoms/globalSearch/index.js +1 -1
  22. package/dist/atoms/org/index.d.cts +15 -15
  23. package/dist/atoms/search/index.cjs +3 -3
  24. package/dist/atoms/search/index.d.ts +14 -14
  25. package/dist/atoms/search/index.js +3 -3
  26. package/dist/atoms/search/utils.cjs +1 -1
  27. package/dist/atoms/search/utils.d.cts +1 -1
  28. package/dist/atoms/search/utils.d.ts +1 -1
  29. package/dist/atoms/search/utils.js +1 -1
  30. package/dist/cdnContext-i5iYA8ig.cjs +53 -0
  31. package/dist/cdnContext-td-gAam0.js +38 -0
  32. package/dist/{chat-WdMVMjQh.js → chat-ZaY3KY-R.js} +3 -3
  33. package/dist/{chat-CgF81Y5r.cjs → chat-rhEjVfrd.cjs} +3 -3
  34. package/dist/{chatState-DAP9YIWn.js → chatState-BbI93m6r.js} +1 -1
  35. package/dist/{chatState-B57-id1_.cjs → chatState-DlJpHAsW.cjs} +1 -1
  36. package/dist/contexts/amplitudeContext/index.cjs +3 -3
  37. package/dist/contexts/amplitudeContext/index.js +3 -3
  38. package/dist/contexts/cdnContext/index.cjs +1 -1
  39. package/dist/contexts/cdnContext/index.d.cts +1 -1
  40. package/dist/contexts/cdnContext/index.d.ts +1 -1
  41. package/dist/contexts/cdnContext/index.js +1 -1
  42. package/dist/contexts/enviveConfigContext/index.cjs +1 -1
  43. package/dist/contexts/enviveConfigContext/index.js +1 -1
  44. package/dist/contexts/enviveCssContext/index.cjs +3 -3
  45. package/dist/contexts/enviveCssContext/index.d.cts +1 -1
  46. package/dist/contexts/enviveCssContext/index.js +3 -3
  47. package/dist/contexts/featureFlagContext/index.cjs +1 -1
  48. package/dist/contexts/featureFlagContext/index.js +1 -1
  49. package/dist/contexts/featureFlagServiceContext/index.cjs +1 -1
  50. package/dist/contexts/featureFlagServiceContext/index.js +1 -1
  51. package/dist/contexts/localStorageContext/index.d.cts +1 -1
  52. package/dist/contexts/newOrgConfigContext/index.cjs +2 -2
  53. package/dist/contexts/newOrgConfigContext/index.d.cts +1 -1
  54. package/dist/contexts/newOrgConfigContext/index.js +2 -2
  55. package/dist/contexts/searchContext/index.cjs +3 -3
  56. package/dist/contexts/searchContext/index.js +3 -3
  57. package/dist/contexts/systemSettingsContext/index.d.cts +1 -1
  58. package/dist/contexts/systemSettingsContext/index.d.ts +2 -2
  59. package/dist/{enviveConfigContext-BG1ihSHO.js → enviveConfigContext-BZbGEgOW.js} +1 -1
  60. package/dist/{enviveConfigContext-Cn83IoUd.cjs → enviveConfigContext-BinpxTCy.cjs} +1 -1
  61. package/dist/exceptions/index.d.cts +1 -1
  62. package/dist/exceptions/index.d.ts +1 -1
  63. package/dist/{featureFlagServiceContext-Dr8Cw23n.js → featureFlagServiceContext-Cvp7NlpC.js} +1 -1
  64. package/dist/{featureFlagServiceContext-rxZhpdEj.cjs → featureFlagServiceContext-DHtkQAtq.cjs} +1 -1
  65. package/dist/{globalSearch-DEKvpWV-.cjs → globalSearch-Cpc8egsM.cjs} +1 -1
  66. package/dist/{globalSearch-D_nMjrlf.js → globalSearch-nmrfGLOn.js} +1 -1
  67. package/dist/hooks/AmplitudeOperations/index.cjs +4 -4
  68. package/dist/hooks/AmplitudeOperations/index.js +4 -4
  69. package/dist/hooks/AppDetails/index.d.cts +1 -1
  70. package/dist/hooks/CdnOperations/index.cjs +1 -1
  71. package/dist/hooks/CdnOperations/index.d.cts +1 -1
  72. package/dist/hooks/CdnOperations/index.js +1 -1
  73. package/dist/hooks/ChatToggle/index.cjs +6 -6
  74. package/dist/hooks/ChatToggle/index.js +6 -6
  75. package/dist/hooks/ChatToggleAnalytics/index.cjs +5 -5
  76. package/dist/hooks/ChatToggleAnalytics/index.js +5 -5
  77. package/dist/hooks/GrabAndScroll/index.d.cts +2 -2
  78. package/dist/hooks/IsSmallScreen/index.d.cts +1 -1
  79. package/dist/hooks/NewOrgConfig/index.cjs +3 -3
  80. package/dist/hooks/NewOrgConfig/index.d.ts +2 -2
  81. package/dist/hooks/NewOrgConfig/index.js +3 -3
  82. package/dist/hooks/Search/index.cjs +9 -9
  83. package/dist/hooks/Search/index.js +9 -9
  84. package/dist/hooks/SearchOperations/index.cjs +3 -3
  85. package/dist/hooks/SearchOperations/index.js +3 -3
  86. package/dist/hooks/SystemSettingsContext/index.d.cts +2 -2
  87. package/dist/hooks/SystemSettingsContext/index.d.ts +4 -4
  88. package/dist/hooks/TrackComponentVisibleEvent/index.cjs +4 -4
  89. package/dist/hooks/TrackComponentVisibleEvent/index.js +4 -4
  90. package/dist/hooks/UpdateAnalyticsProps/index.cjs +3 -3
  91. package/dist/hooks/UpdateAnalyticsProps/index.js +3 -3
  92. package/dist/index-BVZbvpx_.d.cts +1 -1
  93. package/dist/index-CMZcE7pk.d.cts +1 -1
  94. package/dist/index-CsmO1rDH.d.ts +1 -1
  95. package/dist/index-bEjLKG_Q.d.ts +1 -1
  96. package/dist/index-mv7KvWDq.d.ts +1 -1
  97. package/dist/{newOrgConfigContext-cWeJAT6E.cjs → newOrgConfigContext-Brsggue9.cjs} +2 -2
  98. package/dist/{newOrgConfigContext-BdzDnzUM.js → newOrgConfigContext-Dt_W-wlK.js} +2 -2
  99. package/dist/{search-B8HIKjWF.cjs → search-CWkDtqQV.cjs} +3 -3
  100. package/dist/{search-BFXfnniE.js → search-OWKKaQQj.js} +3 -3
  101. package/dist/{searchContext-C3qxKrms.js → searchContext-B-rEZixl.js} +3 -3
  102. package/dist/{searchContext-sVRHEtSD.cjs → searchContext-JCUBg-lA.cjs} +3 -3
  103. package/dist/{searchServiceAdapter-BpmMMb01.js → searchServiceAdapter-B0h7psvh.js} +1 -1
  104. package/dist/{searchServiceAdapter-6Mjz87ZL.cjs → searchServiceAdapter-BclWy4fE.cjs} +1 -1
  105. package/dist/{utils-C8_J5a8M.cjs → utils-CqVRbvfN.cjs} +1 -1
  106. package/dist/{utils-CkYtC91V.js → utils-DQhbbAnt.js} +1 -1
  107. package/package.json +1 -1
  108. package/dist/amplitudeContext-BeKYPEAO.cjs +0 -244
  109. package/dist/amplitudeContext-CfMnZGa7.js +0 -228
  110. package/dist/cdnContext-D-qi0lub.js +0 -38
  111. package/dist/cdnContext-DIVgBnsl.cjs +0 -53
@@ -1,244 +0,0 @@
1
- const require_chunk = require('./chunk-CUT6urMc.cjs');
2
- const require_events = require('./events-CgFGtanE.cjs');
3
- const require_dist = require('./dist-VxRI6eQv.cjs');
4
- const require_logger = require('./logger-BqHq67zN.cjs');
5
- const require_enviveConfig = require('./enviveConfig-CQ_8mT-g.cjs');
6
- const require_org = require('./org-BNs_maoW.cjs');
7
- const require_app = require('./app-DxwdFQlv.cjs');
8
- const require_localStorageContext = require('./localStorageContext-CWc5xJ6U.cjs');
9
- const require_enviveConfigContext = require('./enviveConfigContext-Cn83IoUd.cjs');
10
- const require_featureFlagServiceContext = require('./featureFlagServiceContext-rxZhpdEj.cjs');
11
- let react = require("react");
12
- react = require_chunk.__toESM(react);
13
- let jotai = require("jotai");
14
- jotai = require_chunk.__toESM(jotai);
15
- let react_jsx_runtime = require("react/jsx-runtime");
16
- react_jsx_runtime = require_chunk.__toESM(react_jsx_runtime);
17
- let __amplitude_analytics_browser = require("@amplitude/analytics-browser");
18
- __amplitude_analytics_browser = require_chunk.__toESM(__amplitude_analytics_browser);
19
-
20
- //#region src/contexts/amplitudeContext/amplitudeContext.tsx
21
- const AmplitudeContext = (0, react.createContext)(null);
22
- const AmplitudeProvider = ({ children }) => {
23
- const userId = (0, jotai.useAtomValue)(require_app.userIdAtom);
24
- const amplitudeApiKey = (0, jotai.useAtomValue)(require_enviveConfig.amplitudeApiKeyAtom);
25
- const dataResidency = (0, jotai.useAtomValue)(require_enviveConfig.dataResidencyAtom);
26
- const orgGaConfig = (0, jotai.useAtomValue)(require_org.orgAnalyticsGoogleAnalyticsConfigAtom);
27
- const env = (0, jotai.useAtomValue)(require_enviveConfig.envAtom);
28
- const contextSource = (0, jotai.useAtomValue)(require_enviveConfig.contextSourceAtom);
29
- (0, jotai.useAtomValue)(require_enviveConfig.identifyingPrefixAtom);
30
- const { getItem } = require_localStorageContext.useLocalStorage();
31
- const { publicKey, featureOverrides, variantUrlOverride, variantInfoOverride, show, orgShortName, featureGates } = require_enviveConfigContext.useEnviveConfig();
32
- const { featureFlagService } = require_featureFlagServiceContext.useFeatureFlagService();
33
- const [amplitudeClient, setAmplitudeClient] = react.default.useState(void 0);
34
- const [supplementalDefaultProps, setSupplementalDefaultProps] = react.default.useState({});
35
- const isReady = Boolean(userId && featureFlagService && amplitudeApiKey && userId);
36
- const getDefaultTrackingProps = (0, react.useCallback)(() => {
37
- const gatesProps = featureGates ? featureGates.reduce((acc, curr) => {
38
- if (curr.name && curr.value != null) return {
39
- ...acc,
40
- [`feature_gate.${curr.name}`]: curr.value
41
- };
42
- return acc;
43
- }, {}) : {};
44
- const experimentProps = {};
45
- return {
46
- ...gatesProps,
47
- ...experimentProps,
48
- ...supplementalDefaultProps,
49
- app_id: "commerce-chat-react-component",
50
- chat_id: getItem(require_dist.LocalStorageKeys.ChatId),
51
- env: env || "unknown",
52
- app_source: contextSource,
53
- "org.short_name": orgShortName,
54
- "user.id": userId,
55
- "cdp.user_id": null,
56
- "cdp.provider": null,
57
- "event.source": "web-browser",
58
- "event.type": "user-activity",
59
- "event.id": null,
60
- "event.channel": "web",
61
- "event.timestamp": null
62
- };
63
- }, [
64
- featureGates,
65
- supplementalDefaultProps,
66
- env,
67
- contextSource,
68
- orgShortName,
69
- userId
70
- ]);
71
- const eventPropsToPrefixedEventProps = (0, react.useCallback)((eventName, eventProps) => {
72
- const prefix = eventName.toLowerCase().replace(/\s+/g, "_");
73
- return Object.entries(eventProps).reduce((acc, [key, value$1]) => {
74
- acc[`${prefix}.${key}`] = value$1;
75
- return acc;
76
- }, {});
77
- }, []);
78
- const amplitudeSessionReplayInit = (0, react.useCallback)(() => {
79
- const isEnabled = Boolean(orgShortName === require_dist.OrgShortName.UniqueVintage && featureFlagService?.isClientSessionEnabled() && featureFlagService?.isFeatureGateEnabled(require_dist.FeatureGates.IsNewFeatureEnabled));
80
- const sampleRate = 1;
81
- try {
82
- require_logger.logger_default.logDebug(`[spiffy-ai] amplitude session-replay initializing isEnabled=${isEnabled} sampleRate=${sampleRate}`);
83
- if (!isEnabled) return isEnabled;
84
- return isEnabled;
85
- } catch (e) {
86
- require_logger.logger_default.logError("[spiffy-ai] Error initializing amplitude session-replay", e);
87
- return false;
88
- }
89
- }, [orgShortName, featureFlagService]);
90
- const eventTrackingEnrichment = (0, react.useMemo)(() => {
91
- const defaultProps = getDefaultTrackingProps();
92
- return {
93
- name: "page-view-tracking-enrichment",
94
- type: "enrichment",
95
- setup: async () => void 0,
96
- execute: async (event) => {
97
- let enrichedEvent;
98
- if (["[Amplitude] Page Viewed", `[Spiffy] ${require_dist.SpiffyMetricsEventName.BundleLoaded}`].includes(event.event_type)) {
99
- const globalProperties = {};
100
- if (publicKey) globalProperties["globalProperties.publicKey"] = publicKey;
101
- if (featureOverrides) Object.entries(featureOverrides).forEach(([key, value$1]) => {
102
- globalProperties[`globalProperties.featureOverrides.${key}`] = String(value$1);
103
- });
104
- if (variantUrlOverride) globalProperties["globalProperties.variantUrlOverride"] = variantUrlOverride;
105
- if (variantInfoOverride) globalProperties["globalProperties.variantInfoOverride"] = JSON.stringify(variantInfoOverride);
106
- if (show != null) globalProperties["globalProperties.show"] = String(show);
107
- const enabledFeatures = featureFlagService.getFeatureFlags();
108
- const enabledFeaturesProperties = Object.entries(enabledFeatures).reduce((acc, [key, value$1]) => ({
109
- ...acc,
110
- [`enabledFeatures.${key}`]: `${value$1}`
111
- }), {});
112
- const timingProperties = { "timing.enriched_at_ms": window.performance?.now() };
113
- enrichedEvent = {
114
- ...event,
115
- event_properties: {
116
- ...event.event_properties,
117
- ...defaultProps,
118
- ...globalProperties,
119
- ...enabledFeaturesProperties,
120
- ...timingProperties
121
- }
122
- };
123
- } else enrichedEvent = event;
124
- require_events.EventsDispatcher.dispatch(require_dist.SpiffyEvent.AMPLITUDE_EVENT, enrichedEvent);
125
- return enrichedEvent;
126
- }
127
- };
128
- }, [
129
- getDefaultTrackingProps,
130
- featureFlagService,
131
- publicKey,
132
- featureOverrides,
133
- variantUrlOverride,
134
- variantInfoOverride,
135
- show
136
- ]);
137
- (0, react.useEffect)(() => {
138
- if (isReady && !amplitudeClient) {
139
- const currentAmplitudeInstance = (0, __amplitude_analytics_browser.createInstance)();
140
- const isSessionsEnabled = amplitudeSessionReplayInit();
141
- currentAmplitudeInstance.add(eventTrackingEnrichment);
142
- currentAmplitudeInstance.init(amplitudeApiKey, userId, {
143
- serverZone: dataResidency,
144
- trackingOptions: { ipAddress: true },
145
- autocapture: {
146
- attribution: true,
147
- pageViews: { trackHistoryChanges: "pathOnly" },
148
- sessions: isSessionsEnabled,
149
- formInteractions: false,
150
- fileDownloads: false
151
- }
152
- });
153
- setAmplitudeClient(currentAmplitudeInstance);
154
- }
155
- }, [
156
- isReady,
157
- amplitudeClient,
158
- amplitudeApiKey,
159
- userId,
160
- dataResidency,
161
- amplitudeSessionReplayInit,
162
- eventTrackingEnrichment
163
- ]);
164
- const trackEvent = (0, react.useCallback)(async ({ eventName, eventProps, eventGroups, alsoSendToGoogleAnalytics = false }) => {
165
- require_logger.logger_default.logDebug("Submitting event", eventName);
166
- try {
167
- const decoratedEventName = `[Spiffy] ${eventName}`;
168
- if (!amplitudeClient) {
169
- require_logger.logger_default.logWarn("amplitude client undefined", void 0, { event_name: decoratedEventName });
170
- return;
171
- }
172
- const eventData = JSON.stringify({
173
- eventName,
174
- eventProps,
175
- created_at: (/* @__PURE__ */ new Date()).toISOString()
176
- });
177
- const data = new TextEncoder().encode(eventData);
178
- const hashBuffer = await crypto.subtle.digest("SHA-256", data);
179
- const currentInsertId = Array.from(new Uint8Array(hashBuffer)).map((b) => b.toString(16).padStart(2, "0")).join("");
180
- require_logger.logger_default.logDebug(`amplitude tracking ${decoratedEventName}`, null, {
181
- event_name: decoratedEventName,
182
- props: eventProps
183
- });
184
- amplitudeClient.track(decoratedEventName, {
185
- ...getDefaultTrackingProps(),
186
- ...eventProps,
187
- ...eventProps ? eventPropsToPrefixedEventProps(eventName, eventProps) : {}
188
- }, {
189
- ...eventGroups,
190
- insert_id: currentInsertId
191
- });
192
- if (alsoSendToGoogleAnalytics && orgGaConfig) {
193
- require_logger.logger_default.logDebug("[spiffy-ai] GA tracking", decoratedEventName);
194
- if (window.dataLayer) window.dataLayer.push({
195
- event: decoratedEventName,
196
- eventProps
197
- });
198
- }
199
- } catch (err) {
200
- require_logger.logger_default.logError("[spiffy-ai] Error tracking event", err, {
201
- eventName,
202
- eventProps
203
- });
204
- }
205
- }, [
206
- amplitudeClient,
207
- getDefaultTrackingProps,
208
- eventPropsToPrefixedEventProps,
209
- orgGaConfig
210
- ]);
211
- const value = (0, react.useMemo)(() => ({
212
- trackEvent,
213
- isReady,
214
- setSupplementalDefaultProps: (props) => setSupplementalDefaultProps(props)
215
- }), [
216
- trackEvent,
217
- isReady,
218
- setSupplementalDefaultProps
219
- ]);
220
- return /* @__PURE__ */ (0, react_jsx_runtime.jsx)(AmplitudeContext.Provider, {
221
- value,
222
- children
223
- });
224
- };
225
- const useAmplitude = () => {
226
- const context = (0, react.useContext)(AmplitudeContext);
227
- if (!context) throw new Error("useAmplitude must be used within AmplitudeProvider");
228
- return context;
229
- };
230
-
231
- //#endregion
232
- Object.defineProperty(exports, 'AmplitudeProvider', {
233
- enumerable: true,
234
- get: function () {
235
- return AmplitudeProvider;
236
- }
237
- });
238
- Object.defineProperty(exports, 'useAmplitude', {
239
- enumerable: true,
240
- get: function () {
241
- return useAmplitude;
242
- }
243
- });
244
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"amplitudeContext-BeKYPEAO.cjs","names":["AmplitudeProvider: React.FC<{ children: React.ReactNode }>","userIdAtom","amplitudeApiKeyAtom","dataResidencyAtom","orgAnalyticsGoogleAnalyticsConfigAtom","envAtom","contextSourceAtom","identifyingPrefixAtom","useLocalStorage","useEnviveConfig","useFeatureFlagService","React","LocalStorageKeys","value","OrgShortName","FeatureGates","enrichedEvent: Event","SpiffyMetricsEventName","globalProperties: Record<string, string>","SpiffyEvent","currentAmplitudeInstance: BrowserClient"],"sources":["../src/contexts/amplitudeContext/amplitudeContext.tsx"],"sourcesContent":["import React, {\n  createContext,\n  useContext,\n  useCallback,\n  useMemo,\n  useEffect,\n} from \"react\";\nimport { useAtomValue } from \"jotai\";\nimport { createInstance } from \"@amplitude/analytics-browser\";\nimport {\n  FeatureGates,\n  OrgShortName,\n  LocalStorageKeys,\n  SpiffyEvent,\n  AmplitudeContextType,\n  SpiffyMetricsEventName,\n  TrackEventParams,\n} from \"@envive-ai/types\";\nimport {\n  amplitudeApiKeyAtom,\n  contextSourceAtom,\n  dataResidencyAtom,\n  identifyingPrefixAtom,\n} from \"src/atoms/envive/enviveConfig\";\nimport { useLocalStorage } from \"src/contexts/localStorageContext\";\nimport { orgAnalyticsGoogleAnalyticsConfigAtom } from \"src/atoms/org/orgAnalyticsConfig\";\nimport { userIdAtom } from \"src/atoms/app\";\nimport { envAtom } from \"src/atoms/envive/enviveConfig\";\nimport Logger from \"src/application/logging/logger\";\nimport type {\n  BrowserClient,\n  EnrichmentPlugin,\n  Event,\n  ServerZoneType,\n} from \"@amplitude/analytics-types\";\nimport { useEnviveConfig } from \"src/contexts/enviveConfigContext/enviveConfigContext\";\nimport { useFeatureFlagService } from \"src/contexts/featureFlagServiceContext/featureFlagServiceContext\";\nimport { EventsDispatcher } from \"src/events\";\n\nconst AmplitudeContext = createContext<AmplitudeContextType | null>(null);\n\nexport const AmplitudeProvider: React.FC<{ children: React.ReactNode }> = ({\n  children,\n}) => {\n  const userId = useAtomValue(userIdAtom);\n  const amplitudeApiKey = useAtomValue(amplitudeApiKeyAtom);\n  const dataResidency = useAtomValue(dataResidencyAtom);\n  const orgGaConfig = useAtomValue(orgAnalyticsGoogleAnalyticsConfigAtom);\n  const env = useAtomValue(envAtom);\n  const contextSource = useAtomValue(contextSourceAtom);\n  const identifyingPrefix = useAtomValue(identifyingPrefixAtom);\n  const { getItem } = useLocalStorage();\n  const {\n    publicKey,\n    featureOverrides,\n    variantUrlOverride,\n    variantInfoOverride,\n    show,\n    orgShortName,\n    featureGates,\n  } = useEnviveConfig();\n\n  const { featureFlagService } = useFeatureFlagService();\n\n  const [amplitudeClient, setAmplitudeClient] = React.useState<\n    BrowserClient | undefined\n  >(undefined);\n  const [supplementalDefaultProps, setSupplementalDefaultProps] =\n    React.useState<Record<string, unknown>>({});\n\n  const isReady = Boolean(\n    userId && featureFlagService && amplitudeApiKey && userId\n  );\n\n  const getDefaultTrackingProps = useCallback((): Record<string, unknown> => {\n    const gatesProps = featureGates\n      ? featureGates.reduce<Record<string, boolean>>((acc, curr) => {\n          if (curr.name && curr.value != null) {\n            return { ...acc, [`feature_gate.${curr.name}`]: curr.value };\n          }\n          return acc;\n        }, {})\n      : {};\n    const experimentProps = {}; // No direct equivalent for experiments in EnviveConfig yet\n\n    const orgLevelAmplitudeTrackingProps = {\n      ...gatesProps,\n      ...experimentProps,\n    };\n\n    return {\n      ...orgLevelAmplitudeTrackingProps,\n      ...supplementalDefaultProps,\n      // TODO: org_id is not directly available in EnviveConfig. Need to find a new source or derive it.\n      // org_id: orgConfig?.org?.org?.id,\n      app_id: \"commerce-chat-react-component\",\n      chat_id: getItem(LocalStorageKeys.ChatId),\n      env: env || \"unknown\",\n      app_source: contextSource,\n      \"org.short_name\": orgShortName,\n      \"user.id\": userId,\n      \"cdp.user_id\": null,\n      \"cdp.provider\": null,\n      \"event.source\": \"web-browser\",\n      \"event.type\": \"user-activity\",\n      \"event.id\": null,\n      \"event.channel\": \"web\",\n      \"event.timestamp\": null,\n    };\n  }, [\n    featureGates,\n    supplementalDefaultProps,\n    env,\n    contextSource,\n    orgShortName,\n    userId,\n  ]);\n\n  const eventPropsToPrefixedEventProps = useCallback(\n    (\n      eventName: SpiffyMetricsEventName,\n      eventProps: Record<string, unknown>\n    ): Record<string, unknown> => {\n      const prefix = eventName.toLowerCase().replace(/\\s+/g, \"_\");\n      return Object.entries(eventProps).reduce((acc, [key, value]) => {\n        acc[`${prefix}.${key}`] = value;\n        return acc;\n      }, {} as Record<string, unknown>);\n    },\n    []\n  );\n\n  const amplitudeSessionReplayInit = useCallback((): boolean => {\n    const isEnabled = Boolean(\n      orgShortName === OrgShortName.UniqueVintage &&\n        featureFlagService?.isClientSessionEnabled() &&\n        featureFlagService?.isFeatureGateEnabled(\n          FeatureGates.IsNewFeatureEnabled\n        )\n    );\n    const sampleRate = 1;\n\n    try {\n      Logger.logDebug(\n        `[spiffy-ai] amplitude session-replay initializing isEnabled=${isEnabled} sampleRate=${sampleRate}`\n      );\n\n      if (!isEnabled) {\n        return isEnabled;\n      }\n\n      // amplitudeInstance.add(sessionReplayPlugin({ sampleRate }));\n\n      return isEnabled;\n    } catch (e) {\n      Logger.logError(\n        \"[spiffy-ai] Error initializing amplitude session-replay\",\n        e\n      );\n      return false;\n    }\n  }, [orgShortName, featureFlagService]);\n\n  const eventTrackingEnrichment = useMemo((): EnrichmentPlugin => {\n    // Compute default props outside the execute function to avoid calling hooks inside useMemo's callback\n    const defaultProps = getDefaultTrackingProps();\n\n    const enrichment: EnrichmentPlugin = {\n      name: \"page-view-tracking-enrichment\",\n      type: \"enrichment\",\n      setup: async () => undefined,\n      execute: async (event: Event): Promise<Event> => {\n        let enrichedEvent: Event;\n\n        const eventsToEnrich = [\n          \"[Amplitude] Page Viewed\",\n          `[Spiffy] ${SpiffyMetricsEventName.BundleLoaded}`,\n        ];\n\n        if (eventsToEnrich.includes(event.event_type)) {\n          const globalProperties: Record<string, string> = {};\n\n          if (publicKey) {\n            globalProperties[\"globalProperties.publicKey\"] = publicKey;\n          }\n          if (featureOverrides) {\n            Object.entries(featureOverrides).forEach(([key, value]) => {\n              globalProperties[`globalProperties.featureOverrides.${key}`] =\n                String(value);\n            });\n          }\n          if (variantUrlOverride) {\n            globalProperties[\"globalProperties.variantUrlOverride\"] =\n              variantUrlOverride;\n          }\n          if (variantInfoOverride) {\n            globalProperties[\"globalProperties.variantInfoOverride\"] =\n              JSON.stringify(variantInfoOverride);\n          }\n          if (show != null) {\n            globalProperties[\"globalProperties.show\"] = String(show);\n          }\n\n          const enabledFeatures = featureFlagService!.getFeatureFlags();\n          const enabledFeaturesProperties = Object.entries(\n            enabledFeatures\n          ).reduce<Record<string, string>>(\n            (acc, [key, value]) => ({\n              ...acc,\n              [`enabledFeatures.${key}`]: `${value}`,\n            }),\n            {}\n          );\n\n          const timingProperties = {\n            \"timing.enriched_at_ms\": window.performance?.now(),\n          };\n\n          enrichedEvent = {\n            ...event,\n            event_properties: {\n              ...event.event_properties,\n              ...defaultProps, // Use the captured value instead\n              ...globalProperties,\n              ...enabledFeaturesProperties,\n              ...timingProperties,\n            },\n          };\n        } else {\n          enrichedEvent = event;\n        }\n\n        EventsDispatcher.dispatch(SpiffyEvent.AMPLITUDE_EVENT, enrichedEvent);\n\n        return enrichedEvent;\n      },\n    };\n    return enrichment;\n  }, [\n    getDefaultTrackingProps,\n    featureFlagService,\n    publicKey,\n    featureOverrides,\n    variantUrlOverride,\n    variantInfoOverride,\n    show,\n  ]);\n\n  useEffect(() => {\n    if (isReady && !amplitudeClient) {\n      const currentAmplitudeInstance: BrowserClient = createInstance();\n      const isSessionsEnabled = amplitudeSessionReplayInit();\n      currentAmplitudeInstance.add(eventTrackingEnrichment);\n      currentAmplitudeInstance.init(amplitudeApiKey!, userId!, {\n        serverZone: dataResidency as ServerZoneType,\n        trackingOptions: {\n          ipAddress: true,\n        },\n        autocapture: {\n          attribution: true,\n          pageViews: {\n            trackHistoryChanges: \"pathOnly\",\n          },\n          sessions: isSessionsEnabled,\n          formInteractions: false,\n          fileDownloads: false,\n        },\n      });\n      setAmplitudeClient(currentAmplitudeInstance);\n    }\n  }, [\n    isReady,\n    amplitudeClient,\n    amplitudeApiKey,\n    userId,\n    dataResidency,\n    amplitudeSessionReplayInit,\n    eventTrackingEnrichment,\n  ]);\n\n  const trackEvent = useCallback(\n    async ({\n      eventName,\n      eventProps,\n      eventGroups,\n      alsoSendToGoogleAnalytics = false,\n    }: TrackEventParams): Promise<void> => {\n      Logger.logDebug(\"Submitting event\", eventName);\n      try {\n        const decoratedEventName = `[Spiffy] ${eventName}`;\n\n        if (!amplitudeClient) {\n          Logger.logWarn(\"amplitude client undefined\", undefined, {\n            event_name: decoratedEventName,\n          });\n          return;\n        }\n\n        const eventData = JSON.stringify({\n          eventName,\n          eventProps,\n          created_at: new Date().toISOString(),\n        });\n        const encoder = new TextEncoder();\n        const data = encoder.encode(eventData);\n        // calculate a hash of the event properties to use as the insert_id so that duplicate events\n        // are automatically dropped by Amplitude\n        const hashBuffer = await crypto.subtle.digest(\"SHA-256\", data);\n        const hashArray = Array.from(new Uint8Array(hashBuffer));\n        const currentInsertId = hashArray\n          .map((b) => b.toString(16).padStart(2, \"0\"))\n          .join(\"\");\n\n        Logger.logDebug(`amplitude tracking ${decoratedEventName}`, null, {\n          event_name: decoratedEventName,\n          props: eventProps,\n        });\n\n        amplitudeClient.track(\n          decoratedEventName,\n          {\n            ...getDefaultTrackingProps(),\n            ...eventProps,\n            ...(eventProps\n              ? eventPropsToPrefixedEventProps(eventName, eventProps)\n              : {}),\n          },\n          {\n            ...eventGroups,\n            insert_id: currentInsertId,\n          }\n        );\n\n        if (alsoSendToGoogleAnalytics && orgGaConfig) {\n          // TODO: Add in windowDataLayerService or context alternative and hook it up here\n          Logger.logDebug(\"[spiffy-ai] GA tracking\", decoratedEventName);\n          if (window.dataLayer) {\n            (window.dataLayer as any[]).push({\n              event: decoratedEventName,\n              eventProps: eventProps,\n            });\n          }\n        }\n      } catch (err) {\n        Logger.logError(\"[spiffy-ai] Error tracking event\", err, {\n          eventName,\n          eventProps,\n        });\n      }\n    },\n    [\n      amplitudeClient,\n      getDefaultTrackingProps,\n      eventPropsToPrefixedEventProps,\n      orgGaConfig,\n    ]\n  );\n\n  const value = useMemo(\n    () => ({\n      trackEvent,\n      isReady,\n      setSupplementalDefaultProps: (props: Record<string, unknown>) =>\n        setSupplementalDefaultProps(props),\n    }),\n    [trackEvent, isReady, setSupplementalDefaultProps]\n  );\n\n  return (\n    <AmplitudeContext.Provider value={value}>\n      {children}\n    </AmplitudeContext.Provider>\n  );\n};\n\nexport const useAmplitude = () => {\n  const context = useContext(AmplitudeContext);\n  if (!context) {\n    throw new Error(\"useAmplitude must be used within AmplitudeProvider\");\n  }\n  return context;\n};\n"],"mappings":"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"}
@@ -1,228 +0,0 @@
1
- import { EventsDispatcher } from "./events-WOOrnUAx.js";
2
- import { FeatureGates, LocalStorageKeys, OrgShortName, SpiffyEvent, SpiffyMetricsEventName } from "./dist-C38adNK1.js";
3
- import { logger_default } from "./logger-BMVdhQOV.js";
4
- import { amplitudeApiKeyAtom, contextSourceAtom, dataResidencyAtom, envAtom, identifyingPrefixAtom } from "./enviveConfig-Cwlp7-Qz.js";
5
- import { orgAnalyticsGoogleAnalyticsConfigAtom } from "./org-CScQqL4k.js";
6
- import { userIdAtom } from "./app-BT3g-mDp.js";
7
- import { useLocalStorage } from "./localStorageContext-BFwvuEcf.js";
8
- import { useEnviveConfig } from "./enviveConfigContext-BG1ihSHO.js";
9
- import { useFeatureFlagService } from "./featureFlagServiceContext-Dr8Cw23n.js";
10
- import React, { createContext, useCallback, useContext, useEffect, useMemo } from "react";
11
- import { useAtomValue } from "jotai";
12
- import { jsx } from "react/jsx-runtime";
13
- import { createInstance } from "@amplitude/analytics-browser";
14
-
15
- //#region src/contexts/amplitudeContext/amplitudeContext.tsx
16
- const AmplitudeContext = createContext(null);
17
- const AmplitudeProvider = ({ children }) => {
18
- const userId = useAtomValue(userIdAtom);
19
- const amplitudeApiKey = useAtomValue(amplitudeApiKeyAtom);
20
- const dataResidency = useAtomValue(dataResidencyAtom);
21
- const orgGaConfig = useAtomValue(orgAnalyticsGoogleAnalyticsConfigAtom);
22
- const env = useAtomValue(envAtom);
23
- const contextSource = useAtomValue(contextSourceAtom);
24
- useAtomValue(identifyingPrefixAtom);
25
- const { getItem } = useLocalStorage();
26
- const { publicKey, featureOverrides, variantUrlOverride, variantInfoOverride, show, orgShortName, featureGates } = useEnviveConfig();
27
- const { featureFlagService } = useFeatureFlagService();
28
- const [amplitudeClient, setAmplitudeClient] = React.useState(void 0);
29
- const [supplementalDefaultProps, setSupplementalDefaultProps] = React.useState({});
30
- const isReady = Boolean(userId && featureFlagService && amplitudeApiKey && userId);
31
- const getDefaultTrackingProps = useCallback(() => {
32
- const gatesProps = featureGates ? featureGates.reduce((acc, curr) => {
33
- if (curr.name && curr.value != null) return {
34
- ...acc,
35
- [`feature_gate.${curr.name}`]: curr.value
36
- };
37
- return acc;
38
- }, {}) : {};
39
- const experimentProps = {};
40
- return {
41
- ...gatesProps,
42
- ...experimentProps,
43
- ...supplementalDefaultProps,
44
- app_id: "commerce-chat-react-component",
45
- chat_id: getItem(LocalStorageKeys.ChatId),
46
- env: env || "unknown",
47
- app_source: contextSource,
48
- "org.short_name": orgShortName,
49
- "user.id": userId,
50
- "cdp.user_id": null,
51
- "cdp.provider": null,
52
- "event.source": "web-browser",
53
- "event.type": "user-activity",
54
- "event.id": null,
55
- "event.channel": "web",
56
- "event.timestamp": null
57
- };
58
- }, [
59
- featureGates,
60
- supplementalDefaultProps,
61
- env,
62
- contextSource,
63
- orgShortName,
64
- userId
65
- ]);
66
- const eventPropsToPrefixedEventProps = useCallback((eventName, eventProps) => {
67
- const prefix = eventName.toLowerCase().replace(/\s+/g, "_");
68
- return Object.entries(eventProps).reduce((acc, [key, value$1]) => {
69
- acc[`${prefix}.${key}`] = value$1;
70
- return acc;
71
- }, {});
72
- }, []);
73
- const amplitudeSessionReplayInit = useCallback(() => {
74
- const isEnabled = Boolean(orgShortName === OrgShortName.UniqueVintage && featureFlagService?.isClientSessionEnabled() && featureFlagService?.isFeatureGateEnabled(FeatureGates.IsNewFeatureEnabled));
75
- const sampleRate = 1;
76
- try {
77
- logger_default.logDebug(`[spiffy-ai] amplitude session-replay initializing isEnabled=${isEnabled} sampleRate=${sampleRate}`);
78
- if (!isEnabled) return isEnabled;
79
- return isEnabled;
80
- } catch (e) {
81
- logger_default.logError("[spiffy-ai] Error initializing amplitude session-replay", e);
82
- return false;
83
- }
84
- }, [orgShortName, featureFlagService]);
85
- const eventTrackingEnrichment = useMemo(() => {
86
- const defaultProps = getDefaultTrackingProps();
87
- return {
88
- name: "page-view-tracking-enrichment",
89
- type: "enrichment",
90
- setup: async () => void 0,
91
- execute: async (event) => {
92
- let enrichedEvent;
93
- if (["[Amplitude] Page Viewed", `[Spiffy] ${SpiffyMetricsEventName.BundleLoaded}`].includes(event.event_type)) {
94
- const globalProperties = {};
95
- if (publicKey) globalProperties["globalProperties.publicKey"] = publicKey;
96
- if (featureOverrides) Object.entries(featureOverrides).forEach(([key, value$1]) => {
97
- globalProperties[`globalProperties.featureOverrides.${key}`] = String(value$1);
98
- });
99
- if (variantUrlOverride) globalProperties["globalProperties.variantUrlOverride"] = variantUrlOverride;
100
- if (variantInfoOverride) globalProperties["globalProperties.variantInfoOverride"] = JSON.stringify(variantInfoOverride);
101
- if (show != null) globalProperties["globalProperties.show"] = String(show);
102
- const enabledFeatures = featureFlagService.getFeatureFlags();
103
- const enabledFeaturesProperties = Object.entries(enabledFeatures).reduce((acc, [key, value$1]) => ({
104
- ...acc,
105
- [`enabledFeatures.${key}`]: `${value$1}`
106
- }), {});
107
- const timingProperties = { "timing.enriched_at_ms": window.performance?.now() };
108
- enrichedEvent = {
109
- ...event,
110
- event_properties: {
111
- ...event.event_properties,
112
- ...defaultProps,
113
- ...globalProperties,
114
- ...enabledFeaturesProperties,
115
- ...timingProperties
116
- }
117
- };
118
- } else enrichedEvent = event;
119
- EventsDispatcher.dispatch(SpiffyEvent.AMPLITUDE_EVENT, enrichedEvent);
120
- return enrichedEvent;
121
- }
122
- };
123
- }, [
124
- getDefaultTrackingProps,
125
- featureFlagService,
126
- publicKey,
127
- featureOverrides,
128
- variantUrlOverride,
129
- variantInfoOverride,
130
- show
131
- ]);
132
- useEffect(() => {
133
- if (isReady && !amplitudeClient) {
134
- const currentAmplitudeInstance = createInstance();
135
- const isSessionsEnabled = amplitudeSessionReplayInit();
136
- currentAmplitudeInstance.add(eventTrackingEnrichment);
137
- currentAmplitudeInstance.init(amplitudeApiKey, userId, {
138
- serverZone: dataResidency,
139
- trackingOptions: { ipAddress: true },
140
- autocapture: {
141
- attribution: true,
142
- pageViews: { trackHistoryChanges: "pathOnly" },
143
- sessions: isSessionsEnabled,
144
- formInteractions: false,
145
- fileDownloads: false
146
- }
147
- });
148
- setAmplitudeClient(currentAmplitudeInstance);
149
- }
150
- }, [
151
- isReady,
152
- amplitudeClient,
153
- amplitudeApiKey,
154
- userId,
155
- dataResidency,
156
- amplitudeSessionReplayInit,
157
- eventTrackingEnrichment
158
- ]);
159
- const trackEvent = useCallback(async ({ eventName, eventProps, eventGroups, alsoSendToGoogleAnalytics = false }) => {
160
- logger_default.logDebug("Submitting event", eventName);
161
- try {
162
- const decoratedEventName = `[Spiffy] ${eventName}`;
163
- if (!amplitudeClient) {
164
- logger_default.logWarn("amplitude client undefined", void 0, { event_name: decoratedEventName });
165
- return;
166
- }
167
- const eventData = JSON.stringify({
168
- eventName,
169
- eventProps,
170
- created_at: (/* @__PURE__ */ new Date()).toISOString()
171
- });
172
- const data = new TextEncoder().encode(eventData);
173
- const hashBuffer = await crypto.subtle.digest("SHA-256", data);
174
- const currentInsertId = Array.from(new Uint8Array(hashBuffer)).map((b) => b.toString(16).padStart(2, "0")).join("");
175
- logger_default.logDebug(`amplitude tracking ${decoratedEventName}`, null, {
176
- event_name: decoratedEventName,
177
- props: eventProps
178
- });
179
- amplitudeClient.track(decoratedEventName, {
180
- ...getDefaultTrackingProps(),
181
- ...eventProps,
182
- ...eventProps ? eventPropsToPrefixedEventProps(eventName, eventProps) : {}
183
- }, {
184
- ...eventGroups,
185
- insert_id: currentInsertId
186
- });
187
- if (alsoSendToGoogleAnalytics && orgGaConfig) {
188
- logger_default.logDebug("[spiffy-ai] GA tracking", decoratedEventName);
189
- if (window.dataLayer) window.dataLayer.push({
190
- event: decoratedEventName,
191
- eventProps
192
- });
193
- }
194
- } catch (err) {
195
- logger_default.logError("[spiffy-ai] Error tracking event", err, {
196
- eventName,
197
- eventProps
198
- });
199
- }
200
- }, [
201
- amplitudeClient,
202
- getDefaultTrackingProps,
203
- eventPropsToPrefixedEventProps,
204
- orgGaConfig
205
- ]);
206
- const value = useMemo(() => ({
207
- trackEvent,
208
- isReady,
209
- setSupplementalDefaultProps: (props) => setSupplementalDefaultProps(props)
210
- }), [
211
- trackEvent,
212
- isReady,
213
- setSupplementalDefaultProps
214
- ]);
215
- return /* @__PURE__ */ jsx(AmplitudeContext.Provider, {
216
- value,
217
- children
218
- });
219
- };
220
- const useAmplitude = () => {
221
- const context = useContext(AmplitudeContext);
222
- if (!context) throw new Error("useAmplitude must be used within AmplitudeProvider");
223
- return context;
224
- };
225
-
226
- //#endregion
227
- export { AmplitudeProvider, useAmplitude };
228
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"amplitudeContext-CfMnZGa7.js","names":["AmplitudeProvider: React.FC<{ children: React.ReactNode }>","value","enrichedEvent: Event","globalProperties: Record<string, string>","currentAmplitudeInstance: BrowserClient"],"sources":["../src/contexts/amplitudeContext/amplitudeContext.tsx"],"sourcesContent":["import React, {\n  createContext,\n  useContext,\n  useCallback,\n  useMemo,\n  useEffect,\n} from \"react\";\nimport { useAtomValue } from \"jotai\";\nimport { createInstance } from \"@amplitude/analytics-browser\";\nimport {\n  FeatureGates,\n  OrgShortName,\n  LocalStorageKeys,\n  SpiffyEvent,\n  AmplitudeContextType,\n  SpiffyMetricsEventName,\n  TrackEventParams,\n} from \"@envive-ai/types\";\nimport {\n  amplitudeApiKeyAtom,\n  contextSourceAtom,\n  dataResidencyAtom,\n  identifyingPrefixAtom,\n} from \"src/atoms/envive/enviveConfig\";\nimport { useLocalStorage } from \"src/contexts/localStorageContext\";\nimport { orgAnalyticsGoogleAnalyticsConfigAtom } from \"src/atoms/org/orgAnalyticsConfig\";\nimport { userIdAtom } from \"src/atoms/app\";\nimport { envAtom } from \"src/atoms/envive/enviveConfig\";\nimport Logger from \"src/application/logging/logger\";\nimport type {\n  BrowserClient,\n  EnrichmentPlugin,\n  Event,\n  ServerZoneType,\n} from \"@amplitude/analytics-types\";\nimport { useEnviveConfig } from \"src/contexts/enviveConfigContext/enviveConfigContext\";\nimport { useFeatureFlagService } from \"src/contexts/featureFlagServiceContext/featureFlagServiceContext\";\nimport { EventsDispatcher } from \"src/events\";\n\nconst AmplitudeContext = createContext<AmplitudeContextType | null>(null);\n\nexport const AmplitudeProvider: React.FC<{ children: React.ReactNode }> = ({\n  children,\n}) => {\n  const userId = useAtomValue(userIdAtom);\n  const amplitudeApiKey = useAtomValue(amplitudeApiKeyAtom);\n  const dataResidency = useAtomValue(dataResidencyAtom);\n  const orgGaConfig = useAtomValue(orgAnalyticsGoogleAnalyticsConfigAtom);\n  const env = useAtomValue(envAtom);\n  const contextSource = useAtomValue(contextSourceAtom);\n  const identifyingPrefix = useAtomValue(identifyingPrefixAtom);\n  const { getItem } = useLocalStorage();\n  const {\n    publicKey,\n    featureOverrides,\n    variantUrlOverride,\n    variantInfoOverride,\n    show,\n    orgShortName,\n    featureGates,\n  } = useEnviveConfig();\n\n  const { featureFlagService } = useFeatureFlagService();\n\n  const [amplitudeClient, setAmplitudeClient] = React.useState<\n    BrowserClient | undefined\n  >(undefined);\n  const [supplementalDefaultProps, setSupplementalDefaultProps] =\n    React.useState<Record<string, unknown>>({});\n\n  const isReady = Boolean(\n    userId && featureFlagService && amplitudeApiKey && userId\n  );\n\n  const getDefaultTrackingProps = useCallback((): Record<string, unknown> => {\n    const gatesProps = featureGates\n      ? featureGates.reduce<Record<string, boolean>>((acc, curr) => {\n          if (curr.name && curr.value != null) {\n            return { ...acc, [`feature_gate.${curr.name}`]: curr.value };\n          }\n          return acc;\n        }, {})\n      : {};\n    const experimentProps = {}; // No direct equivalent for experiments in EnviveConfig yet\n\n    const orgLevelAmplitudeTrackingProps = {\n      ...gatesProps,\n      ...experimentProps,\n    };\n\n    return {\n      ...orgLevelAmplitudeTrackingProps,\n      ...supplementalDefaultProps,\n      // TODO: org_id is not directly available in EnviveConfig. Need to find a new source or derive it.\n      // org_id: orgConfig?.org?.org?.id,\n      app_id: \"commerce-chat-react-component\",\n      chat_id: getItem(LocalStorageKeys.ChatId),\n      env: env || \"unknown\",\n      app_source: contextSource,\n      \"org.short_name\": orgShortName,\n      \"user.id\": userId,\n      \"cdp.user_id\": null,\n      \"cdp.provider\": null,\n      \"event.source\": \"web-browser\",\n      \"event.type\": \"user-activity\",\n      \"event.id\": null,\n      \"event.channel\": \"web\",\n      \"event.timestamp\": null,\n    };\n  }, [\n    featureGates,\n    supplementalDefaultProps,\n    env,\n    contextSource,\n    orgShortName,\n    userId,\n  ]);\n\n  const eventPropsToPrefixedEventProps = useCallback(\n    (\n      eventName: SpiffyMetricsEventName,\n      eventProps: Record<string, unknown>\n    ): Record<string, unknown> => {\n      const prefix = eventName.toLowerCase().replace(/\\s+/g, \"_\");\n      return Object.entries(eventProps).reduce((acc, [key, value]) => {\n        acc[`${prefix}.${key}`] = value;\n        return acc;\n      }, {} as Record<string, unknown>);\n    },\n    []\n  );\n\n  const amplitudeSessionReplayInit = useCallback((): boolean => {\n    const isEnabled = Boolean(\n      orgShortName === OrgShortName.UniqueVintage &&\n        featureFlagService?.isClientSessionEnabled() &&\n        featureFlagService?.isFeatureGateEnabled(\n          FeatureGates.IsNewFeatureEnabled\n        )\n    );\n    const sampleRate = 1;\n\n    try {\n      Logger.logDebug(\n        `[spiffy-ai] amplitude session-replay initializing isEnabled=${isEnabled} sampleRate=${sampleRate}`\n      );\n\n      if (!isEnabled) {\n        return isEnabled;\n      }\n\n      // amplitudeInstance.add(sessionReplayPlugin({ sampleRate }));\n\n      return isEnabled;\n    } catch (e) {\n      Logger.logError(\n        \"[spiffy-ai] Error initializing amplitude session-replay\",\n        e\n      );\n      return false;\n    }\n  }, [orgShortName, featureFlagService]);\n\n  const eventTrackingEnrichment = useMemo((): EnrichmentPlugin => {\n    // Compute default props outside the execute function to avoid calling hooks inside useMemo's callback\n    const defaultProps = getDefaultTrackingProps();\n\n    const enrichment: EnrichmentPlugin = {\n      name: \"page-view-tracking-enrichment\",\n      type: \"enrichment\",\n      setup: async () => undefined,\n      execute: async (event: Event): Promise<Event> => {\n        let enrichedEvent: Event;\n\n        const eventsToEnrich = [\n          \"[Amplitude] Page Viewed\",\n          `[Spiffy] ${SpiffyMetricsEventName.BundleLoaded}`,\n        ];\n\n        if (eventsToEnrich.includes(event.event_type)) {\n          const globalProperties: Record<string, string> = {};\n\n          if (publicKey) {\n            globalProperties[\"globalProperties.publicKey\"] = publicKey;\n          }\n          if (featureOverrides) {\n            Object.entries(featureOverrides).forEach(([key, value]) => {\n              globalProperties[`globalProperties.featureOverrides.${key}`] =\n                String(value);\n            });\n          }\n          if (variantUrlOverride) {\n            globalProperties[\"globalProperties.variantUrlOverride\"] =\n              variantUrlOverride;\n          }\n          if (variantInfoOverride) {\n            globalProperties[\"globalProperties.variantInfoOverride\"] =\n              JSON.stringify(variantInfoOverride);\n          }\n          if (show != null) {\n            globalProperties[\"globalProperties.show\"] = String(show);\n          }\n\n          const enabledFeatures = featureFlagService!.getFeatureFlags();\n          const enabledFeaturesProperties = Object.entries(\n            enabledFeatures\n          ).reduce<Record<string, string>>(\n            (acc, [key, value]) => ({\n              ...acc,\n              [`enabledFeatures.${key}`]: `${value}`,\n            }),\n            {}\n          );\n\n          const timingProperties = {\n            \"timing.enriched_at_ms\": window.performance?.now(),\n          };\n\n          enrichedEvent = {\n            ...event,\n            event_properties: {\n              ...event.event_properties,\n              ...defaultProps, // Use the captured value instead\n              ...globalProperties,\n              ...enabledFeaturesProperties,\n              ...timingProperties,\n            },\n          };\n        } else {\n          enrichedEvent = event;\n        }\n\n        EventsDispatcher.dispatch(SpiffyEvent.AMPLITUDE_EVENT, enrichedEvent);\n\n        return enrichedEvent;\n      },\n    };\n    return enrichment;\n  }, [\n    getDefaultTrackingProps,\n    featureFlagService,\n    publicKey,\n    featureOverrides,\n    variantUrlOverride,\n    variantInfoOverride,\n    show,\n  ]);\n\n  useEffect(() => {\n    if (isReady && !amplitudeClient) {\n      const currentAmplitudeInstance: BrowserClient = createInstance();\n      const isSessionsEnabled = amplitudeSessionReplayInit();\n      currentAmplitudeInstance.add(eventTrackingEnrichment);\n      currentAmplitudeInstance.init(amplitudeApiKey!, userId!, {\n        serverZone: dataResidency as ServerZoneType,\n        trackingOptions: {\n          ipAddress: true,\n        },\n        autocapture: {\n          attribution: true,\n          pageViews: {\n            trackHistoryChanges: \"pathOnly\",\n          },\n          sessions: isSessionsEnabled,\n          formInteractions: false,\n          fileDownloads: false,\n        },\n      });\n      setAmplitudeClient(currentAmplitudeInstance);\n    }\n  }, [\n    isReady,\n    amplitudeClient,\n    amplitudeApiKey,\n    userId,\n    dataResidency,\n    amplitudeSessionReplayInit,\n    eventTrackingEnrichment,\n  ]);\n\n  const trackEvent = useCallback(\n    async ({\n      eventName,\n      eventProps,\n      eventGroups,\n      alsoSendToGoogleAnalytics = false,\n    }: TrackEventParams): Promise<void> => {\n      Logger.logDebug(\"Submitting event\", eventName);\n      try {\n        const decoratedEventName = `[Spiffy] ${eventName}`;\n\n        if (!amplitudeClient) {\n          Logger.logWarn(\"amplitude client undefined\", undefined, {\n            event_name: decoratedEventName,\n          });\n          return;\n        }\n\n        const eventData = JSON.stringify({\n          eventName,\n          eventProps,\n          created_at: new Date().toISOString(),\n        });\n        const encoder = new TextEncoder();\n        const data = encoder.encode(eventData);\n        // calculate a hash of the event properties to use as the insert_id so that duplicate events\n        // are automatically dropped by Amplitude\n        const hashBuffer = await crypto.subtle.digest(\"SHA-256\", data);\n        const hashArray = Array.from(new Uint8Array(hashBuffer));\n        const currentInsertId = hashArray\n          .map((b) => b.toString(16).padStart(2, \"0\"))\n          .join(\"\");\n\n        Logger.logDebug(`amplitude tracking ${decoratedEventName}`, null, {\n          event_name: decoratedEventName,\n          props: eventProps,\n        });\n\n        amplitudeClient.track(\n          decoratedEventName,\n          {\n            ...getDefaultTrackingProps(),\n            ...eventProps,\n            ...(eventProps\n              ? eventPropsToPrefixedEventProps(eventName, eventProps)\n              : {}),\n          },\n          {\n            ...eventGroups,\n            insert_id: currentInsertId,\n          }\n        );\n\n        if (alsoSendToGoogleAnalytics && orgGaConfig) {\n          // TODO: Add in windowDataLayerService or context alternative and hook it up here\n          Logger.logDebug(\"[spiffy-ai] GA tracking\", decoratedEventName);\n          if (window.dataLayer) {\n            (window.dataLayer as any[]).push({\n              event: decoratedEventName,\n              eventProps: eventProps,\n            });\n          }\n        }\n      } catch (err) {\n        Logger.logError(\"[spiffy-ai] Error tracking event\", err, {\n          eventName,\n          eventProps,\n        });\n      }\n    },\n    [\n      amplitudeClient,\n      getDefaultTrackingProps,\n      eventPropsToPrefixedEventProps,\n      orgGaConfig,\n    ]\n  );\n\n  const value = useMemo(\n    () => ({\n      trackEvent,\n      isReady,\n      setSupplementalDefaultProps: (props: Record<string, unknown>) =>\n        setSupplementalDefaultProps(props),\n    }),\n    [trackEvent, isReady, setSupplementalDefaultProps]\n  );\n\n  return (\n    <AmplitudeContext.Provider value={value}>\n      {children}\n    </AmplitudeContext.Provider>\n  );\n};\n\nexport const useAmplitude = () => {\n  const context = useContext(AmplitudeContext);\n  if (!context) {\n    throw new Error(\"useAmplitude must be used within AmplitudeProvider\");\n  }\n  return context;\n};\n"],"mappings":"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"}
@@ -1,38 +0,0 @@
1
- import { cdnUrlAtom } from "./enviveConfig-Cwlp7-Qz.js";
2
- import React, { createContext, useCallback, useContext, useMemo } from "react";
3
- import { useAtomValue } from "jotai";
4
- import { jsx } from "react/jsx-runtime";
5
-
6
- //#region src/contexts/cdnContext/cdnContext.tsx
7
- const CdnContext = createContext(null);
8
- const CdnProvider = ({ children }) => {
9
- const cdnUrl = useAtomValue(cdnUrlAtom) || "https://cdn.spiffy.ai/other";
10
- const getCdnBasePath = useCallback(() => {
11
- return cdnUrl;
12
- }, [cdnUrl]);
13
- const getAssetURL = useCallback((assetName, orgShortName) => {
14
- return `${getCdnBasePath()}/assets/${orgShortName}/${assetName}`;
15
- }, [getCdnBasePath]);
16
- const value = useMemo(() => ({
17
- cdnUrl,
18
- getCdnBasePath,
19
- getAssetURL
20
- }), [
21
- cdnUrl,
22
- getCdnBasePath,
23
- getAssetURL
24
- ]);
25
- return /* @__PURE__ */ jsx(CdnContext.Provider, {
26
- value,
27
- children
28
- });
29
- };
30
- const useCdn = () => {
31
- const context = useContext(CdnContext);
32
- if (!context) throw new Error("useCdn must be used within a CdnProvider");
33
- return context;
34
- };
35
-
36
- //#endregion
37
- export { CdnProvider, useCdn };
38
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2RuQ29udGV4dC1ELXFpMGx1Yi5qcyIsIm5hbWVzIjpbIkNkblByb3ZpZGVyOiBSZWFjdC5GQzx7IGNoaWxkcmVuOiBSZWFjdC5SZWFjdE5vZGUgfT4iXSwic291cmNlcyI6WyIuLi9zcmMvY29udGV4dHMvY2RuQ29udGV4dC9jZG5Db250ZXh0LnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgY3JlYXRlQ29udGV4dCwgdXNlQ29udGV4dCwgdXNlQ2FsbGJhY2ssIHVzZU1lbW8gfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyB1c2VBdG9tVmFsdWUgfSBmcm9tICdqb3RhaSc7XG5pbXBvcnQgeyBjZG5VcmxBdG9tIH0gZnJvbSAnLi4vLi4vYXRvbXMvZW52aXZlL2Vudml2ZUNvbmZpZyc7XG5pbXBvcnQgeyBDZG5Db250ZXh0VHlwZSB9IGZyb20gJ0BlbnZpdmUtYWkvdHlwZXMnO1xuXG5jb25zdCBDZG5Db250ZXh0ID0gY3JlYXRlQ29udGV4dDxDZG5Db250ZXh0VHlwZSB8IG51bGw+KG51bGwpO1xuXG5leHBvcnQgY29uc3QgQ2RuUHJvdmlkZXI6IFJlYWN0LkZDPHsgY2hpbGRyZW46IFJlYWN0LlJlYWN0Tm9kZSB9PiA9ICh7IGNoaWxkcmVuIH0pID0+IHtcbiAgY29uc3QgY2RuVXJsQXRvbVZhbHVlID0gdXNlQXRvbVZhbHVlKGNkblVybEF0b20pO1xuICBjb25zdCBjZG5VcmwgPSBjZG5VcmxBdG9tVmFsdWUgfHwgJ2h0dHBzOi8vY2RuLnNwaWZmeS5haS9vdGhlcic7XG5cbiAgY29uc3QgZ2V0Q2RuQmFzZVBhdGggPSB1c2VDYWxsYmFjaygoKSA9PiB7XG4gICAgcmV0dXJuIGNkblVybDtcbiAgfSwgW2NkblVybF0pO1xuXG4gIGNvbnN0IGdldEFzc2V0VVJMID0gdXNlQ2FsbGJhY2soXG4gICAgKGFzc2V0TmFtZTogc3RyaW5nLCBvcmdTaG9ydE5hbWU6IHN0cmluZykgPT4ge1xuICAgICAgcmV0dXJuIGAke2dldENkbkJhc2VQYXRoKCl9L2Fzc2V0cy8ke29yZ1Nob3J0TmFtZX0vJHthc3NldE5hbWV9YDtcbiAgICB9LFxuICAgIFtnZXRDZG5CYXNlUGF0aF0sXG4gICk7XG5cbiAgY29uc3QgdmFsdWUgPSB1c2VNZW1vKFxuICAgICgpID0+ICh7XG4gICAgICBjZG5VcmwsXG4gICAgICBnZXRDZG5CYXNlUGF0aCxcbiAgICAgIGdldEFzc2V0VVJMLFxuICAgIH0pLFxuICAgIFtjZG5VcmwsIGdldENkbkJhc2VQYXRoLCBnZXRBc3NldFVSTF0sXG4gICk7XG5cbiAgcmV0dXJuIDxDZG5Db250ZXh0LlByb3ZpZGVyIHZhbHVlPXt2YWx1ZX0+e2NoaWxkcmVufTwvQ2RuQ29udGV4dC5Qcm92aWRlcj47XG59O1xuXG5leHBvcnQgY29uc3QgdXNlQ2RuID0gKCkgPT4ge1xuICBjb25zdCBjb250ZXh0ID0gdXNlQ29udGV4dChDZG5Db250ZXh0KTtcbiAgaWYgKCFjb250ZXh0KSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCd1c2VDZG4gbXVzdCBiZSB1c2VkIHdpdGhpbiBhIENkblByb3ZpZGVyJyk7XG4gIH1cbiAgcmV0dXJuIGNvbnRleHQ7XG59O1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFLQSxNQUFNLGFBQWEsY0FBcUMsS0FBSztBQUU3RCxNQUFhQSxlQUF3RCxFQUFFLGVBQWU7Q0FFcEYsTUFBTSxTQURrQixhQUFhLFdBQVcsSUFDZDtDQUVsQyxNQUFNLGlCQUFpQixrQkFBa0I7QUFDdkMsU0FBTztJQUNOLENBQUMsT0FBTyxDQUFDO0NBRVosTUFBTSxjQUFjLGFBQ2pCLFdBQW1CLGlCQUF5QjtBQUMzQyxTQUFPLEdBQUcsZ0JBQWdCLENBQUMsVUFBVSxhQUFhLEdBQUc7SUFFdkQsQ0FBQyxlQUFlLENBQ2pCO0NBRUQsTUFBTSxRQUFRLGVBQ0w7RUFDTDtFQUNBO0VBQ0E7RUFDRCxHQUNEO0VBQUM7RUFBUTtFQUFnQjtFQUFZLENBQ3RDO0FBRUQsUUFBTyxvQkFBQyxXQUFXO0VBQWdCO0VBQVE7R0FBK0I7O0FBRzVFLE1BQWEsZUFBZTtDQUMxQixNQUFNLFVBQVUsV0FBVyxXQUFXO0FBQ3RDLEtBQUksQ0FBQyxRQUNILE9BQU0sSUFBSSxNQUFNLDJDQUEyQztBQUU3RCxRQUFPIn0=
@@ -1,53 +0,0 @@
1
- const require_chunk = require('./chunk-CUT6urMc.cjs');
2
- const require_enviveConfig = require('./enviveConfig-CQ_8mT-g.cjs');
3
- let react = require("react");
4
- react = require_chunk.__toESM(react);
5
- let jotai = require("jotai");
6
- jotai = require_chunk.__toESM(jotai);
7
- let react_jsx_runtime = require("react/jsx-runtime");
8
- react_jsx_runtime = require_chunk.__toESM(react_jsx_runtime);
9
-
10
- //#region src/contexts/cdnContext/cdnContext.tsx
11
- const CdnContext = (0, react.createContext)(null);
12
- const CdnProvider = ({ children }) => {
13
- const cdnUrl = (0, jotai.useAtomValue)(require_enviveConfig.cdnUrlAtom) || "https://cdn.spiffy.ai/other";
14
- const getCdnBasePath = (0, react.useCallback)(() => {
15
- return cdnUrl;
16
- }, [cdnUrl]);
17
- const getAssetURL = (0, react.useCallback)((assetName, orgShortName) => {
18
- return `${getCdnBasePath()}/assets/${orgShortName}/${assetName}`;
19
- }, [getCdnBasePath]);
20
- const value = (0, react.useMemo)(() => ({
21
- cdnUrl,
22
- getCdnBasePath,
23
- getAssetURL
24
- }), [
25
- cdnUrl,
26
- getCdnBasePath,
27
- getAssetURL
28
- ]);
29
- return /* @__PURE__ */ (0, react_jsx_runtime.jsx)(CdnContext.Provider, {
30
- value,
31
- children
32
- });
33
- };
34
- const useCdn = () => {
35
- const context = (0, react.useContext)(CdnContext);
36
- if (!context) throw new Error("useCdn must be used within a CdnProvider");
37
- return context;
38
- };
39
-
40
- //#endregion
41
- Object.defineProperty(exports, 'CdnProvider', {
42
- enumerable: true,
43
- get: function () {
44
- return CdnProvider;
45
- }
46
- });
47
- Object.defineProperty(exports, 'useCdn', {
48
- enumerable: true,
49
- get: function () {
50
- return useCdn;
51
- }
52
- });
53
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2RuQ29udGV4dC1ESVZnQm5zbC5janMiLCJuYW1lcyI6WyJDZG5Qcm92aWRlcjogUmVhY3QuRkM8eyBjaGlsZHJlbjogUmVhY3QuUmVhY3ROb2RlIH0+IiwiY2RuVXJsQXRvbSJdLCJzb3VyY2VzIjpbIi4uL3NyYy9jb250ZXh0cy9jZG5Db250ZXh0L2NkbkNvbnRleHQudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCwgeyBjcmVhdGVDb250ZXh0LCB1c2VDb250ZXh0LCB1c2VDYWxsYmFjaywgdXNlTWVtbyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IHVzZUF0b21WYWx1ZSB9IGZyb20gJ2pvdGFpJztcbmltcG9ydCB7IGNkblVybEF0b20gfSBmcm9tICcuLi8uLi9hdG9tcy9lbnZpdmUvZW52aXZlQ29uZmlnJztcbmltcG9ydCB7IENkbkNvbnRleHRUeXBlIH0gZnJvbSAnQGVudml2ZS1haS90eXBlcyc7XG5cbmNvbnN0IENkbkNvbnRleHQgPSBjcmVhdGVDb250ZXh0PENkbkNvbnRleHRUeXBlIHwgbnVsbD4obnVsbCk7XG5cbmV4cG9ydCBjb25zdCBDZG5Qcm92aWRlcjogUmVhY3QuRkM8eyBjaGlsZHJlbjogUmVhY3QuUmVhY3ROb2RlIH0+ID0gKHsgY2hpbGRyZW4gfSkgPT4ge1xuICBjb25zdCBjZG5VcmxBdG9tVmFsdWUgPSB1c2VBdG9tVmFsdWUoY2RuVXJsQXRvbSk7XG4gIGNvbnN0IGNkblVybCA9IGNkblVybEF0b21WYWx1ZSB8fCAnaHR0cHM6Ly9jZG4uc3BpZmZ5LmFpL290aGVyJztcblxuICBjb25zdCBnZXRDZG5CYXNlUGF0aCA9IHVzZUNhbGxiYWNrKCgpID0+IHtcbiAgICByZXR1cm4gY2RuVXJsO1xuICB9LCBbY2RuVXJsXSk7XG5cbiAgY29uc3QgZ2V0QXNzZXRVUkwgPSB1c2VDYWxsYmFjayhcbiAgICAoYXNzZXROYW1lOiBzdHJpbmcsIG9yZ1Nob3J0TmFtZTogc3RyaW5nKSA9PiB7XG4gICAgICByZXR1cm4gYCR7Z2V0Q2RuQmFzZVBhdGgoKX0vYXNzZXRzLyR7b3JnU2hvcnROYW1lfS8ke2Fzc2V0TmFtZX1gO1xuICAgIH0sXG4gICAgW2dldENkbkJhc2VQYXRoXSxcbiAgKTtcblxuICBjb25zdCB2YWx1ZSA9IHVzZU1lbW8oXG4gICAgKCkgPT4gKHtcbiAgICAgIGNkblVybCxcbiAgICAgIGdldENkbkJhc2VQYXRoLFxuICAgICAgZ2V0QXNzZXRVUkwsXG4gICAgfSksXG4gICAgW2NkblVybCwgZ2V0Q2RuQmFzZVBhdGgsIGdldEFzc2V0VVJMXSxcbiAgKTtcblxuICByZXR1cm4gPENkbkNvbnRleHQuUHJvdmlkZXIgdmFsdWU9e3ZhbHVlfT57Y2hpbGRyZW59PC9DZG5Db250ZXh0LlByb3ZpZGVyPjtcbn07XG5cbmV4cG9ydCBjb25zdCB1c2VDZG4gPSAoKSA9PiB7XG4gIGNvbnN0IGNvbnRleHQgPSB1c2VDb250ZXh0KENkbkNvbnRleHQpO1xuICBpZiAoIWNvbnRleHQpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ3VzZUNkbiBtdXN0IGJlIHVzZWQgd2l0aGluIGEgQ2RuUHJvdmlkZXInKTtcbiAgfVxuICByZXR1cm4gY29udGV4dDtcbn07XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7QUFLQSxNQUFNLHNDQUFrRCxLQUFLO0FBRTdELE1BQWFBLGVBQXdELEVBQUUsZUFBZTtDQUVwRixNQUFNLGlDQUQrQkMsZ0NBQVcsSUFDZDtDQUVsQyxNQUFNLDhDQUFtQztBQUN2QyxTQUFPO0lBQ04sQ0FBQyxPQUFPLENBQUM7Q0FFWixNQUFNLHNDQUNILFdBQW1CLGlCQUF5QjtBQUMzQyxTQUFPLEdBQUcsZ0JBQWdCLENBQUMsVUFBVSxhQUFhLEdBQUc7SUFFdkQsQ0FBQyxlQUFlLENBQ2pCO0NBRUQsTUFBTSxrQ0FDRztFQUNMO0VBQ0E7RUFDQTtFQUNELEdBQ0Q7RUFBQztFQUFRO0VBQWdCO0VBQVksQ0FDdEM7QUFFRCxRQUFPLDJDQUFDLFdBQVc7RUFBZ0I7RUFBUTtHQUErQjs7QUFHNUUsTUFBYSxlQUFlO0NBQzFCLE1BQU0sZ0NBQXFCLFdBQVc7QUFDdEMsS0FBSSxDQUFDLFFBQ0gsT0FBTSxJQUFJLE1BQU0sMkNBQTJDO0FBRTdELFFBQU8ifQ==