@envive-ai/react-hooks 0.3.6 → 0.3.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (142) hide show
  1. package/dist/application/commerce-api.cjs +1 -1
  2. package/dist/application/commerce-api.js +1 -1
  3. package/dist/application/models/api/userEvent.d.cts +4 -2
  4. package/dist/application/models/api/userEvent.d.ts +4 -2
  5. package/dist/application/models/graphql/queries/getColorsAndFrontendQuery.cjs +18 -0
  6. package/dist/application/models/graphql/queries/getColorsAndFrontendQuery.js +18 -0
  7. package/dist/application/models/guards/api/isApiFormResponse.cjs +1 -1
  8. package/dist/application/models/guards/api/isApiFormResponse.js +1 -1
  9. package/dist/application/models/guards/api/isApiFormSubmittedResponseAttributes.cjs +1 -1
  10. package/dist/application/models/guards/api/isApiFormSubmittedResponseAttributes.js +1 -1
  11. package/dist/application/models/guards/api/isApiOrderResponseAttributes.cjs +1 -1
  12. package/dist/application/models/guards/api/isApiOrderResponseAttributes.js +1 -1
  13. package/dist/application/models/guards/api/isApiProductResponseAttributes.cjs +1 -1
  14. package/dist/application/models/guards/api/isApiProductResponseAttributes.js +1 -1
  15. package/dist/application/models/guards/api/isApiQueryTypedEventAttributes.cjs +2 -2
  16. package/dist/application/models/guards/api/isApiQueryTypedEventAttributes.js +2 -2
  17. package/dist/application/models/guards/api/isApiResponse.cjs +1 -1
  18. package/dist/application/models/guards/api/isApiResponse.js +1 -1
  19. package/dist/application/utils/analyticsUtils.cjs +1 -1
  20. package/dist/application/utils/analyticsUtils.js +1 -1
  21. package/dist/application/utils/elementObserver.d.cts +2 -2
  22. package/dist/application/utils/elementObserver.d.ts +2 -2
  23. package/dist/atoms/app/variant.d.cts +6 -6
  24. package/dist/atoms/app/variant.d.ts +6 -6
  25. package/dist/atoms/chat/chatState.d.ts +17 -17
  26. package/dist/atoms/chat/form.d.cts +2 -2
  27. package/dist/atoms/chat/form.d.ts +2 -2
  28. package/dist/atoms/chat/index.cjs +1 -3
  29. package/dist/atoms/chat/index.d.cts +4 -5
  30. package/dist/atoms/chat/index.d.ts +4 -5
  31. package/dist/atoms/chat/index.js +2 -3
  32. package/dist/atoms/chat/lastMessage.d.cts +2 -2
  33. package/dist/atoms/chat/lastMessage.d.ts +2 -2
  34. package/dist/atoms/chat/performanceMetrics.d.cts +6 -6
  35. package/dist/atoms/chat/performanceMetrics.d.ts +6 -6
  36. package/dist/atoms/chat/renderedWidgetRefs.d.cts +2 -2
  37. package/dist/atoms/chat/renderedWidgetRefs.d.ts +2 -2
  38. package/dist/atoms/chat/suggestions.d.cts +2 -2
  39. package/dist/atoms/chat/suggestions.d.ts +2 -2
  40. package/dist/atoms/globalSearch/globalSearch.d.cts +5 -5
  41. package/dist/atoms/globalSearch/globalSearch.d.ts +5 -5
  42. package/dist/atoms/org/customerService.d.cts +6 -6
  43. package/dist/atoms/org/customerService.d.ts +6 -6
  44. package/dist/atoms/org/graphqlConfig.d.cts +4 -4
  45. package/dist/atoms/org/graphqlConfig.d.ts +4 -4
  46. package/dist/atoms/org/newOrgConfigAtom.d.cts +2 -2
  47. package/dist/atoms/org/newOrgConfigAtom.d.ts +2 -2
  48. package/dist/atoms/org/orgAnalyticsConfig.d.cts +5 -5
  49. package/dist/atoms/org/orgAnalyticsConfig.d.ts +5 -5
  50. package/dist/atoms/search/chatSearch.d.cts +17 -17
  51. package/dist/atoms/search/chatSearch.d.ts +17 -17
  52. package/dist/atoms/search/searchAPI.d.cts +13 -13
  53. package/dist/atoms/search/searchAPI.d.ts +13 -13
  54. package/dist/atoms/search/types.d.cts +1 -1
  55. package/dist/atoms/widget/chatPreviewLoading.d.cts +2 -2
  56. package/dist/atoms/widget/chatPreviewLoading.d.ts +2 -2
  57. package/dist/contexts/featureFlagContext/featureFlagContext.cjs +1 -1
  58. package/dist/contexts/featureFlagContext/featureFlagContext.js +1 -1
  59. package/dist/contexts/featureFlagServiceContext/featureFlagServiceContext.cjs +1 -1
  60. package/dist/contexts/featureFlagServiceContext/featureFlagServiceContext.js +1 -1
  61. package/dist/contexts/graphqlContext/graphqlContext.cjs +41 -27
  62. package/dist/contexts/graphqlContext/graphqlContext.js +42 -27
  63. package/dist/contexts/graphqlContext/mockV3Config.cjs +47 -45
  64. package/dist/contexts/graphqlContext/mockV3Config.js +5 -3
  65. package/dist/contexts/newOrgConfigContext/newOrgConfigContext.cjs +1 -2
  66. package/dist/contexts/newOrgConfigContext/newOrgConfigContext.js +1 -2
  67. package/dist/contexts/salesAgentContext/chatAPI.cjs +26 -5
  68. package/dist/contexts/salesAgentContext/chatAPI.d.cts +7 -3
  69. package/dist/contexts/salesAgentContext/chatAPI.d.ts +7 -3
  70. package/dist/contexts/salesAgentContext/chatAPI.js +26 -5
  71. package/dist/contexts/salesAgentContext/salesAgentContext.cjs +4 -7
  72. package/dist/contexts/salesAgentContext/salesAgentContext.js +4 -7
  73. package/dist/contexts/salesAgentContext/salesAgentService.cjs +43 -18
  74. package/dist/contexts/salesAgentContext/salesAgentService.js +43 -18
  75. package/dist/contexts/systemSettingsContext/systemSettingsContext.d.cts +2 -2
  76. package/dist/contexts/systemSettingsContext/systemSettingsContext.d.ts +2 -2
  77. package/dist/contexts/types.d.cts +1 -1
  78. package/dist/contexts/types.d.ts +1 -1
  79. package/dist/contexts/typesV3.cjs +1 -1
  80. package/dist/contexts/typesV3.d.cts +4 -4
  81. package/dist/contexts/typesV3.d.ts +4 -4
  82. package/dist/contexts/typesV3.js +1 -1
  83. package/dist/contexts/userIdentityContext/userIdentityContext.cjs +1 -2
  84. package/dist/contexts/userIdentityContext/userIdentityContext.js +1 -2
  85. package/dist/hooks/GrabAndScroll/useGrabAndScroll.d.cts +2 -2
  86. package/dist/hooks/GrabAndScroll/useGrabAndScroll.d.ts +2 -2
  87. package/dist/hooks/GraphQLConfig/useGraphQLConfig.cjs +1 -2
  88. package/dist/hooks/GraphQLConfig/useGraphQLConfig.js +1 -2
  89. package/dist/hooks/Search/useSearchInput.cjs +1 -1
  90. package/dist/hooks/Search/useSearchInput.js +1 -1
  91. package/dist/hooks/utils.d.cts +1 -1
  92. package/dist/hooks/utils.d.ts +1 -1
  93. package/dist/packages/components-v3/dist/ChatHeader/hooks/useGetCloseButtonProperties.cjs +1 -1
  94. package/dist/packages/components-v3/dist/ChatHeader/hooks/useGetCloseButtonProperties.js +1 -1
  95. package/dist/packages/components-v3/dist/Container/Container.cjs +1 -1
  96. package/dist/packages/components-v3/dist/Container/Container.js +1 -1
  97. package/dist/packages/components-v3/dist/FloatingButton/FloatingButton.cjs +2 -0
  98. package/dist/packages/components-v3/dist/FloatingButton/FloatingButton.js +4 -0
  99. package/dist/packages/components-v3/dist/FloatingButton/components/Button.cjs +9 -0
  100. package/dist/packages/components-v3/dist/FloatingButton/components/Button.js +10 -0
  101. package/dist/packages/components-v3/dist/FloatingButton/components/Container.cjs +9 -0
  102. package/dist/packages/components-v3/dist/FloatingButton/components/Container.js +10 -0
  103. package/dist/packages/components-v3/dist/FloatingButton/components/Icon.cjs +3 -0
  104. package/dist/packages/components-v3/dist/FloatingButton/components/Icon.js +5 -0
  105. package/dist/packages/components-v3/dist/FloatingButton/components/Wrapper.cjs +9 -0
  106. package/dist/packages/components-v3/dist/FloatingButton/components/Wrapper.js +10 -0
  107. package/dist/packages/components-v3/dist/FloatingButton/components/index.cjs +4 -0
  108. package/dist/packages/components-v3/dist/FloatingButton/components/index.js +6 -0
  109. package/dist/packages/components-v3/dist/FloatingButton/index.cjs +2 -0
  110. package/dist/packages/components-v3/dist/FloatingButton/index.js +4 -0
  111. package/dist/packages/components-v3/dist/FloatingButton/types/types.cjs +17 -0
  112. package/dist/packages/components-v3/dist/FloatingButton/types/types.js +16 -0
  113. package/dist/packages/components-v3/dist/ImageGallery/components/Layout.cjs +1 -1
  114. package/dist/packages/components-v3/dist/ImageGallery/components/Layout.js +1 -1
  115. package/dist/packages/components-v3/dist/WelcomeMessage/components/SparkleIcon.cjs +1 -1
  116. package/dist/packages/components-v3/dist/WelcomeMessage/components/SparkleIcon.js +1 -1
  117. package/dist/packages/components-v3/dist/utils/CustomIcon.cjs +2 -0
  118. package/dist/packages/components-v3/dist/utils/CustomIcon.js +4 -0
  119. package/dist/services/amplitudeService/amplitudeService.cjs +5 -2
  120. package/dist/services/amplitudeService/amplitudeService.js +5 -2
  121. package/package.json +1 -5
  122. package/src/application/models/api/userEvent.ts +3 -1
  123. package/src/application/models/graphql/queries/getColorsAndFrontendQuery.ts +13 -0
  124. package/src/application/models/guards/api/isApiQueryTypedEventAttributes.ts +6 -1
  125. package/src/atoms/chat/index.ts +0 -1
  126. package/src/contexts/graphqlContext/graphqlContext.tsx +32 -41
  127. package/src/contexts/graphqlContext/mockV3Config.ts +3 -2
  128. package/src/contexts/newOrgConfigContext/newOrgConfigContext.tsx +0 -1
  129. package/src/contexts/salesAgentContext/chatAPI.ts +21 -4
  130. package/src/contexts/salesAgentContext/salesAgentContext.tsx +3 -7
  131. package/src/contexts/salesAgentContext/salesAgentService.ts +36 -11
  132. package/src/contexts/typesV3.ts +3 -4
  133. package/src/contexts/uiConfigContext/__tests__/uiConfigContext.test.tsx +3 -2
  134. package/src/contexts/userIdentityContext/userIdentityContext.tsx +0 -1
  135. package/src/hooks/GraphQLConfig/useGraphQLConfig.ts +0 -1
  136. package/src/services/amplitudeService/__tests__/amplitudeService.test.ts +0 -15
  137. package/src/services/amplitudeService/amplitudeService.ts +2 -1
  138. package/dist/atoms/chat/replies.cjs +0 -46
  139. package/dist/atoms/chat/replies.d.cts +0 -14
  140. package/dist/atoms/chat/replies.d.ts +0 -14
  141. package/dist/atoms/chat/replies.js +0 -45
  142. package/src/atoms/chat/replies.ts +0 -56
@@ -13,7 +13,6 @@ const NewOrgConfigProvider = ({ children, overrideConfig }) => {
13
13
  const orgShortName = (0, jotai.useAtomValue)(require_enviveConfig.orgShortNameAtom);
14
14
  const setNewOrgConfig = (0, jotai.useSetAtom)(require_newOrgConfigAtom.newOrgConfigAtom);
15
15
  const { data: fetchedConfig, loading, error } = require_useGraphQLConfig.useUIConfig();
16
- console.log("NewOrgConfigProvider: newConfig", fetchedConfig, loading, error);
17
16
  const contextValue = (0, react.useMemo)(() => {
18
17
  if (!orgShortName || loading) return {
19
18
  ...fetchedConfig,
@@ -54,4 +53,4 @@ const useNewOrgConfigContext = () => {
54
53
  //#endregion
55
54
  exports.NewOrgConfigProvider = NewOrgConfigProvider;
56
55
  exports.useNewOrgConfigContext = useNewOrgConfigContext;
57
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmV3T3JnQ29uZmlnQ29udGV4dC5janMiLCJuYW1lcyI6WyJOZXdPcmdDb25maWdQcm92aWRlcjogUmVhY3QuRkM8TmV3T3JnQ29uZmlnUHJvdmlkZXJQcm9wcz4iLCJvcmdTaG9ydE5hbWVBdG9tIiwibmV3T3JnQ29uZmlnQXRvbSIsInVzZVVJQ29uZmlnIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2NvbnRleHRzL25ld09yZ0NvbmZpZ0NvbnRleHQvbmV3T3JnQ29uZmlnQ29udGV4dC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IFJlYWN0Tm9kZSwgY3JlYXRlQ29udGV4dCwgdXNlQ29udGV4dCwgdXNlTWVtbyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IHVzZUF0b21WYWx1ZSwgdXNlU2V0QXRvbSB9IGZyb20gJ2pvdGFpJztcbmltcG9ydCB7IHVzZVVJQ29uZmlnIH0gZnJvbSAnc3JjL2hvb2tzL0dyYXBoUUxDb25maWcvdXNlR3JhcGhRTENvbmZpZyc7XG5pbXBvcnQgeyBvcmdTaG9ydE5hbWVBdG9tIH0gZnJvbSAnc3JjL2F0b21zL2Vudml2ZS9lbnZpdmVDb25maWcnO1xuaW1wb3J0IHsgbmV3T3JnQ29uZmlnQXRvbSB9IGZyb20gJ3NyYy9hdG9tcy9vcmcvbmV3T3JnQ29uZmlnQXRvbSc7IC8vIEltcG9ydCBuZXdPcmdDb25maWdBdG9tXG5pbXBvcnQgeyBHcmFwaFFsQ29uZmlnVmFsdWVzIH0gZnJvbSAnLi4vZ3JhcGhxbENvbnRleHQnO1xuXG5leHBvcnQgdHlwZSBOZXdPcmdDb25maWdDb250ZXh0VHlwZSA9IEdyYXBoUWxDb25maWdWYWx1ZXMgJiB7XG4gIGxvYWRpbmc6IGJvb2xlYW47XG4gIGVycm9yOiBFcnJvciB8IG51bGw7XG59O1xuXG5jb25zdCBOZXdPcmdDb25maWdDb250ZXh0ID0gY3JlYXRlQ29udGV4dDxOZXdPcmdDb25maWdDb250ZXh0VHlwZSB8IHVuZGVmaW5lZD4odW5kZWZpbmVkKTtcblxuaW50ZXJmYWNlIE5ld09yZ0NvbmZpZ1Byb3ZpZGVyUHJvcHMge1xuICBjaGlsZHJlbjogUmVhY3ROb2RlO1xuICBvdmVycmlkZUNvbmZpZz86IEdyYXBoUWxDb25maWdWYWx1ZXM7XG59XG5cbmV4cG9ydCBjb25zdCBOZXdPcmdDb25maWdQcm92aWRlcjogUmVhY3QuRkM8TmV3T3JnQ29uZmlnUHJvdmlkZXJQcm9wcz4gPSAoe1xuICBjaGlsZHJlbixcbiAgb3ZlcnJpZGVDb25maWcsXG59KSA9PiB7XG4gIGNvbnN0IG9yZ1Nob3J0TmFtZSA9IHVzZUF0b21WYWx1ZShvcmdTaG9ydE5hbWVBdG9tKTtcbiAgY29uc3Qgc2V0TmV3T3JnQ29uZmlnID0gdXNlU2V0QXRvbShuZXdPcmdDb25maWdBdG9tKTtcblxuICBjb25zdCB7IGRhdGE6IGZldGNoZWRDb25maWcsIGxvYWRpbmcsIGVycm9yIH0gPSB1c2VVSUNvbmZpZygpO1xuICBjb25zb2xlLmxvZygnTmV3T3JnQ29uZmlnUHJvdmlkZXI6IG5ld0NvbmZpZycsIGZldGNoZWRDb25maWcsIGxvYWRpbmcsIGVycm9yKTtcblxuICBjb25zdCBjb250ZXh0VmFsdWUgPSB1c2VNZW1vKCgpID0+IHtcbiAgICBpZiAoIW9yZ1Nob3J0TmFtZSB8fCBsb2FkaW5nKSB7XG4gICAgICByZXR1cm4geyAuLi5mZXRjaGVkQ29uZmlnLCBsb2FkaW5nOiB0cnVlLCBlcnJvcjogbnVsbCB9O1xuICAgIH1cblxuICAgIGlmIChlcnJvcikge1xuICAgICAgcmV0dXJuIHsgLi4uZmV0Y2hlZENvbmZpZywgbG9hZGluZzogZmFsc2UsIGVycm9yIH07XG4gICAgfVxuXG4gICAgY29uc3QgYWN0aXZlQ29uZmlnID0gb3ZlcnJpZGVDb25maWcgfHwgZmV0Y2hlZENvbmZpZztcblxuICAgIHNldE5ld09yZ0NvbmZpZyhhY3RpdmVDb25maWcpO1xuICAgIHJldHVybiB7IC4uLmFjdGl2ZUNvbmZpZywgbG9hZGluZzogZmFsc2UsIGVycm9yOiBudWxsIH07XG4gIH0sIFtvcmdTaG9ydE5hbWUsIGxvYWRpbmcsIGVycm9yLCBzZXROZXdPcmdDb25maWcsIGZldGNoZWRDb25maWcsIG92ZXJyaWRlQ29uZmlnXSk7XG5cbiAgcmV0dXJuIChcbiAgICA8TmV3T3JnQ29uZmlnQ29udGV4dC5Qcm92aWRlciB2YWx1ZT17Y29udGV4dFZhbHVlfT57Y2hpbGRyZW59PC9OZXdPcmdDb25maWdDb250ZXh0LlByb3ZpZGVyPlxuICApO1xufTtcblxuZXhwb3J0IGNvbnN0IHVzZU5ld09yZ0NvbmZpZ0NvbnRleHQgPSAoKSA9PiB7XG4gIGNvbnN0IGNvbnRleHQgPSB1c2VDb250ZXh0KE5ld09yZ0NvbmZpZ0NvbnRleHQpO1xuICBpZiAoY29udGV4dCA9PT0gdW5kZWZpbmVkKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCd1c2VOZXdPcmdDb25maWdDb250ZXh0IG11c3QgYmUgdXNlZCB3aXRoaW4gYSBOZXdPcmdDb25maWdQcm92aWRlcicpO1xuICB9XG4gIHJldHVybiBjb250ZXh0O1xufTtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7OztBQVlBLE1BQU0sK0NBQXlFLE9BQVU7QUFPekYsTUFBYUEsd0JBQTZELEVBQ3hFLFVBQ0EscUJBQ0k7Q0FDSixNQUFNLHVDQUE0QkMsc0NBQWlCO0NBQ25ELE1BQU0sd0NBQTZCQywwQ0FBaUI7Q0FFcEQsTUFBTSxFQUFFLE1BQU0sZUFBZSxTQUFTLFVBQVVDLHNDQUFhO0FBQzdELFNBQVEsSUFBSSxtQ0FBbUMsZUFBZSxTQUFTLE1BQU07Q0FFN0UsTUFBTSx3Q0FBNkI7QUFDakMsTUFBSSxDQUFDLGdCQUFnQixRQUNuQixRQUFPO0dBQUUsR0FBRztHQUFlLFNBQVM7R0FBTSxPQUFPO0dBQU07QUFHekQsTUFBSSxNQUNGLFFBQU87R0FBRSxHQUFHO0dBQWUsU0FBUztHQUFPO0dBQU87RUFHcEQsTUFBTSxlQUFlLGtCQUFrQjtBQUV2QyxrQkFBZ0IsYUFBYTtBQUM3QixTQUFPO0dBQUUsR0FBRztHQUFjLFNBQVM7R0FBTyxPQUFPO0dBQU07SUFDdEQ7RUFBQztFQUFjO0VBQVM7RUFBTztFQUFpQjtFQUFlO0VBQWUsQ0FBQztBQUVsRixRQUNFLDJDQUFDLG9CQUFvQjtFQUFTLE9BQU87RUFBZTtHQUF3Qzs7QUFJaEcsTUFBYSwrQkFBK0I7Q0FDMUMsTUFBTSxnQ0FBcUIsb0JBQW9CO0FBQy9DLEtBQUksWUFBWSxPQUNkLE9BQU0sSUFBSSxNQUFNLG9FQUFvRTtBQUV0RixRQUFPIn0=
56
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmV3T3JnQ29uZmlnQ29udGV4dC5janMiLCJuYW1lcyI6WyJOZXdPcmdDb25maWdQcm92aWRlcjogUmVhY3QuRkM8TmV3T3JnQ29uZmlnUHJvdmlkZXJQcm9wcz4iLCJvcmdTaG9ydE5hbWVBdG9tIiwibmV3T3JnQ29uZmlnQXRvbSIsInVzZVVJQ29uZmlnIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2NvbnRleHRzL25ld09yZ0NvbmZpZ0NvbnRleHQvbmV3T3JnQ29uZmlnQ29udGV4dC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IFJlYWN0Tm9kZSwgY3JlYXRlQ29udGV4dCwgdXNlQ29udGV4dCwgdXNlTWVtbyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IHVzZUF0b21WYWx1ZSwgdXNlU2V0QXRvbSB9IGZyb20gJ2pvdGFpJztcbmltcG9ydCB7IHVzZVVJQ29uZmlnIH0gZnJvbSAnc3JjL2hvb2tzL0dyYXBoUUxDb25maWcvdXNlR3JhcGhRTENvbmZpZyc7XG5pbXBvcnQgeyBvcmdTaG9ydE5hbWVBdG9tIH0gZnJvbSAnc3JjL2F0b21zL2Vudml2ZS9lbnZpdmVDb25maWcnO1xuaW1wb3J0IHsgbmV3T3JnQ29uZmlnQXRvbSB9IGZyb20gJ3NyYy9hdG9tcy9vcmcvbmV3T3JnQ29uZmlnQXRvbSc7IC8vIEltcG9ydCBuZXdPcmdDb25maWdBdG9tXG5pbXBvcnQgeyBHcmFwaFFsQ29uZmlnVmFsdWVzIH0gZnJvbSAnLi4vZ3JhcGhxbENvbnRleHQnO1xuXG5leHBvcnQgdHlwZSBOZXdPcmdDb25maWdDb250ZXh0VHlwZSA9IEdyYXBoUWxDb25maWdWYWx1ZXMgJiB7XG4gIGxvYWRpbmc6IGJvb2xlYW47XG4gIGVycm9yOiBFcnJvciB8IG51bGw7XG59O1xuXG5jb25zdCBOZXdPcmdDb25maWdDb250ZXh0ID0gY3JlYXRlQ29udGV4dDxOZXdPcmdDb25maWdDb250ZXh0VHlwZSB8IHVuZGVmaW5lZD4odW5kZWZpbmVkKTtcblxuaW50ZXJmYWNlIE5ld09yZ0NvbmZpZ1Byb3ZpZGVyUHJvcHMge1xuICBjaGlsZHJlbjogUmVhY3ROb2RlO1xuICBvdmVycmlkZUNvbmZpZz86IEdyYXBoUWxDb25maWdWYWx1ZXM7XG59XG5cbmV4cG9ydCBjb25zdCBOZXdPcmdDb25maWdQcm92aWRlcjogUmVhY3QuRkM8TmV3T3JnQ29uZmlnUHJvdmlkZXJQcm9wcz4gPSAoe1xuICBjaGlsZHJlbixcbiAgb3ZlcnJpZGVDb25maWcsXG59KSA9PiB7XG4gIGNvbnN0IG9yZ1Nob3J0TmFtZSA9IHVzZUF0b21WYWx1ZShvcmdTaG9ydE5hbWVBdG9tKTtcbiAgY29uc3Qgc2V0TmV3T3JnQ29uZmlnID0gdXNlU2V0QXRvbShuZXdPcmdDb25maWdBdG9tKTtcblxuICBjb25zdCB7IGRhdGE6IGZldGNoZWRDb25maWcsIGxvYWRpbmcsIGVycm9yIH0gPSB1c2VVSUNvbmZpZygpO1xuXG4gIGNvbnN0IGNvbnRleHRWYWx1ZSA9IHVzZU1lbW8oKCkgPT4ge1xuICAgIGlmICghb3JnU2hvcnROYW1lIHx8IGxvYWRpbmcpIHtcbiAgICAgIHJldHVybiB7IC4uLmZldGNoZWRDb25maWcsIGxvYWRpbmc6IHRydWUsIGVycm9yOiBudWxsIH07XG4gICAgfVxuXG4gICAgaWYgKGVycm9yKSB7XG4gICAgICByZXR1cm4geyAuLi5mZXRjaGVkQ29uZmlnLCBsb2FkaW5nOiBmYWxzZSwgZXJyb3IgfTtcbiAgICB9XG5cbiAgICBjb25zdCBhY3RpdmVDb25maWcgPSBvdmVycmlkZUNvbmZpZyB8fCBmZXRjaGVkQ29uZmlnO1xuXG4gICAgc2V0TmV3T3JnQ29uZmlnKGFjdGl2ZUNvbmZpZyk7XG4gICAgcmV0dXJuIHsgLi4uYWN0aXZlQ29uZmlnLCBsb2FkaW5nOiBmYWxzZSwgZXJyb3I6IG51bGwgfTtcbiAgfSwgW29yZ1Nob3J0TmFtZSwgbG9hZGluZywgZXJyb3IsIHNldE5ld09yZ0NvbmZpZywgZmV0Y2hlZENvbmZpZywgb3ZlcnJpZGVDb25maWddKTtcblxuICByZXR1cm4gKFxuICAgIDxOZXdPcmdDb25maWdDb250ZXh0LlByb3ZpZGVyIHZhbHVlPXtjb250ZXh0VmFsdWV9PntjaGlsZHJlbn08L05ld09yZ0NvbmZpZ0NvbnRleHQuUHJvdmlkZXI+XG4gICk7XG59O1xuXG5leHBvcnQgY29uc3QgdXNlTmV3T3JnQ29uZmlnQ29udGV4dCA9ICgpID0+IHtcbiAgY29uc3QgY29udGV4dCA9IHVzZUNvbnRleHQoTmV3T3JnQ29uZmlnQ29udGV4dCk7XG4gIGlmIChjb250ZXh0ID09PSB1bmRlZmluZWQpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ3VzZU5ld09yZ0NvbmZpZ0NvbnRleHQgbXVzdCBiZSB1c2VkIHdpdGhpbiBhIE5ld09yZ0NvbmZpZ1Byb3ZpZGVyJyk7XG4gIH1cbiAgcmV0dXJuIGNvbnRleHQ7XG59O1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7O0FBWUEsTUFBTSwrQ0FBeUUsT0FBVTtBQU96RixNQUFhQSx3QkFBNkQsRUFDeEUsVUFDQSxxQkFDSTtDQUNKLE1BQU0sdUNBQTRCQyxzQ0FBaUI7Q0FDbkQsTUFBTSx3Q0FBNkJDLDBDQUFpQjtDQUVwRCxNQUFNLEVBQUUsTUFBTSxlQUFlLFNBQVMsVUFBVUMsc0NBQWE7Q0FFN0QsTUFBTSx3Q0FBNkI7QUFDakMsTUFBSSxDQUFDLGdCQUFnQixRQUNuQixRQUFPO0dBQUUsR0FBRztHQUFlLFNBQVM7R0FBTSxPQUFPO0dBQU07QUFHekQsTUFBSSxNQUNGLFFBQU87R0FBRSxHQUFHO0dBQWUsU0FBUztHQUFPO0dBQU87RUFHcEQsTUFBTSxlQUFlLGtCQUFrQjtBQUV2QyxrQkFBZ0IsYUFBYTtBQUM3QixTQUFPO0dBQUUsR0FBRztHQUFjLFNBQVM7R0FBTyxPQUFPO0dBQU07SUFDdEQ7RUFBQztFQUFjO0VBQVM7RUFBTztFQUFpQjtFQUFlO0VBQWUsQ0FBQztBQUVsRixRQUNFLDJDQUFDLG9CQUFvQjtFQUFTLE9BQU87RUFBZTtHQUF3Qzs7QUFJaEcsTUFBYSwrQkFBK0I7Q0FDMUMsTUFBTSxnQ0FBcUIsb0JBQW9CO0FBQy9DLEtBQUksWUFBWSxPQUNkLE9BQU0sSUFBSSxNQUFNLG9FQUFvRTtBQUV0RixRQUFPIn0=
@@ -11,7 +11,6 @@ const NewOrgConfigProvider = ({ children, overrideConfig }) => {
11
11
  const orgShortName = useAtomValue(orgShortNameAtom);
12
12
  const setNewOrgConfig = useSetAtom(newOrgConfigAtom);
13
13
  const { data: fetchedConfig, loading, error } = useUIConfig();
14
- console.log("NewOrgConfigProvider: newConfig", fetchedConfig, loading, error);
15
14
  const contextValue = useMemo(() => {
16
15
  if (!orgShortName || loading) return {
17
16
  ...fetchedConfig,
@@ -51,4 +50,4 @@ const useNewOrgConfigContext = () => {
51
50
 
52
51
  //#endregion
53
52
  export { NewOrgConfigProvider, useNewOrgConfigContext };
54
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmV3T3JnQ29uZmlnQ29udGV4dC5qcyIsIm5hbWVzIjpbIk5ld09yZ0NvbmZpZ1Byb3ZpZGVyOiBSZWFjdC5GQzxOZXdPcmdDb25maWdQcm92aWRlclByb3BzPiJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb250ZXh0cy9uZXdPcmdDb25maWdDb250ZXh0L25ld09yZ0NvbmZpZ0NvbnRleHQudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCwgeyBSZWFjdE5vZGUsIGNyZWF0ZUNvbnRleHQsIHVzZUNvbnRleHQsIHVzZU1lbW8gfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyB1c2VBdG9tVmFsdWUsIHVzZVNldEF0b20gfSBmcm9tICdqb3RhaSc7XG5pbXBvcnQgeyB1c2VVSUNvbmZpZyB9IGZyb20gJ3NyYy9ob29rcy9HcmFwaFFMQ29uZmlnL3VzZUdyYXBoUUxDb25maWcnO1xuaW1wb3J0IHsgb3JnU2hvcnROYW1lQXRvbSB9IGZyb20gJ3NyYy9hdG9tcy9lbnZpdmUvZW52aXZlQ29uZmlnJztcbmltcG9ydCB7IG5ld09yZ0NvbmZpZ0F0b20gfSBmcm9tICdzcmMvYXRvbXMvb3JnL25ld09yZ0NvbmZpZ0F0b20nOyAvLyBJbXBvcnQgbmV3T3JnQ29uZmlnQXRvbVxuaW1wb3J0IHsgR3JhcGhRbENvbmZpZ1ZhbHVlcyB9IGZyb20gJy4uL2dyYXBocWxDb250ZXh0JztcblxuZXhwb3J0IHR5cGUgTmV3T3JnQ29uZmlnQ29udGV4dFR5cGUgPSBHcmFwaFFsQ29uZmlnVmFsdWVzICYge1xuICBsb2FkaW5nOiBib29sZWFuO1xuICBlcnJvcjogRXJyb3IgfCBudWxsO1xufTtcblxuY29uc3QgTmV3T3JnQ29uZmlnQ29udGV4dCA9IGNyZWF0ZUNvbnRleHQ8TmV3T3JnQ29uZmlnQ29udGV4dFR5cGUgfCB1bmRlZmluZWQ+KHVuZGVmaW5lZCk7XG5cbmludGVyZmFjZSBOZXdPcmdDb25maWdQcm92aWRlclByb3BzIHtcbiAgY2hpbGRyZW46IFJlYWN0Tm9kZTtcbiAgb3ZlcnJpZGVDb25maWc/OiBHcmFwaFFsQ29uZmlnVmFsdWVzO1xufVxuXG5leHBvcnQgY29uc3QgTmV3T3JnQ29uZmlnUHJvdmlkZXI6IFJlYWN0LkZDPE5ld09yZ0NvbmZpZ1Byb3ZpZGVyUHJvcHM+ID0gKHtcbiAgY2hpbGRyZW4sXG4gIG92ZXJyaWRlQ29uZmlnLFxufSkgPT4ge1xuICBjb25zdCBvcmdTaG9ydE5hbWUgPSB1c2VBdG9tVmFsdWUob3JnU2hvcnROYW1lQXRvbSk7XG4gIGNvbnN0IHNldE5ld09yZ0NvbmZpZyA9IHVzZVNldEF0b20obmV3T3JnQ29uZmlnQXRvbSk7XG5cbiAgY29uc3QgeyBkYXRhOiBmZXRjaGVkQ29uZmlnLCBsb2FkaW5nLCBlcnJvciB9ID0gdXNlVUlDb25maWcoKTtcbiAgY29uc29sZS5sb2coJ05ld09yZ0NvbmZpZ1Byb3ZpZGVyOiBuZXdDb25maWcnLCBmZXRjaGVkQ29uZmlnLCBsb2FkaW5nLCBlcnJvcik7XG5cbiAgY29uc3QgY29udGV4dFZhbHVlID0gdXNlTWVtbygoKSA9PiB7XG4gICAgaWYgKCFvcmdTaG9ydE5hbWUgfHwgbG9hZGluZykge1xuICAgICAgcmV0dXJuIHsgLi4uZmV0Y2hlZENvbmZpZywgbG9hZGluZzogdHJ1ZSwgZXJyb3I6IG51bGwgfTtcbiAgICB9XG5cbiAgICBpZiAoZXJyb3IpIHtcbiAgICAgIHJldHVybiB7IC4uLmZldGNoZWRDb25maWcsIGxvYWRpbmc6IGZhbHNlLCBlcnJvciB9O1xuICAgIH1cblxuICAgIGNvbnN0IGFjdGl2ZUNvbmZpZyA9IG92ZXJyaWRlQ29uZmlnIHx8IGZldGNoZWRDb25maWc7XG5cbiAgICBzZXROZXdPcmdDb25maWcoYWN0aXZlQ29uZmlnKTtcbiAgICByZXR1cm4geyAuLi5hY3RpdmVDb25maWcsIGxvYWRpbmc6IGZhbHNlLCBlcnJvcjogbnVsbCB9O1xuICB9LCBbb3JnU2hvcnROYW1lLCBsb2FkaW5nLCBlcnJvciwgc2V0TmV3T3JnQ29uZmlnLCBmZXRjaGVkQ29uZmlnLCBvdmVycmlkZUNvbmZpZ10pO1xuXG4gIHJldHVybiAoXG4gICAgPE5ld09yZ0NvbmZpZ0NvbnRleHQuUHJvdmlkZXIgdmFsdWU9e2NvbnRleHRWYWx1ZX0+e2NoaWxkcmVufTwvTmV3T3JnQ29uZmlnQ29udGV4dC5Qcm92aWRlcj5cbiAgKTtcbn07XG5cbmV4cG9ydCBjb25zdCB1c2VOZXdPcmdDb25maWdDb250ZXh0ID0gKCkgPT4ge1xuICBjb25zdCBjb250ZXh0ID0gdXNlQ29udGV4dChOZXdPcmdDb25maWdDb250ZXh0KTtcbiAgaWYgKGNvbnRleHQgPT09IHVuZGVmaW5lZCkge1xuICAgIHRocm93IG5ldyBFcnJvcigndXNlTmV3T3JnQ29uZmlnQ29udGV4dCBtdXN0IGJlIHVzZWQgd2l0aGluIGEgTmV3T3JnQ29uZmlnUHJvdmlkZXInKTtcbiAgfVxuICByZXR1cm4gY29udGV4dDtcbn07XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7O0FBWUEsTUFBTSxzQkFBc0IsY0FBbUQsT0FBVTtBQU96RixNQUFhQSx3QkFBNkQsRUFDeEUsVUFDQSxxQkFDSTtDQUNKLE1BQU0sZUFBZSxhQUFhLGlCQUFpQjtDQUNuRCxNQUFNLGtCQUFrQixXQUFXLGlCQUFpQjtDQUVwRCxNQUFNLEVBQUUsTUFBTSxlQUFlLFNBQVMsVUFBVSxhQUFhO0FBQzdELFNBQVEsSUFBSSxtQ0FBbUMsZUFBZSxTQUFTLE1BQU07Q0FFN0UsTUFBTSxlQUFlLGNBQWM7QUFDakMsTUFBSSxDQUFDLGdCQUFnQixRQUNuQixRQUFPO0dBQUUsR0FBRztHQUFlLFNBQVM7R0FBTSxPQUFPO0dBQU07QUFHekQsTUFBSSxNQUNGLFFBQU87R0FBRSxHQUFHO0dBQWUsU0FBUztHQUFPO0dBQU87RUFHcEQsTUFBTSxlQUFlLGtCQUFrQjtBQUV2QyxrQkFBZ0IsYUFBYTtBQUM3QixTQUFPO0dBQUUsR0FBRztHQUFjLFNBQVM7R0FBTyxPQUFPO0dBQU07SUFDdEQ7RUFBQztFQUFjO0VBQVM7RUFBTztFQUFpQjtFQUFlO0VBQWUsQ0FBQztBQUVsRixRQUNFLG9CQUFDLG9CQUFvQjtFQUFTLE9BQU87RUFBZTtHQUF3Qzs7QUFJaEcsTUFBYSwrQkFBK0I7Q0FDMUMsTUFBTSxVQUFVLFdBQVcsb0JBQW9CO0FBQy9DLEtBQUksWUFBWSxPQUNkLE9BQU0sSUFBSSxNQUFNLG9FQUFvRTtBQUV0RixRQUFPIn0=
53
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmV3T3JnQ29uZmlnQ29udGV4dC5qcyIsIm5hbWVzIjpbIk5ld09yZ0NvbmZpZ1Byb3ZpZGVyOiBSZWFjdC5GQzxOZXdPcmdDb25maWdQcm92aWRlclByb3BzPiJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb250ZXh0cy9uZXdPcmdDb25maWdDb250ZXh0L25ld09yZ0NvbmZpZ0NvbnRleHQudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCwgeyBSZWFjdE5vZGUsIGNyZWF0ZUNvbnRleHQsIHVzZUNvbnRleHQsIHVzZU1lbW8gfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyB1c2VBdG9tVmFsdWUsIHVzZVNldEF0b20gfSBmcm9tICdqb3RhaSc7XG5pbXBvcnQgeyB1c2VVSUNvbmZpZyB9IGZyb20gJ3NyYy9ob29rcy9HcmFwaFFMQ29uZmlnL3VzZUdyYXBoUUxDb25maWcnO1xuaW1wb3J0IHsgb3JnU2hvcnROYW1lQXRvbSB9IGZyb20gJ3NyYy9hdG9tcy9lbnZpdmUvZW52aXZlQ29uZmlnJztcbmltcG9ydCB7IG5ld09yZ0NvbmZpZ0F0b20gfSBmcm9tICdzcmMvYXRvbXMvb3JnL25ld09yZ0NvbmZpZ0F0b20nOyAvLyBJbXBvcnQgbmV3T3JnQ29uZmlnQXRvbVxuaW1wb3J0IHsgR3JhcGhRbENvbmZpZ1ZhbHVlcyB9IGZyb20gJy4uL2dyYXBocWxDb250ZXh0JztcblxuZXhwb3J0IHR5cGUgTmV3T3JnQ29uZmlnQ29udGV4dFR5cGUgPSBHcmFwaFFsQ29uZmlnVmFsdWVzICYge1xuICBsb2FkaW5nOiBib29sZWFuO1xuICBlcnJvcjogRXJyb3IgfCBudWxsO1xufTtcblxuY29uc3QgTmV3T3JnQ29uZmlnQ29udGV4dCA9IGNyZWF0ZUNvbnRleHQ8TmV3T3JnQ29uZmlnQ29udGV4dFR5cGUgfCB1bmRlZmluZWQ+KHVuZGVmaW5lZCk7XG5cbmludGVyZmFjZSBOZXdPcmdDb25maWdQcm92aWRlclByb3BzIHtcbiAgY2hpbGRyZW46IFJlYWN0Tm9kZTtcbiAgb3ZlcnJpZGVDb25maWc/OiBHcmFwaFFsQ29uZmlnVmFsdWVzO1xufVxuXG5leHBvcnQgY29uc3QgTmV3T3JnQ29uZmlnUHJvdmlkZXI6IFJlYWN0LkZDPE5ld09yZ0NvbmZpZ1Byb3ZpZGVyUHJvcHM+ID0gKHtcbiAgY2hpbGRyZW4sXG4gIG92ZXJyaWRlQ29uZmlnLFxufSkgPT4ge1xuICBjb25zdCBvcmdTaG9ydE5hbWUgPSB1c2VBdG9tVmFsdWUob3JnU2hvcnROYW1lQXRvbSk7XG4gIGNvbnN0IHNldE5ld09yZ0NvbmZpZyA9IHVzZVNldEF0b20obmV3T3JnQ29uZmlnQXRvbSk7XG5cbiAgY29uc3QgeyBkYXRhOiBmZXRjaGVkQ29uZmlnLCBsb2FkaW5nLCBlcnJvciB9ID0gdXNlVUlDb25maWcoKTtcblxuICBjb25zdCBjb250ZXh0VmFsdWUgPSB1c2VNZW1vKCgpID0+IHtcbiAgICBpZiAoIW9yZ1Nob3J0TmFtZSB8fCBsb2FkaW5nKSB7XG4gICAgICByZXR1cm4geyAuLi5mZXRjaGVkQ29uZmlnLCBsb2FkaW5nOiB0cnVlLCBlcnJvcjogbnVsbCB9O1xuICAgIH1cblxuICAgIGlmIChlcnJvcikge1xuICAgICAgcmV0dXJuIHsgLi4uZmV0Y2hlZENvbmZpZywgbG9hZGluZzogZmFsc2UsIGVycm9yIH07XG4gICAgfVxuXG4gICAgY29uc3QgYWN0aXZlQ29uZmlnID0gb3ZlcnJpZGVDb25maWcgfHwgZmV0Y2hlZENvbmZpZztcblxuICAgIHNldE5ld09yZ0NvbmZpZyhhY3RpdmVDb25maWcpO1xuICAgIHJldHVybiB7IC4uLmFjdGl2ZUNvbmZpZywgbG9hZGluZzogZmFsc2UsIGVycm9yOiBudWxsIH07XG4gIH0sIFtvcmdTaG9ydE5hbWUsIGxvYWRpbmcsIGVycm9yLCBzZXROZXdPcmdDb25maWcsIGZldGNoZWRDb25maWcsIG92ZXJyaWRlQ29uZmlnXSk7XG5cbiAgcmV0dXJuIChcbiAgICA8TmV3T3JnQ29uZmlnQ29udGV4dC5Qcm92aWRlciB2YWx1ZT17Y29udGV4dFZhbHVlfT57Y2hpbGRyZW59PC9OZXdPcmdDb25maWdDb250ZXh0LlByb3ZpZGVyPlxuICApO1xufTtcblxuZXhwb3J0IGNvbnN0IHVzZU5ld09yZ0NvbmZpZ0NvbnRleHQgPSAoKSA9PiB7XG4gIGNvbnN0IGNvbnRleHQgPSB1c2VDb250ZXh0KE5ld09yZ0NvbmZpZ0NvbnRleHQpO1xuICBpZiAoY29udGV4dCA9PT0gdW5kZWZpbmVkKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCd1c2VOZXdPcmdDb25maWdDb250ZXh0IG11c3QgYmUgdXNlZCB3aXRoaW4gYSBOZXdPcmdDb25maWdQcm92aWRlcicpO1xuICB9XG4gIHJldHVybiBjb250ZXh0O1xufTtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7QUFZQSxNQUFNLHNCQUFzQixjQUFtRCxPQUFVO0FBT3pGLE1BQWFBLHdCQUE2RCxFQUN4RSxVQUNBLHFCQUNJO0NBQ0osTUFBTSxlQUFlLGFBQWEsaUJBQWlCO0NBQ25ELE1BQU0sa0JBQWtCLFdBQVcsaUJBQWlCO0NBRXBELE1BQU0sRUFBRSxNQUFNLGVBQWUsU0FBUyxVQUFVLGFBQWE7Q0FFN0QsTUFBTSxlQUFlLGNBQWM7QUFDakMsTUFBSSxDQUFDLGdCQUFnQixRQUNuQixRQUFPO0dBQUUsR0FBRztHQUFlLFNBQVM7R0FBTSxPQUFPO0dBQU07QUFHekQsTUFBSSxNQUNGLFFBQU87R0FBRSxHQUFHO0dBQWUsU0FBUztHQUFPO0dBQU87RUFHcEQsTUFBTSxlQUFlLGtCQUFrQjtBQUV2QyxrQkFBZ0IsYUFBYTtBQUM3QixTQUFPO0dBQUUsR0FBRztHQUFjLFNBQVM7R0FBTyxPQUFPO0dBQU07SUFDdEQ7RUFBQztFQUFjO0VBQVM7RUFBTztFQUFpQjtFQUFlO0VBQWUsQ0FBQztBQUVsRixRQUNFLG9CQUFDLG9CQUFvQjtFQUFTLE9BQU87RUFBZTtHQUF3Qzs7QUFJaEcsTUFBYSwrQkFBK0I7Q0FDMUMsTUFBTSxVQUFVLFdBQVcsb0JBQW9CO0FBQy9DLEtBQUksWUFBWSxPQUNkLE9BQU0sSUFBSSxNQUFNLG9FQUFvRTtBQUV0RixRQUFPIn0=
@@ -1,5 +1,8 @@
1
1
  const require_rolldown_runtime = require('../../_virtual/rolldown_runtime.cjs');
2
+ const require_amplitudeService = require('../../services/amplitudeService/amplitudeService.cjs');
3
+ const require_amplitudeContext = require('../amplitudeContext/amplitudeContext.cjs');
2
4
  const require_messageQueue = require('../../atoms/chat/messageQueue.cjs');
5
+ require('../amplitudeContext/index.cjs');
3
6
  let __spiffy_ai_commerce_api_client = require("@spiffy-ai/commerce-api-client");
4
7
  let uuid = require("uuid");
5
8
  let react = require("react");
@@ -8,6 +11,7 @@ let jotai = require("jotai");
8
11
  //#region src/contexts/salesAgentContext/chatAPI.ts
9
12
  const useSalesAgentChatAPI = () => {
10
13
  const queueUserEvent = (0, jotai.useSetAtom)(require_messageQueue.queueUserEventAtom);
14
+ const { trackEvent } = require_amplitudeContext.useAmplitude();
11
15
  return {
12
16
  logPageVisit: (0, react.useCallback)(({ pageVisitCategory }) => {
13
17
  queueUserEvent({
@@ -24,6 +28,13 @@ const useSalesAgentChatAPI = () => {
24
28
  queueUserEvent(event);
25
29
  }, [queueUserEvent]),
26
30
  onSuggestionClicked: (0, react.useCallback)((suggestion) => {
31
+ trackEvent({
32
+ eventName: require_amplitudeService.SpiffyMetricsEventName.ChatSuggestionClicked,
33
+ eventProps: {
34
+ suggestionId: suggestion.id,
35
+ content: suggestion.content
36
+ }
37
+ });
27
38
  queueUserEvent({
28
39
  eventId: (0, uuid.v4)(),
29
40
  category: __spiffy_ai_commerce_api_client.UserEventCategory.SuggestionClicked,
@@ -33,19 +44,29 @@ const useSalesAgentChatAPI = () => {
33
44
  content: suggestion.content
34
45
  }
35
46
  });
36
- }, [queueUserEvent]),
37
- onTypedMessageSubmitted: (0, react.useCallback)(({ query }) => {
47
+ }, [queueUserEvent, trackEvent]),
48
+ onTypedMessageSubmitted: (0, react.useCallback)(({ query, userTyped }) => {
49
+ trackEvent({
50
+ eventName: require_amplitudeService.SpiffyMetricsEventName.ChatUserMessageInput,
51
+ eventProps: {
52
+ query,
53
+ userTyped
54
+ }
55
+ });
38
56
  queueUserEvent({
39
57
  eventId: (0, uuid.v4)(),
40
58
  category: __spiffy_ai_commerce_api_client.UserEventCategory.QueryTyped,
41
59
  createdAt: (/* @__PURE__ */ new Date()).toISOString(),
42
- attributes: { query }
60
+ attributes: {
61
+ query,
62
+ userTyped
63
+ }
43
64
  });
44
- }, [queueUserEvent]),
65
+ }, [queueUserEvent, trackEvent]),
45
66
  onFormResponseSubmitted: (0, react.useCallback)(() => {}, [])
46
67
  };
47
68
  };
48
69
 
49
70
  //#endregion
50
71
  exports.useSalesAgentChatAPI = useSalesAgentChatAPI;
51
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhdEFQSS5janMiLCJuYW1lcyI6WyJxdWV1ZVVzZXJFdmVudEF0b20iLCJVc2VyRXZlbnRDYXRlZ29yeSJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb250ZXh0cy9zYWxlc0FnZW50Q29udGV4dC9jaGF0QVBJLnRzIl0sInNvdXJjZXNDb250ZW50IjpbIi8vIFRoaXMgY29tcG9uZW50IHdpbGwgaW50ZXJhY3Qgd2l0aCB0aGUgYmFja2VuZCBBUEkgdG8gZ2V0IHRoZSByZXNwb25zZXMgZnJvbSB0aGUgc2FsZXMgYWdlbnQuXG5cbmltcG9ydCB7IFBhZ2VWaXNpdENhdGVnb3J5LCBVc2VyRXZlbnRDYXRlZ29yeSB9IGZyb20gJ0BzcGlmZnktYWkvY29tbWVyY2UtYXBpLWNsaWVudCc7XG5pbXBvcnQgeyBTdWdnZXN0aW9uLCBVc2VyRXZlbnQgfSBmcm9tICdzcmMvYXBwbGljYXRpb24vbW9kZWxzJztcbmltcG9ydCB7IHVzZVNldEF0b20gfSBmcm9tICdqb3RhaSc7XG5pbXBvcnQgeyB1c2VDYWxsYmFjayB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IHY0IGFzIHV1aWQgfSBmcm9tICd1dWlkJztcbmltcG9ydCB7IHF1ZXVlVXNlckV2ZW50QXRvbSB9IGZyb20gJ3NyYy9hdG9tcy9jaGF0L21lc3NhZ2VRdWV1ZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2FsZXNBZ2VudENoYXRBUEkge1xuICBsb2dQYWdlVmlzaXQ6ICh7IHBhZ2VWaXNpdENhdGVnb3J5IH06IHsgcGFnZVZpc2l0Q2F0ZWdvcnk6IFBhZ2VWaXNpdENhdGVnb3J5IH0pID0+IHZvaWQ7XG4gIGxvZ1VzZXJFdmVudDogKGV2ZW50OiBVc2VyRXZlbnQpID0+IHZvaWQ7XG4gIG9uU3VnZ2VzdGlvbkNsaWNrZWQ6IChzdWdnZXN0aW9uOiBTdWdnZXN0aW9uKSA9PiB2b2lkO1xuICBvblR5cGVkTWVzc2FnZVN1Ym1pdHRlZDogKHsgcXVlcnkgfTogeyBxdWVyeTogc3RyaW5nIH0pID0+IHZvaWQ7XG4gIG9uRm9ybVJlc3BvbnNlU3VibWl0dGVkOiAoZm9ybVJlc3BvbnNlOiBhbnkpID0+IHZvaWQ7IC8vIFRPRE86IEZpZ3VyZSBvdXQgdGhlIHJpZ2h0IHR5cGVcbn1cblxuZXhwb3J0IGNvbnN0IHVzZVNhbGVzQWdlbnRDaGF0QVBJID0gKCkgPT4ge1xuICAvLyBUT0RPOiBFYWNoIG9mIHRoZXNlIGZ1bmN0aW9ucyB3aWxsIHRyaWdnZXIgYm90aCB0aGUgbmVjZXNzYXJ5IGFtcGxpdHVkZSBldmVudHMgYW5kIGluaXRpYXRlIHRoZVxuICAvLyBuZWNlc3NhcnkgYWN0aW9ucyB0byB0cmlnZ2VyIHRoZSBiYWNrZW5kIEFQSVxuICBjb25zdCBxdWV1ZVVzZXJFdmVudCA9IHVzZVNldEF0b20ocXVldWVVc2VyRXZlbnRBdG9tKTtcblxuICBjb25zdCBsb2dQYWdlVmlzaXQgPSB1c2VDYWxsYmFjayhcbiAgICAoeyBwYWdlVmlzaXRDYXRlZ29yeSB9OiB7IHBhZ2VWaXNpdENhdGVnb3J5OiBQYWdlVmlzaXRDYXRlZ29yeSB9KSA9PiB7XG4gICAgICBjb25zdCBldmVudDogVXNlckV2ZW50ID0ge1xuICAgICAgICBldmVudElkOiB1dWlkKCksXG4gICAgICAgIGNhdGVnb3J5OiBVc2VyRXZlbnRDYXRlZ29yeS5QYWdlVmlzaXQsXG4gICAgICAgIGNyZWF0ZWRBdDogbmV3IERhdGUoKS50b0lTT1N0cmluZygpLFxuICAgICAgICBhdHRyaWJ1dGVzOiB7XG4gICAgICAgICAgdXJsOiB3aW5kb3cubG9jYXRpb24uaHJlZixcbiAgICAgICAgICBwYWdlVmlzaXRDYXRlZ29yeSxcbiAgICAgICAgfSxcbiAgICAgIH07XG4gICAgICBxdWV1ZVVzZXJFdmVudChldmVudCk7XG4gICAgfSxcbiAgICBbcXVldWVVc2VyRXZlbnRdLFxuICApO1xuXG4gIGNvbnN0IGxvZ1VzZXJFdmVudCA9IHVzZUNhbGxiYWNrKFxuICAgIChldmVudDogVXNlckV2ZW50KSA9PiB7XG4gICAgICBxdWV1ZVVzZXJFdmVudChldmVudCk7XG4gICAgfSxcbiAgICBbcXVldWVVc2VyRXZlbnRdLFxuICApO1xuICBjb25zdCBvblN1Z2dlc3Rpb25DbGlja2VkID0gdXNlQ2FsbGJhY2soXG4gICAgKHN1Z2dlc3Rpb246IFN1Z2dlc3Rpb24pID0+IHtcbiAgICAgIGNvbnN0IGV2ZW50OiBVc2VyRXZlbnQgPSB7XG4gICAgICAgIGV2ZW50SWQ6IHV1aWQoKSxcbiAgICAgICAgY2F0ZWdvcnk6IFVzZXJFdmVudENhdGVnb3J5LlN1Z2dlc3Rpb25DbGlja2VkLFxuICAgICAgICBjcmVhdGVkQXQ6IG5ldyBEYXRlKCkudG9JU09TdHJpbmcoKSxcbiAgICAgICAgYXR0cmlidXRlczoge1xuICAgICAgICAgIHN1Z2dlc3Rpb25JZDogc3VnZ2VzdGlvbi5pZCxcbiAgICAgICAgICBjb250ZW50OiBzdWdnZXN0aW9uLmNvbnRlbnQsXG4gICAgICAgIH0sXG4gICAgICB9O1xuICAgICAgcXVldWVVc2VyRXZlbnQoZXZlbnQpO1xuICAgIH0sXG4gICAgW3F1ZXVlVXNlckV2ZW50XSxcbiAgKTtcbiAgY29uc3Qgb25UeXBlZE1lc3NhZ2VTdWJtaXR0ZWQgPSB1c2VDYWxsYmFjayhcbiAgICAoeyBxdWVyeSB9OiB7IHF1ZXJ5OiBzdHJpbmcgfSkgPT4ge1xuICAgICAgY29uc3QgZXZlbnQ6IFVzZXJFdmVudCA9IHtcbiAgICAgICAgZXZlbnRJZDogdXVpZCgpLFxuICAgICAgICBjYXRlZ29yeTogVXNlckV2ZW50Q2F0ZWdvcnkuUXVlcnlUeXBlZCxcbiAgICAgICAgY3JlYXRlZEF0OiBuZXcgRGF0ZSgpLnRvSVNPU3RyaW5nKCksXG4gICAgICAgIGF0dHJpYnV0ZXM6IHtcbiAgICAgICAgICBxdWVyeSxcbiAgICAgICAgfSxcbiAgICAgIH07XG4gICAgICBxdWV1ZVVzZXJFdmVudChldmVudCk7XG4gICAgfSxcbiAgICBbcXVldWVVc2VyRXZlbnRdLFxuICApO1xuICBjb25zdCBvbkZvcm1SZXNwb25zZVN1Ym1pdHRlZCA9IHVzZUNhbGxiYWNrKCgpID0+IHtcbiAgICAvLyBUT0RPOiBJbXBsZW1lbnQgdGhlIGZvcm0gcmVzcG9uc2Ugc3VibWl0dGVkXG4gIH0sIFtdKTtcblxuICByZXR1cm4ge1xuICAgIGxvZ1BhZ2VWaXNpdCxcbiAgICBsb2dVc2VyRXZlbnQsXG4gICAgb25TdWdnZXN0aW9uQ2xpY2tlZCxcbiAgICBvblR5cGVkTWVzc2FnZVN1Ym1pdHRlZCxcbiAgICBvbkZvcm1SZXNwb25zZVN1Ym1pdHRlZCxcbiAgfTtcbn07XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7O0FBaUJBLE1BQWEsNkJBQTZCO0NBR3hDLE1BQU0sdUNBQTRCQSx3Q0FBbUI7QUF5RHJELFFBQU87RUFDTCxzQ0F2REMsRUFBRSx3QkFBa0U7QUFVbkUsa0JBVHlCO0lBQ3ZCLHVCQUFlO0lBQ2YsVUFBVUMsa0RBQWtCO0lBQzVCLDRCQUFXLElBQUksTUFBTSxFQUFDLGFBQWE7SUFDbkMsWUFBWTtLQUNWLEtBQUssT0FBTyxTQUFTO0tBQ3JCO0tBQ0Q7SUFDRixDQUNvQjtLQUV2QixDQUFDLGVBQWUsQ0FDakI7RUEyQ0Msc0NBeENDLFVBQXFCO0FBQ3BCLGtCQUFlLE1BQU07S0FFdkIsQ0FBQyxlQUFlLENBQ2pCO0VBcUNDLDZDQW5DQyxlQUEyQjtBQVUxQixrQkFUeUI7SUFDdkIsdUJBQWU7SUFDZixVQUFVQSxrREFBa0I7SUFDNUIsNEJBQVcsSUFBSSxNQUFNLEVBQUMsYUFBYTtJQUNuQyxZQUFZO0tBQ1YsY0FBYyxXQUFXO0tBQ3pCLFNBQVMsV0FBVztLQUNyQjtJQUNGLENBQ29CO0tBRXZCLENBQUMsZUFBZSxDQUNqQjtFQXVCQyxpREFyQkMsRUFBRSxZQUErQjtBQVNoQyxrQkFSeUI7SUFDdkIsdUJBQWU7SUFDZixVQUFVQSxrREFBa0I7SUFDNUIsNEJBQVcsSUFBSSxNQUFNLEVBQUMsYUFBYTtJQUNuQyxZQUFZLEVBQ1YsT0FDRDtJQUNGLENBQ29CO0tBRXZCLENBQUMsZUFBZSxDQUNqQjtFQVVDLHNEQVRnRCxJQUUvQyxFQUFFLENBQUM7RUFRTCJ9
72
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhdEFQSS5janMiLCJuYW1lcyI6WyJxdWV1ZVVzZXJFdmVudEF0b20iLCJ1c2VBbXBsaXR1ZGUiLCJVc2VyRXZlbnRDYXRlZ29yeSIsIlNwaWZmeU1ldHJpY3NFdmVudE5hbWUiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29udGV4dHMvc2FsZXNBZ2VudENvbnRleHQvY2hhdEFQSS50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvLyBUaGlzIGNvbXBvbmVudCB3aWxsIGludGVyYWN0IHdpdGggdGhlIGJhY2tlbmQgQVBJIHRvIGdldCB0aGUgcmVzcG9uc2VzIGZyb20gdGhlIHNhbGVzIGFnZW50LlxuXG5pbXBvcnQgeyBQYWdlVmlzaXRDYXRlZ29yeSwgVXNlckV2ZW50Q2F0ZWdvcnkgfSBmcm9tICdAc3BpZmZ5LWFpL2NvbW1lcmNlLWFwaS1jbGllbnQnO1xuaW1wb3J0IHsgU3VnZ2VzdGlvbiwgVXNlckV2ZW50IH0gZnJvbSAnc3JjL2FwcGxpY2F0aW9uL21vZGVscyc7XG5pbXBvcnQgeyB1c2VTZXRBdG9tIH0gZnJvbSAnam90YWknO1xuaW1wb3J0IHsgdXNlQ2FsbGJhY2sgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyB2NCBhcyB1dWlkIH0gZnJvbSAndXVpZCc7XG5pbXBvcnQgeyBxdWV1ZVVzZXJFdmVudEF0b20gfSBmcm9tICdzcmMvYXRvbXMvY2hhdC9tZXNzYWdlUXVldWUnO1xuaW1wb3J0IHsgU3BpZmZ5TWV0cmljc0V2ZW50TmFtZSwgdXNlQW1wbGl0dWRlIH0gZnJvbSAnLi4vYW1wbGl0dWRlQ29udGV4dCc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2FsZXNBZ2VudENoYXRBUEkge1xuICBsb2dQYWdlVmlzaXQ6ICh7IHBhZ2VWaXNpdENhdGVnb3J5IH06IHsgcGFnZVZpc2l0Q2F0ZWdvcnk6IFBhZ2VWaXNpdENhdGVnb3J5IH0pID0+IHZvaWQ7XG4gIGxvZ1VzZXJFdmVudDogKGV2ZW50OiBVc2VyRXZlbnQpID0+IHZvaWQ7XG4gIG9uU3VnZ2VzdGlvbkNsaWNrZWQ6IChzdWdnZXN0aW9uOiBTdWdnZXN0aW9uKSA9PiB2b2lkO1xuICBvblR5cGVkTWVzc2FnZVN1Ym1pdHRlZDogKHsgcXVlcnksIHVzZXJUeXBlZCB9OiB7IHF1ZXJ5OiBzdHJpbmc7IHVzZXJUeXBlZDogYm9vbGVhbiB9KSA9PiB2b2lkO1xuICBvbkZvcm1SZXNwb25zZVN1Ym1pdHRlZDogKGZvcm1SZXNwb25zZTogYW55KSA9PiB2b2lkOyAvLyBUT0RPOiBGaWd1cmUgb3V0IHRoZSByaWdodCB0eXBlXG59XG5cbmV4cG9ydCBjb25zdCB1c2VTYWxlc0FnZW50Q2hhdEFQSSA9ICgpID0+IHtcbiAgLy8gVE9ETzogRWFjaCBvZiB0aGVzZSBmdW5jdGlvbnMgd2lsbCB0cmlnZ2VyIGJvdGggdGhlIG5lY2Vzc2FyeSBhbXBsaXR1ZGUgZXZlbnRzIGFuZCBpbml0aWF0ZSB0aGVcbiAgLy8gbmVjZXNzYXJ5IGFjdGlvbnMgdG8gdHJpZ2dlciB0aGUgYmFja2VuZCBBUElcbiAgY29uc3QgcXVldWVVc2VyRXZlbnQgPSB1c2VTZXRBdG9tKHF1ZXVlVXNlckV2ZW50QXRvbSk7XG4gIGNvbnN0IHsgdHJhY2tFdmVudCB9ID0gdXNlQW1wbGl0dWRlKCk7XG5cbiAgY29uc3QgbG9nUGFnZVZpc2l0ID0gdXNlQ2FsbGJhY2soXG4gICAgKHsgcGFnZVZpc2l0Q2F0ZWdvcnkgfTogeyBwYWdlVmlzaXRDYXRlZ29yeTogUGFnZVZpc2l0Q2F0ZWdvcnkgfSkgPT4ge1xuICAgICAgY29uc3QgZXZlbnQ6IFVzZXJFdmVudCA9IHtcbiAgICAgICAgZXZlbnRJZDogdXVpZCgpLFxuICAgICAgICBjYXRlZ29yeTogVXNlckV2ZW50Q2F0ZWdvcnkuUGFnZVZpc2l0LFxuICAgICAgICBjcmVhdGVkQXQ6IG5ldyBEYXRlKCkudG9JU09TdHJpbmcoKSxcbiAgICAgICAgYXR0cmlidXRlczoge1xuICAgICAgICAgIHVybDogd2luZG93LmxvY2F0aW9uLmhyZWYsXG4gICAgICAgICAgcGFnZVZpc2l0Q2F0ZWdvcnksXG4gICAgICAgIH0sXG4gICAgICB9O1xuICAgICAgcXVldWVVc2VyRXZlbnQoZXZlbnQpO1xuICAgIH0sXG4gICAgW3F1ZXVlVXNlckV2ZW50XSxcbiAgKTtcblxuICBjb25zdCBsb2dVc2VyRXZlbnQgPSB1c2VDYWxsYmFjayhcbiAgICAoZXZlbnQ6IFVzZXJFdmVudCkgPT4ge1xuICAgICAgcXVldWVVc2VyRXZlbnQoZXZlbnQpO1xuICAgIH0sXG4gICAgW3F1ZXVlVXNlckV2ZW50XSxcbiAgKTtcbiAgY29uc3Qgb25TdWdnZXN0aW9uQ2xpY2tlZCA9IHVzZUNhbGxiYWNrKFxuICAgIChzdWdnZXN0aW9uOiBTdWdnZXN0aW9uKSA9PiB7XG4gICAgICB0cmFja0V2ZW50KHtcbiAgICAgICAgZXZlbnROYW1lOiBTcGlmZnlNZXRyaWNzRXZlbnROYW1lLkNoYXRTdWdnZXN0aW9uQ2xpY2tlZCxcbiAgICAgICAgZXZlbnRQcm9wczoge1xuICAgICAgICAgIHN1Z2dlc3Rpb25JZDogc3VnZ2VzdGlvbi5pZCxcbiAgICAgICAgICBjb250ZW50OiBzdWdnZXN0aW9uLmNvbnRlbnQsXG4gICAgICAgIH0sXG4gICAgICB9KTtcbiAgICAgIGNvbnN0IGV2ZW50OiBVc2VyRXZlbnQgPSB7XG4gICAgICAgIGV2ZW50SWQ6IHV1aWQoKSxcbiAgICAgICAgY2F0ZWdvcnk6IFVzZXJFdmVudENhdGVnb3J5LlN1Z2dlc3Rpb25DbGlja2VkLFxuICAgICAgICBjcmVhdGVkQXQ6IG5ldyBEYXRlKCkudG9JU09TdHJpbmcoKSxcbiAgICAgICAgYXR0cmlidXRlczoge1xuICAgICAgICAgIHN1Z2dlc3Rpb25JZDogc3VnZ2VzdGlvbi5pZCxcbiAgICAgICAgICBjb250ZW50OiBzdWdnZXN0aW9uLmNvbnRlbnQsXG4gICAgICAgIH0sXG4gICAgICB9O1xuICAgICAgcXVldWVVc2VyRXZlbnQoZXZlbnQpO1xuICAgIH0sXG4gICAgW3F1ZXVlVXNlckV2ZW50LCB0cmFja0V2ZW50XSxcbiAgKTtcbiAgY29uc3Qgb25UeXBlZE1lc3NhZ2VTdWJtaXR0ZWQgPSB1c2VDYWxsYmFjayhcbiAgICAoeyBxdWVyeSwgdXNlclR5cGVkIH06IHsgcXVlcnk6IHN0cmluZzsgdXNlclR5cGVkOiBib29sZWFuIH0pID0+IHtcbiAgICAgIHRyYWNrRXZlbnQoe1xuICAgICAgICBldmVudE5hbWU6IFNwaWZmeU1ldHJpY3NFdmVudE5hbWUuQ2hhdFVzZXJNZXNzYWdlSW5wdXQsXG4gICAgICAgIGV2ZW50UHJvcHM6IHtcbiAgICAgICAgICBxdWVyeSxcbiAgICAgICAgICB1c2VyVHlwZWQsXG4gICAgICAgIH0sXG4gICAgICB9KTtcbiAgICAgIGNvbnN0IGV2ZW50OiBVc2VyRXZlbnQgPSB7XG4gICAgICAgIGV2ZW50SWQ6IHV1aWQoKSxcbiAgICAgICAgY2F0ZWdvcnk6IFVzZXJFdmVudENhdGVnb3J5LlF1ZXJ5VHlwZWQsXG4gICAgICAgIGNyZWF0ZWRBdDogbmV3IERhdGUoKS50b0lTT1N0cmluZygpLFxuICAgICAgICBhdHRyaWJ1dGVzOiB7XG4gICAgICAgICAgcXVlcnksXG4gICAgICAgICAgdXNlclR5cGVkLFxuICAgICAgICB9LFxuICAgICAgfTtcbiAgICAgIHF1ZXVlVXNlckV2ZW50KGV2ZW50KTtcbiAgICB9LFxuICAgIFtxdWV1ZVVzZXJFdmVudCwgdHJhY2tFdmVudF0sXG4gICk7XG4gIGNvbnN0IG9uRm9ybVJlc3BvbnNlU3VibWl0dGVkID0gdXNlQ2FsbGJhY2soKCkgPT4ge1xuICAgIC8vIFRPRE86IEltcGxlbWVudCB0aGUgZm9ybSByZXNwb25zZSBzdWJtaXR0ZWRcbiAgfSwgW10pO1xuXG4gIHJldHVybiB7XG4gICAgbG9nUGFnZVZpc2l0LFxuICAgIGxvZ1VzZXJFdmVudCxcbiAgICBvblN1Z2dlc3Rpb25DbGlja2VkLFxuICAgIG9uVHlwZWRNZXNzYWdlU3VibWl0dGVkLFxuICAgIG9uRm9ybVJlc3BvbnNlU3VibWl0dGVkLFxuICB9O1xufTtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7QUFrQkEsTUFBYSw2QkFBNkI7Q0FHeEMsTUFBTSx1Q0FBNEJBLHdDQUFtQjtDQUNyRCxNQUFNLEVBQUUsZUFBZUMsdUNBQWM7QUF3RXJDLFFBQU87RUFDTCxzQ0F0RUMsRUFBRSx3QkFBa0U7QUFVbkUsa0JBVHlCO0lBQ3ZCLHVCQUFlO0lBQ2YsVUFBVUMsa0RBQWtCO0lBQzVCLDRCQUFXLElBQUksTUFBTSxFQUFDLGFBQWE7SUFDbkMsWUFBWTtLQUNWLEtBQUssT0FBTyxTQUFTO0tBQ3JCO0tBQ0Q7SUFDRixDQUNvQjtLQUV2QixDQUFDLGVBQWUsQ0FDakI7RUEwREMsc0NBdkRDLFVBQXFCO0FBQ3BCLGtCQUFlLE1BQU07S0FFdkIsQ0FBQyxlQUFlLENBQ2pCO0VBb0RDLDZDQWxEQyxlQUEyQjtBQUMxQixjQUFXO0lBQ1QsV0FBV0MsZ0RBQXVCO0lBQ2xDLFlBQVk7S0FDVixjQUFjLFdBQVc7S0FDekIsU0FBUyxXQUFXO0tBQ3JCO0lBQ0YsQ0FBQztBQVVGLGtCQVR5QjtJQUN2Qix1QkFBZTtJQUNmLFVBQVVELGtEQUFrQjtJQUM1Qiw0QkFBVyxJQUFJLE1BQU0sRUFBQyxhQUFhO0lBQ25DLFlBQVk7S0FDVixjQUFjLFdBQVc7S0FDekIsU0FBUyxXQUFXO0tBQ3JCO0lBQ0YsQ0FDb0I7S0FFdkIsQ0FBQyxnQkFBZ0IsV0FBVyxDQUM3QjtFQStCQyxpREE3QkMsRUFBRSxPQUFPLGdCQUF1RDtBQUMvRCxjQUFXO0lBQ1QsV0FBV0MsZ0RBQXVCO0lBQ2xDLFlBQVk7S0FDVjtLQUNBO0tBQ0Q7SUFDRixDQUFDO0FBVUYsa0JBVHlCO0lBQ3ZCLHVCQUFlO0lBQ2YsVUFBVUQsa0RBQWtCO0lBQzVCLDRCQUFXLElBQUksTUFBTSxFQUFDLGFBQWE7SUFDbkMsWUFBWTtLQUNWO0tBQ0E7S0FDRDtJQUNGLENBQ29CO0tBRXZCLENBQUMsZ0JBQWdCLFdBQVcsQ0FDN0I7RUFVQyxzREFUZ0QsSUFFL0MsRUFBRSxDQUFDO0VBUUwifQ==
@@ -12,9 +12,11 @@ interface SalesAgentChatAPI {
12
12
  logUserEvent: (event: UserEvent$1) => void;
13
13
  onSuggestionClicked: (suggestion: Suggestion$1) => void;
14
14
  onTypedMessageSubmitted: ({
15
- query
15
+ query,
16
+ userTyped
16
17
  }: {
17
18
  query: string;
19
+ userTyped: boolean;
18
20
  }) => void;
19
21
  onFormResponseSubmitted: (formResponse: any) => void;
20
22
  }
@@ -27,12 +29,14 @@ declare const useSalesAgentChatAPI: () => {
27
29
  logUserEvent: (event: UserEvent$1) => void;
28
30
  onSuggestionClicked: (suggestion: Suggestion$1) => void;
29
31
  onTypedMessageSubmitted: ({
30
- query
32
+ query,
33
+ userTyped
31
34
  }: {
32
35
  query: string;
36
+ userTyped: boolean;
33
37
  }) => void;
34
38
  onFormResponseSubmitted: () => void;
35
39
  };
36
40
  //#endregion
37
41
  export { SalesAgentChatAPI, useSalesAgentChatAPI };
38
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhdEFQSS5kLmN0cyIsIm5hbWVzIjpbXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29udGV4dHMvc2FsZXNBZ2VudENvbnRleHQvY2hhdEFQSS5kLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBhZ2VWaXNpdENhdGVnb3J5IH0gZnJvbSAnQHNwaWZmeS1haS9jb21tZXJjZS1hcGktY2xpZW50JztcbmltcG9ydCB7IFN1Z2dlc3Rpb24sIFVzZXJFdmVudCB9IGZyb20gJ3NyYy9hcHBsaWNhdGlvbi9tb2RlbHMnO1xuZXhwb3J0IGludGVyZmFjZSBTYWxlc0FnZW50Q2hhdEFQSSB7XG4gICAgbG9nUGFnZVZpc2l0OiAoeyBwYWdlVmlzaXRDYXRlZ29yeSB9OiB7XG4gICAgICAgIHBhZ2VWaXNpdENhdGVnb3J5OiBQYWdlVmlzaXRDYXRlZ29yeTtcbiAgICB9KSA9PiB2b2lkO1xuICAgIGxvZ1VzZXJFdmVudDogKGV2ZW50OiBVc2VyRXZlbnQpID0+IHZvaWQ7XG4gICAgb25TdWdnZXN0aW9uQ2xpY2tlZDogKHN1Z2dlc3Rpb246IFN1Z2dlc3Rpb24pID0+IHZvaWQ7XG4gICAgb25UeXBlZE1lc3NhZ2VTdWJtaXR0ZWQ6ICh7IHF1ZXJ5IH06IHtcbiAgICAgICAgcXVlcnk6IHN0cmluZztcbiAgICB9KSA9PiB2b2lkO1xuICAgIG9uRm9ybVJlc3BvbnNlU3VibWl0dGVkOiAoZm9ybVJlc3BvbnNlOiBhbnkpID0+IHZvaWQ7XG59XG5leHBvcnQgZGVjbGFyZSBjb25zdCB1c2VTYWxlc0FnZW50Q2hhdEFQSTogKCkgPT4ge1xuICAgIGxvZ1BhZ2VWaXNpdDogKHsgcGFnZVZpc2l0Q2F0ZWdvcnkgfToge1xuICAgICAgICBwYWdlVmlzaXRDYXRlZ29yeTogUGFnZVZpc2l0Q2F0ZWdvcnk7XG4gICAgfSkgPT4gdm9pZDtcbiAgICBsb2dVc2VyRXZlbnQ6IChldmVudDogVXNlckV2ZW50KSA9PiB2b2lkO1xuICAgIG9uU3VnZ2VzdGlvbkNsaWNrZWQ6IChzdWdnZXN0aW9uOiBTdWdnZXN0aW9uKSA9PiB2b2lkO1xuICAgIG9uVHlwZWRNZXNzYWdlU3VibWl0dGVkOiAoeyBxdWVyeSB9OiB7XG4gICAgICAgIHF1ZXJ5OiBzdHJpbmc7XG4gICAgfSkgPT4gdm9pZDtcbiAgICBvbkZvcm1SZXNwb25zZVN1Ym1pdHRlZDogKCkgPT4gdm9pZDtcbn07XG4iXSwibWFwcGluZ3MiOiI7Ozs7O0FBRUEsSUFBVyxvQkFBb0I7Q0FBQztPQUFHO09BQUE7T0FBQTtPQUFBO09BQUE7Q0FBQTtBQUNuQyxJQUFXLHVCQUF1QjtDQUFDO09BQU87T0FBQTtPQUFBO09BQUE7T0FBQTtDQUFBIn0=
42
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhdEFQSS5kLmN0cyIsIm5hbWVzIjpbXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29udGV4dHMvc2FsZXNBZ2VudENvbnRleHQvY2hhdEFQSS5kLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBhZ2VWaXNpdENhdGVnb3J5IH0gZnJvbSAnQHNwaWZmeS1haS9jb21tZXJjZS1hcGktY2xpZW50JztcbmltcG9ydCB7IFN1Z2dlc3Rpb24sIFVzZXJFdmVudCB9IGZyb20gJ3NyYy9hcHBsaWNhdGlvbi9tb2RlbHMnO1xuZXhwb3J0IGludGVyZmFjZSBTYWxlc0FnZW50Q2hhdEFQSSB7XG4gICAgbG9nUGFnZVZpc2l0OiAoeyBwYWdlVmlzaXRDYXRlZ29yeSB9OiB7XG4gICAgICAgIHBhZ2VWaXNpdENhdGVnb3J5OiBQYWdlVmlzaXRDYXRlZ29yeTtcbiAgICB9KSA9PiB2b2lkO1xuICAgIGxvZ1VzZXJFdmVudDogKGV2ZW50OiBVc2VyRXZlbnQpID0+IHZvaWQ7XG4gICAgb25TdWdnZXN0aW9uQ2xpY2tlZDogKHN1Z2dlc3Rpb246IFN1Z2dlc3Rpb24pID0+IHZvaWQ7XG4gICAgb25UeXBlZE1lc3NhZ2VTdWJtaXR0ZWQ6ICh7IHF1ZXJ5LCB1c2VyVHlwZWQgfToge1xuICAgICAgICBxdWVyeTogc3RyaW5nO1xuICAgICAgICB1c2VyVHlwZWQ6IGJvb2xlYW47XG4gICAgfSkgPT4gdm9pZDtcbiAgICBvbkZvcm1SZXNwb25zZVN1Ym1pdHRlZDogKGZvcm1SZXNwb25zZTogYW55KSA9PiB2b2lkO1xufVxuZXhwb3J0IGRlY2xhcmUgY29uc3QgdXNlU2FsZXNBZ2VudENoYXRBUEk6ICgpID0+IHtcbiAgICBsb2dQYWdlVmlzaXQ6ICh7IHBhZ2VWaXNpdENhdGVnb3J5IH06IHtcbiAgICAgICAgcGFnZVZpc2l0Q2F0ZWdvcnk6IFBhZ2VWaXNpdENhdGVnb3J5O1xuICAgIH0pID0+IHZvaWQ7XG4gICAgbG9nVXNlckV2ZW50OiAoZXZlbnQ6IFVzZXJFdmVudCkgPT4gdm9pZDtcbiAgICBvblN1Z2dlc3Rpb25DbGlja2VkOiAoc3VnZ2VzdGlvbjogU3VnZ2VzdGlvbikgPT4gdm9pZDtcbiAgICBvblR5cGVkTWVzc2FnZVN1Ym1pdHRlZDogKHsgcXVlcnksIHVzZXJUeXBlZCB9OiB7XG4gICAgICAgIHF1ZXJ5OiBzdHJpbmc7XG4gICAgICAgIHVzZXJUeXBlZDogYm9vbGVhbjtcbiAgICB9KSA9PiB2b2lkO1xuICAgIG9uRm9ybVJlc3BvbnNlU3VibWl0dGVkOiAoKSA9PiB2b2lkO1xufTtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFFQSxJQUFXLG9CQUFvQjtDQUFDO09BQUc7T0FBQTtPQUFBO09BQUE7T0FBQTtPQUFBO0NBQUE7QUFDbkMsSUFBVyx1QkFBdUI7Q0FBQztPQUFPO09BQUE7T0FBQTtPQUFBO09BQUE7T0FBQTtDQUFBIn0=
@@ -12,9 +12,11 @@ interface SalesAgentChatAPI {
12
12
  logUserEvent: (event: UserEvent$1) => void;
13
13
  onSuggestionClicked: (suggestion: Suggestion$1) => void;
14
14
  onTypedMessageSubmitted: ({
15
- query
15
+ query,
16
+ userTyped
16
17
  }: {
17
18
  query: string;
19
+ userTyped: boolean;
18
20
  }) => void;
19
21
  onFormResponseSubmitted: (formResponse: any) => void;
20
22
  }
@@ -27,12 +29,14 @@ declare const useSalesAgentChatAPI: () => {
27
29
  logUserEvent: (event: UserEvent$1) => void;
28
30
  onSuggestionClicked: (suggestion: Suggestion$1) => void;
29
31
  onTypedMessageSubmitted: ({
30
- query
32
+ query,
33
+ userTyped
31
34
  }: {
32
35
  query: string;
36
+ userTyped: boolean;
33
37
  }) => void;
34
38
  onFormResponseSubmitted: () => void;
35
39
  };
36
40
  //#endregion
37
41
  export { SalesAgentChatAPI, useSalesAgentChatAPI };
38
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhdEFQSS5kLnRzIiwibmFtZXMiOltdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb250ZXh0cy9zYWxlc0FnZW50Q29udGV4dC9jaGF0QVBJLmQudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGFnZVZpc2l0Q2F0ZWdvcnkgfSBmcm9tICdAc3BpZmZ5LWFpL2NvbW1lcmNlLWFwaS1jbGllbnQnO1xuaW1wb3J0IHsgU3VnZ2VzdGlvbiwgVXNlckV2ZW50IH0gZnJvbSAnc3JjL2FwcGxpY2F0aW9uL21vZGVscyc7XG5leHBvcnQgaW50ZXJmYWNlIFNhbGVzQWdlbnRDaGF0QVBJIHtcbiAgICBsb2dQYWdlVmlzaXQ6ICh7IHBhZ2VWaXNpdENhdGVnb3J5IH06IHtcbiAgICAgICAgcGFnZVZpc2l0Q2F0ZWdvcnk6IFBhZ2VWaXNpdENhdGVnb3J5O1xuICAgIH0pID0+IHZvaWQ7XG4gICAgbG9nVXNlckV2ZW50OiAoZXZlbnQ6IFVzZXJFdmVudCkgPT4gdm9pZDtcbiAgICBvblN1Z2dlc3Rpb25DbGlja2VkOiAoc3VnZ2VzdGlvbjogU3VnZ2VzdGlvbikgPT4gdm9pZDtcbiAgICBvblR5cGVkTWVzc2FnZVN1Ym1pdHRlZDogKHsgcXVlcnkgfToge1xuICAgICAgICBxdWVyeTogc3RyaW5nO1xuICAgIH0pID0+IHZvaWQ7XG4gICAgb25Gb3JtUmVzcG9uc2VTdWJtaXR0ZWQ6IChmb3JtUmVzcG9uc2U6IGFueSkgPT4gdm9pZDtcbn1cbmV4cG9ydCBkZWNsYXJlIGNvbnN0IHVzZVNhbGVzQWdlbnRDaGF0QVBJOiAoKSA9PiB7XG4gICAgbG9nUGFnZVZpc2l0OiAoeyBwYWdlVmlzaXRDYXRlZ29yeSB9OiB7XG4gICAgICAgIHBhZ2VWaXNpdENhdGVnb3J5OiBQYWdlVmlzaXRDYXRlZ29yeTtcbiAgICB9KSA9PiB2b2lkO1xuICAgIGxvZ1VzZXJFdmVudDogKGV2ZW50OiBVc2VyRXZlbnQpID0+IHZvaWQ7XG4gICAgb25TdWdnZXN0aW9uQ2xpY2tlZDogKHN1Z2dlc3Rpb246IFN1Z2dlc3Rpb24pID0+IHZvaWQ7XG4gICAgb25UeXBlZE1lc3NhZ2VTdWJtaXR0ZWQ6ICh7IHF1ZXJ5IH06IHtcbiAgICAgICAgcXVlcnk6IHN0cmluZztcbiAgICB9KSA9PiB2b2lkO1xuICAgIG9uRm9ybVJlc3BvbnNlU3VibWl0dGVkOiAoKSA9PiB2b2lkO1xufTtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFFQSxJQUFXLG9CQUFvQjtDQUFDO09BQUc7T0FBQTtPQUFBO09BQUE7T0FBQTtDQUFBO0FBQ25DLElBQVcsdUJBQXVCO0NBQUM7T0FBTztPQUFBO09BQUE7T0FBQTtPQUFBO0NBQUEifQ==
42
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhdEFQSS5kLnRzIiwibmFtZXMiOltdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb250ZXh0cy9zYWxlc0FnZW50Q29udGV4dC9jaGF0QVBJLmQudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGFnZVZpc2l0Q2F0ZWdvcnkgfSBmcm9tICdAc3BpZmZ5LWFpL2NvbW1lcmNlLWFwaS1jbGllbnQnO1xuaW1wb3J0IHsgU3VnZ2VzdGlvbiwgVXNlckV2ZW50IH0gZnJvbSAnc3JjL2FwcGxpY2F0aW9uL21vZGVscyc7XG5leHBvcnQgaW50ZXJmYWNlIFNhbGVzQWdlbnRDaGF0QVBJIHtcbiAgICBsb2dQYWdlVmlzaXQ6ICh7IHBhZ2VWaXNpdENhdGVnb3J5IH06IHtcbiAgICAgICAgcGFnZVZpc2l0Q2F0ZWdvcnk6IFBhZ2VWaXNpdENhdGVnb3J5O1xuICAgIH0pID0+IHZvaWQ7XG4gICAgbG9nVXNlckV2ZW50OiAoZXZlbnQ6IFVzZXJFdmVudCkgPT4gdm9pZDtcbiAgICBvblN1Z2dlc3Rpb25DbGlja2VkOiAoc3VnZ2VzdGlvbjogU3VnZ2VzdGlvbikgPT4gdm9pZDtcbiAgICBvblR5cGVkTWVzc2FnZVN1Ym1pdHRlZDogKHsgcXVlcnksIHVzZXJUeXBlZCB9OiB7XG4gICAgICAgIHF1ZXJ5OiBzdHJpbmc7XG4gICAgICAgIHVzZXJUeXBlZDogYm9vbGVhbjtcbiAgICB9KSA9PiB2b2lkO1xuICAgIG9uRm9ybVJlc3BvbnNlU3VibWl0dGVkOiAoZm9ybVJlc3BvbnNlOiBhbnkpID0+IHZvaWQ7XG59XG5leHBvcnQgZGVjbGFyZSBjb25zdCB1c2VTYWxlc0FnZW50Q2hhdEFQSTogKCkgPT4ge1xuICAgIGxvZ1BhZ2VWaXNpdDogKHsgcGFnZVZpc2l0Q2F0ZWdvcnkgfToge1xuICAgICAgICBwYWdlVmlzaXRDYXRlZ29yeTogUGFnZVZpc2l0Q2F0ZWdvcnk7XG4gICAgfSkgPT4gdm9pZDtcbiAgICBsb2dVc2VyRXZlbnQ6IChldmVudDogVXNlckV2ZW50KSA9PiB2b2lkO1xuICAgIG9uU3VnZ2VzdGlvbkNsaWNrZWQ6IChzdWdnZXN0aW9uOiBTdWdnZXN0aW9uKSA9PiB2b2lkO1xuICAgIG9uVHlwZWRNZXNzYWdlU3VibWl0dGVkOiAoeyBxdWVyeSwgdXNlclR5cGVkIH06IHtcbiAgICAgICAgcXVlcnk6IHN0cmluZztcbiAgICAgICAgdXNlclR5cGVkOiBib29sZWFuO1xuICAgIH0pID0+IHZvaWQ7XG4gICAgb25Gb3JtUmVzcG9uc2VTdWJtaXR0ZWQ6ICgpID0+IHZvaWQ7XG59O1xuIl0sIm1hcHBpbmdzIjoiOzs7OztBQUVBLElBQVcsb0JBQW9CO0NBQUM7T0FBRztPQUFBO09BQUE7T0FBQTtPQUFBO09BQUE7Q0FBQTtBQUNuQyxJQUFXLHVCQUF1QjtDQUFDO09BQU87T0FBQTtPQUFBO09BQUE7T0FBQTtPQUFBO0NBQUEifQ==
@@ -1,4 +1,7 @@
1
+ import { SpiffyMetricsEventName } from "../../services/amplitudeService/amplitudeService.js";
2
+ import { useAmplitude } from "../amplitudeContext/amplitudeContext.js";
1
3
  import { queueUserEventAtom } from "../../atoms/chat/messageQueue.js";
4
+ import "../amplitudeContext/index.js";
2
5
  import { UserEventCategory } from "@spiffy-ai/commerce-api-client";
3
6
  import { v4 } from "uuid";
4
7
  import { useCallback } from "react";
@@ -7,6 +10,7 @@ import { useSetAtom } from "jotai";
7
10
  //#region src/contexts/salesAgentContext/chatAPI.ts
8
11
  const useSalesAgentChatAPI = () => {
9
12
  const queueUserEvent = useSetAtom(queueUserEventAtom);
13
+ const { trackEvent } = useAmplitude();
10
14
  return {
11
15
  logPageVisit: useCallback(({ pageVisitCategory }) => {
12
16
  queueUserEvent({
@@ -23,6 +27,13 @@ const useSalesAgentChatAPI = () => {
23
27
  queueUserEvent(event);
24
28
  }, [queueUserEvent]),
25
29
  onSuggestionClicked: useCallback((suggestion) => {
30
+ trackEvent({
31
+ eventName: SpiffyMetricsEventName.ChatSuggestionClicked,
32
+ eventProps: {
33
+ suggestionId: suggestion.id,
34
+ content: suggestion.content
35
+ }
36
+ });
26
37
  queueUserEvent({
27
38
  eventId: v4(),
28
39
  category: UserEventCategory.SuggestionClicked,
@@ -32,19 +43,29 @@ const useSalesAgentChatAPI = () => {
32
43
  content: suggestion.content
33
44
  }
34
45
  });
35
- }, [queueUserEvent]),
36
- onTypedMessageSubmitted: useCallback(({ query }) => {
46
+ }, [queueUserEvent, trackEvent]),
47
+ onTypedMessageSubmitted: useCallback(({ query, userTyped }) => {
48
+ trackEvent({
49
+ eventName: SpiffyMetricsEventName.ChatUserMessageInput,
50
+ eventProps: {
51
+ query,
52
+ userTyped
53
+ }
54
+ });
37
55
  queueUserEvent({
38
56
  eventId: v4(),
39
57
  category: UserEventCategory.QueryTyped,
40
58
  createdAt: (/* @__PURE__ */ new Date()).toISOString(),
41
- attributes: { query }
59
+ attributes: {
60
+ query,
61
+ userTyped
62
+ }
42
63
  });
43
- }, [queueUserEvent]),
64
+ }, [queueUserEvent, trackEvent]),
44
65
  onFormResponseSubmitted: useCallback(() => {}, [])
45
66
  };
46
67
  };
47
68
 
48
69
  //#endregion
49
70
  export { useSalesAgentChatAPI };
50
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhdEFQSS5qcyIsIm5hbWVzIjpbInV1aWQiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29udGV4dHMvc2FsZXNBZ2VudENvbnRleHQvY2hhdEFQSS50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvLyBUaGlzIGNvbXBvbmVudCB3aWxsIGludGVyYWN0IHdpdGggdGhlIGJhY2tlbmQgQVBJIHRvIGdldCB0aGUgcmVzcG9uc2VzIGZyb20gdGhlIHNhbGVzIGFnZW50LlxuXG5pbXBvcnQgeyBQYWdlVmlzaXRDYXRlZ29yeSwgVXNlckV2ZW50Q2F0ZWdvcnkgfSBmcm9tICdAc3BpZmZ5LWFpL2NvbW1lcmNlLWFwaS1jbGllbnQnO1xuaW1wb3J0IHsgU3VnZ2VzdGlvbiwgVXNlckV2ZW50IH0gZnJvbSAnc3JjL2FwcGxpY2F0aW9uL21vZGVscyc7XG5pbXBvcnQgeyB1c2VTZXRBdG9tIH0gZnJvbSAnam90YWknO1xuaW1wb3J0IHsgdXNlQ2FsbGJhY2sgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyB2NCBhcyB1dWlkIH0gZnJvbSAndXVpZCc7XG5pbXBvcnQgeyBxdWV1ZVVzZXJFdmVudEF0b20gfSBmcm9tICdzcmMvYXRvbXMvY2hhdC9tZXNzYWdlUXVldWUnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFNhbGVzQWdlbnRDaGF0QVBJIHtcbiAgbG9nUGFnZVZpc2l0OiAoeyBwYWdlVmlzaXRDYXRlZ29yeSB9OiB7IHBhZ2VWaXNpdENhdGVnb3J5OiBQYWdlVmlzaXRDYXRlZ29yeSB9KSA9PiB2b2lkO1xuICBsb2dVc2VyRXZlbnQ6IChldmVudDogVXNlckV2ZW50KSA9PiB2b2lkO1xuICBvblN1Z2dlc3Rpb25DbGlja2VkOiAoc3VnZ2VzdGlvbjogU3VnZ2VzdGlvbikgPT4gdm9pZDtcbiAgb25UeXBlZE1lc3NhZ2VTdWJtaXR0ZWQ6ICh7IHF1ZXJ5IH06IHsgcXVlcnk6IHN0cmluZyB9KSA9PiB2b2lkO1xuICBvbkZvcm1SZXNwb25zZVN1Ym1pdHRlZDogKGZvcm1SZXNwb25zZTogYW55KSA9PiB2b2lkOyAvLyBUT0RPOiBGaWd1cmUgb3V0IHRoZSByaWdodCB0eXBlXG59XG5cbmV4cG9ydCBjb25zdCB1c2VTYWxlc0FnZW50Q2hhdEFQSSA9ICgpID0+IHtcbiAgLy8gVE9ETzogRWFjaCBvZiB0aGVzZSBmdW5jdGlvbnMgd2lsbCB0cmlnZ2VyIGJvdGggdGhlIG5lY2Vzc2FyeSBhbXBsaXR1ZGUgZXZlbnRzIGFuZCBpbml0aWF0ZSB0aGVcbiAgLy8gbmVjZXNzYXJ5IGFjdGlvbnMgdG8gdHJpZ2dlciB0aGUgYmFja2VuZCBBUElcbiAgY29uc3QgcXVldWVVc2VyRXZlbnQgPSB1c2VTZXRBdG9tKHF1ZXVlVXNlckV2ZW50QXRvbSk7XG5cbiAgY29uc3QgbG9nUGFnZVZpc2l0ID0gdXNlQ2FsbGJhY2soXG4gICAgKHsgcGFnZVZpc2l0Q2F0ZWdvcnkgfTogeyBwYWdlVmlzaXRDYXRlZ29yeTogUGFnZVZpc2l0Q2F0ZWdvcnkgfSkgPT4ge1xuICAgICAgY29uc3QgZXZlbnQ6IFVzZXJFdmVudCA9IHtcbiAgICAgICAgZXZlbnRJZDogdXVpZCgpLFxuICAgICAgICBjYXRlZ29yeTogVXNlckV2ZW50Q2F0ZWdvcnkuUGFnZVZpc2l0LFxuICAgICAgICBjcmVhdGVkQXQ6IG5ldyBEYXRlKCkudG9JU09TdHJpbmcoKSxcbiAgICAgICAgYXR0cmlidXRlczoge1xuICAgICAgICAgIHVybDogd2luZG93LmxvY2F0aW9uLmhyZWYsXG4gICAgICAgICAgcGFnZVZpc2l0Q2F0ZWdvcnksXG4gICAgICAgIH0sXG4gICAgICB9O1xuICAgICAgcXVldWVVc2VyRXZlbnQoZXZlbnQpO1xuICAgIH0sXG4gICAgW3F1ZXVlVXNlckV2ZW50XSxcbiAgKTtcblxuICBjb25zdCBsb2dVc2VyRXZlbnQgPSB1c2VDYWxsYmFjayhcbiAgICAoZXZlbnQ6IFVzZXJFdmVudCkgPT4ge1xuICAgICAgcXVldWVVc2VyRXZlbnQoZXZlbnQpO1xuICAgIH0sXG4gICAgW3F1ZXVlVXNlckV2ZW50XSxcbiAgKTtcbiAgY29uc3Qgb25TdWdnZXN0aW9uQ2xpY2tlZCA9IHVzZUNhbGxiYWNrKFxuICAgIChzdWdnZXN0aW9uOiBTdWdnZXN0aW9uKSA9PiB7XG4gICAgICBjb25zdCBldmVudDogVXNlckV2ZW50ID0ge1xuICAgICAgICBldmVudElkOiB1dWlkKCksXG4gICAgICAgIGNhdGVnb3J5OiBVc2VyRXZlbnRDYXRlZ29yeS5TdWdnZXN0aW9uQ2xpY2tlZCxcbiAgICAgICAgY3JlYXRlZEF0OiBuZXcgRGF0ZSgpLnRvSVNPU3RyaW5nKCksXG4gICAgICAgIGF0dHJpYnV0ZXM6IHtcbiAgICAgICAgICBzdWdnZXN0aW9uSWQ6IHN1Z2dlc3Rpb24uaWQsXG4gICAgICAgICAgY29udGVudDogc3VnZ2VzdGlvbi5jb250ZW50LFxuICAgICAgICB9LFxuICAgICAgfTtcbiAgICAgIHF1ZXVlVXNlckV2ZW50KGV2ZW50KTtcbiAgICB9LFxuICAgIFtxdWV1ZVVzZXJFdmVudF0sXG4gICk7XG4gIGNvbnN0IG9uVHlwZWRNZXNzYWdlU3VibWl0dGVkID0gdXNlQ2FsbGJhY2soXG4gICAgKHsgcXVlcnkgfTogeyBxdWVyeTogc3RyaW5nIH0pID0+IHtcbiAgICAgIGNvbnN0IGV2ZW50OiBVc2VyRXZlbnQgPSB7XG4gICAgICAgIGV2ZW50SWQ6IHV1aWQoKSxcbiAgICAgICAgY2F0ZWdvcnk6IFVzZXJFdmVudENhdGVnb3J5LlF1ZXJ5VHlwZWQsXG4gICAgICAgIGNyZWF0ZWRBdDogbmV3IERhdGUoKS50b0lTT1N0cmluZygpLFxuICAgICAgICBhdHRyaWJ1dGVzOiB7XG4gICAgICAgICAgcXVlcnksXG4gICAgICAgIH0sXG4gICAgICB9O1xuICAgICAgcXVldWVVc2VyRXZlbnQoZXZlbnQpO1xuICAgIH0sXG4gICAgW3F1ZXVlVXNlckV2ZW50XSxcbiAgKTtcbiAgY29uc3Qgb25Gb3JtUmVzcG9uc2VTdWJtaXR0ZWQgPSB1c2VDYWxsYmFjaygoKSA9PiB7XG4gICAgLy8gVE9ETzogSW1wbGVtZW50IHRoZSBmb3JtIHJlc3BvbnNlIHN1Ym1pdHRlZFxuICB9LCBbXSk7XG5cbiAgcmV0dXJuIHtcbiAgICBsb2dQYWdlVmlzaXQsXG4gICAgbG9nVXNlckV2ZW50LFxuICAgIG9uU3VnZ2VzdGlvbkNsaWNrZWQsXG4gICAgb25UeXBlZE1lc3NhZ2VTdWJtaXR0ZWQsXG4gICAgb25Gb3JtUmVzcG9uc2VTdWJtaXR0ZWQsXG4gIH07XG59O1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBaUJBLE1BQWEsNkJBQTZCO0NBR3hDLE1BQU0saUJBQWlCLFdBQVcsbUJBQW1CO0FBeURyRCxRQUFPO0VBQ0wsY0F4RG1CLGFBQ2xCLEVBQUUsd0JBQWtFO0FBVW5FLGtCQVR5QjtJQUN2QixTQUFTQSxJQUFNO0lBQ2YsVUFBVSxrQkFBa0I7SUFDNUIsNEJBQVcsSUFBSSxNQUFNLEVBQUMsYUFBYTtJQUNuQyxZQUFZO0tBQ1YsS0FBSyxPQUFPLFNBQVM7S0FDckI7S0FDRDtJQUNGLENBQ29CO0tBRXZCLENBQUMsZUFBZSxDQUNqQjtFQTJDQyxjQXpDbUIsYUFDbEIsVUFBcUI7QUFDcEIsa0JBQWUsTUFBTTtLQUV2QixDQUFDLGVBQWUsQ0FDakI7RUFxQ0MscUJBcEMwQixhQUN6QixlQUEyQjtBQVUxQixrQkFUeUI7SUFDdkIsU0FBU0EsSUFBTTtJQUNmLFVBQVUsa0JBQWtCO0lBQzVCLDRCQUFXLElBQUksTUFBTSxFQUFDLGFBQWE7SUFDbkMsWUFBWTtLQUNWLGNBQWMsV0FBVztLQUN6QixTQUFTLFdBQVc7S0FDckI7SUFDRixDQUNvQjtLQUV2QixDQUFDLGVBQWUsQ0FDakI7RUF1QkMseUJBdEI4QixhQUM3QixFQUFFLFlBQStCO0FBU2hDLGtCQVJ5QjtJQUN2QixTQUFTQSxJQUFNO0lBQ2YsVUFBVSxrQkFBa0I7SUFDNUIsNEJBQVcsSUFBSSxNQUFNLEVBQUMsYUFBYTtJQUNuQyxZQUFZLEVBQ1YsT0FDRDtJQUNGLENBQ29CO0tBRXZCLENBQUMsZUFBZSxDQUNqQjtFQVVDLHlCQVQ4QixrQkFBa0IsSUFFL0MsRUFBRSxDQUFDO0VBUUwifQ==
71
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhdEFQSS5qcyIsIm5hbWVzIjpbInV1aWQiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29udGV4dHMvc2FsZXNBZ2VudENvbnRleHQvY2hhdEFQSS50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvLyBUaGlzIGNvbXBvbmVudCB3aWxsIGludGVyYWN0IHdpdGggdGhlIGJhY2tlbmQgQVBJIHRvIGdldCB0aGUgcmVzcG9uc2VzIGZyb20gdGhlIHNhbGVzIGFnZW50LlxuXG5pbXBvcnQgeyBQYWdlVmlzaXRDYXRlZ29yeSwgVXNlckV2ZW50Q2F0ZWdvcnkgfSBmcm9tICdAc3BpZmZ5LWFpL2NvbW1lcmNlLWFwaS1jbGllbnQnO1xuaW1wb3J0IHsgU3VnZ2VzdGlvbiwgVXNlckV2ZW50IH0gZnJvbSAnc3JjL2FwcGxpY2F0aW9uL21vZGVscyc7XG5pbXBvcnQgeyB1c2VTZXRBdG9tIH0gZnJvbSAnam90YWknO1xuaW1wb3J0IHsgdXNlQ2FsbGJhY2sgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyB2NCBhcyB1dWlkIH0gZnJvbSAndXVpZCc7XG5pbXBvcnQgeyBxdWV1ZVVzZXJFdmVudEF0b20gfSBmcm9tICdzcmMvYXRvbXMvY2hhdC9tZXNzYWdlUXVldWUnO1xuaW1wb3J0IHsgU3BpZmZ5TWV0cmljc0V2ZW50TmFtZSwgdXNlQW1wbGl0dWRlIH0gZnJvbSAnLi4vYW1wbGl0dWRlQ29udGV4dCc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2FsZXNBZ2VudENoYXRBUEkge1xuICBsb2dQYWdlVmlzaXQ6ICh7IHBhZ2VWaXNpdENhdGVnb3J5IH06IHsgcGFnZVZpc2l0Q2F0ZWdvcnk6IFBhZ2VWaXNpdENhdGVnb3J5IH0pID0+IHZvaWQ7XG4gIGxvZ1VzZXJFdmVudDogKGV2ZW50OiBVc2VyRXZlbnQpID0+IHZvaWQ7XG4gIG9uU3VnZ2VzdGlvbkNsaWNrZWQ6IChzdWdnZXN0aW9uOiBTdWdnZXN0aW9uKSA9PiB2b2lkO1xuICBvblR5cGVkTWVzc2FnZVN1Ym1pdHRlZDogKHsgcXVlcnksIHVzZXJUeXBlZCB9OiB7IHF1ZXJ5OiBzdHJpbmc7IHVzZXJUeXBlZDogYm9vbGVhbiB9KSA9PiB2b2lkO1xuICBvbkZvcm1SZXNwb25zZVN1Ym1pdHRlZDogKGZvcm1SZXNwb25zZTogYW55KSA9PiB2b2lkOyAvLyBUT0RPOiBGaWd1cmUgb3V0IHRoZSByaWdodCB0eXBlXG59XG5cbmV4cG9ydCBjb25zdCB1c2VTYWxlc0FnZW50Q2hhdEFQSSA9ICgpID0+IHtcbiAgLy8gVE9ETzogRWFjaCBvZiB0aGVzZSBmdW5jdGlvbnMgd2lsbCB0cmlnZ2VyIGJvdGggdGhlIG5lY2Vzc2FyeSBhbXBsaXR1ZGUgZXZlbnRzIGFuZCBpbml0aWF0ZSB0aGVcbiAgLy8gbmVjZXNzYXJ5IGFjdGlvbnMgdG8gdHJpZ2dlciB0aGUgYmFja2VuZCBBUElcbiAgY29uc3QgcXVldWVVc2VyRXZlbnQgPSB1c2VTZXRBdG9tKHF1ZXVlVXNlckV2ZW50QXRvbSk7XG4gIGNvbnN0IHsgdHJhY2tFdmVudCB9ID0gdXNlQW1wbGl0dWRlKCk7XG5cbiAgY29uc3QgbG9nUGFnZVZpc2l0ID0gdXNlQ2FsbGJhY2soXG4gICAgKHsgcGFnZVZpc2l0Q2F0ZWdvcnkgfTogeyBwYWdlVmlzaXRDYXRlZ29yeTogUGFnZVZpc2l0Q2F0ZWdvcnkgfSkgPT4ge1xuICAgICAgY29uc3QgZXZlbnQ6IFVzZXJFdmVudCA9IHtcbiAgICAgICAgZXZlbnRJZDogdXVpZCgpLFxuICAgICAgICBjYXRlZ29yeTogVXNlckV2ZW50Q2F0ZWdvcnkuUGFnZVZpc2l0LFxuICAgICAgICBjcmVhdGVkQXQ6IG5ldyBEYXRlKCkudG9JU09TdHJpbmcoKSxcbiAgICAgICAgYXR0cmlidXRlczoge1xuICAgICAgICAgIHVybDogd2luZG93LmxvY2F0aW9uLmhyZWYsXG4gICAgICAgICAgcGFnZVZpc2l0Q2F0ZWdvcnksXG4gICAgICAgIH0sXG4gICAgICB9O1xuICAgICAgcXVldWVVc2VyRXZlbnQoZXZlbnQpO1xuICAgIH0sXG4gICAgW3F1ZXVlVXNlckV2ZW50XSxcbiAgKTtcblxuICBjb25zdCBsb2dVc2VyRXZlbnQgPSB1c2VDYWxsYmFjayhcbiAgICAoZXZlbnQ6IFVzZXJFdmVudCkgPT4ge1xuICAgICAgcXVldWVVc2VyRXZlbnQoZXZlbnQpO1xuICAgIH0sXG4gICAgW3F1ZXVlVXNlckV2ZW50XSxcbiAgKTtcbiAgY29uc3Qgb25TdWdnZXN0aW9uQ2xpY2tlZCA9IHVzZUNhbGxiYWNrKFxuICAgIChzdWdnZXN0aW9uOiBTdWdnZXN0aW9uKSA9PiB7XG4gICAgICB0cmFja0V2ZW50KHtcbiAgICAgICAgZXZlbnROYW1lOiBTcGlmZnlNZXRyaWNzRXZlbnROYW1lLkNoYXRTdWdnZXN0aW9uQ2xpY2tlZCxcbiAgICAgICAgZXZlbnRQcm9wczoge1xuICAgICAgICAgIHN1Z2dlc3Rpb25JZDogc3VnZ2VzdGlvbi5pZCxcbiAgICAgICAgICBjb250ZW50OiBzdWdnZXN0aW9uLmNvbnRlbnQsXG4gICAgICAgIH0sXG4gICAgICB9KTtcbiAgICAgIGNvbnN0IGV2ZW50OiBVc2VyRXZlbnQgPSB7XG4gICAgICAgIGV2ZW50SWQ6IHV1aWQoKSxcbiAgICAgICAgY2F0ZWdvcnk6IFVzZXJFdmVudENhdGVnb3J5LlN1Z2dlc3Rpb25DbGlja2VkLFxuICAgICAgICBjcmVhdGVkQXQ6IG5ldyBEYXRlKCkudG9JU09TdHJpbmcoKSxcbiAgICAgICAgYXR0cmlidXRlczoge1xuICAgICAgICAgIHN1Z2dlc3Rpb25JZDogc3VnZ2VzdGlvbi5pZCxcbiAgICAgICAgICBjb250ZW50OiBzdWdnZXN0aW9uLmNvbnRlbnQsXG4gICAgICAgIH0sXG4gICAgICB9O1xuICAgICAgcXVldWVVc2VyRXZlbnQoZXZlbnQpO1xuICAgIH0sXG4gICAgW3F1ZXVlVXNlckV2ZW50LCB0cmFja0V2ZW50XSxcbiAgKTtcbiAgY29uc3Qgb25UeXBlZE1lc3NhZ2VTdWJtaXR0ZWQgPSB1c2VDYWxsYmFjayhcbiAgICAoeyBxdWVyeSwgdXNlclR5cGVkIH06IHsgcXVlcnk6IHN0cmluZzsgdXNlclR5cGVkOiBib29sZWFuIH0pID0+IHtcbiAgICAgIHRyYWNrRXZlbnQoe1xuICAgICAgICBldmVudE5hbWU6IFNwaWZmeU1ldHJpY3NFdmVudE5hbWUuQ2hhdFVzZXJNZXNzYWdlSW5wdXQsXG4gICAgICAgIGV2ZW50UHJvcHM6IHtcbiAgICAgICAgICBxdWVyeSxcbiAgICAgICAgICB1c2VyVHlwZWQsXG4gICAgICAgIH0sXG4gICAgICB9KTtcbiAgICAgIGNvbnN0IGV2ZW50OiBVc2VyRXZlbnQgPSB7XG4gICAgICAgIGV2ZW50SWQ6IHV1aWQoKSxcbiAgICAgICAgY2F0ZWdvcnk6IFVzZXJFdmVudENhdGVnb3J5LlF1ZXJ5VHlwZWQsXG4gICAgICAgIGNyZWF0ZWRBdDogbmV3IERhdGUoKS50b0lTT1N0cmluZygpLFxuICAgICAgICBhdHRyaWJ1dGVzOiB7XG4gICAgICAgICAgcXVlcnksXG4gICAgICAgICAgdXNlclR5cGVkLFxuICAgICAgICB9LFxuICAgICAgfTtcbiAgICAgIHF1ZXVlVXNlckV2ZW50KGV2ZW50KTtcbiAgICB9LFxuICAgIFtxdWV1ZVVzZXJFdmVudCwgdHJhY2tFdmVudF0sXG4gICk7XG4gIGNvbnN0IG9uRm9ybVJlc3BvbnNlU3VibWl0dGVkID0gdXNlQ2FsbGJhY2soKCkgPT4ge1xuICAgIC8vIFRPRE86IEltcGxlbWVudCB0aGUgZm9ybSByZXNwb25zZSBzdWJtaXR0ZWRcbiAgfSwgW10pO1xuXG4gIHJldHVybiB7XG4gICAgbG9nUGFnZVZpc2l0LFxuICAgIGxvZ1VzZXJFdmVudCxcbiAgICBvblN1Z2dlc3Rpb25DbGlja2VkLFxuICAgIG9uVHlwZWRNZXNzYWdlU3VibWl0dGVkLFxuICAgIG9uRm9ybVJlc3BvbnNlU3VibWl0dGVkLFxuICB9O1xufTtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7OztBQWtCQSxNQUFhLDZCQUE2QjtDQUd4QyxNQUFNLGlCQUFpQixXQUFXLG1CQUFtQjtDQUNyRCxNQUFNLEVBQUUsZUFBZSxjQUFjO0FBd0VyQyxRQUFPO0VBQ0wsY0F2RW1CLGFBQ2xCLEVBQUUsd0JBQWtFO0FBVW5FLGtCQVR5QjtJQUN2QixTQUFTQSxJQUFNO0lBQ2YsVUFBVSxrQkFBa0I7SUFDNUIsNEJBQVcsSUFBSSxNQUFNLEVBQUMsYUFBYTtJQUNuQyxZQUFZO0tBQ1YsS0FBSyxPQUFPLFNBQVM7S0FDckI7S0FDRDtJQUNGLENBQ29CO0tBRXZCLENBQUMsZUFBZSxDQUNqQjtFQTBEQyxjQXhEbUIsYUFDbEIsVUFBcUI7QUFDcEIsa0JBQWUsTUFBTTtLQUV2QixDQUFDLGVBQWUsQ0FDakI7RUFvREMscUJBbkQwQixhQUN6QixlQUEyQjtBQUMxQixjQUFXO0lBQ1QsV0FBVyx1QkFBdUI7SUFDbEMsWUFBWTtLQUNWLGNBQWMsV0FBVztLQUN6QixTQUFTLFdBQVc7S0FDckI7SUFDRixDQUFDO0FBVUYsa0JBVHlCO0lBQ3ZCLFNBQVNBLElBQU07SUFDZixVQUFVLGtCQUFrQjtJQUM1Qiw0QkFBVyxJQUFJLE1BQU0sRUFBQyxhQUFhO0lBQ25DLFlBQVk7S0FDVixjQUFjLFdBQVc7S0FDekIsU0FBUyxXQUFXO0tBQ3JCO0lBQ0YsQ0FDb0I7S0FFdkIsQ0FBQyxnQkFBZ0IsV0FBVyxDQUM3QjtFQStCQyx5QkE5QjhCLGFBQzdCLEVBQUUsT0FBTyxnQkFBdUQ7QUFDL0QsY0FBVztJQUNULFdBQVcsdUJBQXVCO0lBQ2xDLFlBQVk7S0FDVjtLQUNBO0tBQ0Q7SUFDRixDQUFDO0FBVUYsa0JBVHlCO0lBQ3ZCLFNBQVNBLElBQU07SUFDZixVQUFVLGtCQUFrQjtJQUM1Qiw0QkFBVyxJQUFJLE1BQU0sRUFBQyxhQUFhO0lBQ25DLFlBQVk7S0FDVjtLQUNBO0tBQ0Q7SUFDRixDQUNvQjtLQUV2QixDQUFDLGdCQUFnQixXQUFXLENBQzdCO0VBVUMseUJBVDhCLGtCQUFrQixJQUUvQyxFQUFFLENBQUM7RUFRTCJ9
@@ -1,5 +1,6 @@
1
1
  const require_rolldown_runtime = require('../../_virtual/rolldown_runtime.cjs');
2
2
  const require_message = require('../../application/models/message.cjs');
3
+ const require_logger = require('../../application/logging/logger.cjs');
3
4
  const require_atoms_chat_chatState = require('../../atoms/chat/chatState.cjs');
4
5
  const require_messageQueue = require('../../atoms/chat/messageQueue.cjs');
5
6
  const require_useSystemSettingsContext = require('../../hooks/SystemSettingsContext/useSystemSettingsContext.cjs');
@@ -23,22 +24,18 @@ const SalesAgentProvider = ({ children }) => {
23
24
  const { getStreamingResponses, createResponsePayload, getSuggestions, hydrateMessages } = require_salesAgentService.useSalesAgentService();
24
25
  const sendMessagesToBackend = (0, react.useCallback)(async (requestPayload) => {
25
26
  try {
26
- const response = await getStreamingResponses(requestPayload);
27
+ await getStreamingResponses(requestPayload);
27
28
  setIsInitialized(true);
28
- console.log("response", response);
29
29
  requestPayload.userEvents?.map((userEvent) => markUserEventsProcessed([userEvent.eventId]));
30
30
  } catch (error) {
31
- console.error("error sending message");
31
+ require_logger.default.logError("[envive-ai] error sending message", error);
32
32
  }
33
33
  }, [
34
34
  getStreamingResponses,
35
35
  setIsInitialized,
36
36
  markUserEventsProcessed
37
37
  ]);
38
- console.log("userQueueEventCount", userQueueEventCount);
39
- console.log("userEvents", userEvents);
40
38
  (0, react.useEffect)(() => {
41
- console.log("SalesAgentProvider useEffect", userQueueEventCount, isInitialized, userEvents);
42
39
  if (userQueueEventCount > 0) {
43
40
  const payloadEvents = userEvents.slice(0, userQueueEventCount);
44
41
  payloadEvents.forEach((userEvent) => {
@@ -129,4 +126,4 @@ const useSalesAgent = () => {
129
126
  //#endregion
130
127
  exports.SalesAgentProvider = SalesAgentProvider;
131
128
  exports.useSalesAgent = useSalesAgent;
132
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"salesAgentContext.cjs","names":["SalesAgentProvider: React.FC<{ children: ReactNode }>","userEventQueueAtom","userQueueEventCountAtom","processUserEventAtom","initializedAtom","useSystemSettingsContext","messagesAtom","useSalesAgentService","UserEventCategory","newMessage: Message","MessageRole","MessageType","suggestionsAtom","responseStreamingAtom","pendingResponseAtom","useSalesAgentChatAPI"],"sources":["../../../src/contexts/salesAgentContext/salesAgentContext.tsx"],"sourcesContent":["import { useAtom, useAtomValue, useSetAtom } from 'jotai';\nimport { ReactNode, createContext, useCallback, useEffect, useMemo } from 'react';\nimport { UserEventCategory } from '@spiffy-ai/commerce-api-client';\nimport { Message, MessageRole, MessageType } from 'src/application/models/message';\nimport { NextMessageRequest, Suggestion, UserEvent } from 'src/application/models';\nimport {\n  initializedAtom,\n  messagesAtom,\n  pendingResponseAtom,\n  responseStreamingAtom,\n  suggestionsAtom,\n} 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\nexport interface 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 [isInitialized, setIsInitialized] = useAtom(initializedAtom);\n  const settingsContext = useSystemSettingsContext();\n  const setMessages = useSetAtom(messagesAtom);\n\n  const { getStreamingResponses, createResponsePayload, getSuggestions, hydrateMessages } =\n    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(\n    async (requestPayload: NextMessageRequest) => {\n      try {\n        const response = await getStreamingResponses(requestPayload);\n        setIsInitialized(true);\n\n        console.log('response', response);\n        // Remove the pending message from the user events\n        requestPayload.userEvents?.map(userEvent => markUserEventsProcessed([userEvent.eventId]));\n      } catch (error) {\n        console.error('error sending message');\n      }\n    },\n    [getStreamingResponses, setIsInitialized, 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    console.log('SalesAgentProvider useEffect', userQueueEventCount, isInitialized, userEvents);\n    if (userQueueEventCount > 0) {\n      const payloadEvents = userEvents.slice(0, userQueueEventCount);\n\n      payloadEvents.forEach(userEvent => {\n        if (userEvent && userEvent.category === UserEventCategory.QueryTyped) {\n          const newMessage: Message = {\n            id: userEvent.eventId,\n            role: MessageRole.User,\n            type: MessageType.QueryTyped,\n            createdAt: userEvent.createdAt,\n            metadata: {\n              content: userEvent.attributes.query,\n            },\n          };\n          setMessages(current => [...current, [newMessage]]);\n        }\n        if (userEvent && userEvent.category === UserEventCategory.SuggestionClicked) {\n          const newMessage: Message = {\n            id: userEvent.eventId,\n            role: MessageRole.User,\n            type: MessageType.QueryTyped,\n            createdAt: userEvent.createdAt,\n            metadata: {\n              content: userEvent.attributes.content ?? '',\n            },\n          };\n          setMessages(current => [...current, [newMessage]]);\n        }\n      });\n\n      sendMessagesToBackend(\n        createResponsePayload({\n          userEvents: payloadEvents,\n          generationParams: settingsContext.generationParams,\n        }),\n      );\n    } else if (isInitialized) {\n      getSuggestions(\n        createResponsePayload({\n          userEvents: [],\n          generationParams: settingsContext.generationParams,\n        }),\n      );\n    }\n  }, [\n    createResponsePayload,\n    getSuggestions,\n    isInitialized,\n    setMessages,\n    sendMessagesToBackend,\n    settingsContext.generationParams,\n    userEvents,\n    userQueueEventCount,\n  ]);\n\n  useEffect(() => {\n    if (isInitialized) {\n      // Rehydrate any messages from the backend\n      hydrateMessages();\n    }\n  }, [isInitialized, hydrateMessages]);\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 = useAtomValue(responseStreamingAtom);\n  const isPendingResponse = useAtomValue(pendingResponseAtom);\n  const isInitialized = useAtomValue(initializedAtom);\n  const {\n    logPageVisit,\n    logUserEvent,\n    onSuggestionClicked,\n    onTypedMessageSubmitted,\n    onFormResponseSubmitted,\n  } = useSalesAgentChatAPI();\n\n  const salesAgent: SalesAgent = useMemo(() => {\n    return {\n      messages,\n      suggestions,\n      pendingMessages,\n      isInitialized,\n      isResponseStreaming,\n      isPendingResponse,\n      logPageVisit,\n      logUserEvent,\n      onSuggestionClicked,\n      onTypedMessageSubmitted,\n      onFormResponseSubmitted,\n    };\n  }, [\n    messages,\n    suggestions,\n    pendingMessages,\n    isInitialized,\n    isResponseStreaming,\n    isPendingResponse,\n    logPageVisit,\n    logUserEvent,\n    onSuggestionClicked,\n    onTypedMessageSubmitted,\n    onFormResponseSubmitted,\n  ]);\n  return salesAgent;\n};\n"],"mappings":";;;;;;;;;;;;;;AAoCA,MAAM,6CAA0D,OAAU;AAE1E,MAAaA,sBAAyD,EAAE,eAAe;CACrF,MAAM,qCAA0BC,wCAAmB;CACnD,MAAM,8CAAmCC,6CAAwB;CACjE,MAAM,gDAAqCC,0CAAqB;CAChE,MAAM,CAAC,eAAe,uCAA4BC,6CAAgB;CAClE,MAAM,kBAAkBC,2DAA0B;CAClD,MAAM,oCAAyBC,0CAAa;CAE5C,MAAM,EAAE,uBAAuB,uBAAuB,gBAAgB,oBACpEC,gDAAsB;CAOxB,MAAM,+CACJ,OAAO,mBAAuC;AAC5C,MAAI;GACF,MAAM,WAAW,MAAM,sBAAsB,eAAe;AAC5D,oBAAiB,KAAK;AAEtB,WAAQ,IAAI,YAAY,SAAS;AAEjC,kBAAe,YAAY,KAAI,cAAa,wBAAwB,CAAC,UAAU,QAAQ,CAAC,CAAC;WAClF,OAAO;AACd,WAAQ,MAAM,wBAAwB;;IAG1C;EAAC;EAAuB;EAAkB;EAAwB,CACnE;AAED,SAAQ,IAAI,uBAAuB,oBAAoB;AACvD,SAAQ,IAAI,cAAc,WAAW;AAKrC,4BAAgB;AACd,UAAQ,IAAI,gCAAgC,qBAAqB,eAAe,WAAW;AAC3F,MAAI,sBAAsB,GAAG;GAC3B,MAAM,gBAAgB,WAAW,MAAM,GAAG,oBAAoB;AAE9D,iBAAc,SAAQ,cAAa;AACjC,QAAI,aAAa,UAAU,aAAaC,kDAAkB,YAAY;KACpE,MAAMC,aAAsB;MAC1B,IAAI,UAAU;MACd,MAAMC,4BAAY;MAClB,MAAMC,4BAAY;MAClB,WAAW,UAAU;MACrB,UAAU,EACR,SAAS,UAAU,WAAW,OAC/B;MACF;AACD,kBAAY,YAAW,CAAC,GAAG,SAAS,CAAC,WAAW,CAAC,CAAC;;AAEpD,QAAI,aAAa,UAAU,aAAaH,kDAAkB,mBAAmB;KAC3E,MAAMC,aAAsB;MAC1B,IAAI,UAAU;MACd,MAAMC,4BAAY;MAClB,MAAMC,4BAAY;MAClB,WAAW,UAAU;MACrB,UAAU,EACR,SAAS,UAAU,WAAW,WAAW,IAC1C;MACF;AACD,kBAAY,YAAW,CAAC,GAAG,SAAS,CAAC,WAAW,CAAC,CAAC;;KAEpD;AAEF,yBACE,sBAAsB;IACpB,YAAY;IACZ,kBAAkB,gBAAgB;IACnC,CAAC,CACH;aACQ,cACT,gBACE,sBAAsB;GACpB,YAAY,EAAE;GACd,kBAAkB,gBAAgB;GACnC,CAAC,CACH;IAEF;EACD;EACA;EACA;EACA;EACA;EACA,gBAAgB;EAChB;EACA;EACD,CAAC;AAEF,4BAAgB;AACd,MAAI,cAEF,kBAAiB;IAElB,CAAC,eAAe,gBAAgB,CAAC;AAEpC,QAAO,2CAAC,kBAAkB;EAAS,OAAO;EAAY;GAAsC;;AAG9F,MAAa,sBAAkC;CAC7C,MAAM,mCAAwBL,0CAAa;CAC3C,MAAM,sCAA2BM,6CAAgB;CACjD,MAAM,0CAA+BX,wCAAmB;CACxD,MAAM,8CAAmCY,mDAAsB;CAC/D,MAAM,4CAAiCC,iDAAoB;CAC3D,MAAM,wCAA6BV,6CAAgB;CACnD,MAAM,EACJ,cACA,cACA,qBACA,yBACA,4BACEW,sCAAsB;AA6B1B,iCA3B6C;AAC3C,SAAO;GACL;GACA;GACA;GACA;GACA;GACA;GACA;GACA;GACA;GACA;GACA;GACD;IACA;EACD;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACD,CAAC"}
129
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"salesAgentContext.cjs","names":["SalesAgentProvider: React.FC<{ children: ReactNode }>","userEventQueueAtom","userQueueEventCountAtom","processUserEventAtom","initializedAtom","useSystemSettingsContext","messagesAtom","useSalesAgentService","UserEventCategory","newMessage: Message","MessageRole","MessageType","suggestionsAtom","responseStreamingAtom","pendingResponseAtom","useSalesAgentChatAPI"],"sources":["../../../src/contexts/salesAgentContext/salesAgentContext.tsx"],"sourcesContent":["import { useAtom, useAtomValue, useSetAtom } from 'jotai';\nimport { ReactNode, createContext, useCallback, useEffect, useMemo } from 'react';\nimport { UserEventCategory } from '@spiffy-ai/commerce-api-client';\nimport Logger from 'src/application/logging/logger';\nimport { Message, MessageRole, MessageType } from 'src/application/models/message';\nimport { NextMessageRequest, Suggestion, UserEvent } from 'src/application/models';\nimport {\n  initializedAtom,\n  messagesAtom,\n  pendingResponseAtom,\n  responseStreamingAtom,\n  suggestionsAtom,\n} 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\nexport interface 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 [isInitialized, setIsInitialized] = useAtom(initializedAtom);\n  const settingsContext = useSystemSettingsContext();\n  const setMessages = useSetAtom(messagesAtom);\n\n  const { getStreamingResponses, createResponsePayload, getSuggestions, hydrateMessages } =\n    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(\n    async (requestPayload: NextMessageRequest) => {\n      try {\n        await getStreamingResponses(requestPayload);\n        setIsInitialized(true);\n\n        // Remove the pending message from the user events\n        requestPayload.userEvents?.map(userEvent => markUserEventsProcessed([userEvent.eventId]));\n      } catch (error) {\n        Logger.logError('[envive-ai] error sending message', error);\n      }\n    },\n    [getStreamingResponses, setIsInitialized, markUserEventsProcessed],\n  );\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      const payloadEvents = userEvents.slice(0, userQueueEventCount);\n\n      payloadEvents.forEach(userEvent => {\n        if (userEvent && userEvent.category === UserEventCategory.QueryTyped) {\n          const newMessage: Message = {\n            id: userEvent.eventId,\n            role: MessageRole.User,\n            type: MessageType.QueryTyped,\n            createdAt: userEvent.createdAt,\n            metadata: {\n              content: userEvent.attributes.query,\n            },\n          };\n          setMessages(current => [...current, [newMessage]]);\n        }\n        if (userEvent && userEvent.category === UserEventCategory.SuggestionClicked) {\n          const newMessage: Message = {\n            id: userEvent.eventId,\n            role: MessageRole.User,\n            type: MessageType.QueryTyped,\n            createdAt: userEvent.createdAt,\n            metadata: {\n              content: userEvent.attributes.content ?? '',\n            },\n          };\n          setMessages(current => [...current, [newMessage]]);\n        }\n      });\n\n      sendMessagesToBackend(\n        createResponsePayload({\n          userEvents: payloadEvents,\n          generationParams: settingsContext.generationParams,\n        }),\n      );\n    } else if (isInitialized) {\n      getSuggestions(\n        createResponsePayload({\n          userEvents: [],\n          generationParams: settingsContext.generationParams,\n        }),\n      );\n    }\n  }, [\n    createResponsePayload,\n    getSuggestions,\n    isInitialized,\n    setMessages,\n    sendMessagesToBackend,\n    settingsContext.generationParams,\n    userEvents,\n    userQueueEventCount,\n  ]);\n\n  useEffect(() => {\n    if (isInitialized) {\n      // Rehydrate any messages from the backend\n      hydrateMessages();\n    }\n  }, [isInitialized, hydrateMessages]);\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 = useAtomValue(responseStreamingAtom);\n  const isPendingResponse = useAtomValue(pendingResponseAtom);\n  const isInitialized = useAtomValue(initializedAtom);\n  const {\n    logPageVisit,\n    logUserEvent,\n    onSuggestionClicked,\n    onTypedMessageSubmitted,\n    onFormResponseSubmitted,\n  } = useSalesAgentChatAPI();\n\n  const salesAgent: SalesAgent = useMemo(() => {\n    return {\n      messages,\n      suggestions,\n      pendingMessages,\n      isInitialized,\n      isResponseStreaming,\n      isPendingResponse,\n      logPageVisit,\n      logUserEvent,\n      onSuggestionClicked,\n      onTypedMessageSubmitted,\n      onFormResponseSubmitted,\n    };\n  }, [\n    messages,\n    suggestions,\n    pendingMessages,\n    isInitialized,\n    isResponseStreaming,\n    isPendingResponse,\n    logPageVisit,\n    logUserEvent,\n    onSuggestionClicked,\n    onTypedMessageSubmitted,\n    onFormResponseSubmitted,\n  ]);\n  return salesAgent;\n};\n"],"mappings":";;;;;;;;;;;;;;;AAqCA,MAAM,6CAA0D,OAAU;AAE1E,MAAaA,sBAAyD,EAAE,eAAe;CACrF,MAAM,qCAA0BC,wCAAmB;CACnD,MAAM,8CAAmCC,6CAAwB;CACjE,MAAM,gDAAqCC,0CAAqB;CAChE,MAAM,CAAC,eAAe,uCAA4BC,6CAAgB;CAClE,MAAM,kBAAkBC,2DAA0B;CAClD,MAAM,oCAAyBC,0CAAa;CAE5C,MAAM,EAAE,uBAAuB,uBAAuB,gBAAgB,oBACpEC,gDAAsB;CAOxB,MAAM,+CACJ,OAAO,mBAAuC;AAC5C,MAAI;AACF,SAAM,sBAAsB,eAAe;AAC3C,oBAAiB,KAAK;AAGtB,kBAAe,YAAY,KAAI,cAAa,wBAAwB,CAAC,UAAU,QAAQ,CAAC,CAAC;WAClF,OAAO;AACd,0BAAO,SAAS,qCAAqC,MAAM;;IAG/D;EAAC;EAAuB;EAAkB;EAAwB,CACnE;AAKD,4BAAgB;AACd,MAAI,sBAAsB,GAAG;GAC3B,MAAM,gBAAgB,WAAW,MAAM,GAAG,oBAAoB;AAE9D,iBAAc,SAAQ,cAAa;AACjC,QAAI,aAAa,UAAU,aAAaC,kDAAkB,YAAY;KACpE,MAAMC,aAAsB;MAC1B,IAAI,UAAU;MACd,MAAMC,4BAAY;MAClB,MAAMC,4BAAY;MAClB,WAAW,UAAU;MACrB,UAAU,EACR,SAAS,UAAU,WAAW,OAC/B;MACF;AACD,kBAAY,YAAW,CAAC,GAAG,SAAS,CAAC,WAAW,CAAC,CAAC;;AAEpD,QAAI,aAAa,UAAU,aAAaH,kDAAkB,mBAAmB;KAC3E,MAAMC,aAAsB;MAC1B,IAAI,UAAU;MACd,MAAMC,4BAAY;MAClB,MAAMC,4BAAY;MAClB,WAAW,UAAU;MACrB,UAAU,EACR,SAAS,UAAU,WAAW,WAAW,IAC1C;MACF;AACD,kBAAY,YAAW,CAAC,GAAG,SAAS,CAAC,WAAW,CAAC,CAAC;;KAEpD;AAEF,yBACE,sBAAsB;IACpB,YAAY;IACZ,kBAAkB,gBAAgB;IACnC,CAAC,CACH;aACQ,cACT,gBACE,sBAAsB;GACpB,YAAY,EAAE;GACd,kBAAkB,gBAAgB;GACnC,CAAC,CACH;IAEF;EACD;EACA;EACA;EACA;EACA;EACA,gBAAgB;EAChB;EACA;EACD,CAAC;AAEF,4BAAgB;AACd,MAAI,cAEF,kBAAiB;IAElB,CAAC,eAAe,gBAAgB,CAAC;AAEpC,QAAO,2CAAC,kBAAkB;EAAS,OAAO;EAAY;GAAsC;;AAG9F,MAAa,sBAAkC;CAC7C,MAAM,mCAAwBL,0CAAa;CAC3C,MAAM,sCAA2BM,6CAAgB;CACjD,MAAM,0CAA+BX,wCAAmB;CACxD,MAAM,8CAAmCY,mDAAsB;CAC/D,MAAM,4CAAiCC,iDAAoB;CAC3D,MAAM,wCAA6BV,6CAAgB;CACnD,MAAM,EACJ,cACA,cACA,qBACA,yBACA,4BACEW,sCAAsB;AA6B1B,iCA3B6C;AAC3C,SAAO;GACL;GACA;GACA;GACA;GACA;GACA;GACA;GACA;GACA;GACA;GACA;GACD;IACA;EACD;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACD,CAAC"}
@@ -1,4 +1,5 @@
1
1
  import { MessageRole, MessageType } from "../../application/models/message.js";
2
+ import logger_default from "../../application/logging/logger.js";
2
3
  import { initializedAtom, messagesAtom, pendingResponseAtom, responseStreamingAtom, suggestionsAtom } from "../../atoms/chat/chatState.js";
3
4
  import { processUserEventAtom, userEventQueueAtom, userQueueEventCountAtom } from "../../atoms/chat/messageQueue.js";
4
5
  import { useSystemSettingsContext } from "../../hooks/SystemSettingsContext/useSystemSettingsContext.js";
@@ -22,22 +23,18 @@ const SalesAgentProvider = ({ children }) => {
22
23
  const { getStreamingResponses, createResponsePayload, getSuggestions, hydrateMessages } = useSalesAgentService();
23
24
  const sendMessagesToBackend = useCallback(async (requestPayload) => {
24
25
  try {
25
- const response = await getStreamingResponses(requestPayload);
26
+ await getStreamingResponses(requestPayload);
26
27
  setIsInitialized(true);
27
- console.log("response", response);
28
28
  requestPayload.userEvents?.map((userEvent) => markUserEventsProcessed([userEvent.eventId]));
29
29
  } catch (error) {
30
- console.error("error sending message");
30
+ logger_default.logError("[envive-ai] error sending message", error);
31
31
  }
32
32
  }, [
33
33
  getStreamingResponses,
34
34
  setIsInitialized,
35
35
  markUserEventsProcessed
36
36
  ]);
37
- console.log("userQueueEventCount", userQueueEventCount);
38
- console.log("userEvents", userEvents);
39
37
  useEffect(() => {
40
- console.log("SalesAgentProvider useEffect", userQueueEventCount, isInitialized, userEvents);
41
38
  if (userQueueEventCount > 0) {
42
39
  const payloadEvents = userEvents.slice(0, userQueueEventCount);
43
40
  payloadEvents.forEach((userEvent) => {
@@ -127,4 +124,4 @@ const useSalesAgent = () => {
127
124
 
128
125
  //#endregion
129
126
  export { SalesAgentProvider, useSalesAgent };
130
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"salesAgentContext.js","names":["SalesAgentProvider: React.FC<{ children: ReactNode }>","newMessage: Message"],"sources":["../../../src/contexts/salesAgentContext/salesAgentContext.tsx"],"sourcesContent":["import { useAtom, useAtomValue, useSetAtom } from 'jotai';\nimport { ReactNode, createContext, useCallback, useEffect, useMemo } from 'react';\nimport { UserEventCategory } from '@spiffy-ai/commerce-api-client';\nimport { Message, MessageRole, MessageType } from 'src/application/models/message';\nimport { NextMessageRequest, Suggestion, UserEvent } from 'src/application/models';\nimport {\n  initializedAtom,\n  messagesAtom,\n  pendingResponseAtom,\n  responseStreamingAtom,\n  suggestionsAtom,\n} 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\nexport interface 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 [isInitialized, setIsInitialized] = useAtom(initializedAtom);\n  const settingsContext = useSystemSettingsContext();\n  const setMessages = useSetAtom(messagesAtom);\n\n  const { getStreamingResponses, createResponsePayload, getSuggestions, hydrateMessages } =\n    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(\n    async (requestPayload: NextMessageRequest) => {\n      try {\n        const response = await getStreamingResponses(requestPayload);\n        setIsInitialized(true);\n\n        console.log('response', response);\n        // Remove the pending message from the user events\n        requestPayload.userEvents?.map(userEvent => markUserEventsProcessed([userEvent.eventId]));\n      } catch (error) {\n        console.error('error sending message');\n      }\n    },\n    [getStreamingResponses, setIsInitialized, 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    console.log('SalesAgentProvider useEffect', userQueueEventCount, isInitialized, userEvents);\n    if (userQueueEventCount > 0) {\n      const payloadEvents = userEvents.slice(0, userQueueEventCount);\n\n      payloadEvents.forEach(userEvent => {\n        if (userEvent && userEvent.category === UserEventCategory.QueryTyped) {\n          const newMessage: Message = {\n            id: userEvent.eventId,\n            role: MessageRole.User,\n            type: MessageType.QueryTyped,\n            createdAt: userEvent.createdAt,\n            metadata: {\n              content: userEvent.attributes.query,\n            },\n          };\n          setMessages(current => [...current, [newMessage]]);\n        }\n        if (userEvent && userEvent.category === UserEventCategory.SuggestionClicked) {\n          const newMessage: Message = {\n            id: userEvent.eventId,\n            role: MessageRole.User,\n            type: MessageType.QueryTyped,\n            createdAt: userEvent.createdAt,\n            metadata: {\n              content: userEvent.attributes.content ?? '',\n            },\n          };\n          setMessages(current => [...current, [newMessage]]);\n        }\n      });\n\n      sendMessagesToBackend(\n        createResponsePayload({\n          userEvents: payloadEvents,\n          generationParams: settingsContext.generationParams,\n        }),\n      );\n    } else if (isInitialized) {\n      getSuggestions(\n        createResponsePayload({\n          userEvents: [],\n          generationParams: settingsContext.generationParams,\n        }),\n      );\n    }\n  }, [\n    createResponsePayload,\n    getSuggestions,\n    isInitialized,\n    setMessages,\n    sendMessagesToBackend,\n    settingsContext.generationParams,\n    userEvents,\n    userQueueEventCount,\n  ]);\n\n  useEffect(() => {\n    if (isInitialized) {\n      // Rehydrate any messages from the backend\n      hydrateMessages();\n    }\n  }, [isInitialized, hydrateMessages]);\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 = useAtomValue(responseStreamingAtom);\n  const isPendingResponse = useAtomValue(pendingResponseAtom);\n  const isInitialized = useAtomValue(initializedAtom);\n  const {\n    logPageVisit,\n    logUserEvent,\n    onSuggestionClicked,\n    onTypedMessageSubmitted,\n    onFormResponseSubmitted,\n  } = useSalesAgentChatAPI();\n\n  const salesAgent: SalesAgent = useMemo(() => {\n    return {\n      messages,\n      suggestions,\n      pendingMessages,\n      isInitialized,\n      isResponseStreaming,\n      isPendingResponse,\n      logPageVisit,\n      logUserEvent,\n      onSuggestionClicked,\n      onTypedMessageSubmitted,\n      onFormResponseSubmitted,\n    };\n  }, [\n    messages,\n    suggestions,\n    pendingMessages,\n    isInitialized,\n    isResponseStreaming,\n    isPendingResponse,\n    logPageVisit,\n    logUserEvent,\n    onSuggestionClicked,\n    onTypedMessageSubmitted,\n    onFormResponseSubmitted,\n  ]);\n  return salesAgent;\n};\n"],"mappings":";;;;;;;;;;;;;AAoCA,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,CAAC,eAAe,oBAAoB,QAAQ,gBAAgB;CAClE,MAAM,kBAAkB,0BAA0B;CAClD,MAAM,cAAc,WAAW,aAAa;CAE5C,MAAM,EAAE,uBAAuB,uBAAuB,gBAAgB,oBACpE,sBAAsB;CAOxB,MAAM,wBAAwB,YAC5B,OAAO,mBAAuC;AAC5C,MAAI;GACF,MAAM,WAAW,MAAM,sBAAsB,eAAe;AAC5D,oBAAiB,KAAK;AAEtB,WAAQ,IAAI,YAAY,SAAS;AAEjC,kBAAe,YAAY,KAAI,cAAa,wBAAwB,CAAC,UAAU,QAAQ,CAAC,CAAC;WAClF,OAAO;AACd,WAAQ,MAAM,wBAAwB;;IAG1C;EAAC;EAAuB;EAAkB;EAAwB,CACnE;AAED,SAAQ,IAAI,uBAAuB,oBAAoB;AACvD,SAAQ,IAAI,cAAc,WAAW;AAKrC,iBAAgB;AACd,UAAQ,IAAI,gCAAgC,qBAAqB,eAAe,WAAW;AAC3F,MAAI,sBAAsB,GAAG;GAC3B,MAAM,gBAAgB,WAAW,MAAM,GAAG,oBAAoB;AAE9D,iBAAc,SAAQ,cAAa;AACjC,QAAI,aAAa,UAAU,aAAa,kBAAkB,YAAY;KACpE,MAAMC,aAAsB;MAC1B,IAAI,UAAU;MACd,MAAM,YAAY;MAClB,MAAM,YAAY;MAClB,WAAW,UAAU;MACrB,UAAU,EACR,SAAS,UAAU,WAAW,OAC/B;MACF;AACD,kBAAY,YAAW,CAAC,GAAG,SAAS,CAAC,WAAW,CAAC,CAAC;;AAEpD,QAAI,aAAa,UAAU,aAAa,kBAAkB,mBAAmB;KAC3E,MAAMA,aAAsB;MAC1B,IAAI,UAAU;MACd,MAAM,YAAY;MAClB,MAAM,YAAY;MAClB,WAAW,UAAU;MACrB,UAAU,EACR,SAAS,UAAU,WAAW,WAAW,IAC1C;MACF;AACD,kBAAY,YAAW,CAAC,GAAG,SAAS,CAAC,WAAW,CAAC,CAAC;;KAEpD;AAEF,yBACE,sBAAsB;IACpB,YAAY;IACZ,kBAAkB,gBAAgB;IACnC,CAAC,CACH;aACQ,cACT,gBACE,sBAAsB;GACpB,YAAY,EAAE;GACd,kBAAkB,gBAAgB;GACnC,CAAC,CACH;IAEF;EACD;EACA;EACA;EACA;EACA;EACA,gBAAgB;EAChB;EACA;EACD,CAAC;AAEF,iBAAgB;AACd,MAAI,cAEF,kBAAiB;IAElB,CAAC,eAAe,gBAAgB,CAAC;AAEpC,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,aAAa,sBAAsB;CAC/D,MAAM,oBAAoB,aAAa,oBAAoB;CAC3D,MAAM,gBAAgB,aAAa,gBAAgB;CACnD,MAAM,EACJ,cACA,cACA,qBACA,yBACA,4BACE,sBAAsB;AA6B1B,QA3B+B,cAAc;AAC3C,SAAO;GACL;GACA;GACA;GACA;GACA;GACA;GACA;GACA;GACA;GACA;GACA;GACD;IACA;EACD;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACD,CAAC"}
127
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"salesAgentContext.js","names":["SalesAgentProvider: React.FC<{ children: ReactNode }>","newMessage: Message"],"sources":["../../../src/contexts/salesAgentContext/salesAgentContext.tsx"],"sourcesContent":["import { useAtom, useAtomValue, useSetAtom } from 'jotai';\nimport { ReactNode, createContext, useCallback, useEffect, useMemo } from 'react';\nimport { UserEventCategory } from '@spiffy-ai/commerce-api-client';\nimport Logger from 'src/application/logging/logger';\nimport { Message, MessageRole, MessageType } from 'src/application/models/message';\nimport { NextMessageRequest, Suggestion, UserEvent } from 'src/application/models';\nimport {\n  initializedAtom,\n  messagesAtom,\n  pendingResponseAtom,\n  responseStreamingAtom,\n  suggestionsAtom,\n} 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\nexport interface 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 [isInitialized, setIsInitialized] = useAtom(initializedAtom);\n  const settingsContext = useSystemSettingsContext();\n  const setMessages = useSetAtom(messagesAtom);\n\n  const { getStreamingResponses, createResponsePayload, getSuggestions, hydrateMessages } =\n    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(\n    async (requestPayload: NextMessageRequest) => {\n      try {\n        await getStreamingResponses(requestPayload);\n        setIsInitialized(true);\n\n        // Remove the pending message from the user events\n        requestPayload.userEvents?.map(userEvent => markUserEventsProcessed([userEvent.eventId]));\n      } catch (error) {\n        Logger.logError('[envive-ai] error sending message', error);\n      }\n    },\n    [getStreamingResponses, setIsInitialized, markUserEventsProcessed],\n  );\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      const payloadEvents = userEvents.slice(0, userQueueEventCount);\n\n      payloadEvents.forEach(userEvent => {\n        if (userEvent && userEvent.category === UserEventCategory.QueryTyped) {\n          const newMessage: Message = {\n            id: userEvent.eventId,\n            role: MessageRole.User,\n            type: MessageType.QueryTyped,\n            createdAt: userEvent.createdAt,\n            metadata: {\n              content: userEvent.attributes.query,\n            },\n          };\n          setMessages(current => [...current, [newMessage]]);\n        }\n        if (userEvent && userEvent.category === UserEventCategory.SuggestionClicked) {\n          const newMessage: Message = {\n            id: userEvent.eventId,\n            role: MessageRole.User,\n            type: MessageType.QueryTyped,\n            createdAt: userEvent.createdAt,\n            metadata: {\n              content: userEvent.attributes.content ?? '',\n            },\n          };\n          setMessages(current => [...current, [newMessage]]);\n        }\n      });\n\n      sendMessagesToBackend(\n        createResponsePayload({\n          userEvents: payloadEvents,\n          generationParams: settingsContext.generationParams,\n        }),\n      );\n    } else if (isInitialized) {\n      getSuggestions(\n        createResponsePayload({\n          userEvents: [],\n          generationParams: settingsContext.generationParams,\n        }),\n      );\n    }\n  }, [\n    createResponsePayload,\n    getSuggestions,\n    isInitialized,\n    setMessages,\n    sendMessagesToBackend,\n    settingsContext.generationParams,\n    userEvents,\n    userQueueEventCount,\n  ]);\n\n  useEffect(() => {\n    if (isInitialized) {\n      // Rehydrate any messages from the backend\n      hydrateMessages();\n    }\n  }, [isInitialized, hydrateMessages]);\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 = useAtomValue(responseStreamingAtom);\n  const isPendingResponse = useAtomValue(pendingResponseAtom);\n  const isInitialized = useAtomValue(initializedAtom);\n  const {\n    logPageVisit,\n    logUserEvent,\n    onSuggestionClicked,\n    onTypedMessageSubmitted,\n    onFormResponseSubmitted,\n  } = useSalesAgentChatAPI();\n\n  const salesAgent: SalesAgent = useMemo(() => {\n    return {\n      messages,\n      suggestions,\n      pendingMessages,\n      isInitialized,\n      isResponseStreaming,\n      isPendingResponse,\n      logPageVisit,\n      logUserEvent,\n      onSuggestionClicked,\n      onTypedMessageSubmitted,\n      onFormResponseSubmitted,\n    };\n  }, [\n    messages,\n    suggestions,\n    pendingMessages,\n    isInitialized,\n    isResponseStreaming,\n    isPendingResponse,\n    logPageVisit,\n    logUserEvent,\n    onSuggestionClicked,\n    onTypedMessageSubmitted,\n    onFormResponseSubmitted,\n  ]);\n  return salesAgent;\n};\n"],"mappings":";;;;;;;;;;;;;;AAqCA,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,CAAC,eAAe,oBAAoB,QAAQ,gBAAgB;CAClE,MAAM,kBAAkB,0BAA0B;CAClD,MAAM,cAAc,WAAW,aAAa;CAE5C,MAAM,EAAE,uBAAuB,uBAAuB,gBAAgB,oBACpE,sBAAsB;CAOxB,MAAM,wBAAwB,YAC5B,OAAO,mBAAuC;AAC5C,MAAI;AACF,SAAM,sBAAsB,eAAe;AAC3C,oBAAiB,KAAK;AAGtB,kBAAe,YAAY,KAAI,cAAa,wBAAwB,CAAC,UAAU,QAAQ,CAAC,CAAC;WAClF,OAAO;AACd,kBAAO,SAAS,qCAAqC,MAAM;;IAG/D;EAAC;EAAuB;EAAkB;EAAwB,CACnE;AAKD,iBAAgB;AACd,MAAI,sBAAsB,GAAG;GAC3B,MAAM,gBAAgB,WAAW,MAAM,GAAG,oBAAoB;AAE9D,iBAAc,SAAQ,cAAa;AACjC,QAAI,aAAa,UAAU,aAAa,kBAAkB,YAAY;KACpE,MAAMC,aAAsB;MAC1B,IAAI,UAAU;MACd,MAAM,YAAY;MAClB,MAAM,YAAY;MAClB,WAAW,UAAU;MACrB,UAAU,EACR,SAAS,UAAU,WAAW,OAC/B;MACF;AACD,kBAAY,YAAW,CAAC,GAAG,SAAS,CAAC,WAAW,CAAC,CAAC;;AAEpD,QAAI,aAAa,UAAU,aAAa,kBAAkB,mBAAmB;KAC3E,MAAMA,aAAsB;MAC1B,IAAI,UAAU;MACd,MAAM,YAAY;MAClB,MAAM,YAAY;MAClB,WAAW,UAAU;MACrB,UAAU,EACR,SAAS,UAAU,WAAW,WAAW,IAC1C;MACF;AACD,kBAAY,YAAW,CAAC,GAAG,SAAS,CAAC,WAAW,CAAC,CAAC;;KAEpD;AAEF,yBACE,sBAAsB;IACpB,YAAY;IACZ,kBAAkB,gBAAgB;IACnC,CAAC,CACH;aACQ,cACT,gBACE,sBAAsB;GACpB,YAAY,EAAE;GACd,kBAAkB,gBAAgB;GACnC,CAAC,CACH;IAEF;EACD;EACA;EACA;EACA;EACA;EACA,gBAAgB;EAChB;EACA;EACD,CAAC;AAEF,iBAAgB;AACd,MAAI,cAEF,kBAAiB;IAElB,CAAC,eAAe,gBAAgB,CAAC;AAEpC,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,aAAa,sBAAsB;CAC/D,MAAM,oBAAoB,aAAa,oBAAoB;CAC3D,MAAM,gBAAgB,aAAa,gBAAgB;CACnD,MAAM,EACJ,cACA,cACA,qBACA,yBACA,4BACE,sBAAsB;AA6B1B,QA3B+B,cAAc;AAC3C,SAAO;GACL;GACA;GACA;GACA;GACA;GACA;GACA;GACA;GACA;GACA;GACA;GACD;IACA;EACD;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACD,CAAC"}