@envive-ai/react-hooks 0.2.7-arthur-1 → 0.2.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.
Files changed (83) hide show
  1. package/dist/{TrackComponentVisibleEvent-CXhKOwKQ.js → TrackComponentVisibleEvent-qNE0dIL1.js} +2 -2
  2. package/dist/{TrackComponentVisibleEvent-CgxCqrIt.cjs → TrackComponentVisibleEvent-tDRnrJi3.cjs} +2 -2
  3. package/dist/amplitudeContext-C6LHpqP_.cjs +290 -0
  4. package/dist/amplitudeContext-rEjGf57q.js +268 -0
  5. package/dist/application/utils/index.cjs +2 -2
  6. package/dist/application/utils/index.js +2 -2
  7. package/dist/atoms/app/index.d.cts +7 -7
  8. package/dist/atoms/app/index.d.ts +1 -1
  9. package/dist/atoms/chat/index.cjs +3 -3
  10. package/dist/atoms/chat/index.d.cts +26 -26
  11. package/dist/atoms/chat/index.d.ts +1 -1
  12. package/dist/atoms/chat/index.js +3 -3
  13. package/dist/atoms/globalSearch/index.d.cts +6 -6
  14. package/dist/atoms/globalSearch/index.d.ts +5 -5
  15. package/dist/atoms/org/index.d.cts +16 -16
  16. package/dist/atoms/org/index.d.ts +16 -16
  17. package/dist/atoms/search/index.cjs +5 -5
  18. package/dist/atoms/search/index.js +5 -5
  19. package/dist/atoms/search/utils.d.ts +1 -1
  20. package/dist/{cdnContext-CtrIlAqX.js → cdnContext-B8zWuGGT.js} +1 -1
  21. package/dist/{cdnContext-CaDyQ_5p.cjs → cdnContext-DzifgoNo.cjs} +1 -1
  22. package/dist/{chat-BjhQCyW_.js → chat-DChvXHjz.js} +3 -3
  23. package/dist/{chat-BkPax29G.cjs → chat-L_N0qaqs.cjs} +3 -3
  24. package/dist/{chatSearch-C3N3iIxu.cjs → chatSearch-B5whqPLW.cjs} +3 -3
  25. package/dist/{chatSearch-BsYlFvpv.js → chatSearch-so-qeiEL.js} +3 -3
  26. package/dist/{chatState-CJ52Ag_7.cjs → chatState-D9_aA1_h.cjs} +2 -2
  27. package/dist/{chatState-CXA1vF16.js → chatState-Dl5lyuKC.js} +2 -2
  28. package/dist/{commerce-api-rgj30eEp.js → commerce-api-DEFd5HUH.js} +2 -2
  29. package/dist/{commerce-api-DA1QGGMK.cjs → commerce-api-DqVD4NH8.cjs} +2 -2
  30. package/dist/contexts/amplitudeContext/index.cjs +2 -2
  31. package/dist/contexts/amplitudeContext/index.js +2 -2
  32. package/dist/contexts/cdnContext/index.cjs +1 -1
  33. package/dist/contexts/cdnContext/index.js +1 -1
  34. package/dist/contexts/chatContext/index.cjs +7 -7
  35. package/dist/contexts/chatContext/index.d.ts +4 -4
  36. package/dist/contexts/chatContext/index.js +7 -7
  37. package/dist/contexts/systemSettingsContext/index.d.cts +2 -2
  38. package/dist/contexts/systemSettingsContext/index.d.ts +4 -4
  39. package/dist/contexts/userIdentityContext/index.cjs +4 -4
  40. package/dist/contexts/userIdentityContext/index.js +4 -4
  41. package/dist/frontendConfig-Cawh5iqv.d.ts +1 -1
  42. package/dist/frontendConfig-iZipB5FG.d.cts +1 -1
  43. package/dist/hooks/AmplitudeOperations/index.cjs +3 -3
  44. package/dist/hooks/AmplitudeOperations/index.js +3 -3
  45. package/dist/hooks/CdnOperations/index.cjs +1 -1
  46. package/dist/hooks/CdnOperations/index.js +1 -1
  47. package/dist/hooks/ChatToggle/index.cjs +3 -3
  48. package/dist/hooks/ChatToggle/index.js +3 -3
  49. package/dist/hooks/ChatToggleAnalytics/index.cjs +4 -4
  50. package/dist/hooks/ChatToggleAnalytics/index.js +4 -4
  51. package/dist/hooks/GrabAndScroll/index.d.cts +2 -2
  52. package/dist/hooks/IdentifyUser/index.cjs +4 -4
  53. package/dist/hooks/IdentifyUser/index.js +4 -4
  54. package/dist/hooks/Search/index.cjs +19 -1157
  55. package/dist/hooks/Search/index.js +17 -1156
  56. package/dist/hooks/SystemSettingsContext/index.d.ts +2 -2
  57. package/dist/hooks/TrackComponentVisibleEvent/index.cjs +2 -2
  58. package/dist/hooks/TrackComponentVisibleEvent/index.js +2 -2
  59. package/dist/hooks/UpdateAnalyticsProps/index.cjs +1 -1
  60. package/dist/hooks/UpdateAnalyticsProps/index.js +1 -1
  61. package/dist/{search-Csh2n66W.cjs → search-CneZkauD.cjs} +2 -2
  62. package/dist/{search-DkiqkogN.js → search-DbZeJYdg.js} +2 -2
  63. package/dist/{useAmplitudeOperations-zIRSqmMW.js → useAmplitudeOperations-B9HjVe6G.js} +2 -2
  64. package/dist/{useAmplitudeOperations-Bo6YNbTV.cjs → useAmplitudeOperations-BdvxAzuI.cjs} +2 -2
  65. package/dist/userIdentityContext-CPztaX6-.js +126 -0
  66. package/dist/userIdentityContext-DdySlQBz.cjs +143 -0
  67. package/dist/{utils-C1ErYSoW.js → utils-B4PvsKVY.js} +2 -2
  68. package/dist/{utils-mqfncrhI.cjs → utils-BRVP7Mnu.cjs} +2 -2
  69. package/dist/utils-CBD4g2Nc.d.cts +1 -1
  70. package/dist/utils-QKFAbPT6.d.ts +1 -1
  71. package/package.json +3 -2
  72. package/src/contexts/amplitudeContext/__tests__/amplitudeContext.test.tsx +525 -0
  73. package/src/contexts/amplitudeContext/amplitudeContext.tsx +6 -2
  74. package/src/contexts/userIdentityContext/__tests__/userIdentityContext.test.tsx +0 -162
  75. package/src/contexts/userIdentityContext/userIdentityContext.tsx +13 -4
  76. package/dist/amplitudeContext-C8tT74Mi.cjs +0 -286
  77. package/dist/amplitudeContext-DCk6Va-j.js +0 -264
  78. package/dist/userIdentityContext-BqbNu7xu.cjs +0 -132
  79. package/dist/userIdentityContext-BxFH9FNQ.js +0 -115
  80. /package/dist/{AmplitudeOperations-ChZWcSsc.js → AmplitudeOperations-C-ieCm9m.js} +0 -0
  81. /package/dist/{AmplitudeOperations-JggIc1zD.cjs → AmplitudeOperations-p7APchq9.cjs} +0 -0
  82. /package/dist/{amplitudeContext-BItT9HmT.js → amplitudeContext-DbicJUzl.js} +0 -0
  83. /package/dist/{amplitudeContext-DPtyVv3Q.cjs → amplitudeContext-q3mggFSE.cjs} +0 -0
@@ -0,0 +1,268 @@
1
+ import { EventsDispatcher, SpiffyEvent } from "./events-DyUix-Bn.js";
2
+ import { OrgShortName } from "./models-CWOgrLCm.js";
3
+ import { FeatureGates } from "./featureGates-KEwAL8p_.js";
4
+ import { logger_default } from "./logger-W3lqg-4b.js";
5
+ import { LocalStorageKeys, useLocalStorage } from "./localStorageContext-BPZ82q-G.js";
6
+ import { amplitudeApiKeyAtom, contextSourceAtom, dataResidencyAtom, envAtom, identifyingPrefixAtom } from "./enviveConfig-DZBohDpc.js";
7
+ import { orgAnalyticsGoogleAnalyticsConfigAtom } from "./orgAnalyticsConfig-CpBmga08.js";
8
+ import { userIdAtom } from "./app-CflxT_xI.js";
9
+ import { useEnviveConfig } from "./enviveConfigContext-DrDjCems.js";
10
+ import { useFeatureFlagService } from "./featureFlagServiceContext-FBM6DdMJ.js";
11
+ import React, { createContext, useCallback, useContext, useEffect, useMemo } from "react";
12
+ import { useAtomValue } from "jotai";
13
+ import { createInstance } from "@amplitude/analytics-browser";
14
+ import { jsx } from "react/jsx-runtime";
15
+
16
+ //#region src/contexts/amplitudeContext/amplitudeContext.tsx
17
+ let SpiffyMetricsEventName = /* @__PURE__ */ function(SpiffyMetricsEventName$1) {
18
+ SpiffyMetricsEventName$1["BundleLoaded"] = "Bundle Loaded";
19
+ SpiffyMetricsEventName$1["ChatLiveAgentBtnClick"] = "Chat Live Agent Btn Click";
20
+ SpiffyMetricsEventName$1["ChatFloatingButtonVisible"] = "Chat Floating Button Visible";
21
+ SpiffyMetricsEventName$1["ChatComponentVisible"] = "Chat Component Visible";
22
+ SpiffyMetricsEventName$1["ChatComponentExpanded"] = "Chat Component Expanded";
23
+ SpiffyMetricsEventName$1["ChatComponentCollapsed"] = "Chat Component Collapsed";
24
+ SpiffyMetricsEventName$1["ChatUserMessageInput"] = "Chat User Message Input";
25
+ SpiffyMetricsEventName$1["ChatSuggestionClicked"] = "Chat Suggestion Clicked";
26
+ SpiffyMetricsEventName$1["ChatAssistantResponse"] = "Chat Assistant Response";
27
+ SpiffyMetricsEventName$1["ProductCardClicked"] = "Product Card Clicked";
28
+ SpiffyMetricsEventName$1["ProductReviewCardClicked"] = "Product Review Card Clicked";
29
+ SpiffyMetricsEventName$1["AddToCartClicked"] = "Add to Cart Clicked";
30
+ SpiffyMetricsEventName$1["PromptCardClicked"] = "Prompt Card Clicked";
31
+ SpiffyMetricsEventName$1["SupportedEvent"] = "Supported Event";
32
+ SpiffyMetricsEventName$1["SearchBackToResponseClicked"] = "Search Back to Response Clicked";
33
+ SpiffyMetricsEventName$1["PerformanceMetrics"] = "Performance Metrics";
34
+ SpiffyMetricsEventName$1["SearchBarClicked"] = "Search Bar Clicked";
35
+ SpiffyMetricsEventName$1["OrderLookupStarted"] = "Order Lookup Started";
36
+ SpiffyMetricsEventName$1["OrderLookupFormSubmitted"] = "Order Lookup Form Submitted";
37
+ SpiffyMetricsEventName$1["SearchComponentVisible"] = "Search Component Visible";
38
+ SpiffyMetricsEventName$1["SearchZeroStateSuggestionClicked"] = "Search Zero State Suggestion Clicked";
39
+ SpiffyMetricsEventName$1["SearchInputStarted"] = "Search Input Started";
40
+ SpiffyMetricsEventName$1["SearchQuerySubmitted"] = "Search Query Submitted";
41
+ SpiffyMetricsEventName$1["SearchResultsViewed"] = "Search Results Viewed";
42
+ SpiffyMetricsEventName$1["SearchTimeToFirstClick"] = "Search Time to First Click";
43
+ SpiffyMetricsEventName$1["SearchZeroResultsRate"] = "Search Zero Results Rate";
44
+ SpiffyMetricsEventName$1["SearchFilterClicked"] = "Search Filter Clicked";
45
+ SpiffyMetricsEventName$1["SearchSortClicked"] = "Search Sort Clicked";
46
+ return SpiffyMetricsEventName$1;
47
+ }({});
48
+ const AmplitudeContext = createContext(null);
49
+ const AmplitudeProvider = ({ children }) => {
50
+ const userId = useAtomValue(userIdAtom);
51
+ const amplitudeApiKey = useAtomValue(amplitudeApiKeyAtom);
52
+ const dataResidency = useAtomValue(dataResidencyAtom);
53
+ const orgGaConfig = useAtomValue(orgAnalyticsGoogleAnalyticsConfigAtom);
54
+ const env = useAtomValue(envAtom);
55
+ const contextSource = useAtomValue(contextSourceAtom);
56
+ useAtomValue(identifyingPrefixAtom);
57
+ const { getItem } = useLocalStorage();
58
+ const { publicKey, featureOverrides, variantUrlOverride, variantInfoOverride, show, orgShortName, featureGates } = useEnviveConfig();
59
+ const { featureFlagService } = useFeatureFlagService();
60
+ const [amplitudeClient, setAmplitudeClient] = React.useState(void 0);
61
+ const [internalEventTrackingEnrichment, setInternalEventTrackingEnrichment] = React.useState(void 0);
62
+ const [supplementalDefaultProps, setSupplementalDefaultProps] = React.useState({});
63
+ const isReady = Boolean(userId && featureFlagService && amplitudeApiKey);
64
+ const getDefaultTrackingProps = useCallback(() => {
65
+ const gatesProps = featureGates ? featureGates.reduce((acc, curr) => {
66
+ if (curr.name && curr.value != null) return {
67
+ ...acc,
68
+ [`feature_gate.${curr.name}`]: curr.value
69
+ };
70
+ return acc;
71
+ }, {}) : {};
72
+ const experimentProps = {};
73
+ return {
74
+ ...gatesProps,
75
+ ...experimentProps,
76
+ ...supplementalDefaultProps,
77
+ app_id: "commerce-chat-react-component",
78
+ chat_id: getItem(LocalStorageKeys.ChatId),
79
+ env: env || "unknown",
80
+ app_source: contextSource,
81
+ "org.short_name": orgShortName,
82
+ "user.id": userId,
83
+ "cdp.user_id": null,
84
+ "cdp.provider": null,
85
+ "event.source": "web-browser",
86
+ "event.type": "user-activity",
87
+ "event.id": null,
88
+ "event.channel": "web",
89
+ "event.timestamp": null
90
+ };
91
+ }, [
92
+ featureGates,
93
+ supplementalDefaultProps,
94
+ env,
95
+ contextSource,
96
+ orgShortName,
97
+ userId
98
+ ]);
99
+ const eventPropsToPrefixedEventProps = useCallback((eventName, eventProps) => {
100
+ const prefix = eventName.toLowerCase().replace(/\s+/g, "_");
101
+ return Object.entries(eventProps).reduce((acc, [key, value$1]) => {
102
+ acc[`${prefix}.${key}`] = value$1;
103
+ return acc;
104
+ }, {});
105
+ }, []);
106
+ const amplitudeSessionReplayInit = useCallback(() => {
107
+ const isEnabled = Boolean(orgShortName === OrgShortName.UniqueVintage && featureFlagService?.isClientSessionEnabled() && featureFlagService?.isFeatureGateEnabled(FeatureGates.IsNewFeatureEnabled));
108
+ const sampleRate = 1;
109
+ try {
110
+ logger_default.logDebug(`[spiffy-ai] amplitude session-replay initializing isEnabled=${isEnabled} sampleRate=${sampleRate}`);
111
+ if (!isEnabled) return isEnabled;
112
+ return isEnabled;
113
+ } catch (e) {
114
+ logger_default.logError("[spiffy-ai] Error initializing amplitude session-replay", e);
115
+ return false;
116
+ }
117
+ }, [orgShortName, featureFlagService]);
118
+ const getEventTrackingEnrichment = useCallback(() => {
119
+ if (internalEventTrackingEnrichment !== void 0) return internalEventTrackingEnrichment;
120
+ const enrichment = {
121
+ name: "page-view-tracking-enrichment",
122
+ type: "enrichment",
123
+ setup: async () => void 0,
124
+ execute: async (event) => {
125
+ let enrichedEvent;
126
+ if (["[Amplitude] Page Viewed", `[Spiffy] ${SpiffyMetricsEventName.BundleLoaded}`].includes(event.event_type)) {
127
+ const globalProperties = {};
128
+ if (publicKey) globalProperties["globalProperties.publicKey"] = publicKey;
129
+ if (featureOverrides) Object.entries(featureOverrides).forEach(([key, value$1]) => {
130
+ globalProperties[`globalProperties.featureOverrides.${key}`] = String(value$1);
131
+ });
132
+ if (variantUrlOverride) globalProperties["globalProperties.variantUrlOverride"] = variantUrlOverride;
133
+ if (variantInfoOverride) globalProperties["globalProperties.variantInfoOverride"] = JSON.stringify(variantInfoOverride);
134
+ if (show != null) globalProperties["globalProperties.show"] = String(show);
135
+ const enabledFeatures = featureFlagService.getFeatureFlags();
136
+ const enabledFeaturesProperties = Object.entries(enabledFeatures).reduce((acc, [key, value$1]) => ({
137
+ ...acc,
138
+ [`enabledFeatures.${key}`]: `${value$1}`
139
+ }), {});
140
+ const timingProperties = { "timing.enriched_at_ms": window.performance?.now() };
141
+ enrichedEvent = {
142
+ ...event,
143
+ event_properties: {
144
+ ...event.event_properties,
145
+ ...getDefaultTrackingProps(),
146
+ ...globalProperties,
147
+ ...enabledFeaturesProperties,
148
+ ...timingProperties
149
+ }
150
+ };
151
+ } else enrichedEvent = event;
152
+ EventsDispatcher.dispatch(SpiffyEvent.AMPLITUDE_EVENT, enrichedEvent);
153
+ return enrichedEvent;
154
+ }
155
+ };
156
+ setInternalEventTrackingEnrichment(enrichment);
157
+ return enrichment;
158
+ }, [
159
+ internalEventTrackingEnrichment,
160
+ getDefaultTrackingProps,
161
+ featureFlagService,
162
+ publicKey,
163
+ featureOverrides,
164
+ variantUrlOverride,
165
+ variantInfoOverride,
166
+ show
167
+ ]);
168
+ useEffect(() => {
169
+ if (isReady && !amplitudeClient) {
170
+ const currentAmplitudeInstance = createInstance();
171
+ const isSessionsEnabled = amplitudeSessionReplayInit();
172
+ currentAmplitudeInstance.add(getEventTrackingEnrichment());
173
+ currentAmplitudeInstance.init(amplitudeApiKey, userId, {
174
+ serverZone: dataResidency,
175
+ trackingOptions: { ipAddress: true },
176
+ autocapture: {
177
+ attribution: true,
178
+ pageViews: { trackHistoryChanges: "pathOnly" },
179
+ sessions: isSessionsEnabled,
180
+ formInteractions: false,
181
+ fileDownloads: false
182
+ }
183
+ });
184
+ setAmplitudeClient(currentAmplitudeInstance);
185
+ }
186
+ }, [
187
+ isReady,
188
+ amplitudeClient,
189
+ amplitudeApiKey,
190
+ userId,
191
+ dataResidency,
192
+ amplitudeSessionReplayInit,
193
+ getEventTrackingEnrichment
194
+ ]);
195
+ const trackEvent = useCallback(async ({ eventName, eventProps, eventGroups, alsoSendToGoogleAnalytics = false }) => {
196
+ logger_default.logDebug("Submitting event", eventName);
197
+ try {
198
+ const decoratedEventName = `[Spiffy] ${eventName}`;
199
+ if (!amplitudeClient) {
200
+ logger_default.logWarn("amplitude client undefined", void 0, { event_name: decoratedEventName });
201
+ return;
202
+ }
203
+ const eventData = JSON.stringify({
204
+ eventName,
205
+ eventProps,
206
+ created_at: (/* @__PURE__ */ new Date()).toISOString()
207
+ });
208
+ const data = new TextEncoder().encode(eventData);
209
+ const hashBuffer = await crypto.subtle.digest("SHA-256", data);
210
+ const currentInsertId = Array.from(new Uint8Array(hashBuffer)).map((b) => b.toString(16).padStart(2, "0")).join("");
211
+ logger_default.logDebug(`amplitude tracking ${decoratedEventName}`, null, {
212
+ event_name: decoratedEventName,
213
+ props: eventProps
214
+ });
215
+ amplitudeClient.track(decoratedEventName, {
216
+ ...getDefaultTrackingProps(),
217
+ ...eventProps,
218
+ ...eventProps ? eventPropsToPrefixedEventProps(eventName, eventProps) : {}
219
+ }, {
220
+ ...eventGroups,
221
+ insert_id: currentInsertId
222
+ });
223
+ if (alsoSendToGoogleAnalytics && orgGaConfig) {
224
+ logger_default.logDebug("[spiffy-ai] GA tracking", decoratedEventName);
225
+ if (window.dataLayer) window.dataLayer.push({
226
+ event: decoratedEventName,
227
+ eventProps
228
+ });
229
+ }
230
+ } catch (err) {
231
+ logger_default.logError("[spiffy-ai] Error tracking event", err, {
232
+ eventName,
233
+ eventProps
234
+ });
235
+ }
236
+ }, [
237
+ amplitudeClient,
238
+ getDefaultTrackingProps,
239
+ eventPropsToPrefixedEventProps,
240
+ orgGaConfig
241
+ ]);
242
+ const value = useMemo(() => ({
243
+ trackEvent,
244
+ isReady,
245
+ setSupplementalDefaultProps: (props) => setSupplementalDefaultProps(props)
246
+ }), [
247
+ trackEvent,
248
+ isReady,
249
+ setSupplementalDefaultProps
250
+ ]);
251
+ if (!isReady) {
252
+ console.log("AmplitudeProvider is not ready", isReady, userId, featureFlagService, amplitudeApiKey);
253
+ return null;
254
+ }
255
+ return /* @__PURE__ */ jsx(AmplitudeContext.Provider, {
256
+ value,
257
+ children
258
+ });
259
+ };
260
+ const useAmplitude = () => {
261
+ const context = useContext(AmplitudeContext);
262
+ if (!context) throw new Error("useAmplitude must be used within AmplitudeProvider");
263
+ return context;
264
+ };
265
+
266
+ //#endregion
267
+ export { AmplitudeProvider, SpiffyMetricsEventName, useAmplitude };
268
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"amplitudeContext-rEjGf57q.js","names":["AmplitudeProvider: React.FC<{ children: React.ReactNode }>","value","enrichment: EnrichmentPlugin","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 { FeatureGates } from \"src/application/models/featureGates\";\nimport { OrgShortName } from \"src/application/models\";\nimport { EventsDispatcher, SpiffyEvent } from \"src/events\";\nimport {\n  amplitudeApiKeyAtom,\n  contextSourceAtom,\n  dataResidencyAtom,\n  identifyingPrefixAtom,\n} from \"src/atoms/envive/enviveConfig\";\nimport {\n  LocalStorageKeys,\n  useLocalStorage,\n} 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 {\n  useFeatureFlagService,\n} from \"src/contexts/featureFlagServiceContext/featureFlagServiceContext\";\n\nexport enum SpiffyMetricsEventName {\n  BundleLoaded = \"Bundle Loaded\",\n  ChatLiveAgentBtnClick = \"Chat Live Agent Btn Click\",\n  ChatFloatingButtonVisible = \"Chat Floating Button Visible\",\n  ChatComponentVisible = \"Chat Component Visible\",\n  ChatComponentExpanded = \"Chat Component Expanded\",\n  ChatComponentCollapsed = \"Chat Component Collapsed\",\n  ChatUserMessageInput = \"Chat User Message Input\",\n  ChatSuggestionClicked = \"Chat Suggestion Clicked\",\n  ChatAssistantResponse = \"Chat Assistant Response\",\n  ProductCardClicked = \"Product Card Clicked\",\n  ProductReviewCardClicked = \"Product Review Card Clicked\",\n  AddToCartClicked = \"Add to Cart Clicked\",\n  PromptCardClicked = \"Prompt Card Clicked\",\n  SupportedEvent = \"Supported Event\",\n  SearchBackToResponseClicked = \"Search Back to Response Clicked\",\n  PerformanceMetrics = \"Performance Metrics\",\n  SearchBarClicked = \"Search Bar Clicked\",\n  OrderLookupStarted = \"Order Lookup Started\",\n  OrderLookupFormSubmitted = \"Order Lookup Form Submitted\",\n  SearchComponentVisible = \"Search Component Visible\",\n  SearchZeroStateSuggestionClicked = \"Search Zero State Suggestion Clicked\", // This is the scrolling list of suggestion buttons in global search\n  SearchInputStarted = \"Search Input Started\",\n  SearchQuerySubmitted = \"Search Query Submitted\",\n  // SearchAutocompleteViewed = 'Search Autocomplete Viewed', // TODO: add this when autocomplete is added\n  // SearchAutocompleteClicked = 'Search Autocomplete Clicked', // TODO: add this when autocomplete is added\n  SearchResultsViewed = \"Search Results Viewed\",\n  SearchTimeToFirstClick = \"Search Time to First Click\",\n  SearchZeroResultsRate = \"Search Zero Results Rate\",\n  SearchFilterClicked = \"Search Filter Clicked\",\n  SearchSortClicked = \"Search Sort Clicked\",\n}\n\ninterface TrackEventParams {\n  eventName: SpiffyMetricsEventName;\n  eventProps?: Record<string, unknown>;\n  eventGroups?: Record<string, unknown>;\n  alsoSendToGoogleAnalytics?: boolean;\n}\n\ninterface AmplitudeContextType {\n  trackEvent: (params: TrackEventParams) => Promise<void>;\n  isReady: boolean;\n  setSupplementalDefaultProps: (props: Record<string, unknown>) => void;\n}\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 [internalEventTrackingEnrichment, setInternalEventTrackingEnrichment] =\n    React.useState<EnrichmentPlugin | undefined>(undefined);\n  const [supplementalDefaultProps, setSupplementalDefaultProps] =\n    React.useState<Record<string, unknown>>({});\n\n  const isReady = Boolean(\n    userId && featureFlagService && amplitudeApiKey\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 getEventTrackingEnrichment = useCallback((): EnrichmentPlugin => {\n    if (internalEventTrackingEnrichment !== undefined) {\n      return internalEventTrackingEnrichment;\n    }\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              ...getDefaultTrackingProps(),\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    setInternalEventTrackingEnrichment(enrichment);\n    return enrichment;\n  }, [\n    internalEventTrackingEnrichment,\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(getEventTrackingEnrichment());\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    getEventTrackingEnrichment,\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  if (!isReady) {\n    console.log(\"AmplitudeProvider is not ready\", isReady, userId, featureFlagService, amplitudeApiKey);\n    return null;\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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"}
@@ -16,8 +16,8 @@ require('../../atomStore-CmZbgQHc.cjs');
16
16
  require('../../app-BbPSHefQ.cjs');
17
17
  require('../../enviveConfigContext-D2OELZDR.cjs');
18
18
  require('../../featureFlagServiceContext-CJyYItqu.cjs');
19
- require('../../amplitudeContext-C8tT74Mi.cjs');
20
- const require_utils$1 = require('../../utils-mqfncrhI.cjs');
19
+ require('../../amplitudeContext-C6LHpqP_.cjs');
20
+ const require_utils$1 = require('../../utils-BRVP7Mnu.cjs');
21
21
  const require_domObserver = require('../../domObserver-COKvTfZV.cjs');
22
22
 
23
23
  exports.DOMObserver = require_domObserver.DOMObserver;
@@ -16,8 +16,8 @@ import "../../atomStore-DEcDhiLp.js";
16
16
  import "../../app-CflxT_xI.js";
17
17
  import "../../enviveConfigContext-DrDjCems.js";
18
18
  import "../../featureFlagServiceContext-FBM6DdMJ.js";
19
- import "../../amplitudeContext-DCk6Va-j.js";
20
- import { NodeSelector, SelectorFactory, StringUtils, applyOverrides, coreContextToApiContext, coreSupportedEventRequestToApiRequest, coreUserEventToApiUserEvent, divideArray, getRecentProductImageUrls, initAmplitude, initDataLayerWrapper, messageFromFormSubmittedEvent, messageFromQueryEvent, messageFromResponse, messageFromSuggestionEvent, messageRequestToCommerceMessageRequest, prepareMerchantPage, validateEmail } from "../../utils-C1ErYSoW.js";
19
+ import "../../amplitudeContext-rEjGf57q.js";
20
+ import { NodeSelector, SelectorFactory, StringUtils, applyOverrides, coreContextToApiContext, coreSupportedEventRequestToApiRequest, coreUserEventToApiUserEvent, divideArray, getRecentProductImageUrls, initAmplitude, initDataLayerWrapper, messageFromFormSubmittedEvent, messageFromQueryEvent, messageFromResponse, messageFromSuggestionEvent, messageRequestToCommerceMessageRequest, prepareMerchantPage, validateEmail } from "../../utils-B4PvsKVY.js";
21
21
  import { DOMObserver, ElementObserver, MutationHelper } from "../../domObserver-DEiUh0qg.js";
22
22
 
23
23
  export { DOMObserver, ElementObserver, MutationHelper, NodeSelector, SelectorFactory, StringUtils, applyOverrides, buildSearchHash, buildSearchStartHash, coreContextToApiContext, coreSupportedEventRequestToApiRequest, coreUserEventToApiUserEvent, createUrlWithQueryParams, divideArray, getQueryParam, getRecentProductImageUrls, initAmplitude, initDataLayerWrapper, messageFromFormSubmittedEvent, messageFromQueryEvent, messageFromResponse, messageFromSuggestionEvent, messageRequestToCommerceMessageRequest, parseHref, parseSearchHash, prepareMerchantPage, validateEmail };
@@ -12,12 +12,12 @@ import "../../search-6RrxBXD6.cjs";
12
12
  import { VariantInfo } from "../../index-OkKEOL6H.cjs";
13
13
  import { UserIdentityContextType } from "../../userIdentityContext-kU1PIo8K.cjs";
14
14
  import { ContextEnvEnum, ContextSourceEnum, PageVisitCategory } from "@spiffy-ai/commerce-api-client";
15
- import * as jotai22 from "jotai";
15
+ import * as jotai8 from "jotai";
16
16
  import * as jotai_utils0 from "jotai/utils";
17
17
 
18
18
  //#region src/atoms/app/variant.d.ts
19
19
 
20
- declare const variantInfoAtom: jotai22.WritableAtom<VariantInfo, [newVariant: VariantInfo], void>;
20
+ declare const variantInfoAtom: jotai8.WritableAtom<VariantInfo, [newVariant: VariantInfo], void>;
21
21
  //#endregion
22
22
  //#region src/atoms/app/index.d.ts
23
23
  interface AppDetails {
@@ -29,12 +29,12 @@ interface AppDetails {
29
29
  env: ContextEnvEnum;
30
30
  variantInfo: VariantInfo;
31
31
  }
32
- declare const userIdAtom: jotai22.WritableAtom<string, [value: string | undefined], void>;
33
- declare const userIdentityAtom: jotai22.PrimitiveAtom<UserIdentityContextType | undefined> & {
32
+ declare const userIdAtom: jotai8.WritableAtom<string, [value: string | undefined], void>;
33
+ declare const userIdentityAtom: jotai8.PrimitiveAtom<UserIdentityContextType | undefined> & {
34
34
  init: UserIdentityContextType | undefined;
35
35
  };
36
- declare const appSourceAtom: jotai22.Atom<ContextSourceEnum>;
37
- declare const chatIdAtom: jotai22.WritableAtom<string, [string | typeof jotai_utils0.RESET | ((prev: string) => string | typeof jotai_utils0.RESET)], void>;
36
+ declare const appSourceAtom: jotai8.Atom<ContextSourceEnum>;
37
+ declare const chatIdAtom: jotai8.WritableAtom<string, [string | typeof jotai_utils0.RESET | ((prev: string) => string | typeof jotai_utils0.RESET)], void>;
38
38
  //#endregion
39
39
  export { AppDetails, appSourceAtom, chatIdAtom, userIdAtom, userIdentityAtom, variantInfoAtom };
40
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC5jdHMiLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2F0b21zL2FwcC92YXJpYW50LmQudHMiLCIuLi8uLi8uLi9zcmMvYXRvbXMvYXBwL2luZGV4LmQudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU3VwcG9ydGVkRXZlbnRSZXNwb25zZSwgUGFnZVZpc2l0Q2F0ZWdvcnkgfSBmcm9tICdAc3BpZmZ5LWFpL2NvbW1lcmNlLWFwaS1jbGllbnQnO1xuaW1wb3J0IHsgVmFyaWFudEluZm8gfSBmcm9tICdzcmMvYXBwbGljYXRpb24vbW9kZWxzJztcbmV4cG9ydCBpbnRlcmZhY2UgU3VwcG9ydGVkRXZlbnQgZXh0ZW5kcyBQaWNrPFN1cHBvcnRlZEV2ZW50UmVzcG9uc2UsICdzdXBwb3J0ZWQnIHwgJ3JlYWR5JyB8ICdjYXRlZ29yeScgfCAnY29sbGVjdGlvbnMnIHwgJ3RvcF9jYXRlZ29yeSc+IHtcbiAgICBudW1iZXJPZlJldmlld3M6IG51bWJlciB8IHVuZGVmaW5lZDtcbiAgICBtZXJjaGFudF90YWdzPzogc3RyaW5nW107XG59XG5pbnRlcmZhY2UgUERQQXR0cmlidXRlcyB7XG4gICAgcHJvZHVjdF9pZD86IHN0cmluZztcbn1cbmludGVyZmFjZSBQTFBBdHRyaWJ1dGVzIHtcbiAgICBhdHRyaWJ1dGVzPzoge1xuICAgICAgICBpZD86IHN0cmluZztcbiAgICB9O1xufVxuZXhwb3J0IGludGVyZmFjZSBVcmxSZXNvbHZpbmdQRFBDb25maWcge1xuICAgIHBkcF9hdHRyaWJ1dGVzOiBQRFBBdHRyaWJ1dGVzO1xuICAgIG51bWJlcl9vZl9yZXZpZXdzPzogbnVtYmVyO1xuICAgIGNvbGxlY3Rpb25zPzogc3RyaW5nW107XG4gICAgbWVyY2hhbnRfdGFncz86IHN0cmluZ1tdO1xufVxuZXhwb3J0IGludGVyZmFjZSBVcmxSZXNvbHZpbmdQTFBDb25maWcge1xuICAgIHBscF9hdHRyaWJ1dGVzOiBQTFBBdHRyaWJ1dGVzO1xuICAgIHRvcF9jYXRlZ29yeT86IHN0cmluZztcbn1cbmludGVyZmFjZSBVcmxSZXNvbHZpbmdHZW5lcmljQ29uZmlnIHtcbiAgICBkZXRhaWxzPzogc3RyaW5nO1xufVxuZXhwb3J0IHR5cGUgUGFnZVZhcmlhbnRDaGVja0NvbmZpZyA9IHtcbiAgICBjaGVja190eXBlOiBzdHJpbmc7XG4gICAgZmVhdHVyZV9nYXRlPzogc3RyaW5nO1xuICAgIGV4dHJhY3Rvcj86IHtcbiAgICAgICAgdHlwZTogc3RyaW5nO1xuICAgICAgICBtYXA/OiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmdbXT47XG4gICAgICAgIHZhbHVlPzogc3RyaW5nO1xuICAgIH07XG4gICAgcHJvZHVjdF9pZF9leHRyYWN0b3I/OiBzdHJpbmc7XG4gICAgcHJvZHVjdF9pZHM/OiBzdHJpbmdbXTtcbiAgICBwbHBfaWRfZXh0cmFjdG9yPzogc3RyaW5nO1xuICAgIHBscF9pZHM/OiBzdHJpbmdbXTtcbiAgICBjb2xsZWN0aW9ucz86IHN0cmluZ1tdO1xuICAgIHF1ZXJ5X3BhcmFtPzogc3RyaW5nO1xuICAgIGNhdGVnb3J5Pzogc3RyaW5nO1xuICAgIHRvcF9jYXRlZ29yeT86IHN0cmluZ1tdO1xuICAgIHJldmlld19taW5pbXVtPzogbnVtYmVyO1xuICAgIG1lcmNoYW50X3RhZ3M/OiBzdHJpbmdbXTtcbn07XG5leHBvcnQgdHlwZSBCYWNrZW5kV2lkZ2V0TW91bnRpbmdDb25maWcgPSB7XG4gICAgbW91bnRpbmdfY29uZmlnX2lkOiBzdHJpbmc7XG4gICAgd2lkZ2V0X2NvbmZpZ19pZD86IHN0cmluZztcbiAgICBtb3VudGluZ19wb2ludF93aWRnZXRzPzogQXJyYXk8e1xuICAgICAgICBjaGVja3M6IFBhZ2VWYXJpYW50Q2hlY2tDb25maWdbXTtcbiAgICAgICAgd2lkZ2V0X2NvbmZpZ19pZDogc3RyaW5nO1xuICAgIH0+O1xufTtcbmV4cG9ydCB0eXBlIEJhY2tlbmRQYWdlVmFyaWFudENvbmZpZyA9IHtcbiAgICB2YXJpYW50X2lkOiBzdHJpbmc7XG4gICAgdmFyaWFudF90eXBlOiBzdHJpbmc7XG4gICAgdmFyaWFudF9jaGVja3M6IFBhZ2VWYXJpYW50Q2hlY2tDb25maWdbXTtcbiAgICB3aWRnZXRfbW91bnRpbmc6IEJhY2tlbmRXaWRnZXRNb3VudGluZ0NvbmZpZ1tdO1xuICAgIHBscF9pZF9leHRyYWN0b3I/OiBzdHJpbmc7XG4gICAgcHJvZHVjdF9pZF9leHRyYWN0b3I/OiBzdHJpbmc7XG4gICAgcGFyZW50X3Byb2R1Y3RfaWRfZXh0cmFjdG9yPzogc3RyaW5nO1xufTtcbmV4cG9ydCBpbnRlcmZhY2UgVXJsUmVzb2x2ZXJSZXNwb25zZSB7XG4gICAgdmFyaWFudF90eXBlOiBzdHJpbmc7XG4gICAgc3BlY2lmaWNfZGV0YWlsczogVXJsUmVzb2x2aW5nUERQQ29uZmlnIHwgVXJsUmVzb2x2aW5nUExQQ29uZmlnIHwgVXJsUmVzb2x2aW5nR2VuZXJpY0NvbmZpZztcbiAgICByZWFkeTogYm9vbGVhbjtcbiAgICB1c2VyX2V2ZW50Pzoge1xuICAgICAgICBldmVudF9pZD86IHN0cmluZztcbiAgICAgICAgYXR0cmlidXRlcz86IFBEUEF0dHJpYnV0ZXMgfCBQTFBBdHRyaWJ1dGVzO1xuICAgICAgICBjYXRlZ29yeT86IHN0cmluZztcbiAgICAgICAgY3JlYXRlZF9hdD86IHN0cmluZztcbiAgICB9O1xuICAgIHBhZ2VfdmFyaWFudD86IEJhY2tlbmRQYWdlVmFyaWFudENvbmZpZztcbn1cbmV4cG9ydCB0eXBlIFVybFJlc29sdmVyQ2FjaGUgPSBSZWNvcmQ8c3RyaW5nLCBVcmxSZXNvbHZlclJlc3BvbnNlIHwgdW5kZWZpbmVkPjtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHVybFJlc29sdmVyQXRvbTogaW1wb3J0KFwiam90YWlcIikuV3JpdGFibGVBdG9tPFVybFJlc29sdmVyQ2FjaGUsIFt2YWx1ZToge1xuICAgIHVybDogc3RyaW5nO1xuICAgIHJlc3BvbnNlOiBVcmxSZXNvbHZlclJlc3BvbnNlIHwgdW5kZWZpbmVkO1xufV0sIHZvaWQ+O1xuZXhwb3J0IGRlY2xhcmUgY29uc3Qgc3VwcG9ydGVkRXZlbnRBdG9tOiBpbXBvcnQoXCJqb3RhaVwiKS5Xcml0YWJsZUF0b208U3VwcG9ydGVkRXZlbnQgfCB1bmRlZmluZWQsIFt2YWx1ZTogU3VwcG9ydGVkRXZlbnQgfCB1bmRlZmluZWRdLCB2b2lkPjtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHZhcmlhbnRJZEF0b206IGltcG9ydChcImpvdGFpXCIpLkF0b208c3RyaW5nIHwgdW5kZWZpbmVkPjtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHByb2R1Y3RJZEF0b206IGltcG9ydChcImpvdGFpXCIpLkF0b208c3RyaW5nIHwgdW5kZWZpbmVkPjtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHBhcmVudFByb2R1Y3RJZEF0b206IGltcG9ydChcImpvdGFpXCIpLkF0b208c3RyaW5nIHwgdW5kZWZpbmVkPjtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHByb2R1Y3RVcmxBdG9tOiBpbXBvcnQoXCJqb3RhaVwiKS5BdG9tPHN0cmluZyB8IHVuZGVmaW5lZD47XG5leHBvcnQgZGVjbGFyZSBjb25zdCBwbHBJZEF0b206IGltcG9ydChcImpvdGFpXCIpLkF0b208c3RyaW5nIHwgdW5kZWZpbmVkPjtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHVybEF0b206IGltcG9ydChcImpvdGFpXCIpLkF0b208c3RyaW5nIHwgdW5kZWZpbmVkPjtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHBhZ2VWaXNpdENhdGVnb3J5QXRvbTogaW1wb3J0KFwiam90YWlcIikuQXRvbTxQYWdlVmlzaXRDYXRlZ29yeSB8IHVuZGVmaW5lZD47XG5leHBvcnQgZGVjbGFyZSBjb25zdCB2YXJpYW50QXRvbTogaW1wb3J0KFwiam90YWlcIikuQXRvbTxcInNlYXJjaFwiIHwgXCJwZHBcIiB8IFwicGxwXCIgfCBcInBhZ2VfdmlzaXRcIj47XG5leHBvcnQgZGVjbGFyZSBjb25zdCBoYXNQYXJzZWRWYXJpYW50SW5mb0F0b206IGltcG9ydChcImpvdGFpXCIpLlByaW1pdGl2ZUF0b208Ym9vbGVhbj4gJiB7XG4gICAgaW5pdDogYm9vbGVhbjtcbn07XG5leHBvcnQgZGVjbGFyZSBjb25zdCB2YXJpYW50SW5mb0F0b206IGltcG9ydChcImpvdGFpXCIpLldyaXRhYmxlQXRvbTxWYXJpYW50SW5mbywgW25ld1ZhcmlhbnQ6IFZhcmlhbnRJbmZvXSwgdm9pZD47XG5leHBvcnQge307XG4iLCJpbXBvcnQgeyBDb250ZXh0RW52RW51bSwgQ29udGV4dFNvdXJjZUVudW0gfSBmcm9tIFwiQHNwaWZmeS1haS9jb21tZXJjZS1hcGktY2xpZW50XCI7XG5pbXBvcnQgeyBWYXJpYW50SW5mbyB9IGZyb20gXCJzcmMvYXBwbGljYXRpb24vbW9kZWxzXCI7XG5pbXBvcnQgeyBVc2VySWRlbnRpdHlDb250ZXh0VHlwZSB9IGZyb20gXCJzcmMvY29udGV4dHMvdXNlcklkZW50aXR5Q29udGV4dC91c2VySWRlbnRpdHlDb250ZXh0XCI7XG5leHBvcnQgaW50ZXJmYWNlIEFwcERldGFpbHMge1xuICAgIG9yZ0lkOiBzdHJpbmc7XG4gICAgb3JnU2hvcnROYW1lOiBzdHJpbmc7XG4gICAgY2hhdElkOiBzdHJpbmc7XG4gICAgdXNlcklkOiBzdHJpbmc7XG4gICAgc291cmNlOiBDb250ZXh0U291cmNlRW51bTtcbiAgICBlbnY6IENvbnRleHRFbnZFbnVtO1xuICAgIHZhcmlhbnRJbmZvOiBWYXJpYW50SW5mbztcbn1cbmV4cG9ydCB7IHZhcmlhbnRJbmZvQXRvbSB9IGZyb20gXCIuL3ZhcmlhbnRcIjtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHVzZXJJZEF0b206IGltcG9ydChcImpvdGFpXCIpLldyaXRhYmxlQXRvbTxzdHJpbmcsIFt2YWx1ZTogc3RyaW5nIHwgdW5kZWZpbmVkXSwgdm9pZD47XG5leHBvcnQgZGVjbGFyZSBjb25zdCB1c2VySWRlbnRpdHlBdG9tOiBpbXBvcnQoXCJqb3RhaVwiKS5QcmltaXRpdmVBdG9tPFVzZXJJZGVudGl0eUNvbnRleHRUeXBlIHwgdW5kZWZpbmVkPiAmIHtcbiAgICBpbml0OiBVc2VySWRlbnRpdHlDb250ZXh0VHlwZSB8IHVuZGVmaW5lZDtcbn07XG5leHBvcnQgZGVjbGFyZSBjb25zdCBhcHBTb3VyY2VBdG9tOiBpbXBvcnQoXCJqb3RhaVwiKS5BdG9tPENvbnRleHRTb3VyY2VFbnVtPjtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IGNoYXRJZEF0b206IGltcG9ydChcImpvdGFpXCIpLldyaXRhYmxlQXRvbTxzdHJpbmcsIFtzdHJpbmcgfCB0eXBlb2YgaW1wb3J0KFwiam90YWkvdXRpbHNcIikuUkVTRVQgfCAoKHByZXY6IHN0cmluZykgPT4gc3RyaW5nIHwgdHlwZW9mIGltcG9ydChcImpvdGFpL3V0aWxzXCIpLlJFU0VUKV0sIHZvaWQ+O1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7QUF5QkEsSUFBVyxrQkFBUztDQUFBO09BQUE7T0FBQTtPQUFBLFFBQUE7Q0FBQTs7OztBQ3BCcEIsSUFBVyxhQUFhO0NBQUE7T0FBQTtPQUFBO09BQUE7Q0FBQTtBQUV4QixJQUFXLGFBQU8sQ0FBQSxXQUFBLFFBQUEsYUFBQTtBQUNsQixJQUFXLG1CQUFrQjtDQUFBO09BQUE7T0FBQSxRQUFBO09BQUE7Q0FBQTtBQUM3QixJQUFXLGdCQUFZO0NBQUE7T0FBQTtPQUFBLFFBQUE7Q0FBQTtBQUN2QixJQUFXLGFBQWE7Q0FBQztPQUFHLGFBQUE7T0FBQSxhQUFBO09BQUEsUUFBQTtDQUFBIn0=
40
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC5jdHMiLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2F0b21zL2FwcC92YXJpYW50LmQudHMiLCIuLi8uLi8uLi9zcmMvYXRvbXMvYXBwL2luZGV4LmQudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU3VwcG9ydGVkRXZlbnRSZXNwb25zZSwgUGFnZVZpc2l0Q2F0ZWdvcnkgfSBmcm9tICdAc3BpZmZ5LWFpL2NvbW1lcmNlLWFwaS1jbGllbnQnO1xuaW1wb3J0IHsgVmFyaWFudEluZm8gfSBmcm9tICdzcmMvYXBwbGljYXRpb24vbW9kZWxzJztcbmV4cG9ydCBpbnRlcmZhY2UgU3VwcG9ydGVkRXZlbnQgZXh0ZW5kcyBQaWNrPFN1cHBvcnRlZEV2ZW50UmVzcG9uc2UsICdzdXBwb3J0ZWQnIHwgJ3JlYWR5JyB8ICdjYXRlZ29yeScgfCAnY29sbGVjdGlvbnMnIHwgJ3RvcF9jYXRlZ29yeSc+IHtcbiAgICBudW1iZXJPZlJldmlld3M6IG51bWJlciB8IHVuZGVmaW5lZDtcbiAgICBtZXJjaGFudF90YWdzPzogc3RyaW5nW107XG59XG5pbnRlcmZhY2UgUERQQXR0cmlidXRlcyB7XG4gICAgcHJvZHVjdF9pZD86IHN0cmluZztcbn1cbmludGVyZmFjZSBQTFBBdHRyaWJ1dGVzIHtcbiAgICBhdHRyaWJ1dGVzPzoge1xuICAgICAgICBpZD86IHN0cmluZztcbiAgICB9O1xufVxuZXhwb3J0IGludGVyZmFjZSBVcmxSZXNvbHZpbmdQRFBDb25maWcge1xuICAgIHBkcF9hdHRyaWJ1dGVzOiBQRFBBdHRyaWJ1dGVzO1xuICAgIG51bWJlcl9vZl9yZXZpZXdzPzogbnVtYmVyO1xuICAgIGNvbGxlY3Rpb25zPzogc3RyaW5nW107XG4gICAgbWVyY2hhbnRfdGFncz86IHN0cmluZ1tdO1xufVxuZXhwb3J0IGludGVyZmFjZSBVcmxSZXNvbHZpbmdQTFBDb25maWcge1xuICAgIHBscF9hdHRyaWJ1dGVzOiBQTFBBdHRyaWJ1dGVzO1xuICAgIHRvcF9jYXRlZ29yeT86IHN0cmluZztcbn1cbmludGVyZmFjZSBVcmxSZXNvbHZpbmdHZW5lcmljQ29uZmlnIHtcbiAgICBkZXRhaWxzPzogc3RyaW5nO1xufVxuZXhwb3J0IHR5cGUgUGFnZVZhcmlhbnRDaGVja0NvbmZpZyA9IHtcbiAgICBjaGVja190eXBlOiBzdHJpbmc7XG4gICAgZmVhdHVyZV9nYXRlPzogc3RyaW5nO1xuICAgIGV4dHJhY3Rvcj86IHtcbiAgICAgICAgdHlwZTogc3RyaW5nO1xuICAgICAgICBtYXA/OiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmdbXT47XG4gICAgICAgIHZhbHVlPzogc3RyaW5nO1xuICAgIH07XG4gICAgcHJvZHVjdF9pZF9leHRyYWN0b3I/OiBzdHJpbmc7XG4gICAgcHJvZHVjdF9pZHM/OiBzdHJpbmdbXTtcbiAgICBwbHBfaWRfZXh0cmFjdG9yPzogc3RyaW5nO1xuICAgIHBscF9pZHM/OiBzdHJpbmdbXTtcbiAgICBjb2xsZWN0aW9ucz86IHN0cmluZ1tdO1xuICAgIHF1ZXJ5X3BhcmFtPzogc3RyaW5nO1xuICAgIGNhdGVnb3J5Pzogc3RyaW5nO1xuICAgIHRvcF9jYXRlZ29yeT86IHN0cmluZ1tdO1xuICAgIHJldmlld19taW5pbXVtPzogbnVtYmVyO1xuICAgIG1lcmNoYW50X3RhZ3M/OiBzdHJpbmdbXTtcbn07XG5leHBvcnQgdHlwZSBCYWNrZW5kV2lkZ2V0TW91bnRpbmdDb25maWcgPSB7XG4gICAgbW91bnRpbmdfY29uZmlnX2lkOiBzdHJpbmc7XG4gICAgd2lkZ2V0X2NvbmZpZ19pZD86IHN0cmluZztcbiAgICBtb3VudGluZ19wb2ludF93aWRnZXRzPzogQXJyYXk8e1xuICAgICAgICBjaGVja3M6IFBhZ2VWYXJpYW50Q2hlY2tDb25maWdbXTtcbiAgICAgICAgd2lkZ2V0X2NvbmZpZ19pZDogc3RyaW5nO1xuICAgIH0+O1xufTtcbmV4cG9ydCB0eXBlIEJhY2tlbmRQYWdlVmFyaWFudENvbmZpZyA9IHtcbiAgICB2YXJpYW50X2lkOiBzdHJpbmc7XG4gICAgdmFyaWFudF90eXBlOiBzdHJpbmc7XG4gICAgdmFyaWFudF9jaGVja3M6IFBhZ2VWYXJpYW50Q2hlY2tDb25maWdbXTtcbiAgICB3aWRnZXRfbW91bnRpbmc6IEJhY2tlbmRXaWRnZXRNb3VudGluZ0NvbmZpZ1tdO1xuICAgIHBscF9pZF9leHRyYWN0b3I/OiBzdHJpbmc7XG4gICAgcHJvZHVjdF9pZF9leHRyYWN0b3I/OiBzdHJpbmc7XG4gICAgcGFyZW50X3Byb2R1Y3RfaWRfZXh0cmFjdG9yPzogc3RyaW5nO1xufTtcbmV4cG9ydCBpbnRlcmZhY2UgVXJsUmVzb2x2ZXJSZXNwb25zZSB7XG4gICAgdmFyaWFudF90eXBlOiBzdHJpbmc7XG4gICAgc3BlY2lmaWNfZGV0YWlsczogVXJsUmVzb2x2aW5nUERQQ29uZmlnIHwgVXJsUmVzb2x2aW5nUExQQ29uZmlnIHwgVXJsUmVzb2x2aW5nR2VuZXJpY0NvbmZpZztcbiAgICByZWFkeTogYm9vbGVhbjtcbiAgICB1c2VyX2V2ZW50Pzoge1xuICAgICAgICBldmVudF9pZD86IHN0cmluZztcbiAgICAgICAgYXR0cmlidXRlcz86IFBEUEF0dHJpYnV0ZXMgfCBQTFBBdHRyaWJ1dGVzO1xuICAgICAgICBjYXRlZ29yeT86IHN0cmluZztcbiAgICAgICAgY3JlYXRlZF9hdD86IHN0cmluZztcbiAgICB9O1xuICAgIHBhZ2VfdmFyaWFudD86IEJhY2tlbmRQYWdlVmFyaWFudENvbmZpZztcbn1cbmV4cG9ydCB0eXBlIFVybFJlc29sdmVyQ2FjaGUgPSBSZWNvcmQ8c3RyaW5nLCBVcmxSZXNvbHZlclJlc3BvbnNlIHwgdW5kZWZpbmVkPjtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHVybFJlc29sdmVyQXRvbTogaW1wb3J0KFwiam90YWlcIikuV3JpdGFibGVBdG9tPFVybFJlc29sdmVyQ2FjaGUsIFt2YWx1ZToge1xuICAgIHVybDogc3RyaW5nO1xuICAgIHJlc3BvbnNlOiBVcmxSZXNvbHZlclJlc3BvbnNlIHwgdW5kZWZpbmVkO1xufV0sIHZvaWQ+O1xuZXhwb3J0IGRlY2xhcmUgY29uc3Qgc3VwcG9ydGVkRXZlbnRBdG9tOiBpbXBvcnQoXCJqb3RhaVwiKS5Xcml0YWJsZUF0b208U3VwcG9ydGVkRXZlbnQgfCB1bmRlZmluZWQsIFt2YWx1ZTogU3VwcG9ydGVkRXZlbnQgfCB1bmRlZmluZWRdLCB2b2lkPjtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHZhcmlhbnRJZEF0b206IGltcG9ydChcImpvdGFpXCIpLkF0b208c3RyaW5nIHwgdW5kZWZpbmVkPjtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHByb2R1Y3RJZEF0b206IGltcG9ydChcImpvdGFpXCIpLkF0b208c3RyaW5nIHwgdW5kZWZpbmVkPjtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHBhcmVudFByb2R1Y3RJZEF0b206IGltcG9ydChcImpvdGFpXCIpLkF0b208c3RyaW5nIHwgdW5kZWZpbmVkPjtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHByb2R1Y3RVcmxBdG9tOiBpbXBvcnQoXCJqb3RhaVwiKS5BdG9tPHN0cmluZyB8IHVuZGVmaW5lZD47XG5leHBvcnQgZGVjbGFyZSBjb25zdCBwbHBJZEF0b206IGltcG9ydChcImpvdGFpXCIpLkF0b208c3RyaW5nIHwgdW5kZWZpbmVkPjtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHVybEF0b206IGltcG9ydChcImpvdGFpXCIpLkF0b208c3RyaW5nIHwgdW5kZWZpbmVkPjtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHBhZ2VWaXNpdENhdGVnb3J5QXRvbTogaW1wb3J0KFwiam90YWlcIikuQXRvbTxQYWdlVmlzaXRDYXRlZ29yeSB8IHVuZGVmaW5lZD47XG5leHBvcnQgZGVjbGFyZSBjb25zdCB2YXJpYW50QXRvbTogaW1wb3J0KFwiam90YWlcIikuQXRvbTxcInNlYXJjaFwiIHwgXCJwZHBcIiB8IFwicGxwXCIgfCBcInBhZ2VfdmlzaXRcIj47XG5leHBvcnQgZGVjbGFyZSBjb25zdCBoYXNQYXJzZWRWYXJpYW50SW5mb0F0b206IGltcG9ydChcImpvdGFpXCIpLlByaW1pdGl2ZUF0b208Ym9vbGVhbj4gJiB7XG4gICAgaW5pdDogYm9vbGVhbjtcbn07XG5leHBvcnQgZGVjbGFyZSBjb25zdCB2YXJpYW50SW5mb0F0b206IGltcG9ydChcImpvdGFpXCIpLldyaXRhYmxlQXRvbTxWYXJpYW50SW5mbywgW25ld1ZhcmlhbnQ6IFZhcmlhbnRJbmZvXSwgdm9pZD47XG5leHBvcnQge307XG4iLCJpbXBvcnQgeyBDb250ZXh0RW52RW51bSwgQ29udGV4dFNvdXJjZUVudW0gfSBmcm9tIFwiQHNwaWZmeS1haS9jb21tZXJjZS1hcGktY2xpZW50XCI7XG5pbXBvcnQgeyBWYXJpYW50SW5mbyB9IGZyb20gXCJzcmMvYXBwbGljYXRpb24vbW9kZWxzXCI7XG5pbXBvcnQgeyBVc2VySWRlbnRpdHlDb250ZXh0VHlwZSB9IGZyb20gXCJzcmMvY29udGV4dHMvdXNlcklkZW50aXR5Q29udGV4dC91c2VySWRlbnRpdHlDb250ZXh0XCI7XG5leHBvcnQgaW50ZXJmYWNlIEFwcERldGFpbHMge1xuICAgIG9yZ0lkOiBzdHJpbmc7XG4gICAgb3JnU2hvcnROYW1lOiBzdHJpbmc7XG4gICAgY2hhdElkOiBzdHJpbmc7XG4gICAgdXNlcklkOiBzdHJpbmc7XG4gICAgc291cmNlOiBDb250ZXh0U291cmNlRW51bTtcbiAgICBlbnY6IENvbnRleHRFbnZFbnVtO1xuICAgIHZhcmlhbnRJbmZvOiBWYXJpYW50SW5mbztcbn1cbmV4cG9ydCB7IHZhcmlhbnRJbmZvQXRvbSB9IGZyb20gXCIuL3ZhcmlhbnRcIjtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHVzZXJJZEF0b206IGltcG9ydChcImpvdGFpXCIpLldyaXRhYmxlQXRvbTxzdHJpbmcsIFt2YWx1ZTogc3RyaW5nIHwgdW5kZWZpbmVkXSwgdm9pZD47XG5leHBvcnQgZGVjbGFyZSBjb25zdCB1c2VySWRlbnRpdHlBdG9tOiBpbXBvcnQoXCJqb3RhaVwiKS5QcmltaXRpdmVBdG9tPFVzZXJJZGVudGl0eUNvbnRleHRUeXBlIHwgdW5kZWZpbmVkPiAmIHtcbiAgICBpbml0OiBVc2VySWRlbnRpdHlDb250ZXh0VHlwZSB8IHVuZGVmaW5lZDtcbn07XG5leHBvcnQgZGVjbGFyZSBjb25zdCBhcHBTb3VyY2VBdG9tOiBpbXBvcnQoXCJqb3RhaVwiKS5BdG9tPENvbnRleHRTb3VyY2VFbnVtPjtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IGNoYXRJZEF0b206IGltcG9ydChcImpvdGFpXCIpLldyaXRhYmxlQXRvbTxzdHJpbmcsIFtzdHJpbmcgfCB0eXBlb2YgaW1wb3J0KFwiam90YWkvdXRpbHNcIikuUkVTRVQgfCAoKHByZXY6IHN0cmluZykgPT4gc3RyaW5nIHwgdHlwZW9mIGltcG9ydChcImpvdGFpL3V0aWxzXCIpLlJFU0VUKV0sIHZvaWQ+O1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7QUF5QkEsSUFBVyxrQkFBUztDQUFBO09BQUE7T0FBQTtPQUFBLE9BQUE7Q0FBQTs7OztBQ3BCcEIsSUFBVyxhQUFhO0NBQUE7T0FBQTtPQUFBO09BQUE7Q0FBQTtBQUV4QixJQUFXLGFBQU8sQ0FBQSxXQUFBLE9BQUEsYUFBQTtBQUNsQixJQUFXLG1CQUFrQjtDQUFBO09BQUE7T0FBQSxPQUFBO09BQUE7Q0FBQTtBQUM3QixJQUFXLGdCQUFZO0NBQUE7T0FBQTtPQUFBLE9BQUE7Q0FBQTtBQUN2QixJQUFXLGFBQWE7Q0FBQztPQUFHLGFBQUE7T0FBQSxhQUFBO09BQUEsT0FBQTtDQUFBIn0=
@@ -37,4 +37,4 @@ declare const appSourceAtom: jotai74.Atom<ContextSourceEnum>;
37
37
  declare const chatIdAtom: jotai74.WritableAtom<string, [string | typeof jotai_utils0.RESET | ((prev: string) => string | typeof jotai_utils0.RESET)], void>;
38
38
  //#endregion
39
39
  export { AppDetails, appSourceAtom, chatIdAtom, userIdAtom, userIdentityAtom, variantInfoAtom };
40
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsIm5hbWVzIjpbXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXRvbXMvYXBwL3ZhcmlhbnQuZC50cyIsIi4uLy4uLy4uL3NyYy9hdG9tcy9hcHAvaW5kZXguZC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTdXBwb3J0ZWRFdmVudFJlc3BvbnNlLCBQYWdlVmlzaXRDYXRlZ29yeSB9IGZyb20gJ0BzcGlmZnktYWkvY29tbWVyY2UtYXBpLWNsaWVudCc7XG5pbXBvcnQgeyBWYXJpYW50SW5mbyB9IGZyb20gJ3NyYy9hcHBsaWNhdGlvbi9tb2RlbHMnO1xuZXhwb3J0IGludGVyZmFjZSBTdXBwb3J0ZWRFdmVudCBleHRlbmRzIFBpY2s8U3VwcG9ydGVkRXZlbnRSZXNwb25zZSwgJ3N1cHBvcnRlZCcgfCAncmVhZHknIHwgJ2NhdGVnb3J5JyB8ICdjb2xsZWN0aW9ucycgfCAndG9wX2NhdGVnb3J5Jz4ge1xuICAgIG51bWJlck9mUmV2aWV3czogbnVtYmVyIHwgdW5kZWZpbmVkO1xuICAgIG1lcmNoYW50X3RhZ3M/OiBzdHJpbmdbXTtcbn1cbmludGVyZmFjZSBQRFBBdHRyaWJ1dGVzIHtcbiAgICBwcm9kdWN0X2lkPzogc3RyaW5nO1xufVxuaW50ZXJmYWNlIFBMUEF0dHJpYnV0ZXMge1xuICAgIGF0dHJpYnV0ZXM/OiB7XG4gICAgICAgIGlkPzogc3RyaW5nO1xuICAgIH07XG59XG5leHBvcnQgaW50ZXJmYWNlIFVybFJlc29sdmluZ1BEUENvbmZpZyB7XG4gICAgcGRwX2F0dHJpYnV0ZXM6IFBEUEF0dHJpYnV0ZXM7XG4gICAgbnVtYmVyX29mX3Jldmlld3M/OiBudW1iZXI7XG4gICAgY29sbGVjdGlvbnM/OiBzdHJpbmdbXTtcbiAgICBtZXJjaGFudF90YWdzPzogc3RyaW5nW107XG59XG5leHBvcnQgaW50ZXJmYWNlIFVybFJlc29sdmluZ1BMUENvbmZpZyB7XG4gICAgcGxwX2F0dHJpYnV0ZXM6IFBMUEF0dHJpYnV0ZXM7XG4gICAgdG9wX2NhdGVnb3J5Pzogc3RyaW5nO1xufVxuaW50ZXJmYWNlIFVybFJlc29sdmluZ0dlbmVyaWNDb25maWcge1xuICAgIGRldGFpbHM/OiBzdHJpbmc7XG59XG5leHBvcnQgdHlwZSBQYWdlVmFyaWFudENoZWNrQ29uZmlnID0ge1xuICAgIGNoZWNrX3R5cGU6IHN0cmluZztcbiAgICBmZWF0dXJlX2dhdGU/OiBzdHJpbmc7XG4gICAgZXh0cmFjdG9yPzoge1xuICAgICAgICB0eXBlOiBzdHJpbmc7XG4gICAgICAgIG1hcD86IFJlY29yZDxzdHJpbmcsIHN0cmluZ1tdPjtcbiAgICAgICAgdmFsdWU/OiBzdHJpbmc7XG4gICAgfTtcbiAgICBwcm9kdWN0X2lkX2V4dHJhY3Rvcj86IHN0cmluZztcbiAgICBwcm9kdWN0X2lkcz86IHN0cmluZ1tdO1xuICAgIHBscF9pZF9leHRyYWN0b3I/OiBzdHJpbmc7XG4gICAgcGxwX2lkcz86IHN0cmluZ1tdO1xuICAgIGNvbGxlY3Rpb25zPzogc3RyaW5nW107XG4gICAgcXVlcnlfcGFyYW0/OiBzdHJpbmc7XG4gICAgY2F0ZWdvcnk/OiBzdHJpbmc7XG4gICAgdG9wX2NhdGVnb3J5Pzogc3RyaW5nW107XG4gICAgcmV2aWV3X21pbmltdW0/OiBudW1iZXI7XG4gICAgbWVyY2hhbnRfdGFncz86IHN0cmluZ1tdO1xufTtcbmV4cG9ydCB0eXBlIEJhY2tlbmRXaWRnZXRNb3VudGluZ0NvbmZpZyA9IHtcbiAgICBtb3VudGluZ19jb25maWdfaWQ6IHN0cmluZztcbiAgICB3aWRnZXRfY29uZmlnX2lkPzogc3RyaW5nO1xuICAgIG1vdW50aW5nX3BvaW50X3dpZGdldHM/OiBBcnJheTx7XG4gICAgICAgIGNoZWNrczogUGFnZVZhcmlhbnRDaGVja0NvbmZpZ1tdO1xuICAgICAgICB3aWRnZXRfY29uZmlnX2lkOiBzdHJpbmc7XG4gICAgfT47XG59O1xuZXhwb3J0IHR5cGUgQmFja2VuZFBhZ2VWYXJpYW50Q29uZmlnID0ge1xuICAgIHZhcmlhbnRfaWQ6IHN0cmluZztcbiAgICB2YXJpYW50X3R5cGU6IHN0cmluZztcbiAgICB2YXJpYW50X2NoZWNrczogUGFnZVZhcmlhbnRDaGVja0NvbmZpZ1tdO1xuICAgIHdpZGdldF9tb3VudGluZzogQmFja2VuZFdpZGdldE1vdW50aW5nQ29uZmlnW107XG4gICAgcGxwX2lkX2V4dHJhY3Rvcj86IHN0cmluZztcbiAgICBwcm9kdWN0X2lkX2V4dHJhY3Rvcj86IHN0cmluZztcbiAgICBwYXJlbnRfcHJvZHVjdF9pZF9leHRyYWN0b3I/OiBzdHJpbmc7XG59O1xuZXhwb3J0IGludGVyZmFjZSBVcmxSZXNvbHZlclJlc3BvbnNlIHtcbiAgICB2YXJpYW50X3R5cGU6IHN0cmluZztcbiAgICBzcGVjaWZpY19kZXRhaWxzOiBVcmxSZXNvbHZpbmdQRFBDb25maWcgfCBVcmxSZXNvbHZpbmdQTFBDb25maWcgfCBVcmxSZXNvbHZpbmdHZW5lcmljQ29uZmlnO1xuICAgIHJlYWR5OiBib29sZWFuO1xuICAgIHVzZXJfZXZlbnQ/OiB7XG4gICAgICAgIGV2ZW50X2lkPzogc3RyaW5nO1xuICAgICAgICBhdHRyaWJ1dGVzPzogUERQQXR0cmlidXRlcyB8IFBMUEF0dHJpYnV0ZXM7XG4gICAgICAgIGNhdGVnb3J5Pzogc3RyaW5nO1xuICAgICAgICBjcmVhdGVkX2F0Pzogc3RyaW5nO1xuICAgIH07XG4gICAgcGFnZV92YXJpYW50PzogQmFja2VuZFBhZ2VWYXJpYW50Q29uZmlnO1xufVxuZXhwb3J0IHR5cGUgVXJsUmVzb2x2ZXJDYWNoZSA9IFJlY29yZDxzdHJpbmcsIFVybFJlc29sdmVyUmVzcG9uc2UgfCB1bmRlZmluZWQ+O1xuZXhwb3J0IGRlY2xhcmUgY29uc3QgdXJsUmVzb2x2ZXJBdG9tOiBpbXBvcnQoXCJqb3RhaVwiKS5Xcml0YWJsZUF0b208VXJsUmVzb2x2ZXJDYWNoZSwgW3ZhbHVlOiB7XG4gICAgdXJsOiBzdHJpbmc7XG4gICAgcmVzcG9uc2U6IFVybFJlc29sdmVyUmVzcG9uc2UgfCB1bmRlZmluZWQ7XG59XSwgdm9pZD47XG5leHBvcnQgZGVjbGFyZSBjb25zdCBzdXBwb3J0ZWRFdmVudEF0b206IGltcG9ydChcImpvdGFpXCIpLldyaXRhYmxlQXRvbTxTdXBwb3J0ZWRFdmVudCB8IHVuZGVmaW5lZCwgW3ZhbHVlOiBTdXBwb3J0ZWRFdmVudCB8IHVuZGVmaW5lZF0sIHZvaWQ+O1xuZXhwb3J0IGRlY2xhcmUgY29uc3QgdmFyaWFudElkQXRvbTogaW1wb3J0KFwiam90YWlcIikuQXRvbTxzdHJpbmcgfCB1bmRlZmluZWQ+O1xuZXhwb3J0IGRlY2xhcmUgY29uc3QgcHJvZHVjdElkQXRvbTogaW1wb3J0KFwiam90YWlcIikuQXRvbTxzdHJpbmcgfCB1bmRlZmluZWQ+O1xuZXhwb3J0IGRlY2xhcmUgY29uc3QgcGFyZW50UHJvZHVjdElkQXRvbTogaW1wb3J0KFwiam90YWlcIikuQXRvbTxzdHJpbmcgfCB1bmRlZmluZWQ+O1xuZXhwb3J0IGRlY2xhcmUgY29uc3QgcHJvZHVjdFVybEF0b206IGltcG9ydChcImpvdGFpXCIpLkF0b208c3RyaW5nIHwgdW5kZWZpbmVkPjtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHBscElkQXRvbTogaW1wb3J0KFwiam90YWlcIikuQXRvbTxzdHJpbmcgfCB1bmRlZmluZWQ+O1xuZXhwb3J0IGRlY2xhcmUgY29uc3QgdXJsQXRvbTogaW1wb3J0KFwiam90YWlcIikuQXRvbTxzdHJpbmcgfCB1bmRlZmluZWQ+O1xuZXhwb3J0IGRlY2xhcmUgY29uc3QgcGFnZVZpc2l0Q2F0ZWdvcnlBdG9tOiBpbXBvcnQoXCJqb3RhaVwiKS5BdG9tPFBhZ2VWaXNpdENhdGVnb3J5IHwgdW5kZWZpbmVkPjtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHZhcmlhbnRBdG9tOiBpbXBvcnQoXCJqb3RhaVwiKS5BdG9tPFwic2VhcmNoXCIgfCBcInBkcFwiIHwgXCJwbHBcIiB8IFwicGFnZV92aXNpdFwiPjtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IGhhc1BhcnNlZFZhcmlhbnRJbmZvQXRvbTogaW1wb3J0KFwiam90YWlcIikuUHJpbWl0aXZlQXRvbTxib29sZWFuPiAmIHtcbiAgICBpbml0OiBib29sZWFuO1xufTtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHZhcmlhbnRJbmZvQXRvbTogaW1wb3J0KFwiam90YWlcIikuV3JpdGFibGVBdG9tPFZhcmlhbnRJbmZvLCBbbmV3VmFyaWFudDogVmFyaWFudEluZm9dLCB2b2lkPjtcbmV4cG9ydCB7fTtcbiIsImltcG9ydCB7IENvbnRleHRFbnZFbnVtLCBDb250ZXh0U291cmNlRW51bSB9IGZyb20gXCJAc3BpZmZ5LWFpL2NvbW1lcmNlLWFwaS1jbGllbnRcIjtcbmltcG9ydCB7IFZhcmlhbnRJbmZvIH0gZnJvbSBcInNyYy9hcHBsaWNhdGlvbi9tb2RlbHNcIjtcbmltcG9ydCB7IFVzZXJJZGVudGl0eUNvbnRleHRUeXBlIH0gZnJvbSBcInNyYy9jb250ZXh0cy91c2VySWRlbnRpdHlDb250ZXh0L3VzZXJJZGVudGl0eUNvbnRleHRcIjtcbmV4cG9ydCBpbnRlcmZhY2UgQXBwRGV0YWlscyB7XG4gICAgb3JnSWQ6IHN0cmluZztcbiAgICBvcmdTaG9ydE5hbWU6IHN0cmluZztcbiAgICBjaGF0SWQ6IHN0cmluZztcbiAgICB1c2VySWQ6IHN0cmluZztcbiAgICBzb3VyY2U6IENvbnRleHRTb3VyY2VFbnVtO1xuICAgIGVudjogQ29udGV4dEVudkVudW07XG4gICAgdmFyaWFudEluZm86IFZhcmlhbnRJbmZvO1xufVxuZXhwb3J0IHsgdmFyaWFudEluZm9BdG9tIH0gZnJvbSBcIi4vdmFyaWFudFwiO1xuZXhwb3J0IGRlY2xhcmUgY29uc3QgdXNlcklkQXRvbTogaW1wb3J0KFwiam90YWlcIikuV3JpdGFibGVBdG9tPHN0cmluZywgW3ZhbHVlOiBzdHJpbmcgfCB1bmRlZmluZWRdLCB2b2lkPjtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHVzZXJJZGVudGl0eUF0b206IGltcG9ydChcImpvdGFpXCIpLlByaW1pdGl2ZUF0b208VXNlcklkZW50aXR5Q29udGV4dFR5cGUgfCB1bmRlZmluZWQ+ICYge1xuICAgIGluaXQ6IFVzZXJJZGVudGl0eUNvbnRleHRUeXBlIHwgdW5kZWZpbmVkO1xufTtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IGFwcFNvdXJjZUF0b206IGltcG9ydChcImpvdGFpXCIpLkF0b208Q29udGV4dFNvdXJjZUVudW0+O1xuZXhwb3J0IGRlY2xhcmUgY29uc3QgY2hhdElkQXRvbTogaW1wb3J0KFwiam90YWlcIikuV3JpdGFibGVBdG9tPHN0cmluZywgW3N0cmluZyB8IHR5cGVvZiBpbXBvcnQoXCJqb3RhaS91dGlsc1wiKS5SRVNFVCB8ICgocHJldjogc3RyaW5nKSA9PiBzdHJpbmcgfCB0eXBlb2YgaW1wb3J0KFwiam90YWkvdXRpbHNcIikuUkVTRVQpXSwgdm9pZD47XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQXlCQSxJQUFXLGtCQUFTO0NBQUE7T0FBQTtPQUFBO09BQUEsUUFBQTtDQUFBOzs7O0FDcEJwQixJQUFXLGFBQWE7Q0FBQTtPQUFBO09BQUE7T0FBQTtDQUFBO0FBRXhCLElBQVcsYUFBTyxDQUFBLFdBQUEsUUFBQSxhQUFBO0FBQ2xCLElBQVcsbUJBQWtCO0NBQUE7T0FBQTtPQUFBLFFBQUE7T0FBQTtDQUFBO0FBQzdCLElBQVcsZ0JBQVk7Q0FBQTtPQUFBO09BQUEsUUFBQTtDQUFBO0FBQ3ZCLElBQVcsYUFBYTtDQUFDO09BQUcsYUFBQTtPQUFBLGFBQUE7T0FBQSxRQUFBO0NBQUEifQ==
40
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsIm5hbWVzIjpbXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXRvbXMvYXBwL3ZhcmlhbnQuZC50cyIsIi4uLy4uLy4uL3NyYy9hdG9tcy9hcHAvaW5kZXguZC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTdXBwb3J0ZWRFdmVudFJlc3BvbnNlLCBQYWdlVmlzaXRDYXRlZ29yeSB9IGZyb20gJ0BzcGlmZnktYWkvY29tbWVyY2UtYXBpLWNsaWVudCc7XG5pbXBvcnQgeyBWYXJpYW50SW5mbyB9IGZyb20gJ3NyYy9hcHBsaWNhdGlvbi9tb2RlbHMnO1xuZXhwb3J0IGludGVyZmFjZSBTdXBwb3J0ZWRFdmVudCBleHRlbmRzIFBpY2s8U3VwcG9ydGVkRXZlbnRSZXNwb25zZSwgJ3N1cHBvcnRlZCcgfCAncmVhZHknIHwgJ2NhdGVnb3J5JyB8ICdjb2xsZWN0aW9ucycgfCAndG9wX2NhdGVnb3J5Jz4ge1xuICAgIG51bWJlck9mUmV2aWV3czogbnVtYmVyIHwgdW5kZWZpbmVkO1xuICAgIG1lcmNoYW50X3RhZ3M/OiBzdHJpbmdbXTtcbn1cbmludGVyZmFjZSBQRFBBdHRyaWJ1dGVzIHtcbiAgICBwcm9kdWN0X2lkPzogc3RyaW5nO1xufVxuaW50ZXJmYWNlIFBMUEF0dHJpYnV0ZXMge1xuICAgIGF0dHJpYnV0ZXM/OiB7XG4gICAgICAgIGlkPzogc3RyaW5nO1xuICAgIH07XG59XG5leHBvcnQgaW50ZXJmYWNlIFVybFJlc29sdmluZ1BEUENvbmZpZyB7XG4gICAgcGRwX2F0dHJpYnV0ZXM6IFBEUEF0dHJpYnV0ZXM7XG4gICAgbnVtYmVyX29mX3Jldmlld3M/OiBudW1iZXI7XG4gICAgY29sbGVjdGlvbnM/OiBzdHJpbmdbXTtcbiAgICBtZXJjaGFudF90YWdzPzogc3RyaW5nW107XG59XG5leHBvcnQgaW50ZXJmYWNlIFVybFJlc29sdmluZ1BMUENvbmZpZyB7XG4gICAgcGxwX2F0dHJpYnV0ZXM6IFBMUEF0dHJpYnV0ZXM7XG4gICAgdG9wX2NhdGVnb3J5Pzogc3RyaW5nO1xufVxuaW50ZXJmYWNlIFVybFJlc29sdmluZ0dlbmVyaWNDb25maWcge1xuICAgIGRldGFpbHM/OiBzdHJpbmc7XG59XG5leHBvcnQgdHlwZSBQYWdlVmFyaWFudENoZWNrQ29uZmlnID0ge1xuICAgIGNoZWNrX3R5cGU6IHN0cmluZztcbiAgICBmZWF0dXJlX2dhdGU/OiBzdHJpbmc7XG4gICAgZXh0cmFjdG9yPzoge1xuICAgICAgICB0eXBlOiBzdHJpbmc7XG4gICAgICAgIG1hcD86IFJlY29yZDxzdHJpbmcsIHN0cmluZ1tdPjtcbiAgICAgICAgdmFsdWU/OiBzdHJpbmc7XG4gICAgfTtcbiAgICBwcm9kdWN0X2lkX2V4dHJhY3Rvcj86IHN0cmluZztcbiAgICBwcm9kdWN0X2lkcz86IHN0cmluZ1tdO1xuICAgIHBscF9pZF9leHRyYWN0b3I/OiBzdHJpbmc7XG4gICAgcGxwX2lkcz86IHN0cmluZ1tdO1xuICAgIGNvbGxlY3Rpb25zPzogc3RyaW5nW107XG4gICAgcXVlcnlfcGFyYW0/OiBzdHJpbmc7XG4gICAgY2F0ZWdvcnk/OiBzdHJpbmc7XG4gICAgdG9wX2NhdGVnb3J5Pzogc3RyaW5nW107XG4gICAgcmV2aWV3X21pbmltdW0/OiBudW1iZXI7XG4gICAgbWVyY2hhbnRfdGFncz86IHN0cmluZ1tdO1xufTtcbmV4cG9ydCB0eXBlIEJhY2tlbmRXaWRnZXRNb3VudGluZ0NvbmZpZyA9IHtcbiAgICBtb3VudGluZ19jb25maWdfaWQ6IHN0cmluZztcbiAgICB3aWRnZXRfY29uZmlnX2lkPzogc3RyaW5nO1xuICAgIG1vdW50aW5nX3BvaW50X3dpZGdldHM/OiBBcnJheTx7XG4gICAgICAgIGNoZWNrczogUGFnZVZhcmlhbnRDaGVja0NvbmZpZ1tdO1xuICAgICAgICB3aWRnZXRfY29uZmlnX2lkOiBzdHJpbmc7XG4gICAgfT47XG59O1xuZXhwb3J0IHR5cGUgQmFja2VuZFBhZ2VWYXJpYW50Q29uZmlnID0ge1xuICAgIHZhcmlhbnRfaWQ6IHN0cmluZztcbiAgICB2YXJpYW50X3R5cGU6IHN0cmluZztcbiAgICB2YXJpYW50X2NoZWNrczogUGFnZVZhcmlhbnRDaGVja0NvbmZpZ1tdO1xuICAgIHdpZGdldF9tb3VudGluZzogQmFja2VuZFdpZGdldE1vdW50aW5nQ29uZmlnW107XG4gICAgcGxwX2lkX2V4dHJhY3Rvcj86IHN0cmluZztcbiAgICBwcm9kdWN0X2lkX2V4dHJhY3Rvcj86IHN0cmluZztcbiAgICBwYXJlbnRfcHJvZHVjdF9pZF9leHRyYWN0b3I/OiBzdHJpbmc7XG59O1xuZXhwb3J0IGludGVyZmFjZSBVcmxSZXNvbHZlclJlc3BvbnNlIHtcbiAgICB2YXJpYW50X3R5cGU6IHN0cmluZztcbiAgICBzcGVjaWZpY19kZXRhaWxzOiBVcmxSZXNvbHZpbmdQRFBDb25maWcgfCBVcmxSZXNvbHZpbmdQTFBDb25maWcgfCBVcmxSZXNvbHZpbmdHZW5lcmljQ29uZmlnO1xuICAgIHJlYWR5OiBib29sZWFuO1xuICAgIHVzZXJfZXZlbnQ/OiB7XG4gICAgICAgIGV2ZW50X2lkPzogc3RyaW5nO1xuICAgICAgICBhdHRyaWJ1dGVzPzogUERQQXR0cmlidXRlcyB8IFBMUEF0dHJpYnV0ZXM7XG4gICAgICAgIGNhdGVnb3J5Pzogc3RyaW5nO1xuICAgICAgICBjcmVhdGVkX2F0Pzogc3RyaW5nO1xuICAgIH07XG4gICAgcGFnZV92YXJpYW50PzogQmFja2VuZFBhZ2VWYXJpYW50Q29uZmlnO1xufVxuZXhwb3J0IHR5cGUgVXJsUmVzb2x2ZXJDYWNoZSA9IFJlY29yZDxzdHJpbmcsIFVybFJlc29sdmVyUmVzcG9uc2UgfCB1bmRlZmluZWQ+O1xuZXhwb3J0IGRlY2xhcmUgY29uc3QgdXJsUmVzb2x2ZXJBdG9tOiBpbXBvcnQoXCJqb3RhaVwiKS5Xcml0YWJsZUF0b208VXJsUmVzb2x2ZXJDYWNoZSwgW3ZhbHVlOiB7XG4gICAgdXJsOiBzdHJpbmc7XG4gICAgcmVzcG9uc2U6IFVybFJlc29sdmVyUmVzcG9uc2UgfCB1bmRlZmluZWQ7XG59XSwgdm9pZD47XG5leHBvcnQgZGVjbGFyZSBjb25zdCBzdXBwb3J0ZWRFdmVudEF0b206IGltcG9ydChcImpvdGFpXCIpLldyaXRhYmxlQXRvbTxTdXBwb3J0ZWRFdmVudCB8IHVuZGVmaW5lZCwgW3ZhbHVlOiBTdXBwb3J0ZWRFdmVudCB8IHVuZGVmaW5lZF0sIHZvaWQ+O1xuZXhwb3J0IGRlY2xhcmUgY29uc3QgdmFyaWFudElkQXRvbTogaW1wb3J0KFwiam90YWlcIikuQXRvbTxzdHJpbmcgfCB1bmRlZmluZWQ+O1xuZXhwb3J0IGRlY2xhcmUgY29uc3QgcHJvZHVjdElkQXRvbTogaW1wb3J0KFwiam90YWlcIikuQXRvbTxzdHJpbmcgfCB1bmRlZmluZWQ+O1xuZXhwb3J0IGRlY2xhcmUgY29uc3QgcGFyZW50UHJvZHVjdElkQXRvbTogaW1wb3J0KFwiam90YWlcIikuQXRvbTxzdHJpbmcgfCB1bmRlZmluZWQ+O1xuZXhwb3J0IGRlY2xhcmUgY29uc3QgcHJvZHVjdFVybEF0b206IGltcG9ydChcImpvdGFpXCIpLkF0b208c3RyaW5nIHwgdW5kZWZpbmVkPjtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHBscElkQXRvbTogaW1wb3J0KFwiam90YWlcIikuQXRvbTxzdHJpbmcgfCB1bmRlZmluZWQ+O1xuZXhwb3J0IGRlY2xhcmUgY29uc3QgdXJsQXRvbTogaW1wb3J0KFwiam90YWlcIikuQXRvbTxzdHJpbmcgfCB1bmRlZmluZWQ+O1xuZXhwb3J0IGRlY2xhcmUgY29uc3QgcGFnZVZpc2l0Q2F0ZWdvcnlBdG9tOiBpbXBvcnQoXCJqb3RhaVwiKS5BdG9tPFBhZ2VWaXNpdENhdGVnb3J5IHwgdW5kZWZpbmVkPjtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHZhcmlhbnRBdG9tOiBpbXBvcnQoXCJqb3RhaVwiKS5BdG9tPFwic2VhcmNoXCIgfCBcInBkcFwiIHwgXCJwbHBcIiB8IFwicGFnZV92aXNpdFwiPjtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IGhhc1BhcnNlZFZhcmlhbnRJbmZvQXRvbTogaW1wb3J0KFwiam90YWlcIikuUHJpbWl0aXZlQXRvbTxib29sZWFuPiAmIHtcbiAgICBpbml0OiBib29sZWFuO1xufTtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHZhcmlhbnRJbmZvQXRvbTogaW1wb3J0KFwiam90YWlcIikuV3JpdGFibGVBdG9tPFZhcmlhbnRJbmZvLCBbbmV3VmFyaWFudDogVmFyaWFudEluZm9dLCB2b2lkPjtcbmV4cG9ydCB7fTtcbiIsImltcG9ydCB7IENvbnRleHRFbnZFbnVtLCBDb250ZXh0U291cmNlRW51bSB9IGZyb20gXCJAc3BpZmZ5LWFpL2NvbW1lcmNlLWFwaS1jbGllbnRcIjtcbmltcG9ydCB7IFZhcmlhbnRJbmZvIH0gZnJvbSBcInNyYy9hcHBsaWNhdGlvbi9tb2RlbHNcIjtcbmltcG9ydCB7IFVzZXJJZGVudGl0eUNvbnRleHRUeXBlIH0gZnJvbSBcInNyYy9jb250ZXh0cy91c2VySWRlbnRpdHlDb250ZXh0L3VzZXJJZGVudGl0eUNvbnRleHRcIjtcbmV4cG9ydCBpbnRlcmZhY2UgQXBwRGV0YWlscyB7XG4gICAgb3JnSWQ6IHN0cmluZztcbiAgICBvcmdTaG9ydE5hbWU6IHN0cmluZztcbiAgICBjaGF0SWQ6IHN0cmluZztcbiAgICB1c2VySWQ6IHN0cmluZztcbiAgICBzb3VyY2U6IENvbnRleHRTb3VyY2VFbnVtO1xuICAgIGVudjogQ29udGV4dEVudkVudW07XG4gICAgdmFyaWFudEluZm86IFZhcmlhbnRJbmZvO1xufVxuZXhwb3J0IHsgdmFyaWFudEluZm9BdG9tIH0gZnJvbSBcIi4vdmFyaWFudFwiO1xuZXhwb3J0IGRlY2xhcmUgY29uc3QgdXNlcklkQXRvbTogaW1wb3J0KFwiam90YWlcIikuV3JpdGFibGVBdG9tPHN0cmluZywgW3ZhbHVlOiBzdHJpbmcgfCB1bmRlZmluZWRdLCB2b2lkPjtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHVzZXJJZGVudGl0eUF0b206IGltcG9ydChcImpvdGFpXCIpLlByaW1pdGl2ZUF0b208VXNlcklkZW50aXR5Q29udGV4dFR5cGUgfCB1bmRlZmluZWQ+ICYge1xuICAgIGluaXQ6IFVzZXJJZGVudGl0eUNvbnRleHRUeXBlIHwgdW5kZWZpbmVkO1xufTtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IGFwcFNvdXJjZUF0b206IGltcG9ydChcImpvdGFpXCIpLkF0b208Q29udGV4dFNvdXJjZUVudW0+O1xuZXhwb3J0IGRlY2xhcmUgY29uc3QgY2hhdElkQXRvbTogaW1wb3J0KFwiam90YWlcIikuV3JpdGFibGVBdG9tPHN0cmluZywgW3N0cmluZyB8IHR5cGVvZiBpbXBvcnQoXCJqb3RhaS91dGlsc1wiKS5SRVNFVCB8ICgocHJldjogc3RyaW5nKSA9PiBzdHJpbmcgfCB0eXBlb2YgaW1wb3J0KFwiam90YWkvdXRpbHNcIikuUkVTRVQpXSwgdm9pZD47XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQXlCQSxJQUFXLGtCQUFTO0NBQUE7T0FBQTtPQUFBO09BQUEsUUFBQTtDQUFBOzs7O0FDcEJwQixJQUFXLGFBQWE7Q0FBQTtPQUFBO09BQUE7T0FBQTtDQUFBO0FBRXhCLElBQVcsYUFBTyxDQUFBLFNBQUEsUUFBQSxhQUFBO0FBQ2xCLElBQVcsbUJBQWtCO0NBQUE7T0FBQTtPQUFBLFFBQUE7T0FBQTtDQUFBO0FBQzdCLElBQVcsZ0JBQVk7Q0FBQTtPQUFBO09BQUEsUUFBQTtDQUFBO0FBQ3ZCLElBQVcsYUFBYTtDQUFDO09BQUcsYUFBQTtPQUFBLGFBQUE7T0FBQSxRQUFBO0NBQUEifQ==
@@ -16,10 +16,10 @@ require('../../atomStore-CmZbgQHc.cjs');
16
16
  require('../../app-BbPSHefQ.cjs');
17
17
  require('../../enviveConfigContext-D2OELZDR.cjs');
18
18
  require('../../featureFlagServiceContext-CJyYItqu.cjs');
19
- require('../../amplitudeContext-C8tT74Mi.cjs');
20
- const require_chatState = require('../../chatState-CJ52Ag_7.cjs');
19
+ require('../../amplitudeContext-C6LHpqP_.cjs');
20
+ const require_chatState = require('../../chatState-D9_aA1_h.cjs');
21
21
  require('../../graphqlConfig-BnfE0ql5.cjs');
22
- const require_chat = require('../../chat-BkPax29G.cjs');
22
+ const require_chat = require('../../chat-L_N0qaqs.cjs');
23
23
 
24
24
  exports.APP_INITIAL_START_TIME_KEY = require_chat.APP_INITIAL_START_TIME_KEY;
25
25
  exports.PAGE_LOAD_OFFSET_TIME_KEY = require_chat.PAGE_LOAD_OFFSET_TIME_KEY;
@@ -12,51 +12,51 @@ import "../../search-6RrxBXD6.cjs";
12
12
  import "../../index-OkKEOL6H.cjs";
13
13
  import { SpiffyMetricsEventName } from "../../amplitudeContext-CCVyp5RU.cjs";
14
14
  import * as _spiffy_ai_commerce_api_client0 from "@spiffy-ai/commerce-api-client";
15
- import * as jotai35 from "jotai";
15
+ import * as jotai20 from "jotai";
16
16
  import * as jotai_utils1 from "jotai/utils";
17
17
  import { UserEventCategory as UserEventCategory$1 } from "@spiffy-ai/commerce-api-client/dist/models/UserEventCategory";
18
18
 
19
19
  //#region src/atoms/chat/chatState.d.ts
20
- declare const userHasRepliedAtom: jotai35.PrimitiveAtom<boolean> & {
20
+ declare const userHasRepliedAtom: jotai20.PrimitiveAtom<boolean> & {
21
21
  init: boolean;
22
22
  };
23
- declare const replyEventCategoryAtom: jotai35.PrimitiveAtom<UserEventCategory$1> & {
23
+ declare const replyEventCategoryAtom: jotai20.PrimitiveAtom<UserEventCategory$1> & {
24
24
  init: UserEventCategory$1;
25
25
  };
26
- declare const userQueryAtom: jotai35.PrimitiveAtom<string | undefined> & {
26
+ declare const userQueryAtom: jotai20.PrimitiveAtom<string | undefined> & {
27
27
  init: string | undefined;
28
28
  };
29
- declare const suggestionAtom: jotai35.PrimitiveAtom<Suggestion$1 | undefined> & {
29
+ declare const suggestionAtom: jotai20.PrimitiveAtom<Suggestion$1 | undefined> & {
30
30
  init: Suggestion$1 | undefined;
31
31
  };
32
- declare const askQuestionBtnClickedAtom: jotai35.PrimitiveAtom<boolean> & {
32
+ declare const askQuestionBtnClickedAtom: jotai20.PrimitiveAtom<boolean> & {
33
33
  init: boolean;
34
34
  };
35
- declare const messagesAtom: jotai35.PrimitiveAtom<Message[][]> & {
35
+ declare const messagesAtom: jotai20.PrimitiveAtom<Message[][]> & {
36
36
  init: Message[][];
37
37
  };
38
- declare const userEventsAtom: jotai35.PrimitiveAtom<UserEvent$1[]> & {
38
+ declare const userEventsAtom: jotai20.PrimitiveAtom<UserEvent$1[]> & {
39
39
  init: UserEvent$1[];
40
40
  };
41
- declare const suggestionsAtom: jotai35.PrimitiveAtom<Suggestion$1[]> & {
41
+ declare const suggestionsAtom: jotai20.PrimitiveAtom<Suggestion$1[]> & {
42
42
  init: Suggestion$1[];
43
43
  };
44
- declare const suggestionsLoadingAtom: jotai35.PrimitiveAtom<boolean> & {
44
+ declare const suggestionsLoadingAtom: jotai20.PrimitiveAtom<boolean> & {
45
45
  init: boolean;
46
46
  };
47
- declare const responseStreamingAtom: jotai35.PrimitiveAtom<boolean> & {
47
+ declare const responseStreamingAtom: jotai20.PrimitiveAtom<boolean> & {
48
48
  init: boolean;
49
49
  };
50
- declare const chatIsOpenAtom: jotai35.PrimitiveAtom<boolean> & {
50
+ declare const chatIsOpenAtom: jotai20.PrimitiveAtom<boolean> & {
51
51
  init: boolean;
52
52
  };
53
- declare const requestFailureAtom: jotai35.PrimitiveAtom<boolean> & {
53
+ declare const requestFailureAtom: jotai20.PrimitiveAtom<boolean> & {
54
54
  init: boolean;
55
55
  };
56
- declare const formSubmitAtom: jotai35.PrimitiveAtom<FormSubmittedAttributes$1 | undefined> & {
56
+ declare const formSubmitAtom: jotai20.PrimitiveAtom<FormSubmittedAttributes$1 | undefined> & {
57
57
  init: FormSubmittedAttributes$1 | undefined;
58
58
  };
59
- declare const chatOnToggleAtom: jotai35.WritableAtom<null, [triggerLocation?: ChatElementDisplayLocation | undefined, track?: ((eventName: SpiffyMetricsEventName, eventProps?: Record<string, unknown>) => void) | undefined], void> & {
59
+ declare const chatOnToggleAtom: jotai20.WritableAtom<null, [triggerLocation?: ChatElementDisplayLocation | undefined, track?: ((eventName: SpiffyMetricsEventName, eventProps?: Record<string, unknown>) => void) | undefined], void> & {
60
60
  init: null;
61
61
  };
62
62
  //#endregion
@@ -65,7 +65,7 @@ type HandleReplyParams = {
65
65
  message: Message;
66
66
  userTyped: boolean;
67
67
  };
68
- declare const handleReplyAtom: jotai35.WritableAtom<null, [HandleReplyParams], void> & {
68
+ declare const handleReplyAtom: jotai20.WritableAtom<null, [HandleReplyParams], void> & {
69
69
  init: null;
70
70
  };
71
71
  //#endregion
@@ -91,8 +91,8 @@ declare enum PerfMetricsEvents {
91
91
  BottomSuggestionsBarRendered = "bottom_suggestions_bar_rendered_ms",
92
92
  SearchPromptRendered = "search_prompt_rendered_ms",
93
93
  }
94
- declare const appInitialStartTimeMsAtom: jotai35.WritableAtom<string | undefined, [string | typeof jotai_utils1.RESET | ((prev: string | undefined) => string | typeof jotai_utils1.RESET | undefined) | undefined], void>;
95
- declare const pageLoadOffsetTimeAtom: jotai35.WritableAtom<string | undefined, [string | typeof jotai_utils1.RESET | ((prev: string | undefined) => string | typeof jotai_utils1.RESET | undefined) | undefined], void>;
94
+ declare const appInitialStartTimeMsAtom: jotai20.WritableAtom<string | undefined, [string | typeof jotai_utils1.RESET | ((prev: string | undefined) => string | typeof jotai_utils1.RESET | undefined) | undefined], void>;
95
+ declare const pageLoadOffsetTimeAtom: jotai20.WritableAtom<string | undefined, [string | typeof jotai_utils1.RESET | ((prev: string | undefined) => string | typeof jotai_utils1.RESET | undefined) | undefined], void>;
96
96
  /**
97
97
  * Resets the performance metrics atom to an empty map. This should be called after the performance
98
98
  * metrics have been reported to amplitude. On SPA, it ensures that we can still capture metrics as
@@ -100,8 +100,8 @@ declare const pageLoadOffsetTimeAtom: jotai35.WritableAtom<string | undefined, [
100
100
  * On non-SPA, it ensures that previously captured metrics are not reported again.
101
101
  */
102
102
  declare const resetPerformanceMetricsAtom: () => void;
103
- declare const performanceMetricsAtom: jotai35.Atom<Map<PerfMetricsEvents, number>>;
104
- declare const hasReportedPerformanceMetricsAtom: jotai35.PrimitiveAtom<boolean> & {
103
+ declare const performanceMetricsAtom: jotai20.Atom<Map<PerfMetricsEvents, number>>;
104
+ declare const hasReportedPerformanceMetricsAtom: jotai20.PrimitiveAtom<boolean> & {
105
105
  init: boolean;
106
106
  };
107
107
  /**
@@ -110,25 +110,25 @@ declare const hasReportedPerformanceMetricsAtom: jotai35.PrimitiveAtom<boolean>
110
110
  *
111
111
  * @param value The performance metric name to log.
112
112
  */
113
- declare const logPerfMetricAtom: jotai35.WritableAtom<null, [value: PerfMetricsEvents], void> & {
113
+ declare const logPerfMetricAtom: jotai20.WritableAtom<null, [value: PerfMetricsEvents], void> & {
114
114
  init: null;
115
115
  };
116
116
  //#endregion
117
117
  //#region src/atoms/chat/form.d.ts
118
- declare const handleFormSubmittedAtom: jotai35.WritableAtom<null, [form: FormSubmittedAttributes$1], void> & {
118
+ declare const handleFormSubmittedAtom: jotai20.WritableAtom<null, [form: FormSubmittedAttributes$1], void> & {
119
119
  init: null;
120
120
  };
121
121
  //#endregion
122
122
  //#region src/atoms/chat/suggestions.d.ts
123
- declare const handleSuggestionAtom: jotai35.WritableAtom<null, [suggestion: Suggestion$1], void> & {
123
+ declare const handleSuggestionAtom: jotai20.WritableAtom<null, [suggestion: Suggestion$1], void> & {
124
124
  init: null;
125
125
  };
126
126
  //#endregion
127
127
  //#region src/atoms/chat/lastMessage.d.ts
128
- declare const lastAssistantMessageAtom: jotai35.Atom<Message[] | null>;
128
+ declare const lastAssistantMessageAtom: jotai20.Atom<Message[] | null>;
129
129
  //#endregion
130
130
  //#region src/atoms/chat/renderedWidgetRefs.d.ts
131
- declare const widgetArrayAtom: jotai35.Atom<HTMLElement[]>;
131
+ declare const widgetArrayAtom: jotai20.Atom<HTMLElement[]>;
132
132
  /**
133
133
  * This function call is used to create a list of the Spiffy widgets
134
134
  * that are rendering on the page.
@@ -145,7 +145,7 @@ declare const widgetArrayAtom: jotai35.Atom<HTMLElement[]>;
145
145
  declare const addWidget: (ref: HTMLElement, idx?: number) => void;
146
146
  //#endregion
147
147
  //#region src/atoms/chat/index.d.ts
148
- declare const chatAtom: jotai35.Atom<{
148
+ declare const chatAtom: jotai20.Atom<{
149
149
  userHasReplied: boolean;
150
150
  replyEventCategory: _spiffy_ai_commerce_api_client0.UserEventCategory;
151
151
  userQuery: string | undefined;