droplinked-chatbot-next 1.0.2

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 (175) hide show
  1. package/README.md +205 -0
  2. package/dist/assets/animations/chat-greeting.json +1 -0
  3. package/dist/assets/icons/AI/AI/AIMd.d.ts +2 -0
  4. package/dist/assets/icons/AI/AI/AIMd.js +3 -0
  5. package/dist/assets/icons/AI/AI/AIMd.js.map +1 -0
  6. package/dist/assets/icons/Action/Refresh2/Refresh2Sm.d.ts +2 -0
  7. package/dist/assets/icons/Action/Refresh2/Refresh2Sm.js +3 -0
  8. package/dist/assets/icons/Action/Refresh2/Refresh2Sm.js.map +1 -0
  9. package/dist/assets/icons/Action/Send/SendSm.d.ts +2 -0
  10. package/dist/assets/icons/Action/Send/SendSm.js +3 -0
  11. package/dist/assets/icons/Action/Send/SendSm.js.map +1 -0
  12. package/dist/assets/icons/Navigation/ChevronLeft/ChevronleftMd.d.ts +2 -0
  13. package/dist/assets/icons/Navigation/ChevronLeft/ChevronleftMd.js +3 -0
  14. package/dist/assets/icons/Navigation/ChevronLeft/ChevronleftMd.js.map +1 -0
  15. package/dist/assets/icons/Navigation/ExternalArrow/ExternalarrowMd.d.ts +2 -0
  16. package/dist/assets/icons/Navigation/ExternalArrow/ExternalarrowMd.js +3 -0
  17. package/dist/assets/icons/Navigation/ExternalArrow/ExternalarrowMd.js.map +1 -0
  18. package/dist/assets/icons/Sign/Close/CloseMd.d.ts +2 -0
  19. package/dist/assets/icons/Sign/Close/CloseMd.js +3 -0
  20. package/dist/assets/icons/Sign/Close/CloseMd.js.map +1 -0
  21. package/dist/assets/icons/Sign/Help/HelpMd.d.ts +2 -0
  22. package/dist/assets/icons/Sign/Help/HelpMd.js +3 -0
  23. package/dist/assets/icons/Sign/Help/HelpMd.js.map +1 -0
  24. package/dist/assets/icons/Sign/Tooltip/TooltipMd.d.ts +2 -0
  25. package/dist/assets/icons/Sign/Tooltip/TooltipMd.js +3 -0
  26. package/dist/assets/icons/Sign/Tooltip/TooltipMd.js.map +1 -0
  27. package/dist/assets/icons/Sign/Warning/WarningMd.d.ts +2 -0
  28. package/dist/assets/icons/Sign/Warning/WarningMd.js +3 -0
  29. package/dist/assets/icons/Sign/Warning/WarningMd.js.map +1 -0
  30. package/dist/components/ChatDrawer.d.ts +9 -0
  31. package/dist/components/ChatDrawer.js +15 -0
  32. package/dist/components/ChatDrawer.js.map +1 -0
  33. package/dist/components/ChatHeader.d.ts +8 -0
  34. package/dist/components/ChatHeader.js +13 -0
  35. package/dist/components/ChatHeader.js.map +1 -0
  36. package/dist/components/ChatPage.d.ts +16 -0
  37. package/dist/components/Chatbot.d.ts +9 -0
  38. package/dist/components/Chatbot.js +20 -0
  39. package/dist/components/Chatbot.js.map +1 -0
  40. package/dist/components/EmbeddedChatButton.d.ts +5 -0
  41. package/dist/components/EmbeddedChatButton.js +13 -0
  42. package/dist/components/EmbeddedChatButton.js.map +1 -0
  43. package/dist/components/ErrorMessage.d.ts +6 -0
  44. package/dist/components/ErrorMessage.js +24 -0
  45. package/dist/components/ErrorMessage.js.map +1 -0
  46. package/dist/components/FloatingChatButton.d.ts +6 -0
  47. package/dist/components/FloatingChatButton.js +17 -0
  48. package/dist/components/FloatingChatButton.js.map +1 -0
  49. package/dist/components/GradualMessageDisplay.d.ts +9 -0
  50. package/dist/components/GradualMessageDisplay.js +141 -0
  51. package/dist/components/GradualMessageDisplay.js.map +1 -0
  52. package/dist/components/HeaderIconButton.d.ts +9 -0
  53. package/dist/components/HeaderIconButton.js +6 -0
  54. package/dist/components/HeaderIconButton.js.map +1 -0
  55. package/dist/components/HelloPage.d.ts +10 -0
  56. package/dist/components/MarkdownRenderer.d.ts +8 -0
  57. package/dist/components/MarkdownRenderer.js +40 -0
  58. package/dist/components/MarkdownRenderer.js.map +1 -0
  59. package/dist/components/MessageInput.d.ts +11 -0
  60. package/dist/components/MessageInput.js +52 -0
  61. package/dist/components/MessageInput.js.map +1 -0
  62. package/dist/components/MessageList.d.ts +12 -0
  63. package/dist/components/MessageList.js +64 -0
  64. package/dist/components/MessageList.js.map +1 -0
  65. package/dist/components/RuledGrid.d.ts +6 -0
  66. package/dist/components/RuledGrid.js +9 -0
  67. package/dist/components/RuledGrid.js.map +1 -0
  68. package/dist/components/TypingIndicator.d.ts +8 -0
  69. package/dist/components/TypingIndicator.js +92 -0
  70. package/dist/components/TypingIndicator.js.map +1 -0
  71. package/dist/components/input/EmailCapture.d.ts +6 -0
  72. package/dist/components/input/EmailCapture.js +15 -0
  73. package/dist/components/input/EmailCapture.js.map +1 -0
  74. package/dist/components/input/MessageInput.d.ts +11 -0
  75. package/dist/components/input/SuggestionChips.d.ts +7 -0
  76. package/dist/components/input/SuggestionChips.js +8 -0
  77. package/dist/components/input/SuggestionChips.js.map +1 -0
  78. package/dist/components/messages/ErrorMessage.d.ts +6 -0
  79. package/dist/components/messages/MessageItem.d.ts +10 -0
  80. package/dist/components/messages/MessageItem.js +20 -0
  81. package/dist/components/messages/MessageItem.js.map +1 -0
  82. package/dist/components/ui/tooltip.d.ts +11 -0
  83. package/dist/components/ui/tooltip.js +9 -0
  84. package/dist/components/ui/tooltip.js.map +1 -0
  85. package/dist/hooks/useChatbot.d.ts +27 -0
  86. package/dist/hooks/useChatbot.js +229 -0
  87. package/dist/hooks/useChatbot.js.map +1 -0
  88. package/dist/index.d.ts +19 -0
  89. package/dist/index.esm.js +66459 -0
  90. package/dist/index.esm.js.map +1 -0
  91. package/dist/index.js +66499 -0
  92. package/dist/index.js.map +1 -0
  93. package/dist/lib/chatbot/api/client.d.ts +30 -0
  94. package/dist/lib/chatbot/api/client.js +130 -0
  95. package/dist/lib/chatbot/api/client.js.map +1 -0
  96. package/dist/lib/chatbot/components/ChatDrawer.d.ts +9 -0
  97. package/dist/lib/chatbot/components/ChatDrawer.js +15 -0
  98. package/dist/lib/chatbot/components/ChatDrawer.js.map +1 -0
  99. package/dist/lib/chatbot/components/ChatHeader.d.ts +8 -0
  100. package/dist/lib/chatbot/components/ChatHeader.js +14 -0
  101. package/dist/lib/chatbot/components/ChatHeader.js.map +1 -0
  102. package/dist/lib/chatbot/components/Chatbot.d.ts +10 -0
  103. package/dist/lib/chatbot/components/Chatbot.js +20 -0
  104. package/dist/lib/chatbot/components/Chatbot.js.map +1 -0
  105. package/dist/lib/chatbot/components/EmbeddedChatButton.d.ts +5 -0
  106. package/dist/lib/chatbot/components/EmbeddedChatButton.js +13 -0
  107. package/dist/lib/chatbot/components/EmbeddedChatButton.js.map +1 -0
  108. package/dist/lib/chatbot/components/ErrorMessage.d.ts +6 -0
  109. package/dist/lib/chatbot/components/ErrorMessage.js +24 -0
  110. package/dist/lib/chatbot/components/ErrorMessage.js.map +1 -0
  111. package/dist/lib/chatbot/components/FloatingChatButton.d.ts +6 -0
  112. package/dist/lib/chatbot/components/FloatingChatButton.js +17 -0
  113. package/dist/lib/chatbot/components/FloatingChatButton.js.map +1 -0
  114. package/dist/lib/chatbot/components/GradualMessageDisplay.d.ts +9 -0
  115. package/dist/lib/chatbot/components/GradualMessageDisplay.js +141 -0
  116. package/dist/lib/chatbot/components/GradualMessageDisplay.js.map +1 -0
  117. package/dist/lib/chatbot/components/MarkdownRenderer.d.ts +8 -0
  118. package/dist/lib/chatbot/components/MarkdownRenderer.js +40 -0
  119. package/dist/lib/chatbot/components/MarkdownRenderer.js.map +1 -0
  120. package/dist/lib/chatbot/components/MessageInput.d.ts +11 -0
  121. package/dist/lib/chatbot/components/MessageInput.js +69 -0
  122. package/dist/lib/chatbot/components/MessageInput.js.map +1 -0
  123. package/dist/lib/chatbot/components/MessageList.d.ts +12 -0
  124. package/dist/lib/chatbot/components/MessageList.js +85 -0
  125. package/dist/lib/chatbot/components/MessageList.js.map +1 -0
  126. package/dist/lib/chatbot/components/RuledGrid.d.ts +6 -0
  127. package/dist/lib/chatbot/components/RuledGrid.js +9 -0
  128. package/dist/lib/chatbot/components/RuledGrid.js.map +1 -0
  129. package/dist/lib/chatbot/components/TypingIndicator.d.ts +14 -0
  130. package/dist/lib/chatbot/components/TypingIndicator.js +98 -0
  131. package/dist/lib/chatbot/components/TypingIndicator.js.map +1 -0
  132. package/dist/lib/chatbot/components/ui/tooltip.d.ts +11 -0
  133. package/dist/lib/chatbot/components/ui/tooltip.js +9 -0
  134. package/dist/lib/chatbot/components/ui/tooltip.js.map +1 -0
  135. package/dist/lib/chatbot/hooks/useChatbot.d.ts +25 -0
  136. package/dist/lib/chatbot/hooks/useChatbot.js +212 -0
  137. package/dist/lib/chatbot/hooks/useChatbot.js.map +1 -0
  138. package/dist/lib/chatbot/index.d.ts +5 -0
  139. package/dist/lib/chatbot/index.js +5 -0
  140. package/dist/lib/chatbot/index.js.map +1 -0
  141. package/dist/lib/chatbot/types/index.d.ts +55 -0
  142. package/dist/lib/chatbot/types/index.js +2 -0
  143. package/dist/lib/chatbot/types/index.js.map +1 -0
  144. package/dist/lib/chatbot/utils/helpers.d.ts +9 -0
  145. package/dist/lib/chatbot/utils/helpers.js +55 -0
  146. package/dist/lib/chatbot/utils/helpers.js.map +1 -0
  147. package/dist/lib/chatbot/views/ChatPage.d.ts +16 -0
  148. package/dist/lib/chatbot/views/ChatPage.js +9 -0
  149. package/dist/lib/chatbot/views/ChatPage.js.map +1 -0
  150. package/dist/lib/chatbot/views/HelloPage.d.ts +10 -0
  151. package/dist/lib/chatbot/views/HelloPage.js +33 -0
  152. package/dist/lib/chatbot/views/HelloPage.js.map +1 -0
  153. package/dist/services/api.d.ts +30 -0
  154. package/dist/services/axiosClient.d.ts +8 -0
  155. package/dist/services/axiosClient.js +38 -0
  156. package/dist/services/axiosClient.js.map +1 -0
  157. package/dist/services/client.d.ts +31 -0
  158. package/dist/services/client.js +52 -0
  159. package/dist/services/client.js.map +1 -0
  160. package/dist/services/http.d.ts +8 -0
  161. package/dist/services/http.js +38 -0
  162. package/dist/services/http.js.map +1 -0
  163. package/dist/types/index.d.ts +55 -0
  164. package/dist/types/index.js +2 -0
  165. package/dist/types/index.js.map +1 -0
  166. package/dist/utils/helpers.d.ts +6 -0
  167. package/dist/utils/helpers.js +46 -0
  168. package/dist/utils/helpers.js.map +1 -0
  169. package/dist/views/ChatPage.d.ts +16 -0
  170. package/dist/views/ChatPage.js +9 -0
  171. package/dist/views/ChatPage.js.map +1 -0
  172. package/dist/views/HelloPage.d.ts +7 -0
  173. package/dist/views/HelloPage.js +33 -0
  174. package/dist/views/HelloPage.js.map +1 -0
  175. package/package.json +70 -0
@@ -0,0 +1,24 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { Box, Text, HStack, VStack, Button } from "@chakra-ui/react";
3
+ import { useState } from "react";
4
+ import { Refresh2Sm } from '../assets/icons/Action/Refresh2/Refresh2Sm';
5
+ import { WarningMd } from '../assets/icons/Sign/Warning/WarningMd';
6
+ function ErrorMessage({ onRetry, showRetry = true, }) {
7
+ const [isRetrying, setIsRetrying] = useState(false);
8
+ const handleRetry = async () => {
9
+ if (onRetry) {
10
+ setIsRetrying(true);
11
+ try {
12
+ onRetry();
13
+ }
14
+ finally {
15
+ setIsRetrying(false);
16
+ }
17
+ }
18
+ };
19
+ return (_jsxs(Box, { alignSelf: "stretch", p: 4, bg: "rgba(244, 63, 94, 0.05)", borderRadius: "lg", border: "1px solid", borderColor: "rgb(244, 63, 94)", display: "flex", alignItems: "flex-start", gap: 4, children: [_jsxs(HStack, { flex: 1, align: "flex-start", gap: 2, children: [_jsx(WarningMd, { color: "#F24" }), _jsxs(VStack, { flex: 1, align: "flex-start", gap: 1, children: [_jsx(Text, { w: "full", color: "white", fontSize: "sm", fontWeight: "bold", lineHeight: "tight", children: "Connection Lost" }), _jsx(Text, { w: "full", color: "white", fontSize: "sm", fontWeight: "normal", lineHeight: "tight", children: "Chatbot encountered connected issues." })] })] }), showRetry && onRetry && (_jsx(Button, { px: "14px", py: "10px", bg: "black", borderRadius: "lg", color: "white", fontSize: "sm", fontWeight: "medium", lineHeight: "tight", isLoading: isRetrying, onClick: handleRetry, _hover: {
20
+ bg: "gray.800",
21
+ }, children: _jsxs(HStack, { children: [_jsx(Refresh2Sm, {}), _jsx(Text, { children: "Retry" })] }) }))] }));
22
+ }
23
+ export default ErrorMessage;
24
+ //# sourceMappingURL=ErrorMessage.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ErrorMessage.js","sourceRoot":"","sources":["../../src/components/ErrorMessage.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAC;AACrE,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AACjC,OAAO,EAAC,UAAU,EAAC,MAAM,4CAA4C,CAAA;AACrE,OAAO,EAAE,SAAS,EAAC,MAAM,wCAAwC,CAAA;AAOjE,SAAS,YAAY,CAAC,EAClB,OAAO,EACP,SAAS,GAAG,IAAI,GACA;IAChB,MAAM,CAAC,UAAU,EAAE,aAAa,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IAEpD,MAAM,WAAW,GAAG,KAAK,IAAI,EAAE;QAC3B,IAAI,OAAO,EAAE,CAAC;YACV,aAAa,CAAC,IAAI,CAAC,CAAC;YACpB,IAAI,CAAC;gBACD,OAAO,EAAE,CAAC;YACd,CAAC;oBAAS,CAAC;gBACP,aAAa,CAAC,KAAK,CAAC,CAAC;YACzB,CAAC;QACL,CAAC;IACL,CAAC,CAAC;IAEF,OAAO,CACH,MAAC,GAAG,IACA,SAAS,EAAC,SAAS,EACnB,CAAC,EAAE,CAAC,EACJ,EAAE,EAAC,yBAAyB,EAC5B,YAAY,EAAC,IAAI,EACjB,MAAM,EAAC,WAAW,EAClB,WAAW,EAAC,kBAAkB,EAC9B,OAAO,EAAC,MAAM,EACd,UAAU,EAAC,YAAY,EACvB,GAAG,EAAE,CAAC,aAEN,MAAC,MAAM,IAAC,IAAI,EAAE,CAAC,EAAE,KAAK,EAAC,YAAY,EAAC,GAAG,EAAE,CAAC,aAEtC,KAAC,SAAS,IAAC,KAAK,EAAC,MAAM,GAAE,EAGzB,MAAC,MAAM,IAAC,IAAI,EAAE,CAAC,EAAE,KAAK,EAAC,YAAY,EAAC,GAAG,EAAE,CAAC,aACtC,KAAC,IAAI,IACD,CAAC,EAAC,MAAM,EACR,KAAK,EAAC,OAAO,EACb,QAAQ,EAAC,IAAI,EACb,UAAU,EAAC,MAAM,EAEjB,UAAU,EAAC,OAAO,gCAGf,EACP,KAAC,IAAI,IACD,CAAC,EAAC,MAAM,EACR,KAAK,EAAC,OAAO,EACb,QAAQ,EAAC,IAAI,EACb,UAAU,EAAC,QAAQ,EAEnB,UAAU,EAAC,OAAO,sDAGf,IACF,IACJ,EAGR,SAAS,IAAI,OAAO,IAAI,CACrB,KAAC,MAAM,IACH,EAAE,EAAC,MAAM,EACT,EAAE,EAAC,MAAM,EACT,EAAE,EAAC,OAAO,EACV,YAAY,EAAC,IAAI,EACjB,KAAK,EAAC,OAAO,EACb,QAAQ,EAAC,IAAI,EACb,UAAU,EAAC,QAAQ,EAEnB,UAAU,EAAC,OAAO,EAClB,SAAS,EAAE,UAAU,EACrB,OAAO,EAAE,WAAW,EACpB,MAAM,EAAE;oBACJ,EAAE,EAAE,UAAU;iBACjB,YAED,MAAC,MAAM,eACH,KAAC,UAAU,KAAE,EACb,KAAC,IAAI,wBAAa,IACb,GACJ,CACZ,IACC,CACT,CAAC;AACN,CAAC;AAED,eAAe,YAAY,CAAC"}
@@ -0,0 +1,6 @@
1
+ interface FloatingChatButtonProps {
2
+ onClick: () => void;
3
+ isVisible?: boolean;
4
+ }
5
+ declare function FloatingChatButton({ onClick, isVisible }: FloatingChatButtonProps): import("react/jsx-runtime").JSX.Element | null;
6
+ export default FloatingChatButton;
@@ -0,0 +1,17 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { Box, Flex, Text } from "@chakra-ui/react";
3
+ import { AIMd } from "../assets/icons/AI/AI/AIMd";
4
+ function FloatingChatButton({ onClick, isVisible = true }) {
5
+ if (!isVisible)
6
+ return null;
7
+ return (_jsxs(Box, { position: "fixed", bottom: 6, right: 6, zIndex: 1000, onClick: onClick, cursor: "pointer", css: {
8
+ "&:hover .animated-bg": {
9
+ transform: "scale(1)"
10
+ },
11
+ "&:hover .text-label": {
12
+ color: "black"
13
+ }
14
+ }, children: [_jsx(Box, { position: "absolute", inset: 0, borderRadius: "32px", bg: "rgba(43, 207, 161, 0.2)", border: "1px solid rgba(43, 207, 161, 0.10)", backdropFilter: "blur(24px)", transition: "all 0.2s" }), _jsx(Box, { className: "animated-bg", position: "absolute", inset: 0, borderRadius: "32px", bg: "#2BCFA1", transform: "scale(0)", transformOrigin: "20px center", transition: "transform 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94)" }), _jsxs(Flex, { display: "inline-flex", justifyContent: "flex-start", alignItems: "center", position: "relative", zIndex: 1, pl: 1, pr: 4, py: 1, gap: 2, children: [_jsx(Box, { position: "absolute", left: "4px", top: "4px", w: "32px", h: "32px", borderRadius: "24px", bg: "#2BCFA1" }), _jsx(Flex, { justifyContent: "center", alignItems: "center", position: "relative", zIndex: 1, w: "32px", h: "32px", p: 2, borderRadius: "24px", bg: "#2BCFA1", children: _jsx(AIMd, { color: "black" }) }), _jsx(Text, { className: "text-label", position: "relative", zIndex: 1, color: "white", fontSize: "sm", fontWeight: "medium", lineHeight: "tight", transition: "color 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94)", children: "AI Assistant" })] })] }));
15
+ }
16
+ export default FloatingChatButton;
17
+ //# sourceMappingURL=FloatingChatButton.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FloatingChatButton.js","sourceRoot":"","sources":["../../src/components/FloatingChatButton.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,kBAAkB,CAAA;AAClD,OAAO,EAAE,IAAI,EAAE,MAAM,4BAA4B,CAAA;AAOjD,SAAS,kBAAkB,CAAC,EAAE,OAAO,EAAE,SAAS,GAAG,IAAI,EAA2B;IAC9E,IAAI,CAAC,SAAS;QAAE,OAAO,IAAI,CAAA;IAE3B,OAAO,CACH,MAAC,GAAG,IACA,QAAQ,EAAC,OAAO,EAChB,MAAM,EAAE,CAAC,EACT,KAAK,EAAE,CAAC,EACR,MAAM,EAAE,IAAI,EACZ,OAAO,EAAE,OAAO,EAChB,MAAM,EAAC,SAAS,EAChB,GAAG,EAAE;YACD,sBAAsB,EAAE;gBACpB,SAAS,EAAE,UAAU;aACxB;YACD,qBAAqB,EAAE;gBACnB,KAAK,EAAE,OAAO;aACjB;SACJ,aAGD,KAAC,GAAG,IACA,QAAQ,EAAC,UAAU,EACnB,KAAK,EAAE,CAAC,EACR,YAAY,EAAC,MAAM,EACnB,EAAE,EAAC,yBAAyB,EAC5B,MAAM,EAAC,oCAAoC,EAC3C,cAAc,EAAC,YAAY,EAC3B,UAAU,EAAC,UAAU,GACvB,EAGF,KAAC,GAAG,IACA,SAAS,EAAC,aAAa,EACvB,QAAQ,EAAC,UAAU,EACnB,KAAK,EAAE,CAAC,EACR,YAAY,EAAC,MAAM,EACnB,EAAE,EAAC,SAAS,EACZ,SAAS,EAAC,UAAU,EACpB,eAAe,EAAC,aAAa,EAC7B,UAAU,EAAC,qDAAqD,GAClE,EAEF,MAAC,IAAI,IACD,OAAO,EAAC,aAAa,EACrB,cAAc,EAAC,YAAY,EAC3B,UAAU,EAAC,QAAQ,EACnB,QAAQ,EAAC,UAAU,EACnB,MAAM,EAAE,CAAC,EACT,EAAE,EAAE,CAAC,EACL,EAAE,EAAE,CAAC,EACL,EAAE,EAAE,CAAC,EACL,GAAG,EAAE,CAAC,aAGN,KAAC,GAAG,IACA,QAAQ,EAAC,UAAU,EACnB,IAAI,EAAC,KAAK,EACV,GAAG,EAAC,KAAK,EACT,CAAC,EAAC,MAAM,EACR,CAAC,EAAC,MAAM,EACR,YAAY,EAAC,MAAM,EACnB,EAAE,EAAC,SAAS,GACd,EAGF,KAAC,IAAI,IACD,cAAc,EAAC,QAAQ,EACvB,UAAU,EAAC,QAAQ,EACnB,QAAQ,EAAC,UAAU,EACnB,MAAM,EAAE,CAAC,EACT,CAAC,EAAC,MAAM,EACR,CAAC,EAAC,MAAM,EACR,CAAC,EAAE,CAAC,EACJ,YAAY,EAAC,MAAM,EACnB,EAAE,EAAC,SAAS,YAEZ,KAAC,IAAI,IAAC,KAAK,EAAC,OAAO,GAAG,GACnB,EAGP,KAAC,IAAI,IACD,SAAS,EAAC,YAAY,EACtB,QAAQ,EAAC,UAAU,EACnB,MAAM,EAAE,CAAC,EACT,KAAK,EAAC,OAAO,EACb,QAAQ,EAAC,IAAI,EACb,UAAU,EAAC,QAAQ,EACnB,UAAU,EAAC,OAAO,EAClB,UAAU,EAAC,iDAAiD,6BAGzD,IACJ,IACL,CAET,CAAA;AACL,CAAC;AAED,eAAe,kBAAkB,CAAA"}
@@ -0,0 +1,9 @@
1
+ interface GradualMessageDisplayProps {
2
+ message: string;
3
+ isBot: boolean;
4
+ onComplete?: () => void;
5
+ enableMarkdown?: boolean;
6
+ isHistoryMessage?: boolean;
7
+ }
8
+ declare function GradualMessageDisplay({ message, isBot, onComplete, isHistoryMessage, }: GradualMessageDisplayProps): import("react/jsx-runtime").JSX.Element;
9
+ export default GradualMessageDisplay;
@@ -0,0 +1,141 @@
1
+ import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { Box } from "@chakra-ui/react";
3
+ import { useEffect, useRef, useState } from "react";
4
+ import MarkdownRenderer from "./MarkdownRenderer";
5
+ import TypingIndicator from "./TypingIndicator";
6
+ function GradualMessageDisplay({ message, isBot, onComplete, isHistoryMessage = false, }) {
7
+ const [phase, setPhase] = useState("typing");
8
+ const [displayedLines, setDisplayedLines] = useState([]);
9
+ const [currentLineIndex, setCurrentLineIndex] = useState(0);
10
+ const [lineProgress, setLineProgress] = useState(0);
11
+ const intervalRef = useRef(null);
12
+ const onCompleteRef = useRef(onComplete);
13
+ const messageLines = useRef([]);
14
+ useEffect(() => {
15
+ onCompleteRef.current = onComplete;
16
+ }, [onComplete]);
17
+ useEffect(() => {
18
+ if (!isBot || isHistoryMessage) {
19
+ setDisplayedLines([message]);
20
+ setPhase("complete");
21
+ onCompleteRef.current?.();
22
+ return;
23
+ }
24
+ messageLines.current = message.split("\n");
25
+ setDisplayedLines([]);
26
+ setCurrentLineIndex(0);
27
+ setLineProgress(0);
28
+ setPhase("typing");
29
+ if (intervalRef.current) {
30
+ clearInterval(intervalRef.current);
31
+ intervalRef.current = null;
32
+ }
33
+ const typingTimer = setTimeout(() => {
34
+ setPhase("revealing");
35
+ let currentLine = 0;
36
+ const showNextLine = () => {
37
+ if (currentLine < messageLines.current.length) {
38
+ setDisplayedLines((prev) => {
39
+ const newLine = messageLines.current[currentLine];
40
+ if (newLine !== undefined) {
41
+ return [...prev, newLine];
42
+ }
43
+ return prev;
44
+ });
45
+ setCurrentLineIndex(currentLine);
46
+ setLineProgress(0);
47
+ let progress = 0;
48
+ const lineInterval = setInterval(() => {
49
+ progress += 4;
50
+ setLineProgress(progress);
51
+ if (progress >= 100) {
52
+ clearInterval(lineInterval);
53
+ currentLine++;
54
+ if (currentLine < messageLines.current.length) {
55
+ showNextLine();
56
+ }
57
+ else {
58
+ setPhase("complete");
59
+ onCompleteRef.current?.();
60
+ }
61
+ }
62
+ }, 15);
63
+ intervalRef.current = lineInterval;
64
+ }
65
+ };
66
+ showNextLine();
67
+ }, 1500);
68
+ return () => {
69
+ clearTimeout(typingTimer);
70
+ if (intervalRef.current) {
71
+ clearInterval(intervalRef.current);
72
+ intervalRef.current = null;
73
+ }
74
+ };
75
+ }, [message, isBot, isHistoryMessage]);
76
+ if (!isBot || isHistoryMessage) {
77
+ return (_jsx(Box, { alignSelf: "flex-start", mb: 4, children: _jsx(Box, { p: 4, borderRadius: "12px", borderBottomLeftRadius: "6px", children: _jsx(MarkdownRenderer, { content: message, fontSize: "sm", lineHeight: "1.4", color: "white" }) }) }));
78
+ }
79
+ return (_jsx(Box, { alignSelf: "flex-end", mb: 4, children: _jsxs(Box, { display: "flex", flexDirection: "column", gap: 2, children: [(phase === "typing" || phase === "revealing") && (_jsx(TypingIndicator, { isVisible: true, size: "normal", state: phase === "typing" ? "typing" : "completed" })), (phase === "revealing" || phase === "complete") && (_jsx(Box, { position: "relative", borderRadius: "12px", _before: {
80
+ content: '""',
81
+ position: 'absolute',
82
+ zIndex: -1,
83
+ width: 'calc(100% + 1px)',
84
+ height: 'calc(100% + 1px)',
85
+ top: 0,
86
+ left: 0,
87
+ borderRadius: '12px',
88
+ backgroundSize: '400% 400%',
89
+ opacity: phase === "revealing" ? 1 : 0,
90
+ transition: 'opacity 0.3s ease',
91
+ }, _after: {
92
+ content: '""',
93
+ position: 'absolute',
94
+ zIndex: -1,
95
+ width: 'calc(100% + 1px)',
96
+ height: 'calc(100% + 1px)',
97
+ top: 0,
98
+ left: 0,
99
+ borderRadius: '12px',
100
+ backgroundSize: '400% 400%',
101
+ opacity: phase === "revealing" ? 1 : 0,
102
+ transition: 'opacity 0.3s ease',
103
+ filter: 'blur(100px)',
104
+ }, children: _jsx(Box, { borderRadius: "11px", p: "12px 16px", position: "relative", zIndex: 1, children: displayedLines.map((line, lineIndex) => {
105
+ const isCurrentLine = lineIndex === currentLineIndex &&
106
+ phase === "revealing";
107
+ return (_jsxs(Box, { position: "relative", css: isCurrentLine
108
+ ? {
109
+ maskImage: `linear-gradient(to right,
110
+ black 0%,
111
+ black ${Math.max(0, lineProgress - 10)}%,
112
+ transparent ${lineProgress}%,
113
+ transparent 100%)`,
114
+ WebkitMaskImage: `linear-gradient(to right,
115
+ black 0%,
116
+ black ${Math.max(0, lineProgress - 10)}%,
117
+ transparent ${lineProgress}%,
118
+ transparent 100%)`,
119
+ }
120
+ : {}, children: [isCurrentLine && (_jsxs(_Fragment, { children: [_jsx(Box, { position: "absolute", top: 0, left: 0, right: 0, css: {
121
+ filter: "blur(800px)",
122
+ opacity: 0,
123
+ transform: "scale(500)",
124
+ }, children: _jsx(MarkdownRenderer, { content: line || " ", fontSize: "sm", lineHeight: "1.4", color: "white" }) }), _jsx(Box, { position: "absolute", top: 0, left: 0, right: 0, css: {
125
+ filter: "blur(8px)",
126
+ opacity: 0.7,
127
+ }, children: _jsx(MarkdownRenderer, { content: line || " ", fontSize: "sm", lineHeight: "1.4", color: "white" }) })] })), _jsx(Box, { position: "relative", css: {
128
+ filter: isCurrentLine
129
+ ? `blur(${Math.max(0, 6 -
130
+ (lineProgress /
131
+ 100) *
132
+ 6)}px)`
133
+ : "blur(0px)",
134
+ opacity: isCurrentLine
135
+ ? Math.min(1, lineProgress / 70)
136
+ : 1,
137
+ }, children: _jsx(MarkdownRenderer, { content: line || " ", fontSize: "sm", lineHeight: "1.4", color: "white" }) })] }, lineIndex));
138
+ }) }) }))] }) }));
139
+ }
140
+ export default GradualMessageDisplay;
141
+ //# sourceMappingURL=GradualMessageDisplay.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"GradualMessageDisplay.js","sourceRoot":"","sources":["../../src/components/GradualMessageDisplay.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,9 @@
1
+ import { ReactNode } from 'react';
2
+ interface HeaderIconButtonProps {
3
+ onClick?: () => void;
4
+ borderColor?: string;
5
+ children: ReactNode;
6
+ cursor?: string;
7
+ }
8
+ export default function HeaderIconButton({ onClick, borderColor, children, cursor }: HeaderIconButtonProps): import("react/jsx-runtime").JSX.Element;
9
+ export {};
@@ -0,0 +1,6 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { Center, Box } from '@chakra-ui/react';
3
+ export default function HeaderIconButton({ onClick, borderColor = '#2BCFA11A', children, cursor = 'pointer' }) {
4
+ return (_jsx(Center, { onClick: onClick, w: 10, h: 10, borderRadius: "lg", border: "1px solid", borderColor: borderColor, cursor: cursor, children: _jsx(Box, { w: 5, h: 5, position: "relative", overflow: "hidden", children: children }) }));
5
+ }
6
+ //# sourceMappingURL=HeaderIconButton.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"HeaderIconButton.js","sourceRoot":"","sources":["../../src/components/HeaderIconButton.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,kBAAkB,CAAA;AAU9C,MAAM,CAAC,OAAO,UAAU,gBAAgB,CAAC,EAAE,OAAO,EAAE,WAAW,GAAG,WAAW,EAAE,QAAQ,EAAE,MAAM,GAAG,SAAS,EAAyB;IAClI,OAAO,CACL,KAAC,MAAM,IAEL,OAAO,EAAE,OAAO,EAEhB,CAAC,EAAE,EAAE,EACL,CAAC,EAAE,EAAE,EACL,YAAY,EAAC,IAAI,EACjB,MAAM,EAAC,WAAW,EAClB,WAAW,EAAE,WAAW,EAExB,MAAM,EAAE,MAAM,YAEd,KAAC,GAAG,IAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,QAAQ,EAAC,UAAU,EAAC,QAAQ,EAAC,QAAQ,YACnD,QAAQ,GACL,GACC,CACV,CAAA;AACH,CAAC"}
@@ -0,0 +1,10 @@
1
+ import { NavigationLink } from "../types";
2
+ interface HelloPageProps {
3
+ userName?: string;
4
+ onStartChat: () => void;
5
+ isStartingChat?: boolean;
6
+ navigationLinks?: NavigationLink[];
7
+ externalLinks?: NavigationLink[];
8
+ }
9
+ declare function HelloPage({ userName, onStartChat, isStartingChat, }: HelloPageProps): import("react/jsx-runtime").JSX.Element;
10
+ export default HelloPage;
@@ -0,0 +1,8 @@
1
+ interface MarkdownRendererProps {
2
+ content: string;
3
+ fontSize?: string;
4
+ lineHeight?: string | number;
5
+ color?: string;
6
+ }
7
+ declare function MarkdownRenderer({ content, fontSize, lineHeight, color }: MarkdownRendererProps): import("react/jsx-runtime").JSX.Element;
8
+ export default MarkdownRenderer;
@@ -0,0 +1,40 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { Box, Link, Text } from '@chakra-ui/react';
3
+ import ReactMarkdown from 'react-markdown';
4
+ import rehypeRaw from 'rehype-raw';
5
+ import remarkGfm from 'remark-gfm';
6
+ function MarkdownRenderer({ content, fontSize = "14", lineHeight = "20px", color = "white" }) {
7
+ return (_jsx(Box, { css: {
8
+ '& > *:first-of-type': {
9
+ marginTop: 0,
10
+ },
11
+ '& > *:last-child': {
12
+ marginBottom: 0,
13
+ },
14
+ }, children: _jsx(ReactMarkdown, { remarkPlugins: [remarkGfm], rehypePlugins: [rehypeRaw], components: {
15
+ p: ({ children }) => (_jsx(Text, { fontSize: fontSize, lineHeight: lineHeight, color: color, mb: 2, children: children })),
16
+ a: ({ href, children }) => (_jsx(Link, { href: href, color: "#179EF8", textDecoration: "underline", textUnderlineOffset: "2px", _hover: {
17
+ transform: "translateY(-1px)",
18
+ transition: "all 0.2s ease"
19
+ }, target: href?.startsWith('http') ? '_blank' : undefined, rel: href?.startsWith('http') ? 'noopener noreferrer' : undefined, fontSize: fontSize, fontWeight: "medium", cursor: "pointer", transition: "all 0.2s ease", children: children })),
20
+ ul: ({ children }) => (_jsx(Box, { as: "ul", pl: 4, mb: 2, color: color, fontSize: fontSize, lineHeight: lineHeight, css: {
21
+ listStyleType: 'disc',
22
+ listStylePosition: 'outside'
23
+ }, children: children })),
24
+ ol: ({ children }) => (_jsx(Box, { as: "ol", pl: 4, mb: 2, color: color, fontSize: fontSize, lineHeight: lineHeight, css: {
25
+ listStyleType: 'decimal',
26
+ listStylePosition: 'outside'
27
+ }, children: children })),
28
+ li: ({ children }) => (_jsx(Box, { as: "li", mb: 1, color: color, fontSize: fontSize, lineHeight: lineHeight, css: {
29
+ display: 'list-item'
30
+ }, children: children })),
31
+ strong: ({ children }) => (_jsx(Text, { as: "strong", fontWeight: "bold", color: color, fontSize: fontSize, children: children })),
32
+ em: ({ children }) => (_jsx(Text, { as: "em", fontStyle: "italic", color: color, fontSize: fontSize, children: children })),
33
+ h1: ({ children }) => (_jsx(Text, { fontSize: "lg", fontWeight: "bold", color: color, mb: 2, lineHeight: lineHeight, children: children })),
34
+ h2: ({ children }) => (_jsx(Text, { fontSize: "md", fontWeight: "bold", color: color, mb: 2, lineHeight: lineHeight, children: children })),
35
+ h3: ({ children }) => (_jsx(Text, { fontSize: fontSize, fontWeight: "bold", color: color, mb: 2, lineHeight: lineHeight, children: children })),
36
+ br: () => _jsx("br", {}),
37
+ }, children: content }) }));
38
+ }
39
+ export default MarkdownRenderer;
40
+ //# sourceMappingURL=MarkdownRenderer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MarkdownRenderer.js","sourceRoot":"","sources":["../../src/components/MarkdownRenderer.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,11 @@
1
+ import { ChatbotUser, Message } from "../types";
2
+ interface MessageInputProps {
3
+ onSend: (text: string) => void;
4
+ user: ChatbotUser;
5
+ onEmailSubmit: (email: string) => void;
6
+ isLoading?: boolean;
7
+ isEmailSubmitting?: boolean;
8
+ messages?: Message[];
9
+ }
10
+ declare function MessageInput({ onSend, user, onEmailSubmit, isLoading, isEmailSubmitting, messages, }: MessageInputProps): import("react/jsx-runtime").JSX.Element;
11
+ export default MessageInput;
@@ -0,0 +1,52 @@
1
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
+ import { Box, HStack, IconButton, Image, Input, VStack, Spacer } from "@chakra-ui/react";
3
+ import { useState } from "react";
4
+ import { SendSm } from "../assets/icons/Action/Send/SendSm";
5
+ import EmailCapture from "./input/EmailCapture";
6
+ import SuggestionChips from "./input/SuggestionChips";
7
+ const messageSuggestions = [
8
+ { id: "1", text: "How do I get started?" },
9
+ { id: "2", text: "What services do you offer?" },
10
+ { id: "3", text: "I need help with my account" },
11
+ { id: "4", text: "Billing questions" },
12
+ ];
13
+ function MessageInput({ onSend, user, onEmailSubmit, isLoading = false, isEmailSubmitting = false, messages = [], }) {
14
+ const [input, setInput] = useState("");
15
+ const handleSend = () => {
16
+ if (!input.trim())
17
+ return;
18
+ onSend(input);
19
+ setInput("");
20
+ };
21
+ const handleEmailSubmit = (email) => {
22
+ onEmailSubmit(email);
23
+ };
24
+ const handleSuggestionClick = (suggestion) => {
25
+ setInput(suggestion.text);
26
+ };
27
+ if (!user.isLoggedIn) {
28
+ return _jsx(EmailCapture, { onSubmit: handleEmailSubmit, isSubmitting: isEmailSubmitting });
29
+ }
30
+ return (_jsxs(_Fragment, { children: [messages.length === 0 && (_jsx(SuggestionChips, { suggestions: messageSuggestions, onPick: (text) => setInput(text) })), _jsx(Box, { w: "full", p: 4, borderTop: "1px solid", borderColor: "#27272A", borderBottomRadius: 16, children: _jsx(VStack, { gap: 6, w: "full", align: "stretch", children: _jsxs(VStack, { gap: 4, w: "full", children: [_jsx(Box, { w: "full", position: "relative", children: _jsx(Input, { value: input, onChange: (e) => setInput(e.target.value), onKeyDown: (e) => e.key === "Enter" && handleSend(), placeholder: " Send a message", bg: "transparent", color: "white", border: "none", outline: "none", _placeholder: { color: "#737373" }, _focus: {
31
+ border: "none",
32
+ outline: "none",
33
+ boxShadow: "none",
34
+ }, _active: {
35
+ border: "none",
36
+ outline: "none",
37
+ boxShadow: "none",
38
+ }, p: 3, fontSize: "sm" }) }), _jsxs(HStack, { p: 2, align: "center", w: "full", children: [user.logoUrl && (_jsx(HStack, { gap: 3, children: _jsx(Image, { boxSize: "40px", src: user.logoUrl, alt: "User avatar", border: "1px solid", borderColor: "#27272A", borderRadius: "24px" }) })), _jsx(Spacer, {}), _jsx(IconButton, { "aria-label": "Send message", onClick: handleSend, isDisabled: !input.trim() || isLoading, isLoading: isLoading, size: "sm", bg: !input.trim() || isLoading
39
+ ? "#262626"
40
+ : "#2BCFA1", _hover: {
41
+ bg: !input.trim() || isLoading
42
+ ? "#262626"
43
+ : "#22B890",
44
+ }, _disabled: {
45
+ bg: "#262626",
46
+ cursor: "not-allowed",
47
+ }, borderRadius: "lg", border: "none", children: _jsx(SendSm, { color: !input.trim() || isLoading
48
+ ? "#525252"
49
+ : "white" }) })] })] }) }) })] }));
50
+ }
51
+ export default MessageInput;
52
+ //# sourceMappingURL=MessageInput.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MessageInput.js","sourceRoot":"","sources":["../../src/components/MessageInput.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,12 @@
1
+ import { Message, ChatbotUser } from "../types";
2
+ interface MessageListProps {
3
+ messages: Message[];
4
+ user: ChatbotUser;
5
+ isTyping?: boolean;
6
+ historyMessageIds?: Set<string>;
7
+ currentlyProcessingMessageId?: string | null;
8
+ clearProcessingMessageId?: () => void;
9
+ onRetryMessage?: () => void;
10
+ }
11
+ declare function MessageList({ messages, user, isTyping, historyMessageIds, currentlyProcessingMessageId, clearProcessingMessageId, onRetryMessage, }: MessageListProps): import("react/jsx-runtime").JSX.Element;
12
+ export default MessageList;
@@ -0,0 +1,64 @@
1
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
+ import { Box, Text, VStack } from "@chakra-ui/react";
3
+ import { useEffect, useRef, useState } from "react";
4
+ import TypingIndicator from "./TypingIndicator";
5
+ import MessageItem from "./messages/MessageItem";
6
+ import { AIMd } from "../assets/icons/AI/AI/AIMd";
7
+ import Lottie from "lottie-react";
8
+ import animationData from "../assets/animations/chat-greeting.json";
9
+ function MessageList({ messages, user, isTyping = false, historyMessageIds, currentlyProcessingMessageId, clearProcessingMessageId, onRetryMessage, }) {
10
+ const scrollContainerRef = useRef(null);
11
+ const [completedMessages, setCompletedMessages] = useState(new Set());
12
+ const [currentlyDisplayingMessage, setCurrentlyDisplayingMessage] = useState(null);
13
+ const handleMessageComplete = (messageId) => {
14
+ setCompletedMessages((prev) => {
15
+ const newSet = new Set(Array.from(prev));
16
+ newSet.add(messageId);
17
+ return newSet;
18
+ });
19
+ setCurrentlyDisplayingMessage(null);
20
+ };
21
+ useEffect(() => {
22
+ const latestBotMessage = messages
23
+ .filter((msg) => msg.sender === "bot")
24
+ .slice(-1)[0];
25
+ if (latestBotMessage && !completedMessages.has(latestBotMessage.id)) {
26
+ setCurrentlyDisplayingMessage(latestBotMessage.id);
27
+ }
28
+ }, [messages, completedMessages]);
29
+ useEffect(() => {
30
+ if (scrollContainerRef.current) {
31
+ scrollContainerRef.current.scrollTo({
32
+ top: scrollContainerRef.current.scrollHeight,
33
+ behavior: "smooth",
34
+ });
35
+ }
36
+ }, [messages, isTyping]);
37
+ return (_jsx(Box, { ref: scrollContainerRef, h: "full", w: "full", overflowY: "auto", overflowX: "hidden", p: 4, css: {
38
+ "&::-webkit-scrollbar": {
39
+ width: "6px",
40
+ },
41
+ "&::-webkit-scrollbar-track": {
42
+ background: "rgba(255, 255, 255, 0.1)",
43
+ borderRadius: "3px",
44
+ },
45
+ "&::-webkit-scrollbar-thumb": {
46
+ background: "rgba(255, 255, 255, 0.3)",
47
+ borderRadius: "3px",
48
+ },
49
+ "&::-webkit-scrollbar-thumb:hover": {
50
+ background: "rgba(255, 255, 255, 0.5)",
51
+ },
52
+ scrollBehavior: "smooth",
53
+ }, children: _jsx(VStack, { align: "stretch", gap: 4, minH: "full", children: messages.length === 0 ? (_jsx(VStack, { w: "full", pt: 12, gap: 6, align: "center", justify: "center", children: _jsxs(VStack, { w: "full", gap: 2, align: "center", children: [_jsx(Box, { p: "10px", bg: "rgba(43, 207, 161, 0.1)", borderRadius: "lg", border: "1px solid", borderColor: "rgba(43, 207, 161, 0.1)", display: "flex", alignItems: "center", justifyContent: "center", overflow: "hidden", children: _jsx(AIMd, { color: "#2BCFA1" }) }), _jsxs(VStack, { w: "full", align: "stretch", children: [_jsxs(Text, { textAlign: "center", color: "#2BCFA1", fontSize: "2xl", fontWeight: "bold", children: ["Hi ", user.name, " \uD83D\uDC4B\uD83C\uDFFB"] }), _jsx(Text, { textAlign: "center", color: "white", fontSize: "2xl", fontWeight: "bold", children: "How can I help today?" }), !user.isLoggedIn && (_jsx(Box, { w: 64, h: 64, alignSelf: "center", children: _jsx(Lottie, { animationData: animationData, loop: true, autoplay: true, style: {
54
+ width: "100%",
55
+ height: "100%",
56
+ } }) }))] })] }) })) : (_jsxs(_Fragment, { children: [messages.map((message) => {
57
+ const isCurrentlyDisplaying = currentlyDisplayingMessage === message.id;
58
+ const isHistoryMessage = historyMessageIds?.has(message.id) || false;
59
+ const shouldAnimate = currentlyProcessingMessageId === message.id;
60
+ return (_jsx(MessageItem, { message: message, isHistoryMessage: isHistoryMessage, shouldAnimate: !!shouldAnimate, onComplete: handleMessageComplete, onRetry: onRetryMessage, clearProcessingMessageId: clearProcessingMessageId }, message.id));
61
+ }), isTyping && !currentlyDisplayingMessage && (_jsx(TypingIndicator, { isVisible: true, size: "normal" }))] })) }) }));
62
+ }
63
+ export default MessageList;
64
+ //# sourceMappingURL=MessageList.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MessageList.js","sourceRoot":"","sources":["../../src/components/MessageList.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,6 @@
1
+ import { GridProps } from "@chakra-ui/react";
2
+ export interface RuledGridProps extends GridProps {
3
+ columns: number;
4
+ }
5
+ declare function RuledGrid({ columns, children, ...rest }: RuledGridProps): import("react/jsx-runtime").JSX.Element;
6
+ export default RuledGrid;
@@ -0,0 +1,9 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { Box, Grid } from "@chakra-ui/react";
3
+ import React from "react";
4
+ function RuledGrid({ columns, children, ...rest }) {
5
+ const childrenArray = React.Children.toArray(children);
6
+ return (_jsx(Grid, { templateColumns: `repeat(${columns}, 1fr)`, border: "1px solid", borderColor: "#292929", overflow: "hidden", ...rest, children: childrenArray.map((child, index) => (_jsx(Box, { borderRight: (index % columns !== columns - 1) || (index % columns !== 0) ? "1px solid" : "none", borderBottom: index < childrenArray.length - columns ? "1px solid" : "none", borderColor: rest.borderColor ?? "#292929", children: child }, index))) }));
7
+ }
8
+ export default RuledGrid;
9
+ //# sourceMappingURL=RuledGrid.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RuledGrid.js","sourceRoot":"","sources":["../../src/components/RuledGrid.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,GAAG,EAAE,IAAI,EAAa,MAAM,kBAAkB,CAAA;AACvD,OAAO,KAAK,MAAM,OAAO,CAAA;AAMzB,SAAS,SAAS,CAAC,EAAE,OAAO,EAAE,QAAQ,EAAE,GAAG,IAAI,EAAkB;IAG7D,MAAM,aAAa,GAAG,KAAK,CAAC,QAAQ,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAA;IAEtD,OAAO,CACH,KAAC,IAAI,IACD,eAAe,EAAE,UAAU,OAAO,QAAQ,EAC1C,MAAM,EAAC,WAAW,EAClB,WAAW,EAAC,SAAS,EACrB,QAAQ,EAAC,QAAQ,KACb,IAAI,YAEP,aAAa,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,KAAK,EAAE,EAAE,CAAC,CACjC,KAAC,GAAG,IAGA,WAAW,EAAE,CAAC,KAAK,GAAG,OAAO,KAAK,OAAO,GAAG,CAAC,CAAC,IAAI,CAAC,KAAK,GAAG,OAAO,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,MAAM,EAChG,YAAY,EAAE,KAAK,GAAG,aAAa,CAAC,MAAM,GAAG,OAAO,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,MAAM,EAC3E,WAAW,EAAE,IAAI,CAAC,WAAW,IAAI,SAAS,YAEzC,KAAK,IAND,KAAK,CAOR,CACT,CAAC,GACC,CACV,CAAA;AACL,CAAC;AAED,eAAe,SAAS,CAAA"}
@@ -0,0 +1,8 @@
1
+ import React from "react";
2
+ interface TypingIndicatorProps {
3
+ isVisible: boolean;
4
+ size?: "normal" | "small";
5
+ state?: "typing" | "completed";
6
+ }
7
+ declare const TypingIndicator: React.NamedExoticComponent<TypingIndicatorProps>;
8
+ export default TypingIndicator;
@@ -0,0 +1,92 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { Box, HStack } from "@chakra-ui/react";
3
+ import React from "react";
4
+ const typingIndicatorStyles = `
5
+ @keyframes typingDotBounce {
6
+ 0%, 60%, 100% {
7
+ transform: translateY(0);
8
+ opacity: 0.6;
9
+ }
10
+ 10%, 30% {
11
+ transform: translateY(-6px);
12
+ opacity: 1;
13
+ }
14
+ 50%, 70% {
15
+ transform: translateY(6px);
16
+ opacity: 1;
17
+ }
18
+ }
19
+
20
+ @keyframes scaleIn {
21
+ 0% {
22
+ transform: scale(0);
23
+ opacity: 0;
24
+ }
25
+ 100% {
26
+ transform: scale(1);
27
+ opacity: 1;
28
+ }
29
+ }
30
+
31
+ @keyframes scaleOut {
32
+ 0% {
33
+ transform: scale(1);
34
+ opacity: 1;
35
+ }
36
+ 100% {
37
+ transform: scale(0);
38
+ opacity: 0;
39
+ }
40
+ }
41
+ `;
42
+ if (typeof document !== "undefined" &&
43
+ !document.getElementById("typing-indicator-styles")) {
44
+ const styleElement = document.createElement("style");
45
+ styleElement.id = "typing-indicator-styles";
46
+ styleElement.textContent = typingIndicatorStyles;
47
+ document.head.appendChild(styleElement);
48
+ }
49
+ const TypingIndicator = React.memo(function TypingIndicator({ isVisible, size = "normal", state = "typing", }) {
50
+ const getDotStyle = React.useMemo(() => (index, delay, small) => {
51
+ const animationDelay = `${index * 0.2 + delay * 0.5}s`;
52
+ return {
53
+ animation: `typingDotBounce 1.6s ease-in-out infinite`,
54
+ animationDelay,
55
+ transformOrigin: "center",
56
+ };
57
+ }, []);
58
+ const containerAnimationStyle = {
59
+ animation: isVisible ? 'scaleIn 0.5s ease-out forwards' : 'scaleOut 0.5s ease-in forwards',
60
+ transformOrigin: 'bottom left',
61
+ };
62
+ const [shouldRender, setShouldRender] = React.useState(isVisible);
63
+ React.useEffect(() => {
64
+ let timer = null;
65
+ if (isVisible) {
66
+ setShouldRender(true);
67
+ }
68
+ else {
69
+ timer = setTimeout(() => setShouldRender(false), 300);
70
+ }
71
+ return () => {
72
+ if (timer) {
73
+ clearTimeout(timer);
74
+ }
75
+ };
76
+ }, [isVisible]);
77
+ if (!shouldRender)
78
+ return null;
79
+ const isSmall = size === "small";
80
+ const dotSize = isSmall ? "6px" : "8px";
81
+ const smallDotSize = isSmall ? "5px" : "6px";
82
+ const containerPadding = isSmall ? "8px 12px" : "12px 16px";
83
+ const smallContainerPadding = isSmall ? "6px 10px" : "8px 12px";
84
+ const isCompleted = state === "completed";
85
+ const TypingDots = React.useMemo(() => React.memo(({ delay = 0, small = false, }) => (_jsx(HStack, { gap: small ? "4px" : "6px", justify: "center", children: [0, 1, 2].map((index) => (_jsx(Box, { w: small ? smallDotSize : dotSize, h: small ? smallDotSize : dotSize, bg: "#2BCFA1", borderRadius: "full", style: getDotStyle(index, delay, small) }, index))) }))), [getDotStyle, dotSize, smallDotSize]);
86
+ if (isCompleted) {
87
+ return (_jsx(Box, { alignSelf: "flex-start", maxW: "80%", mb: isSmall ? 2 : 4, style: containerAnimationStyle, children: _jsx(Box, { bg: "rgba(43, 207, 161, 0.15)", p: smallContainerPadding, borderRadius: "16px", w: "fit-content", border: "1px solid rgba(43, 207, 161, 0.2)", backdropFilter: "blur(10px)", boxShadow: "0 4px 12px rgba(0, 0, 0, 0.1)", children: _jsx(TypingDots, { delay: 0.1, small: true }) }) }));
88
+ }
89
+ return (_jsx(Box, { alignSelf: "flex-start", maxW: "80%", mb: isSmall ? 2 : 4, style: containerAnimationStyle, children: _jsxs(Box, { display: "flex", flexDirection: "column", gap: 2, children: [_jsx(Box, { bg: "rgba(34, 197, 94, 0.2)", p: containerPadding, borderRadius: "20px", w: "fit-content", border: "1px solid rgba(34, 197, 94, 0.3)", backdropFilter: "blur(10px)", boxShadow: "0 4px 12px rgba(0, 0, 0, 0.1)", children: _jsx(TypingDots, {}) }), _jsx(Box, { bg: "rgba(34, 197, 94, 0.2)", p: smallContainerPadding, borderRadius: "16px", w: "fit-content", border: "1px solid rgba(34, 197, 94, 0.3)", backdropFilter: "blur(10px)", boxShadow: "0 4px 12px rgba(0, 0, 0, 0.1)", children: _jsx(TypingDots, { delay: 0.1, small: true }) })] }) }));
90
+ });
91
+ export default TypingIndicator;
92
+ //# sourceMappingURL=TypingIndicator.js.map