@envive-ai/react-hooks 0.3.2 → 0.3.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (132) hide show
  1. package/dist/application/commerce-api.cjs +6 -4
  2. package/dist/application/commerce-api.js +6 -4
  3. package/dist/application/models/api/nextMessageRequest.d.cts +3 -1
  4. package/dist/application/models/api/nextMessageRequest.d.ts +3 -1
  5. package/dist/application/models/variantInfo/variantInfo.cjs +4 -1
  6. package/dist/application/models/variantInfo/variantInfo.d.cts +4 -1
  7. package/dist/application/models/variantInfo/variantInfo.d.ts +4 -1
  8. package/dist/application/models/variantInfo/variantInfo.js +4 -1
  9. package/dist/application/utils/elementObserver.d.cts +2 -2
  10. package/dist/application/utils/elementObserver.d.ts +2 -2
  11. package/dist/atoms/app/index.cjs +12 -1
  12. package/dist/atoms/app/index.d.cts +3 -2
  13. package/dist/atoms/app/index.d.ts +3 -2
  14. package/dist/atoms/app/index.js +13 -3
  15. package/dist/atoms/app/variant.cjs +2 -2
  16. package/dist/atoms/app/variant.d.cts +69 -5
  17. package/dist/atoms/app/variant.d.ts +69 -5
  18. package/dist/atoms/app/variant.js +2 -2
  19. package/dist/atoms/chat/chatState.d.cts +15 -15
  20. package/dist/atoms/chat/chatState.d.ts +15 -15
  21. package/dist/atoms/chat/form.d.cts +2 -2
  22. package/dist/atoms/chat/form.d.ts +2 -2
  23. package/dist/atoms/chat/index.d.cts +2 -2
  24. package/dist/atoms/chat/index.d.ts +2 -2
  25. package/dist/atoms/chat/lastMessage.d.cts +2 -2
  26. package/dist/atoms/chat/lastMessage.d.ts +2 -2
  27. package/dist/atoms/chat/messageQueue.cjs +1 -35
  28. package/dist/atoms/chat/messageQueue.js +2 -34
  29. package/dist/atoms/chat/performanceMetrics.d.cts +6 -6
  30. package/dist/atoms/chat/performanceMetrics.d.ts +6 -6
  31. package/dist/atoms/chat/renderedWidgetRefs.d.cts +2 -2
  32. package/dist/atoms/chat/renderedWidgetRefs.d.ts +2 -2
  33. package/dist/atoms/chat/replies.d.cts +2 -2
  34. package/dist/atoms/chat/replies.d.ts +2 -2
  35. package/dist/atoms/chat/suggestions.d.cts +2 -2
  36. package/dist/atoms/chat/suggestions.d.ts +2 -2
  37. package/dist/atoms/globalSearch/globalSearch.cjs +1 -3
  38. package/dist/atoms/globalSearch/globalSearch.d.cts +7 -10
  39. package/dist/atoms/globalSearch/globalSearch.d.ts +7 -10
  40. package/dist/atoms/globalSearch/globalSearch.js +2 -3
  41. package/dist/atoms/globalSearch/index.cjs +0 -1
  42. package/dist/atoms/globalSearch/index.d.cts +2 -2
  43. package/dist/atoms/globalSearch/index.d.ts +2 -2
  44. package/dist/atoms/globalSearch/index.js +2 -2
  45. package/dist/atoms/org/customerService.d.cts +6 -6
  46. package/dist/atoms/org/customerService.d.ts +6 -6
  47. package/dist/atoms/org/graphqlConfig.d.cts +5 -5
  48. package/dist/atoms/org/graphqlConfig.d.ts +5 -5
  49. package/dist/atoms/org/newOrgConfigAtom.d.cts +2 -2
  50. package/dist/atoms/org/newOrgConfigAtom.d.ts +2 -2
  51. package/dist/atoms/org/orgAnalyticsConfig.d.cts +5 -5
  52. package/dist/atoms/org/orgAnalyticsConfig.d.ts +5 -5
  53. package/dist/atoms/search/chatSearch.d.cts +17 -17
  54. package/dist/atoms/search/chatSearch.d.ts +17 -17
  55. package/dist/atoms/search/searchAPI.cjs +1 -1
  56. package/dist/atoms/search/searchAPI.d.cts +14 -14
  57. package/dist/atoms/search/searchAPI.d.ts +14 -14
  58. package/dist/atoms/search/searchAPI.js +1 -1
  59. package/dist/contexts/amplitudeContext/amplitudeContext.cjs +5 -5
  60. package/dist/contexts/amplitudeContext/amplitudeContext.js +5 -5
  61. package/dist/contexts/enviveContext/enviveContext.cjs +7 -3
  62. package/dist/contexts/enviveContext/enviveContext.js +7 -3
  63. package/dist/contexts/graphqlContext/graphqlContext.cjs +1 -1
  64. package/dist/contexts/graphqlContext/graphqlContext.js +1 -1
  65. package/dist/contexts/hardcopyContext/hardcopyContext.cjs +62 -0
  66. package/dist/contexts/hardcopyContext/hardcopyContext.d.cts +23 -0
  67. package/dist/contexts/hardcopyContext/hardcopyContext.d.ts +23 -0
  68. package/dist/contexts/hardcopyContext/hardcopyContext.js +60 -0
  69. package/dist/contexts/hardcopyContext/index.cjs +4 -0
  70. package/dist/contexts/hardcopyContext/index.d.cts +2 -0
  71. package/dist/contexts/hardcopyContext/index.d.ts +2 -0
  72. package/dist/contexts/hardcopyContext/index.js +3 -0
  73. package/dist/contexts/pageContext/index.cjs +6 -0
  74. package/dist/contexts/pageContext/index.d.cts +3 -0
  75. package/dist/contexts/pageContext/index.d.ts +3 -0
  76. package/dist/contexts/pageContext/index.js +4 -0
  77. package/dist/contexts/pageContext/mapping.cjs +25 -0
  78. package/dist/contexts/pageContext/mapping.d.cts +8 -0
  79. package/dist/contexts/pageContext/mapping.d.ts +8 -0
  80. package/dist/contexts/pageContext/mapping.js +25 -0
  81. package/dist/contexts/pageContext/pageContext.cjs +66 -0
  82. package/dist/contexts/pageContext/pageContext.d.cts +11 -0
  83. package/dist/contexts/pageContext/pageContext.d.ts +11 -0
  84. package/dist/contexts/pageContext/pageContext.js +64 -0
  85. package/dist/contexts/pageContext/types.cjs +0 -0
  86. package/dist/contexts/pageContext/types.d.cts +27 -0
  87. package/dist/contexts/pageContext/types.d.ts +27 -0
  88. package/dist/contexts/pageContext/types.js +1 -0
  89. package/dist/contexts/salesAgentContext/chatAPI.cjs +45 -0
  90. package/dist/contexts/salesAgentContext/chatAPI.d.cts +35 -0
  91. package/dist/contexts/salesAgentContext/chatAPI.d.ts +35 -0
  92. package/dist/contexts/salesAgentContext/chatAPI.js +44 -0
  93. package/dist/contexts/salesAgentContext/index.cjs +20 -0
  94. package/dist/contexts/salesAgentContext/index.d.cts +4 -0
  95. package/dist/contexts/salesAgentContext/index.d.ts +4 -0
  96. package/dist/contexts/salesAgentContext/index.js +5 -0
  97. package/dist/contexts/salesAgentContext/salesAgentContext.cjs +90 -0
  98. package/dist/contexts/salesAgentContext/salesAgentContext.d.cts +22 -0
  99. package/dist/contexts/salesAgentContext/salesAgentContext.d.ts +22 -0
  100. package/dist/contexts/salesAgentContext/salesAgentContext.js +88 -0
  101. package/dist/contexts/salesAgentContext/salesAgentService.cjs +99 -0
  102. package/dist/contexts/salesAgentContext/salesAgentService.js +98 -0
  103. package/dist/contexts/searchContext/searchContext.cjs +1 -1
  104. package/dist/contexts/searchContext/searchContext.js +1 -1
  105. package/dist/contexts/systemSettingsContext/systemSettingsContext.d.cts +2 -2
  106. package/dist/contexts/types.cjs +11 -1
  107. package/dist/contexts/types.d.cts +10 -2
  108. package/dist/contexts/types.d.ts +10 -2
  109. package/dist/contexts/types.js +11 -2
  110. package/dist/contexts/userIdentityContext/userIdentityContext.cjs +1 -1
  111. package/dist/contexts/userIdentityContext/userIdentityContext.js +1 -1
  112. package/dist/hooks/GrabAndScroll/useGrabAndScroll.d.cts +2 -2
  113. package/dist/hooks/GrabAndScroll/useGrabAndScroll.d.ts +2 -2
  114. package/dist/hooks/GraphQLConfig/useGraphQLConfig.cjs +9 -3
  115. package/dist/hooks/GraphQLConfig/useGraphQLConfig.js +9 -3
  116. package/dist/hooks/ImageResolver/useImageResolver.cjs +1 -1
  117. package/dist/hooks/ImageResolver/useImageResolver.js +1 -1
  118. package/dist/hooks/Search/useSearch.cjs +5 -8
  119. package/dist/hooks/Search/useSearch.d.cts +1 -3
  120. package/dist/hooks/Search/useSearch.d.ts +1 -3
  121. package/dist/hooks/Search/useSearch.js +6 -9
  122. package/dist/hooks/utils.d.cts +1 -1
  123. package/dist/hooks/utils.d.ts +1 -1
  124. package/package.json +5 -1
  125. package/dist/contexts/chatContext/chatContext.cjs +0 -306
  126. package/dist/contexts/chatContext/chatContext.d.cts +0 -15
  127. package/dist/contexts/chatContext/chatContext.d.ts +0 -15
  128. package/dist/contexts/chatContext/chatContext.js +0 -304
  129. package/dist/contexts/chatContext/index.cjs +0 -4
  130. package/dist/contexts/chatContext/index.d.cts +0 -2
  131. package/dist/contexts/chatContext/index.d.ts +0 -2
  132. package/dist/contexts/chatContext/index.js +0 -3
@@ -0,0 +1,35 @@
1
+ import { Suggestion as Suggestion$1 } from "../../application/models/api/suggestion.cjs";
2
+ import { PageVisitCategory } from "@spiffy-ai/commerce-api-client";
3
+
4
+ //#region src/contexts/salesAgentContext/chatAPI.d.ts
5
+ interface SalesAgentChatAPI {
6
+ logPageVisit: ({
7
+ pageVisitCategory
8
+ }: {
9
+ pageVisitCategory: PageVisitCategory;
10
+ }) => void;
11
+ onSuggestionClicked: (suggestion: Suggestion$1) => void;
12
+ onTypedMessageSubmitted: ({
13
+ query
14
+ }: {
15
+ query: string;
16
+ }) => void;
17
+ onFormResponseSubmitted: (formResponse: any) => void;
18
+ }
19
+ declare const useSalesAgentChatAPI: () => {
20
+ logPageVisit: ({
21
+ pageVisitCategory
22
+ }: {
23
+ pageVisitCategory: PageVisitCategory;
24
+ }) => void;
25
+ onSuggestionClicked: (suggestion: Suggestion$1) => void;
26
+ onTypedMessageSubmitted: ({
27
+ query
28
+ }: {
29
+ query: string;
30
+ }) => void;
31
+ onFormResponseSubmitted: () => void;
32
+ };
33
+ //#endregion
34
+ export { SalesAgentChatAPI, useSalesAgentChatAPI };
35
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhdEFQSS5kLmN0cyIsIm5hbWVzIjpbXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29udGV4dHMvc2FsZXNBZ2VudENvbnRleHQvY2hhdEFQSS5kLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBhZ2VWaXNpdENhdGVnb3J5IH0gZnJvbSAnQHNwaWZmeS1haS9jb21tZXJjZS1hcGktY2xpZW50JztcbmltcG9ydCB7IFN1Z2dlc3Rpb24gfSBmcm9tICdzcmMvYXBwbGljYXRpb24vbW9kZWxzJztcbmV4cG9ydCBpbnRlcmZhY2UgU2FsZXNBZ2VudENoYXRBUEkge1xuICAgIGxvZ1BhZ2VWaXNpdDogKHsgcGFnZVZpc2l0Q2F0ZWdvcnkgfToge1xuICAgICAgICBwYWdlVmlzaXRDYXRlZ29yeTogUGFnZVZpc2l0Q2F0ZWdvcnk7XG4gICAgfSkgPT4gdm9pZDtcbiAgICBvblN1Z2dlc3Rpb25DbGlja2VkOiAoc3VnZ2VzdGlvbjogU3VnZ2VzdGlvbikgPT4gdm9pZDtcbiAgICBvblR5cGVkTWVzc2FnZVN1Ym1pdHRlZDogKHsgcXVlcnkgfToge1xuICAgICAgICBxdWVyeTogc3RyaW5nO1xuICAgIH0pID0+IHZvaWQ7XG4gICAgb25Gb3JtUmVzcG9uc2VTdWJtaXR0ZWQ6IChmb3JtUmVzcG9uc2U6IGFueSkgPT4gdm9pZDtcbn1cbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHVzZVNhbGVzQWdlbnRDaGF0QVBJOiAoKSA9PiB7XG4gICAgbG9nUGFnZVZpc2l0OiAoeyBwYWdlVmlzaXRDYXRlZ29yeSB9OiB7XG4gICAgICAgIHBhZ2VWaXNpdENhdGVnb3J5OiBQYWdlVmlzaXRDYXRlZ29yeTtcbiAgICB9KSA9PiB2b2lkO1xuICAgIG9uU3VnZ2VzdGlvbkNsaWNrZWQ6IChzdWdnZXN0aW9uOiBTdWdnZXN0aW9uKSA9PiB2b2lkO1xuICAgIG9uVHlwZWRNZXNzYWdlU3VibWl0dGVkOiAoeyBxdWVyeSB9OiB7XG4gICAgICAgIHF1ZXJ5OiBzdHJpbmc7XG4gICAgfSkgPT4gdm9pZDtcbiAgICBvbkZvcm1SZXNwb25zZVN1Ym1pdHRlZDogKCkgPT4gdm9pZDtcbn07XG4iXSwibWFwcGluZ3MiOiI7Ozs7QUFFQSxJQUFXLG9CQUFvQjtDQUFDO09BQUc7T0FBQTtPQUFBO09BQUE7Q0FBQTtBQUNuQyxJQUFXLHVCQUF1QjtDQUFDO09BQU87T0FBQTtPQUFBO09BQUE7Q0FBQSJ9
@@ -0,0 +1,35 @@
1
+ import { Suggestion as Suggestion$1 } from "../../application/models/api/suggestion.js";
2
+ import { PageVisitCategory } from "@spiffy-ai/commerce-api-client";
3
+
4
+ //#region src/contexts/salesAgentContext/chatAPI.d.ts
5
+ interface SalesAgentChatAPI {
6
+ logPageVisit: ({
7
+ pageVisitCategory
8
+ }: {
9
+ pageVisitCategory: PageVisitCategory;
10
+ }) => void;
11
+ onSuggestionClicked: (suggestion: Suggestion$1) => void;
12
+ onTypedMessageSubmitted: ({
13
+ query
14
+ }: {
15
+ query: string;
16
+ }) => void;
17
+ onFormResponseSubmitted: (formResponse: any) => void;
18
+ }
19
+ declare const useSalesAgentChatAPI: () => {
20
+ logPageVisit: ({
21
+ pageVisitCategory
22
+ }: {
23
+ pageVisitCategory: PageVisitCategory;
24
+ }) => void;
25
+ onSuggestionClicked: (suggestion: Suggestion$1) => void;
26
+ onTypedMessageSubmitted: ({
27
+ query
28
+ }: {
29
+ query: string;
30
+ }) => void;
31
+ onFormResponseSubmitted: () => void;
32
+ };
33
+ //#endregion
34
+ export { SalesAgentChatAPI, useSalesAgentChatAPI };
35
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhdEFQSS5kLnRzIiwibmFtZXMiOltdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb250ZXh0cy9zYWxlc0FnZW50Q29udGV4dC9jaGF0QVBJLmQudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGFnZVZpc2l0Q2F0ZWdvcnkgfSBmcm9tICdAc3BpZmZ5LWFpL2NvbW1lcmNlLWFwaS1jbGllbnQnO1xuaW1wb3J0IHsgU3VnZ2VzdGlvbiB9IGZyb20gJ3NyYy9hcHBsaWNhdGlvbi9tb2RlbHMnO1xuZXhwb3J0IGludGVyZmFjZSBTYWxlc0FnZW50Q2hhdEFQSSB7XG4gICAgbG9nUGFnZVZpc2l0OiAoeyBwYWdlVmlzaXRDYXRlZ29yeSB9OiB7XG4gICAgICAgIHBhZ2VWaXNpdENhdGVnb3J5OiBQYWdlVmlzaXRDYXRlZ29yeTtcbiAgICB9KSA9PiB2b2lkO1xuICAgIG9uU3VnZ2VzdGlvbkNsaWNrZWQ6IChzdWdnZXN0aW9uOiBTdWdnZXN0aW9uKSA9PiB2b2lkO1xuICAgIG9uVHlwZWRNZXNzYWdlU3VibWl0dGVkOiAoeyBxdWVyeSB9OiB7XG4gICAgICAgIHF1ZXJ5OiBzdHJpbmc7XG4gICAgfSkgPT4gdm9pZDtcbiAgICBvbkZvcm1SZXNwb25zZVN1Ym1pdHRlZDogKGZvcm1SZXNwb25zZTogYW55KSA9PiB2b2lkO1xufVxuZXhwb3J0IGRlY2xhcmUgY29uc3QgdXNlU2FsZXNBZ2VudENoYXRBUEk6ICgpID0+IHtcbiAgICBsb2dQYWdlVmlzaXQ6ICh7IHBhZ2VWaXNpdENhdGVnb3J5IH06IHtcbiAgICAgICAgcGFnZVZpc2l0Q2F0ZWdvcnk6IFBhZ2VWaXNpdENhdGVnb3J5O1xuICAgIH0pID0+IHZvaWQ7XG4gICAgb25TdWdnZXN0aW9uQ2xpY2tlZDogKHN1Z2dlc3Rpb246IFN1Z2dlc3Rpb24pID0+IHZvaWQ7XG4gICAgb25UeXBlZE1lc3NhZ2VTdWJtaXR0ZWQ6ICh7IHF1ZXJ5IH06IHtcbiAgICAgICAgcXVlcnk6IHN0cmluZztcbiAgICB9KSA9PiB2b2lkO1xuICAgIG9uRm9ybVJlc3BvbnNlU3VibWl0dGVkOiAoKSA9PiB2b2lkO1xufTtcbiJdLCJtYXBwaW5ncyI6Ijs7OztBQUVBLElBQVcsb0JBQW9CO0NBQUM7T0FBRztPQUFBO09BQUE7T0FBQTtDQUFBO0FBQ25DLElBQVcsdUJBQXVCO0NBQUM7T0FBTztPQUFBO09BQUE7T0FBQTtDQUFBIn0=
@@ -0,0 +1,44 @@
1
+ import { queueUserEventAtom } from "../../atoms/chat/messageQueue.js";
2
+ import { UserEventCategory } from "@spiffy-ai/commerce-api-client";
3
+ import { useCallback } from "react";
4
+ import { v4 } from "uuid";
5
+ import { useSetAtom } from "jotai";
6
+
7
+ //#region src/contexts/salesAgentContext/chatAPI.ts
8
+ const useSalesAgentChatAPI = () => {
9
+ const queueUserEvent = useSetAtom(queueUserEventAtom);
10
+ return {
11
+ logPageVisit: useCallback(({ pageVisitCategory }) => {
12
+ queueUserEvent({
13
+ eventId: v4(),
14
+ category: UserEventCategory.PageVisit,
15
+ createdAt: (/* @__PURE__ */ new Date()).toISOString(),
16
+ attributes: {
17
+ url: window.location.href,
18
+ pageVisitCategory
19
+ }
20
+ });
21
+ }, [queueUserEvent]),
22
+ onSuggestionClicked: useCallback((suggestion) => {
23
+ queueUserEvent({
24
+ eventId: v4(),
25
+ category: UserEventCategory.SuggestionClicked,
26
+ createdAt: (/* @__PURE__ */ new Date()).toISOString(),
27
+ attributes: { suggestionId: suggestion.id }
28
+ });
29
+ }, [queueUserEvent]),
30
+ onTypedMessageSubmitted: useCallback(({ query }) => {
31
+ queueUserEvent({
32
+ eventId: v4(),
33
+ category: UserEventCategory.QueryTyped,
34
+ createdAt: (/* @__PURE__ */ new Date()).toISOString(),
35
+ attributes: { query }
36
+ });
37
+ }, [queueUserEvent]),
38
+ onFormResponseSubmitted: useCallback(() => {}, [])
39
+ };
40
+ };
41
+
42
+ //#endregion
43
+ export { useSalesAgentChatAPI };
44
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhdEFQSS5qcyIsIm5hbWVzIjpbInV1aWQiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29udGV4dHMvc2FsZXNBZ2VudENvbnRleHQvY2hhdEFQSS50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvLyBUaGlzIGNvbXBvbmVudCB3aWxsIGludGVyYWN0IHdpdGggdGhlIGJhY2tlbmQgQVBJIHRvIGdldCB0aGUgcmVzcG9uc2VzIGZyb20gdGhlIHNhbGVzIGFnZW50LlxuXG5pbXBvcnQgeyBQYWdlVmlzaXRDYXRlZ29yeSwgVXNlckV2ZW50Q2F0ZWdvcnkgfSBmcm9tICdAc3BpZmZ5LWFpL2NvbW1lcmNlLWFwaS1jbGllbnQnO1xuaW1wb3J0IHsgU3VnZ2VzdGlvbiwgVXNlckV2ZW50IH0gZnJvbSAnc3JjL2FwcGxpY2F0aW9uL21vZGVscyc7XG5pbXBvcnQgeyB1c2VTZXRBdG9tIH0gZnJvbSAnam90YWknO1xuaW1wb3J0IHsgdXNlQ2FsbGJhY2sgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyB2NCBhcyB1dWlkIH0gZnJvbSAndXVpZCc7XG5pbXBvcnQgeyBxdWV1ZVVzZXJFdmVudEF0b20gfSBmcm9tICdzcmMvYXRvbXMvY2hhdC9tZXNzYWdlUXVldWUnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFNhbGVzQWdlbnRDaGF0QVBJIHtcbiAgbG9nUGFnZVZpc2l0OiAoeyBwYWdlVmlzaXRDYXRlZ29yeSB9OiB7IHBhZ2VWaXNpdENhdGVnb3J5OiBQYWdlVmlzaXRDYXRlZ29yeSB9KSA9PiB2b2lkO1xuICBvblN1Z2dlc3Rpb25DbGlja2VkOiAoc3VnZ2VzdGlvbjogU3VnZ2VzdGlvbikgPT4gdm9pZDtcbiAgb25UeXBlZE1lc3NhZ2VTdWJtaXR0ZWQ6ICh7IHF1ZXJ5IH06IHsgcXVlcnk6IHN0cmluZyB9KSA9PiB2b2lkO1xuICBvbkZvcm1SZXNwb25zZVN1Ym1pdHRlZDogKGZvcm1SZXNwb25zZTogYW55KSA9PiB2b2lkOyAvLyBUT0RPOiBGaWd1cmUgb3V0IHRoZSByaWdodCB0eXBlXG59XG5cbmV4cG9ydCBjb25zdCB1c2VTYWxlc0FnZW50Q2hhdEFQSSA9ICgpID0+IHtcbiAgLy8gVE9ETzogRWFjaCBvZiB0aGVzZSBmdW5jdGlvbnMgd2lsbCB0cmlnZ2VyIGJvdGggdGhlIG5lY2Vzc2FyeSBhbXBsaXR1ZGUgZXZlbnRzIGFuZCBpbml0aWF0ZSB0aGVcbiAgLy8gbmVjZXNzYXJ5IGFjdGlvbnMgdG8gdHJpZ2dlciB0aGUgYmFja2VuZCBBUElcbiAgY29uc3QgcXVldWVVc2VyRXZlbnQgPSB1c2VTZXRBdG9tKHF1ZXVlVXNlckV2ZW50QXRvbSk7XG5cbiAgY29uc3QgbG9nUGFnZVZpc2l0ID0gdXNlQ2FsbGJhY2soXG4gICAgKHsgcGFnZVZpc2l0Q2F0ZWdvcnkgfTogeyBwYWdlVmlzaXRDYXRlZ29yeTogUGFnZVZpc2l0Q2F0ZWdvcnkgfSkgPT4ge1xuICAgICAgY29uc3QgZXZlbnQ6IFVzZXJFdmVudCA9IHtcbiAgICAgICAgZXZlbnRJZDogdXVpZCgpLFxuICAgICAgICBjYXRlZ29yeTogVXNlckV2ZW50Q2F0ZWdvcnkuUGFnZVZpc2l0LFxuICAgICAgICBjcmVhdGVkQXQ6IG5ldyBEYXRlKCkudG9JU09TdHJpbmcoKSxcbiAgICAgICAgYXR0cmlidXRlczoge1xuICAgICAgICAgIHVybDogd2luZG93LmxvY2F0aW9uLmhyZWYsXG4gICAgICAgICAgcGFnZVZpc2l0Q2F0ZWdvcnksXG4gICAgICAgIH0sXG4gICAgICB9O1xuICAgICAgcXVldWVVc2VyRXZlbnQoZXZlbnQpO1xuICAgIH0sXG4gICAgW3F1ZXVlVXNlckV2ZW50XSxcbiAgKTtcbiAgY29uc3Qgb25TdWdnZXN0aW9uQ2xpY2tlZCA9IHVzZUNhbGxiYWNrKFxuICAgIChzdWdnZXN0aW9uOiBTdWdnZXN0aW9uKSA9PiB7XG4gICAgICBjb25zdCBldmVudDogVXNlckV2ZW50ID0ge1xuICAgICAgICBldmVudElkOiB1dWlkKCksXG4gICAgICAgIGNhdGVnb3J5OiBVc2VyRXZlbnRDYXRlZ29yeS5TdWdnZXN0aW9uQ2xpY2tlZCxcbiAgICAgICAgY3JlYXRlZEF0OiBuZXcgRGF0ZSgpLnRvSVNPU3RyaW5nKCksXG4gICAgICAgIGF0dHJpYnV0ZXM6IHtcbiAgICAgICAgICBzdWdnZXN0aW9uSWQ6IHN1Z2dlc3Rpb24uaWQsXG4gICAgICAgIH0sXG4gICAgICB9O1xuICAgICAgcXVldWVVc2VyRXZlbnQoZXZlbnQpO1xuICAgIH0sXG4gICAgW3F1ZXVlVXNlckV2ZW50XSxcbiAgKTtcbiAgY29uc3Qgb25UeXBlZE1lc3NhZ2VTdWJtaXR0ZWQgPSB1c2VDYWxsYmFjayhcbiAgICAoeyBxdWVyeSB9OiB7IHF1ZXJ5OiBzdHJpbmcgfSkgPT4ge1xuICAgICAgY29uc3QgZXZlbnQ6IFVzZXJFdmVudCA9IHtcbiAgICAgICAgZXZlbnRJZDogdXVpZCgpLFxuICAgICAgICBjYXRlZ29yeTogVXNlckV2ZW50Q2F0ZWdvcnkuUXVlcnlUeXBlZCxcbiAgICAgICAgY3JlYXRlZEF0OiBuZXcgRGF0ZSgpLnRvSVNPU3RyaW5nKCksXG4gICAgICAgIGF0dHJpYnV0ZXM6IHtcbiAgICAgICAgICBxdWVyeSxcbiAgICAgICAgfSxcbiAgICAgIH07XG4gICAgICBxdWV1ZVVzZXJFdmVudChldmVudCk7XG4gICAgfSxcbiAgICBbcXVldWVVc2VyRXZlbnRdLFxuICApO1xuICBjb25zdCBvbkZvcm1SZXNwb25zZVN1Ym1pdHRlZCA9IHVzZUNhbGxiYWNrKCgpID0+IHtcbiAgICAvLyBUT0RPOiBJbXBsZW1lbnQgdGhlIGZvcm0gcmVzcG9uc2Ugc3VibWl0dGVkXG4gIH0sIFtdKTtcblxuICByZXR1cm4ge1xuICAgIGxvZ1BhZ2VWaXNpdCxcbiAgICBvblN1Z2dlc3Rpb25DbGlja2VkLFxuICAgIG9uVHlwZWRNZXNzYWdlU3VibWl0dGVkLFxuICAgIG9uRm9ybVJlc3BvbnNlU3VibWl0dGVkLFxuICB9O1xufTtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQWdCQSxNQUFhLDZCQUE2QjtDQUd4QyxNQUFNLGlCQUFpQixXQUFXLG1CQUFtQjtBQWlEckQsUUFBTztFQUNMLGNBaERtQixhQUNsQixFQUFFLHdCQUFrRTtBQVVuRSxrQkFUeUI7SUFDdkIsU0FBU0EsSUFBTTtJQUNmLFVBQVUsa0JBQWtCO0lBQzVCLDRCQUFXLElBQUksTUFBTSxFQUFDLGFBQWE7SUFDbkMsWUFBWTtLQUNWLEtBQUssT0FBTyxTQUFTO0tBQ3JCO0tBQ0Q7SUFDRixDQUNvQjtLQUV2QixDQUFDLGVBQWUsQ0FDakI7RUFtQ0MscUJBbEMwQixhQUN6QixlQUEyQjtBQVMxQixrQkFSeUI7SUFDdkIsU0FBU0EsSUFBTTtJQUNmLFVBQVUsa0JBQWtCO0lBQzVCLDRCQUFXLElBQUksTUFBTSxFQUFDLGFBQWE7SUFDbkMsWUFBWSxFQUNWLGNBQWMsV0FBVyxJQUMxQjtJQUNGLENBQ29CO0tBRXZCLENBQUMsZUFBZSxDQUNqQjtFQXNCQyx5QkFyQjhCLGFBQzdCLEVBQUUsWUFBK0I7QUFTaEMsa0JBUnlCO0lBQ3ZCLFNBQVNBLElBQU07SUFDZixVQUFVLGtCQUFrQjtJQUM1Qiw0QkFBVyxJQUFJLE1BQU0sRUFBQyxhQUFhO0lBQ25DLFlBQVksRUFDVixPQUNEO0lBQ0YsQ0FDb0I7S0FFdkIsQ0FBQyxlQUFlLENBQ2pCO0VBU0MseUJBUjhCLGtCQUFrQixJQUUvQyxFQUFFLENBQUM7RUFPTCJ9
@@ -0,0 +1,20 @@
1
+ const require_rolldown_runtime = require('../../_virtual/rolldown_runtime.cjs');
2
+ const require_chatAPI = require('./chatAPI.cjs');
3
+ const require_salesAgentContext = require('./salesAgentContext.cjs');
4
+ let __spiffy_ai_commerce_api_client = require("@spiffy-ai/commerce-api-client");
5
+
6
+ Object.defineProperty(exports, 'PageVisitCategory', {
7
+ enumerable: true,
8
+ get: function () {
9
+ return __spiffy_ai_commerce_api_client.PageVisitCategory;
10
+ }
11
+ });
12
+ exports.SalesAgentProvider = require_salesAgentContext.SalesAgentProvider;
13
+ Object.defineProperty(exports, 'SuggestionCategory', {
14
+ enumerable: true,
15
+ get: function () {
16
+ return __spiffy_ai_commerce_api_client.SuggestionCategory;
17
+ }
18
+ });
19
+ exports.useSalesAgent = require_salesAgentContext.useSalesAgent;
20
+ exports.useSalesAgentChatAPI = require_chatAPI.useSalesAgentChatAPI;
@@ -0,0 +1,4 @@
1
+ import { SalesAgentChatAPI, useSalesAgentChatAPI } from "./chatAPI.cjs";
2
+ import { SalesAgentProvider, useSalesAgent } from "./salesAgentContext.cjs";
3
+ import { PageVisitCategory, SuggestionCategory } from "@spiffy-ai/commerce-api-client";
4
+ export { PageVisitCategory, SalesAgentChatAPI, SalesAgentProvider, SuggestionCategory, useSalesAgent, useSalesAgentChatAPI };
@@ -0,0 +1,4 @@
1
+ import { SalesAgentChatAPI, useSalesAgentChatAPI } from "./chatAPI.js";
2
+ import { SalesAgentProvider, useSalesAgent } from "./salesAgentContext.js";
3
+ import { PageVisitCategory, SuggestionCategory } from "@spiffy-ai/commerce-api-client";
4
+ export { PageVisitCategory, SalesAgentChatAPI, SalesAgentProvider, SuggestionCategory, useSalesAgent, useSalesAgentChatAPI };
@@ -0,0 +1,5 @@
1
+ import { useSalesAgentChatAPI } from "./chatAPI.js";
2
+ import { SalesAgentProvider, useSalesAgent } from "./salesAgentContext.js";
3
+ import { PageVisitCategory, SuggestionCategory } from "@spiffy-ai/commerce-api-client";
4
+
5
+ export { PageVisitCategory, SalesAgentProvider, SuggestionCategory, useSalesAgent, useSalesAgentChatAPI };
@@ -0,0 +1,90 @@
1
+ const require_rolldown_runtime = require('../../_virtual/rolldown_runtime.cjs');
2
+ const require_chatState = require('../../atoms/chat/chatState.cjs');
3
+ const require_messageQueue = require('../../atoms/chat/messageQueue.cjs');
4
+ const require_useSystemSettingsContext = require('../../hooks/SystemSettingsContext/useSystemSettingsContext.cjs');
5
+ require('../../hooks/SystemSettingsContext/index.cjs');
6
+ const require_chatAPI = require('./chatAPI.cjs');
7
+ const require_salesAgentService = require('./salesAgentService.cjs');
8
+ let react = require("react");
9
+ let jotai = require("jotai");
10
+ let react_jsx_runtime = require("react/jsx-runtime");
11
+
12
+ //#region src/contexts/salesAgentContext/salesAgentContext.tsx
13
+ const SalesAgentContext = (0, react.createContext)(void 0);
14
+ const SalesAgentProvider = ({ children }) => {
15
+ const userEvents = (0, jotai.useAtomValue)(require_messageQueue.userEventQueueAtom);
16
+ const userQueueEventCount = (0, jotai.useAtomValue)(require_messageQueue.userQueueEventCountAtom);
17
+ const markUserEventsProcessed = (0, jotai.useSetAtom)(require_messageQueue.processUserEventAtom);
18
+ const settingsContext = require_useSystemSettingsContext.useSystemSettingsContext();
19
+ const { getStreamingResponses, createResponsePayload } = require_salesAgentService.useSalesAgentService();
20
+ const sendMessagesToBackend = (0, react.useCallback)(async () => {
21
+ if (userEvents.length === 0) return;
22
+ const [pendingMessage] = userEvents.slice(0, userQueueEventCount);
23
+ try {
24
+ const response = await getStreamingResponses(createResponsePayload({
25
+ userEvents: [pendingMessage],
26
+ generationParams: settingsContext.generationParams
27
+ }));
28
+ console.log("response", response);
29
+ markUserEventsProcessed([pendingMessage.eventId]);
30
+ } catch (error) {
31
+ console.error("error sending message");
32
+ }
33
+ }, [
34
+ userEvents,
35
+ userQueueEventCount,
36
+ createResponsePayload,
37
+ settingsContext.generationParams,
38
+ getStreamingResponses,
39
+ markUserEventsProcessed
40
+ ]);
41
+ console.log("userQueueEventCount", userQueueEventCount);
42
+ console.log("userEvents", userEvents);
43
+ (0, react.useEffect)(() => {
44
+ if (userQueueEventCount > 0) sendMessagesToBackend();
45
+ console.log("SalesAgentProvider useEffect");
46
+ }, [sendMessagesToBackend, userQueueEventCount]);
47
+ return /* @__PURE__ */ (0, react_jsx_runtime.jsx)(SalesAgentContext.Provider, {
48
+ value: void 0,
49
+ children
50
+ });
51
+ };
52
+ const useSalesAgent = () => {
53
+ const messages = (0, jotai.useAtomValue)(require_chatState.messagesAtom);
54
+ const suggestions = (0, jotai.useAtomValue)(require_chatState.suggestionsAtom);
55
+ const pendingMessages = (0, jotai.useAtomValue)(require_messageQueue.userEventQueueAtom);
56
+ const isResponseStreaming = false;
57
+ const isPendingResponse = false;
58
+ const isInitialized = false;
59
+ const { logPageVisit, onSuggestionClicked, onTypedMessageSubmitted, onFormResponseSubmitted } = require_chatAPI.useSalesAgentChatAPI();
60
+ return (0, react.useMemo)(() => {
61
+ return {
62
+ messages,
63
+ suggestions,
64
+ pendingMessages,
65
+ isResponseStreaming,
66
+ isPendingResponse,
67
+ isInitialized,
68
+ logPageVisit,
69
+ onSuggestionClicked,
70
+ onTypedMessageSubmitted,
71
+ onFormResponseSubmitted
72
+ };
73
+ }, [
74
+ messages,
75
+ suggestions,
76
+ pendingMessages,
77
+ isResponseStreaming,
78
+ isPendingResponse,
79
+ isInitialized,
80
+ logPageVisit,
81
+ onSuggestionClicked,
82
+ onTypedMessageSubmitted,
83
+ onFormResponseSubmitted
84
+ ]);
85
+ };
86
+
87
+ //#endregion
88
+ exports.SalesAgentProvider = SalesAgentProvider;
89
+ exports.useSalesAgent = useSalesAgent;
90
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"salesAgentContext.cjs","names":["SalesAgentProvider: React.FC<{ children: ReactNode }>","userEventQueueAtom","userQueueEventCountAtom","processUserEventAtom","useSystemSettingsContext","useSalesAgentService","messagesAtom","suggestionsAtom","useSalesAgentChatAPI"],"sources":["../../../src/contexts/salesAgentContext/salesAgentContext.tsx"],"sourcesContent":["import { useAtomValue, useSetAtom } from 'jotai';\nimport { ReactNode, createContext, useCallback, useEffect, useMemo } from 'react';\nimport { Message } from 'src/application/models/message';\nimport { Suggestion, UserEvent } from 'src/application/models';\nimport { messagesAtom, suggestionsAtom } from 'src/atoms/chat/chatState';\nimport {\n  processUserEventAtom,\n  userEventQueueAtom,\n  userQueueEventCountAtom,\n} from 'src/atoms/chat/messageQueue';\nimport { useSystemSettingsContext } from 'src/hooks/SystemSettingsContext';\nimport { SalesAgentChatAPI, useSalesAgentChatAPI } from './chatAPI';\nimport { useSalesAgentService } from './salesAgentService';\n\ninterface SalesAgent extends SalesAgentChatAPI {\n  // Messages are the full list of all turns\n  messages: Message[][];\n  // Pending messages are messages that the user has clicked/typed but have not yet been sent to the backend.\n  pendingMessages: UserEvent[];\n  // Suggestions are the list of suggestions that the user can click on in response to the most recent message from the backend\n  suggestions: Suggestion[];\n  // True while the response is streaming from the backend\n  isResponseStreaming: boolean;\n  // True while the response is pending from the backend\n  isPendingResponse: boolean;\n  // True when the sales agent is initialized\n  isInitialized: boolean;\n}\n\nconst SalesAgentContext = createContext<SalesAgent | undefined>(undefined);\n\nexport const SalesAgentProvider: React.FC<{ children: ReactNode }> = ({ children }) => {\n  const userEvents = useAtomValue(userEventQueueAtom);\n  const userQueueEventCount = useAtomValue(userQueueEventCountAtom);\n  const markUserEventsProcessed = useSetAtom(processUserEventAtom);\n  const settingsContext = useSystemSettingsContext();\n\n  const { getStreamingResponses, createResponsePayload } = useSalesAgentService();\n\n  // TODO: Ensure that amplitude events are being emitted\n\n  // TODO: Add support for the streaming responses to function\n\n  // TODO: Add support for the hydration of the messages from the backend on initialization\n  const sendMessagesToBackend = useCallback(async () => {\n    // Fast exit if there are no pending messages\n    if (userEvents.length === 0) {\n      return;\n    }\n    // TODO: Support sending multiple messages to the backend in one request\n    const [pendingMessage] = userEvents.slice(0, userQueueEventCount);\n    try {\n      const requestPayload = createResponsePayload({\n        userEvents: [pendingMessage],\n        generationParams: settingsContext.generationParams,\n      });\n      const response = await getStreamingResponses(requestPayload);\n\n      console.log('response', response);\n      // Remove the pending message from the user events\n      markUserEventsProcessed([pendingMessage.eventId]);\n    } catch (error) {\n      console.error('error sending message');\n    }\n  }, [\n    userEvents,\n    userQueueEventCount,\n    createResponsePayload,\n    settingsContext.generationParams,\n    getStreamingResponses,\n    markUserEventsProcessed,\n  ]);\n\n  console.log('userQueueEventCount', userQueueEventCount);\n  console.log('userEvents', userEvents);\n\n  // This is the primary event loop for communicating with the backend API\n  // It will be triggered when there are pending messages to be sent to the backend\n  // It will be responsible for sending the messages to the backend and receiving the responses\n  useEffect(() => {\n    if (userQueueEventCount > 0) {\n      sendMessagesToBackend();\n    }\n    // TODO: Add a suggestion retrieval here (don't get suggestions unless the event queue is empty)\n    console.log('SalesAgentProvider useEffect');\n  }, [sendMessagesToBackend, userQueueEventCount]);\n\n  return <SalesAgentContext.Provider value={undefined}>{children}</SalesAgentContext.Provider>;\n};\n\nexport const useSalesAgent = (): SalesAgent => {\n  const messages = useAtomValue(messagesAtom);\n  const suggestions = useAtomValue(suggestionsAtom);\n  const pendingMessages = useAtomValue(userEventQueueAtom);\n  const isResponseStreaming = false; // useAtomValue(isResponseStreamingAtom);\n  const isPendingResponse = false; // useAtomValue(isPendingResponseAtom);\n  const isInitialized = false; // useAtomValue(isInitializedAtom);\n\n  const { logPageVisit, onSuggestionClicked, onTypedMessageSubmitted, onFormResponseSubmitted } =\n    useSalesAgentChatAPI();\n\n  const salesAgent: SalesAgent = useMemo(() => {\n    return {\n      messages,\n      suggestions,\n      pendingMessages,\n      isResponseStreaming,\n      isPendingResponse,\n      isInitialized,\n      logPageVisit,\n      onSuggestionClicked,\n      onTypedMessageSubmitted,\n      onFormResponseSubmitted,\n    };\n  }, [\n    messages,\n    suggestions,\n    pendingMessages,\n    isResponseStreaming,\n    isPendingResponse,\n    isInitialized,\n    logPageVisit,\n    onSuggestionClicked,\n    onTypedMessageSubmitted,\n    onFormResponseSubmitted,\n  ]);\n  return salesAgent;\n};\n"],"mappings":";;;;;;;;;;;;AA6BA,MAAM,6CAA0D,OAAU;AAE1E,MAAaA,sBAAyD,EAAE,eAAe;CACrF,MAAM,qCAA0BC,wCAAmB;CACnD,MAAM,8CAAmCC,6CAAwB;CACjE,MAAM,gDAAqCC,0CAAqB;CAChE,MAAM,kBAAkBC,2DAA0B;CAElD,MAAM,EAAE,uBAAuB,0BAA0BC,gDAAsB;CAO/E,MAAM,+CAAoC,YAAY;AAEpD,MAAI,WAAW,WAAW,EACxB;EAGF,MAAM,CAAC,kBAAkB,WAAW,MAAM,GAAG,oBAAoB;AACjE,MAAI;GAKF,MAAM,WAAW,MAAM,sBAJA,sBAAsB;IAC3C,YAAY,CAAC,eAAe;IAC5B,kBAAkB,gBAAgB;IACnC,CAAC,CAC0D;AAE5D,WAAQ,IAAI,YAAY,SAAS;AAEjC,2BAAwB,CAAC,eAAe,QAAQ,CAAC;WAC1C,OAAO;AACd,WAAQ,MAAM,wBAAwB;;IAEvC;EACD;EACA;EACA;EACA,gBAAgB;EAChB;EACA;EACD,CAAC;AAEF,SAAQ,IAAI,uBAAuB,oBAAoB;AACvD,SAAQ,IAAI,cAAc,WAAW;AAKrC,4BAAgB;AACd,MAAI,sBAAsB,EACxB,wBAAuB;AAGzB,UAAQ,IAAI,+BAA+B;IAC1C,CAAC,uBAAuB,oBAAoB,CAAC;AAEhD,QAAO,2CAAC,kBAAkB;EAAS,OAAO;EAAY;GAAsC;;AAG9F,MAAa,sBAAkC;CAC7C,MAAM,mCAAwBC,+BAAa;CAC3C,MAAM,sCAA2BC,kCAAgB;CACjD,MAAM,0CAA+BN,wCAAmB;CACxD,MAAM,sBAAsB;CAC5B,MAAM,oBAAoB;CAC1B,MAAM,gBAAgB;CAEtB,MAAM,EAAE,cAAc,qBAAqB,yBAAyB,4BAClEO,sCAAsB;AA2BxB,iCAzB6C;AAC3C,SAAO;GACL;GACA;GACA;GACA;GACA;GACA;GACA;GACA;GACA;GACA;GACD;IACA;EACD;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACD,CAAC"}
@@ -0,0 +1,22 @@
1
+ import { Message } from "../../application/models/message.cjs";
2
+ import { UserEvent } from "../../application/models/api/userEvent.cjs";
3
+ import { Suggestion } from "../../application/models/api/suggestion.cjs";
4
+ import { SalesAgentChatAPI } from "./chatAPI.cjs";
5
+ import { ReactNode } from "react";
6
+
7
+ //#region src/contexts/salesAgentContext/salesAgentContext.d.ts
8
+ interface SalesAgent extends SalesAgentChatAPI {
9
+ messages: Message[][];
10
+ pendingMessages: UserEvent[];
11
+ suggestions: Suggestion[];
12
+ isResponseStreaming: boolean;
13
+ isPendingResponse: boolean;
14
+ isInitialized: boolean;
15
+ }
16
+ declare const SalesAgentProvider: React.FC<{
17
+ children: ReactNode;
18
+ }>;
19
+ declare const useSalesAgent: () => SalesAgent;
20
+ //#endregion
21
+ export { SalesAgentProvider, useSalesAgent };
22
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2FsZXNBZ2VudENvbnRleHQuZC5jdHMiLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2NvbnRleHRzL3NhbGVzQWdlbnRDb250ZXh0L3NhbGVzQWdlbnRDb250ZXh0LmQudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgTWVzc2FnZSB9IGZyb20gJ3NyYy9hcHBsaWNhdGlvbi9tb2RlbHMvbWVzc2FnZSc7XG5pbXBvcnQgeyBTdWdnZXN0aW9uLCBVc2VyRXZlbnQgfSBmcm9tICdzcmMvYXBwbGljYXRpb24vbW9kZWxzJztcbmltcG9ydCB7IFNhbGVzQWdlbnRDaGF0QVBJIH0gZnJvbSAnLi9jaGF0QVBJJztcbmludGVyZmFjZSBTYWxlc0FnZW50IGV4dGVuZHMgU2FsZXNBZ2VudENoYXRBUEkge1xuICAgIG1lc3NhZ2VzOiBNZXNzYWdlW11bXTtcbiAgICBwZW5kaW5nTWVzc2FnZXM6IFVzZXJFdmVudFtdO1xuICAgIHN1Z2dlc3Rpb25zOiBTdWdnZXN0aW9uW107XG4gICAgaXNSZXNwb25zZVN0cmVhbWluZzogYm9vbGVhbjtcbiAgICBpc1BlbmRpbmdSZXNwb25zZTogYm9vbGVhbjtcbiAgICBpc0luaXRpYWxpemVkOiBib29sZWFuO1xufVxuZXhwb3J0IGRlY2xhcmUgY29uc3QgU2FsZXNBZ2VudFByb3ZpZGVyOiBSZWFjdC5GQzx7XG4gICAgY2hpbGRyZW46IFJlYWN0Tm9kZTtcbn0+O1xuZXhwb3J0IGRlY2xhcmUgY29uc3QgdXNlU2FsZXNBZ2VudDogKCkgPT4gU2FsZXNBZ2VudDtcbmV4cG9ydCB7fTtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUlBLElBQUksYUFBYTtDQUFDO09BQVc7T0FBZTtPQUFHO09BQUE7Q0FBQTtBQUMvQyxJQUFXLHFCQUFjO0NBQUE7T0FBQTtPQUFBLE1BQUE7Q0FBQTtBQUN6QixJQUFXLGdCQUFnQixDQUFDLFdBQUksV0FBQSJ9
@@ -0,0 +1,22 @@
1
+ import { Message } from "../../application/models/message.js";
2
+ import { UserEvent } from "../../application/models/api/userEvent.js";
3
+ import { Suggestion } from "../../application/models/api/suggestion.js";
4
+ import { SalesAgentChatAPI } from "./chatAPI.js";
5
+ import { ReactNode } from "react";
6
+
7
+ //#region src/contexts/salesAgentContext/salesAgentContext.d.ts
8
+ interface SalesAgent extends SalesAgentChatAPI {
9
+ messages: Message[][];
10
+ pendingMessages: UserEvent[];
11
+ suggestions: Suggestion[];
12
+ isResponseStreaming: boolean;
13
+ isPendingResponse: boolean;
14
+ isInitialized: boolean;
15
+ }
16
+ declare const SalesAgentProvider: React.FC<{
17
+ children: ReactNode;
18
+ }>;
19
+ declare const useSalesAgent: () => SalesAgent;
20
+ //#endregion
21
+ export { SalesAgentProvider, useSalesAgent };
22
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2FsZXNBZ2VudENvbnRleHQuZC50cyIsIm5hbWVzIjpbXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29udGV4dHMvc2FsZXNBZ2VudENvbnRleHQvc2FsZXNBZ2VudENvbnRleHQuZC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBNZXNzYWdlIH0gZnJvbSAnc3JjL2FwcGxpY2F0aW9uL21vZGVscy9tZXNzYWdlJztcbmltcG9ydCB7IFN1Z2dlc3Rpb24sIFVzZXJFdmVudCB9IGZyb20gJ3NyYy9hcHBsaWNhdGlvbi9tb2RlbHMnO1xuaW1wb3J0IHsgU2FsZXNBZ2VudENoYXRBUEkgfSBmcm9tICcuL2NoYXRBUEknO1xuaW50ZXJmYWNlIFNhbGVzQWdlbnQgZXh0ZW5kcyBTYWxlc0FnZW50Q2hhdEFQSSB7XG4gICAgbWVzc2FnZXM6IE1lc3NhZ2VbXVtdO1xuICAgIHBlbmRpbmdNZXNzYWdlczogVXNlckV2ZW50W107XG4gICAgc3VnZ2VzdGlvbnM6IFN1Z2dlc3Rpb25bXTtcbiAgICBpc1Jlc3BvbnNlU3RyZWFtaW5nOiBib29sZWFuO1xuICAgIGlzUGVuZGluZ1Jlc3BvbnNlOiBib29sZWFuO1xuICAgIGlzSW5pdGlhbGl6ZWQ6IGJvb2xlYW47XG59XG5leHBvcnQgZGVjbGFyZSBjb25zdCBTYWxlc0FnZW50UHJvdmlkZXI6IFJlYWN0LkZDPHtcbiAgICBjaGlsZHJlbjogUmVhY3ROb2RlO1xufT47XG5leHBvcnQgZGVjbGFyZSBjb25zdCB1c2VTYWxlc0FnZW50OiAoKSA9PiBTYWxlc0FnZW50O1xuZXhwb3J0IHt9O1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBSUEsSUFBSSxhQUFhO0NBQUM7T0FBVztPQUFlO09BQUc7T0FBQTtDQUFBO0FBQy9DLElBQVcscUJBQWM7Q0FBQTtPQUFBO09BQUEsTUFBQTtDQUFBO0FBQ3pCLElBQVcsZ0JBQWdCLENBQUMsV0FBSSxXQUFBIn0=
@@ -0,0 +1,88 @@
1
+ import { messagesAtom, suggestionsAtom } from "../../atoms/chat/chatState.js";
2
+ import { processUserEventAtom, userEventQueueAtom, userQueueEventCountAtom } from "../../atoms/chat/messageQueue.js";
3
+ import { useSystemSettingsContext } from "../../hooks/SystemSettingsContext/useSystemSettingsContext.js";
4
+ import "../../hooks/SystemSettingsContext/index.js";
5
+ import { useSalesAgentChatAPI } from "./chatAPI.js";
6
+ import { useSalesAgentService } from "./salesAgentService.js";
7
+ import { createContext, useCallback, useEffect, useMemo } from "react";
8
+ import { useAtomValue, useSetAtom } from "jotai";
9
+ import { jsx } from "react/jsx-runtime";
10
+
11
+ //#region src/contexts/salesAgentContext/salesAgentContext.tsx
12
+ const SalesAgentContext = createContext(void 0);
13
+ const SalesAgentProvider = ({ children }) => {
14
+ const userEvents = useAtomValue(userEventQueueAtom);
15
+ const userQueueEventCount = useAtomValue(userQueueEventCountAtom);
16
+ const markUserEventsProcessed = useSetAtom(processUserEventAtom);
17
+ const settingsContext = useSystemSettingsContext();
18
+ const { getStreamingResponses, createResponsePayload } = useSalesAgentService();
19
+ const sendMessagesToBackend = useCallback(async () => {
20
+ if (userEvents.length === 0) return;
21
+ const [pendingMessage] = userEvents.slice(0, userQueueEventCount);
22
+ try {
23
+ const response = await getStreamingResponses(createResponsePayload({
24
+ userEvents: [pendingMessage],
25
+ generationParams: settingsContext.generationParams
26
+ }));
27
+ console.log("response", response);
28
+ markUserEventsProcessed([pendingMessage.eventId]);
29
+ } catch (error) {
30
+ console.error("error sending message");
31
+ }
32
+ }, [
33
+ userEvents,
34
+ userQueueEventCount,
35
+ createResponsePayload,
36
+ settingsContext.generationParams,
37
+ getStreamingResponses,
38
+ markUserEventsProcessed
39
+ ]);
40
+ console.log("userQueueEventCount", userQueueEventCount);
41
+ console.log("userEvents", userEvents);
42
+ useEffect(() => {
43
+ if (userQueueEventCount > 0) sendMessagesToBackend();
44
+ console.log("SalesAgentProvider useEffect");
45
+ }, [sendMessagesToBackend, userQueueEventCount]);
46
+ return /* @__PURE__ */ jsx(SalesAgentContext.Provider, {
47
+ value: void 0,
48
+ children
49
+ });
50
+ };
51
+ const useSalesAgent = () => {
52
+ const messages = useAtomValue(messagesAtom);
53
+ const suggestions = useAtomValue(suggestionsAtom);
54
+ const pendingMessages = useAtomValue(userEventQueueAtom);
55
+ const isResponseStreaming = false;
56
+ const isPendingResponse = false;
57
+ const isInitialized = false;
58
+ const { logPageVisit, onSuggestionClicked, onTypedMessageSubmitted, onFormResponseSubmitted } = useSalesAgentChatAPI();
59
+ return useMemo(() => {
60
+ return {
61
+ messages,
62
+ suggestions,
63
+ pendingMessages,
64
+ isResponseStreaming,
65
+ isPendingResponse,
66
+ isInitialized,
67
+ logPageVisit,
68
+ onSuggestionClicked,
69
+ onTypedMessageSubmitted,
70
+ onFormResponseSubmitted
71
+ };
72
+ }, [
73
+ messages,
74
+ suggestions,
75
+ pendingMessages,
76
+ isResponseStreaming,
77
+ isPendingResponse,
78
+ isInitialized,
79
+ logPageVisit,
80
+ onSuggestionClicked,
81
+ onTypedMessageSubmitted,
82
+ onFormResponseSubmitted
83
+ ]);
84
+ };
85
+
86
+ //#endregion
87
+ export { SalesAgentProvider, useSalesAgent };
88
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"salesAgentContext.js","names":["SalesAgentProvider: React.FC<{ children: ReactNode }>"],"sources":["../../../src/contexts/salesAgentContext/salesAgentContext.tsx"],"sourcesContent":["import { useAtomValue, useSetAtom } from 'jotai';\nimport { ReactNode, createContext, useCallback, useEffect, useMemo } from 'react';\nimport { Message } from 'src/application/models/message';\nimport { Suggestion, UserEvent } from 'src/application/models';\nimport { messagesAtom, suggestionsAtom } from 'src/atoms/chat/chatState';\nimport {\n  processUserEventAtom,\n  userEventQueueAtom,\n  userQueueEventCountAtom,\n} from 'src/atoms/chat/messageQueue';\nimport { useSystemSettingsContext } from 'src/hooks/SystemSettingsContext';\nimport { SalesAgentChatAPI, useSalesAgentChatAPI } from './chatAPI';\nimport { useSalesAgentService } from './salesAgentService';\n\ninterface SalesAgent extends SalesAgentChatAPI {\n  // Messages are the full list of all turns\n  messages: Message[][];\n  // Pending messages are messages that the user has clicked/typed but have not yet been sent to the backend.\n  pendingMessages: UserEvent[];\n  // Suggestions are the list of suggestions that the user can click on in response to the most recent message from the backend\n  suggestions: Suggestion[];\n  // True while the response is streaming from the backend\n  isResponseStreaming: boolean;\n  // True while the response is pending from the backend\n  isPendingResponse: boolean;\n  // True when the sales agent is initialized\n  isInitialized: boolean;\n}\n\nconst SalesAgentContext = createContext<SalesAgent | undefined>(undefined);\n\nexport const SalesAgentProvider: React.FC<{ children: ReactNode }> = ({ children }) => {\n  const userEvents = useAtomValue(userEventQueueAtom);\n  const userQueueEventCount = useAtomValue(userQueueEventCountAtom);\n  const markUserEventsProcessed = useSetAtom(processUserEventAtom);\n  const settingsContext = useSystemSettingsContext();\n\n  const { getStreamingResponses, createResponsePayload } = useSalesAgentService();\n\n  // TODO: Ensure that amplitude events are being emitted\n\n  // TODO: Add support for the streaming responses to function\n\n  // TODO: Add support for the hydration of the messages from the backend on initialization\n  const sendMessagesToBackend = useCallback(async () => {\n    // Fast exit if there are no pending messages\n    if (userEvents.length === 0) {\n      return;\n    }\n    // TODO: Support sending multiple messages to the backend in one request\n    const [pendingMessage] = userEvents.slice(0, userQueueEventCount);\n    try {\n      const requestPayload = createResponsePayload({\n        userEvents: [pendingMessage],\n        generationParams: settingsContext.generationParams,\n      });\n      const response = await getStreamingResponses(requestPayload);\n\n      console.log('response', response);\n      // Remove the pending message from the user events\n      markUserEventsProcessed([pendingMessage.eventId]);\n    } catch (error) {\n      console.error('error sending message');\n    }\n  }, [\n    userEvents,\n    userQueueEventCount,\n    createResponsePayload,\n    settingsContext.generationParams,\n    getStreamingResponses,\n    markUserEventsProcessed,\n  ]);\n\n  console.log('userQueueEventCount', userQueueEventCount);\n  console.log('userEvents', userEvents);\n\n  // This is the primary event loop for communicating with the backend API\n  // It will be triggered when there are pending messages to be sent to the backend\n  // It will be responsible for sending the messages to the backend and receiving the responses\n  useEffect(() => {\n    if (userQueueEventCount > 0) {\n      sendMessagesToBackend();\n    }\n    // TODO: Add a suggestion retrieval here (don't get suggestions unless the event queue is empty)\n    console.log('SalesAgentProvider useEffect');\n  }, [sendMessagesToBackend, userQueueEventCount]);\n\n  return <SalesAgentContext.Provider value={undefined}>{children}</SalesAgentContext.Provider>;\n};\n\nexport const useSalesAgent = (): SalesAgent => {\n  const messages = useAtomValue(messagesAtom);\n  const suggestions = useAtomValue(suggestionsAtom);\n  const pendingMessages = useAtomValue(userEventQueueAtom);\n  const isResponseStreaming = false; // useAtomValue(isResponseStreamingAtom);\n  const isPendingResponse = false; // useAtomValue(isPendingResponseAtom);\n  const isInitialized = false; // useAtomValue(isInitializedAtom);\n\n  const { logPageVisit, onSuggestionClicked, onTypedMessageSubmitted, onFormResponseSubmitted } =\n    useSalesAgentChatAPI();\n\n  const salesAgent: SalesAgent = useMemo(() => {\n    return {\n      messages,\n      suggestions,\n      pendingMessages,\n      isResponseStreaming,\n      isPendingResponse,\n      isInitialized,\n      logPageVisit,\n      onSuggestionClicked,\n      onTypedMessageSubmitted,\n      onFormResponseSubmitted,\n    };\n  }, [\n    messages,\n    suggestions,\n    pendingMessages,\n    isResponseStreaming,\n    isPendingResponse,\n    isInitialized,\n    logPageVisit,\n    onSuggestionClicked,\n    onTypedMessageSubmitted,\n    onFormResponseSubmitted,\n  ]);\n  return salesAgent;\n};\n"],"mappings":";;;;;;;;;;;AA6BA,MAAM,oBAAoB,cAAsC,OAAU;AAE1E,MAAaA,sBAAyD,EAAE,eAAe;CACrF,MAAM,aAAa,aAAa,mBAAmB;CACnD,MAAM,sBAAsB,aAAa,wBAAwB;CACjE,MAAM,0BAA0B,WAAW,qBAAqB;CAChE,MAAM,kBAAkB,0BAA0B;CAElD,MAAM,EAAE,uBAAuB,0BAA0B,sBAAsB;CAO/E,MAAM,wBAAwB,YAAY,YAAY;AAEpD,MAAI,WAAW,WAAW,EACxB;EAGF,MAAM,CAAC,kBAAkB,WAAW,MAAM,GAAG,oBAAoB;AACjE,MAAI;GAKF,MAAM,WAAW,MAAM,sBAJA,sBAAsB;IAC3C,YAAY,CAAC,eAAe;IAC5B,kBAAkB,gBAAgB;IACnC,CAAC,CAC0D;AAE5D,WAAQ,IAAI,YAAY,SAAS;AAEjC,2BAAwB,CAAC,eAAe,QAAQ,CAAC;WAC1C,OAAO;AACd,WAAQ,MAAM,wBAAwB;;IAEvC;EACD;EACA;EACA;EACA,gBAAgB;EAChB;EACA;EACD,CAAC;AAEF,SAAQ,IAAI,uBAAuB,oBAAoB;AACvD,SAAQ,IAAI,cAAc,WAAW;AAKrC,iBAAgB;AACd,MAAI,sBAAsB,EACxB,wBAAuB;AAGzB,UAAQ,IAAI,+BAA+B;IAC1C,CAAC,uBAAuB,oBAAoB,CAAC;AAEhD,QAAO,oBAAC,kBAAkB;EAAS,OAAO;EAAY;GAAsC;;AAG9F,MAAa,sBAAkC;CAC7C,MAAM,WAAW,aAAa,aAAa;CAC3C,MAAM,cAAc,aAAa,gBAAgB;CACjD,MAAM,kBAAkB,aAAa,mBAAmB;CACxD,MAAM,sBAAsB;CAC5B,MAAM,oBAAoB;CAC1B,MAAM,gBAAgB;CAEtB,MAAM,EAAE,cAAc,qBAAqB,yBAAyB,4BAClE,sBAAsB;AA2BxB,QAzB+B,cAAc;AAC3C,SAAO;GACL;GACA;GACA;GACA;GACA;GACA;GACA;GACA;GACA;GACA;GACD;IACA;EACD;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACD,CAAC"}
@@ -0,0 +1,99 @@
1
+ const require_rolldown_runtime = require('../../_virtual/rolldown_runtime.cjs');
2
+ const require_useMessageInterceptor = require('../../interceptors/useMessageInterceptor.cjs');
3
+ const require_logger = require('../../application/logging/logger.cjs');
4
+ const require_message = require('../../application/models/message.cjs');
5
+ require('../../application/models/index.cjs');
6
+ const require_atoms_app_index = require('../../atoms/app/index.cjs');
7
+ const require_featureFlagServiceContext = require('../featureFlagServiceContext/featureFlagServiceContext.cjs');
8
+ const require_messageFromResponse = require('../../application/utils/messageFromResponse.cjs');
9
+ require('../../application/utils/index.cjs');
10
+ const require_chatState = require('../../atoms/chat/chatState.cjs');
11
+ require('../featureFlagServiceContext/index.cjs');
12
+ const require_commerce_api = require('../../application/commerce-api.cjs');
13
+ let react = require("react");
14
+ let uuid = require("uuid");
15
+ let jotai = require("jotai");
16
+
17
+ //#region src/contexts/salesAgentContext/salesAgentService.ts
18
+ const getQueryParam = (key) => {
19
+ return new URL(window.location.href).searchParams.get(key);
20
+ };
21
+ const updateMessageState = (message, lastMessage, setMessages) => {
22
+ if (lastMessage == null) {
23
+ setMessages((prev) => [...prev, [message]]);
24
+ return message;
25
+ }
26
+ if (lastMessage.type === require_message.MessageType.Text && message.type === require_message.MessageType.Text) {
27
+ const newMessage = {
28
+ ...lastMessage,
29
+ metadata: {
30
+ ...lastMessage.metadata,
31
+ content: lastMessage.metadata.content + message.metadata.content
32
+ }
33
+ };
34
+ setMessages((prev) => {
35
+ const lastTurn = prev[prev.length - 1];
36
+ return [...prev.slice(0, prev.length - 1), [...lastTurn.slice(0, lastTurn.length - 1), newMessage]];
37
+ });
38
+ return newMessage;
39
+ }
40
+ setMessages((prev) => [...prev.slice(0, prev.length - 1), [...prev[prev.length - 1], message]]);
41
+ return message;
42
+ };
43
+ const processStreamingResponse = async (stream, messageInterceptor, setMessages) => {
44
+ let lastMessage;
45
+ for await (const response of stream) try {
46
+ if (messageInterceptor.intercept(response)) return;
47
+ if (!response) throw new Error("No response from stream");
48
+ const message = require_messageFromResponse.messageFromResponse(response);
49
+ if (!message) throw new Error("Failed to transform API response to client message");
50
+ lastMessage = updateMessageState(message, lastMessage, setMessages);
51
+ } catch (error) {
52
+ require_logger.default.logWarn(`[spiffy-ai] Failed to generate responses from stream`, error, {
53
+ lastResponse: lastMessage,
54
+ response
55
+ });
56
+ }
57
+ };
58
+ const useSalesAgentService = () => {
59
+ const setRequestFailure = (0, jotai.useSetAtom)(require_chatState.requestFailureAtom);
60
+ const setMessages = (0, jotai.useSetAtom)(require_chatState.messagesAtom);
61
+ const messageInterceptor = require_useMessageInterceptor.useMessageInterceptor();
62
+ const featureFlagService = require_featureFlagServiceContext.useFeatureFlagService();
63
+ const context = (0, jotai.useAtomValue)(require_atoms_app_index.appDetailsAtom);
64
+ return {
65
+ createResponsePayload: (0, react.useCallback)(({ userEvents, generationParams }) => {
66
+ const featureFlags = featureFlagService?.featureFlagService?.getFeatureFlags() || {};
67
+ const overrideConfigVersion = getQueryParam("spiffy_config_version") || getQueryParam("envive_config_version") || void 0;
68
+ const overrideModelDatetime = getQueryParam("override_model_datetime") || void 0;
69
+ return {
70
+ id: (0, uuid.v4)(),
71
+ context,
72
+ userEvents,
73
+ featureFlags,
74
+ generationParams,
75
+ overrideConfigVersion,
76
+ overrideModelDatetime
77
+ };
78
+ }, [context, featureFlagService?.featureFlagService]),
79
+ getStreamingResponses: (0, react.useCallback)(async (payload) => {
80
+ console.log("getStreamingResponses payload", JSON.stringify(payload, null, 2));
81
+ const stream = require_commerce_api.default.getNextResponseStreaming(payload);
82
+ try {
83
+ setRequestFailure(false);
84
+ await processStreamingResponse(stream, messageInterceptor, setMessages);
85
+ } catch (e) {
86
+ console.error("error getting streaming responses", e);
87
+ throw e;
88
+ }
89
+ }, [
90
+ setRequestFailure,
91
+ messageInterceptor,
92
+ setMessages
93
+ ])
94
+ };
95
+ };
96
+
97
+ //#endregion
98
+ exports.useSalesAgentService = useSalesAgentService;
99
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"salesAgentService.cjs","names":["MessageType","lastMessage: Message | undefined","messageFromResponse","error: unknown","useSalesAgentService: () => SalesAgentService","requestFailureAtom","messagesAtom","useMessageInterceptor","useFeatureFlagService","appDetailsAtom","CommerceApiClient"],"sources":["../../../src/contexts/salesAgentContext/salesAgentService.ts"],"sourcesContent":["import { useAtomValue, useSetAtom } from 'jotai';\nimport { useCallback } from 'react';\nimport { v4 as uuid } from 'uuid';\nimport CommerceApiClient from 'src/application/commerce-api';\nimport { appDetailsAtom } from 'src/atoms/app';\nimport Logger from 'src/application/logging/logger';\nimport {\n  GenerationParams,\n  Message,\n  MessageType,\n  NextMessageRequest,\n  Response,\n  UserEvent,\n} from 'src/application/models';\nimport { messageFromResponse } from 'src/application/utils';\nimport { messagesAtom, requestFailureAtom } from 'src/atoms/chat/chatState';\nimport { useMessageInterceptor } from 'src/interceptors/useMessageInterceptor';\nimport { useFeatureFlagService } from '../featureFlagServiceContext';\n\ninterface SalesAgentService {\n  createResponsePayload: (payload: {\n    userEvents: UserEvent[];\n    generationParams?: GenerationParams;\n  }) => NextMessageRequest;\n  getStreamingResponses: (payload: NextMessageRequest) => Promise<void>;\n}\n\nexport const getQueryParam = (key: string): string | null => {\n  const urlObj = new URL(window.location.href);\n  return urlObj.searchParams.get(key);\n};\n\nconst updateMessageState = (\n  message: Message,\n  lastMessage: Message,\n  setMessages: (updater: (prev: Message[][]) => Message[][]) => void,\n): Message => {\n  if (lastMessage == null) {\n    setMessages(prev => [...prev, [message]]);\n    return message;\n  }\n  if (lastMessage.type === MessageType.Text && message.type === MessageType.Text) {\n    const newMessage = {\n      ...lastMessage,\n      metadata: {\n        ...lastMessage.metadata,\n        content: lastMessage.metadata.content + message.metadata.content,\n      },\n    };\n    setMessages(prev => {\n      const lastTurn = prev[prev.length - 1];\n      return [\n        ...prev.slice(0, prev.length - 1),\n        [...lastTurn.slice(0, lastTurn.length - 1), newMessage],\n      ];\n    });\n    return newMessage;\n  }\n  setMessages(prev => [...prev.slice(0, prev.length - 1), [...prev[prev.length - 1], message]]);\n  return message;\n};\n\nconst processStreamingResponse = async (\n  stream: AsyncIterable<Response>,\n  messageInterceptor: { intercept: (response?: Response) => boolean | undefined },\n  setMessages: (updater: (prev: Message[][]) => Message[][]) => void,\n): Promise<void> => {\n  let lastMessage: Message | undefined;\n\n  for await (const response of stream) {\n    try {\n      if (messageInterceptor.intercept(response)) {\n        return;\n      }\n\n      if (!response) {\n        throw new Error('No response from stream');\n      }\n      const message = messageFromResponse(response);\n      if (!message) {\n        throw new Error('Failed to transform API response to client message');\n      }\n\n      // No support for ChatSearch messages at the current time.\n      // Perhaps we add support back in the future\n      // if (message.type === MessageType.ProductSearch) {\n      //   handleSearchResults(message);\n      //   hasSearchResults = true;\n      //   setSearchIsLoading(false); // Update search loading immediately when results are detected\n      // }\n\n      lastMessage = updateMessageState(message, lastMessage!, setMessages);\n    } catch (error: unknown) {\n      Logger.logWarn(`[spiffy-ai] Failed to generate responses from stream`, error, {\n        lastResponse: lastMessage,\n        response,\n      });\n    }\n  }\n};\n\nexport const useSalesAgentService: () => SalesAgentService = () => {\n  const setRequestFailure = useSetAtom(requestFailureAtom);\n  const setMessages = useSetAtom(messagesAtom);\n  const messageInterceptor = useMessageInterceptor();\n\n  const featureFlagService = useFeatureFlagService();\n  const context = useAtomValue(appDetailsAtom);\n\n  const createResponsePayload = useCallback(\n    ({\n      userEvents,\n      generationParams,\n    }: {\n      userEvents: UserEvent[];\n      generationParams?: GenerationParams;\n    }): NextMessageRequest => {\n      const featureFlags = featureFlagService?.featureFlagService?.getFeatureFlags() || {};\n\n      const overrideConfigVersion =\n        getQueryParam('spiffy_config_version') ||\n        getQueryParam('envive_config_version') ||\n        undefined;\n      const overrideModelDatetime = getQueryParam('override_model_datetime') || undefined;\n      return {\n        id: uuid(),\n        context,\n        userEvents,\n        featureFlags,\n        generationParams,\n        overrideConfigVersion,\n        overrideModelDatetime,\n      };\n    },\n    [context, featureFlagService?.featureFlagService],\n  );\n\n  const getStreamingResponses = useCallback(\n    async (payload: NextMessageRequest): Promise<void> => {\n      // logPerfMetric(PerfMetricsEvents.FirstResponseStarted);\n      // const startTime = Date.now();\n      console.log('getStreamingResponses payload', JSON.stringify(payload, null, 2));\n      const stream = CommerceApiClient.getNextResponseStreaming(payload);\n\n      try {\n        setRequestFailure(false);\n\n        await processStreamingResponse(stream, messageInterceptor, setMessages);\n\n        // TODO: Add support for the Chrome Extension communication\n        // Log successful next_responses call\n        // const responseTime = Date.now() - startTime;\n        // await logBundleEvent({\n        //   level: 'info',\n        //   event: 'NEXT_RESPONSE_SUCCESS',\n        //   context: {\n        //     type: 'next_responses',\n        //     endpoint: '/v1/next_responses',\n        //     statusCode: 200,\n        //     responseTime,\n        //   },\n        // });\n      } catch (e) {\n        console.error('error getting streaming responses', e);\n        // Log failed next_responses call\n        // const responseTime = Date.now() - startTime;\n        // await logBundleEvent({\n        //   level: 'error',\n        //   event: 'NEXT_RESPONSE_FAILED',\n        //   message: `Failed to get streaming response: ${e}`,\n        //   context: {\n        //     type: 'next_responses',\n        //     endpoint: '/v1/next_responses',\n        //     responseTime,\n        //     error: e instanceof Error ? e.message : String(e),\n        //   },\n        // });\n\n        // handleStreamingError(e, setRequestFailure, setMessages);\n        throw e;\n        // } finally {\n        // logPerfMetric(PerfMetricsEvents.FirstResponseCompleted);\n      }\n    },\n    [\n      // logPerfMetric,\n      setRequestFailure,\n      messageInterceptor,\n      setMessages,\n    ],\n  );\n\n  return {\n    createResponsePayload,\n    getStreamingResponses,\n  };\n};\n"],"mappings":";;;;;;;;;;;;;;;;;AA2BA,MAAa,iBAAiB,QAA+B;AAE3D,QADe,IAAI,IAAI,OAAO,SAAS,KAAK,CAC9B,aAAa,IAAI,IAAI;;AAGrC,MAAM,sBACJ,SACA,aACA,gBACY;AACZ,KAAI,eAAe,MAAM;AACvB,eAAY,SAAQ,CAAC,GAAG,MAAM,CAAC,QAAQ,CAAC,CAAC;AACzC,SAAO;;AAET,KAAI,YAAY,SAASA,4BAAY,QAAQ,QAAQ,SAASA,4BAAY,MAAM;EAC9E,MAAM,aAAa;GACjB,GAAG;GACH,UAAU;IACR,GAAG,YAAY;IACf,SAAS,YAAY,SAAS,UAAU,QAAQ,SAAS;IAC1D;GACF;AACD,eAAY,SAAQ;GAClB,MAAM,WAAW,KAAK,KAAK,SAAS;AACpC,UAAO,CACL,GAAG,KAAK,MAAM,GAAG,KAAK,SAAS,EAAE,EACjC,CAAC,GAAG,SAAS,MAAM,GAAG,SAAS,SAAS,EAAE,EAAE,WAAW,CACxD;IACD;AACF,SAAO;;AAET,cAAY,SAAQ,CAAC,GAAG,KAAK,MAAM,GAAG,KAAK,SAAS,EAAE,EAAE,CAAC,GAAG,KAAK,KAAK,SAAS,IAAI,QAAQ,CAAC,CAAC;AAC7F,QAAO;;AAGT,MAAM,2BAA2B,OAC/B,QACA,oBACA,gBACkB;CAClB,IAAIC;AAEJ,YAAW,MAAM,YAAY,OAC3B,KAAI;AACF,MAAI,mBAAmB,UAAU,SAAS,CACxC;AAGF,MAAI,CAAC,SACH,OAAM,IAAI,MAAM,0BAA0B;EAE5C,MAAM,UAAUC,gDAAoB,SAAS;AAC7C,MAAI,CAAC,QACH,OAAM,IAAI,MAAM,qDAAqD;AAWvE,gBAAc,mBAAmB,SAAS,aAAc,YAAY;UAC7DC,OAAgB;AACvB,yBAAO,QAAQ,wDAAwD,OAAO;GAC5E,cAAc;GACd;GACD,CAAC;;;AAKR,MAAaC,6BAAsD;CACjE,MAAM,0CAA+BC,qCAAmB;CACxD,MAAM,oCAAyBC,+BAAa;CAC5C,MAAM,qBAAqBC,qDAAuB;CAElD,MAAM,qBAAqBC,yDAAuB;CAClD,MAAM,kCAAuBC,uCAAe;AAqF5C,QAAO;EACL,+CAnFC,EACC,YACA,uBAIwB;GACxB,MAAM,eAAe,oBAAoB,oBAAoB,iBAAiB,IAAI,EAAE;GAEpF,MAAM,wBACJ,cAAc,wBAAwB,IACtC,cAAc,wBAAwB,IACtC;GACF,MAAM,wBAAwB,cAAc,0BAA0B,IAAI;AAC1E,UAAO;IACL,kBAAU;IACV;IACA;IACA;IACA;IACA;IACA;IACD;KAEH,CAAC,SAAS,oBAAoB,mBAAmB,CAClD;EA2DC,8CAxDA,OAAO,YAA+C;AAGpD,WAAQ,IAAI,iCAAiC,KAAK,UAAU,SAAS,MAAM,EAAE,CAAC;GAC9E,MAAM,SAASC,6BAAkB,yBAAyB,QAAQ;AAElE,OAAI;AACF,sBAAkB,MAAM;AAExB,UAAM,yBAAyB,QAAQ,oBAAoB,YAAY;YAehE,GAAG;AACV,YAAQ,MAAM,qCAAqC,EAAE;AAgBrD,UAAM;;KAKV;GAEE;GACA;GACA;GACD,CACF;EAKA"}