@envive-ai/react-hooks 0.2.6-alpha-10 → 0.2.6-alpha-arthur-1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/{AmplitudeOperations-BgeRn1-f.js → AmplitudeOperations-CXU93q_4.js} +2 -2
- package/dist/{AmplitudeOperations-D_Ryy56B.cjs → AmplitudeOperations-_uIb5QED.cjs} +2 -2
- package/dist/{NewOrgConfig-C9aQqGsb.js → NewOrgConfig-CUQGpmw9.js} +2 -2
- package/dist/{NewOrgConfig-CHkHRqHx.cjs → NewOrgConfig-DD0oloeK.cjs} +2 -2
- package/dist/{TrackComponentVisibleEvent-IUaBjwTi.cjs → TrackComponentVisibleEvent-D-hN3owz.cjs} +2 -2
- package/dist/{TrackComponentVisibleEvent-BDG4krXl.js → TrackComponentVisibleEvent-D-pvNVOP.js} +2 -2
- package/dist/amplitudeContext-DFXeRauX.js +233 -0
- package/dist/amplitudeContext-DrFGH7Q7.cjs +249 -0
- package/dist/{amplitudeTrackEventAtom-iEIu11Om.js → amplitudeTrackEventAtom-D66l5oFp.js} +1 -1
- package/dist/{amplitudeTrackEventAtom-D9vs8dpE.cjs → amplitudeTrackEventAtom-f22P2U0u.cjs} +1 -1
- package/dist/application/utils/index.d.cts +3 -3
- package/dist/atoms/app/index.d.cts +7 -7
- package/dist/atoms/app/index.d.ts +7 -7
- package/dist/atoms/atomStore/index.d.ts +1 -1
- package/dist/atoms/chat/index.cjs +3 -3
- package/dist/atoms/chat/index.d.cts +31 -31
- package/dist/atoms/chat/index.d.ts +32 -32
- package/dist/atoms/chat/index.js +3 -3
- package/dist/atoms/globalSearch/index.cjs +1 -1
- package/dist/atoms/globalSearch/index.d.cts +6 -6
- package/dist/atoms/globalSearch/index.d.ts +6 -6
- package/dist/atoms/globalSearch/index.js +1 -1
- package/dist/atoms/org/index.d.cts +15 -15
- package/dist/atoms/org/index.d.ts +16 -16
- package/dist/atoms/search/index.cjs +3 -3
- package/dist/atoms/search/index.d.cts +13 -13
- package/dist/atoms/search/index.d.ts +14 -14
- package/dist/atoms/search/index.js +3 -3
- package/dist/atoms/search/utils.cjs +1 -1
- package/dist/atoms/search/utils.d.ts +1 -1
- package/dist/atoms/search/utils.js +1 -1
- package/dist/{cdnContext-td-gAam0.js → cdnContext-D-qi0lub.js} +1 -1
- package/dist/{cdnContext-i5iYA8ig.cjs → cdnContext-DIVgBnsl.cjs} +1 -1
- package/dist/{chat-ByolnbMa.js → chat-ZaY3KY-R.js} +3 -3
- package/dist/{chat-EVIlt-8f.cjs → chat-rhEjVfrd.cjs} +3 -3
- package/dist/{chatState-D_UIPkjR.js → chatState-BbI93m6r.js} +1 -1
- package/dist/{chatState-CIhb4BWP.cjs → chatState-DlJpHAsW.cjs} +1 -1
- package/dist/config/locators/components/chat/variants/index.d.cts +1 -1
- package/dist/config/locators/components/search/index.d.cts +1 -1
- package/dist/contexts/amplitudeContext/index.cjs +3 -3
- package/dist/contexts/amplitudeContext/index.js +3 -3
- package/dist/contexts/cdnContext/index.cjs +1 -1
- package/dist/contexts/cdnContext/index.js +1 -1
- package/dist/contexts/enviveConfigContext/index.cjs +1 -1
- package/dist/contexts/enviveConfigContext/index.d.cts +1 -1
- package/dist/contexts/enviveConfigContext/index.js +1 -1
- package/dist/contexts/enviveCssContext/index.cjs +3 -3
- package/dist/contexts/enviveCssContext/index.d.cts +1 -1
- package/dist/contexts/enviveCssContext/index.js +3 -3
- package/dist/contexts/featureFlagContext/index.cjs +1 -1
- package/dist/contexts/featureFlagContext/index.js +1 -1
- package/dist/contexts/featureFlagServiceContext/index.cjs +1 -1
- package/dist/contexts/featureFlagServiceContext/index.js +1 -1
- package/dist/contexts/newOrgConfigContext/index.cjs +2 -2
- package/dist/contexts/newOrgConfigContext/index.js +2 -2
- package/dist/contexts/searchContext/index.cjs +3 -3
- package/dist/contexts/searchContext/index.js +3 -3
- package/dist/contexts/systemSettingsContext/index.d.cts +3 -3
- package/dist/contexts/userIdentityContext/index.d.cts +1 -1
- package/dist/{enviveConfigContext-De7lbzWa.js → enviveConfigContext-CIavPzcm.js} +2 -1
- package/dist/{enviveConfigContext-B2NpnOjc.cjs → enviveConfigContext-DHEs077z.cjs} +2 -1
- package/dist/exceptions/index.d.cts +1 -1
- package/dist/{featureFlagServiceContext-Cvp7NlpC.js → featureFlagServiceContext-Dr8Cw23n.js} +1 -1
- package/dist/{featureFlagServiceContext-DHtkQAtq.cjs → featureFlagServiceContext-rxZhpdEj.cjs} +1 -1
- package/dist/{globalSearch-DEKvpWV-.cjs → globalSearch-Cpc8egsM.cjs} +1 -1
- package/dist/{globalSearch-D_nMjrlf.js → globalSearch-nmrfGLOn.js} +1 -1
- package/dist/hooks/AmplitudeOperations/index.cjs +4 -4
- package/dist/hooks/AmplitudeOperations/index.js +4 -4
- package/dist/hooks/AppDetails/index.d.cts +1 -1
- package/dist/hooks/BlockBackButton/index.d.cts +1 -1
- package/dist/hooks/CdnOperations/index.cjs +1 -1
- package/dist/hooks/CdnOperations/index.js +1 -1
- package/dist/hooks/ChatToggle/index.cjs +6 -6
- package/dist/hooks/ChatToggle/index.d.cts +1 -1
- package/dist/hooks/ChatToggle/index.js +6 -6
- package/dist/hooks/ChatToggleAnalytics/index.cjs +5 -5
- package/dist/hooks/ChatToggleAnalytics/index.d.ts +1 -1
- package/dist/hooks/ChatToggleAnalytics/index.js +5 -5
- package/dist/hooks/Debounce/index.d.ts +1 -1
- package/dist/hooks/GrabAndScroll/index.d.cts +2 -2
- package/dist/hooks/GrabAndScroll/index.d.ts +2 -2
- package/dist/hooks/ImageResolver/index.d.ts +1 -1
- package/dist/hooks/IsSmallScreen/index.d.cts +1 -1
- package/dist/hooks/LocalStorageOperations/index.d.cts +1 -1
- package/dist/hooks/MessageFilter/index.d.cts +1 -1
- package/dist/hooks/NewOrgConfig/index.cjs +3 -3
- package/dist/hooks/NewOrgConfig/index.d.cts +2 -2
- package/dist/hooks/NewOrgConfig/index.d.ts +2 -2
- package/dist/hooks/NewOrgConfig/index.js +3 -3
- package/dist/hooks/Search/index.cjs +9 -9
- package/dist/hooks/Search/index.js +9 -9
- package/dist/hooks/SearchOperations/index.cjs +3 -3
- package/dist/hooks/SearchOperations/index.js +3 -3
- package/dist/hooks/SessionStorageOperations/index.d.cts +1 -1
- package/dist/hooks/ShopifyUrlOperations/index.d.cts +2 -2
- package/dist/hooks/ShopifyUrlOperations/index.d.ts +2 -2
- package/dist/hooks/SystemSettingsContext/index.d.cts +2 -2
- package/dist/hooks/TrackComponentVisibleEvent/index.cjs +4 -4
- package/dist/hooks/TrackComponentVisibleEvent/index.js +4 -4
- package/dist/hooks/UpdateAnalyticsProps/index.cjs +3 -3
- package/dist/hooks/UpdateAnalyticsProps/index.js +3 -3
- package/dist/hooks/utils.d.cts +1 -1
- package/dist/hooks/utils.d.ts +1 -1
- package/dist/index-CMZcE7pk.d.cts +1 -1
- package/dist/index-CsmO1rDH.d.ts +1 -1
- package/dist/index-DtzPIcQp.d.ts +1 -1
- package/dist/index-bEjLKG_Q.d.ts +1 -1
- package/dist/index-mv7KvWDq.d.ts +1 -1
- package/dist/index-npqPeJ1g.d.cts +1 -1
- package/dist/{newOrgConfigContext-Dt_W-wlK.js → newOrgConfigContext-BdzDnzUM.js} +2 -2
- package/dist/{newOrgConfigContext-Brsggue9.cjs → newOrgConfigContext-cWeJAT6E.cjs} +2 -2
- package/dist/nodeSelector-BYEAyrsj.d.cts +1 -1
- package/dist/{search-OWKKaQQj.js → search-CsXXamht.js} +3 -3
- package/dist/{search-CWkDtqQV.cjs → search-DHhDpeQU.cjs} +3 -3
- package/dist/{searchContext-DeNsXmHq.js → searchContext-B5ZNLtvd.js} +3 -3
- package/dist/{searchContext-CjB3sD6b.cjs → searchContext-SFvF_Y8J.cjs} +3 -3
- package/dist/{searchServiceAdapter-B0h7psvh.js → searchServiceAdapter-BkvDIhV8.js} +1 -1
- package/dist/{searchServiceAdapter-BclWy4fE.cjs → searchServiceAdapter-C4zzBUl0.cjs} +1 -1
- package/dist/{utils-DQhbbAnt.js → utils-BRNaQkCK.js} +1 -1
- package/dist/{utils-CqVRbvfN.cjs → utils-Buo4KU5l.cjs} +1 -1
- package/package.json +1 -1
- package/src/contexts/amplitudeContext/amplitudeContext.tsx +4 -0
- package/src/contexts/enviveConfigContext/enviveConfigContext.tsx +1 -0
- package/dist/amplitudeContext-BM6ctR3o.cjs +0 -248
- package/dist/amplitudeContext-DHCtfce5.js +0 -232
|
@@ -0,0 +1,249 @@
|
|
|
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-DHEs077z.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
|
+
if (typeof window !== "undefined") window.AmplitudeReact = react.default;
|
|
23
|
+
const AmplitudeProvider = ({ children }) => {
|
|
24
|
+
const userId = (0, jotai.useAtomValue)(require_app.userIdAtom);
|
|
25
|
+
const amplitudeApiKey = (0, jotai.useAtomValue)(require_enviveConfig.amplitudeApiKeyAtom);
|
|
26
|
+
const dataResidency = (0, jotai.useAtomValue)(require_enviveConfig.dataResidencyAtom);
|
|
27
|
+
const orgGaConfig = (0, jotai.useAtomValue)(require_org.orgAnalyticsGoogleAnalyticsConfigAtom);
|
|
28
|
+
const env = (0, jotai.useAtomValue)(require_enviveConfig.envAtom);
|
|
29
|
+
const contextSource = (0, jotai.useAtomValue)(require_enviveConfig.contextSourceAtom);
|
|
30
|
+
(0, jotai.useAtomValue)(require_enviveConfig.identifyingPrefixAtom);
|
|
31
|
+
const { getItem } = require_localStorageContext.useLocalStorage();
|
|
32
|
+
const { publicKey, featureOverrides, variantUrlOverride, variantInfoOverride, show, orgShortName, featureGates } = require_enviveConfigContext.useEnviveConfig();
|
|
33
|
+
const { featureFlagService } = require_featureFlagServiceContext.useFeatureFlagService();
|
|
34
|
+
const [amplitudeClient, setAmplitudeClient] = react.default.useState(void 0);
|
|
35
|
+
const [internalEventTrackingEnrichment, setInternalEventTrackingEnrichment] = react.default.useState(void 0);
|
|
36
|
+
const [supplementalDefaultProps, setSupplementalDefaultProps] = react.default.useState({});
|
|
37
|
+
const isReady = Boolean(userId && featureFlagService && amplitudeApiKey && userId);
|
|
38
|
+
const getDefaultTrackingProps = (0, react.useCallback)(() => {
|
|
39
|
+
const gatesProps = featureGates ? featureGates.reduce((acc, curr) => {
|
|
40
|
+
if (curr.name && curr.value != null) return {
|
|
41
|
+
...acc,
|
|
42
|
+
[`feature_gate.${curr.name}`]: curr.value
|
|
43
|
+
};
|
|
44
|
+
return acc;
|
|
45
|
+
}, {}) : {};
|
|
46
|
+
const experimentProps = {};
|
|
47
|
+
return {
|
|
48
|
+
...gatesProps,
|
|
49
|
+
...experimentProps,
|
|
50
|
+
...supplementalDefaultProps,
|
|
51
|
+
app_id: "commerce-chat-react-component",
|
|
52
|
+
chat_id: getItem(require_dist.LocalStorageKeys.ChatId),
|
|
53
|
+
env: env || "unknown",
|
|
54
|
+
app_source: contextSource,
|
|
55
|
+
"org.short_name": orgShortName,
|
|
56
|
+
"user.id": userId,
|
|
57
|
+
"cdp.user_id": null,
|
|
58
|
+
"cdp.provider": null,
|
|
59
|
+
"event.source": "web-browser",
|
|
60
|
+
"event.type": "user-activity",
|
|
61
|
+
"event.id": null,
|
|
62
|
+
"event.channel": "web",
|
|
63
|
+
"event.timestamp": null
|
|
64
|
+
};
|
|
65
|
+
}, [
|
|
66
|
+
featureGates,
|
|
67
|
+
supplementalDefaultProps,
|
|
68
|
+
env,
|
|
69
|
+
contextSource,
|
|
70
|
+
orgShortName,
|
|
71
|
+
userId
|
|
72
|
+
]);
|
|
73
|
+
const eventPropsToPrefixedEventProps = (0, react.useCallback)((eventName, eventProps) => {
|
|
74
|
+
const prefix = eventName.toLowerCase().replace(/\s+/g, "_");
|
|
75
|
+
return Object.entries(eventProps).reduce((acc, [key, value$1]) => {
|
|
76
|
+
acc[`${prefix}.${key}`] = value$1;
|
|
77
|
+
return acc;
|
|
78
|
+
}, {});
|
|
79
|
+
}, []);
|
|
80
|
+
const amplitudeSessionReplayInit = (0, react.useCallback)(() => {
|
|
81
|
+
const isEnabled = Boolean(orgShortName === require_dist.OrgShortName.UniqueVintage && featureFlagService?.isClientSessionEnabled() && featureFlagService?.isFeatureGateEnabled(require_dist.FeatureGates.IsNewFeatureEnabled));
|
|
82
|
+
const sampleRate = 1;
|
|
83
|
+
try {
|
|
84
|
+
require_logger.logger_default.logDebug(`[spiffy-ai] amplitude session-replay initializing isEnabled=${isEnabled} sampleRate=${sampleRate}`);
|
|
85
|
+
if (!isEnabled) return isEnabled;
|
|
86
|
+
return isEnabled;
|
|
87
|
+
} catch (e) {
|
|
88
|
+
require_logger.logger_default.logError("[spiffy-ai] Error initializing amplitude session-replay", e);
|
|
89
|
+
return false;
|
|
90
|
+
}
|
|
91
|
+
}, [orgShortName, featureFlagService]);
|
|
92
|
+
const getEventTrackingEnrichment = (0, react.useCallback)(() => {
|
|
93
|
+
if (internalEventTrackingEnrichment !== void 0) return internalEventTrackingEnrichment;
|
|
94
|
+
const enrichment = {
|
|
95
|
+
name: "page-view-tracking-enrichment",
|
|
96
|
+
type: "enrichment",
|
|
97
|
+
setup: async () => void 0,
|
|
98
|
+
execute: async (event) => {
|
|
99
|
+
let enrichedEvent;
|
|
100
|
+
if (["[Amplitude] Page Viewed", `[Spiffy] ${require_dist.SpiffyMetricsEventName.BundleLoaded}`].includes(event.event_type)) {
|
|
101
|
+
const globalProperties = {};
|
|
102
|
+
if (publicKey) globalProperties["globalProperties.publicKey"] = publicKey;
|
|
103
|
+
if (featureOverrides) Object.entries(featureOverrides).forEach(([key, value$1]) => {
|
|
104
|
+
globalProperties[`globalProperties.featureOverrides.${key}`] = String(value$1);
|
|
105
|
+
});
|
|
106
|
+
if (variantUrlOverride) globalProperties["globalProperties.variantUrlOverride"] = variantUrlOverride;
|
|
107
|
+
if (variantInfoOverride) globalProperties["globalProperties.variantInfoOverride"] = JSON.stringify(variantInfoOverride);
|
|
108
|
+
if (show != null) globalProperties["globalProperties.show"] = String(show);
|
|
109
|
+
const enabledFeatures = featureFlagService.getFeatureFlags();
|
|
110
|
+
const enabledFeaturesProperties = Object.entries(enabledFeatures).reduce((acc, [key, value$1]) => ({
|
|
111
|
+
...acc,
|
|
112
|
+
[`enabledFeatures.${key}`]: `${value$1}`
|
|
113
|
+
}), {});
|
|
114
|
+
const timingProperties = { "timing.enriched_at_ms": window.performance?.now() };
|
|
115
|
+
enrichedEvent = {
|
|
116
|
+
...event,
|
|
117
|
+
event_properties: {
|
|
118
|
+
...event.event_properties,
|
|
119
|
+
...getDefaultTrackingProps(),
|
|
120
|
+
...globalProperties,
|
|
121
|
+
...enabledFeaturesProperties,
|
|
122
|
+
...timingProperties
|
|
123
|
+
}
|
|
124
|
+
};
|
|
125
|
+
} else enrichedEvent = event;
|
|
126
|
+
require_events.EventsDispatcher.dispatch(require_dist.SpiffyEvent.AMPLITUDE_EVENT, enrichedEvent);
|
|
127
|
+
return enrichedEvent;
|
|
128
|
+
}
|
|
129
|
+
};
|
|
130
|
+
setInternalEventTrackingEnrichment(enrichment);
|
|
131
|
+
return enrichment;
|
|
132
|
+
}, [
|
|
133
|
+
internalEventTrackingEnrichment,
|
|
134
|
+
getDefaultTrackingProps,
|
|
135
|
+
featureFlagService,
|
|
136
|
+
publicKey,
|
|
137
|
+
featureOverrides,
|
|
138
|
+
variantUrlOverride,
|
|
139
|
+
variantInfoOverride,
|
|
140
|
+
show
|
|
141
|
+
]);
|
|
142
|
+
(0, react.useEffect)(() => {
|
|
143
|
+
if (isReady && !amplitudeClient) {
|
|
144
|
+
const currentAmplitudeInstance = (0, __amplitude_analytics_browser.createInstance)();
|
|
145
|
+
const isSessionsEnabled = amplitudeSessionReplayInit();
|
|
146
|
+
currentAmplitudeInstance.add(getEventTrackingEnrichment());
|
|
147
|
+
currentAmplitudeInstance.init(amplitudeApiKey, userId, {
|
|
148
|
+
serverZone: dataResidency,
|
|
149
|
+
trackingOptions: { ipAddress: true },
|
|
150
|
+
autocapture: {
|
|
151
|
+
attribution: true,
|
|
152
|
+
pageViews: { trackHistoryChanges: "pathOnly" },
|
|
153
|
+
sessions: isSessionsEnabled,
|
|
154
|
+
formInteractions: false,
|
|
155
|
+
fileDownloads: false
|
|
156
|
+
}
|
|
157
|
+
});
|
|
158
|
+
setAmplitudeClient(currentAmplitudeInstance);
|
|
159
|
+
}
|
|
160
|
+
}, [
|
|
161
|
+
isReady,
|
|
162
|
+
amplitudeClient,
|
|
163
|
+
amplitudeApiKey,
|
|
164
|
+
userId,
|
|
165
|
+
dataResidency,
|
|
166
|
+
amplitudeSessionReplayInit,
|
|
167
|
+
getEventTrackingEnrichment
|
|
168
|
+
]);
|
|
169
|
+
const trackEvent = (0, react.useCallback)(async ({ eventName, eventProps, eventGroups, alsoSendToGoogleAnalytics = false }) => {
|
|
170
|
+
require_logger.logger_default.logDebug("Submitting event", eventName);
|
|
171
|
+
try {
|
|
172
|
+
const decoratedEventName = `[Spiffy] ${eventName}`;
|
|
173
|
+
if (!amplitudeClient) {
|
|
174
|
+
require_logger.logger_default.logWarn("amplitude client undefined", void 0, { event_name: decoratedEventName });
|
|
175
|
+
return;
|
|
176
|
+
}
|
|
177
|
+
const eventData = JSON.stringify({
|
|
178
|
+
eventName,
|
|
179
|
+
eventProps,
|
|
180
|
+
created_at: (/* @__PURE__ */ new Date()).toISOString()
|
|
181
|
+
});
|
|
182
|
+
const data = new TextEncoder().encode(eventData);
|
|
183
|
+
const hashBuffer = await crypto.subtle.digest("SHA-256", data);
|
|
184
|
+
const currentInsertId = Array.from(new Uint8Array(hashBuffer)).map((b) => b.toString(16).padStart(2, "0")).join("");
|
|
185
|
+
require_logger.logger_default.logDebug(`amplitude tracking ${decoratedEventName}`, null, {
|
|
186
|
+
event_name: decoratedEventName,
|
|
187
|
+
props: eventProps
|
|
188
|
+
});
|
|
189
|
+
amplitudeClient.track(decoratedEventName, {
|
|
190
|
+
...getDefaultTrackingProps(),
|
|
191
|
+
...eventProps,
|
|
192
|
+
...eventProps ? eventPropsToPrefixedEventProps(eventName, eventProps) : {}
|
|
193
|
+
}, {
|
|
194
|
+
...eventGroups,
|
|
195
|
+
insert_id: currentInsertId
|
|
196
|
+
});
|
|
197
|
+
if (alsoSendToGoogleAnalytics && orgGaConfig) {
|
|
198
|
+
require_logger.logger_default.logDebug("[spiffy-ai] GA tracking", decoratedEventName);
|
|
199
|
+
if (window.dataLayer) window.dataLayer.push({
|
|
200
|
+
event: decoratedEventName,
|
|
201
|
+
eventProps
|
|
202
|
+
});
|
|
203
|
+
}
|
|
204
|
+
} catch (err) {
|
|
205
|
+
require_logger.logger_default.logError("[spiffy-ai] Error tracking event", err, {
|
|
206
|
+
eventName,
|
|
207
|
+
eventProps
|
|
208
|
+
});
|
|
209
|
+
}
|
|
210
|
+
}, [
|
|
211
|
+
amplitudeClient,
|
|
212
|
+
getDefaultTrackingProps,
|
|
213
|
+
eventPropsToPrefixedEventProps,
|
|
214
|
+
orgGaConfig
|
|
215
|
+
]);
|
|
216
|
+
const value = (0, react.useMemo)(() => ({
|
|
217
|
+
trackEvent,
|
|
218
|
+
isReady,
|
|
219
|
+
setSupplementalDefaultProps: (props) => setSupplementalDefaultProps(props)
|
|
220
|
+
}), [
|
|
221
|
+
trackEvent,
|
|
222
|
+
isReady,
|
|
223
|
+
setSupplementalDefaultProps
|
|
224
|
+
]);
|
|
225
|
+
return /* @__PURE__ */ (0, react_jsx_runtime.jsx)(AmplitudeContext.Provider, {
|
|
226
|
+
value,
|
|
227
|
+
children
|
|
228
|
+
});
|
|
229
|
+
};
|
|
230
|
+
const useAmplitude = () => {
|
|
231
|
+
const context = (0, react.useContext)(AmplitudeContext);
|
|
232
|
+
if (!context) throw new Error("useAmplitude must be used within AmplitudeProvider");
|
|
233
|
+
return context;
|
|
234
|
+
};
|
|
235
|
+
|
|
236
|
+
//#endregion
|
|
237
|
+
Object.defineProperty(exports, 'AmplitudeProvider', {
|
|
238
|
+
enumerable: true,
|
|
239
|
+
get: function () {
|
|
240
|
+
return AmplitudeProvider;
|
|
241
|
+
}
|
|
242
|
+
});
|
|
243
|
+
Object.defineProperty(exports, 'useAmplitude', {
|
|
244
|
+
enumerable: true,
|
|
245
|
+
get: function () {
|
|
246
|
+
return useAmplitude;
|
|
247
|
+
}
|
|
248
|
+
});
|
|
249
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"amplitudeContext-DrFGH7Q7.cjs","names":["React","AmplitudeProvider: React.FC<{ children: React.ReactNode }>","userIdAtom","amplitudeApiKeyAtom","dataResidencyAtom","orgAnalyticsGoogleAnalyticsConfigAtom","envAtom","contextSourceAtom","identifyingPrefixAtom","useLocalStorage","useEnviveConfig","useFeatureFlagService","LocalStorageKeys","value","OrgShortName","FeatureGates","enrichment: EnrichmentPlugin","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\nif (typeof window !== 'undefined') {\n  (window as any).AmplitudeReact = React;\n}\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 && 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 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  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":";;;;;;;;;;;;;;;;;;;;AAuCA,MAAM,4CAA8D,KAAK;AAEzE,IAAI,OAAO,WAAW,YACpB,CAAC,OAAe,iBAAiBA;AAGnC,MAAaC,qBAA8D,EACzE,eACI;CACJ,MAAM,iCAAsBC,uBAAW;CACvC,MAAM,0CAA+BC,yCAAoB;CACzD,MAAM,wCAA6BC,uCAAkB;CACrD,MAAM,sCAA2BC,kDAAsC;CACvE,MAAM,8BAAmBC,6BAAQ;CACjC,MAAM,wCAA6BC,uCAAkB;AAC3B,yBAAaC,2CAAsB;CAC7D,MAAM,EAAE,YAAYC,6CAAiB;CACrC,MAAM,EACJ,WACA,kBACA,oBACA,qBACA,MACA,cACA,iBACEC,6CAAiB;CAErB,MAAM,EAAE,uBAAuBC,yDAAuB;CAEtD,MAAM,CAAC,iBAAiB,sBAAsBX,cAAM,SAElD,OAAU;CACZ,MAAM,CAAC,iCAAiC,sCACtCA,cAAM,SAAuC,OAAU;CACzD,MAAM,CAAC,0BAA0B,+BAC/BA,cAAM,SAAkC,EAAE,CAAC;CAE7C,MAAM,UAAU,QACd,UAAU,sBAAsB,mBAAmB,OACpD;CAED,MAAM,uDAAqE;EACzE,MAAM,aAAa,eACf,aAAa,QAAiC,KAAK,SAAS;AAC1D,OAAI,KAAK,QAAQ,KAAK,SAAS,KAC7B,QAAO;IAAE,GAAG;KAAM,gBAAgB,KAAK,SAAS,KAAK;IAAO;AAE9D,UAAO;KACN,EAAE,CAAC,GACN,EAAE;EACN,MAAM,kBAAkB,EAAE;AAO1B,SAAO;GAJL,GAAG;GACH,GAAG;GAKH,GAAG;GAGH,QAAQ;GACR,SAAS,QAAQY,8BAAiB,OAAO;GACzC,KAAK,OAAO;GACZ,YAAY;GACZ,kBAAkB;GAClB,WAAW;GACX,eAAe;GACf,gBAAgB;GAChB,gBAAgB;GAChB,cAAc;GACd,YAAY;GACZ,iBAAiB;GACjB,mBAAmB;GACpB;IACA;EACD;EACA;EACA;EACA;EACA;EACA;EACD,CAAC;CAEF,MAAM,yDAEF,WACA,eAC4B;EAC5B,MAAM,SAAS,UAAU,aAAa,CAAC,QAAQ,QAAQ,IAAI;AAC3D,SAAO,OAAO,QAAQ,WAAW,CAAC,QAAQ,KAAK,CAAC,KAAKC,aAAW;AAC9D,OAAI,GAAG,OAAO,GAAG,SAASA;AAC1B,UAAO;KACN,EAAE,CAA4B;IAEnC,EAAE,CACH;CAED,MAAM,0DAAwD;EAC5D,MAAM,YAAY,QAChB,iBAAiBC,0BAAa,iBAC5B,oBAAoB,wBAAwB,IAC5C,oBAAoB,qBAClBC,0BAAa,oBACd,CACJ;EACD,MAAM,aAAa;AAEnB,MAAI;AACF,iCAAO,SACL,+DAA+D,UAAU,cAAc,aACxF;AAED,OAAI,CAAC,UACH,QAAO;AAKT,UAAO;WACA,GAAG;AACV,iCAAO,SACL,2DACA,EACD;AACD,UAAO;;IAER,CAAC,cAAc,mBAAmB,CAAC;CAEtC,MAAM,0DAAiE;AACrE,MAAI,oCAAoC,OACtC,QAAO;EAGT,MAAMC,aAA+B;GACnC,MAAM;GACN,MAAM;GACN,OAAO,YAAY;GACnB,SAAS,OAAO,UAAiC;IAC/C,IAAIC;AAOJ,QALuB,CACrB,2BACA,YAAYC,oCAAuB,eACpC,CAEkB,SAAS,MAAM,WAAW,EAAE;KAC7C,MAAMC,mBAA2C,EAAE;AAEnD,SAAI,UACF,kBAAiB,gCAAgC;AAEnD,SAAI,iBACF,QAAO,QAAQ,iBAAiB,CAAC,SAAS,CAAC,KAAKN,aAAW;AACzD,uBAAiB,qCAAqC,SACpD,OAAOA,QAAM;OACf;AAEJ,SAAI,mBACF,kBAAiB,yCACf;AAEJ,SAAI,oBACF,kBAAiB,0CACf,KAAK,UAAU,oBAAoB;AAEvC,SAAI,QAAQ,KACV,kBAAiB,2BAA2B,OAAO,KAAK;KAG1D,MAAM,kBAAkB,mBAAoB,iBAAiB;KAC7D,MAAM,4BAA4B,OAAO,QACvC,gBACD,CAAC,QACC,KAAK,CAAC,KAAKA,cAAY;MACtB,GAAG;OACF,mBAAmB,QAAQ,GAAGA;MAChC,GACD,EAAE,CACH;KAED,MAAM,mBAAmB,EACvB,yBAAyB,OAAO,aAAa,KAAK,EACnD;AAED,qBAAgB;MACd,GAAG;MACH,kBAAkB;OAChB,GAAG,MAAM;OACT,GAAG,yBAAyB;OAC5B,GAAG;OACH,GAAG;OACH,GAAG;OACJ;MACF;UAED,iBAAgB;AAGlB,oCAAiB,SAASO,yBAAY,iBAAiB,cAAc;AAErE,WAAO;;GAEV;AACD,qCAAmC,WAAW;AAC9C,SAAO;IACN;EACD;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACD,CAAC;AAEF,4BAAgB;AACd,MAAI,WAAW,CAAC,iBAAiB;GAC/B,MAAMC,8EAA0D;GAChE,MAAM,oBAAoB,4BAA4B;AACtD,4BAAyB,IAAI,4BAA4B,CAAC;AAC1D,4BAAyB,KAAK,iBAAkB,QAAS;IACvD,YAAY;IACZ,iBAAiB,EACf,WAAW,MACZ;IACD,aAAa;KACX,aAAa;KACb,WAAW,EACT,qBAAqB,YACtB;KACD,UAAU;KACV,kBAAkB;KAClB,eAAe;KAChB;IACF,CAAC;AACF,sBAAmB,yBAAyB;;IAE7C;EACD;EACA;EACA;EACA;EACA;EACA;EACA;EACD,CAAC;CAEF,MAAM,oCACJ,OAAO,EACL,WACA,YACA,aACA,4BAA4B,YACS;AACrC,gCAAO,SAAS,oBAAoB,UAAU;AAC9C,MAAI;GACF,MAAM,qBAAqB,YAAY;AAEvC,OAAI,CAAC,iBAAiB;AACpB,kCAAO,QAAQ,8BAA8B,QAAW,EACtD,YAAY,oBACb,CAAC;AACF;;GAGF,MAAM,YAAY,KAAK,UAAU;IAC/B;IACA;IACA,6BAAY,IAAI,MAAM,EAAC,aAAa;IACrC,CAAC;GAEF,MAAM,OADU,IAAI,aAAa,CACZ,OAAO,UAAU;GAGtC,MAAM,aAAa,MAAM,OAAO,OAAO,OAAO,WAAW,KAAK;GAE9D,MAAM,kBADY,MAAM,KAAK,IAAI,WAAW,WAAW,CAAC,CAErD,KAAK,MAAM,EAAE,SAAS,GAAG,CAAC,SAAS,GAAG,IAAI,CAAC,CAC3C,KAAK,GAAG;AAEX,iCAAO,SAAS,sBAAsB,sBAAsB,MAAM;IAChE,YAAY;IACZ,OAAO;IACR,CAAC;AAEF,mBAAgB,MACd,oBACA;IACE,GAAG,yBAAyB;IAC5B,GAAG;IACH,GAAI,aACA,+BAA+B,WAAW,WAAW,GACrD,EAAE;IACP,EACD;IACE,GAAG;IACH,WAAW;IACZ,CACF;AAED,OAAI,6BAA6B,aAAa;AAE5C,kCAAO,SAAS,2BAA2B,mBAAmB;AAC9D,QAAI,OAAO,UACT,CAAC,OAAO,UAAoB,KAAK;KAC/B,OAAO;KACK;KACb,CAAC;;WAGC,KAAK;AACZ,iCAAO,SAAS,oCAAoC,KAAK;IACvD;IACA;IACD,CAAC;;IAGN;EACE;EACA;EACA;EACA;EACD,CACF;CAED,MAAM,kCACG;EACL;EACA;EACA,8BAA8B,UAC5B,4BAA4B,MAAM;EACrC,GACD;EAAC;EAAY;EAAS;EAA4B,CACnD;AAED,QACE,2CAAC,iBAAiB;EAAgB;EAC/B;GACyB;;AAIhC,MAAa,qBAAqB;CAChC,MAAM,gCAAqB,iBAAiB;AAC5C,KAAI,CAAC,QACH,OAAM,IAAI,MAAM,qDAAqD;AAEvE,QAAO"}
|
|
@@ -5,4 +5,4 @@ const amplitudeTrackEventAtom = atom(null);
|
|
|
5
5
|
|
|
6
6
|
//#endregion
|
|
7
7
|
export { amplitudeTrackEventAtom };
|
|
8
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
8
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW1wbGl0dWRlVHJhY2tFdmVudEF0b20tRDY2bDVvRnAuanMiLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vc3JjL2F0b21zL2FtcGxpdHVkZS9hbXBsaXR1ZGVUcmFja0V2ZW50QXRvbS50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTcGlmZnlNZXRyaWNzRXZlbnROYW1lIH0gZnJvbSBcIkBlbnZpdmUtYWkvdHlwZXNcIjtcbmltcG9ydCB7IGF0b20gfSBmcm9tIFwiam90YWlcIjtcblxuaW50ZXJmYWNlIFRyYWNrRXZlbnRQYXJhbXMge1xuICBldmVudE5hbWU6IFNwaWZmeU1ldHJpY3NFdmVudE5hbWU7XG4gIGV2ZW50UHJvcHM/OiBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPjtcbiAgZXZlbnRHcm91cHM/OiBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPjtcbiAgYWxzb1NlbmRUb0dvb2dsZUFuYWx5dGljcz86IGJvb2xlYW47XG59XG5cbi8vIFRoaXMgYXRvbSB3aWxsIGhvbGQgdGhlIHRyYWNrRXZlbnQgZnVuY3Rpb24gZnJvbSB0aGUgQW1wbGl0dWRlIGNvbnRleHQuXG4vLyBJdCBuZWVkcyB0byBiZSBpbml0aWFsaXplZCBieSBhIFJlYWN0IGNvbXBvbmVudCB0aGF0IGhhcyBhY2Nlc3MgdG8gdGhlIHVzZUFtcGxpdHVkZSBob29rLlxuZXhwb3J0IGNvbnN0IGFtcGxpdHVkZVRyYWNrRXZlbnRBdG9tID0gYXRvbTxcbiAgKChwYXJhbXM6IFRyYWNrRXZlbnRQYXJhbXMpID0+IFByb21pc2U8dm9pZD4pIHwgbnVsbFxuPihudWxsKTtcbiJdLCJtYXBwaW5ncyI6Ijs7O0FBWUEsTUFBYSwwQkFBMEIsS0FFckMsS0FBSyJ9
|
|
@@ -12,4 +12,4 @@ Object.defineProperty(exports, 'amplitudeTrackEventAtom', {
|
|
|
12
12
|
return amplitudeTrackEventAtom;
|
|
13
13
|
}
|
|
14
14
|
});
|
|
15
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
15
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW1wbGl0dWRlVHJhY2tFdmVudEF0b20tZjIyUDJVMHUuY2pzIiwibmFtZXMiOltdLCJzb3VyY2VzIjpbIi4uL3NyYy9hdG9tcy9hbXBsaXR1ZGUvYW1wbGl0dWRlVHJhY2tFdmVudEF0b20udHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU3BpZmZ5TWV0cmljc0V2ZW50TmFtZSB9IGZyb20gXCJAZW52aXZlLWFpL3R5cGVzXCI7XG5pbXBvcnQgeyBhdG9tIH0gZnJvbSBcImpvdGFpXCI7XG5cbmludGVyZmFjZSBUcmFja0V2ZW50UGFyYW1zIHtcbiAgZXZlbnROYW1lOiBTcGlmZnlNZXRyaWNzRXZlbnROYW1lO1xuICBldmVudFByb3BzPzogUmVjb3JkPHN0cmluZywgdW5rbm93bj47XG4gIGV2ZW50R3JvdXBzPzogUmVjb3JkPHN0cmluZywgdW5rbm93bj47XG4gIGFsc29TZW5kVG9Hb29nbGVBbmFseXRpY3M/OiBib29sZWFuO1xufVxuXG4vLyBUaGlzIGF0b20gd2lsbCBob2xkIHRoZSB0cmFja0V2ZW50IGZ1bmN0aW9uIGZyb20gdGhlIEFtcGxpdHVkZSBjb250ZXh0LlxuLy8gSXQgbmVlZHMgdG8gYmUgaW5pdGlhbGl6ZWQgYnkgYSBSZWFjdCBjb21wb25lbnQgdGhhdCBoYXMgYWNjZXNzIHRvIHRoZSB1c2VBbXBsaXR1ZGUgaG9vay5cbmV4cG9ydCBjb25zdCBhbXBsaXR1ZGVUcmFja0V2ZW50QXRvbSA9IGF0b208XG4gICgocGFyYW1zOiBUcmFja0V2ZW50UGFyYW1zKSA9PiBQcm9taXNlPHZvaWQ+KSB8IG51bGxcbj4obnVsbCk7XG4iXSwibWFwcGluZ3MiOiI7Ozs7O0FBWUEsTUFBYSwwQ0FFWCxLQUFLIn0=
|
|
@@ -2,7 +2,7 @@ import { ApiResponse as ApiResponse$1, Message as Message$1, Suggestion as Sugge
|
|
|
2
2
|
import { NodeSelector, SelectorFactory } from "../../nodeSelector-BYEAyrsj.cjs";
|
|
3
3
|
import { Context, NextMessageRequest, SupportedEventRequest, UserEvent } from "@spiffy-ai/commerce-api-client";
|
|
4
4
|
import { CamelCasedPropertiesDeep, FormResponseAttributes, MergeOptions, Message, MouseEventTypes, NextMessageRequest as NextMessageRequest$1, NoInfer, Override, SearchMessage, SpiffyMetricsEventName, SupportedEventRequest as SupportedEventRequest$1, UserEvent as UserEvent$1 } from "@envive-ai/types";
|
|
5
|
-
import * as
|
|
5
|
+
import * as react0 from "react";
|
|
6
6
|
import { ReactElement } from "react";
|
|
7
7
|
|
|
8
8
|
//#region src/application/utils/analyticsUtils.d.ts
|
|
@@ -67,7 +67,7 @@ declare class ElementObserver {
|
|
|
67
67
|
init(): void;
|
|
68
68
|
watch(node: Node): void;
|
|
69
69
|
destroy(): void;
|
|
70
|
-
render(fn: () => ReactElement):
|
|
70
|
+
render(fn: () => ReactElement): react0.ReactPortal | undefined;
|
|
71
71
|
fire(event: MouseEventTypes): void;
|
|
72
72
|
show(): void;
|
|
73
73
|
hide(): void;
|
|
@@ -210,4 +210,4 @@ declare const parseSearchHash: (hash: string) => {
|
|
|
210
210
|
declare const validateEmail: (value: string) => boolean;
|
|
211
211
|
//#endregion
|
|
212
212
|
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 };
|
|
213
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"index.d.cts","names":[],"sources":["../../../src/application/utils/analyticsUtils.d.ts","../../../src/application/utils/coreContextToApiContext.d.ts","../../../src/application/utils/coreUserEventToApiUserEvent.d.ts","../../../src/application/utils/divideArray.d.ts","../../../src/application/utils/elementObserver.d.ts","../../../src/application/utils/domObserver.d.ts","../../../src/application/utils/imageFilter.d.ts","../../../src/application/utils/merchantUtils.d.ts","../../../src/application/utils/messageFromFormSubmittedEvent.d.ts","../../../src/application/utils/messageFromQueryEvent.d.ts","../../../src/application/utils/messageFromResponse.d.ts","../../../src/application/utils/messageFromSuggestionEvent.d.ts","../../../src/application/utils/mutationHelper.d.ts","../../../src/application/utils/nextMessageRequestToApiRequest.d.ts","../../../src/application/utils/overrides.d.ts","../../../src/application/utils/stringUtils.d.ts","../../../src/application/utils/supportedEventRequestToApiRequest.d.ts","../../../src/application/utils/urlsParser.d.ts","../../../src/application/utils/validation.d.ts"],"sourcesContent":["import { SpiffyMetricsEventName } from \"@envive-ai/types\";\n/**\n * Wraps the window.dataLayer.push method to intercept add_to_cart events and send them to Amplitude.\n * This function runs on an interval until the dataLayer is available.\n */\nexport declare const initDataLayerWrapper: (track: (eventName: SpiffyMetricsEventName, eventProps?: Record<string, unknown>) => void) => void;\nexport declare const initAmplitude: (track: (eventName: SpiffyMetricsEventName, eventProps?: Record<string, unknown>) => void) => void;\n","import { CamelCasedPropertiesDeep } from '@envive-ai/types';\nimport { Context as ApiContext } from '@spiffy-ai/commerce-api-client';\ninterface CoreContext extends CamelCasedPropertiesDeep<ApiContext> {\n}\nexport declare const coreContextToApiContext: (context: CoreContext) => ApiContext;\nexport {};\n","import { UserEvent } from '@envive-ai/types';\nimport { UserEvent as ApiUserEvent } from '@spiffy-ai/commerce-api-client';\nexport declare const coreUserEventToApiUserEvent: (data: UserEvent) => ApiUserEvent;\n","export declare const divideArray: <T>(array: T[], size: number) => T[][];\n","import { ReactElement } from 'react';\nimport { MouseEventTypes } from '@envive-ai/types';\nimport { NodeSelector } from './nodeSelector';\n/**\n * The `ElementObserver` class monitors all changes related to the specific element it is responsible for.\n * It is automatically instantiated by the `useElementObserver` hook, which manages all instances of this class.\n *\n * How it works:\n *\n * Each instance of `ElementObserver` holds several pieces of information related to the node it is monitoring,\n * such as the node's selector and its `MutationObserver`. This class is responsible for translating raw node\n * changes into a more user-friendly format. For example, when the node is added to the DOM, the `ElementObserver`\n * is notified by the `DOMObserver`, which triggers the `onAdd` callback function on the respective `useElementObserver`\n * instance.\n *\n * Instances of `ElementObserver` are fully managed by the `useElementObserver` hook, requiring no additional configuration.\n * When the hook is destroyed, its corresponding `ElementObserver` instance is automatically removed.\n *\n */\nexport declare class ElementObserver {\n    private mutation;\n    private node;\n    private selector;\n    private eventListeners;\n    private classAdded;\n    private classRemoved;\n    private nodeDisplay;\n    private addFn;\n    private removeFn;\n    private changeFn;\n    private classChangeFn;\n    private addChildFn?;\n    private removeChildFn?;\n    private resetFn;\n    constructor(selector: NodeSelector);\n    private handleAttributes;\n    private handleChildList;\n    private addInitialListeners;\n    private clearEventListeners;\n    private renew;\n    getSelector(): NodeSelector;\n    getNode(): HTMLElement | null;\n    synchronize(): void;\n    init(): void;\n    watch(node: Node): void;\n    destroy(): void;\n    render(fn: () => ReactElement): import(\"react\").ReactPortal | undefined;\n    fire(event: MouseEventTypes): void;\n    show(): void;\n    hide(): void;\n    registerEvent(event: keyof HTMLElementEventMap, fn: EventListenerOrEventListenerObject): void;\n    registerOnReset(fn: () => void): void;\n    registerOnChange(fn: (el: HTMLElement | null) => void): void;\n    registerOnAdd(fn: (el: HTMLElement | null) => void): void;\n    registerOnRemove(fn: (el: HTMLElement | null) => void): void;\n    registerOnclassChange(fn: (classes?: DOMTokenList) => void): void;\n    registerOnAddChild(fn: (classes?: DOMTokenList) => void): void;\n    registerOnRemoveChild(fn: (classes?: DOMTokenList) => void): void;\n    registerOnClassAdded(className: string, fn: () => void): void;\n    registerOnClassRemoved(className: string, fn: () => void): void;\n}\n","import { ElementObserver } from './elementObserver';\nimport { NodeSelector } from './nodeSelector';\n/**\n * This class manages a `MutationObserver` for the `document.body`. It monitors nodes that are\n * added or removed from the DOM and notifies the observers for each observable element\n * when they are ready to be watched.\n *\n * How that works:\n *\n * When the `observe` function is called, it attaches a `MutationObserver` to the `document.body` element.\n * All changes to `document.body` are tracked by this observer. When changes are detected, the `MutationObserver`\n * iterates through all added and removed nodes and checks if each node exists in the main map of observable elements.\n *\n * If a match is found, it notifies the corresponding `ElementObserver` instance to start monitoring changes for that element.\n *\n * The primary `MutationObserver` remains active until the `destroy` function is called. Calling `destroy` will disconnect all\n * individual element observers and release any associated resources.\n *\n * There is no need to explicitly call the `observe` function. It is automatically invoked when a `useElementObserver` hook is instantiated.\n *\n */\nexport declare class DOMObserver {\n    private static documentObserver;\n    private static listeners;\n    private static notifyAdition;\n    private static notifyRemoval;\n    private static notifyChildrenChanges;\n    private static mapNodeInstancesToListeners;\n    static add(selector: NodeSelector): ElementObserver;\n    static remove(selector: NodeSelector): void;\n    static observe(): void;\n    static destroy(): void;\n}\n","import { Message } from '@envive-ai/types';\nexport declare const getRecentProductImageUrls: (lastMessages: Message[], currentProductId: string | undefined) => string[];\n","export declare const prepareMerchantPage: () => void;\n","import { FormResponseAttributes, Message, UserEvent } from '@envive-ai/types';\nexport declare const messageFromFormSubmittedEvent: (event: UserEvent, formResponseAttributes: FormResponseAttributes[\"attributes\"]) => Message | undefined;\n","import { Message, UserEvent } from '@envive-ai/types';\n/**\n * Transforms a query UserEvent object into a Message object for presentation.\n *\n * @param event The user event object received from the server\n *\n * @returns A Message if the event is a query event, otherwise undefined\n */\nexport declare const messageFromQueryEvent: (event: UserEvent) => Message | undefined;\n","import { Message, ApiResponse } from \"src/types\";\n/**\n * Transforms a server Response object into a Message object for presentation.\n *\n * @param response The response object received from the server containing model generated content\n *\n * @returns A Message if the response contains known attributes, undefined otherwise\n */\nexport declare const messageFromResponse: (response?: ApiResponse) => Message | undefined;\n","import { Message, Suggestion } from \"src/types\";\nimport { UserEvent } from \"@envive-ai/types\";\n/**\n * Transforms a UserEvent object into a Message object for presentation.\n *\n * @param event The UserEvent object received from the server\n * @param suggestions A list of generated suggestions to match the event to\n *\n * @returns A Message if the event is a suggestion click event, undefined otherwise\n */\nexport declare const messageFromSuggestionEvent: (event: UserEvent, suggestions: Suggestion[]) => Message | undefined;\n","export declare class MutationHelper {\n    static fireClassChange(record: MutationRecord, node: HTMLElement | null, fn: (classes: DOMTokenList) => void): void;\n    static fireClassAdded(record: MutationRecord, node: HTMLElement | null, classMap: Map<string, () => void>): void;\n    static fireClassRemoved(record: MutationRecord, node: HTMLElement | null, classMap: Map<string, () => void>): void;\n    static fireSubtreeChange(nodes: NodeList, fn?: (nodes: NodeList) => void): void;\n    static isClass(mutation: MutationRecord): boolean;\n    static isChildList(mutation: MutationRecord): boolean;\n}\n","import { NextMessageRequest as ApiNextMessageRequest } from '@spiffy-ai/commerce-api-client';\nimport { NextMessageRequest } from '@envive-ai/types';\nexport declare const messageRequestToCommerceMessageRequest: (data: NextMessageRequest) => ApiNextMessageRequest;\n","import { MergeOptions, NoInfer, Override } from '@envive-ai/types';\nexport declare function applyOverrides<T>(base: T, patch: Override<NoInfer<T>>, opts?: MergeOptions): T;\n","declare class StringUtils {\n    static isNullOrEmpty(value: string | undefined): boolean;\n    static trimToNull(value: string | undefined): string | undefined;\n    static capitalize(type: string | undefined): string;\n    /**\n     * Finds the first pattern in an array that matches a given URL.\n     * Patterns can include a single wildcard '*' which matches any sequence of characters.\n     *\n     * @param patterns\n     * @param urlToTest\n     * @returns\n     */\n    static findMatchingPattern(patterns: string[], urlToTest: Location): string | undefined;\n}\nexport { StringUtils };\n","import { SupportedEventRequest as ApiSupportedEventRequest } from '@spiffy-ai/commerce-api-client';\nimport { SupportedEventRequest } from '@envive-ai/types';\ntype CoreSupportedEventRequest = SupportedEventRequest;\nexport declare const coreSupportedEventRequestToApiRequest: (coreSupportedEventRequest: CoreSupportedEventRequest) => ApiSupportedEventRequest;\nexport {};\n","import { SearchMessage } from '@envive-ai/types';\nexport declare const parseHref: (href: string) => {\n    url: URL | undefined;\n    urlSearchParams: URLSearchParams | undefined;\n};\nexport declare const createUrlWithQueryParams: (url: string, queryParams: Record<string, string>) => string;\nexport declare const getQueryParam: (key: string) => string | null;\nexport declare const buildSearchHash: (message: SearchMessage) => string;\nexport declare const buildSearchStartHash: (query: string) => string;\nexport declare const parseSearchHash: (hash: string) => {\n    id: string | null;\n    query: string | null;\n};\n","export declare const validateEmail: (value: string) => boolean;\n"],"mappings":";;;;;;;;AACA,IAAE,uBAAA;CAAA;OAAA;OAAA;CAAA;AACF,IAAW,gBAAgB;CAAC;OAAW;OAA8B;CAAO;;;;ACA5E,IAAI,cAAc;CAAC;OAAW;OAAkB;CAAmB;AACnE,IAAA,0BAAA;CAAA;OAAA;OAAA;CAAA;;;;ACDA,IAAW,8BAA8B;CAAC;OAAW;OAAiB;CAAa;;;;ACFnF,IAAW,cAAc;CAAC;OAAW;OAAS;CAAE;;;;ACIhD,IAAW,kBAAkB;CAAC;OAAW;OAAoB;OAAoB;OAAmB;OAAK;OAAA,OAAA;OAAA;OAAA;OAAA;OAAA;OAAA;OAAA;OAAA;OAAA;OAAA;CAAA;;;;ACFzG,IAAE,cAAA;CAAA;OAAA;OAAA;OAAA;CAAA;;;;ACDF,IAAW,4BAA4B,CAAC,WAAW,QAAQ;;;;ACD3D,IAAW,sBAAsB,CAAC,IAAI;;;;ACCtC,IAAW,gCAAgC;CAAC;OAAW;OAAiB;OAA8B;CAAQ;;;;ACA9G,IAAE,wBAAA;CAAA;OAAA;OAAA;CAAA;;;;ACAF,IAAE,sBAAA;CAAA;OAAA;OAAA;CAAA;;;;ACCF,IAAE,6BAAA;CAAA;OAAA;OAAA;OAAA;CAAA;;;;ACFF,IAAW,iBAAiB;CAAC;OAAO;OAAA;OAAA;OAAA;OAAA;OAAA;OAAA;OAAA;OAAA;OAAA;OAAA;OAAA;OAAA;CAAA;;;;ACEpC,IAAW,yCAAyC;CAAC;OAAW;OAA0B;CAAsB;;;;ACDhH,IAAW,iBAAiB;CAAC;OAAW;OAAS;OAAS;OAAe;OAAgB;OAAc;CAAA;;;;ACDvG,IAAI,cAAc,CAAC,WAAO,SAAA;;;;ACE1B,IAAI,4BAA4B,CAAC,WAAW,wBAAU;AACtD,IAAW,wCAAwC;CAAC;OAAW;OAAiC;CAAyB;;;;ACFzH,IAAW,YAAY;CAAC;OAAW;OAAW;CAAI;AAClD,IAAW,2BAAa,CAAA,WAAA,OAAA;AACxB,IAAW,gBAAgB,CAAC,IAAI;AAChC,IAAC,kBAAA,CAAA,WAAA,cAAA;AACD,IAAW,uBAAuB,CAAC,IAAI;AACvC,IAAW,kBAAkB,CAAC,IAAI;;;;ACNlC,IAAW,gBAAgB,CAAC,IAAI"}
|
|
213
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"index.d.cts","names":[],"sources":["../../../src/application/utils/analyticsUtils.d.ts","../../../src/application/utils/coreContextToApiContext.d.ts","../../../src/application/utils/coreUserEventToApiUserEvent.d.ts","../../../src/application/utils/divideArray.d.ts","../../../src/application/utils/elementObserver.d.ts","../../../src/application/utils/domObserver.d.ts","../../../src/application/utils/imageFilter.d.ts","../../../src/application/utils/merchantUtils.d.ts","../../../src/application/utils/messageFromFormSubmittedEvent.d.ts","../../../src/application/utils/messageFromQueryEvent.d.ts","../../../src/application/utils/messageFromResponse.d.ts","../../../src/application/utils/messageFromSuggestionEvent.d.ts","../../../src/application/utils/mutationHelper.d.ts","../../../src/application/utils/nextMessageRequestToApiRequest.d.ts","../../../src/application/utils/overrides.d.ts","../../../src/application/utils/stringUtils.d.ts","../../../src/application/utils/supportedEventRequestToApiRequest.d.ts","../../../src/application/utils/urlsParser.d.ts","../../../src/application/utils/validation.d.ts"],"sourcesContent":["import { SpiffyMetricsEventName } from \"@envive-ai/types\";\n/**\n * Wraps the window.dataLayer.push method to intercept add_to_cart events and send them to Amplitude.\n * This function runs on an interval until the dataLayer is available.\n */\nexport declare const initDataLayerWrapper: (track: (eventName: SpiffyMetricsEventName, eventProps?: Record<string, unknown>) => void) => void;\nexport declare const initAmplitude: (track: (eventName: SpiffyMetricsEventName, eventProps?: Record<string, unknown>) => void) => void;\n","import { CamelCasedPropertiesDeep } from '@envive-ai/types';\nimport { Context as ApiContext } from '@spiffy-ai/commerce-api-client';\ninterface CoreContext extends CamelCasedPropertiesDeep<ApiContext> {\n}\nexport declare const coreContextToApiContext: (context: CoreContext) => ApiContext;\nexport {};\n","import { UserEvent } from '@envive-ai/types';\nimport { UserEvent as ApiUserEvent } from '@spiffy-ai/commerce-api-client';\nexport declare const coreUserEventToApiUserEvent: (data: UserEvent) => ApiUserEvent;\n","export declare const divideArray: <T>(array: T[], size: number) => T[][];\n","import { ReactElement } from 'react';\nimport { MouseEventTypes } from '@envive-ai/types';\nimport { NodeSelector } from './nodeSelector';\n/**\n * The `ElementObserver` class monitors all changes related to the specific element it is responsible for.\n * It is automatically instantiated by the `useElementObserver` hook, which manages all instances of this class.\n *\n * How it works:\n *\n * Each instance of `ElementObserver` holds several pieces of information related to the node it is monitoring,\n * such as the node's selector and its `MutationObserver`. This class is responsible for translating raw node\n * changes into a more user-friendly format. For example, when the node is added to the DOM, the `ElementObserver`\n * is notified by the `DOMObserver`, which triggers the `onAdd` callback function on the respective `useElementObserver`\n * instance.\n *\n * Instances of `ElementObserver` are fully managed by the `useElementObserver` hook, requiring no additional configuration.\n * When the hook is destroyed, its corresponding `ElementObserver` instance is automatically removed.\n *\n */\nexport declare class ElementObserver {\n    private mutation;\n    private node;\n    private selector;\n    private eventListeners;\n    private classAdded;\n    private classRemoved;\n    private nodeDisplay;\n    private addFn;\n    private removeFn;\n    private changeFn;\n    private classChangeFn;\n    private addChildFn?;\n    private removeChildFn?;\n    private resetFn;\n    constructor(selector: NodeSelector);\n    private handleAttributes;\n    private handleChildList;\n    private addInitialListeners;\n    private clearEventListeners;\n    private renew;\n    getSelector(): NodeSelector;\n    getNode(): HTMLElement | null;\n    synchronize(): void;\n    init(): void;\n    watch(node: Node): void;\n    destroy(): void;\n    render(fn: () => ReactElement): import(\"react\").ReactPortal | undefined;\n    fire(event: MouseEventTypes): void;\n    show(): void;\n    hide(): void;\n    registerEvent(event: keyof HTMLElementEventMap, fn: EventListenerOrEventListenerObject): void;\n    registerOnReset(fn: () => void): void;\n    registerOnChange(fn: (el: HTMLElement | null) => void): void;\n    registerOnAdd(fn: (el: HTMLElement | null) => void): void;\n    registerOnRemove(fn: (el: HTMLElement | null) => void): void;\n    registerOnclassChange(fn: (classes?: DOMTokenList) => void): void;\n    registerOnAddChild(fn: (classes?: DOMTokenList) => void): void;\n    registerOnRemoveChild(fn: (classes?: DOMTokenList) => void): void;\n    registerOnClassAdded(className: string, fn: () => void): void;\n    registerOnClassRemoved(className: string, fn: () => void): void;\n}\n","import { ElementObserver } from './elementObserver';\nimport { NodeSelector } from './nodeSelector';\n/**\n * This class manages a `MutationObserver` for the `document.body`. It monitors nodes that are\n * added or removed from the DOM and notifies the observers for each observable element\n * when they are ready to be watched.\n *\n * How that works:\n *\n * When the `observe` function is called, it attaches a `MutationObserver` to the `document.body` element.\n * All changes to `document.body` are tracked by this observer. When changes are detected, the `MutationObserver`\n * iterates through all added and removed nodes and checks if each node exists in the main map of observable elements.\n *\n * If a match is found, it notifies the corresponding `ElementObserver` instance to start monitoring changes for that element.\n *\n * The primary `MutationObserver` remains active until the `destroy` function is called. Calling `destroy` will disconnect all\n * individual element observers and release any associated resources.\n *\n * There is no need to explicitly call the `observe` function. It is automatically invoked when a `useElementObserver` hook is instantiated.\n *\n */\nexport declare class DOMObserver {\n    private static documentObserver;\n    private static listeners;\n    private static notifyAdition;\n    private static notifyRemoval;\n    private static notifyChildrenChanges;\n    private static mapNodeInstancesToListeners;\n    static add(selector: NodeSelector): ElementObserver;\n    static remove(selector: NodeSelector): void;\n    static observe(): void;\n    static destroy(): void;\n}\n","import { Message } from '@envive-ai/types';\nexport declare const getRecentProductImageUrls: (lastMessages: Message[], currentProductId: string | undefined) => string[];\n","export declare const prepareMerchantPage: () => void;\n","import { FormResponseAttributes, Message, UserEvent } from '@envive-ai/types';\nexport declare const messageFromFormSubmittedEvent: (event: UserEvent, formResponseAttributes: FormResponseAttributes[\"attributes\"]) => Message | undefined;\n","import { Message, UserEvent } from '@envive-ai/types';\n/**\n * Transforms a query UserEvent object into a Message object for presentation.\n *\n * @param event The user event object received from the server\n *\n * @returns A Message if the event is a query event, otherwise undefined\n */\nexport declare const messageFromQueryEvent: (event: UserEvent) => Message | undefined;\n","import { Message, ApiResponse } from \"src/types\";\n/**\n * Transforms a server Response object into a Message object for presentation.\n *\n * @param response The response object received from the server containing model generated content\n *\n * @returns A Message if the response contains known attributes, undefined otherwise\n */\nexport declare const messageFromResponse: (response?: ApiResponse) => Message | undefined;\n","import { Message, Suggestion } from \"src/types\";\nimport { UserEvent } from \"@envive-ai/types\";\n/**\n * Transforms a UserEvent object into a Message object for presentation.\n *\n * @param event The UserEvent object received from the server\n * @param suggestions A list of generated suggestions to match the event to\n *\n * @returns A Message if the event is a suggestion click event, undefined otherwise\n */\nexport declare const messageFromSuggestionEvent: (event: UserEvent, suggestions: Suggestion[]) => Message | undefined;\n","export declare class MutationHelper {\n    static fireClassChange(record: MutationRecord, node: HTMLElement | null, fn: (classes: DOMTokenList) => void): void;\n    static fireClassAdded(record: MutationRecord, node: HTMLElement | null, classMap: Map<string, () => void>): void;\n    static fireClassRemoved(record: MutationRecord, node: HTMLElement | null, classMap: Map<string, () => void>): void;\n    static fireSubtreeChange(nodes: NodeList, fn?: (nodes: NodeList) => void): void;\n    static isClass(mutation: MutationRecord): boolean;\n    static isChildList(mutation: MutationRecord): boolean;\n}\n","import { NextMessageRequest as ApiNextMessageRequest } from '@spiffy-ai/commerce-api-client';\nimport { NextMessageRequest } from '@envive-ai/types';\nexport declare const messageRequestToCommerceMessageRequest: (data: NextMessageRequest) => ApiNextMessageRequest;\n","import { MergeOptions, NoInfer, Override } from '@envive-ai/types';\nexport declare function applyOverrides<T>(base: T, patch: Override<NoInfer<T>>, opts?: MergeOptions): T;\n","declare class StringUtils {\n    static isNullOrEmpty(value: string | undefined): boolean;\n    static trimToNull(value: string | undefined): string | undefined;\n    static capitalize(type: string | undefined): string;\n    /**\n     * Finds the first pattern in an array that matches a given URL.\n     * Patterns can include a single wildcard '*' which matches any sequence of characters.\n     *\n     * @param patterns\n     * @param urlToTest\n     * @returns\n     */\n    static findMatchingPattern(patterns: string[], urlToTest: Location): string | undefined;\n}\nexport { StringUtils };\n","import { SupportedEventRequest as ApiSupportedEventRequest } from '@spiffy-ai/commerce-api-client';\nimport { SupportedEventRequest } from '@envive-ai/types';\ntype CoreSupportedEventRequest = SupportedEventRequest;\nexport declare const coreSupportedEventRequestToApiRequest: (coreSupportedEventRequest: CoreSupportedEventRequest) => ApiSupportedEventRequest;\nexport {};\n","import { SearchMessage } from '@envive-ai/types';\nexport declare const parseHref: (href: string) => {\n    url: URL | undefined;\n    urlSearchParams: URLSearchParams | undefined;\n};\nexport declare const createUrlWithQueryParams: (url: string, queryParams: Record<string, string>) => string;\nexport declare const getQueryParam: (key: string) => string | null;\nexport declare const buildSearchHash: (message: SearchMessage) => string;\nexport declare const buildSearchStartHash: (query: string) => string;\nexport declare const parseSearchHash: (hash: string) => {\n    id: string | null;\n    query: string | null;\n};\n","export declare const validateEmail: (value: string) => boolean;\n"],"mappings":";;;;;;;;AACA,IAAE,uBAAA;CAAA;OAAA;OAAA;CAAA;AACF,IAAW,gBAAgB;CAAC;OAAU;OAA8B;CAAO;;;;ACA3E,IAAI,cAAc;CAAC;OAAU;OAAkB;CAAoB;AACnE,IAAA,0BAAA;CAAA;OAAA;OAAA;CAAA;;;;ACDA,IAAW,8BAA8B;CAAC;OAAU;OAAiB;CAAa;;;;ACFlF,IAAW,cAAc;CAAC;OAAU;OAAS;CAAE;;;;ACI/C,IAAW,kBAAkB;CAAC;OAAU;OAAoB;OAAoB;OAAmB;OAAM;OAAA,OAAA;OAAA;OAAA;OAAA;OAAA;OAAA;OAAA;OAAA;OAAA;OAAA;CAAA;;;;ACFzG,IAAE,cAAA;CAAA;OAAA;OAAA;OAAA;CAAA;;;;ACDF,IAAW,4BAA4B,CAAC,UAAU,QAAQ;;;;ACD1D,IAAW,sBAAsB,CAAC,GAAG;;;;ACCrC,IAAW,gCAAgC;CAAC;OAAU;OAAiB;OAA8B;CAAQ;;;;ACA7G,IAAE,wBAAA;CAAA;OAAA;OAAA;CAAA;;;;ACAF,IAAE,sBAAA;CAAA;OAAA;OAAA;CAAA;;;;ACCF,IAAE,6BAAA;CAAA;OAAA;OAAA;OAAA;CAAA;;;;ACFF,IAAW,iBAAiB;CAAC;OAAO;OAAA;OAAA;OAAA;OAAA;OAAA;OAAA;OAAA;OAAA;OAAA;OAAA;OAAA;OAAA;CAAA;;;;ACEpC,IAAW,yCAAyC;CAAC;OAAW;OAA0B;CAAsB;;;;ACDhH,IAAW,iBAAiB;CAAC;OAAU;OAAS;OAAS;OAAe;OAAgB;OAAe;CAAA;;;;ACDvG,IAAI,cAAc,CAAC,WAAO,SAAA;;;;ACE1B,IAAI,4BAA4B,CAAC,UAAU,wBAAW;AACtD,IAAW,wCAAwC;CAAC;OAAU;OAAiC;CAAyB;;;;ACFxH,IAAW,YAAY;CAAC;OAAU;OAAW;CAAK;AAClD,IAAW,2BAAa,CAAA,UAAA,OAAA;AACxB,IAAW,gBAAgB,CAAC,GAAG;AAC/B,IAAC,kBAAA,CAAA,WAAA,cAAA;AACD,IAAW,uBAAuB,CAAC,IAAI;AACvC,IAAW,kBAAkB,CAAC,IAAI;;;;ACNlC,IAAW,gBAAgB,CAAC,IAAI"}
|
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
import { ContextEnvEnum, ContextSourceEnum } from "@spiffy-ai/commerce-api-client";
|
|
2
2
|
import { UserIdentityContextType, VariantInfo } from "@envive-ai/types";
|
|
3
|
-
import * as
|
|
3
|
+
import * as jotai8 from "jotai";
|
|
4
4
|
import * as jotai_utils0 from "jotai/utils";
|
|
5
5
|
|
|
6
6
|
//#region src/atoms/app/variant.d.ts
|
|
7
7
|
|
|
8
|
-
declare const variantInfoAtom:
|
|
8
|
+
declare const variantInfoAtom: jotai8.WritableAtom<VariantInfo, [newVariant: VariantInfo], void>;
|
|
9
9
|
//#endregion
|
|
10
10
|
//#region src/atoms/app/index.d.ts
|
|
11
11
|
interface AppDetails {
|
|
@@ -17,12 +17,12 @@ interface AppDetails {
|
|
|
17
17
|
env: ContextEnvEnum;
|
|
18
18
|
variantInfo: VariantInfo;
|
|
19
19
|
}
|
|
20
|
-
declare const userIdAtom:
|
|
21
|
-
declare const userIdentityAtom:
|
|
20
|
+
declare const userIdAtom: jotai8.WritableAtom<string, [value: string | undefined], void>;
|
|
21
|
+
declare const userIdentityAtom: jotai8.PrimitiveAtom<UserIdentityContextType | undefined> & {
|
|
22
22
|
init: UserIdentityContextType | undefined;
|
|
23
23
|
};
|
|
24
|
-
declare const appSourceAtom:
|
|
25
|
-
declare const chatIdAtom:
|
|
24
|
+
declare const appSourceAtom: jotai8.Atom<ContextSourceEnum>;
|
|
25
|
+
declare const chatIdAtom: jotai8.WritableAtom<string, [string | typeof jotai_utils0.RESET | ((prev: string) => string | typeof jotai_utils0.RESET)], void>;
|
|
26
26
|
//#endregion
|
|
27
27
|
export { AppDetails, appSourceAtom, chatIdAtom, userIdAtom, userIdentityAtom, variantInfoAtom };
|
|
28
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC5jdHMiLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2F0b21zL2FwcC92YXJpYW50LmQudHMiLCIuLi8uLi8uLi9zcmMvYXRvbXMvYXBwL2luZGV4LmQudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU3VwcG9ydGVkRXZlbnRSZXNwb25zZSwgUGFnZVZpc2l0Q2F0ZWdvcnkgfSBmcm9tICdAc3BpZmZ5LWFpL2NvbW1lcmNlLWFwaS1jbGllbnQnO1xuaW1wb3J0IHsgVmFyaWFudEluZm8gfSBmcm9tICdAZW52aXZlLWFpL3R5cGVzJztcbmV4cG9ydCBpbnRlcmZhY2UgU3VwcG9ydGVkRXZlbnQgZXh0ZW5kcyBQaWNrPFN1cHBvcnRlZEV2ZW50UmVzcG9uc2UsICdzdXBwb3J0ZWQnIHwgJ3JlYWR5JyB8ICdjYXRlZ29yeScgfCAnY29sbGVjdGlvbnMnIHwgJ3RvcF9jYXRlZ29yeSc+IHtcbiAgICBudW1iZXJPZlJldmlld3M6IG51bWJlciB8IHVuZGVmaW5lZDtcbiAgICBtZXJjaGFudF90YWdzPzogc3RyaW5nW107XG59XG5pbnRlcmZhY2UgUERQQXR0cmlidXRlcyB7XG4gICAgcHJvZHVjdF9pZD86IHN0cmluZztcbn1cbmludGVyZmFjZSBQTFBBdHRyaWJ1dGVzIHtcbiAgICBhdHRyaWJ1dGVzPzoge1xuICAgICAgICBpZD86IHN0cmluZztcbiAgICB9O1xufVxuZXhwb3J0IGludGVyZmFjZSBVcmxSZXNvbHZpbmdQRFBDb25maWcge1xuICAgIHBkcF9hdHRyaWJ1dGVzOiBQRFBBdHRyaWJ1dGVzO1xuICAgIG51bWJlcl9vZl9yZXZpZXdzPzogbnVtYmVyO1xuICAgIGNvbGxlY3Rpb25zPzogc3RyaW5nW107XG4gICAgbWVyY2hhbnRfdGFncz86IHN0cmluZ1tdO1xufVxuZXhwb3J0IGludGVyZmFjZSBVcmxSZXNvbHZpbmdQTFBDb25maWcge1xuICAgIHBscF9hdHRyaWJ1dGVzOiBQTFBBdHRyaWJ1dGVzO1xuICAgIHRvcF9jYXRlZ29yeT86IHN0cmluZztcbn1cbmludGVyZmFjZSBVcmxSZXNvbHZpbmdHZW5lcmljQ29uZmlnIHtcbiAgICBkZXRhaWxzPzogc3RyaW5nO1xufVxuZXhwb3J0IHR5cGUgUGFnZVZhcmlhbnRDaGVja0NvbmZpZyA9IHtcbiAgICBjaGVja190eXBlOiBzdHJpbmc7XG4gICAgZmVhdHVyZV9nYXRlPzogc3RyaW5nO1xuICAgIGV4dHJhY3Rvcj86IHtcbiAgICAgICAgdHlwZTogc3RyaW5nO1xuICAgICAgICBtYXA/OiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmdbXT47XG4gICAgICAgIHZhbHVlPzogc3RyaW5nO1xuICAgIH07XG4gICAgcHJvZHVjdF9pZF9leHRyYWN0b3I/OiBzdHJpbmc7XG4gICAgcHJvZHVjdF9pZHM/OiBzdHJpbmdbXTtcbiAgICBwbHBfaWRfZXh0cmFjdG9yPzogc3RyaW5nO1xuICAgIHBscF9pZHM/OiBzdHJpbmdbXTtcbiAgICBjb2xsZWN0aW9ucz86IHN0cmluZ1tdO1xuICAgIHF1ZXJ5X3BhcmFtPzogc3RyaW5nO1xuICAgIGNhdGVnb3J5Pzogc3RyaW5nO1xuICAgIHRvcF9jYXRlZ29yeT86IHN0cmluZ1tdO1xuICAgIHJldmlld19taW5pbXVtPzogbnVtYmVyO1xuICAgIG1lcmNoYW50X3RhZ3M/OiBzdHJpbmdbXTtcbn07XG5leHBvcnQgdHlwZSBCYWNrZW5kV2lkZ2V0TW91bnRpbmdDb25maWcgPSB7XG4gICAgbW91bnRpbmdfY29uZmlnX2lkOiBzdHJpbmc7XG4gICAgd2lkZ2V0X2NvbmZpZ19pZD86IHN0cmluZztcbiAgICBtb3VudGluZ19wb2ludF93aWRnZXRzPzogQXJyYXk8e1xuICAgICAgICBjaGVja3M6IFBhZ2VWYXJpYW50Q2hlY2tDb25maWdbXTtcbiAgICAgICAgd2lkZ2V0X2NvbmZpZ19pZDogc3RyaW5nO1xuICAgIH0+O1xufTtcbmV4cG9ydCB0eXBlIEJhY2tlbmRQYWdlVmFyaWFudENvbmZpZyA9IHtcbiAgICB2YXJpYW50X2lkOiBzdHJpbmc7XG4gICAgdmFyaWFudF90eXBlOiBzdHJpbmc7XG4gICAgdmFyaWFudF9jaGVja3M6IFBhZ2VWYXJpYW50Q2hlY2tDb25maWdbXTtcbiAgICB3aWRnZXRfbW91bnRpbmc6IEJhY2tlbmRXaWRnZXRNb3VudGluZ0NvbmZpZ1tdO1xuICAgIHBscF9pZF9leHRyYWN0b3I/OiBzdHJpbmc7XG4gICAgcHJvZHVjdF9pZF9leHRyYWN0b3I/OiBzdHJpbmc7XG4gICAgcGFyZW50X3Byb2R1Y3RfaWRfZXh0cmFjdG9yPzogc3RyaW5nO1xufTtcbmV4cG9ydCBpbnRlcmZhY2UgVXJsUmVzb2x2ZXJSZXNwb25zZSB7XG4gICAgdmFyaWFudF90eXBlOiBzdHJpbmc7XG4gICAgc3BlY2lmaWNfZGV0YWlsczogVXJsUmVzb2x2aW5nUERQQ29uZmlnIHwgVXJsUmVzb2x2aW5nUExQQ29uZmlnIHwgVXJsUmVzb2x2aW5nR2VuZXJpY0NvbmZpZztcbiAgICByZWFkeTogYm9vbGVhbjtcbiAgICB1c2VyX2V2ZW50Pzoge1xuICAgICAgICBldmVudF9pZD86IHN0cmluZztcbiAgICAgICAgYXR0cmlidXRlcz86IFBEUEF0dHJpYnV0ZXMgfCBQTFBBdHRyaWJ1dGVzO1xuICAgICAgICBjYXRlZ29yeT86IHN0cmluZztcbiAgICAgICAgY3JlYXRlZF9hdD86IHN0cmluZztcbiAgICB9O1xuICAgIHBhZ2VfdmFyaWFudD86IEJhY2tlbmRQYWdlVmFyaWFudENvbmZpZztcbn1cbmV4cG9ydCB0eXBlIFVybFJlc29sdmVyQ2FjaGUgPSBSZWNvcmQ8c3RyaW5nLCBVcmxSZXNvbHZlclJlc3BvbnNlIHwgdW5kZWZpbmVkPjtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHVybFJlc29sdmVyQXRvbTogaW1wb3J0KFwiam90YWlcIikuV3JpdGFibGVBdG9tPFVybFJlc29sdmVyQ2FjaGUsIFt2YWx1ZToge1xuICAgIHVybDogc3RyaW5nO1xuICAgIHJlc3BvbnNlOiBVcmxSZXNvbHZlclJlc3BvbnNlIHwgdW5kZWZpbmVkO1xufV0sIHZvaWQ+O1xuZXhwb3J0IGRlY2xhcmUgY29uc3Qgc3VwcG9ydGVkRXZlbnRBdG9tOiBpbXBvcnQoXCJqb3RhaVwiKS5Xcml0YWJsZUF0b208U3VwcG9ydGVkRXZlbnQgfCB1bmRlZmluZWQsIFt2YWx1ZTogU3VwcG9ydGVkRXZlbnQgfCB1bmRlZmluZWRdLCB2b2lkPjtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHZhcmlhbnRJZEF0b206IGltcG9ydChcImpvdGFpXCIpLkF0b208c3RyaW5nIHwgdW5kZWZpbmVkPjtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHByb2R1Y3RJZEF0b206IGltcG9ydChcImpvdGFpXCIpLkF0b208c3RyaW5nIHwgdW5kZWZpbmVkPjtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHBhcmVudFByb2R1Y3RJZEF0b206IGltcG9ydChcImpvdGFpXCIpLkF0b208c3RyaW5nIHwgdW5kZWZpbmVkPjtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHByb2R1Y3RVcmxBdG9tOiBpbXBvcnQoXCJqb3RhaVwiKS5BdG9tPHN0cmluZyB8IHVuZGVmaW5lZD47XG5leHBvcnQgZGVjbGFyZSBjb25zdCBwbHBJZEF0b206IGltcG9ydChcImpvdGFpXCIpLkF0b208c3RyaW5nIHwgdW5kZWZpbmVkPjtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHVybEF0b206IGltcG9ydChcImpvdGFpXCIpLkF0b208c3RyaW5nIHwgdW5kZWZpbmVkPjtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHBhZ2VWaXNpdENhdGVnb3J5QXRvbTogaW1wb3J0KFwiam90YWlcIikuQXRvbTxQYWdlVmlzaXRDYXRlZ29yeSB8IHVuZGVmaW5lZD47XG5leHBvcnQgZGVjbGFyZSBjb25zdCB2YXJpYW50QXRvbTogaW1wb3J0KFwiam90YWlcIikuQXRvbTxcInNlYXJjaFwiIHwgXCJwZHBcIiB8IFwicGxwXCIgfCBcInBhZ2VfdmlzaXRcIj47XG5leHBvcnQgZGVjbGFyZSBjb25zdCBoYXNQYXJzZWRWYXJpYW50SW5mb0F0b206IGltcG9ydChcImpvdGFpXCIpLlByaW1pdGl2ZUF0b208Ym9vbGVhbj4gJiB7XG4gICAgaW5pdDogYm9vbGVhbjtcbn07XG5leHBvcnQgZGVjbGFyZSBjb25zdCB2YXJpYW50SW5mb0F0b206IGltcG9ydChcImpvdGFpXCIpLldyaXRhYmxlQXRvbTxWYXJpYW50SW5mbywgW25ld1ZhcmlhbnQ6IFZhcmlhbnRJbmZvXSwgdm9pZD47XG5leHBvcnQge307XG4iLCJpbXBvcnQgeyBDb250ZXh0RW52RW51bSwgQ29udGV4dFNvdXJjZUVudW0gfSBmcm9tICdAc3BpZmZ5LWFpL2NvbW1lcmNlLWFwaS1jbGllbnQnO1xuaW1wb3J0IHsgVmFyaWFudEluZm8sIFVzZXJJZGVudGl0eUNvbnRleHRUeXBlIH0gZnJvbSAnQGVudml2ZS1haS90eXBlcyc7XG5leHBvcnQgaW50ZXJmYWNlIEFwcERldGFpbHMge1xuICAgIG9yZ0lkOiBzdHJpbmc7XG4gICAgb3JnU2hvcnROYW1lOiBzdHJpbmc7XG4gICAgY2hhdElkOiBzdHJpbmc7XG4gICAgdXNlcklkOiBzdHJpbmc7XG4gICAgc291cmNlOiBDb250ZXh0U291cmNlRW51bTtcbiAgICBlbnY6IENvbnRleHRFbnZFbnVtO1xuICAgIHZhcmlhbnRJbmZvOiBWYXJpYW50SW5mbztcbn1cbmV4cG9ydCB7IHZhcmlhbnRJbmZvQXRvbSB9IGZyb20gJy4vdmFyaWFudCc7XG5leHBvcnQgZGVjbGFyZSBjb25zdCB1c2VySWRBdG9tOiBpbXBvcnQoXCJqb3RhaVwiKS5Xcml0YWJsZUF0b208c3RyaW5nLCBbdmFsdWU6IHN0cmluZyB8IHVuZGVmaW5lZF0sIHZvaWQ+O1xuZXhwb3J0IGRlY2xhcmUgY29uc3QgdXNlcklkZW50aXR5QXRvbTogaW1wb3J0KFwiam90YWlcIikuUHJpbWl0aXZlQXRvbTxVc2VySWRlbnRpdHlDb250ZXh0VHlwZSB8IHVuZGVmaW5lZD4gJiB7XG4gICAgaW5pdDogVXNlcklkZW50aXR5Q29udGV4dFR5cGUgfCB1bmRlZmluZWQ7XG59O1xuZXhwb3J0IGRlY2xhcmUgY29uc3QgYXBwU291cmNlQXRvbTogaW1wb3J0KFwiam90YWlcIikuQXRvbTxDb250ZXh0U291cmNlRW51bT47XG5leHBvcnQgZGVjbGFyZSBjb25zdCBjaGF0SWRBdG9tOiBpbXBvcnQoXCJqb3RhaVwiKS5Xcml0YWJsZUF0b208c3RyaW5nLCBbc3RyaW5nIHwgdHlwZW9mIGltcG9ydChcImpvdGFpL3V0aWxzXCIpLlJFU0VUIHwgKChwcmV2OiBzdHJpbmcpID0+
|
|
28
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC5jdHMiLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2F0b21zL2FwcC92YXJpYW50LmQudHMiLCIuLi8uLi8uLi9zcmMvYXRvbXMvYXBwL2luZGV4LmQudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU3VwcG9ydGVkRXZlbnRSZXNwb25zZSwgUGFnZVZpc2l0Q2F0ZWdvcnkgfSBmcm9tICdAc3BpZmZ5LWFpL2NvbW1lcmNlLWFwaS1jbGllbnQnO1xuaW1wb3J0IHsgVmFyaWFudEluZm8gfSBmcm9tICdAZW52aXZlLWFpL3R5cGVzJztcbmV4cG9ydCBpbnRlcmZhY2UgU3VwcG9ydGVkRXZlbnQgZXh0ZW5kcyBQaWNrPFN1cHBvcnRlZEV2ZW50UmVzcG9uc2UsICdzdXBwb3J0ZWQnIHwgJ3JlYWR5JyB8ICdjYXRlZ29yeScgfCAnY29sbGVjdGlvbnMnIHwgJ3RvcF9jYXRlZ29yeSc+IHtcbiAgICBudW1iZXJPZlJldmlld3M6IG51bWJlciB8IHVuZGVmaW5lZDtcbiAgICBtZXJjaGFudF90YWdzPzogc3RyaW5nW107XG59XG5pbnRlcmZhY2UgUERQQXR0cmlidXRlcyB7XG4gICAgcHJvZHVjdF9pZD86IHN0cmluZztcbn1cbmludGVyZmFjZSBQTFBBdHRyaWJ1dGVzIHtcbiAgICBhdHRyaWJ1dGVzPzoge1xuICAgICAgICBpZD86IHN0cmluZztcbiAgICB9O1xufVxuZXhwb3J0IGludGVyZmFjZSBVcmxSZXNvbHZpbmdQRFBDb25maWcge1xuICAgIHBkcF9hdHRyaWJ1dGVzOiBQRFBBdHRyaWJ1dGVzO1xuICAgIG51bWJlcl9vZl9yZXZpZXdzPzogbnVtYmVyO1xuICAgIGNvbGxlY3Rpb25zPzogc3RyaW5nW107XG4gICAgbWVyY2hhbnRfdGFncz86IHN0cmluZ1tdO1xufVxuZXhwb3J0IGludGVyZmFjZSBVcmxSZXNvbHZpbmdQTFBDb25maWcge1xuICAgIHBscF9hdHRyaWJ1dGVzOiBQTFBBdHRyaWJ1dGVzO1xuICAgIHRvcF9jYXRlZ29yeT86IHN0cmluZztcbn1cbmludGVyZmFjZSBVcmxSZXNvbHZpbmdHZW5lcmljQ29uZmlnIHtcbiAgICBkZXRhaWxzPzogc3RyaW5nO1xufVxuZXhwb3J0IHR5cGUgUGFnZVZhcmlhbnRDaGVja0NvbmZpZyA9IHtcbiAgICBjaGVja190eXBlOiBzdHJpbmc7XG4gICAgZmVhdHVyZV9nYXRlPzogc3RyaW5nO1xuICAgIGV4dHJhY3Rvcj86IHtcbiAgICAgICAgdHlwZTogc3RyaW5nO1xuICAgICAgICBtYXA/OiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmdbXT47XG4gICAgICAgIHZhbHVlPzogc3RyaW5nO1xuICAgIH07XG4gICAgcHJvZHVjdF9pZF9leHRyYWN0b3I/OiBzdHJpbmc7XG4gICAgcHJvZHVjdF9pZHM/OiBzdHJpbmdbXTtcbiAgICBwbHBfaWRfZXh0cmFjdG9yPzogc3RyaW5nO1xuICAgIHBscF9pZHM/OiBzdHJpbmdbXTtcbiAgICBjb2xsZWN0aW9ucz86IHN0cmluZ1tdO1xuICAgIHF1ZXJ5X3BhcmFtPzogc3RyaW5nO1xuICAgIGNhdGVnb3J5Pzogc3RyaW5nO1xuICAgIHRvcF9jYXRlZ29yeT86IHN0cmluZ1tdO1xuICAgIHJldmlld19taW5pbXVtPzogbnVtYmVyO1xuICAgIG1lcmNoYW50X3RhZ3M/OiBzdHJpbmdbXTtcbn07XG5leHBvcnQgdHlwZSBCYWNrZW5kV2lkZ2V0TW91bnRpbmdDb25maWcgPSB7XG4gICAgbW91bnRpbmdfY29uZmlnX2lkOiBzdHJpbmc7XG4gICAgd2lkZ2V0X2NvbmZpZ19pZD86IHN0cmluZztcbiAgICBtb3VudGluZ19wb2ludF93aWRnZXRzPzogQXJyYXk8e1xuICAgICAgICBjaGVja3M6IFBhZ2VWYXJpYW50Q2hlY2tDb25maWdbXTtcbiAgICAgICAgd2lkZ2V0X2NvbmZpZ19pZDogc3RyaW5nO1xuICAgIH0+O1xufTtcbmV4cG9ydCB0eXBlIEJhY2tlbmRQYWdlVmFyaWFudENvbmZpZyA9IHtcbiAgICB2YXJpYW50X2lkOiBzdHJpbmc7XG4gICAgdmFyaWFudF90eXBlOiBzdHJpbmc7XG4gICAgdmFyaWFudF9jaGVja3M6IFBhZ2VWYXJpYW50Q2hlY2tDb25maWdbXTtcbiAgICB3aWRnZXRfbW91bnRpbmc6IEJhY2tlbmRXaWRnZXRNb3VudGluZ0NvbmZpZ1tdO1xuICAgIHBscF9pZF9leHRyYWN0b3I/OiBzdHJpbmc7XG4gICAgcHJvZHVjdF9pZF9leHRyYWN0b3I/OiBzdHJpbmc7XG4gICAgcGFyZW50X3Byb2R1Y3RfaWRfZXh0cmFjdG9yPzogc3RyaW5nO1xufTtcbmV4cG9ydCBpbnRlcmZhY2UgVXJsUmVzb2x2ZXJSZXNwb25zZSB7XG4gICAgdmFyaWFudF90eXBlOiBzdHJpbmc7XG4gICAgc3BlY2lmaWNfZGV0YWlsczogVXJsUmVzb2x2aW5nUERQQ29uZmlnIHwgVXJsUmVzb2x2aW5nUExQQ29uZmlnIHwgVXJsUmVzb2x2aW5nR2VuZXJpY0NvbmZpZztcbiAgICByZWFkeTogYm9vbGVhbjtcbiAgICB1c2VyX2V2ZW50Pzoge1xuICAgICAgICBldmVudF9pZD86IHN0cmluZztcbiAgICAgICAgYXR0cmlidXRlcz86IFBEUEF0dHJpYnV0ZXMgfCBQTFBBdHRyaWJ1dGVzO1xuICAgICAgICBjYXRlZ29yeT86IHN0cmluZztcbiAgICAgICAgY3JlYXRlZF9hdD86IHN0cmluZztcbiAgICB9O1xuICAgIHBhZ2VfdmFyaWFudD86IEJhY2tlbmRQYWdlVmFyaWFudENvbmZpZztcbn1cbmV4cG9ydCB0eXBlIFVybFJlc29sdmVyQ2FjaGUgPSBSZWNvcmQ8c3RyaW5nLCBVcmxSZXNvbHZlclJlc3BvbnNlIHwgdW5kZWZpbmVkPjtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHVybFJlc29sdmVyQXRvbTogaW1wb3J0KFwiam90YWlcIikuV3JpdGFibGVBdG9tPFVybFJlc29sdmVyQ2FjaGUsIFt2YWx1ZToge1xuICAgIHVybDogc3RyaW5nO1xuICAgIHJlc3BvbnNlOiBVcmxSZXNvbHZlclJlc3BvbnNlIHwgdW5kZWZpbmVkO1xufV0sIHZvaWQ+O1xuZXhwb3J0IGRlY2xhcmUgY29uc3Qgc3VwcG9ydGVkRXZlbnRBdG9tOiBpbXBvcnQoXCJqb3RhaVwiKS5Xcml0YWJsZUF0b208U3VwcG9ydGVkRXZlbnQgfCB1bmRlZmluZWQsIFt2YWx1ZTogU3VwcG9ydGVkRXZlbnQgfCB1bmRlZmluZWRdLCB2b2lkPjtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHZhcmlhbnRJZEF0b206IGltcG9ydChcImpvdGFpXCIpLkF0b208c3RyaW5nIHwgdW5kZWZpbmVkPjtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHByb2R1Y3RJZEF0b206IGltcG9ydChcImpvdGFpXCIpLkF0b208c3RyaW5nIHwgdW5kZWZpbmVkPjtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHBhcmVudFByb2R1Y3RJZEF0b206IGltcG9ydChcImpvdGFpXCIpLkF0b208c3RyaW5nIHwgdW5kZWZpbmVkPjtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHByb2R1Y3RVcmxBdG9tOiBpbXBvcnQoXCJqb3RhaVwiKS5BdG9tPHN0cmluZyB8IHVuZGVmaW5lZD47XG5leHBvcnQgZGVjbGFyZSBjb25zdCBwbHBJZEF0b206IGltcG9ydChcImpvdGFpXCIpLkF0b208c3RyaW5nIHwgdW5kZWZpbmVkPjtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHVybEF0b206IGltcG9ydChcImpvdGFpXCIpLkF0b208c3RyaW5nIHwgdW5kZWZpbmVkPjtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHBhZ2VWaXNpdENhdGVnb3J5QXRvbTogaW1wb3J0KFwiam90YWlcIikuQXRvbTxQYWdlVmlzaXRDYXRlZ29yeSB8IHVuZGVmaW5lZD47XG5leHBvcnQgZGVjbGFyZSBjb25zdCB2YXJpYW50QXRvbTogaW1wb3J0KFwiam90YWlcIikuQXRvbTxcInNlYXJjaFwiIHwgXCJwZHBcIiB8IFwicGxwXCIgfCBcInBhZ2VfdmlzaXRcIj47XG5leHBvcnQgZGVjbGFyZSBjb25zdCBoYXNQYXJzZWRWYXJpYW50SW5mb0F0b206IGltcG9ydChcImpvdGFpXCIpLlByaW1pdGl2ZUF0b208Ym9vbGVhbj4gJiB7XG4gICAgaW5pdDogYm9vbGVhbjtcbn07XG5leHBvcnQgZGVjbGFyZSBjb25zdCB2YXJpYW50SW5mb0F0b206IGltcG9ydChcImpvdGFpXCIpLldyaXRhYmxlQXRvbTxWYXJpYW50SW5mbywgW25ld1ZhcmlhbnQ6IFZhcmlhbnRJbmZvXSwgdm9pZD47XG5leHBvcnQge307XG4iLCJpbXBvcnQgeyBDb250ZXh0RW52RW51bSwgQ29udGV4dFNvdXJjZUVudW0gfSBmcm9tICdAc3BpZmZ5LWFpL2NvbW1lcmNlLWFwaS1jbGllbnQnO1xuaW1wb3J0IHsgVmFyaWFudEluZm8sIFVzZXJJZGVudGl0eUNvbnRleHRUeXBlIH0gZnJvbSAnQGVudml2ZS1haS90eXBlcyc7XG5leHBvcnQgaW50ZXJmYWNlIEFwcERldGFpbHMge1xuICAgIG9yZ0lkOiBzdHJpbmc7XG4gICAgb3JnU2hvcnROYW1lOiBzdHJpbmc7XG4gICAgY2hhdElkOiBzdHJpbmc7XG4gICAgdXNlcklkOiBzdHJpbmc7XG4gICAgc291cmNlOiBDb250ZXh0U291cmNlRW51bTtcbiAgICBlbnY6IENvbnRleHRFbnZFbnVtO1xuICAgIHZhcmlhbnRJbmZvOiBWYXJpYW50SW5mbztcbn1cbmV4cG9ydCB7IHZhcmlhbnRJbmZvQXRvbSB9IGZyb20gJy4vdmFyaWFudCc7XG5leHBvcnQgZGVjbGFyZSBjb25zdCB1c2VySWRBdG9tOiBpbXBvcnQoXCJqb3RhaVwiKS5Xcml0YWJsZUF0b208c3RyaW5nLCBbdmFsdWU6IHN0cmluZyB8IHVuZGVmaW5lZF0sIHZvaWQ+O1xuZXhwb3J0IGRlY2xhcmUgY29uc3QgdXNlcklkZW50aXR5QXRvbTogaW1wb3J0KFwiam90YWlcIikuUHJpbWl0aXZlQXRvbTxVc2VySWRlbnRpdHlDb250ZXh0VHlwZSB8IHVuZGVmaW5lZD4gJiB7XG4gICAgaW5pdDogVXNlcklkZW50aXR5Q29udGV4dFR5cGUgfCB1bmRlZmluZWQ7XG59O1xuZXhwb3J0IGRlY2xhcmUgY29uc3QgYXBwU291cmNlQXRvbTogaW1wb3J0KFwiam90YWlcIikuQXRvbTxDb250ZXh0U291cmNlRW51bT47XG5leHBvcnQgZGVjbGFyZSBjb25zdCBjaGF0SWRBdG9tOiBpbXBvcnQoXCJqb3RhaVwiKS5Xcml0YWJsZUF0b208c3RyaW5nLCBbc3RyaW5nIHwgdHlwZW9mIGltcG9ydChcImpvdGFpL3V0aWxzXCIpLlJFU0VUIHwgKChwcmV2OiBzdHJpbmcpID0+IHN0cmluZyB8IHR5cGVvZiBpbXBvcnQoXCJqb3RhaS91dGlsc1wiKS5SRVNFVCldLCB2b2lkPjtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBeUJBLElBQVcsa0JBQVM7Q0FBQTtPQUFBO09BQUE7T0FBQSxPQUFBO0NBQUE7Ozs7QUNyQnBCLElBQVcsYUFBYTtDQUFBO09BQUE7T0FBQTtPQUFBO0NBQUE7QUFFeEIsSUFBVyxhQUFPLENBQUEsU0FBQSxPQUFBLGFBQUE7QUFDbEIsSUFBVyxtQkFBa0I7Q0FBQTtPQUFBO09BQUEsT0FBQTtPQUFBO0NBQUE7QUFDN0IsSUFBVyxnQkFBWTtDQUFBO09BQUE7T0FBQSxPQUFBO0NBQUE7QUFDdkIsSUFBVyxhQUFhO0NBQUM7T0FBRyxhQUFBO09BQUEsYUFBQTtPQUFBLE9BQUE7Q0FBQSJ9
|
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
import { ContextEnvEnum, ContextSourceEnum, PageVisitCategory } from "@spiffy-ai/commerce-api-client";
|
|
2
|
-
import * as
|
|
2
|
+
import * as jotai4 from "jotai";
|
|
3
3
|
import * as jotai_utils0 from "jotai/utils";
|
|
4
4
|
import { UserIdentityContextType, VariantInfo } from "@envive-ai/types";
|
|
5
5
|
|
|
6
6
|
//#region src/atoms/app/variant.d.ts
|
|
7
7
|
|
|
8
|
-
declare const variantInfoAtom:
|
|
8
|
+
declare const variantInfoAtom: jotai4.WritableAtom<VariantInfo, [newVariant: VariantInfo], void>;
|
|
9
9
|
//#endregion
|
|
10
10
|
//#region src/atoms/app/index.d.ts
|
|
11
11
|
interface AppDetails {
|
|
@@ -17,12 +17,12 @@ interface AppDetails {
|
|
|
17
17
|
env: ContextEnvEnum;
|
|
18
18
|
variantInfo: VariantInfo;
|
|
19
19
|
}
|
|
20
|
-
declare const userIdAtom:
|
|
21
|
-
declare const userIdentityAtom:
|
|
20
|
+
declare const userIdAtom: jotai4.WritableAtom<string, [value: string | undefined], void>;
|
|
21
|
+
declare const userIdentityAtom: jotai4.PrimitiveAtom<UserIdentityContextType | undefined> & {
|
|
22
22
|
init: UserIdentityContextType | undefined;
|
|
23
23
|
};
|
|
24
|
-
declare const appSourceAtom:
|
|
25
|
-
declare const chatIdAtom:
|
|
24
|
+
declare const appSourceAtom: jotai4.Atom<ContextSourceEnum>;
|
|
25
|
+
declare const chatIdAtom: jotai4.WritableAtom<string, [string | typeof jotai_utils0.RESET | ((prev: string) => string | typeof jotai_utils0.RESET)], void>;
|
|
26
26
|
//#endregion
|
|
27
27
|
export { AppDetails, appSourceAtom, chatIdAtom, userIdAtom, userIdentityAtom, variantInfoAtom };
|
|
28
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsIm5hbWVzIjpbXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXRvbXMvYXBwL3ZhcmlhbnQuZC50cyIsIi4uLy4uLy4uL3NyYy9hdG9tcy9hcHAvaW5kZXguZC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTdXBwb3J0ZWRFdmVudFJlc3BvbnNlLCBQYWdlVmlzaXRDYXRlZ29yeSB9IGZyb20gJ0BzcGlmZnktYWkvY29tbWVyY2UtYXBpLWNsaWVudCc7XG5pbXBvcnQgeyBWYXJpYW50SW5mbyB9IGZyb20gJ0BlbnZpdmUtYWkvdHlwZXMnO1xuZXhwb3J0IGludGVyZmFjZSBTdXBwb3J0ZWRFdmVudCBleHRlbmRzIFBpY2s8U3VwcG9ydGVkRXZlbnRSZXNwb25zZSwgJ3N1cHBvcnRlZCcgfCAncmVhZHknIHwgJ2NhdGVnb3J5JyB8ICdjb2xsZWN0aW9ucycgfCAndG9wX2NhdGVnb3J5Jz4ge1xuICAgIG51bWJlck9mUmV2aWV3czogbnVtYmVyIHwgdW5kZWZpbmVkO1xuICAgIG1lcmNoYW50X3RhZ3M/OiBzdHJpbmdbXTtcbn1cbmludGVyZmFjZSBQRFBBdHRyaWJ1dGVzIHtcbiAgICBwcm9kdWN0X2lkPzogc3RyaW5nO1xufVxuaW50ZXJmYWNlIFBMUEF0dHJpYnV0ZXMge1xuICAgIGF0dHJpYnV0ZXM/OiB7XG4gICAgICAgIGlkPzogc3RyaW5nO1xuICAgIH07XG59XG5leHBvcnQgaW50ZXJmYWNlIFVybFJlc29sdmluZ1BEUENvbmZpZyB7XG4gICAgcGRwX2F0dHJpYnV0ZXM6IFBEUEF0dHJpYnV0ZXM7XG4gICAgbnVtYmVyX29mX3Jldmlld3M/OiBudW1iZXI7XG4gICAgY29sbGVjdGlvbnM/OiBzdHJpbmdbXTtcbiAgICBtZXJjaGFudF90YWdzPzogc3RyaW5nW107XG59XG5leHBvcnQgaW50ZXJmYWNlIFVybFJlc29sdmluZ1BMUENvbmZpZyB7XG4gICAgcGxwX2F0dHJpYnV0ZXM6IFBMUEF0dHJpYnV0ZXM7XG4gICAgdG9wX2NhdGVnb3J5Pzogc3RyaW5nO1xufVxuaW50ZXJmYWNlIFVybFJlc29sdmluZ0dlbmVyaWNDb25maWcge1xuICAgIGRldGFpbHM/OiBzdHJpbmc7XG59XG5leHBvcnQgdHlwZSBQYWdlVmFyaWFudENoZWNrQ29uZmlnID0ge1xuICAgIGNoZWNrX3R5cGU6IHN0cmluZztcbiAgICBmZWF0dXJlX2dhdGU/OiBzdHJpbmc7XG4gICAgZXh0cmFjdG9yPzoge1xuICAgICAgICB0eXBlOiBzdHJpbmc7XG4gICAgICAgIG1hcD86IFJlY29yZDxzdHJpbmcsIHN0cmluZ1tdPjtcbiAgICAgICAgdmFsdWU/OiBzdHJpbmc7XG4gICAgfTtcbiAgICBwcm9kdWN0X2lkX2V4dHJhY3Rvcj86IHN0cmluZztcbiAgICBwcm9kdWN0X2lkcz86IHN0cmluZ1tdO1xuICAgIHBscF9pZF9leHRyYWN0b3I/OiBzdHJpbmc7XG4gICAgcGxwX2lkcz86IHN0cmluZ1tdO1xuICAgIGNvbGxlY3Rpb25zPzogc3RyaW5nW107XG4gICAgcXVlcnlfcGFyYW0/OiBzdHJpbmc7XG4gICAgY2F0ZWdvcnk/OiBzdHJpbmc7XG4gICAgdG9wX2NhdGVnb3J5Pzogc3RyaW5nW107XG4gICAgcmV2aWV3X21pbmltdW0/OiBudW1iZXI7XG4gICAgbWVyY2hhbnRfdGFncz86IHN0cmluZ1tdO1xufTtcbmV4cG9ydCB0eXBlIEJhY2tlbmRXaWRnZXRNb3VudGluZ0NvbmZpZyA9IHtcbiAgICBtb3VudGluZ19jb25maWdfaWQ6IHN0cmluZztcbiAgICB3aWRnZXRfY29uZmlnX2lkPzogc3RyaW5nO1xuICAgIG1vdW50aW5nX3BvaW50X3dpZGdldHM/OiBBcnJheTx7XG4gICAgICAgIGNoZWNrczogUGFnZVZhcmlhbnRDaGVja0NvbmZpZ1tdO1xuICAgICAgICB3aWRnZXRfY29uZmlnX2lkOiBzdHJpbmc7XG4gICAgfT47XG59O1xuZXhwb3J0IHR5cGUgQmFja2VuZFBhZ2VWYXJpYW50Q29uZmlnID0ge1xuICAgIHZhcmlhbnRfaWQ6IHN0cmluZztcbiAgICB2YXJpYW50X3R5cGU6IHN0cmluZztcbiAgICB2YXJpYW50X2NoZWNrczogUGFnZVZhcmlhbnRDaGVja0NvbmZpZ1tdO1xuICAgIHdpZGdldF9tb3VudGluZzogQmFja2VuZFdpZGdldE1vdW50aW5nQ29uZmlnW107XG4gICAgcGxwX2lkX2V4dHJhY3Rvcj86IHN0cmluZztcbiAgICBwcm9kdWN0X2lkX2V4dHJhY3Rvcj86IHN0cmluZztcbiAgICBwYXJlbnRfcHJvZHVjdF9pZF9leHRyYWN0b3I/OiBzdHJpbmc7XG59O1xuZXhwb3J0IGludGVyZmFjZSBVcmxSZXNvbHZlclJlc3BvbnNlIHtcbiAgICB2YXJpYW50X3R5cGU6IHN0cmluZztcbiAgICBzcGVjaWZpY19kZXRhaWxzOiBVcmxSZXNvbHZpbmdQRFBDb25maWcgfCBVcmxSZXNvbHZpbmdQTFBDb25maWcgfCBVcmxSZXNvbHZpbmdHZW5lcmljQ29uZmlnO1xuICAgIHJlYWR5OiBib29sZWFuO1xuICAgIHVzZXJfZXZlbnQ/OiB7XG4gICAgICAgIGV2ZW50X2lkPzogc3RyaW5nO1xuICAgICAgICBhdHRyaWJ1dGVzPzogUERQQXR0cmlidXRlcyB8IFBMUEF0dHJpYnV0ZXM7XG4gICAgICAgIGNhdGVnb3J5Pzogc3RyaW5nO1xuICAgICAgICBjcmVhdGVkX2F0Pzogc3RyaW5nO1xuICAgIH07XG4gICAgcGFnZV92YXJpYW50PzogQmFja2VuZFBhZ2VWYXJpYW50Q29uZmlnO1xufVxuZXhwb3J0IHR5cGUgVXJsUmVzb2x2ZXJDYWNoZSA9IFJlY29yZDxzdHJpbmcsIFVybFJlc29sdmVyUmVzcG9uc2UgfCB1bmRlZmluZWQ+O1xuZXhwb3J0IGRlY2xhcmUgY29uc3QgdXJsUmVzb2x2ZXJBdG9tOiBpbXBvcnQoXCJqb3RhaVwiKS5Xcml0YWJsZUF0b208VXJsUmVzb2x2ZXJDYWNoZSwgW3ZhbHVlOiB7XG4gICAgdXJsOiBzdHJpbmc7XG4gICAgcmVzcG9uc2U6IFVybFJlc29sdmVyUmVzcG9uc2UgfCB1bmRlZmluZWQ7XG59XSwgdm9pZD47XG5leHBvcnQgZGVjbGFyZSBjb25zdCBzdXBwb3J0ZWRFdmVudEF0b206IGltcG9ydChcImpvdGFpXCIpLldyaXRhYmxlQXRvbTxTdXBwb3J0ZWRFdmVudCB8IHVuZGVmaW5lZCwgW3ZhbHVlOiBTdXBwb3J0ZWRFdmVudCB8IHVuZGVmaW5lZF0sIHZvaWQ+O1xuZXhwb3J0IGRlY2xhcmUgY29uc3QgdmFyaWFudElkQXRvbTogaW1wb3J0KFwiam90YWlcIikuQXRvbTxzdHJpbmcgfCB1bmRlZmluZWQ+O1xuZXhwb3J0IGRlY2xhcmUgY29uc3QgcHJvZHVjdElkQXRvbTogaW1wb3J0KFwiam90YWlcIikuQXRvbTxzdHJpbmcgfCB1bmRlZmluZWQ+O1xuZXhwb3J0IGRlY2xhcmUgY29uc3QgcGFyZW50UHJvZHVjdElkQXRvbTogaW1wb3J0KFwiam90YWlcIikuQXRvbTxzdHJpbmcgfCB1bmRlZmluZWQ+O1xuZXhwb3J0IGRlY2xhcmUgY29uc3QgcHJvZHVjdFVybEF0b206IGltcG9ydChcImpvdGFpXCIpLkF0b208c3RyaW5nIHwgdW5kZWZpbmVkPjtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHBscElkQXRvbTogaW1wb3J0KFwiam90YWlcIikuQXRvbTxzdHJpbmcgfCB1bmRlZmluZWQ+O1xuZXhwb3J0IGRlY2xhcmUgY29uc3QgdXJsQXRvbTogaW1wb3J0KFwiam90YWlcIikuQXRvbTxzdHJpbmcgfCB1bmRlZmluZWQ+O1xuZXhwb3J0IGRlY2xhcmUgY29uc3QgcGFnZVZpc2l0Q2F0ZWdvcnlBdG9tOiBpbXBvcnQoXCJqb3RhaVwiKS5BdG9tPFBhZ2VWaXNpdENhdGVnb3J5IHwgdW5kZWZpbmVkPjtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHZhcmlhbnRBdG9tOiBpbXBvcnQoXCJqb3RhaVwiKS5BdG9tPFwic2VhcmNoXCIgfCBcInBkcFwiIHwgXCJwbHBcIiB8IFwicGFnZV92aXNpdFwiPjtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IGhhc1BhcnNlZFZhcmlhbnRJbmZvQXRvbTogaW1wb3J0KFwiam90YWlcIikuUHJpbWl0aXZlQXRvbTxib29sZWFuPiAmIHtcbiAgICBpbml0OiBib29sZWFuO1xufTtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHZhcmlhbnRJbmZvQXRvbTogaW1wb3J0KFwiam90YWlcIikuV3JpdGFibGVBdG9tPFZhcmlhbnRJbmZvLCBbbmV3VmFyaWFudDogVmFyaWFudEluZm9dLCB2b2lkPjtcbmV4cG9ydCB7fTtcbiIsImltcG9ydCB7IENvbnRleHRFbnZFbnVtLCBDb250ZXh0U291cmNlRW51bSB9IGZyb20gJ0BzcGlmZnktYWkvY29tbWVyY2UtYXBpLWNsaWVudCc7XG5pbXBvcnQgeyBWYXJpYW50SW5mbywgVXNlcklkZW50aXR5Q29udGV4dFR5cGUgfSBmcm9tICdAZW52aXZlLWFpL3R5cGVzJztcbmV4cG9ydCBpbnRlcmZhY2UgQXBwRGV0YWlscyB7XG4gICAgb3JnSWQ6IHN0cmluZztcbiAgICBvcmdTaG9ydE5hbWU6IHN0cmluZztcbiAgICBjaGF0SWQ6IHN0cmluZztcbiAgICB1c2VySWQ6IHN0cmluZztcbiAgICBzb3VyY2U6IENvbnRleHRTb3VyY2VFbnVtO1xuICAgIGVudjogQ29udGV4dEVudkVudW07XG4gICAgdmFyaWFudEluZm86IFZhcmlhbnRJbmZvO1xufVxuZXhwb3J0IHsgdmFyaWFudEluZm9BdG9tIH0gZnJvbSAnLi92YXJpYW50JztcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHVzZXJJZEF0b206IGltcG9ydChcImpvdGFpXCIpLldyaXRhYmxlQXRvbTxzdHJpbmcsIFt2YWx1ZTogc3RyaW5nIHwgdW5kZWZpbmVkXSwgdm9pZD47XG5leHBvcnQgZGVjbGFyZSBjb25zdCB1c2VySWRlbnRpdHlBdG9tOiBpbXBvcnQoXCJqb3RhaVwiKS5QcmltaXRpdmVBdG9tPFVzZXJJZGVudGl0eUNvbnRleHRUeXBlIHwgdW5kZWZpbmVkPiAmIHtcbiAgICBpbml0OiBVc2VySWRlbnRpdHlDb250ZXh0VHlwZSB8IHVuZGVmaW5lZDtcbn07XG5leHBvcnQgZGVjbGFyZSBjb25zdCBhcHBTb3VyY2VBdG9tOiBpbXBvcnQoXCJqb3RhaVwiKS5BdG9tPENvbnRleHRTb3VyY2VFbnVtPjtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IGNoYXRJZEF0b206IGltcG9ydChcImpvdGFpXCIpLldyaXRhYmxlQXRvbTxzdHJpbmcsIFtzdHJpbmcgfCB0eXBlb2YgaW1wb3J0KFwiam90YWkvdXRpbHNcIikuUkVTRVQgfCAoKHByZXY6IHN0cmluZykgPT4gc3RyaW5nIHwgdHlwZW9mIGltcG9ydChcImpvdGFpL3V0aWxzXCIpLlJFU0VUKV0sIHZvaWQ+
|
|
28
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsIm5hbWVzIjpbXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXRvbXMvYXBwL3ZhcmlhbnQuZC50cyIsIi4uLy4uLy4uL3NyYy9hdG9tcy9hcHAvaW5kZXguZC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTdXBwb3J0ZWRFdmVudFJlc3BvbnNlLCBQYWdlVmlzaXRDYXRlZ29yeSB9IGZyb20gJ0BzcGlmZnktYWkvY29tbWVyY2UtYXBpLWNsaWVudCc7XG5pbXBvcnQgeyBWYXJpYW50SW5mbyB9IGZyb20gJ0BlbnZpdmUtYWkvdHlwZXMnO1xuZXhwb3J0IGludGVyZmFjZSBTdXBwb3J0ZWRFdmVudCBleHRlbmRzIFBpY2s8U3VwcG9ydGVkRXZlbnRSZXNwb25zZSwgJ3N1cHBvcnRlZCcgfCAncmVhZHknIHwgJ2NhdGVnb3J5JyB8ICdjb2xsZWN0aW9ucycgfCAndG9wX2NhdGVnb3J5Jz4ge1xuICAgIG51bWJlck9mUmV2aWV3czogbnVtYmVyIHwgdW5kZWZpbmVkO1xuICAgIG1lcmNoYW50X3RhZ3M/OiBzdHJpbmdbXTtcbn1cbmludGVyZmFjZSBQRFBBdHRyaWJ1dGVzIHtcbiAgICBwcm9kdWN0X2lkPzogc3RyaW5nO1xufVxuaW50ZXJmYWNlIFBMUEF0dHJpYnV0ZXMge1xuICAgIGF0dHJpYnV0ZXM/OiB7XG4gICAgICAgIGlkPzogc3RyaW5nO1xuICAgIH07XG59XG5leHBvcnQgaW50ZXJmYWNlIFVybFJlc29sdmluZ1BEUENvbmZpZyB7XG4gICAgcGRwX2F0dHJpYnV0ZXM6IFBEUEF0dHJpYnV0ZXM7XG4gICAgbnVtYmVyX29mX3Jldmlld3M/OiBudW1iZXI7XG4gICAgY29sbGVjdGlvbnM/OiBzdHJpbmdbXTtcbiAgICBtZXJjaGFudF90YWdzPzogc3RyaW5nW107XG59XG5leHBvcnQgaW50ZXJmYWNlIFVybFJlc29sdmluZ1BMUENvbmZpZyB7XG4gICAgcGxwX2F0dHJpYnV0ZXM6IFBMUEF0dHJpYnV0ZXM7XG4gICAgdG9wX2NhdGVnb3J5Pzogc3RyaW5nO1xufVxuaW50ZXJmYWNlIFVybFJlc29sdmluZ0dlbmVyaWNDb25maWcge1xuICAgIGRldGFpbHM/OiBzdHJpbmc7XG59XG5leHBvcnQgdHlwZSBQYWdlVmFyaWFudENoZWNrQ29uZmlnID0ge1xuICAgIGNoZWNrX3R5cGU6IHN0cmluZztcbiAgICBmZWF0dXJlX2dhdGU/OiBzdHJpbmc7XG4gICAgZXh0cmFjdG9yPzoge1xuICAgICAgICB0eXBlOiBzdHJpbmc7XG4gICAgICAgIG1hcD86IFJlY29yZDxzdHJpbmcsIHN0cmluZ1tdPjtcbiAgICAgICAgdmFsdWU/OiBzdHJpbmc7XG4gICAgfTtcbiAgICBwcm9kdWN0X2lkX2V4dHJhY3Rvcj86IHN0cmluZztcbiAgICBwcm9kdWN0X2lkcz86IHN0cmluZ1tdO1xuICAgIHBscF9pZF9leHRyYWN0b3I/OiBzdHJpbmc7XG4gICAgcGxwX2lkcz86IHN0cmluZ1tdO1xuICAgIGNvbGxlY3Rpb25zPzogc3RyaW5nW107XG4gICAgcXVlcnlfcGFyYW0/OiBzdHJpbmc7XG4gICAgY2F0ZWdvcnk/OiBzdHJpbmc7XG4gICAgdG9wX2NhdGVnb3J5Pzogc3RyaW5nW107XG4gICAgcmV2aWV3X21pbmltdW0/OiBudW1iZXI7XG4gICAgbWVyY2hhbnRfdGFncz86IHN0cmluZ1tdO1xufTtcbmV4cG9ydCB0eXBlIEJhY2tlbmRXaWRnZXRNb3VudGluZ0NvbmZpZyA9IHtcbiAgICBtb3VudGluZ19jb25maWdfaWQ6IHN0cmluZztcbiAgICB3aWRnZXRfY29uZmlnX2lkPzogc3RyaW5nO1xuICAgIG1vdW50aW5nX3BvaW50X3dpZGdldHM/OiBBcnJheTx7XG4gICAgICAgIGNoZWNrczogUGFnZVZhcmlhbnRDaGVja0NvbmZpZ1tdO1xuICAgICAgICB3aWRnZXRfY29uZmlnX2lkOiBzdHJpbmc7XG4gICAgfT47XG59O1xuZXhwb3J0IHR5cGUgQmFja2VuZFBhZ2VWYXJpYW50Q29uZmlnID0ge1xuICAgIHZhcmlhbnRfaWQ6IHN0cmluZztcbiAgICB2YXJpYW50X3R5cGU6IHN0cmluZztcbiAgICB2YXJpYW50X2NoZWNrczogUGFnZVZhcmlhbnRDaGVja0NvbmZpZ1tdO1xuICAgIHdpZGdldF9tb3VudGluZzogQmFja2VuZFdpZGdldE1vdW50aW5nQ29uZmlnW107XG4gICAgcGxwX2lkX2V4dHJhY3Rvcj86IHN0cmluZztcbiAgICBwcm9kdWN0X2lkX2V4dHJhY3Rvcj86IHN0cmluZztcbiAgICBwYXJlbnRfcHJvZHVjdF9pZF9leHRyYWN0b3I/OiBzdHJpbmc7XG59O1xuZXhwb3J0IGludGVyZmFjZSBVcmxSZXNvbHZlclJlc3BvbnNlIHtcbiAgICB2YXJpYW50X3R5cGU6IHN0cmluZztcbiAgICBzcGVjaWZpY19kZXRhaWxzOiBVcmxSZXNvbHZpbmdQRFBDb25maWcgfCBVcmxSZXNvbHZpbmdQTFBDb25maWcgfCBVcmxSZXNvbHZpbmdHZW5lcmljQ29uZmlnO1xuICAgIHJlYWR5OiBib29sZWFuO1xuICAgIHVzZXJfZXZlbnQ/OiB7XG4gICAgICAgIGV2ZW50X2lkPzogc3RyaW5nO1xuICAgICAgICBhdHRyaWJ1dGVzPzogUERQQXR0cmlidXRlcyB8IFBMUEF0dHJpYnV0ZXM7XG4gICAgICAgIGNhdGVnb3J5Pzogc3RyaW5nO1xuICAgICAgICBjcmVhdGVkX2F0Pzogc3RyaW5nO1xuICAgIH07XG4gICAgcGFnZV92YXJpYW50PzogQmFja2VuZFBhZ2VWYXJpYW50Q29uZmlnO1xufVxuZXhwb3J0IHR5cGUgVXJsUmVzb2x2ZXJDYWNoZSA9IFJlY29yZDxzdHJpbmcsIFVybFJlc29sdmVyUmVzcG9uc2UgfCB1bmRlZmluZWQ+O1xuZXhwb3J0IGRlY2xhcmUgY29uc3QgdXJsUmVzb2x2ZXJBdG9tOiBpbXBvcnQoXCJqb3RhaVwiKS5Xcml0YWJsZUF0b208VXJsUmVzb2x2ZXJDYWNoZSwgW3ZhbHVlOiB7XG4gICAgdXJsOiBzdHJpbmc7XG4gICAgcmVzcG9uc2U6IFVybFJlc29sdmVyUmVzcG9uc2UgfCB1bmRlZmluZWQ7XG59XSwgdm9pZD47XG5leHBvcnQgZGVjbGFyZSBjb25zdCBzdXBwb3J0ZWRFdmVudEF0b206IGltcG9ydChcImpvdGFpXCIpLldyaXRhYmxlQXRvbTxTdXBwb3J0ZWRFdmVudCB8IHVuZGVmaW5lZCwgW3ZhbHVlOiBTdXBwb3J0ZWRFdmVudCB8IHVuZGVmaW5lZF0sIHZvaWQ+O1xuZXhwb3J0IGRlY2xhcmUgY29uc3QgdmFyaWFudElkQXRvbTogaW1wb3J0KFwiam90YWlcIikuQXRvbTxzdHJpbmcgfCB1bmRlZmluZWQ+O1xuZXhwb3J0IGRlY2xhcmUgY29uc3QgcHJvZHVjdElkQXRvbTogaW1wb3J0KFwiam90YWlcIikuQXRvbTxzdHJpbmcgfCB1bmRlZmluZWQ+O1xuZXhwb3J0IGRlY2xhcmUgY29uc3QgcGFyZW50UHJvZHVjdElkQXRvbTogaW1wb3J0KFwiam90YWlcIikuQXRvbTxzdHJpbmcgfCB1bmRlZmluZWQ+O1xuZXhwb3J0IGRlY2xhcmUgY29uc3QgcHJvZHVjdFVybEF0b206IGltcG9ydChcImpvdGFpXCIpLkF0b208c3RyaW5nIHwgdW5kZWZpbmVkPjtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHBscElkQXRvbTogaW1wb3J0KFwiam90YWlcIikuQXRvbTxzdHJpbmcgfCB1bmRlZmluZWQ+O1xuZXhwb3J0IGRlY2xhcmUgY29uc3QgdXJsQXRvbTogaW1wb3J0KFwiam90YWlcIikuQXRvbTxzdHJpbmcgfCB1bmRlZmluZWQ+O1xuZXhwb3J0IGRlY2xhcmUgY29uc3QgcGFnZVZpc2l0Q2F0ZWdvcnlBdG9tOiBpbXBvcnQoXCJqb3RhaVwiKS5BdG9tPFBhZ2VWaXNpdENhdGVnb3J5IHwgdW5kZWZpbmVkPjtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHZhcmlhbnRBdG9tOiBpbXBvcnQoXCJqb3RhaVwiKS5BdG9tPFwic2VhcmNoXCIgfCBcInBkcFwiIHwgXCJwbHBcIiB8IFwicGFnZV92aXNpdFwiPjtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IGhhc1BhcnNlZFZhcmlhbnRJbmZvQXRvbTogaW1wb3J0KFwiam90YWlcIikuUHJpbWl0aXZlQXRvbTxib29sZWFuPiAmIHtcbiAgICBpbml0OiBib29sZWFuO1xufTtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHZhcmlhbnRJbmZvQXRvbTogaW1wb3J0KFwiam90YWlcIikuV3JpdGFibGVBdG9tPFZhcmlhbnRJbmZvLCBbbmV3VmFyaWFudDogVmFyaWFudEluZm9dLCB2b2lkPjtcbmV4cG9ydCB7fTtcbiIsImltcG9ydCB7IENvbnRleHRFbnZFbnVtLCBDb250ZXh0U291cmNlRW51bSB9IGZyb20gJ0BzcGlmZnktYWkvY29tbWVyY2UtYXBpLWNsaWVudCc7XG5pbXBvcnQgeyBWYXJpYW50SW5mbywgVXNlcklkZW50aXR5Q29udGV4dFR5cGUgfSBmcm9tICdAZW52aXZlLWFpL3R5cGVzJztcbmV4cG9ydCBpbnRlcmZhY2UgQXBwRGV0YWlscyB7XG4gICAgb3JnSWQ6IHN0cmluZztcbiAgICBvcmdTaG9ydE5hbWU6IHN0cmluZztcbiAgICBjaGF0SWQ6IHN0cmluZztcbiAgICB1c2VySWQ6IHN0cmluZztcbiAgICBzb3VyY2U6IENvbnRleHRTb3VyY2VFbnVtO1xuICAgIGVudjogQ29udGV4dEVudkVudW07XG4gICAgdmFyaWFudEluZm86IFZhcmlhbnRJbmZvO1xufVxuZXhwb3J0IHsgdmFyaWFudEluZm9BdG9tIH0gZnJvbSAnLi92YXJpYW50JztcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHVzZXJJZEF0b206IGltcG9ydChcImpvdGFpXCIpLldyaXRhYmxlQXRvbTxzdHJpbmcsIFt2YWx1ZTogc3RyaW5nIHwgdW5kZWZpbmVkXSwgdm9pZD47XG5leHBvcnQgZGVjbGFyZSBjb25zdCB1c2VySWRlbnRpdHlBdG9tOiBpbXBvcnQoXCJqb3RhaVwiKS5QcmltaXRpdmVBdG9tPFVzZXJJZGVudGl0eUNvbnRleHRUeXBlIHwgdW5kZWZpbmVkPiAmIHtcbiAgICBpbml0OiBVc2VySWRlbnRpdHlDb250ZXh0VHlwZSB8IHVuZGVmaW5lZDtcbn07XG5leHBvcnQgZGVjbGFyZSBjb25zdCBhcHBTb3VyY2VBdG9tOiBpbXBvcnQoXCJqb3RhaVwiKS5BdG9tPENvbnRleHRTb3VyY2VFbnVtPjtcbmV4cG9ydCBkZWNsYXJlIGNvbnN0IGNoYXRJZEF0b206IGltcG9ydChcImpvdGFpXCIpLldyaXRhYmxlQXRvbTxzdHJpbmcsIFtzdHJpbmcgfCB0eXBlb2YgaW1wb3J0KFwiam90YWkvdXRpbHNcIikuUkVTRVQgfCAoKHByZXY6IHN0cmluZykgPT4gc3RyaW5nIHwgdHlwZW9mIGltcG9ydChcImpvdGFpL3V0aWxzXCIpLlJFU0VUKV0sIHZvaWQ+O1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7QUF5QkEsSUFBVyxrQkFBUztDQUFBO09BQUE7T0FBQTtPQUFBLE9BQUE7Q0FBQTs7OztBQ3JCcEIsSUFBVyxhQUFhO0NBQUE7T0FBQTtPQUFBO09BQUE7Q0FBQTtBQUV4QixJQUFXLGFBQU8sQ0FBQSxTQUFBLE9BQUEsYUFBQTtBQUNsQixJQUFXLG1CQUFrQjtDQUFBO09BQUE7T0FBQSxPQUFBO09BQUE7Q0FBQTtBQUM3QixJQUFXLGdCQUFZO0NBQUE7T0FBQTtPQUFBLE9BQUE7Q0FBQTtBQUN2QixJQUFXLGFBQWE7Q0FBQztPQUFHLGFBQUE7T0FBQSxhQUFBO09BQUEsT0FBQTtDQUFBIn0=
|
|
@@ -21,4 +21,4 @@ declare const resetAtomStore: () => void;
|
|
|
21
21
|
declare const sessionStorageUtil: jotai_vanilla_utils_atomWithStorage0.SyncStorage<string | undefined>;
|
|
22
22
|
//#endregion
|
|
23
23
|
export { AtomStore, getAtomStore, resetAtomStore, sessionStorageUtil, setAtomStoreForTesting };
|
|
24
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsIm5hbWVzIjpbXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXRvbXMvYXRvbVN0b3JlL2F0b21TdG9yZS5kLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGdldERlZmF1bHRTdG9yZSB9IGZyb20gJ2pvdGFpJztcbmV4cG9ydCB0eXBlIEF0b21TdG9yZSA9IFJldHVyblR5cGU8dHlwZW9mIGdldERlZmF1bHRTdG9yZT47XG5leHBvcnQgZGVjbGFyZSBjb25zdCBnZXRBdG9tU3RvcmU6ICgpID0+IEF0b21TdG9yZTtcbi8qKlxuICogQGludGVybmFsXG4gKlxuICogU2V0cyB0aGUgZ2xvYmFsIGF0b20gc3RvcmUgdG8gYmUgdGhlIHByb3ZpZGVkIHN0b3JlLlxuICpcbiAqIEBwYXJhbSBzdG9yZSAtIFRoZSBzdG9yZSB0byBzZXQgdGhlIGdsb2JhbCBhdG9tIHN0b3JlIHRvLlxuICovXG5leHBvcnQgZGVjbGFyZSBjb25zdCBzZXRBdG9tU3RvcmVGb3JUZXN0aW5nOiAoc3RvcmU6IEF0b21TdG9yZSkgPT4gdm9pZDtcbi8qKlxuICogQGludGVybmFsXG4gKlxuICogUmVzZXRzIHRoZSBnbG9iYWwgYXRvbSBzdG9yZSB0byBudWxsXG4gKi9cbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHJlc2V0QXRvbVN0b3JlOiAoKSA9PiB2b2lkO1xuZXhwb3J0IGRlY2xhcmUgY29uc3Qgc2Vzc2lvblN0b3JhZ2VVdGlsOiBpbXBvcnQoXCJqb3RhaS92YW5pbGxhL3V0aWxzL2F0b21XaXRoU3RvcmFnZVwiKS5TeW5jU3RvcmFnZTxzdHJpbmcgfCB1bmRlZmluZWQ+
|
|
24
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsIm5hbWVzIjpbXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXRvbXMvYXRvbVN0b3JlL2F0b21TdG9yZS5kLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGdldERlZmF1bHRTdG9yZSB9IGZyb20gJ2pvdGFpJztcbmV4cG9ydCB0eXBlIEF0b21TdG9yZSA9IFJldHVyblR5cGU8dHlwZW9mIGdldERlZmF1bHRTdG9yZT47XG5leHBvcnQgZGVjbGFyZSBjb25zdCBnZXRBdG9tU3RvcmU6ICgpID0+IEF0b21TdG9yZTtcbi8qKlxuICogQGludGVybmFsXG4gKlxuICogU2V0cyB0aGUgZ2xvYmFsIGF0b20gc3RvcmUgdG8gYmUgdGhlIHByb3ZpZGVkIHN0b3JlLlxuICpcbiAqIEBwYXJhbSBzdG9yZSAtIFRoZSBzdG9yZSB0byBzZXQgdGhlIGdsb2JhbCBhdG9tIHN0b3JlIHRvLlxuICovXG5leHBvcnQgZGVjbGFyZSBjb25zdCBzZXRBdG9tU3RvcmVGb3JUZXN0aW5nOiAoc3RvcmU6IEF0b21TdG9yZSkgPT4gdm9pZDtcbi8qKlxuICogQGludGVybmFsXG4gKlxuICogUmVzZXRzIHRoZSBnbG9iYWwgYXRvbSBzdG9yZSB0byBudWxsXG4gKi9cbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHJlc2V0QXRvbVN0b3JlOiAoKSA9PiB2b2lkO1xuZXhwb3J0IGRlY2xhcmUgY29uc3Qgc2Vzc2lvblN0b3JhZ2VVdGlsOiBpbXBvcnQoXCJqb3RhaS92YW5pbGxhL3V0aWxzL2F0b21XaXRoU3RvcmFnZVwiKS5TeW5jU3RvcmFnZTxzdHJpbmcgfCB1bmRlZmluZWQ+O1xuIl0sIm1hcHBpbmdzIjoiOzs7O0FBRUEsSUFBVyxZQUFZO0NBQUM7T0FBVTtPQUFnQjtDQUFBO0FBQ2xELElBQUUsZUFBQSxDQUFBLFVBQUEsVUFBQTtBQUNGLElBQVcseUJBQUEsQ0FBQSxVQUFBLFVBQUE7QUFDWCxJQUFDLGlCQUFBLENBQUEsR0FBQTtBQUNELElBQVcscUJBQXFCLENBQUMsVUFBVSxxQ0FBVyxZQUFBIn0=
|
|
@@ -15,9 +15,9 @@ require('../../org-BNs_maoW.cjs');
|
|
|
15
15
|
require('../../newOrgConfigAtom-CDttTiuu.cjs');
|
|
16
16
|
require('../../app-DxwdFQlv.cjs');
|
|
17
17
|
require('../../localStorageContext-CWc5xJ6U.cjs');
|
|
18
|
-
const require_chatState = require('../../chatState-
|
|
19
|
-
const require_chat = require('../../chat-
|
|
20
|
-
require('../../amplitudeTrackEventAtom-
|
|
18
|
+
const require_chatState = require('../../chatState-DlJpHAsW.cjs');
|
|
19
|
+
const require_chat = require('../../chat-rhEjVfrd.cjs');
|
|
20
|
+
require('../../amplitudeTrackEventAtom-f22P2U0u.cjs');
|
|
21
21
|
|
|
22
22
|
exports.APP_INITIAL_START_TIME_KEY = require_chat.APP_INITIAL_START_TIME_KEY;
|
|
23
23
|
exports.PAGE_LOAD_OFFSET_TIME_KEY = require_chat.PAGE_LOAD_OFFSET_TIME_KEY;
|