@townco/ui 0.1.3 → 0.1.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 (250) hide show
  1. package/README.md +11 -11
  2. package/dist/core/hooks/use-chat-input.d.ts +17 -17
  3. package/dist/core/hooks/use-chat-input.js +55 -64
  4. package/dist/core/hooks/use-chat-messages.d.ts +11 -11
  5. package/dist/core/hooks/use-chat-messages.js +114 -121
  6. package/dist/core/hooks/use-chat-session.d.ts +5 -5
  7. package/dist/core/hooks/use-chat-session.js +80 -78
  8. package/dist/core/index.d.ts +1 -1
  9. package/dist/core/index.js +1 -1
  10. package/dist/core/schemas/chat.d.ts +56 -83
  11. package/dist/core/schemas/chat.js +25 -27
  12. package/dist/core/store/chat-store.d.ts +22 -28
  13. package/dist/core/store/chat-store.js +50 -59
  14. package/dist/gui/components/Button.d.ts +7 -23
  15. package/dist/gui/components/Button.js +27 -40
  16. package/dist/gui/components/Card.d.ts +7 -26
  17. package/dist/gui/components/Card.js +8 -54
  18. package/dist/gui/components/ChatInput.d.ts +36 -58
  19. package/dist/gui/components/ChatInput.js +121 -191
  20. package/dist/gui/components/ChatSecondaryPanel.d.ts +11 -14
  21. package/dist/gui/components/ChatSecondaryPanel.js +38 -115
  22. package/dist/gui/components/ChatStatus.d.ts +2 -4
  23. package/dist/gui/components/ChatStatus.js +34 -45
  24. package/dist/gui/components/Conversation.d.ts +14 -17
  25. package/dist/gui/components/Conversation.js +83 -143
  26. package/dist/gui/components/Dialog.d.ts +11 -57
  27. package/dist/gui/components/Dialog.js +8 -84
  28. package/dist/gui/components/HeightTransition.d.ts +7 -12
  29. package/dist/gui/components/HeightTransition.js +77 -88
  30. package/dist/gui/components/Input.d.ts +6 -13
  31. package/dist/gui/components/Input.js +16 -27
  32. package/dist/gui/components/Label.d.ts +1 -7
  33. package/dist/gui/components/Label.js +2 -12
  34. package/dist/gui/components/MarkdownRenderer.d.ts +4 -6
  35. package/dist/gui/components/MarkdownRenderer.js +81 -178
  36. package/dist/gui/components/Message.d.ts +18 -25
  37. package/dist/gui/components/Message.js +23 -44
  38. package/dist/gui/components/MessageContent.d.ts +22 -29
  39. package/dist/gui/components/MessageContent.js +85 -157
  40. package/dist/gui/components/Reasoning.d.ts +24 -30
  41. package/dist/gui/components/Reasoning.js +60 -187
  42. package/dist/gui/components/Response.d.ts +9 -11
  43. package/dist/gui/components/Response.js +90 -229
  44. package/dist/gui/components/Select.d.ts +10 -69
  45. package/dist/gui/components/Select.js +12 -118
  46. package/dist/gui/components/Tabs.d.ts +4 -24
  47. package/dist/gui/components/Tabs.js +4 -32
  48. package/dist/gui/components/Task.d.ts +24 -28
  49. package/dist/gui/components/Task.js +31 -164
  50. package/dist/gui/components/Textarea.d.ts +7 -15
  51. package/dist/gui/components/Textarea.js +46 -63
  52. package/dist/gui/components/ThinkingBlock.d.ts +10 -20
  53. package/dist/gui/components/ThinkingBlock.js +35 -134
  54. package/dist/gui/components/TodoList.d.ts +10 -12
  55. package/dist/gui/components/TodoList.js +7 -22
  56. package/dist/gui/components/TodoListItem.d.ts +6 -9
  57. package/dist/gui/components/TodoListItem.js +4 -18
  58. package/dist/gui/components/index.d.ts +8 -59
  59. package/dist/gui/components/index.js +8 -42
  60. package/dist/gui/lib/utils.js +1 -1
  61. package/dist/index.d.ts +1 -1
  62. package/dist/index.js +1 -1
  63. package/dist/index.test.js +1 -0
  64. package/dist/sdk/client/acp-client.d.ts +76 -88
  65. package/dist/sdk/client/acp-client.js +217 -215
  66. package/dist/sdk/index.d.ts +1 -1
  67. package/dist/sdk/index.js +1 -1
  68. package/dist/sdk/schemas/agent.d.ts +64 -111
  69. package/dist/sdk/schemas/agent.js +24 -24
  70. package/dist/sdk/schemas/message.d.ts +147 -245
  71. package/dist/sdk/schemas/message.js +40 -40
  72. package/dist/sdk/schemas/session.d.ts +135 -219
  73. package/dist/sdk/schemas/session.js +27 -27
  74. package/dist/sdk/transports/http.d.ts +55 -55
  75. package/dist/sdk/transports/http.js +469 -472
  76. package/dist/sdk/transports/stdio.d.ts +20 -20
  77. package/dist/sdk/transports/stdio.js +286 -289
  78. package/dist/sdk/transports/types.d.ts +42 -42
  79. package/dist/sdk/transports/websocket.d.ts +12 -12
  80. package/dist/sdk/transports/websocket.js +46 -52
  81. package/dist/tui/components/ChatView.d.ts +2 -4
  82. package/dist/tui/components/ChatView.js +18 -51
  83. package/dist/tui/components/GameOfLife.js +35 -64
  84. package/dist/tui/components/InputBox.d.ts +11 -18
  85. package/dist/tui/components/InputBox.js +10 -70
  86. package/dist/tui/components/MessageList.d.ts +2 -4
  87. package/dist/tui/components/MessageList.js +10 -37
  88. package/dist/tui/components/MultiSelect.d.ts +10 -15
  89. package/dist/tui/components/MultiSelect.js +73 -116
  90. package/dist/tui/components/ReadlineInput.d.ts +6 -12
  91. package/dist/tui/components/ReadlineInput.js +237 -252
  92. package/dist/tui/components/SingleSelect.d.ts +9 -15
  93. package/dist/tui/components/SingleSelect.js +43 -84
  94. package/dist/tui/components/StatusBar.d.ts +6 -11
  95. package/dist/tui/components/StatusBar.js +67 -102
  96. package/dist/tui/index.d.ts +1 -1
  97. package/dist/tui/index.js +1 -1
  98. package/package.json +2 -2
  99. package/dist/core/hooks/index.d.ts.map +0 -1
  100. package/dist/core/hooks/index.js.map +0 -1
  101. package/dist/core/hooks/use-chat-input.d.ts.map +0 -1
  102. package/dist/core/hooks/use-chat-input.js.map +0 -1
  103. package/dist/core/hooks/use-chat-messages.d.ts.map +0 -1
  104. package/dist/core/hooks/use-chat-messages.js.map +0 -1
  105. package/dist/core/hooks/use-chat-session.d.ts.map +0 -1
  106. package/dist/core/hooks/use-chat-session.js.map +0 -1
  107. package/dist/core/hooks/use-media-query.d.ts +0 -39
  108. package/dist/core/hooks/use-media-query.js +0 -80
  109. package/dist/core/index.d.ts.map +0 -1
  110. package/dist/core/index.js.map +0 -1
  111. package/dist/core/schemas/chat.d.ts.map +0 -1
  112. package/dist/core/schemas/chat.js.map +0 -1
  113. package/dist/core/schemas/index.d.ts.map +0 -1
  114. package/dist/core/schemas/index.js.map +0 -1
  115. package/dist/core/store/chat-store.d.ts.map +0 -1
  116. package/dist/core/store/chat-store.js.map +0 -1
  117. package/dist/gui/components/Button.d.ts.map +0 -1
  118. package/dist/gui/components/Button.js.map +0 -1
  119. package/dist/gui/components/Card.d.ts.map +0 -1
  120. package/dist/gui/components/Card.js.map +0 -1
  121. package/dist/gui/components/ChatHeader.d.ts +0 -65
  122. package/dist/gui/components/ChatHeader.js +0 -189
  123. package/dist/gui/components/ChatInput.d.ts.map +0 -1
  124. package/dist/gui/components/ChatInput.js.map +0 -1
  125. package/dist/gui/components/ChatInterface.d.ts +0 -12
  126. package/dist/gui/components/ChatInterface.d.ts.map +0 -1
  127. package/dist/gui/components/ChatInterface.js +0 -204
  128. package/dist/gui/components/ChatInterface.js.map +0 -1
  129. package/dist/gui/components/ChatLayout.d.ts +0 -82
  130. package/dist/gui/components/ChatLayout.js +0 -232
  131. package/dist/gui/components/ChatPanelTabContent.d.ts +0 -27
  132. package/dist/gui/components/ChatPanelTabContent.js +0 -93
  133. package/dist/gui/components/ChatPreview.d.ts +0 -12
  134. package/dist/gui/components/ChatPreview.d.ts.map +0 -1
  135. package/dist/gui/components/ChatPreview.js +0 -214
  136. package/dist/gui/components/ChatPreview.js.map +0 -1
  137. package/dist/gui/components/ChatSecondaryPanel.d.ts.map +0 -1
  138. package/dist/gui/components/ChatSecondaryPanel.js.map +0 -1
  139. package/dist/gui/components/ChatSidebar.d.ts +0 -27
  140. package/dist/gui/components/ChatSidebar.js +0 -57
  141. package/dist/gui/components/ChatStatus.d.ts.map +0 -1
  142. package/dist/gui/components/ChatStatus.js.map +0 -1
  143. package/dist/gui/components/ChatView.d.ts +0 -8
  144. package/dist/gui/components/ChatView.d.ts.map +0 -1
  145. package/dist/gui/components/ChatView.js +0 -42
  146. package/dist/gui/components/ChatView.js.map +0 -1
  147. package/dist/gui/components/ConfigPanel.d.ts +0 -20
  148. package/dist/gui/components/ConfigPanel.d.ts.map +0 -1
  149. package/dist/gui/components/ConfigPanel.js +0 -225
  150. package/dist/gui/components/ConfigPanel.js.map +0 -1
  151. package/dist/gui/components/Conversation.d.ts.map +0 -1
  152. package/dist/gui/components/Conversation.js.map +0 -1
  153. package/dist/gui/components/Dialog.d.ts.map +0 -1
  154. package/dist/gui/components/Dialog.js.map +0 -1
  155. package/dist/gui/components/DropdownMenu.d.ts +0 -108
  156. package/dist/gui/components/DropdownMenu.js +0 -215
  157. package/dist/gui/components/HeightTransition.d.ts.map +0 -1
  158. package/dist/gui/components/HeightTransition.js.map +0 -1
  159. package/dist/gui/components/Input.d.ts.map +0 -1
  160. package/dist/gui/components/Input.js.map +0 -1
  161. package/dist/gui/components/InputBox.d.ts +0 -21
  162. package/dist/gui/components/InputBox.d.ts.map +0 -1
  163. package/dist/gui/components/InputBox.js +0 -90
  164. package/dist/gui/components/InputBox.js.map +0 -1
  165. package/dist/gui/components/Label.d.ts.map +0 -1
  166. package/dist/gui/components/Label.js.map +0 -1
  167. package/dist/gui/components/MarkdownRenderer.d.ts.map +0 -1
  168. package/dist/gui/components/MarkdownRenderer.js.map +0 -1
  169. package/dist/gui/components/Message.d.ts.map +0 -1
  170. package/dist/gui/components/Message.js.map +0 -1
  171. package/dist/gui/components/MessageContent.d.ts.map +0 -1
  172. package/dist/gui/components/MessageContent.js.map +0 -1
  173. package/dist/gui/components/MessageList.d.ts.map +0 -1
  174. package/dist/gui/components/MessageList.js.map +0 -1
  175. package/dist/gui/components/PlaygroundLayout.d.ts +0 -14
  176. package/dist/gui/components/PlaygroundLayout.d.ts.map +0 -1
  177. package/dist/gui/components/PlaygroundLayout.js +0 -49
  178. package/dist/gui/components/PlaygroundLayout.js.map +0 -1
  179. package/dist/gui/components/Reasoning.d.ts.map +0 -1
  180. package/dist/gui/components/Reasoning.js.map +0 -1
  181. package/dist/gui/components/Response.d.ts.map +0 -1
  182. package/dist/gui/components/Response.js.map +0 -1
  183. package/dist/gui/components/Select.d.ts.map +0 -1
  184. package/dist/gui/components/Select.js.map +0 -1
  185. package/dist/gui/components/Sonner.d.ts +0 -7
  186. package/dist/gui/components/Sonner.js +0 -34
  187. package/dist/gui/components/StatusBar.d.ts +0 -12
  188. package/dist/gui/components/StatusBar.d.ts.map +0 -1
  189. package/dist/gui/components/StatusBar.js +0 -58
  190. package/dist/gui/components/StatusBar.js.map +0 -1
  191. package/dist/gui/components/Tabs.d.ts.map +0 -1
  192. package/dist/gui/components/Tabs.js.map +0 -1
  193. package/dist/gui/components/Task.d.ts.map +0 -1
  194. package/dist/gui/components/Task.js.map +0 -1
  195. package/dist/gui/components/Textarea.d.ts.map +0 -1
  196. package/dist/gui/components/Textarea.js.map +0 -1
  197. package/dist/gui/components/ThinkingBlock.d.ts.map +0 -1
  198. package/dist/gui/components/ThinkingBlock.js.map +0 -1
  199. package/dist/gui/components/TodoList.d.ts.map +0 -1
  200. package/dist/gui/components/TodoList.js.map +0 -1
  201. package/dist/gui/components/TodoListItem.d.ts.map +0 -1
  202. package/dist/gui/components/TodoListItem.js.map +0 -1
  203. package/dist/gui/components/index.d.ts.map +0 -1
  204. package/dist/gui/components/index.js.map +0 -1
  205. package/dist/gui/index.d.ts.map +0 -1
  206. package/dist/gui/index.js.map +0 -1
  207. package/dist/gui/lib/utils.d.ts.map +0 -1
  208. package/dist/gui/lib/utils.js.map +0 -1
  209. package/dist/index.d.ts.map +0 -1
  210. package/dist/index.js.map +0 -1
  211. package/dist/sdk/client/acp-client.d.ts.map +0 -1
  212. package/dist/sdk/client/acp-client.js.map +0 -1
  213. package/dist/sdk/client/index.d.ts.map +0 -1
  214. package/dist/sdk/client/index.js.map +0 -1
  215. package/dist/sdk/index.d.ts.map +0 -1
  216. package/dist/sdk/index.js.map +0 -1
  217. package/dist/sdk/schemas/agent.d.ts.map +0 -1
  218. package/dist/sdk/schemas/agent.js.map +0 -1
  219. package/dist/sdk/schemas/index.d.ts.map +0 -1
  220. package/dist/sdk/schemas/index.js.map +0 -1
  221. package/dist/sdk/schemas/message.d.ts.map +0 -1
  222. package/dist/sdk/schemas/message.js.map +0 -1
  223. package/dist/sdk/schemas/session.d.ts.map +0 -1
  224. package/dist/sdk/schemas/session.js.map +0 -1
  225. package/dist/sdk/transports/http.d.ts.map +0 -1
  226. package/dist/sdk/transports/http.js.map +0 -1
  227. package/dist/sdk/transports/index.d.ts.map +0 -1
  228. package/dist/sdk/transports/index.js.map +0 -1
  229. package/dist/sdk/transports/stdio.d.ts.map +0 -1
  230. package/dist/sdk/transports/stdio.js.map +0 -1
  231. package/dist/sdk/transports/types.d.ts.map +0 -1
  232. package/dist/sdk/transports/types.js.map +0 -1
  233. package/dist/sdk/transports/websocket.d.ts.map +0 -1
  234. package/dist/sdk/transports/websocket.js.map +0 -1
  235. package/dist/tui/components/ChatView.d.ts.map +0 -1
  236. package/dist/tui/components/ChatView.js.map +0 -1
  237. package/dist/tui/components/GameOfLife.d.ts.map +0 -1
  238. package/dist/tui/components/GameOfLife.js.map +0 -1
  239. package/dist/tui/components/InputBox.d.ts.map +0 -1
  240. package/dist/tui/components/InputBox.js.map +0 -1
  241. package/dist/tui/components/MessageList.d.ts.map +0 -1
  242. package/dist/tui/components/MessageList.js.map +0 -1
  243. package/dist/tui/components/ReadlineInput.d.ts.map +0 -1
  244. package/dist/tui/components/ReadlineInput.js.map +0 -1
  245. package/dist/tui/components/StatusBar.d.ts.map +0 -1
  246. package/dist/tui/components/StatusBar.js.map +0 -1
  247. package/dist/tui/components/index.d.ts.map +0 -1
  248. package/dist/tui/components/index.js.map +0 -1
  249. package/dist/tui/index.d.ts.map +0 -1
  250. package/dist/tui/index.js.map +0 -1
@@ -2,182 +2,85 @@ import { jsx as _jsx } from "react/jsx-runtime";
2
2
  import ReactMarkdown from "react-markdown";
3
3
  import remarkGfm from "remark-gfm";
4
4
  import { cn } from "../lib/utils.js";
5
- export function MarkdownRenderer({ content, className }) {
6
- if (!content) {
7
- return null;
8
- }
9
- const components = {
10
- // Table styling
11
- table: ({ node, ...props }) =>
12
- _jsx("div", {
13
- className: "overflow-x-auto my-4",
14
- children: _jsx("table", {
15
- className:
16
- "min-w-full border-collapse border border-border rounded-md",
17
- ...props,
18
- }),
19
- }),
20
- thead: ({ node, ...props }) =>
21
- _jsx("thead", { className: "bg-card border-b border-border", ...props }),
22
- tbody: ({ node, ...props }) => _jsx("tbody", { ...props }),
23
- tr: ({ node, ...props }) =>
24
- _jsx("tr", {
25
- className: "border-b border-border hover:bg-card transition-colors",
26
- ...props,
27
- }),
28
- th: ({ node, ...props }) =>
29
- _jsx("th", {
30
- className:
31
- "px-4 py-2 text-left font-semibold text-foreground border-r border-border last:border-r-0",
32
- ...props,
33
- }),
34
- td: ({ node, ...props }) =>
35
- _jsx("td", {
36
- className:
37
- "px-4 py-2 text-foreground border-r border-border last:border-r-0",
38
- ...props,
39
- }),
40
- // Task list styling
41
- input: ({ node, checked, ...props }) => {
42
- if (props.type === "checkbox") {
43
- return _jsx("input", {
44
- type: "checkbox",
45
- checked: checked || false,
46
- disabled: true,
47
- readOnly: true,
48
- className: "mr-2 w-4 h-4 accent-[primary] cursor-not-allowed",
49
- ...props,
50
- });
51
- }
52
- return _jsx("input", { ...props });
53
- },
54
- // Code block styling
55
- code: ({ node, ...props }) => {
56
- const inline = !props.className?.includes("language-");
57
- if (inline) {
58
- return _jsx("code", {
59
- className:
60
- "px-1.5 py-0.5 bg-card border border-border rounded text-sm font-mono text-foreground",
61
- ...props,
62
- });
63
- }
64
- return _jsx("code", {
65
- className:
66
- "block p-4 bg-card border border-border rounded-md overflow-x-auto text-sm font-mono text-foreground",
67
- ...props,
68
- });
69
- },
70
- pre: ({ node, ...props }) => _jsx("pre", { className: "my-4", ...props }),
71
- // Heading styling
72
- h1: ({ node, ...props }) =>
73
- _jsx("h1", {
74
- className: "text-2xl font-bold mt-6 mb-4 text-foreground",
75
- ...props,
76
- }),
77
- h2: ({ node, ...props }) =>
78
- _jsx("h2", {
79
- className: "text-xl font-semibold mt-5 mb-3 text-foreground",
80
- ...props,
81
- }),
82
- h3: ({ node, ...props }) =>
83
- _jsx("h3", {
84
- className: "text-lg font-semibold mt-4 mb-2 text-foreground",
85
- ...props,
86
- }),
87
- // List styling
88
- ul: ({ node, ...props }) => {
89
- // Check if this is a task list by looking for checkbox inputs in children
90
- const isTaskList = node?.children?.some(
91
- (child) =>
92
- typeof child === "object" &&
93
- child !== null &&
94
- "type" in child &&
95
- child.type === "element" &&
96
- "tagName" in child &&
97
- child.tagName === "li" &&
98
- "children" in child &&
99
- Array.isArray(child.children) &&
100
- child.children.some(
101
- (grandChild) =>
102
- typeof grandChild === "object" &&
103
- grandChild !== null &&
104
- "type" in grandChild &&
105
- grandChild.type === "element" &&
106
- "tagName" in grandChild &&
107
- grandChild.tagName === "input" &&
108
- "properties" in grandChild &&
109
- typeof grandChild.properties === "object" &&
110
- grandChild.properties !== null &&
111
- "type" in grandChild.properties &&
112
- grandChild.properties.type === "checkbox",
113
- ),
114
- );
115
- return _jsx("ul", {
116
- className: cn(
117
- "my-2 space-y-1 text-foreground",
118
- isTaskList ? "list-none space-y-2" : "list-disc list-inside",
119
- ),
120
- ...props,
121
- });
122
- },
123
- ol: ({ node, ...props }) =>
124
- _jsx("ol", {
125
- className: "list-decimal list-inside my-2 space-y-1 text-foreground",
126
- ...props,
127
- }),
128
- // List item styling
129
- li: ({ node, ...props }) => {
130
- // Check if this li contains a checkbox (task list item)
131
- const isTaskListItem = node?.children?.some(
132
- (child) =>
133
- typeof child === "object" &&
134
- child !== null &&
135
- "type" in child &&
136
- child.type === "element" &&
137
- "tagName" in child &&
138
- child.tagName === "input" &&
139
- "properties" in child &&
140
- typeof child.properties === "object" &&
141
- child.properties !== null &&
142
- "type" in child.properties &&
143
- child.properties.type === "checkbox",
144
- );
145
- return _jsx("li", {
146
- className: cn("flex items-start", isTaskListItem ? "gap-2" : "ml-2"),
147
- ...props,
148
- });
149
- },
150
- // Link styling
151
- a: ({ node, ...props }) =>
152
- _jsx("a", {
153
- className: "text-primary hover:underline",
154
- target: "_blank",
155
- rel: "noopener noreferrer",
156
- ...props,
157
- }),
158
- // Paragraph styling
159
- p: ({ node, ...props }) =>
160
- _jsx("p", {
161
- className: "my-2 text-foreground leading-relaxed",
162
- ...props,
163
- }),
164
- // Blockquote styling
165
- blockquote: ({ node, ...props }) =>
166
- _jsx("blockquote", {
167
- className:
168
- "border-l-4 border-[primary] pl-4 italic my-4 text-foreground bg-card py-2",
169
- ...props,
170
- }),
171
- };
172
- return _jsx("div", {
173
- className: cn(
174
- "markdown-content prose prose-sm max-w-none dark:prose-invert",
175
- className,
176
- ),
177
- children: _jsx(ReactMarkdown, {
178
- remarkPlugins: [remarkGfm],
179
- components: components,
180
- children: content,
181
- }),
182
- });
5
+ export function MarkdownRenderer({ content, className, }) {
6
+ if (!content) {
7
+ return null;
8
+ }
9
+ const components = {
10
+ // Table styling
11
+ table: ({ node, ...props }) => (_jsx("div", { className: "overflow-x-auto my-4", children: _jsx("table", { className: "min-w-full border-collapse border border-border rounded-md", ...props }) })),
12
+ thead: ({ node, ...props }) => (_jsx("thead", { className: "bg-card border-b border-border", ...props })),
13
+ tbody: ({ node, ...props }) => _jsx("tbody", { ...props }),
14
+ tr: ({ node, ...props }) => (_jsx("tr", { className: "border-b border-border hover:bg-card transition-colors", ...props })),
15
+ th: ({ node, ...props }) => (_jsx("th", { className: "px-4 py-2 text-left font-semibold text-foreground border-r border-border last:border-r-0", ...props })),
16
+ td: ({ node, ...props }) => (_jsx("td", { className: "px-4 py-2 text-foreground border-r border-border last:border-r-0", ...props })),
17
+ // Task list styling
18
+ input: ({ node, checked, ...props }) => {
19
+ if (props.type === "checkbox") {
20
+ return (_jsx("input", { type: "checkbox", checked: checked || false, disabled: true, readOnly: true, className: "mr-2 w-4 h-4 accent-[primary] cursor-not-allowed", ...props }));
21
+ }
22
+ return _jsx("input", { ...props });
23
+ },
24
+ // Code block styling
25
+ code: ({ node, ...props }) => {
26
+ const inline = !props.className?.includes("language-");
27
+ if (inline) {
28
+ return (_jsx("code", { className: "px-1.5 py-0.5 bg-card border border-border rounded text-sm font-mono text-foreground", ...props }));
29
+ }
30
+ return (_jsx("code", { className: "block p-4 bg-card border border-border rounded-md overflow-x-auto text-sm font-mono text-foreground", ...props }));
31
+ },
32
+ pre: ({ node, ...props }) => _jsx("pre", { className: "my-4", ...props }),
33
+ // Heading styling
34
+ h1: ({ node, ...props }) => (_jsx("h1", { className: "text-2xl font-bold mt-6 mb-4 text-foreground", ...props })),
35
+ h2: ({ node, ...props }) => (_jsx("h2", { className: "text-xl font-semibold mt-5 mb-3 text-foreground", ...props })),
36
+ h3: ({ node, ...props }) => (_jsx("h3", { className: "text-lg font-semibold mt-4 mb-2 text-foreground", ...props })),
37
+ // List styling
38
+ ul: ({ node, ...props }) => {
39
+ // Check if this is a task list by looking for checkbox inputs in children
40
+ const isTaskList = node?.children?.some((child) => typeof child === "object" &&
41
+ child !== null &&
42
+ "type" in child &&
43
+ child.type === "element" &&
44
+ "tagName" in child &&
45
+ child.tagName === "li" &&
46
+ "children" in child &&
47
+ Array.isArray(child.children) &&
48
+ child.children.some((grandChild) => typeof grandChild === "object" &&
49
+ grandChild !== null &&
50
+ "type" in grandChild &&
51
+ grandChild.type === "element" &&
52
+ "tagName" in grandChild &&
53
+ grandChild.tagName === "input" &&
54
+ "properties" in grandChild &&
55
+ typeof grandChild.properties === "object" &&
56
+ grandChild.properties !== null &&
57
+ "type" in grandChild.properties &&
58
+ grandChild.properties.type === "checkbox"));
59
+ return (_jsx("ul", { className: cn("my-2 space-y-1 text-foreground", isTaskList ? "list-none space-y-2" : "list-disc list-inside"), ...props }));
60
+ },
61
+ ol: ({ node, ...props }) => (_jsx("ol", { className: "list-decimal list-inside my-2 space-y-1 text-foreground", ...props })),
62
+ // List item styling
63
+ li: ({ node, ...props }) => {
64
+ // Check if this li contains a checkbox (task list item)
65
+ const isTaskListItem = node?.children?.some((child) => typeof child === "object" &&
66
+ child !== null &&
67
+ "type" in child &&
68
+ child.type === "element" &&
69
+ "tagName" in child &&
70
+ child.tagName === "input" &&
71
+ "properties" in child &&
72
+ typeof child.properties === "object" &&
73
+ child.properties !== null &&
74
+ "type" in child.properties &&
75
+ child.properties.type === "checkbox");
76
+ return (_jsx("li", { className: cn("flex items-start", isTaskListItem ? "gap-2" : "ml-2"), ...props }));
77
+ },
78
+ // Link styling
79
+ a: ({ node, ...props }) => (_jsx("a", { className: "text-primary hover:underline", target: "_blank", rel: "noopener noreferrer", ...props })),
80
+ // Paragraph styling
81
+ p: ({ node, ...props }) => (_jsx("p", { className: "my-2 text-foreground leading-relaxed", ...props })),
82
+ // Blockquote styling
83
+ blockquote: ({ node, ...props }) => (_jsx("blockquote", { className: "border-l-4 border-[primary] pl-4 italic my-4 text-foreground bg-card py-2", ...props })),
84
+ };
85
+ return (_jsx("div", { className: cn("markdown-content prose prose-sm max-w-none dark:prose-invert", className), children: _jsx(ReactMarkdown, { remarkPlugins: [remarkGfm], components: components, children: content }) }));
183
86
  }
@@ -5,29 +5,22 @@ import type { DisplayMessage } from "./MessageList.js";
5
5
  * Message wrapper component inspired by shadcn.io/ai
6
6
  * Provides role-based layout and styling for chat messages
7
7
  */
8
- declare const messageVariants: (
9
- props?:
10
- | ({
11
- role?: "user" | "assistant" | "system" | null | undefined;
12
- layout?: "default" | "full" | "compact" | null | undefined;
13
- } & import("class-variance-authority/types").ClassProp)
14
- | undefined,
15
- ) => string;
16
- export interface MessageProps
17
- extends React.HTMLAttributes<HTMLDivElement>,
18
- VariantProps<typeof messageVariants> {
19
- /**
20
- * Message object for smart rendering (optional)
21
- * When provided, automatically extracts role and id
22
- */
23
- message?: DisplayMessage;
24
- /** Message role - determines alignment and styling (fallback if message not provided) */
25
- role?: "user" | "assistant" | "system";
26
- /** Optional layout override */
27
- layout?: "default" | "full" | "compact";
28
- /** Optional message ID for accessibility (fallback if message not provided) */
29
- messageId?: string;
8
+ declare const messageVariants: (props?: ({
9
+ role?: "user" | "assistant" | "system" | null | undefined;
10
+ layout?: "default" | "full" | "compact" | null | undefined;
11
+ } & import("class-variance-authority/types").ClassProp) | undefined) => string;
12
+ export interface MessageProps extends React.HTMLAttributes<HTMLDivElement>, VariantProps<typeof messageVariants> {
13
+ /**
14
+ * Message object for smart rendering (optional)
15
+ * When provided, automatically extracts role and id
16
+ */
17
+ message?: DisplayMessage;
18
+ /** Message role - determines alignment and styling (fallback if message not provided) */
19
+ role?: "user" | "assistant" | "system";
20
+ /** Optional layout override */
21
+ layout?: "default" | "full" | "compact";
22
+ /** Optional message ID for accessibility (fallback if message not provided) */
23
+ messageId?: string;
30
24
  }
31
- export declare const Message: React.ForwardRefExoticComponent<
32
- MessageProps & React.RefAttributes<HTMLDivElement>
33
- >;
25
+ export declare const Message: React.ForwardRefExoticComponent<MessageProps & React.RefAttributes<HTMLDivElement>>;
26
+ export {};
@@ -1,54 +1,33 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
1
2
  import { cva } from "class-variance-authority";
2
3
  import * as React from "react";
3
- import { jsx as _jsx } from "react/jsx-runtime";
4
4
  import { cn } from "../lib/utils.js";
5
-
6
5
  /**
7
6
  * Message wrapper component inspired by shadcn.io/ai
8
7
  * Provides role-based layout and styling for chat messages
9
8
  */
10
9
  const messageVariants = cva("flex animate-fadeIn", {
11
- variants: {
12
- role: {
13
- user: "max-w-[80%] self-end ml-auto",
14
- assistant: "self-start mr-auto",
15
- system: "self-start mr-auto max-w-full",
16
- },
17
- layout: {
18
- default: "",
19
- full: "max-w-full",
20
- compact: "max-w-[90%]",
21
- },
22
- },
23
- defaultVariants: {
24
- role: "assistant",
25
- layout: "default",
26
- },
10
+ variants: {
11
+ role: {
12
+ user: "max-w-[80%] self-end ml-auto",
13
+ assistant: "self-start mr-auto",
14
+ system: "self-start mr-auto max-w-full",
15
+ },
16
+ layout: {
17
+ default: "",
18
+ full: "max-w-full",
19
+ compact: "max-w-[90%]",
20
+ },
21
+ },
22
+ defaultVariants: {
23
+ role: "assistant",
24
+ layout: "default",
25
+ },
26
+ });
27
+ export const Message = React.forwardRef(({ message, role: roleProp, layout, className, children, messageId: messageIdProp, ...props }, ref) => {
28
+ // Extract role and messageId from message if provided
29
+ const role = message ? message.role : roleProp || "assistant";
30
+ const messageId = message ? message.id : messageIdProp;
31
+ return (_jsx("article", { ref: ref, "aria-label": `${role} message`, "data-message-id": messageId, className: cn(messageVariants({ role, layout }), className), ...props, children: children }));
27
32
  });
28
- export const Message = React.forwardRef(
29
- (
30
- {
31
- message,
32
- role: roleProp,
33
- layout,
34
- className,
35
- children,
36
- messageId: messageIdProp,
37
- ...props
38
- },
39
- ref,
40
- ) => {
41
- // Extract role and messageId from message if provided
42
- const role = message ? message.role : roleProp || "assistant";
43
- const messageId = message ? message.id : messageIdProp;
44
- return _jsx("article", {
45
- ref: ref,
46
- "aria-label": `${role} message`,
47
- "data-message-id": messageId,
48
- className: cn(messageVariants({ role, layout }), className),
49
- ...props,
50
- children: children,
51
- });
52
- },
53
- );
54
33
  Message.displayName = "Message";
@@ -1,33 +1,26 @@
1
1
  import { type VariantProps } from "class-variance-authority";
2
2
  import * as React from "react";
3
3
  import type { DisplayMessage } from "./MessageList.js";
4
- declare const messageContentVariants: (
5
- props?:
6
- | ({
7
- role?: "user" | "assistant" | "system" | null | undefined;
8
- variant?: "default" | "outline" | "ghost" | null | undefined;
9
- } & import("class-variance-authority/types").ClassProp)
10
- | undefined,
11
- ) => string;
12
- export interface MessageContentProps
13
- extends Omit<React.HTMLAttributes<HTMLDivElement>, "children">,
14
- VariantProps<typeof messageContentVariants> {
15
- /** Message role - determines styling */
16
- role?: "user" | "assistant" | "system";
17
- /** Visual variant */
18
- variant?: "default" | "outline" | "ghost";
19
- /** Whether the message is currently streaming */
20
- isStreaming?: boolean;
21
- /**
22
- * Message object for smart rendering (optional)
23
- * When provided, automatically renders thinking, waiting, and content
24
- */
25
- message?: DisplayMessage;
26
- /** Display style for thinking/reasoning blocks (when using smart rendering) */
27
- thinkingDisplayStyle?: "collapsible" | "inline";
28
- /** Custom content (overrides smart rendering) */
29
- children?: React.ReactNode;
4
+ declare const messageContentVariants: (props?: ({
5
+ role?: "user" | "assistant" | "system" | null | undefined;
6
+ variant?: "default" | "outline" | "ghost" | null | undefined;
7
+ } & import("class-variance-authority/types").ClassProp) | undefined) => string;
8
+ export interface MessageContentProps extends Omit<React.HTMLAttributes<HTMLDivElement>, "children">, VariantProps<typeof messageContentVariants> {
9
+ /** Message role - determines styling */
10
+ role?: "user" | "assistant" | "system";
11
+ /** Visual variant */
12
+ variant?: "default" | "outline" | "ghost";
13
+ /** Whether the message is currently streaming */
14
+ isStreaming?: boolean;
15
+ /**
16
+ * Message object for smart rendering (optional)
17
+ * When provided, automatically renders thinking, waiting, and content
18
+ */
19
+ message?: DisplayMessage;
20
+ /** Display style for thinking/reasoning blocks (when using smart rendering) */
21
+ thinkingDisplayStyle?: "collapsible" | "inline";
22
+ /** Custom content (overrides smart rendering) */
23
+ children?: React.ReactNode;
30
24
  }
31
- export declare const MessageContent: React.ForwardRefExoticComponent<
32
- MessageContentProps & React.RefAttributes<HTMLDivElement>
33
- >;
25
+ export declare const MessageContent: React.ForwardRefExoticComponent<MessageContentProps & React.RefAttributes<HTMLDivElement>>;
26
+ export {};