@envive-ai/react-hooks 0.3.19-alpha-marlo-2 → 0.3.19-alpha-marlo-4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/application/utils/elementObserver.d.cts +2 -2
- package/dist/application/utils/elementObserver.d.ts +2 -2
- package/dist/atoms/app/index.d.cts +7 -7
- package/dist/atoms/app/index.d.ts +7 -7
- package/dist/atoms/app/variant.d.ts +6 -6
- package/dist/atoms/chat/chatState.d.cts +17 -17
- package/dist/atoms/chat/chatState.d.ts +18 -18
- package/dist/atoms/chat/form.d.cts +2 -2
- package/dist/atoms/chat/form.d.ts +3 -3
- package/dist/atoms/chat/index.d.cts +2 -2
- package/dist/atoms/chat/index.d.ts +3 -3
- package/dist/atoms/chat/lastMessage.d.cts +2 -2
- package/dist/atoms/chat/lastMessage.d.ts +2 -2
- package/dist/atoms/chat/messageQueue.d.cts +6 -6
- package/dist/atoms/chat/messageQueue.d.ts +7 -7
- package/dist/atoms/chat/performanceMetrics.d.cts +6 -6
- package/dist/atoms/chat/performanceMetrics.d.ts +6 -6
- package/dist/atoms/chat/renderedWidgetRefs.d.cts +2 -2
- package/dist/atoms/chat/renderedWidgetRefs.d.ts +2 -2
- package/dist/atoms/chat/replies.d.cts +3 -3
- package/dist/atoms/chat/replies.d.ts +3 -3
- package/dist/atoms/chat/suggestions.d.cts +2 -2
- package/dist/atoms/chat/suggestions.d.ts +3 -3
- package/dist/atoms/envive/enviveConfig.d.cts +12 -12
- package/dist/atoms/envive/enviveConfig.d.ts +13 -13
- package/dist/atoms/globalSearch/globalSearch.d.cts +5 -5
- package/dist/atoms/globalSearch/globalSearch.d.ts +5 -5
- package/dist/atoms/org/customerService.d.cts +6 -6
- package/dist/atoms/org/customerService.d.ts +6 -6
- package/dist/atoms/org/graphqlConfig.d.cts +4 -4
- package/dist/atoms/org/graphqlConfig.d.ts +4 -4
- package/dist/atoms/org/newOrgConfigAtom.d.cts +2 -2
- package/dist/atoms/org/newOrgConfigAtom.d.ts +2 -2
- package/dist/atoms/org/orgAnalyticsConfig.d.cts +5 -5
- package/dist/atoms/org/orgAnalyticsConfig.d.ts +5 -5
- package/dist/atoms/search/chatSearch.d.cts +17 -17
- package/dist/atoms/search/chatSearch.d.ts +17 -17
- package/dist/atoms/search/searchAPI.d.cts +13 -13
- package/dist/atoms/search/searchAPI.d.ts +13 -13
- package/dist/atoms/search/types.d.cts +1 -1
- package/dist/atoms/search/types.d.ts +1 -1
- package/dist/atoms/search/utils.d.cts +1 -1
- package/dist/atoms/widget/chatPreviewLoading.d.cts +2 -2
- package/dist/atoms/widget/chatPreviewLoading.d.ts +2 -2
- package/dist/contexts/amplitudeContext/amplitudeContext.cjs +9 -6
- package/dist/contexts/amplitudeContext/amplitudeContext.js +9 -6
- package/dist/contexts/enviveContext/enviveContext.cjs +3 -3
- package/dist/contexts/enviveContext/enviveContext.js +3 -3
- package/dist/contexts/enviveContext/types.d.cts +1 -1
- package/dist/contexts/pageContext/pageContext.cjs +58 -1
- package/dist/contexts/pageContext/pageContext.js +60 -3
- package/dist/contexts/pageContext/types.d.ts +1 -1
- package/dist/contexts/systemSettingsContext/systemSettingsContext.d.cts +2 -2
- package/dist/contexts/systemSettingsContext/systemSettingsContext.d.ts +2 -2
- package/dist/contexts/types.d.cts +1 -1
- package/dist/contexts/types.d.ts +1 -1
- package/dist/contexts/typesV3.d.ts +1 -1
- package/dist/hooks/GrabAndScroll/useGrabAndScroll.d.ts +2 -2
- package/dist/hooks/PageViewedEvent/index.cjs +4 -0
- package/dist/hooks/PageViewedEvent/index.d.cts +2 -0
- package/dist/hooks/PageViewedEvent/index.d.ts +2 -0
- package/dist/hooks/PageViewedEvent/index.js +3 -0
- package/dist/hooks/PageViewedEvent/usePageViewedEvent.cjs +84 -0
- package/dist/hooks/PageViewedEvent/usePageViewedEvent.d.cts +18 -0
- package/dist/hooks/PageViewedEvent/usePageViewedEvent.d.ts +18 -0
- package/dist/hooks/PageViewedEvent/usePageViewedEvent.js +82 -0
- package/dist/hooks/SystemSettingsContext/useSystemSettingsContext.d.cts +2 -2
- package/dist/hooks/SystemSettingsContext/useSystemSettingsContext.d.ts +2 -2
- package/dist/hooks/WidgetInteraction/types.d.ts +1 -1
- package/dist/hooks/WidgetInteraction/utils.d.ts +1 -1
- package/dist/hooks/utils.d.ts +1 -1
- package/dist/services/amplitudeService/amplitudeService.cjs +5 -10
- package/dist/services/amplitudeService/amplitudeService.d.cts +2 -4
- package/dist/services/amplitudeService/amplitudeService.d.ts +2 -4
- package/dist/services/amplitudeService/amplitudeService.js +5 -10
- package/package.json +5 -1
- package/src/contexts/amplitudeContext/__tests__/amplitudeContext.test.tsx +5 -6
- package/src/contexts/amplitudeContext/amplitudeContext.tsx +7 -3
- package/src/contexts/pageContext/__tests__/pageContext.test.tsx +6 -0
- package/src/contexts/pageContext/pageContext.tsx +60 -1
- package/src/hooks/PageViewedEvent/__tests__/usePageViewedEvent.test.ts +297 -0
- package/src/hooks/PageViewedEvent/index.ts +1 -0
- package/src/hooks/PageViewedEvent/usePageViewedEvent.ts +103 -0
- package/src/services/amplitudeService/__tests__/amplitudeService.test.ts +6 -56
- package/src/services/amplitudeService/amplitudeService.ts +4 -14
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { ChatSearchFilter, ProductSorting } from "./types.cjs";
|
|
2
2
|
import { SearchParams, SearchResult } from "../../application/models/api/search.cjs";
|
|
3
|
-
import * as
|
|
3
|
+
import * as jotai61 from "jotai";
|
|
4
4
|
|
|
5
5
|
//#region src/atoms/search/searchAPI.d.ts
|
|
6
6
|
type SelectedFilterOption = {
|
|
@@ -15,28 +15,28 @@ interface SearchState {
|
|
|
15
15
|
error: string | null;
|
|
16
16
|
lastQuery: string | null;
|
|
17
17
|
}
|
|
18
|
-
declare const searchAtom:
|
|
18
|
+
declare const searchAtom: jotai61.PrimitiveAtom<SearchState> & {
|
|
19
19
|
init: SearchState;
|
|
20
20
|
};
|
|
21
|
-
declare const searchProductSortingAtom:
|
|
21
|
+
declare const searchProductSortingAtom: jotai61.PrimitiveAtom<ProductSorting> & {
|
|
22
22
|
init: ProductSorting;
|
|
23
23
|
};
|
|
24
|
-
declare const searchSelectedFiltersAtom:
|
|
24
|
+
declare const searchSelectedFiltersAtom: jotai61.PrimitiveAtom<SelectedFilterOption[]> & {
|
|
25
25
|
init: SelectedFilterOption[];
|
|
26
26
|
};
|
|
27
27
|
declare const createFilterOption: (filterId: string, filterItemId: string, displayName: string) => SelectedFilterOption;
|
|
28
|
-
declare const searchParamsAtom:
|
|
28
|
+
declare const searchParamsAtom: jotai61.WritableAtom<{
|
|
29
29
|
id: string | null;
|
|
30
30
|
query: string | null;
|
|
31
31
|
}, [value: {
|
|
32
32
|
id: string | null;
|
|
33
33
|
query: string | null;
|
|
34
34
|
}], void>;
|
|
35
|
-
declare const internalSearchSystemStateAtom:
|
|
35
|
+
declare const internalSearchSystemStateAtom: jotai61.PrimitiveAtom<boolean> & {
|
|
36
36
|
init: boolean;
|
|
37
37
|
};
|
|
38
|
-
declare const searchSystemAtom:
|
|
39
|
-
declare const filteredSearchProductsAtom:
|
|
38
|
+
declare const searchSystemAtom: jotai61.WritableAtom<boolean, [value: boolean], void>;
|
|
39
|
+
declare const filteredSearchProductsAtom: jotai61.Atom<{
|
|
40
40
|
averageRating?: number | undefined;
|
|
41
41
|
colors?: string[] | undefined;
|
|
42
42
|
description?: string | undefined;
|
|
@@ -59,17 +59,17 @@ declare const filteredSearchProductsAtom: jotai48.Atom<{
|
|
|
59
59
|
title: string;
|
|
60
60
|
url: string;
|
|
61
61
|
}[]>;
|
|
62
|
-
declare const searchFiltersAtom:
|
|
63
|
-
declare const addSearchFilterAtom:
|
|
62
|
+
declare const searchFiltersAtom: jotai61.Atom<ChatSearchFilter[]>;
|
|
63
|
+
declare const addSearchFilterAtom: jotai61.WritableAtom<null, [filter: SelectedFilterOption], void> & {
|
|
64
64
|
init: null;
|
|
65
65
|
};
|
|
66
|
-
declare const removeSearchFilterAtom:
|
|
66
|
+
declare const removeSearchFilterAtom: jotai61.WritableAtom<null, [filterId: string], void> & {
|
|
67
67
|
init: null;
|
|
68
68
|
};
|
|
69
|
-
declare const clearSearchFiltersAtom:
|
|
69
|
+
declare const clearSearchFiltersAtom: jotai61.WritableAtom<null, [], void> & {
|
|
70
70
|
init: null;
|
|
71
71
|
};
|
|
72
|
-
declare const performSearchAtom:
|
|
72
|
+
declare const performSearchAtom: jotai61.WritableAtom<null, [params: SearchParams, allowRedirect?: unknown], Promise<void>> & {
|
|
73
73
|
init: null;
|
|
74
74
|
};
|
|
75
75
|
//#endregion
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { ChatSearchFilter, ProductSorting } from "./types.js";
|
|
2
2
|
import { SearchParams, SearchResult } from "../../application/models/api/search.js";
|
|
3
|
-
import * as
|
|
3
|
+
import * as jotai65 from "jotai";
|
|
4
4
|
|
|
5
5
|
//#region src/atoms/search/searchAPI.d.ts
|
|
6
6
|
type SelectedFilterOption = {
|
|
@@ -15,28 +15,28 @@ interface SearchState {
|
|
|
15
15
|
error: string | null;
|
|
16
16
|
lastQuery: string | null;
|
|
17
17
|
}
|
|
18
|
-
declare const searchAtom:
|
|
18
|
+
declare const searchAtom: jotai65.PrimitiveAtom<SearchState> & {
|
|
19
19
|
init: SearchState;
|
|
20
20
|
};
|
|
21
|
-
declare const searchProductSortingAtom:
|
|
21
|
+
declare const searchProductSortingAtom: jotai65.PrimitiveAtom<ProductSorting> & {
|
|
22
22
|
init: ProductSorting;
|
|
23
23
|
};
|
|
24
|
-
declare const searchSelectedFiltersAtom:
|
|
24
|
+
declare const searchSelectedFiltersAtom: jotai65.PrimitiveAtom<SelectedFilterOption[]> & {
|
|
25
25
|
init: SelectedFilterOption[];
|
|
26
26
|
};
|
|
27
27
|
declare const createFilterOption: (filterId: string, filterItemId: string, displayName: string) => SelectedFilterOption;
|
|
28
|
-
declare const searchParamsAtom:
|
|
28
|
+
declare const searchParamsAtom: jotai65.WritableAtom<{
|
|
29
29
|
id: string | null;
|
|
30
30
|
query: string | null;
|
|
31
31
|
}, [value: {
|
|
32
32
|
id: string | null;
|
|
33
33
|
query: string | null;
|
|
34
34
|
}], void>;
|
|
35
|
-
declare const internalSearchSystemStateAtom:
|
|
35
|
+
declare const internalSearchSystemStateAtom: jotai65.PrimitiveAtom<boolean> & {
|
|
36
36
|
init: boolean;
|
|
37
37
|
};
|
|
38
|
-
declare const searchSystemAtom:
|
|
39
|
-
declare const filteredSearchProductsAtom:
|
|
38
|
+
declare const searchSystemAtom: jotai65.WritableAtom<boolean, [value: boolean], void>;
|
|
39
|
+
declare const filteredSearchProductsAtom: jotai65.Atom<{
|
|
40
40
|
averageRating?: number | undefined;
|
|
41
41
|
colors?: string[] | undefined;
|
|
42
42
|
description?: string | undefined;
|
|
@@ -59,17 +59,17 @@ declare const filteredSearchProductsAtom: jotai33.Atom<{
|
|
|
59
59
|
title: string;
|
|
60
60
|
url: string;
|
|
61
61
|
}[]>;
|
|
62
|
-
declare const searchFiltersAtom:
|
|
63
|
-
declare const addSearchFilterAtom:
|
|
62
|
+
declare const searchFiltersAtom: jotai65.Atom<ChatSearchFilter[]>;
|
|
63
|
+
declare const addSearchFilterAtom: jotai65.WritableAtom<null, [filter: SelectedFilterOption], void> & {
|
|
64
64
|
init: null;
|
|
65
65
|
};
|
|
66
|
-
declare const removeSearchFilterAtom:
|
|
66
|
+
declare const removeSearchFilterAtom: jotai65.WritableAtom<null, [filterId: string], void> & {
|
|
67
67
|
init: null;
|
|
68
68
|
};
|
|
69
|
-
declare const clearSearchFiltersAtom:
|
|
69
|
+
declare const clearSearchFiltersAtom: jotai65.WritableAtom<null, [], void> & {
|
|
70
70
|
init: null;
|
|
71
71
|
};
|
|
72
|
-
declare const performSearchAtom:
|
|
72
|
+
declare const performSearchAtom: jotai65.WritableAtom<null, [params: SearchParams, allowRedirect?: unknown], Promise<void>> & {
|
|
73
73
|
init: null;
|
|
74
74
|
};
|
|
75
75
|
//#endregion
|
|
@@ -57,4 +57,4 @@ interface ProductRetrievalParams {
|
|
|
57
57
|
}
|
|
58
58
|
//#endregion
|
|
59
59
|
export { ChatSearchFilter, ChatSearchFilterItem, ChatSearchSortModalProps, ChatSearchSortOverrides, ChatSearchSortProps, ChatSearchStateType, ProductRetrievalParams, ProductRetrievalResult, ProductSorting, ProductSortingNames, SortOption };
|
|
60
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuZC5jdHMiLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2F0b21zL3NlYXJjaC90eXBlcy5kLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFNlYXJjaFJlc3BvbnNlUHJvZHVjdEF0dHJpYnV0ZXMgfSBmcm9tICdzcmMvYXBwbGljYXRpb24vbW9kZWxzL2FwaS9yZXNwb25zZSc7XG5leHBvcnQgZGVjbGFyZSBlbnVtIFByb2R1Y3RTb3J0aW5nIHtcbiAgICBGRUFUVVJFRCA9IFwiZmVhdHVyZWRcIixcbiAgICBQUklDRV9BU0MgPSBcInByaWNlX2FzY1wiLFxuICAgIFBSSUNFX0RFU0MgPSBcInByaWNlX2Rlc2NcIlxufVxuZXhwb3J0IGRlY2xhcmUgY29uc3QgUHJvZHVjdFNvcnRpbmdOYW1lczoge1xuICAgIGZlYXR1cmVkOiBzdHJpbmc7XG4gICAgcHJpY2VfYXNjOiBzdHJpbmc7XG4gICAgcHJpY2VfZGVzYzogc3RyaW5nO1xufTtcbmV4cG9ydCB0eXBlIENoYXRTZWFyY2hTdGF0ZVR5cGUgPSAnZW50cnlwb2ludCcgfCAnaW5pdGlhbGl6aW5nLXNlYXJjaCcgfCAncHJvZHVjdC1wYWdlJztcbmV4cG9ydCB0eXBlIENoYXRTZWFyY2hGaWx0ZXIgPSB7XG4gICAgZmlsdGVySWQ6IHN0cmluZztcbiAgICBkaXNwbGF5TmFtZTogc3RyaW5nO1xuICAgIGl0ZW1zOiBDaGF0U2VhcmNoRmlsdGVySXRlbVtdO1xufTtcbmV4cG9ydCB0eXBlIENoYXRTZWFyY2hGaWx0ZXJJdGVtID0ge1xuICAgIGZpbHRlckl0ZW1JZDogc3RyaW5nO1xuICAgIGRpc3BsYXlOYW1lOiBzdHJpbmc7XG4gICAgcHJvZHVjdENvdW50OiBudW1iZXI7XG4gICAgaXNTZWxlY3RlZDogYm9vbGVhbjtcbn07XG5leHBvcnQgaW50ZXJmYWNlIENoYXRTZWFyY2hTb3J0UHJvcHMge1xuICAgIG9wdGlvbnM6IFByb2R1Y3RTb3J0aW5nW107XG59XG5leHBvcnQgaW50ZXJmYWNlIENoYXRTZWFyY2hTb3J0TW9kYWxQcm9wcyBleHRlbmRzIENoYXRTZWFyY2hTb3J0UHJvcHMge1xuICAgIG9wZW46IGJvb2xlYW47XG4gICAgaGFuZGxlUG9wdXBTdGF0ZTogKHN0YXRlOiBib29sZWFuKSA9PiB2b2lkO1xufVxuZXhwb3J0IGludGVyZmFjZSBTb3J0T3B0aW9uIHtcbiAgICB2YWx1ZTogUHJvZHVjdFNvcnRpbmc7XG4gICAgaXNTZWxlY3RlZDogYm9vbGVhbjtcbiAgICBvblNlbGVjdDogKG9wdGlvbjogUHJvZHVjdFNvcnRpbmcpID0+
|
|
60
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuZC5jdHMiLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2F0b21zL3NlYXJjaC90eXBlcy5kLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFNlYXJjaFJlc3BvbnNlUHJvZHVjdEF0dHJpYnV0ZXMgfSBmcm9tICdzcmMvYXBwbGljYXRpb24vbW9kZWxzL2FwaS9yZXNwb25zZSc7XG5leHBvcnQgZGVjbGFyZSBlbnVtIFByb2R1Y3RTb3J0aW5nIHtcbiAgICBGRUFUVVJFRCA9IFwiZmVhdHVyZWRcIixcbiAgICBQUklDRV9BU0MgPSBcInByaWNlX2FzY1wiLFxuICAgIFBSSUNFX0RFU0MgPSBcInByaWNlX2Rlc2NcIlxufVxuZXhwb3J0IGRlY2xhcmUgY29uc3QgUHJvZHVjdFNvcnRpbmdOYW1lczoge1xuICAgIGZlYXR1cmVkOiBzdHJpbmc7XG4gICAgcHJpY2VfYXNjOiBzdHJpbmc7XG4gICAgcHJpY2VfZGVzYzogc3RyaW5nO1xufTtcbmV4cG9ydCB0eXBlIENoYXRTZWFyY2hTdGF0ZVR5cGUgPSAnZW50cnlwb2ludCcgfCAnaW5pdGlhbGl6aW5nLXNlYXJjaCcgfCAncHJvZHVjdC1wYWdlJztcbmV4cG9ydCB0eXBlIENoYXRTZWFyY2hGaWx0ZXIgPSB7XG4gICAgZmlsdGVySWQ6IHN0cmluZztcbiAgICBkaXNwbGF5TmFtZTogc3RyaW5nO1xuICAgIGl0ZW1zOiBDaGF0U2VhcmNoRmlsdGVySXRlbVtdO1xufTtcbmV4cG9ydCB0eXBlIENoYXRTZWFyY2hGaWx0ZXJJdGVtID0ge1xuICAgIGZpbHRlckl0ZW1JZDogc3RyaW5nO1xuICAgIGRpc3BsYXlOYW1lOiBzdHJpbmc7XG4gICAgcHJvZHVjdENvdW50OiBudW1iZXI7XG4gICAgaXNTZWxlY3RlZDogYm9vbGVhbjtcbn07XG5leHBvcnQgaW50ZXJmYWNlIENoYXRTZWFyY2hTb3J0UHJvcHMge1xuICAgIG9wdGlvbnM6IFByb2R1Y3RTb3J0aW5nW107XG59XG5leHBvcnQgaW50ZXJmYWNlIENoYXRTZWFyY2hTb3J0TW9kYWxQcm9wcyBleHRlbmRzIENoYXRTZWFyY2hTb3J0UHJvcHMge1xuICAgIG9wZW46IGJvb2xlYW47XG4gICAgaGFuZGxlUG9wdXBTdGF0ZTogKHN0YXRlOiBib29sZWFuKSA9PiB2b2lkO1xufVxuZXhwb3J0IGludGVyZmFjZSBTb3J0T3B0aW9uIHtcbiAgICB2YWx1ZTogUHJvZHVjdFNvcnRpbmc7XG4gICAgaXNTZWxlY3RlZDogYm9vbGVhbjtcbiAgICBvblNlbGVjdDogKG9wdGlvbjogUHJvZHVjdFNvcnRpbmcpID0+IHZvaWQ7XG59XG5leHBvcnQgZGVjbGFyZSBlbnVtIENoYXRTZWFyY2hTb3J0T3ZlcnJpZGVzIHtcbiAgICBERVNLVE9QX0ZJTFRFUl9DT05UQUlORVIgPSBcInNwaWZmeS1jaGF0LXNlYXJjaC1maWx0ZXItY29udGFpbmVyXCIsXG4gICAgREVTS1RPUF9GSUxURVJfU0VMRUNUX0NPTVBPTkVOVCA9IFwic3BpZmZ5LWNoYXQtc2VhcmNoLWZpbHRlci1zZWxlY3QtY29tcG9uZW50XCIsXG4gICAgREVTS1RPUF9GSUxURVJfU0VMRUNUX0lDT04gPSBcInNwaWZmeS1jaGF0LXNlYXJjaC1maWx0ZXItc2VsZWN0LWljb25cIixcbiAgICBNT0JJTEVfRklMVEVSX0JVVFRPTiA9IFwic3BpZmZ5LWNoYXQtc2VhcmNoLWZpbHRlci1idXR0b25cIixcbiAgICBNT0JJTEVfRklMVEVSX01PREFMX0NPTlRBSU5FUiA9IFwic3BpZmZ5LWNoYXQtc2VhcmNoLWZpbHRlci1tb2RhbC1jb250YWluZXJcIixcbiAgICBNT0JJTEVfRklMVEVSX01PREFMX0hFQURFUiA9IFwic3BpZmZ5LWNoYXQtc2VhcmNoLWZpbHRlci1tb2RhbC1oZWFkZXJcIixcbiAgICBNT0JJTEVfRklMVEVSX01PREFMX1NFTEVDVElPTiA9IFwic3BpZmZ5LWNoYXQtc2VhcmNoLWZpbHRlci1tb2RhbC1zZWxlY3Rpb25cIixcbiAgICBNT0JJTEVfRklMVEVSX01PREFMX09QVElPTiA9IFwic3BpZmZ5LWNoYXQtc2VhcmNoLWZpbHRlci1tb2RhbC1vcHRpb25cIixcbiAgICBNT0JJTEVfRklMVEVSX01PREFMX09QVElPTl9QSUxMID0gXCJzcGlmZnktY2hhdC1zZWFyY2gtZmlsdGVyLW1vZGFsLW9wdGlvbi1waWxsXCIsXG4gICAgTU9CSUxFX0ZJTFRFUl9NT0RBTF9PUFRJT05fREVTQ1JJUFRJT04gPSBcInNwaWZmeS1jaGF0LXNlYXJjaC1maWx0ZXItbW9kYWwtb3B0aW9uLWRlc2NcIixcbiAgICBNT0JJTEVfRklMVEVSX01PREFMX0FQUExZX0JVVFRPTiA9IFwic3BpZmZ5LWNoYXQtc2VhcmNoLWZpbHRlci1tb2RhbC1hcHBseS1idXR0b25cIlxufVxuZXhwb3J0IGludGVyZmFjZSBQcm9kdWN0UmV0cmlldmFsUmVzdWx0IHtcbiAgICBwcm9kdWN0czogU2VhcmNoUmVzcG9uc2VQcm9kdWN0QXR0cmlidXRlc1snYXR0cmlidXRlcyddW107XG4gICAgdG90YWxQcm9kdWN0Q291bnQ6IG51bWJlcjtcbn1cbmV4cG9ydCBpbnRlcmZhY2UgUHJvZHVjdFJldHJpZXZhbFBhcmFtcyB7XG4gICAgcHJvZHVjdElkczogc3RyaW5nW107XG59XG4iXSwibWFwcGluZ3MiOiI7OztBQUNBLElBQVcsaUJBQWlCLENBQUMsRUFBRTtBQUMvQixJQUFXLHNCQUFjLENBQUEsR0FBQTtBQUN6QixJQUFXLHNCQUFnQixDQUFBLEdBQUE7QUFDM0IsSUFBVyxtQkFBaUIsQ0FBQSxVQUFBLHFCQUFBO0FBQzVCLElBQUEsdUJBQUEsQ0FBQSxHQUFBO0FBQ0EsSUFBVyxzQkFBc0IsQ0FBQyxVQUFRLGVBQUE7QUFDMUMsSUFBVywyQkFBUyxDQUFBLFVBQUEsb0JBQUE7QUFDcEIsSUFBVyxhQUFVO0NBQUE7T0FBQTtPQUFBO0NBQUE7QUFDckIsSUFBVywwQkFBVyxDQUFBLEdBQUE7QUFDdEIsSUFBQyx5QkFBQSxDQUFBLFVBQUEsZ0NBQUE7QUFDRCxJQUFXLHlCQUF5QixDQUFDLEdBQUcifQ==
|
|
@@ -57,4 +57,4 @@ interface ProductRetrievalParams {
|
|
|
57
57
|
}
|
|
58
58
|
//#endregion
|
|
59
59
|
export { ChatSearchFilter, ChatSearchFilterItem, ChatSearchSortModalProps, ChatSearchSortOverrides, ChatSearchSortProps, ChatSearchStateType, ProductRetrievalParams, ProductRetrievalResult, ProductSorting, ProductSortingNames, SortOption };
|
|
60
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuZC50cyIsIm5hbWVzIjpbXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXRvbXMvc2VhcmNoL3R5cGVzLmQudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU2VhcmNoUmVzcG9uc2VQcm9kdWN0QXR0cmlidXRlcyB9IGZyb20gJ3NyYy9hcHBsaWNhdGlvbi9tb2RlbHMvYXBpL3Jlc3BvbnNlJztcbmV4cG9ydCBkZWNsYXJlIGVudW0gUHJvZHVjdFNvcnRpbmcge1xuICAgIEZFQVRVUkVEID0gXCJmZWF0dXJlZFwiLFxuICAgIFBSSUNFX0FTQyA9IFwicHJpY2VfYXNjXCIsXG4gICAgUFJJQ0VfREVTQyA9IFwicHJpY2VfZGVzY1wiXG59XG5leHBvcnQgZGVjbGFyZSBjb25zdCBQcm9kdWN0U29ydGluZ05hbWVzOiB7XG4gICAgZmVhdHVyZWQ6IHN0cmluZztcbiAgICBwcmljZV9hc2M6IHN0cmluZztcbiAgICBwcmljZV9kZXNjOiBzdHJpbmc7XG59O1xuZXhwb3J0IHR5cGUgQ2hhdFNlYXJjaFN0YXRlVHlwZSA9ICdlbnRyeXBvaW50JyB8ICdpbml0aWFsaXppbmctc2VhcmNoJyB8ICdwcm9kdWN0LXBhZ2UnO1xuZXhwb3J0IHR5cGUgQ2hhdFNlYXJjaEZpbHRlciA9IHtcbiAgICBmaWx0ZXJJZDogc3RyaW5nO1xuICAgIGRpc3BsYXlOYW1lOiBzdHJpbmc7XG4gICAgaXRlbXM6IENoYXRTZWFyY2hGaWx0ZXJJdGVtW107XG59O1xuZXhwb3J0IHR5cGUgQ2hhdFNlYXJjaEZpbHRlckl0ZW0gPSB7XG4gICAgZmlsdGVySXRlbUlkOiBzdHJpbmc7XG4gICAgZGlzcGxheU5hbWU6IHN0cmluZztcbiAgICBwcm9kdWN0Q291bnQ6IG51bWJlcjtcbiAgICBpc1NlbGVjdGVkOiBib29sZWFuO1xufTtcbmV4cG9ydCBpbnRlcmZhY2UgQ2hhdFNlYXJjaFNvcnRQcm9wcyB7XG4gICAgb3B0aW9uczogUHJvZHVjdFNvcnRpbmdbXTtcbn1cbmV4cG9ydCBpbnRlcmZhY2UgQ2hhdFNlYXJjaFNvcnRNb2RhbFByb3BzIGV4dGVuZHMgQ2hhdFNlYXJjaFNvcnRQcm9wcyB7XG4gICAgb3BlbjogYm9vbGVhbjtcbiAgICBoYW5kbGVQb3B1cFN0YXRlOiAoc3RhdGU6IGJvb2xlYW4pID0+
|
|
60
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuZC50cyIsIm5hbWVzIjpbXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXRvbXMvc2VhcmNoL3R5cGVzLmQudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU2VhcmNoUmVzcG9uc2VQcm9kdWN0QXR0cmlidXRlcyB9IGZyb20gJ3NyYy9hcHBsaWNhdGlvbi9tb2RlbHMvYXBpL3Jlc3BvbnNlJztcbmV4cG9ydCBkZWNsYXJlIGVudW0gUHJvZHVjdFNvcnRpbmcge1xuICAgIEZFQVRVUkVEID0gXCJmZWF0dXJlZFwiLFxuICAgIFBSSUNFX0FTQyA9IFwicHJpY2VfYXNjXCIsXG4gICAgUFJJQ0VfREVTQyA9IFwicHJpY2VfZGVzY1wiXG59XG5leHBvcnQgZGVjbGFyZSBjb25zdCBQcm9kdWN0U29ydGluZ05hbWVzOiB7XG4gICAgZmVhdHVyZWQ6IHN0cmluZztcbiAgICBwcmljZV9hc2M6IHN0cmluZztcbiAgICBwcmljZV9kZXNjOiBzdHJpbmc7XG59O1xuZXhwb3J0IHR5cGUgQ2hhdFNlYXJjaFN0YXRlVHlwZSA9ICdlbnRyeXBvaW50JyB8ICdpbml0aWFsaXppbmctc2VhcmNoJyB8ICdwcm9kdWN0LXBhZ2UnO1xuZXhwb3J0IHR5cGUgQ2hhdFNlYXJjaEZpbHRlciA9IHtcbiAgICBmaWx0ZXJJZDogc3RyaW5nO1xuICAgIGRpc3BsYXlOYW1lOiBzdHJpbmc7XG4gICAgaXRlbXM6IENoYXRTZWFyY2hGaWx0ZXJJdGVtW107XG59O1xuZXhwb3J0IHR5cGUgQ2hhdFNlYXJjaEZpbHRlckl0ZW0gPSB7XG4gICAgZmlsdGVySXRlbUlkOiBzdHJpbmc7XG4gICAgZGlzcGxheU5hbWU6IHN0cmluZztcbiAgICBwcm9kdWN0Q291bnQ6IG51bWJlcjtcbiAgICBpc1NlbGVjdGVkOiBib29sZWFuO1xufTtcbmV4cG9ydCBpbnRlcmZhY2UgQ2hhdFNlYXJjaFNvcnRQcm9wcyB7XG4gICAgb3B0aW9uczogUHJvZHVjdFNvcnRpbmdbXTtcbn1cbmV4cG9ydCBpbnRlcmZhY2UgQ2hhdFNlYXJjaFNvcnRNb2RhbFByb3BzIGV4dGVuZHMgQ2hhdFNlYXJjaFNvcnRQcm9wcyB7XG4gICAgb3BlbjogYm9vbGVhbjtcbiAgICBoYW5kbGVQb3B1cFN0YXRlOiAoc3RhdGU6IGJvb2xlYW4pID0+IHZvaWQ7XG59XG5leHBvcnQgaW50ZXJmYWNlIFNvcnRPcHRpb24ge1xuICAgIHZhbHVlOiBQcm9kdWN0U29ydGluZztcbiAgICBpc1NlbGVjdGVkOiBib29sZWFuO1xuICAgIG9uU2VsZWN0OiAob3B0aW9uOiBQcm9kdWN0U29ydGluZykgPT4gdm9pZDtcbn1cbmV4cG9ydCBkZWNsYXJlIGVudW0gQ2hhdFNlYXJjaFNvcnRPdmVycmlkZXMge1xuICAgIERFU0tUT1BfRklMVEVSX0NPTlRBSU5FUiA9IFwic3BpZmZ5LWNoYXQtc2VhcmNoLWZpbHRlci1jb250YWluZXJcIixcbiAgICBERVNLVE9QX0ZJTFRFUl9TRUxFQ1RfQ09NUE9ORU5UID0gXCJzcGlmZnktY2hhdC1zZWFyY2gtZmlsdGVyLXNlbGVjdC1jb21wb25lbnRcIixcbiAgICBERVNLVE9QX0ZJTFRFUl9TRUxFQ1RfSUNPTiA9IFwic3BpZmZ5LWNoYXQtc2VhcmNoLWZpbHRlci1zZWxlY3QtaWNvblwiLFxuICAgIE1PQklMRV9GSUxURVJfQlVUVE9OID0gXCJzcGlmZnktY2hhdC1zZWFyY2gtZmlsdGVyLWJ1dHRvblwiLFxuICAgIE1PQklMRV9GSUxURVJfTU9EQUxfQ09OVEFJTkVSID0gXCJzcGlmZnktY2hhdC1zZWFyY2gtZmlsdGVyLW1vZGFsLWNvbnRhaW5lclwiLFxuICAgIE1PQklMRV9GSUxURVJfTU9EQUxfSEVBREVSID0gXCJzcGlmZnktY2hhdC1zZWFyY2gtZmlsdGVyLW1vZGFsLWhlYWRlclwiLFxuICAgIE1PQklMRV9GSUxURVJfTU9EQUxfU0VMRUNUSU9OID0gXCJzcGlmZnktY2hhdC1zZWFyY2gtZmlsdGVyLW1vZGFsLXNlbGVjdGlvblwiLFxuICAgIE1PQklMRV9GSUxURVJfTU9EQUxfT1BUSU9OID0gXCJzcGlmZnktY2hhdC1zZWFyY2gtZmlsdGVyLW1vZGFsLW9wdGlvblwiLFxuICAgIE1PQklMRV9GSUxURVJfTU9EQUxfT1BUSU9OX1BJTEwgPSBcInNwaWZmeS1jaGF0LXNlYXJjaC1maWx0ZXItbW9kYWwtb3B0aW9uLXBpbGxcIixcbiAgICBNT0JJTEVfRklMVEVSX01PREFMX09QVElPTl9ERVNDUklQVElPTiA9IFwic3BpZmZ5LWNoYXQtc2VhcmNoLWZpbHRlci1tb2RhbC1vcHRpb24tZGVzY1wiLFxuICAgIE1PQklMRV9GSUxURVJfTU9EQUxfQVBQTFlfQlVUVE9OID0gXCJzcGlmZnktY2hhdC1zZWFyY2gtZmlsdGVyLW1vZGFsLWFwcGx5LWJ1dHRvblwiXG59XG5leHBvcnQgaW50ZXJmYWNlIFByb2R1Y3RSZXRyaWV2YWxSZXN1bHQge1xuICAgIHByb2R1Y3RzOiBTZWFyY2hSZXNwb25zZVByb2R1Y3RBdHRyaWJ1dGVzWydhdHRyaWJ1dGVzJ11bXTtcbiAgICB0b3RhbFByb2R1Y3RDb3VudDogbnVtYmVyO1xufVxuZXhwb3J0IGludGVyZmFjZSBQcm9kdWN0UmV0cmlldmFsUGFyYW1zIHtcbiAgICBwcm9kdWN0SWRzOiBzdHJpbmdbXTtcbn1cbiJdLCJtYXBwaW5ncyI6Ijs7O0FBQ0EsSUFBVyxpQkFBaUIsQ0FBQyxFQUFFO0FBQy9CLElBQVcsc0JBQWMsQ0FBQSxFQUFBO0FBQ3pCLElBQVcsc0JBQWdCLENBQUEsRUFBQTtBQUMzQixJQUFXLG1CQUFpQixDQUFBLFNBQUEscUJBQUE7QUFDNUIsSUFBQSx1QkFBQSxDQUFBLEVBQUE7QUFDQSxJQUFXLHNCQUFzQixDQUFDLFNBQVEsZUFBQTtBQUMxQyxJQUFXLDJCQUFTLENBQUEsU0FBQSxvQkFBQTtBQUNwQixJQUFXLGFBQVU7Q0FBQTtPQUFBO09BQUE7Q0FBQTtBQUNyQixJQUFXLDBCQUFXLENBQUEsRUFBQTtBQUN0QixJQUFDLHlCQUFBLENBQUEsU0FBQSxnQ0FBQTtBQUNELElBQVcseUJBQXlCLENBQUMsR0FBRyJ9
|
|
@@ -2,4 +2,4 @@
|
|
|
2
2
|
declare const formatFilterDisplayName: (displayName: string) => string;
|
|
3
3
|
//#endregion
|
|
4
4
|
export { formatFilterDisplayName };
|
|
5
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
5
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuZC5jdHMiLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2F0b21zL3NlYXJjaC91dGlscy5kLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBkZWNsYXJlIGNvbnN0IGZvcm1hdEZpbHRlckRpc3BsYXlOYW1lOiAoZGlzcGxheU5hbWU6IHN0cmluZykgPT4gc3RyaW5nO1xuIl0sIm1hcHBpbmdzIjoiO0FBQUEsSUFBVywwQkFBMEIsQ0FBQyxHQUFHIn0=
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { WidgetWrapperVariant } from "@envive-ai/react-toolkit-v3/WidgetWrapper";
|
|
2
|
-
import * as
|
|
2
|
+
import * as jotai60 from "jotai";
|
|
3
3
|
|
|
4
4
|
//#region src/atoms/widget/chatPreviewLoading.d.ts
|
|
5
5
|
/**
|
|
@@ -17,7 +17,7 @@ type ChatPreviewLoadingData = {
|
|
|
17
17
|
/**
|
|
18
18
|
* Atom to read ChatPreviewLoading data for a specific widgetConfigId.
|
|
19
19
|
*/
|
|
20
|
-
declare const chatPreviewLoadingDataAtom:
|
|
20
|
+
declare const chatPreviewLoadingDataAtom: jotai60.WritableAtom<Record<string, ChatPreviewLoadingData>, [update: {
|
|
21
21
|
widgetConfigId: string;
|
|
22
22
|
data: ChatPreviewLoadingData;
|
|
23
23
|
}], void>;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import * as
|
|
1
|
+
import * as jotai33 from "jotai";
|
|
2
2
|
import { WidgetWrapperVariant } from "@envive-ai/react-toolkit-v3/WidgetWrapper";
|
|
3
3
|
|
|
4
4
|
//#region src/atoms/widget/chatPreviewLoading.d.ts
|
|
@@ -17,7 +17,7 @@ type ChatPreviewLoadingData = {
|
|
|
17
17
|
/**
|
|
18
18
|
* Atom to read ChatPreviewLoading data for a specific widgetConfigId.
|
|
19
19
|
*/
|
|
20
|
-
declare const chatPreviewLoadingDataAtom:
|
|
20
|
+
declare const chatPreviewLoadingDataAtom: jotai33.WritableAtom<Record<string, ChatPreviewLoadingData>, [update: {
|
|
21
21
|
widgetConfigId: string;
|
|
22
22
|
data: ChatPreviewLoadingData;
|
|
23
23
|
}], void>;
|
|
@@ -15,7 +15,12 @@ let react_jsx_runtime = require("react/jsx-runtime");
|
|
|
15
15
|
let jotai = require("jotai");
|
|
16
16
|
|
|
17
17
|
//#region src/contexts/amplitudeContext/amplitudeContext.tsx
|
|
18
|
-
const
|
|
18
|
+
const noOpAmplitudeContext = {
|
|
19
|
+
trackEvent: async () => {},
|
|
20
|
+
isReady: false,
|
|
21
|
+
setSupplementalDefaultProps: () => {}
|
|
22
|
+
};
|
|
23
|
+
const AmplitudeContext = (0, react.createContext)(noOpAmplitudeContext);
|
|
19
24
|
const AmplitudeProvider = ({ externalAmplitudeService, children }) => {
|
|
20
25
|
const userId = (0, jotai.useAtomValue)(require_atoms_app_index.userIdAtom);
|
|
21
26
|
const amplitudeApiKey = (0, jotai.useAtomValue)(require_atoms_envive_enviveConfig.amplitudeApiKeyAtom);
|
|
@@ -77,17 +82,15 @@ const AmplitudeProvider = ({ externalAmplitudeService, children }) => {
|
|
|
77
82
|
}
|
|
78
83
|
}), [service, isReady]);
|
|
79
84
|
return /* @__PURE__ */ (0, react_jsx_runtime.jsx)(AmplitudeContext.Provider, {
|
|
80
|
-
value,
|
|
85
|
+
value: isReady ? value : noOpAmplitudeContext,
|
|
81
86
|
children
|
|
82
87
|
});
|
|
83
88
|
};
|
|
84
89
|
const useAmplitude = () => {
|
|
85
|
-
|
|
86
|
-
if (!context) throw new Error("useAmplitude must be used within AmplitudeProvider");
|
|
87
|
-
return context;
|
|
90
|
+
return (0, react.useContext)(AmplitudeContext);
|
|
88
91
|
};
|
|
89
92
|
|
|
90
93
|
//#endregion
|
|
91
94
|
exports.AmplitudeProvider = AmplitudeProvider;
|
|
92
95
|
exports.useAmplitude = useAmplitude;
|
|
93
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
96
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW1wbGl0dWRlQ29udGV4dC5janMiLCJuYW1lcyI6WyJub09wQW1wbGl0dWRlQ29udGV4dDogQW1wbGl0dWRlQ29udGV4dFR5cGUiLCJBbXBsaXR1ZGVQcm92aWRlcjogUmVhY3QuRkM8e1xuICBleHRlcm5hbEFtcGxpdHVkZVNlcnZpY2U/OiBBbXBsaXR1ZGVTZXJ2aWNlO1xuICBjaGlsZHJlbjogUmVhY3QuUmVhY3ROb2RlO1xufT4iLCJ1c2VySWRBdG9tIiwiYW1wbGl0dWRlQXBpS2V5QXRvbSIsImRhdGFSZXNpZGVuY3lBdG9tIiwib3JnQW5hbHl0aWNzR29vZ2xlQW5hbHl0aWNzQ29uZmlnQXRvbSIsImVudkF0b20iLCJjb250ZXh0U291cmNlQXRvbSIsInVzZUxvY2FsU3RvcmFnZSIsInVzZUVudml2ZUNvbmZpZyIsInVzZUZlYXR1cmVGbGFnU2VydmljZSIsIkFtcGxpdHVkZVNlcnZpY2UiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29udGV4dHMvYW1wbGl0dWRlQ29udGV4dC9hbXBsaXR1ZGVDb250ZXh0LnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgY3JlYXRlQ29udGV4dCwgdXNlQ29udGV4dCwgdXNlRWZmZWN0LCB1c2VNZW1vLCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IHVzZUF0b21WYWx1ZSB9IGZyb20gJ2pvdGFpJztcbmltcG9ydCB7XG4gIGFtcGxpdHVkZUFwaUtleUF0b20sXG4gIGNvbnRleHRTb3VyY2VBdG9tLFxuICBkYXRhUmVzaWRlbmN5QXRvbSxcbiAgZW52QXRvbSxcbn0gZnJvbSAnc3JjL2F0b21zL2Vudml2ZS9lbnZpdmVDb25maWcnO1xuaW1wb3J0IHsgdXNlTG9jYWxTdG9yYWdlIH0gZnJvbSAnc3JjL2NvbnRleHRzL2xvY2FsU3RvcmFnZUNvbnRleHQnO1xuaW1wb3J0IHsgb3JnQW5hbHl0aWNzR29vZ2xlQW5hbHl0aWNzQ29uZmlnQXRvbSB9IGZyb20gJ3NyYy9hdG9tcy9vcmcvb3JnQW5hbHl0aWNzQ29uZmlnJztcbmltcG9ydCB7IHVzZXJJZEF0b20gfSBmcm9tICdzcmMvYXRvbXMvYXBwJztcbmltcG9ydCB7IHVzZUVudml2ZUNvbmZpZyB9IGZyb20gJ3NyYy9jb250ZXh0cy9lbnZpdmVDb25maWdDb250ZXh0JztcbmltcG9ydCB7IHVzZUZlYXR1cmVGbGFnU2VydmljZSB9IGZyb20gJ3NyYy9jb250ZXh0cy9mZWF0dXJlRmxhZ1NlcnZpY2VDb250ZXh0L2ZlYXR1cmVGbGFnU2VydmljZUNvbnRleHQnO1xuaW1wb3J0IHtcbiAgQW1wbGl0dWRlU2VydmljZSxcbiAgRW52aXZlTWV0cmljc0V2ZW50TmFtZSxcbiAgU3BpZmZ5TWV0cmljc0V2ZW50TmFtZSxcbiAgVHJhY2tFdmVudFBhcmFtcyxcbn0gZnJvbSAnc3JjL3NlcnZpY2VzL2FtcGxpdHVkZVNlcnZpY2UvYW1wbGl0dWRlU2VydmljZSc7XG5cbmV4cG9ydCB7IEVudml2ZU1ldHJpY3NFdmVudE5hbWUsIFNwaWZmeU1ldHJpY3NFdmVudE5hbWUgfTtcblxuaW50ZXJmYWNlIEFtcGxpdHVkZUNvbnRleHRUeXBlIHtcbiAgdHJhY2tFdmVudDogKHBhcmFtczogVHJhY2tFdmVudFBhcmFtcykgPT4gUHJvbWlzZTx2b2lkPjtcbiAgaXNSZWFkeTogYm9vbGVhbjtcbiAgc2V0U3VwcGxlbWVudGFsRGVmYXVsdFByb3BzOiAocHJvcHM6IFJlY29yZDxzdHJpbmcsIHVua25vd24+KSA9PiB2b2lkO1xufVxuXG5jb25zdCBub09wQW1wbGl0dWRlQ29udGV4dDogQW1wbGl0dWRlQ29udGV4dFR5cGUgPSB7XG4gIHRyYWNrRXZlbnQ6IGFzeW5jICgpID0+IHt9LFxuICBpc1JlYWR5OiBmYWxzZSxcbiAgc2V0U3VwcGxlbWVudGFsRGVmYXVsdFByb3BzOiAoKSA9PiB7fSxcbn07XG5cbmNvbnN0IEFtcGxpdHVkZUNvbnRleHQgPSBjcmVhdGVDb250ZXh0PEFtcGxpdHVkZUNvbnRleHRUeXBlPihub09wQW1wbGl0dWRlQ29udGV4dCk7XG5cbmV4cG9ydCBjb25zdCBBbXBsaXR1ZGVQcm92aWRlcjogUmVhY3QuRkM8e1xuICBleHRlcm5hbEFtcGxpdHVkZVNlcnZpY2U/OiBBbXBsaXR1ZGVTZXJ2aWNlO1xuICBjaGlsZHJlbjogUmVhY3QuUmVhY3ROb2RlO1xufT4gPSAoeyBleHRlcm5hbEFtcGxpdHVkZVNlcnZpY2UsIGNoaWxkcmVuIH0pID0+IHtcbiAgY29uc3QgdXNlcklkID0gdXNlQXRvbVZhbHVlKHVzZXJJZEF0b20pO1xuICBjb25zdCBhbXBsaXR1ZGVBcGlLZXkgPSB1c2VBdG9tVmFsdWUoYW1wbGl0dWRlQXBpS2V5QXRvbSk7XG4gIGNvbnN0IGRhdGFSZXNpZGVuY3kgPSB1c2VBdG9tVmFsdWUoZGF0YVJlc2lkZW5jeUF0b20pO1xuICBjb25zdCBvcmdHYUNvbmZpZyA9IHVzZUF0b21WYWx1ZShvcmdBbmFseXRpY3NHb29nbGVBbmFseXRpY3NDb25maWdBdG9tKTtcbiAgY29uc3QgZW52ID0gdXNlQXRvbVZhbHVlKGVudkF0b20pO1xuICBjb25zdCBjb250ZXh0U291cmNlID0gdXNlQXRvbVZhbHVlKGNvbnRleHRTb3VyY2VBdG9tKTtcbiAgY29uc3QgeyBnZXRJdGVtIH0gPSB1c2VMb2NhbFN0b3JhZ2UoKTtcbiAgY29uc3Qge1xuICAgIGZlYXR1cmVPdmVycmlkZXMsXG4gICAgdmFyaWFudFVybE92ZXJyaWRlLFxuICAgIHZhcmlhbnRJbmZvT3ZlcnJpZGUsXG4gICAgc2hvdyxcbiAgICBlbnZpdmVPbixcbiAgICBvcmdJZCxcbiAgICBvcmdTaG9ydE5hbWUsXG4gICAgZmVhdHVyZUdhdGVzLFxuICB9ID0gdXNlRW52aXZlQ29uZmlnKCk7XG5cbiAgY29uc3QgeyBmZWF0dXJlRmxhZ1NlcnZpY2UgfSA9IHVzZUZlYXR1cmVGbGFnU2VydmljZSgpO1xuXG4gIGNvbnN0IFtzZXJ2aWNlLCBzZXRTZXJ2aWNlXSA9IHVzZVN0YXRlPEFtcGxpdHVkZVNlcnZpY2UgfCBudWxsPihudWxsKTtcblxuICBjb25zdCBpc1JlYWR5ID0gQm9vbGVhbih1c2VySWQgJiYgc2VydmljZSAmJiBzZXJ2aWNlLmlzUmVhZHkpO1xuXG4gIC8vIENyZWF0ZSBzZXJ2aWNlIGluc3RhbmNlIHdoZW4gZGVwZW5kZW5jaWVzIGFyZSByZWFkeVxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmIChleHRlcm5hbEFtcGxpdHVkZVNlcnZpY2UgIT09IHVuZGVmaW5lZCkge1xuICAgICAgc2V0U2VydmljZShleHRlcm5hbEFtcGxpdHVkZVNlcnZpY2UpO1xuICAgICAgcmV0dXJuO1xuICAgIH1cbiAgICBpZiAodXNlcklkICYmIGFtcGxpdHVkZUFwaUtleSAmJiBkYXRhUmVzaWRlbmN5ICYmIGZlYXR1cmVGbGFnU2VydmljZSkge1xuICAgICAgY29uc3QgYW1wbGl0dWRlU2VydmljZSA9IG5ldyBBbXBsaXR1ZGVTZXJ2aWNlKHtcbiAgICAgICAgdXNlcklkLFxuICAgICAgICBhbXBsaXR1ZGVBcGlLZXksXG4gICAgICAgIGRhdGFSZXNpZGVuY3ksXG4gICAgICAgIGVudjogZW52IHx8ICcnLFxuICAgICAgICBjb250ZXh0U291cmNlOiBjb250ZXh0U291cmNlIHx8ICcnLFxuICAgICAgICBvcmdTaG9ydE5hbWU6IG9yZ1Nob3J0TmFtZSB8fCAnJyxcbiAgICAgICAgb3JnSWQ6IG9yZ0lkIHx8ICcnLFxuICAgICAgICBmZWF0dXJlRmxhZ1NlcnZpY2UsXG4gICAgICAgIG9yZ0dhQ29uZmlnLFxuICAgICAgICBzaG93OiBzaG93ID8/IGZhbHNlLFxuICAgICAgICBlbnZpdmVPbjogZW52aXZlT24gPz8gZmFsc2UsXG4gICAgICAgIGdldExvY2FsU3RvcmFnZUl0ZW06IGdldEl0ZW0sXG4gICAgICB9KTtcbiAgICAgIHNldFNlcnZpY2UoYW1wbGl0dWRlU2VydmljZSk7XG4gICAgfSBlbHNlIHtcbiAgICAgIHNldFNlcnZpY2UobnVsbCk7XG4gICAgfVxuICB9LCBbXG4gICAgdXNlcklkLFxuICAgIGFtcGxpdHVkZUFwaUtleSxcbiAgICBkYXRhUmVzaWRlbmN5LFxuICAgIGVudixcbiAgICBjb250ZXh0U291cmNlLFxuICAgIG9yZ1Nob3J0TmFtZSxcbiAgICBmZWF0dXJlRmxhZ1NlcnZpY2UsXG4gICAgb3JnR2FDb25maWcsXG4gICAgZmVhdHVyZU92ZXJyaWRlcyxcbiAgICB2YXJpYW50VXJsT3ZlcnJpZGUsXG4gICAgdmFyaWFudEluZm9PdmVycmlkZSxcbiAgICBzaG93LFxuICAgIGVudml2ZU9uLFxuICAgIGZlYXR1cmVHYXRlcyxcbiAgICBnZXRJdGVtLFxuICAgIGV4dGVybmFsQW1wbGl0dWRlU2VydmljZSxcbiAgICBvcmdJZCxcbiAgXSk7XG5cbiAgY29uc3QgdmFsdWUgPSB1c2VNZW1vKFxuICAgICgpID0+ICh7XG4gICAgICB0cmFja0V2ZW50OiBhc3luYyAocGFyYW1zOiBUcmFja0V2ZW50UGFyYW1zKTogUHJvbWlzZTx2b2lkPiA9PiB7XG4gICAgICAgIGlmIChzZXJ2aWNlKSB7XG4gICAgICAgICAgYXdhaXQgc2VydmljZS50cmFja0V2ZW50KHBhcmFtcyk7XG4gICAgICAgIH1cbiAgICAgIH0sXG4gICAgICBpc1JlYWR5LFxuICAgICAgc2V0U3VwcGxlbWVudGFsRGVmYXVsdFByb3BzOiAocHJvcHM6IFJlY29yZDxzdHJpbmcsIHVua25vd24+KSA9PiB7XG4gICAgICAgIGlmIChzZXJ2aWNlKSB7XG4gICAgICAgICAgc2VydmljZS5zZXRTdXBwbGVtZW50YWxEZWZhdWx0UHJvcHMocHJvcHMpO1xuICAgICAgICB9XG4gICAgICB9LFxuICAgIH0pLFxuICAgIFtzZXJ2aWNlLCBpc1JlYWR5XSxcbiAgKTtcblxuICByZXR1cm4gKFxuICAgIDxBbXBsaXR1ZGVDb250ZXh0LlByb3ZpZGVyIHZhbHVlPXtpc1JlYWR5ID8gdmFsdWUgOiBub09wQW1wbGl0dWRlQ29udGV4dH0+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgPC9BbXBsaXR1ZGVDb250ZXh0LlByb3ZpZGVyPlxuICApO1xufTtcblxuZXhwb3J0IGNvbnN0IHVzZUFtcGxpdHVkZSA9ICgpID0+IHtcbiAgcmV0dXJuIHVzZUNvbnRleHQoQW1wbGl0dWRlQ29udGV4dCk7XG59O1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7OztBQTRCQSxNQUFNQSx1QkFBNkM7Q0FDakQsWUFBWSxZQUFZO0NBQ3hCLFNBQVM7Q0FDVCxtQ0FBbUM7Q0FDcEM7QUFFRCxNQUFNLDRDQUF1RCxxQkFBcUI7QUFFbEYsTUFBYUMscUJBR1AsRUFBRSwwQkFBMEIsZUFBZTtDQUMvQyxNQUFNLGlDQUFzQkMsbUNBQVc7Q0FDdkMsTUFBTSwwQ0FBK0JDLHNEQUFvQjtDQUN6RCxNQUFNLHdDQUE2QkMsb0RBQWtCO0NBQ3JELE1BQU0sc0NBQTJCQyxpRUFBc0M7Q0FDdkUsTUFBTSw4QkFBbUJDLDBDQUFRO0NBQ2pDLE1BQU0sd0NBQTZCQyxvREFBa0I7Q0FDckQsTUFBTSxFQUFFLFlBQVlDLDZDQUFpQjtDQUNyQyxNQUFNLEVBQ0osa0JBQ0Esb0JBQ0EscUJBQ0EsTUFDQSxVQUNBLE9BQ0EsY0FDQSxpQkFDRUMseUNBQWlCO0NBRXJCLE1BQU0sRUFBRSx1QkFBdUJDLHlEQUF1QjtDQUV0RCxNQUFNLENBQUMsU0FBUyxrQ0FBZ0QsS0FBSztDQUVyRSxNQUFNLFVBQVUsUUFBUSxVQUFVLFdBQVcsUUFBUSxRQUFRO0FBRzdELDRCQUFnQjtBQUNkLE1BQUksNkJBQTZCLFFBQVc7QUFDMUMsY0FBVyx5QkFBeUI7QUFDcEM7O0FBRUYsTUFBSSxVQUFVLG1CQUFtQixpQkFBaUIsbUJBZWhELFlBZHlCLElBQUlDLDBDQUFpQjtHQUM1QztHQUNBO0dBQ0E7R0FDQSxLQUFLLE9BQU87R0FDWixlQUFlLGlCQUFpQjtHQUNoQyxjQUFjLGdCQUFnQjtHQUM5QixPQUFPLFNBQVM7R0FDaEI7R0FDQTtHQUNBLE1BQU0sUUFBUTtHQUNkLFVBQVUsWUFBWTtHQUN0QixxQkFBcUI7R0FDdEIsQ0FBQyxDQUMwQjtNQUU1QixZQUFXLEtBQUs7SUFFakI7RUFDRDtFQUNBO0VBQ0E7RUFDQTtFQUNBO0VBQ0E7RUFDQTtFQUNBO0VBQ0E7RUFDQTtFQUNBO0VBQ0E7RUFDQTtFQUNBO0VBQ0E7RUFDQTtFQUNBO0VBQ0QsQ0FBQztDQUVGLE1BQU0sa0NBQ0c7RUFDTCxZQUFZLE9BQU8sV0FBNEM7QUFDN0QsT0FBSSxRQUNGLE9BQU0sUUFBUSxXQUFXLE9BQU87O0VBR3BDO0VBQ0EsOEJBQThCLFVBQW1DO0FBQy9ELE9BQUksUUFDRixTQUFRLDRCQUE0QixNQUFNOztFQUcvQyxHQUNELENBQUMsU0FBUyxRQUFRLENBQ25CO0FBRUQsUUFDRSwyQ0FBQyxpQkFBaUI7RUFBUyxPQUFPLFVBQVUsUUFBUTtFQUNqRDtHQUN5Qjs7QUFJaEMsTUFBYSxxQkFBcUI7QUFDaEMsOEJBQWtCLGlCQUFpQiJ9
|
|
@@ -13,7 +13,12 @@ import { jsx } from "react/jsx-runtime";
|
|
|
13
13
|
import { useAtomValue } from "jotai";
|
|
14
14
|
|
|
15
15
|
//#region src/contexts/amplitudeContext/amplitudeContext.tsx
|
|
16
|
-
const
|
|
16
|
+
const noOpAmplitudeContext = {
|
|
17
|
+
trackEvent: async () => {},
|
|
18
|
+
isReady: false,
|
|
19
|
+
setSupplementalDefaultProps: () => {}
|
|
20
|
+
};
|
|
21
|
+
const AmplitudeContext = createContext(noOpAmplitudeContext);
|
|
17
22
|
const AmplitudeProvider = ({ externalAmplitudeService, children }) => {
|
|
18
23
|
const userId = useAtomValue(userIdAtom);
|
|
19
24
|
const amplitudeApiKey = useAtomValue(amplitudeApiKeyAtom);
|
|
@@ -75,16 +80,14 @@ const AmplitudeProvider = ({ externalAmplitudeService, children }) => {
|
|
|
75
80
|
}
|
|
76
81
|
}), [service, isReady]);
|
|
77
82
|
return /* @__PURE__ */ jsx(AmplitudeContext.Provider, {
|
|
78
|
-
value,
|
|
83
|
+
value: isReady ? value : noOpAmplitudeContext,
|
|
79
84
|
children
|
|
80
85
|
});
|
|
81
86
|
};
|
|
82
87
|
const useAmplitude = () => {
|
|
83
|
-
|
|
84
|
-
if (!context) throw new Error("useAmplitude must be used within AmplitudeProvider");
|
|
85
|
-
return context;
|
|
88
|
+
return useContext(AmplitudeContext);
|
|
86
89
|
};
|
|
87
90
|
|
|
88
91
|
//#endregion
|
|
89
92
|
export { AmplitudeProvider, useAmplitude };
|
|
90
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
93
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW1wbGl0dWRlQ29udGV4dC5qcyIsIm5hbWVzIjpbIm5vT3BBbXBsaXR1ZGVDb250ZXh0OiBBbXBsaXR1ZGVDb250ZXh0VHlwZSIsIkFtcGxpdHVkZVByb3ZpZGVyOiBSZWFjdC5GQzx7XG4gIGV4dGVybmFsQW1wbGl0dWRlU2VydmljZT86IEFtcGxpdHVkZVNlcnZpY2U7XG4gIGNoaWxkcmVuOiBSZWFjdC5SZWFjdE5vZGU7XG59PiJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb250ZXh0cy9hbXBsaXR1ZGVDb250ZXh0L2FtcGxpdHVkZUNvbnRleHQudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCwgeyBjcmVhdGVDb250ZXh0LCB1c2VDb250ZXh0LCB1c2VFZmZlY3QsIHVzZU1lbW8sIHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgdXNlQXRvbVZhbHVlIH0gZnJvbSAnam90YWknO1xuaW1wb3J0IHtcbiAgYW1wbGl0dWRlQXBpS2V5QXRvbSxcbiAgY29udGV4dFNvdXJjZUF0b20sXG4gIGRhdGFSZXNpZGVuY3lBdG9tLFxuICBlbnZBdG9tLFxufSBmcm9tICdzcmMvYXRvbXMvZW52aXZlL2Vudml2ZUNvbmZpZyc7XG5pbXBvcnQgeyB1c2VMb2NhbFN0b3JhZ2UgfSBmcm9tICdzcmMvY29udGV4dHMvbG9jYWxTdG9yYWdlQ29udGV4dCc7XG5pbXBvcnQgeyBvcmdBbmFseXRpY3NHb29nbGVBbmFseXRpY3NDb25maWdBdG9tIH0gZnJvbSAnc3JjL2F0b21zL29yZy9vcmdBbmFseXRpY3NDb25maWcnO1xuaW1wb3J0IHsgdXNlcklkQXRvbSB9IGZyb20gJ3NyYy9hdG9tcy9hcHAnO1xuaW1wb3J0IHsgdXNlRW52aXZlQ29uZmlnIH0gZnJvbSAnc3JjL2NvbnRleHRzL2Vudml2ZUNvbmZpZ0NvbnRleHQnO1xuaW1wb3J0IHsgdXNlRmVhdHVyZUZsYWdTZXJ2aWNlIH0gZnJvbSAnc3JjL2NvbnRleHRzL2ZlYXR1cmVGbGFnU2VydmljZUNvbnRleHQvZmVhdHVyZUZsYWdTZXJ2aWNlQ29udGV4dCc7XG5pbXBvcnQge1xuICBBbXBsaXR1ZGVTZXJ2aWNlLFxuICBFbnZpdmVNZXRyaWNzRXZlbnROYW1lLFxuICBTcGlmZnlNZXRyaWNzRXZlbnROYW1lLFxuICBUcmFja0V2ZW50UGFyYW1zLFxufSBmcm9tICdzcmMvc2VydmljZXMvYW1wbGl0dWRlU2VydmljZS9hbXBsaXR1ZGVTZXJ2aWNlJztcblxuZXhwb3J0IHsgRW52aXZlTWV0cmljc0V2ZW50TmFtZSwgU3BpZmZ5TWV0cmljc0V2ZW50TmFtZSB9O1xuXG5pbnRlcmZhY2UgQW1wbGl0dWRlQ29udGV4dFR5cGUge1xuICB0cmFja0V2ZW50OiAocGFyYW1zOiBUcmFja0V2ZW50UGFyYW1zKSA9PiBQcm9taXNlPHZvaWQ+O1xuICBpc1JlYWR5OiBib29sZWFuO1xuICBzZXRTdXBwbGVtZW50YWxEZWZhdWx0UHJvcHM6IChwcm9wczogUmVjb3JkPHN0cmluZywgdW5rbm93bj4pID0+IHZvaWQ7XG59XG5cbmNvbnN0IG5vT3BBbXBsaXR1ZGVDb250ZXh0OiBBbXBsaXR1ZGVDb250ZXh0VHlwZSA9IHtcbiAgdHJhY2tFdmVudDogYXN5bmMgKCkgPT4ge30sXG4gIGlzUmVhZHk6IGZhbHNlLFxuICBzZXRTdXBwbGVtZW50YWxEZWZhdWx0UHJvcHM6ICgpID0+IHt9LFxufTtcblxuY29uc3QgQW1wbGl0dWRlQ29udGV4dCA9IGNyZWF0ZUNvbnRleHQ8QW1wbGl0dWRlQ29udGV4dFR5cGU+KG5vT3BBbXBsaXR1ZGVDb250ZXh0KTtcblxuZXhwb3J0IGNvbnN0IEFtcGxpdHVkZVByb3ZpZGVyOiBSZWFjdC5GQzx7XG4gIGV4dGVybmFsQW1wbGl0dWRlU2VydmljZT86IEFtcGxpdHVkZVNlcnZpY2U7XG4gIGNoaWxkcmVuOiBSZWFjdC5SZWFjdE5vZGU7XG59PiA9ICh7IGV4dGVybmFsQW1wbGl0dWRlU2VydmljZSwgY2hpbGRyZW4gfSkgPT4ge1xuICBjb25zdCB1c2VySWQgPSB1c2VBdG9tVmFsdWUodXNlcklkQXRvbSk7XG4gIGNvbnN0IGFtcGxpdHVkZUFwaUtleSA9IHVzZUF0b21WYWx1ZShhbXBsaXR1ZGVBcGlLZXlBdG9tKTtcbiAgY29uc3QgZGF0YVJlc2lkZW5jeSA9IHVzZUF0b21WYWx1ZShkYXRhUmVzaWRlbmN5QXRvbSk7XG4gIGNvbnN0IG9yZ0dhQ29uZmlnID0gdXNlQXRvbVZhbHVlKG9yZ0FuYWx5dGljc0dvb2dsZUFuYWx5dGljc0NvbmZpZ0F0b20pO1xuICBjb25zdCBlbnYgPSB1c2VBdG9tVmFsdWUoZW52QXRvbSk7XG4gIGNvbnN0IGNvbnRleHRTb3VyY2UgPSB1c2VBdG9tVmFsdWUoY29udGV4dFNvdXJjZUF0b20pO1xuICBjb25zdCB7IGdldEl0ZW0gfSA9IHVzZUxvY2FsU3RvcmFnZSgpO1xuICBjb25zdCB7XG4gICAgZmVhdHVyZU92ZXJyaWRlcyxcbiAgICB2YXJpYW50VXJsT3ZlcnJpZGUsXG4gICAgdmFyaWFudEluZm9PdmVycmlkZSxcbiAgICBzaG93LFxuICAgIGVudml2ZU9uLFxuICAgIG9yZ0lkLFxuICAgIG9yZ1Nob3J0TmFtZSxcbiAgICBmZWF0dXJlR2F0ZXMsXG4gIH0gPSB1c2VFbnZpdmVDb25maWcoKTtcblxuICBjb25zdCB7IGZlYXR1cmVGbGFnU2VydmljZSB9ID0gdXNlRmVhdHVyZUZsYWdTZXJ2aWNlKCk7XG5cbiAgY29uc3QgW3NlcnZpY2UsIHNldFNlcnZpY2VdID0gdXNlU3RhdGU8QW1wbGl0dWRlU2VydmljZSB8IG51bGw+KG51bGwpO1xuXG4gIGNvbnN0IGlzUmVhZHkgPSBCb29sZWFuKHVzZXJJZCAmJiBzZXJ2aWNlICYmIHNlcnZpY2UuaXNSZWFkeSk7XG5cbiAgLy8gQ3JlYXRlIHNlcnZpY2UgaW5zdGFuY2Ugd2hlbiBkZXBlbmRlbmNpZXMgYXJlIHJlYWR5XG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgaWYgKGV4dGVybmFsQW1wbGl0dWRlU2VydmljZSAhPT0gdW5kZWZpbmVkKSB7XG4gICAgICBzZXRTZXJ2aWNlKGV4dGVybmFsQW1wbGl0dWRlU2VydmljZSk7XG4gICAgICByZXR1cm47XG4gICAgfVxuICAgIGlmICh1c2VySWQgJiYgYW1wbGl0dWRlQXBpS2V5ICYmIGRhdGFSZXNpZGVuY3kgJiYgZmVhdHVyZUZsYWdTZXJ2aWNlKSB7XG4gICAgICBjb25zdCBhbXBsaXR1ZGVTZXJ2aWNlID0gbmV3IEFtcGxpdHVkZVNlcnZpY2Uoe1xuICAgICAgICB1c2VySWQsXG4gICAgICAgIGFtcGxpdHVkZUFwaUtleSxcbiAgICAgICAgZGF0YVJlc2lkZW5jeSxcbiAgICAgICAgZW52OiBlbnYgfHwgJycsXG4gICAgICAgIGNvbnRleHRTb3VyY2U6IGNvbnRleHRTb3VyY2UgfHwgJycsXG4gICAgICAgIG9yZ1Nob3J0TmFtZTogb3JnU2hvcnROYW1lIHx8ICcnLFxuICAgICAgICBvcmdJZDogb3JnSWQgfHwgJycsXG4gICAgICAgIGZlYXR1cmVGbGFnU2VydmljZSxcbiAgICAgICAgb3JnR2FDb25maWcsXG4gICAgICAgIHNob3c6IHNob3cgPz8gZmFsc2UsXG4gICAgICAgIGVudml2ZU9uOiBlbnZpdmVPbiA/PyBmYWxzZSxcbiAgICAgICAgZ2V0TG9jYWxTdG9yYWdlSXRlbTogZ2V0SXRlbSxcbiAgICAgIH0pO1xuICAgICAgc2V0U2VydmljZShhbXBsaXR1ZGVTZXJ2aWNlKTtcbiAgICB9IGVsc2Uge1xuICAgICAgc2V0U2VydmljZShudWxsKTtcbiAgICB9XG4gIH0sIFtcbiAgICB1c2VySWQsXG4gICAgYW1wbGl0dWRlQXBpS2V5LFxuICAgIGRhdGFSZXNpZGVuY3ksXG4gICAgZW52LFxuICAgIGNvbnRleHRTb3VyY2UsXG4gICAgb3JnU2hvcnROYW1lLFxuICAgIGZlYXR1cmVGbGFnU2VydmljZSxcbiAgICBvcmdHYUNvbmZpZyxcbiAgICBmZWF0dXJlT3ZlcnJpZGVzLFxuICAgIHZhcmlhbnRVcmxPdmVycmlkZSxcbiAgICB2YXJpYW50SW5mb092ZXJyaWRlLFxuICAgIHNob3csXG4gICAgZW52aXZlT24sXG4gICAgZmVhdHVyZUdhdGVzLFxuICAgIGdldEl0ZW0sXG4gICAgZXh0ZXJuYWxBbXBsaXR1ZGVTZXJ2aWNlLFxuICAgIG9yZ0lkLFxuICBdKTtcblxuICBjb25zdCB2YWx1ZSA9IHVzZU1lbW8oXG4gICAgKCkgPT4gKHtcbiAgICAgIHRyYWNrRXZlbnQ6IGFzeW5jIChwYXJhbXM6IFRyYWNrRXZlbnRQYXJhbXMpOiBQcm9taXNlPHZvaWQ+ID0+IHtcbiAgICAgICAgaWYgKHNlcnZpY2UpIHtcbiAgICAgICAgICBhd2FpdCBzZXJ2aWNlLnRyYWNrRXZlbnQocGFyYW1zKTtcbiAgICAgICAgfVxuICAgICAgfSxcbiAgICAgIGlzUmVhZHksXG4gICAgICBzZXRTdXBwbGVtZW50YWxEZWZhdWx0UHJvcHM6IChwcm9wczogUmVjb3JkPHN0cmluZywgdW5rbm93bj4pID0+IHtcbiAgICAgICAgaWYgKHNlcnZpY2UpIHtcbiAgICAgICAgICBzZXJ2aWNlLnNldFN1cHBsZW1lbnRhbERlZmF1bHRQcm9wcyhwcm9wcyk7XG4gICAgICAgIH1cbiAgICAgIH0sXG4gICAgfSksXG4gICAgW3NlcnZpY2UsIGlzUmVhZHldLFxuICApO1xuXG4gIHJldHVybiAoXG4gICAgPEFtcGxpdHVkZUNvbnRleHQuUHJvdmlkZXIgdmFsdWU9e2lzUmVhZHkgPyB2YWx1ZSA6IG5vT3BBbXBsaXR1ZGVDb250ZXh0fT5cbiAgICAgIHtjaGlsZHJlbn1cbiAgICA8L0FtcGxpdHVkZUNvbnRleHQuUHJvdmlkZXI+XG4gICk7XG59O1xuXG5leHBvcnQgY29uc3QgdXNlQW1wbGl0dWRlID0gKCkgPT4ge1xuICByZXR1cm4gdXNlQ29udGV4dChBbXBsaXR1ZGVDb250ZXh0KTtcbn07XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7OztBQTRCQSxNQUFNQSx1QkFBNkM7Q0FDakQsWUFBWSxZQUFZO0NBQ3hCLFNBQVM7Q0FDVCxtQ0FBbUM7Q0FDcEM7QUFFRCxNQUFNLG1CQUFtQixjQUFvQyxxQkFBcUI7QUFFbEYsTUFBYUMscUJBR1AsRUFBRSwwQkFBMEIsZUFBZTtDQUMvQyxNQUFNLFNBQVMsYUFBYSxXQUFXO0NBQ3ZDLE1BQU0sa0JBQWtCLGFBQWEsb0JBQW9CO0NBQ3pELE1BQU0sZ0JBQWdCLGFBQWEsa0JBQWtCO0NBQ3JELE1BQU0sY0FBYyxhQUFhLHNDQUFzQztDQUN2RSxNQUFNLE1BQU0sYUFBYSxRQUFRO0NBQ2pDLE1BQU0sZ0JBQWdCLGFBQWEsa0JBQWtCO0NBQ3JELE1BQU0sRUFBRSxZQUFZLGlCQUFpQjtDQUNyQyxNQUFNLEVBQ0osa0JBQ0Esb0JBQ0EscUJBQ0EsTUFDQSxVQUNBLE9BQ0EsY0FDQSxpQkFDRSxpQkFBaUI7Q0FFckIsTUFBTSxFQUFFLHVCQUF1Qix1QkFBdUI7Q0FFdEQsTUFBTSxDQUFDLFNBQVMsY0FBYyxTQUFrQyxLQUFLO0NBRXJFLE1BQU0sVUFBVSxRQUFRLFVBQVUsV0FBVyxRQUFRLFFBQVE7QUFHN0QsaUJBQWdCO0FBQ2QsTUFBSSw2QkFBNkIsUUFBVztBQUMxQyxjQUFXLHlCQUF5QjtBQUNwQzs7QUFFRixNQUFJLFVBQVUsbUJBQW1CLGlCQUFpQixtQkFlaEQsWUFkeUIsSUFBSSxpQkFBaUI7R0FDNUM7R0FDQTtHQUNBO0dBQ0EsS0FBSyxPQUFPO0dBQ1osZUFBZSxpQkFBaUI7R0FDaEMsY0FBYyxnQkFBZ0I7R0FDOUIsT0FBTyxTQUFTO0dBQ2hCO0dBQ0E7R0FDQSxNQUFNLFFBQVE7R0FDZCxVQUFVLFlBQVk7R0FDdEIscUJBQXFCO0dBQ3RCLENBQUMsQ0FDMEI7TUFFNUIsWUFBVyxLQUFLO0lBRWpCO0VBQ0Q7RUFDQTtFQUNBO0VBQ0E7RUFDQTtFQUNBO0VBQ0E7RUFDQTtFQUNBO0VBQ0E7RUFDQTtFQUNBO0VBQ0E7RUFDQTtFQUNBO0VBQ0E7RUFDQTtFQUNELENBQUM7Q0FFRixNQUFNLFFBQVEsZUFDTDtFQUNMLFlBQVksT0FBTyxXQUE0QztBQUM3RCxPQUFJLFFBQ0YsT0FBTSxRQUFRLFdBQVcsT0FBTzs7RUFHcEM7RUFDQSw4QkFBOEIsVUFBbUM7QUFDL0QsT0FBSSxRQUNGLFNBQVEsNEJBQTRCLE1BQU07O0VBRy9DLEdBQ0QsQ0FBQyxTQUFTLFFBQVEsQ0FDbkI7QUFFRCxRQUNFLG9CQUFDLGlCQUFpQjtFQUFTLE9BQU8sVUFBVSxRQUFRO0VBQ2pEO0dBQ3lCOztBQUloQyxNQUFhLHFCQUFxQjtBQUNoQyxRQUFPLFdBQVcsaUJBQWlCIn0=
|
|
@@ -7,13 +7,13 @@ require('../enviveConfigContext/index.cjs');
|
|
|
7
7
|
const require_featureFlagServiceContext = require('../featureFlagServiceContext/featureFlagServiceContext.cjs');
|
|
8
8
|
const require_amplitudeContext = require('../amplitudeContext/amplitudeContext.cjs');
|
|
9
9
|
require('../amplitudeContext/index.cjs');
|
|
10
|
+
const require_enviveConfigService = require('../../services/enviveConfigService/enviveConfigService.cjs');
|
|
11
|
+
const require_userIdentityService = require('../../services/userIdentityService/userIdentityService.cjs');
|
|
12
|
+
require('../../services/userIdentityService/index.cjs');
|
|
10
13
|
const require_graphqlContext = require('../graphqlContext/graphqlContext.cjs');
|
|
11
14
|
const require_newOrgConfigContext = require('../newOrgConfigContext/newOrgConfigContext.cjs');
|
|
12
15
|
const require_enviveCssContext = require('../enviveCssContext/enviveCssContext.cjs');
|
|
13
16
|
require('../enviveCssContext/index.cjs');
|
|
14
|
-
const require_enviveConfigService = require('../../services/enviveConfigService/enviveConfigService.cjs');
|
|
15
|
-
const require_userIdentityService = require('../../services/userIdentityService/userIdentityService.cjs');
|
|
16
|
-
require('../../services/userIdentityService/index.cjs');
|
|
17
17
|
require('../featureFlagServiceContext/index.cjs');
|
|
18
18
|
require('../graphqlContext/index.cjs');
|
|
19
19
|
require('../newOrgConfigContext/index.cjs');
|
|
@@ -6,13 +6,13 @@ import "../enviveConfigContext/index.js";
|
|
|
6
6
|
import { FeatureFlagService, FeatureFlagServiceProvider } from "../featureFlagServiceContext/featureFlagServiceContext.js";
|
|
7
7
|
import { AmplitudeProvider } from "../amplitudeContext/amplitudeContext.js";
|
|
8
8
|
import "../amplitudeContext/index.js";
|
|
9
|
+
import { EnviveConfigService } from "../../services/enviveConfigService/enviveConfigService.js";
|
|
10
|
+
import { UserIdentityService } from "../../services/userIdentityService/userIdentityService.js";
|
|
11
|
+
import "../../services/userIdentityService/index.js";
|
|
9
12
|
import { GraphQLProvider } from "../graphqlContext/graphqlContext.js";
|
|
10
13
|
import { NewOrgConfigProvider } from "../newOrgConfigContext/newOrgConfigContext.js";
|
|
11
14
|
import { EnviveCssProvider } from "../enviveCssContext/enviveCssContext.js";
|
|
12
15
|
import "../enviveCssContext/index.js";
|
|
13
|
-
import { EnviveConfigService } from "../../services/enviveConfigService/enviveConfigService.js";
|
|
14
|
-
import { UserIdentityService } from "../../services/userIdentityService/userIdentityService.js";
|
|
15
|
-
import "../../services/userIdentityService/index.js";
|
|
16
16
|
import "../featureFlagServiceContext/index.js";
|
|
17
17
|
import "../graphqlContext/index.js";
|
|
18
18
|
import "../newOrgConfigContext/index.js";
|
|
@@ -5,4 +5,4 @@ declare enum EnviveAgent {
|
|
|
5
5
|
}
|
|
6
6
|
//#endregion
|
|
7
7
|
export { EnviveAgent };
|
|
8
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
8
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuZC5jdHMiLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2NvbnRleHRzL2Vudml2ZUNvbnRleHQvdHlwZXMuZC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZGVjbGFyZSBlbnVtIEVudml2ZUFnZW50IHtcbiAgICBTYWxlc0FnZW50ID0gXCJzYWxlc1wiLFxuICAgIFNlYXJjaEFnZW50ID0gXCJzZWFyY2hcIlxufVxuIl0sIm1hcHBpbmdzIjoiO0FBQUEsSUFBVyxjQUFjLENBQUMsR0FBRyJ9
|
|
@@ -2,8 +2,11 @@ const require_rolldown_runtime = require('../../_virtual/rolldown_runtime.cjs');
|
|
|
2
2
|
const require_logger = require('../../application/logging/logger.cjs');
|
|
3
3
|
const require_variantInfo = require('../../application/models/variantInfo/variantInfo.cjs');
|
|
4
4
|
require('../../application/models/index.cjs');
|
|
5
|
+
const require_eventNames = require('../../services/amplitudeService/eventNames.cjs');
|
|
5
6
|
const require_variant = require('../../atoms/app/variant.cjs');
|
|
6
7
|
const require_application_commerce_api = require('../../application/commerce-api.cjs');
|
|
8
|
+
const require_amplitudeContext = require('../amplitudeContext/amplitudeContext.cjs');
|
|
9
|
+
require('../amplitudeContext/index.cjs');
|
|
7
10
|
const require_mapping = require('./mapping.cjs');
|
|
8
11
|
let __spiffy_ai_commerce_api_client = require("@spiffy-ai/commerce-api-client");
|
|
9
12
|
let react = require("react");
|
|
@@ -108,6 +111,60 @@ const PageProvider = ({ children, previewMode = false, onUrlResolverNotReady })
|
|
|
108
111
|
previewMode,
|
|
109
112
|
onUrlResolverNotReady
|
|
110
113
|
]);
|
|
114
|
+
const { trackEvent } = require_amplitudeContext.useAmplitude();
|
|
115
|
+
const resolvedVariantInfo = (0, jotai.useAtomValue)(require_variant.variantInfoAtom);
|
|
116
|
+
const hasParsedVariantInfo = (0, jotai.useAtomValue)(require_variant.hasParsedVariantInfoAtom);
|
|
117
|
+
const pageViewedFired = (0, react.useRef)(false);
|
|
118
|
+
(0, react.useEffect)(() => {
|
|
119
|
+
if (pageViewedFired.current || isLoading || !hasParsedVariantInfo || !variantInfo) return;
|
|
120
|
+
let pageType;
|
|
121
|
+
let pageId;
|
|
122
|
+
switch (variantInfo.variantType) {
|
|
123
|
+
case require_variantInfo.VariantTypeEnum.Pdp:
|
|
124
|
+
pageType = "pdp";
|
|
125
|
+
pageId = variantInfo.productId;
|
|
126
|
+
break;
|
|
127
|
+
case require_variantInfo.VariantTypeEnum.Plp:
|
|
128
|
+
pageType = "plp";
|
|
129
|
+
pageId = variantInfo.plpId;
|
|
130
|
+
break;
|
|
131
|
+
case require_variantInfo.VariantTypeEnum.Home:
|
|
132
|
+
pageType = "homepage";
|
|
133
|
+
pageId = variantInfo.url;
|
|
134
|
+
break;
|
|
135
|
+
case require_variantInfo.VariantTypeEnum.Other:
|
|
136
|
+
pageType = "other";
|
|
137
|
+
pageId = variantInfo.url;
|
|
138
|
+
break;
|
|
139
|
+
case require_variantInfo.VariantTypeEnum.PageVisit:
|
|
140
|
+
pageType = "other";
|
|
141
|
+
pageId = variantInfo.url;
|
|
142
|
+
break;
|
|
143
|
+
case require_variantInfo.VariantTypeEnum.FullPageSalesAgent:
|
|
144
|
+
pageType = "full_page_sales_agent";
|
|
145
|
+
pageId = variantInfo.url;
|
|
146
|
+
break;
|
|
147
|
+
default: return;
|
|
148
|
+
}
|
|
149
|
+
pageViewedFired.current = true;
|
|
150
|
+
trackEvent({
|
|
151
|
+
eventName: require_eventNames.EnviveMetricsEventName.PageViewed,
|
|
152
|
+
eventProps: {
|
|
153
|
+
"context.page_type": pageType,
|
|
154
|
+
"context.page_id": pageId,
|
|
155
|
+
"context.supported": isSupported,
|
|
156
|
+
"context.ready": isSupported,
|
|
157
|
+
"context.page_variant_id": resolvedVariantInfo.variantId
|
|
158
|
+
}
|
|
159
|
+
});
|
|
160
|
+
}, [
|
|
161
|
+
isLoading,
|
|
162
|
+
isSupported,
|
|
163
|
+
hasParsedVariantInfo,
|
|
164
|
+
variantInfo,
|
|
165
|
+
resolvedVariantInfo,
|
|
166
|
+
trackEvent
|
|
167
|
+
]);
|
|
111
168
|
const setPageUrlStable = (0, react.useCallback)((url) => {
|
|
112
169
|
setPageUrl(url);
|
|
113
170
|
}, []);
|
|
@@ -140,4 +197,4 @@ const usePage = () => {
|
|
|
140
197
|
//#endregion
|
|
141
198
|
exports.PageProvider = PageProvider;
|
|
142
199
|
exports.usePage = usePage;
|
|
143
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"pageContext.cjs","names":["Logger","PageProvider: React.FC<{\n  children: ReactNode;\n  previewMode: boolean;\n  /** When URL resolver returns `ready: false`, invoked for extension/injection failure reporting. */\n  onUrlResolverNotReady?: (error: Error) => Promise<unknown> | void;\n}>","urlResolverAtom","pageVariantInfoAtom","pageUserEventAtom","UserEventCategory","PageVisitCategory","VariantTypeEnum","mapUrlResolverResponseToVariantInfo","mapApiUserEventToUserEvent","CommerceApiClient"],"sources":["../../../src/contexts/pageContext/pageContext.tsx"],"sourcesContent":["import {\n  ReactNode,\n  createContext,\n  useCallback,\n  useContext,\n  useEffect,\n  useMemo,\n  useRef,\n  useState,\n} from 'react';\nimport {\n  UrlResolverResponse,\n  pageUserEventAtom,\n  pageVariantInfoAtom,\n  urlResolverAtom,\n} from 'src/atoms/app/variant';\nimport { useAtom } from 'jotai';\nimport CommerceApiClient from 'src/application/commerce-api';\nimport Logger from 'src/application/logging/logger';\nimport { PageVisitCategory, UserEventCategory } from '@spiffy-ai/commerce-api-client';\nimport { VariantTypeEnum } from 'src/application/models';\nimport { mapApiUserEventToUserEvent, mapUrlResolverResponseToVariantInfo } from './mapping';\nimport { PageDetails } from './types';\n\nconst logger = new Logger('pageContext');\n\nconst PageContext = createContext<\n  | (PageDetails & {\n      isLoading: boolean;\n      isSupported: boolean;\n      setPageUrl: (url: string) => void;\n    })\n  | undefined\n>(undefined);\n\nexport const PageProvider: React.FC<{\n  children: ReactNode;\n  previewMode: boolean;\n  /** When URL resolver returns `ready: false`, invoked for extension/injection failure reporting. */\n  onUrlResolverNotReady?: (error: Error) => Promise<unknown> | void;\n}> = ({ children, previewMode = false, onUrlResolverNotReady }) => {\n  const [pageUrl, setPageUrl] = useState<string | undefined>(undefined);\n  const [urlResolverResponse, setUrlResolverResponse] = useAtom(urlResolverAtom);\n  const [isLoading, setIsLoading] = useState(false);\n  const [variantInfo, setVariantInfo] = useAtom(pageVariantInfoAtom);\n  const [userEvent, setUserEvent] = useAtom(pageUserEventAtom);\n  const [isSupported, setIsSupported] = useState(false);\n  const lastNotReadyUrlRef = useRef<string | null>(null);\n\n  useEffect(() => {\n    setPageUrl(window.location.href);\n  }, []);\n\n  // Auto-initialize atoms for preview mode\n  useEffect(() => {\n    if (previewMode && !userEvent && !variantInfo) {\n      const url = typeof window !== 'undefined' ? window.location.href : '';\n      setUserEvent({\n        event_id: 'preview-user-event',\n        created_at: new Date().toISOString(),\n        category: UserEventCategory.PageVisit,\n        attributes: {\n          page_visit_category: PageVisitCategory.Other,\n          url,\n        },\n      } as any);\n\n      setVariantInfo({\n        variantType: VariantTypeEnum.PageVisit,\n        url,\n      });\n    }\n  }, [previewMode, userEvent, variantInfo, setUserEvent, setVariantInfo]);\n\n  const setVariantFromUrlResolver = useCallback(\n    (url: string, response: UrlResolverResponse) => {\n      if (response.ready) {\n        const newVariantInfo = mapUrlResolverResponseToVariantInfo(url, response);\n        const newUserEvent = mapApiUserEventToUserEvent(response.user_event ?? undefined);\n        logger.logDebug('setting variant info and user event', { newVariantInfo, newUserEvent });\n        setVariantInfo(newVariantInfo);\n        setUserEvent(newUserEvent);\n      } else {\n        setUserEvent(undefined);\n        setVariantInfo(undefined);\n        logger.logDebug('set variant info and user event to undefined', { variantInfo, userEvent });\n      }\n    },\n    [setVariantInfo, setUserEvent],\n  );\n\n  useEffect(() => {\n    const resolvePageUrl = async () => {\n      setIsLoading(true);\n      try {\n        if (!pageUrl) {\n          setIsLoading(false);\n          return;\n        }\n\n        // If in preview mode or atoms are already set (e.g., by storybook), skip API call\n        if (previewMode || userEvent || variantInfo) {\n          setIsLoading(false);\n          return;\n        }\n\n        const cleansedUrl = pageUrl.toLowerCase().trim();\n        const response =\n          urlResolverResponse[cleansedUrl] ??\n          ((await CommerceApiClient.resolveUrl(cleansedUrl)) as UrlResolverResponse);\n        setVariantFromUrlResolver(cleansedUrl, response);\n        setIsLoading(false);\n        setIsSupported(response.ready);\n\n        if (response.ready) {\n          lastNotReadyUrlRef.current = null;\n        } else if (onUrlResolverNotReady && lastNotReadyUrlRef.current !== cleansedUrl) {\n          lastNotReadyUrlRef.current = cleansedUrl;\n          const err = new Error(`URL resolver returned ready=false for ${cleansedUrl}`);\n          Promise.resolve(onUrlResolverNotReady(err)).catch(callbackError => {\n            logger.logDebug('onUrlResolverNotReady callback failed', callbackError);\n          });\n        }\n      } catch (e) {\n        setIsLoading(false);\n        logger.logError('Failed to resolve page URL', e, { pageUrl });\n      }\n    };\n    resolvePageUrl();\n  }, [\n    pageUrl,\n    urlResolverResponse,\n    setUrlResolverResponse,\n    setVariantFromUrlResolver,\n    userEvent,\n    variantInfo,\n    previewMode,\n    onUrlResolverNotReady,\n  ]);\n\n  const setPageUrlStable = useCallback((url: string) => {\n    setPageUrl(url);\n  }, []);\n\n  const value = useMemo(\n    () => ({\n      pageUrl,\n      variantInfo,\n      userEvent,\n      isLoading,\n      isSupported,\n      setPageUrl: setPageUrlStable,\n    }),\n    [pageUrl, userEvent, variantInfo, isLoading, isSupported, setPageUrlStable],\n  );\n\n  return <PageContext.Provider value={value}>{children}</PageContext.Provider>;\n};\n\nexport const usePage = () => {\n  const context = useContext(PageContext);\n  if (!context) {\n    throw new Error('usePage must be used within a PageProvider');\n  }\n  return context;\n};\n"],"mappings":";;;;;;;;;;;;;AAwBA,MAAM,SAAS,IAAIA,uBAAO,cAAc;AAExC,MAAM,uCAOJ,OAAU;AAEZ,MAAaC,gBAKP,EAAE,UAAU,cAAc,OAAO,4BAA4B;CACjE,MAAM,CAAC,SAAS,kCAA2C,OAAU;CACrE,MAAM,CAAC,qBAAqB,6CAAkCC,gCAAgB;CAC9E,MAAM,CAAC,WAAW,oCAAyB,MAAM;CACjD,MAAM,CAAC,aAAa,qCAA0BC,oCAAoB;CAClE,MAAM,CAAC,WAAW,mCAAwBC,kCAAkB;CAC5D,MAAM,CAAC,aAAa,sCAA2B,MAAM;CACrD,MAAM,uCAA2C,KAAK;AAEtD,4BAAgB;AACd,aAAW,OAAO,SAAS,KAAK;IAC/B,EAAE,CAAC;AAGN,4BAAgB;AACd,MAAI,eAAe,CAAC,aAAa,CAAC,aAAa;GAC7C,MAAM,MAAM,OAAO,WAAW,cAAc,OAAO,SAAS,OAAO;AACnE,gBAAa;IACX,UAAU;IACV,6BAAY,IAAI,MAAM,EAAC,aAAa;IACpC,UAAUC,kDAAkB;IAC5B,YAAY;KACV,qBAAqBC,kDAAkB;KACvC;KACD;IACF,CAAQ;AAET,kBAAe;IACb,aAAaC,oCAAgB;IAC7B;IACD,CAAC;;IAEH;EAAC;EAAa;EAAW;EAAa;EAAc;EAAe,CAAC;CAEvE,MAAM,oDACH,KAAa,aAAkC;AAC9C,MAAI,SAAS,OAAO;GAClB,MAAM,iBAAiBC,oDAAoC,KAAK,SAAS;GACzE,MAAM,eAAeC,2CAA2B,SAAS,cAAc,OAAU;AACjF,UAAO,SAAS,uCAAuC;IAAE;IAAgB;IAAc,CAAC;AACxF,kBAAe,eAAe;AAC9B,gBAAa,aAAa;SACrB;AACL,gBAAa,OAAU;AACvB,kBAAe,OAAU;AACzB,UAAO,SAAS,gDAAgD;IAAE;IAAa;IAAW,CAAC;;IAG/F,CAAC,gBAAgB,aAAa,CAC/B;AAED,4BAAgB;EACd,MAAM,iBAAiB,YAAY;AACjC,gBAAa,KAAK;AAClB,OAAI;AACF,QAAI,CAAC,SAAS;AACZ,kBAAa,MAAM;AACnB;;AAIF,QAAI,eAAe,aAAa,aAAa;AAC3C,kBAAa,MAAM;AACnB;;IAGF,MAAM,cAAc,QAAQ,aAAa,CAAC,MAAM;IAChD,MAAM,WACJ,oBAAoB,gBAClB,MAAMC,yCAAkB,WAAW,YAAY;AACnD,8BAA0B,aAAa,SAAS;AAChD,iBAAa,MAAM;AACnB,mBAAe,SAAS,MAAM;AAE9B,QAAI,SAAS,MACX,oBAAmB,UAAU;aACpB,yBAAyB,mBAAmB,YAAY,aAAa;AAC9E,wBAAmB,UAAU;KAC7B,MAAM,sBAAM,IAAI,MAAM,yCAAyC,cAAc;AAC7E,aAAQ,QAAQ,sBAAsB,IAAI,CAAC,CAAC,OAAM,kBAAiB;AACjE,aAAO,SAAS,yCAAyC,cAAc;OACvE;;YAEG,GAAG;AACV,iBAAa,MAAM;AACnB,WAAO,SAAS,8BAA8B,GAAG,EAAE,SAAS,CAAC;;;AAGjE,kBAAgB;IACf;EACD;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACD,CAAC;CAEF,MAAM,2CAAgC,QAAgB;AACpD,aAAW,IAAI;IACd,EAAE,CAAC;CAEN,MAAM,kCACG;EACL;EACA;EACA;EACA;EACA;EACA,YAAY;EACb,GACD;EAAC;EAAS;EAAW;EAAa;EAAW;EAAa;EAAiB,CAC5E;AAED,QAAO,2CAAC,YAAY;EAAgB;EAAQ;GAAgC;;AAG9E,MAAa,gBAAgB;CAC3B,MAAM,gCAAqB,YAAY;AACvC,KAAI,CAAC,QACH,OAAM,IAAI,MAAM,6CAA6C;AAE/D,QAAO"}
|
|
200
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"pageContext.cjs","names":["Logger","PageProvider: React.FC<{\n  children: ReactNode;\n  previewMode: boolean;\n  /** When URL resolver returns `ready: false`, invoked for extension/injection failure reporting. */\n  onUrlResolverNotReady?: (error: Error) => Promise<unknown> | void;\n}>","urlResolverAtom","pageVariantInfoAtom","pageUserEventAtom","UserEventCategory","PageVisitCategory","VariantTypeEnum","mapUrlResolverResponseToVariantInfo","mapApiUserEventToUserEvent","CommerceApiClient","useAmplitude","variantInfoAtom","hasParsedVariantInfoAtom","pageType: string","pageId: string","EnviveMetricsEventName"],"sources":["../../../src/contexts/pageContext/pageContext.tsx"],"sourcesContent":["import {\n  ReactNode,\n  createContext,\n  useCallback,\n  useContext,\n  useEffect,\n  useMemo,\n  useRef,\n  useState,\n} from 'react';\nimport {\n  UrlResolverResponse,\n  hasParsedVariantInfoAtom,\n  pageUserEventAtom,\n  pageVariantInfoAtom,\n  urlResolverAtom,\n  variantInfoAtom,\n} from 'src/atoms/app/variant';\nimport { useAtom, useAtomValue } from 'jotai';\nimport CommerceApiClient from 'src/application/commerce-api';\nimport Logger from 'src/application/logging/logger';\nimport { PageVisitCategory, UserEventCategory } from '@spiffy-ai/commerce-api-client';\nimport { VariantTypeEnum } from 'src/application/models';\nimport { EnviveMetricsEventName, useAmplitude } from 'src/contexts/amplitudeContext';\nimport { mapApiUserEventToUserEvent, mapUrlResolverResponseToVariantInfo } from './mapping';\nimport { PageDetails } from './types';\n\nconst logger = new Logger('pageContext');\n\nconst PageContext = createContext<\n  | (PageDetails & {\n      isLoading: boolean;\n      isSupported: boolean;\n      setPageUrl: (url: string) => void;\n    })\n  | undefined\n>(undefined);\n\nexport const PageProvider: React.FC<{\n  children: ReactNode;\n  previewMode: boolean;\n  /** When URL resolver returns `ready: false`, invoked for extension/injection failure reporting. */\n  onUrlResolverNotReady?: (error: Error) => Promise<unknown> | void;\n}> = ({ children, previewMode = false, onUrlResolverNotReady }) => {\n  const [pageUrl, setPageUrl] = useState<string | undefined>(undefined);\n  const [urlResolverResponse, setUrlResolverResponse] = useAtom(urlResolverAtom);\n  const [isLoading, setIsLoading] = useState(false);\n  const [variantInfo, setVariantInfo] = useAtom(pageVariantInfoAtom);\n  const [userEvent, setUserEvent] = useAtom(pageUserEventAtom);\n  const [isSupported, setIsSupported] = useState(false);\n  const lastNotReadyUrlRef = useRef<string | null>(null);\n\n  useEffect(() => {\n    setPageUrl(window.location.href);\n  }, []);\n\n  // Auto-initialize atoms for preview mode\n  useEffect(() => {\n    if (previewMode && !userEvent && !variantInfo) {\n      const url = typeof window !== 'undefined' ? window.location.href : '';\n      setUserEvent({\n        event_id: 'preview-user-event',\n        created_at: new Date().toISOString(),\n        category: UserEventCategory.PageVisit,\n        attributes: {\n          page_visit_category: PageVisitCategory.Other,\n          url,\n        },\n      } as any);\n\n      setVariantInfo({\n        variantType: VariantTypeEnum.PageVisit,\n        url,\n      });\n    }\n  }, [previewMode, userEvent, variantInfo, setUserEvent, setVariantInfo]);\n\n  const setVariantFromUrlResolver = useCallback(\n    (url: string, response: UrlResolverResponse) => {\n      if (response.ready) {\n        const newVariantInfo = mapUrlResolverResponseToVariantInfo(url, response);\n        const newUserEvent = mapApiUserEventToUserEvent(response.user_event ?? undefined);\n        logger.logDebug('setting variant info and user event', { newVariantInfo, newUserEvent });\n        setVariantInfo(newVariantInfo);\n        setUserEvent(newUserEvent);\n      } else {\n        setUserEvent(undefined);\n        setVariantInfo(undefined);\n        logger.logDebug('set variant info and user event to undefined', { variantInfo, userEvent });\n      }\n    },\n    [setVariantInfo, setUserEvent],\n  );\n\n  useEffect(() => {\n    const resolvePageUrl = async () => {\n      setIsLoading(true);\n      try {\n        if (!pageUrl) {\n          setIsLoading(false);\n          return;\n        }\n\n        // If in preview mode or atoms are already set (e.g., by storybook), skip API call\n        if (previewMode || userEvent || variantInfo) {\n          setIsLoading(false);\n          return;\n        }\n\n        const cleansedUrl = pageUrl.toLowerCase().trim();\n        const response =\n          urlResolverResponse[cleansedUrl] ??\n          ((await CommerceApiClient.resolveUrl(cleansedUrl)) as UrlResolverResponse);\n        setVariantFromUrlResolver(cleansedUrl, response);\n        setIsLoading(false);\n        setIsSupported(response.ready);\n\n        if (response.ready) {\n          lastNotReadyUrlRef.current = null;\n        } else if (onUrlResolverNotReady && lastNotReadyUrlRef.current !== cleansedUrl) {\n          lastNotReadyUrlRef.current = cleansedUrl;\n          const err = new Error(`URL resolver returned ready=false for ${cleansedUrl}`);\n          Promise.resolve(onUrlResolverNotReady(err)).catch(callbackError => {\n            logger.logDebug('onUrlResolverNotReady callback failed', callbackError);\n          });\n        }\n      } catch (e) {\n        setIsLoading(false);\n        logger.logError('Failed to resolve page URL', e, { pageUrl });\n      }\n    };\n    resolvePageUrl();\n  }, [\n    pageUrl,\n    urlResolverResponse,\n    setUrlResolverResponse,\n    setVariantFromUrlResolver,\n    userEvent,\n    variantInfo,\n    previewMode,\n    onUrlResolverNotReady,\n  ]);\n\n  const { trackEvent } = useAmplitude();\n  const resolvedVariantInfo = useAtomValue(variantInfoAtom);\n  const hasParsedVariantInfo = useAtomValue(hasParsedVariantInfoAtom);\n  const pageViewedFired = useRef(false);\n\n  useEffect(() => {\n    if (pageViewedFired.current || isLoading || !hasParsedVariantInfo || !variantInfo) {\n      return;\n    }\n\n    let pageType: string;\n    let pageId: string;\n\n    switch (variantInfo.variantType) {\n      case VariantTypeEnum.Pdp:\n        pageType = 'pdp';\n        pageId = variantInfo.productId;\n        break;\n      case VariantTypeEnum.Plp:\n        pageType = 'plp';\n        pageId = variantInfo.plpId;\n        break;\n      case VariantTypeEnum.Home:\n        pageType = 'homepage';\n        pageId = variantInfo.url;\n        break;\n      case VariantTypeEnum.Other:\n        pageType = 'other';\n        pageId = variantInfo.url;\n        break;\n      case VariantTypeEnum.PageVisit:\n        pageType = 'other';\n        pageId = variantInfo.url;\n        break;\n      case VariantTypeEnum.FullPageSalesAgent:\n        pageType = 'full_page_sales_agent';\n        pageId = variantInfo.url;\n        break;\n      default:\n        return;\n    }\n\n    pageViewedFired.current = true;\n\n    trackEvent({\n      eventName: EnviveMetricsEventName.PageViewed,\n      eventProps: {\n        'context.page_type': pageType,\n        'context.page_id': pageId,\n        'context.supported': isSupported,\n        'context.ready': isSupported,\n        'context.page_variant_id': resolvedVariantInfo.variantId,\n      },\n    });\n  }, [isLoading, isSupported, hasParsedVariantInfo, variantInfo, resolvedVariantInfo, trackEvent]);\n\n  const setPageUrlStable = useCallback((url: string) => {\n    setPageUrl(url);\n  }, []);\n\n  const value = useMemo(\n    () => ({\n      pageUrl,\n      variantInfo,\n      userEvent,\n      isLoading,\n      isSupported,\n      setPageUrl: setPageUrlStable,\n    }),\n    [pageUrl, userEvent, variantInfo, isLoading, isSupported, setPageUrlStable],\n  );\n\n  return <PageContext.Provider value={value}>{children}</PageContext.Provider>;\n};\n\nexport const usePage = () => {\n  const context = useContext(PageContext);\n  if (!context) {\n    throw new Error('usePage must be used within a PageProvider');\n  }\n  return context;\n};\n"],"mappings":";;;;;;;;;;;;;;;;AA2BA,MAAM,SAAS,IAAIA,uBAAO,cAAc;AAExC,MAAM,uCAOJ,OAAU;AAEZ,MAAaC,gBAKP,EAAE,UAAU,cAAc,OAAO,4BAA4B;CACjE,MAAM,CAAC,SAAS,kCAA2C,OAAU;CACrE,MAAM,CAAC,qBAAqB,6CAAkCC,gCAAgB;CAC9E,MAAM,CAAC,WAAW,oCAAyB,MAAM;CACjD,MAAM,CAAC,aAAa,qCAA0BC,oCAAoB;CAClE,MAAM,CAAC,WAAW,mCAAwBC,kCAAkB;CAC5D,MAAM,CAAC,aAAa,sCAA2B,MAAM;CACrD,MAAM,uCAA2C,KAAK;AAEtD,4BAAgB;AACd,aAAW,OAAO,SAAS,KAAK;IAC/B,EAAE,CAAC;AAGN,4BAAgB;AACd,MAAI,eAAe,CAAC,aAAa,CAAC,aAAa;GAC7C,MAAM,MAAM,OAAO,WAAW,cAAc,OAAO,SAAS,OAAO;AACnE,gBAAa;IACX,UAAU;IACV,6BAAY,IAAI,MAAM,EAAC,aAAa;IACpC,UAAUC,kDAAkB;IAC5B,YAAY;KACV,qBAAqBC,kDAAkB;KACvC;KACD;IACF,CAAQ;AAET,kBAAe;IACb,aAAaC,oCAAgB;IAC7B;IACD,CAAC;;IAEH;EAAC;EAAa;EAAW;EAAa;EAAc;EAAe,CAAC;CAEvE,MAAM,oDACH,KAAa,aAAkC;AAC9C,MAAI,SAAS,OAAO;GAClB,MAAM,iBAAiBC,oDAAoC,KAAK,SAAS;GACzE,MAAM,eAAeC,2CAA2B,SAAS,cAAc,OAAU;AACjF,UAAO,SAAS,uCAAuC;IAAE;IAAgB;IAAc,CAAC;AACxF,kBAAe,eAAe;AAC9B,gBAAa,aAAa;SACrB;AACL,gBAAa,OAAU;AACvB,kBAAe,OAAU;AACzB,UAAO,SAAS,gDAAgD;IAAE;IAAa;IAAW,CAAC;;IAG/F,CAAC,gBAAgB,aAAa,CAC/B;AAED,4BAAgB;EACd,MAAM,iBAAiB,YAAY;AACjC,gBAAa,KAAK;AAClB,OAAI;AACF,QAAI,CAAC,SAAS;AACZ,kBAAa,MAAM;AACnB;;AAIF,QAAI,eAAe,aAAa,aAAa;AAC3C,kBAAa,MAAM;AACnB;;IAGF,MAAM,cAAc,QAAQ,aAAa,CAAC,MAAM;IAChD,MAAM,WACJ,oBAAoB,gBAClB,MAAMC,yCAAkB,WAAW,YAAY;AACnD,8BAA0B,aAAa,SAAS;AAChD,iBAAa,MAAM;AACnB,mBAAe,SAAS,MAAM;AAE9B,QAAI,SAAS,MACX,oBAAmB,UAAU;aACpB,yBAAyB,mBAAmB,YAAY,aAAa;AAC9E,wBAAmB,UAAU;KAC7B,MAAM,sBAAM,IAAI,MAAM,yCAAyC,cAAc;AAC7E,aAAQ,QAAQ,sBAAsB,IAAI,CAAC,CAAC,OAAM,kBAAiB;AACjE,aAAO,SAAS,yCAAyC,cAAc;OACvE;;YAEG,GAAG;AACV,iBAAa,MAAM;AACnB,WAAO,SAAS,8BAA8B,GAAG,EAAE,SAAS,CAAC;;;AAGjE,kBAAgB;IACf;EACD;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACD,CAAC;CAEF,MAAM,EAAE,eAAeC,uCAAc;CACrC,MAAM,8CAAmCC,gCAAgB;CACzD,MAAM,+CAAoCC,yCAAyB;CACnE,MAAM,oCAAyB,MAAM;AAErC,4BAAgB;AACd,MAAI,gBAAgB,WAAW,aAAa,CAAC,wBAAwB,CAAC,YACpE;EAGF,IAAIC;EACJ,IAAIC;AAEJ,UAAQ,YAAY,aAApB;GACE,KAAKR,oCAAgB;AACnB,eAAW;AACX,aAAS,YAAY;AACrB;GACF,KAAKA,oCAAgB;AACnB,eAAW;AACX,aAAS,YAAY;AACrB;GACF,KAAKA,oCAAgB;AACnB,eAAW;AACX,aAAS,YAAY;AACrB;GACF,KAAKA,oCAAgB;AACnB,eAAW;AACX,aAAS,YAAY;AACrB;GACF,KAAKA,oCAAgB;AACnB,eAAW;AACX,aAAS,YAAY;AACrB;GACF,KAAKA,oCAAgB;AACnB,eAAW;AACX,aAAS,YAAY;AACrB;GACF,QACE;;AAGJ,kBAAgB,UAAU;AAE1B,aAAW;GACT,WAAWS,0CAAuB;GAClC,YAAY;IACV,qBAAqB;IACrB,mBAAmB;IACnB,qBAAqB;IACrB,iBAAiB;IACjB,2BAA2B,oBAAoB;IAChD;GACF,CAAC;IACD;EAAC;EAAW;EAAa;EAAsB;EAAa;EAAqB;EAAW,CAAC;CAEhG,MAAM,2CAAgC,QAAgB;AACpD,aAAW,IAAI;IACd,EAAE,CAAC;CAEN,MAAM,kCACG;EACL;EACA;EACA;EACA;EACA;EACA,YAAY;EACb,GACD;EAAC;EAAS;EAAW;EAAa;EAAW;EAAa;EAAiB,CAC5E;AAED,QAAO,2CAAC,YAAY;EAAgB;EAAQ;GAAgC;;AAG9E,MAAa,gBAAgB;CAC3B,MAAM,gCAAqB,YAAY;AACvC,KAAI,CAAC,QACH,OAAM,IAAI,MAAM,6CAA6C;AAE/D,QAAO"}
|