@patternfly/chatbot 6.5.0-prerelease.9 → 6.5.0

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 (314) hide show
  1. package/dist/cjs/ChatbotConversationHistoryNav/ChatbotConversationHistoryNav.d.ts +9 -1
  2. package/dist/cjs/ChatbotConversationHistoryNav/ChatbotConversationHistoryNav.js +9 -2
  3. package/dist/cjs/ChatbotConversationHistoryNav/ChatbotConversationHistoryNav.test.js +38 -0
  4. package/dist/cjs/ChatbotHeader/ChatbotHeaderMenu.js +29 -2
  5. package/dist/cjs/CodeModal/CodeModal.d.ts +2 -0
  6. package/dist/cjs/CodeModal/CodeModal.js +53 -12
  7. package/dist/cjs/DeepThinking/DeepThinking.d.ts +13 -0
  8. package/dist/cjs/DeepThinking/DeepThinking.js +31 -3
  9. package/dist/cjs/DeepThinking/DeepThinking.test.js +80 -0
  10. package/dist/cjs/MarkdownContent/MarkdownContent.d.ts +44 -0
  11. package/dist/cjs/MarkdownContent/MarkdownContent.js +181 -0
  12. package/dist/cjs/MarkdownContent/MarkdownContent.test.d.ts +1 -0
  13. package/dist/cjs/MarkdownContent/MarkdownContent.test.js +192 -0
  14. package/dist/cjs/MarkdownContent/index.d.ts +2 -0
  15. package/dist/cjs/MarkdownContent/index.js +23 -0
  16. package/dist/cjs/Message/CodeBlockMessage/CodeBlockMessage.d.ts +3 -1
  17. package/dist/cjs/Message/CodeBlockMessage/CodeBlockMessage.js +15 -4
  18. package/dist/cjs/Message/CodeBlockMessage/CodeBlockMessage.test.d.ts +1 -0
  19. package/dist/cjs/Message/CodeBlockMessage/CodeBlockMessage.test.js +131 -0
  20. package/dist/cjs/Message/ErrorMessage/ErrorMessage.d.ts +15 -1
  21. package/dist/cjs/Message/ErrorMessage/ErrorMessage.js +5 -3
  22. package/dist/cjs/Message/ErrorMessage/ErrorMessage.test.d.ts +1 -0
  23. package/dist/cjs/Message/ErrorMessage/ErrorMessage.test.js +30 -0
  24. package/dist/cjs/Message/LinkMessage/LinkMessage.d.ts +5 -1
  25. package/dist/cjs/Message/LinkMessage/LinkMessage.js +4 -3
  26. package/dist/cjs/Message/ListMessage/OrderedListMessage.d.ts +9 -1
  27. package/dist/cjs/Message/ListMessage/OrderedListMessage.js +2 -1
  28. package/dist/cjs/Message/ListMessage/UnorderedListMessage.d.ts +7 -1
  29. package/dist/cjs/Message/ListMessage/UnorderedListMessage.js +2 -1
  30. package/dist/cjs/Message/Message.d.ts +20 -3
  31. package/dist/cjs/Message/Message.js +7 -160
  32. package/dist/cjs/Message/Message.test.js +129 -2
  33. package/dist/cjs/Message/MessageAndActions/MessageAndActions.d.ts +14 -0
  34. package/dist/cjs/Message/MessageAndActions/MessageAndActions.js +22 -0
  35. package/dist/cjs/Message/MessageAndActions/MessageAndActions.test.d.ts +1 -0
  36. package/dist/cjs/Message/MessageAndActions/MessageAndActions.test.js +25 -0
  37. package/dist/cjs/Message/MessageAndActions/index.d.ts +1 -0
  38. package/dist/cjs/Message/MessageAndActions/index.js +17 -0
  39. package/dist/cjs/Message/MessageAttachments/MessageAttachmentItem.d.ts +13 -0
  40. package/dist/cjs/Message/MessageAttachments/MessageAttachmentItem.js +22 -0
  41. package/dist/cjs/Message/MessageAttachments/MessageAttachmentItem.test.d.ts +1 -0
  42. package/dist/cjs/Message/MessageAttachments/MessageAttachmentItem.test.js +25 -0
  43. package/dist/cjs/Message/MessageAttachments/MessageAttachmentsContainer.d.ts +13 -0
  44. package/dist/cjs/Message/MessageAttachments/MessageAttachmentsContainer.js +22 -0
  45. package/dist/cjs/Message/MessageAttachments/MessageAttachmentsContainer.test.d.ts +1 -0
  46. package/dist/cjs/Message/MessageAttachments/MessageAttachmentsContainer.test.js +25 -0
  47. package/dist/cjs/Message/MessageAttachments/index.d.ts +2 -0
  48. package/dist/cjs/Message/MessageAttachments/index.js +18 -0
  49. package/dist/cjs/Message/MessageInput.d.ts +1 -1
  50. package/dist/cjs/Message/MessageInput.js +3 -1
  51. package/dist/cjs/Message/MessageLoading.d.ts +13 -4
  52. package/dist/cjs/Message/MessageLoading.js +19 -5
  53. package/dist/cjs/Message/MessageLoading.test.d.ts +1 -0
  54. package/dist/cjs/Message/MessageLoading.test.js +25 -0
  55. package/dist/cjs/Message/QuickResponse/QuickResponse.js +3 -2
  56. package/dist/cjs/Message/QuickResponse/QuickResponse.test.d.ts +1 -0
  57. package/dist/cjs/Message/QuickResponse/QuickResponse.test.js +109 -0
  58. package/dist/cjs/Message/QuickResponse/index.d.ts +1 -0
  59. package/dist/cjs/Message/QuickResponse/index.js +17 -0
  60. package/dist/cjs/Message/QuickStarts/QuickStartTile.d.ts +1 -1
  61. package/dist/cjs/Message/QuickStarts/QuickStartTile.js +3 -2
  62. package/dist/cjs/Message/QuickStarts/index.d.ts +2 -0
  63. package/dist/cjs/Message/QuickStarts/index.js +18 -0
  64. package/dist/cjs/Message/TableMessage/TableMessage.d.ts +6 -1
  65. package/dist/cjs/Message/TableMessage/TableMessage.js +3 -2
  66. package/dist/cjs/Message/TextMessage/TextMessage.d.ts +8 -1
  67. package/dist/cjs/Message/TextMessage/TextMessage.js +3 -2
  68. package/dist/cjs/Message/UserFeedback/UserFeedback.d.ts +3 -1
  69. package/dist/cjs/Message/UserFeedback/UserFeedback.js +8 -6
  70. package/dist/cjs/Message/UserFeedback/UserFeedbackComplete.d.ts +1 -1
  71. package/dist/cjs/Message/UserFeedback/UserFeedbackComplete.js +3 -2
  72. package/dist/cjs/Message/UserFeedback/index.d.ts +2 -0
  73. package/dist/cjs/Message/UserFeedback/index.js +18 -0
  74. package/dist/cjs/Message/index.d.ts +8 -0
  75. package/dist/cjs/Message/index.js +8 -0
  76. package/dist/cjs/MessageBar/MessageBar.d.ts +4 -0
  77. package/dist/cjs/MessageBar/MessageBar.js +20 -5
  78. package/dist/cjs/MessageBar/MessageBar.test.js +8 -0
  79. package/dist/cjs/Onboarding/Onboarding.d.ts +36 -0
  80. package/dist/cjs/Onboarding/Onboarding.js +37 -0
  81. package/dist/cjs/Onboarding/Onboarding.test.d.ts +1 -0
  82. package/dist/cjs/Onboarding/Onboarding.test.js +80 -0
  83. package/dist/cjs/Onboarding/index.d.ts +2 -0
  84. package/dist/cjs/Onboarding/index.js +23 -0
  85. package/dist/cjs/ResponseActions/ResponseActions.d.ts +7 -0
  86. package/dist/cjs/ResponseActions/ResponseActions.js +28 -7
  87. package/dist/cjs/ResponseActions/ResponseActions.test.js +67 -12
  88. package/dist/cjs/ResponseActions/ResponseActionsGroups.d.ts +13 -0
  89. package/dist/cjs/ResponseActions/ResponseActionsGroups.js +22 -0
  90. package/dist/cjs/ResponseActions/ResponseActionsGroups.test.d.ts +1 -0
  91. package/dist/cjs/ResponseActions/ResponseActionsGroups.test.js +25 -0
  92. package/dist/cjs/ResponseActions/index.d.ts +1 -0
  93. package/dist/cjs/ResponseActions/index.js +1 -0
  94. package/dist/cjs/ToolCall/ToolCall.d.ts +11 -0
  95. package/dist/cjs/ToolCall/ToolCall.js +24 -3
  96. package/dist/cjs/ToolCall/ToolCall.test.js +57 -0
  97. package/dist/cjs/ToolResponse/ToolResponse.d.ts +17 -0
  98. package/dist/cjs/ToolResponse/ToolResponse.js +49 -3
  99. package/dist/cjs/ToolResponse/ToolResponse.test.js +100 -0
  100. package/dist/cjs/index.d.ts +4 -0
  101. package/dist/cjs/index.js +7 -1
  102. package/dist/css/main.css +264 -30
  103. package/dist/css/main.css.map +1 -1
  104. package/dist/dynamic/MarkdownContent/package.json +1 -0
  105. package/dist/dynamic/Onboarding/package.json +1 -0
  106. package/dist/esm/ChatbotConversationHistoryNav/ChatbotConversationHistoryNav.d.ts +9 -1
  107. package/dist/esm/ChatbotConversationHistoryNav/ChatbotConversationHistoryNav.js +10 -3
  108. package/dist/esm/ChatbotConversationHistoryNav/ChatbotConversationHistoryNav.test.js +38 -0
  109. package/dist/esm/ChatbotHeader/ChatbotHeaderMenu.js +30 -3
  110. package/dist/esm/CodeModal/CodeModal.d.ts +2 -0
  111. package/dist/esm/CodeModal/CodeModal.js +54 -13
  112. package/dist/esm/DeepThinking/DeepThinking.d.ts +13 -0
  113. package/dist/esm/DeepThinking/DeepThinking.js +28 -3
  114. package/dist/esm/DeepThinking/DeepThinking.test.js +80 -0
  115. package/dist/esm/MarkdownContent/MarkdownContent.d.ts +44 -0
  116. package/dist/esm/MarkdownContent/MarkdownContent.js +174 -0
  117. package/dist/esm/MarkdownContent/MarkdownContent.test.d.ts +1 -0
  118. package/dist/esm/MarkdownContent/MarkdownContent.test.js +187 -0
  119. package/dist/esm/MarkdownContent/index.d.ts +2 -0
  120. package/dist/esm/MarkdownContent/index.js +2 -0
  121. package/dist/esm/Message/CodeBlockMessage/CodeBlockMessage.d.ts +3 -1
  122. package/dist/esm/Message/CodeBlockMessage/CodeBlockMessage.js +15 -4
  123. package/dist/esm/Message/CodeBlockMessage/CodeBlockMessage.test.d.ts +1 -0
  124. package/dist/esm/Message/CodeBlockMessage/CodeBlockMessage.test.js +126 -0
  125. package/dist/esm/Message/ErrorMessage/ErrorMessage.d.ts +15 -1
  126. package/dist/esm/Message/ErrorMessage/ErrorMessage.js +3 -3
  127. package/dist/esm/Message/ErrorMessage/ErrorMessage.test.d.ts +1 -0
  128. package/dist/esm/Message/ErrorMessage/ErrorMessage.test.js +25 -0
  129. package/dist/esm/Message/LinkMessage/LinkMessage.d.ts +5 -1
  130. package/dist/esm/Message/LinkMessage/LinkMessage.js +4 -3
  131. package/dist/esm/Message/ListMessage/OrderedListMessage.d.ts +9 -1
  132. package/dist/esm/Message/ListMessage/OrderedListMessage.js +2 -1
  133. package/dist/esm/Message/ListMessage/UnorderedListMessage.d.ts +7 -1
  134. package/dist/esm/Message/ListMessage/UnorderedListMessage.js +2 -1
  135. package/dist/esm/Message/Message.d.ts +20 -3
  136. package/dist/esm/Message/Message.js +8 -161
  137. package/dist/esm/Message/Message.test.js +129 -2
  138. package/dist/esm/Message/MessageAndActions/MessageAndActions.d.ts +14 -0
  139. package/dist/esm/Message/MessageAndActions/MessageAndActions.js +18 -0
  140. package/dist/esm/Message/MessageAndActions/MessageAndActions.test.d.ts +1 -0
  141. package/dist/esm/Message/MessageAndActions/MessageAndActions.test.js +20 -0
  142. package/dist/esm/Message/MessageAndActions/index.d.ts +1 -0
  143. package/dist/esm/Message/MessageAndActions/index.js +1 -0
  144. package/dist/esm/Message/MessageAttachments/MessageAttachmentItem.d.ts +13 -0
  145. package/dist/esm/Message/MessageAttachments/MessageAttachmentItem.js +18 -0
  146. package/dist/esm/Message/MessageAttachments/MessageAttachmentItem.test.d.ts +1 -0
  147. package/dist/esm/Message/MessageAttachments/MessageAttachmentItem.test.js +20 -0
  148. package/dist/esm/Message/MessageAttachments/MessageAttachmentsContainer.d.ts +13 -0
  149. package/dist/esm/Message/MessageAttachments/MessageAttachmentsContainer.js +18 -0
  150. package/dist/esm/Message/MessageAttachments/MessageAttachmentsContainer.test.d.ts +1 -0
  151. package/dist/esm/Message/MessageAttachments/MessageAttachmentsContainer.test.js +20 -0
  152. package/dist/esm/Message/MessageAttachments/index.d.ts +2 -0
  153. package/dist/esm/Message/MessageAttachments/index.js +2 -0
  154. package/dist/esm/Message/MessageInput.d.ts +1 -1
  155. package/dist/esm/Message/MessageInput.js +1 -1
  156. package/dist/esm/Message/MessageLoading.d.ts +13 -4
  157. package/dist/esm/Message/MessageLoading.js +16 -4
  158. package/dist/esm/Message/MessageLoading.test.d.ts +1 -0
  159. package/dist/esm/Message/MessageLoading.test.js +20 -0
  160. package/dist/esm/Message/QuickResponse/QuickResponse.js +3 -2
  161. package/dist/esm/Message/QuickResponse/QuickResponse.test.d.ts +1 -0
  162. package/dist/esm/Message/QuickResponse/QuickResponse.test.js +104 -0
  163. package/dist/esm/Message/QuickResponse/index.d.ts +1 -0
  164. package/dist/esm/Message/QuickResponse/index.js +1 -0
  165. package/dist/esm/Message/QuickStarts/QuickStartTile.d.ts +1 -1
  166. package/dist/esm/Message/QuickStarts/QuickStartTile.js +1 -1
  167. package/dist/esm/Message/QuickStarts/index.d.ts +2 -0
  168. package/dist/esm/Message/QuickStarts/index.js +2 -0
  169. package/dist/esm/Message/TableMessage/TableMessage.d.ts +6 -1
  170. package/dist/esm/Message/TableMessage/TableMessage.js +3 -2
  171. package/dist/esm/Message/TextMessage/TextMessage.d.ts +8 -1
  172. package/dist/esm/Message/TextMessage/TextMessage.js +3 -2
  173. package/dist/esm/Message/UserFeedback/UserFeedback.d.ts +3 -1
  174. package/dist/esm/Message/UserFeedback/UserFeedback.js +7 -7
  175. package/dist/esm/Message/UserFeedback/UserFeedbackComplete.d.ts +1 -1
  176. package/dist/esm/Message/UserFeedback/UserFeedbackComplete.js +1 -2
  177. package/dist/esm/Message/UserFeedback/index.d.ts +2 -0
  178. package/dist/esm/Message/UserFeedback/index.js +2 -0
  179. package/dist/esm/Message/index.d.ts +8 -0
  180. package/dist/esm/Message/index.js +8 -0
  181. package/dist/esm/MessageBar/MessageBar.d.ts +4 -0
  182. package/dist/esm/MessageBar/MessageBar.js +20 -5
  183. package/dist/esm/MessageBar/MessageBar.test.js +8 -0
  184. package/dist/esm/Onboarding/Onboarding.d.ts +36 -0
  185. package/dist/esm/Onboarding/Onboarding.js +30 -0
  186. package/dist/esm/Onboarding/Onboarding.test.d.ts +1 -0
  187. package/dist/esm/Onboarding/Onboarding.test.js +75 -0
  188. package/dist/esm/Onboarding/index.d.ts +2 -0
  189. package/dist/esm/Onboarding/index.js +2 -0
  190. package/dist/esm/ResponseActions/ResponseActions.d.ts +7 -0
  191. package/dist/esm/ResponseActions/ResponseActions.js +28 -7
  192. package/dist/esm/ResponseActions/ResponseActions.test.js +67 -12
  193. package/dist/esm/ResponseActions/ResponseActionsGroups.d.ts +13 -0
  194. package/dist/esm/ResponseActions/ResponseActionsGroups.js +18 -0
  195. package/dist/esm/ResponseActions/ResponseActionsGroups.test.d.ts +1 -0
  196. package/dist/esm/ResponseActions/ResponseActionsGroups.test.js +20 -0
  197. package/dist/esm/ResponseActions/index.d.ts +1 -0
  198. package/dist/esm/ResponseActions/index.js +1 -0
  199. package/dist/esm/ToolCall/ToolCall.d.ts +11 -0
  200. package/dist/esm/ToolCall/ToolCall.js +21 -3
  201. package/dist/esm/ToolCall/ToolCall.test.js +57 -0
  202. package/dist/esm/ToolResponse/ToolResponse.d.ts +17 -0
  203. package/dist/esm/ToolResponse/ToolResponse.js +46 -3
  204. package/dist/esm/ToolResponse/ToolResponse.test.js +100 -0
  205. package/dist/esm/index.d.ts +4 -0
  206. package/dist/esm/index.js +4 -0
  207. package/dist/tsconfig.tsbuildinfo +1 -1
  208. package/package.json +13 -3
  209. package/patternfly-docs/content/extensions/chatbot/chatbot.md +57 -0
  210. package/patternfly-docs/content/extensions/chatbot/design-guidelines.md +12 -12
  211. package/patternfly-docs/content/extensions/chatbot/examples/Analytics/Analytics.md +1 -1
  212. package/patternfly-docs/content/extensions/chatbot/examples/Customizing Messages/Customizing Messages.md +1 -1
  213. package/patternfly-docs/content/extensions/chatbot/examples/Messages/BotMessage.tsx +1 -0
  214. package/patternfly-docs/content/extensions/chatbot/examples/Messages/MessageWithCustomStructure.tsx +102 -0
  215. package/patternfly-docs/content/extensions/chatbot/examples/Messages/MessageWithDeepThinking.tsx +25 -11
  216. package/patternfly-docs/content/extensions/chatbot/examples/Messages/MessageWithFeedback.tsx +14 -1
  217. package/patternfly-docs/content/extensions/chatbot/examples/Messages/MessageWithMarkdownDeepThinking.tsx +26 -0
  218. package/patternfly-docs/content/extensions/chatbot/examples/Messages/MessageWithMarkdownToolCall.tsx +29 -0
  219. package/patternfly-docs/content/extensions/chatbot/examples/Messages/MessageWithMarkdownToolResponse.tsx +200 -0
  220. package/patternfly-docs/content/extensions/chatbot/examples/Messages/MessageWithMultipleActionGroups.tsx +61 -0
  221. package/patternfly-docs/content/extensions/chatbot/examples/Messages/MessageWithPersistedActions.tsx +22 -0
  222. package/patternfly-docs/content/extensions/chatbot/examples/Messages/MessageWithQuickResponses.tsx +11 -0
  223. package/patternfly-docs/content/extensions/chatbot/examples/Messages/MessageWithToolCall.tsx +14 -1
  224. package/patternfly-docs/content/extensions/chatbot/examples/Messages/MessageWithToolResponse.tsx +222 -105
  225. package/patternfly-docs/content/extensions/chatbot/examples/Messages/Messages.md +123 -14
  226. package/patternfly-docs/content/extensions/chatbot/examples/Messages/UserMessage.tsx +1 -0
  227. package/patternfly-docs/content/extensions/chatbot/examples/UI/ChatbotHeaderDrawerWithSearchActions.tsx +198 -0
  228. package/patternfly-docs/content/extensions/chatbot/examples/UI/ChatbotMessageBarIndicatorThinking.tsx +15 -0
  229. package/patternfly-docs/content/extensions/chatbot/examples/UI/CompactOnboarding.tsx +141 -0
  230. package/patternfly-docs/content/extensions/chatbot/examples/UI/Onboarding.tsx +151 -0
  231. package/patternfly-docs/content/extensions/chatbot/examples/UI/RH-Hat-Image.svg +9 -0
  232. package/patternfly-docs/content/extensions/chatbot/examples/UI/UI.md +67 -29
  233. package/patternfly-docs/content/extensions/chatbot/examples/demos/AttachmentDemos.md +18 -18
  234. package/patternfly-docs/content/extensions/chatbot/examples/demos/Chatbot.md +33 -19
  235. package/patternfly-docs/patternfly-docs.config.js +1 -1
  236. package/patternfly-docs/patternfly-docs.source.js +1 -1
  237. package/src/ChatbotConversationHistoryNav/ChatbotConversationHistoryNav.scss +43 -0
  238. package/src/ChatbotConversationHistoryNav/ChatbotConversationHistoryNav.test.tsx +95 -0
  239. package/src/ChatbotConversationHistoryNav/ChatbotConversationHistoryNav.tsx +51 -15
  240. package/src/ChatbotHeader/ChatbotHeaderMenu.tsx +56 -14
  241. package/src/ChatbotModal/ChatbotModal.scss +3 -0
  242. package/src/CodeModal/CodeModal.tsx +71 -26
  243. package/src/DeepThinking/DeepThinking.scss +1 -1
  244. package/src/DeepThinking/DeepThinking.test.tsx +109 -0
  245. package/src/DeepThinking/DeepThinking.tsx +54 -5
  246. package/src/MarkdownContent/MarkdownContent.test.tsx +207 -0
  247. package/src/MarkdownContent/MarkdownContent.tsx +269 -0
  248. package/src/MarkdownContent/index.ts +2 -0
  249. package/src/Message/CodeBlockMessage/CodeBlockMessage.scss +13 -0
  250. package/src/Message/CodeBlockMessage/CodeBlockMessage.test.tsx +171 -0
  251. package/src/Message/CodeBlockMessage/CodeBlockMessage.tsx +17 -4
  252. package/src/Message/ErrorMessage/ErrorMessage.test.tsx +38 -0
  253. package/src/Message/ErrorMessage/ErrorMessage.tsx +17 -2
  254. package/src/Message/LinkMessage/LinkMessage.scss +5 -0
  255. package/src/Message/LinkMessage/LinkMessage.tsx +24 -2
  256. package/src/Message/ListMessage/ListMessage.scss +8 -0
  257. package/src/Message/ListMessage/OrderedListMessage.tsx +16 -2
  258. package/src/Message/ListMessage/UnorderedListMessage.tsx +12 -2
  259. package/src/Message/Message.scss +11 -7
  260. package/src/Message/Message.test.tsx +202 -2
  261. package/src/Message/Message.tsx +129 -241
  262. package/src/Message/MessageAndActions/MessageAndActions.test.tsx +23 -0
  263. package/src/Message/MessageAndActions/MessageAndActions.tsx +22 -0
  264. package/src/Message/MessageAndActions/index.ts +1 -0
  265. package/src/Message/MessageAttachments/MessageAttachmentItem.test.tsx +23 -0
  266. package/src/Message/MessageAttachments/MessageAttachmentItem.tsx +25 -0
  267. package/src/Message/MessageAttachments/MessageAttachmentsContainer.test.tsx +23 -0
  268. package/src/Message/MessageAttachments/MessageAttachmentsContainer.tsx +25 -0
  269. package/src/Message/MessageAttachments/index.ts +2 -0
  270. package/src/Message/MessageInput.tsx +1 -1
  271. package/src/Message/MessageLoading.test.tsx +23 -0
  272. package/src/Message/MessageLoading.tsx +17 -2
  273. package/src/Message/QuickResponse/QuickResponse.scss +3 -1
  274. package/src/Message/QuickResponse/QuickResponse.test.tsx +131 -0
  275. package/src/Message/QuickResponse/QuickResponse.tsx +3 -2
  276. package/src/Message/QuickResponse/index.ts +1 -0
  277. package/src/Message/QuickStarts/QuickStartTile.tsx +1 -1
  278. package/src/Message/QuickStarts/index.ts +2 -0
  279. package/src/Message/TableMessage/TableMessage.scss +13 -1
  280. package/src/Message/TableMessage/TableMessage.tsx +18 -2
  281. package/src/Message/TextMessage/TextMessage.scss +12 -0
  282. package/src/Message/TextMessage/TextMessage.tsx +29 -2
  283. package/src/Message/UserFeedback/UserFeedback.scss +28 -1
  284. package/src/Message/UserFeedback/UserFeedback.tsx +23 -13
  285. package/src/Message/UserFeedback/UserFeedbackComplete.tsx +1 -4
  286. package/src/Message/UserFeedback/index.ts +2 -0
  287. package/src/Message/index.ts +8 -0
  288. package/src/MessageBar/AttachButton.scss +0 -1
  289. package/src/MessageBar/MessageBar.scss +48 -6
  290. package/src/MessageBar/MessageBar.test.tsx +12 -0
  291. package/src/MessageBar/MessageBar.tsx +38 -4
  292. package/src/MessageBar/MicrophoneButton.scss +0 -1
  293. package/src/MessageBar/SendButton.scss +0 -1
  294. package/src/MessageBar/StopButton.scss +0 -1
  295. package/src/Onboarding/Onboarding.scss +101 -0
  296. package/src/Onboarding/Onboarding.test.tsx +148 -0
  297. package/src/Onboarding/Onboarding.tsx +126 -0
  298. package/src/Onboarding/index.ts +3 -0
  299. package/src/ResponseActions/ResponseActions.scss +12 -1
  300. package/src/ResponseActions/ResponseActions.test.tsx +111 -12
  301. package/src/ResponseActions/ResponseActions.tsx +44 -10
  302. package/src/ResponseActions/ResponseActionsGroups.test.tsx +23 -0
  303. package/src/ResponseActions/ResponseActionsGroups.tsx +28 -0
  304. package/src/ResponseActions/index.ts +1 -0
  305. package/src/ToolCall/ToolCall.scss +1 -1
  306. package/src/ToolCall/ToolCall.test.tsx +91 -0
  307. package/src/ToolCall/ToolCall.tsx +49 -4
  308. package/src/ToolResponse/ToolResponse.scss +13 -3
  309. package/src/ToolResponse/ToolResponse.test.tsx +119 -0
  310. package/src/ToolResponse/ToolResponse.tsx +82 -7
  311. package/src/index.ts +6 -0
  312. package/src/main.scss +2 -0
  313. package/tsconfig.json +1 -1
  314. package/patternfly-docs/content/extensions/chatbot/about-chatbot.md +0 -44
@@ -10,6 +10,7 @@ import {
10
10
  TextAreaProps,
11
11
  TooltipProps
12
12
  } from '@patternfly/react-core';
13
+ import { css } from '@patternfly/react-styles';
13
14
 
14
15
  // Import Chatbot components
15
16
  import SendButton from './SendButton';
@@ -115,6 +116,10 @@ export interface MessageBarProps extends Omit<TextAreaProps, 'innerRef'> {
115
116
  innerRef?: React.Ref<HTMLTextAreaElement>;
116
117
  /** Sets background color to primary */
117
118
  isPrimary?: boolean;
119
+ /** @beta Flag indicating whether the message bar has an AI indicator border. */
120
+ hasAiIndicator?: boolean;
121
+ /** @beta Flag indicating whether the chatbot is thinking in response to a query, adding an animation to the message bar. */
122
+ isThinking?: boolean;
118
123
  }
119
124
 
120
125
  export const MessageBarBase: FunctionComponent<MessageBarProps> = ({
@@ -146,6 +151,8 @@ export const MessageBarBase: FunctionComponent<MessageBarProps> = ({
146
151
  dropzoneProps,
147
152
  innerRef,
148
153
  isPrimary,
154
+ hasAiIndicator,
155
+ isThinking,
149
156
  ...props
150
157
  }: MessageBarProps) => {
151
158
  // Text Input
@@ -154,6 +161,7 @@ export const MessageBarBase: FunctionComponent<MessageBarProps> = ({
154
161
  const [isListeningMessage, setIsListeningMessage] = useState<boolean>(false);
155
162
  const [hasSentMessage, setHasSentMessage] = useState(false);
156
163
  const [isComposing, setIsComposing] = useState(false);
164
+ const [isMultiline, setIsMultiline] = useState(false);
157
165
  const inputRef = useRef<HTMLTextAreaElement>(null);
158
166
  const textareaRef = (innerRef as React.RefObject<HTMLTextAreaElement>) ?? inputRef;
159
167
  const attachButtonRef = useRef<HTMLButtonElement>(null);
@@ -202,6 +210,19 @@ export const MessageBarBase: FunctionComponent<MessageBarProps> = ({
202
210
  return lines > 2;
203
211
  };
204
212
 
213
+ const checkIfMultiline = useCallback(
214
+ (field: HTMLTextAreaElement) => {
215
+ const parent = field.parentElement;
216
+ const grandparent = parent?.parentElement;
217
+ if (grandparent) {
218
+ const containerHeight = grandparent.offsetHeight;
219
+ const threshold = isCompact ? 56 : 70;
220
+ setIsMultiline(containerHeight > threshold);
221
+ }
222
+ },
223
+ [isCompact]
224
+ );
225
+
205
226
  const setAutoWidth = useCallback((field: HTMLTextAreaElement) => {
206
227
  const parent = field.parentElement;
207
228
  if (parent) {
@@ -256,12 +277,14 @@ export const MessageBarBase: FunctionComponent<MessageBarProps> = ({
256
277
  if (field) {
257
278
  if (field.value === '') {
258
279
  setInitialLineHeight(field);
280
+ setIsMultiline(false);
259
281
  } else {
260
282
  setAutoHeight(field);
261
283
  setAutoWidth(field);
284
+ checkIfMultiline(field);
262
285
  }
263
286
  }
264
- }, [displayMode, message, setAutoWidth]);
287
+ }, [displayMode, message, setAutoWidth, checkIfMultiline]);
265
288
 
266
289
  useEffect(() => {
267
290
  const field = textareaRef.current;
@@ -277,13 +300,15 @@ export const MessageBarBase: FunctionComponent<MessageBarProps> = ({
277
300
  if (textareaRef.current) {
278
301
  if (event.target.value === '') {
279
302
  setInitialLineHeight(textareaRef.current);
303
+ setIsMultiline(false);
280
304
  } else {
281
305
  setAutoHeight(textareaRef.current);
306
+ checkIfMultiline(textareaRef.current);
282
307
  }
283
308
  }
284
309
  setMessage(event.target.value);
285
310
  },
286
- [onChange]
311
+ [onChange, checkIfMultiline]
287
312
  );
288
313
 
289
314
  // Handle sending message
@@ -446,7 +471,7 @@ export const MessageBarBase: FunctionComponent<MessageBarProps> = ({
446
471
  return (
447
472
  <AttachMenu
448
473
  toggle={(toggleRef) => (
449
- <div ref={toggleRef} className={`pf-chatbot__message-bar ${className ?? ''}`}>
474
+ <div ref={toggleRef} className={css('pf-chatbot__message-bar', isMultiline && 'pf-m-multiline', className)}>
450
475
  {messageBarContents}
451
476
  </div>
452
477
  )}
@@ -468,7 +493,16 @@ export const MessageBarBase: FunctionComponent<MessageBarProps> = ({
468
493
  }
469
494
 
470
495
  return (
471
- <div className={`pf-chatbot__message-bar ${isPrimary ? 'pf-m-primary' : ''} ${className ?? ''}`}>
496
+ <div
497
+ className={css(
498
+ 'pf-chatbot__message-bar',
499
+ isPrimary && 'pf-m-primary',
500
+ hasAiIndicator && 'pf-v6-m-ai-indicator',
501
+ isThinking && 'pf-v6-m-thinking',
502
+ isMultiline && 'pf-m-multiline',
503
+ className
504
+ )}
505
+ >
472
506
  {messageBarContents}
473
507
  </div>
474
508
  );
@@ -53,6 +53,5 @@
53
53
  .pf-v6-c-button.pf-chatbot__button--microphone.pf-m-compact {
54
54
  width: 1.5rem;
55
55
  height: 1.5rem;
56
- padding: var(--pf-t--global--spacer--sm);
57
56
  align-items: center;
58
57
  }
@@ -58,6 +58,5 @@
58
58
  .pf-v6-c-button.pf-chatbot__button--send.pf-m-compact {
59
59
  width: 1.5rem;
60
60
  height: 1.5rem;
61
- padding: var(--pf-t--global--spacer--sm);
62
61
  align-items: center;
63
62
  }
@@ -41,6 +41,5 @@
41
41
  .pf-v6-c-button.pf-chatbot__button--stop.pf-m-compact {
42
42
  width: 1.5rem;
43
43
  height: 1.5rem;
44
- padding: var(--pf-t--global--spacer--sm);
45
44
  align-items: center;
46
45
  }
@@ -0,0 +1,101 @@
1
+ .pf-chatbot__onboarding-modal {
2
+ overflow-x: hidden;
3
+
4
+ .pf-chatbot__onboarding--title {
5
+ margin-block-end: var(--pf-t--global--spacer--md);
6
+ }
7
+
8
+ .pf-chatbot__onboarding--section {
9
+ display: flex;
10
+ flex-direction: column;
11
+ width: 100%;
12
+ height: 100%;
13
+ }
14
+
15
+ .pf-chatbot__onboarding--modal-body {
16
+ display: flex;
17
+ flex-direction: column;
18
+ }
19
+
20
+ .pf-chatbot__onboarding--modal-text {
21
+ display: flex;
22
+ flex-direction: column;
23
+ justify-content: flex-end;
24
+ }
25
+
26
+ .pf-v6-c-content {
27
+ font-size: var(--pf-t--global--font--size--body--lg);
28
+ }
29
+
30
+ .pf-chatbot__onboarding--header {
31
+ display: flex;
32
+ align-items: center;
33
+ justify-content: center;
34
+ flex-direction: column;
35
+ max-height: 65%;
36
+
37
+ img {
38
+ max-width: unset;
39
+ height: 100%;
40
+ }
41
+ }
42
+
43
+ .pf-chatbot__onboarding--title {
44
+ font-size: var(--pf-t--global--font--size--heading--h1);
45
+ font-family: var(--pf-t--global--font--family--heading);
46
+ font-weight: var(--pf-t--global--font--weight--heading--bold);
47
+ }
48
+
49
+ .pf-chatbot__onboarding--footer {
50
+ margin-block-start: var(--pf-t--global--spacer--md);
51
+ }
52
+
53
+ // for handling zoom conditions; zoom to 125% or higher to see this
54
+ @media screen and (max-height: 620px) {
55
+ .pf-v6-c-modal-box__body {
56
+ --pf-v6-c-modal-box__body--MinHeight: auto;
57
+ overflow: visible;
58
+ }
59
+ }
60
+ }
61
+
62
+ .pf-chatbot__chatbot-modal.pf-chatbot__chatbot-modal--docked.pf-chatbot__onboarding-modal.pf-chatbot__onboarding-modal--docked,
63
+ .pf-chatbot__chatbot-modal.pf-chatbot__chatbot-modal--fullscreen.pf-chatbot__onboarding-modal.pf-chatbot__onboarding-modal--fullscreen,
64
+ .pf-chatbot__chatbot-modal.pf-chatbot__chatbot-modal--embedded.pf-chatbot__onboarding-modal.pf-chatbot__onboarding-modal--embedded {
65
+ .pf-chatbot__onboarding--header {
66
+ img {
67
+ max-width: 100%;
68
+ height: auto;
69
+ }
70
+ }
71
+ }
72
+
73
+ .pf-chatbot__chatbot-modal.pf-chatbot__chatbot-modal--fullscreen.pf-chatbot__onboarding-modal.pf-chatbot__onboarding-modal--fullscreen,
74
+ .pf-chatbot__chatbot-modal.pf-chatbot__chatbot-modal--embedded.pf-chatbot__onboarding-modal.pf-chatbot__onboarding-modal--embedded {
75
+ // override parent modal style
76
+ height: inherit !important;
77
+
78
+ .pf-chatbot__onboarding--title {
79
+ font-size: var(--pf-t--global--font--size--heading--2xl);
80
+ }
81
+ }
82
+
83
+ .pf-chatbot__onboarding-modal.pf-m-compact {
84
+ .pf-chatbot__onboarding--header {
85
+ gap: var(--pf-t--global--spacer--md);
86
+ align-items: flex-start;
87
+ margin-block-start: var(--pf-t--global--spacer--lg);
88
+ }
89
+
90
+ .pf-chatbot__onboarding--modal-header {
91
+ --pf-v6-c-modal-box__header--PaddingBlockStart: var(--pf-t--global--spacer--md);
92
+ --pf-v6-c-modal-box__header--PaddingBlockEnd: var(--pf-t--global--spacer--md);
93
+ --pf-v6-c-modal-box__header--PaddingInlineStart: var(--pf-t--global--spacer--md);
94
+ --pf-v6-c-modal-box__header--PaddingInlineEnd: var(--pf-t--global--spacer--md);
95
+ }
96
+
97
+ .pf-chatbot__onboarding--modal-body {
98
+ --pf-v6-c-modal-box__body--PaddingInlineStart: var(--pf-t--global--spacer--md);
99
+ --pf-v6-c-modal-box__body--PaddingInlineEnd: var(--pf-t--global--spacer--md);
100
+ }
101
+ }
@@ -0,0 +1,148 @@
1
+ import { render, screen } from '@testing-library/react';
2
+ import '@testing-library/jest-dom';
3
+ import userEvent from '@testing-library/user-event';
4
+ import Onboarding from './Onboarding';
5
+
6
+ const handleModalToggle = jest.fn();
7
+ const onPrimaryAction = jest.fn();
8
+ const onSecondaryAction = jest.fn();
9
+
10
+ const body =
11
+ 'Experience personalized assistance and seamless problem-solving, simplifying your journey with Red Hat every step of the way.';
12
+
13
+ describe('Onboarding', () => {
14
+ afterEach(() => {
15
+ jest.clearAllMocks();
16
+ });
17
+ it('should render modal correctly', () => {
18
+ render(
19
+ <Onboarding
20
+ isModalOpen
21
+ onSecondaryAction={onSecondaryAction}
22
+ handleModalToggle={handleModalToggle}
23
+ ouiaId="Terms"
24
+ >
25
+ {body}
26
+ </Onboarding>
27
+ );
28
+ expect(screen.getByRole('heading', { name: /Onboarding/i })).toBeTruthy();
29
+ expect(screen.getByRole('button', { name: /Continue/i })).toBeTruthy();
30
+ expect(screen.getByRole('button', { name: /Skip/i })).toBeTruthy();
31
+ expect(screen.getByText(body)).toBeTruthy();
32
+ expect(screen.getByRole('dialog')).toHaveClass('pf-chatbot__onboarding-modal');
33
+ expect(screen.getByRole('dialog')).toHaveClass('pf-chatbot__onboarding-modal--default');
34
+ });
35
+ it('should handle image and altText props', () => {
36
+ render(
37
+ <Onboarding
38
+ isModalOpen
39
+ onSecondaryAction={onSecondaryAction}
40
+ handleModalToggle={handleModalToggle}
41
+ headerImage="./image.png"
42
+ headerImageAltText="Test image"
43
+ >
44
+ {body}
45
+ </Onboarding>
46
+ );
47
+ expect(screen.getByRole('img')).toBeTruthy();
48
+ expect(screen.getByRole('img')).toHaveAttribute('alt', 'Test image');
49
+ });
50
+ it('should handle className prop', () => {
51
+ render(
52
+ <Onboarding
53
+ isModalOpen
54
+ onSecondaryAction={onSecondaryAction}
55
+ handleModalToggle={handleModalToggle}
56
+ className="test"
57
+ >
58
+ {body}
59
+ </Onboarding>
60
+ );
61
+ expect(screen.getByRole('dialog')).toHaveClass('pf-chatbot__onboarding-modal');
62
+ expect(screen.getByRole('dialog')).toHaveClass('pf-chatbot__onboarding-modal--default');
63
+ expect(screen.getByRole('dialog')).toHaveClass('test');
64
+ });
65
+ it('should handle title prop', () => {
66
+ render(
67
+ <Onboarding
68
+ isModalOpen
69
+ onSecondaryAction={onSecondaryAction}
70
+ handleModalToggle={handleModalToggle}
71
+ title="Updated title"
72
+ >
73
+ {body}
74
+ </Onboarding>
75
+ );
76
+ expect(screen.getByRole('heading', { name: /Updated title/i })).toBeTruthy();
77
+ expect(screen.queryByRole('heading', { name: /Onboarding/i })).toBeFalsy();
78
+ });
79
+ it('should handle primary button prop', () => {
80
+ render(
81
+ <Onboarding
82
+ isModalOpen
83
+ onSecondaryAction={onSecondaryAction}
84
+ handleModalToggle={handleModalToggle}
85
+ primaryActionBtn="First"
86
+ >
87
+ {body}
88
+ </Onboarding>
89
+ );
90
+ expect(screen.getByRole('button', { name: /First/i })).toBeTruthy();
91
+ expect(screen.queryByRole('button', { name: /Continue/i })).toBeFalsy();
92
+ });
93
+ it('should handle secondary button prop', () => {
94
+ render(
95
+ <Onboarding
96
+ isModalOpen
97
+ onSecondaryAction={onSecondaryAction}
98
+ handleModalToggle={handleModalToggle}
99
+ secondaryActionBtn="Second"
100
+ >
101
+ {body}
102
+ </Onboarding>
103
+ );
104
+ expect(screen.getByRole('button', { name: /Second/i })).toBeTruthy();
105
+ expect(screen.queryByRole('button', { name: /Skip/i })).toBeFalsy();
106
+ });
107
+ it('should handle primary button click', async () => {
108
+ render(
109
+ <Onboarding
110
+ isModalOpen
111
+ onPrimaryAction={onPrimaryAction}
112
+ onSecondaryAction={onSecondaryAction}
113
+ handleModalToggle={handleModalToggle}
114
+ >
115
+ {body}
116
+ </Onboarding>
117
+ );
118
+ await userEvent.click(screen.getByRole('button', { name: /Continue/i }));
119
+ expect(onPrimaryAction).toHaveBeenCalledTimes(1);
120
+ expect(handleModalToggle).toHaveBeenCalledTimes(1);
121
+ });
122
+ it('should handle secondary button click', async () => {
123
+ render(
124
+ <Onboarding isModalOpen onSecondaryAction={onSecondaryAction} handleModalToggle={handleModalToggle}>
125
+ {body}
126
+ </Onboarding>
127
+ );
128
+ await userEvent.click(screen.getByRole('button', { name: /Skip/i }));
129
+ expect(onSecondaryAction).toHaveBeenCalledTimes(1);
130
+ expect(handleModalToggle).not.toHaveBeenCalled();
131
+ });
132
+ it('should handle isCompact prop', () => {
133
+ render(
134
+ <Onboarding
135
+ isModalOpen
136
+ onSecondaryAction={onSecondaryAction}
137
+ handleModalToggle={handleModalToggle}
138
+ isCompact={true}
139
+ headerImage="./image.png"
140
+ headerImageAltText="Test image"
141
+ >
142
+ {body}
143
+ </Onboarding>
144
+ );
145
+ expect(screen.getByRole('dialog')).toHaveClass('pf-m-compact');
146
+ expect(screen.queryByRole('img')).toBeFalsy();
147
+ });
148
+ });
@@ -0,0 +1,126 @@
1
+ // ============================================================================
2
+ // Terms of Use Modal - Chatbot Modal Extension
3
+ // ============================================================================
4
+ import type { FunctionComponent, MouseEvent as ReactMouseEvent, Ref } from 'react';
5
+ import { forwardRef } from 'react';
6
+ import { Button, Content, ModalBody, ModalFooter, ModalProps } from '@patternfly/react-core';
7
+ import { ChatbotDisplayMode } from '../Chatbot';
8
+ import ChatbotModal from '../ChatbotModal/ChatbotModal';
9
+
10
+ export interface OnboardingProps extends ModalProps {
11
+ /** Class applied to modal */
12
+ className?: string;
13
+ /** Action assigned to primary modal button */
14
+ onPrimaryAction?: (event: React.MouseEvent | MouseEvent | KeyboardEvent) => void;
15
+ /** Action assigned to secondary modal button */
16
+ onSecondaryAction: (event: React.MouseEvent | MouseEvent | KeyboardEvent) => void;
17
+ /** Name of primary modal button */
18
+ primaryActionBtn?: string;
19
+ /** Name of secondary modal button */
20
+ secondaryActionBtn?: string;
21
+ /** Function that handles modal toggle */
22
+ handleModalToggle: (event: React.MouseEvent | MouseEvent | KeyboardEvent) => void;
23
+ /** Whether modal is open */
24
+ isModalOpen: boolean;
25
+ /** Title of modal */
26
+ title?: string;
27
+ /** Display mode for the Chatbot parent; this influences the styles applied */
28
+ displayMode?: ChatbotDisplayMode;
29
+ /** Optional image displayed in header */
30
+ headerImage?: string;
31
+ /** Alt text for optional image displayed in header */
32
+ headerImageAltText?: string;
33
+ /** Ref applied to modal */
34
+ innerRef?: React.Ref<HTMLDivElement>;
35
+ /** OuiaID applied to modal */
36
+ ouiaId?: string;
37
+ /** Sets modal to compact styling. */
38
+ isCompact?: boolean;
39
+ }
40
+
41
+ export const OnboardingBase: FunctionComponent<OnboardingProps> = ({
42
+ handleModalToggle,
43
+ isModalOpen,
44
+ onPrimaryAction,
45
+ onSecondaryAction,
46
+ primaryActionBtn = 'Continue',
47
+ secondaryActionBtn = 'Skip',
48
+ title = 'Onboarding',
49
+ headerImage,
50
+ headerImageAltText = '',
51
+ displayMode = ChatbotDisplayMode.default,
52
+ className,
53
+ children,
54
+ innerRef,
55
+ ouiaId = 'Onboarding',
56
+ isCompact,
57
+ ...props
58
+ }: OnboardingProps) => {
59
+ const handlePrimaryAction = (_event: ReactMouseEvent | MouseEvent | KeyboardEvent) => {
60
+ handleModalToggle(_event);
61
+ onPrimaryAction && onPrimaryAction(_event);
62
+ };
63
+
64
+ const handleSecondaryAction = (_event: ReactMouseEvent | MouseEvent | KeyboardEvent) => {
65
+ onSecondaryAction(_event);
66
+ };
67
+
68
+ const modal = (
69
+ <ChatbotModal
70
+ isOpen={isModalOpen}
71
+ ouiaId={ouiaId}
72
+ aria-labelledby="onboarding-title"
73
+ aria-describedby="onboarding-modal"
74
+ className={`pf-chatbot__onboarding-modal pf-chatbot__onboarding-modal--${displayMode} ${isCompact ? 'pf-m-compact' : ''} ${className ? className : ''}`}
75
+ displayMode={displayMode}
76
+ onClose={handleModalToggle}
77
+ {...props}
78
+ >
79
+ {/* This is a workaround since the PatternFly modal doesn't have ref forwarding */}
80
+ <section className={`pf-chatbot__onboarding--section`} aria-label={title} tabIndex={-1} ref={innerRef}>
81
+ <>
82
+ <ModalBody className="pf-chatbot__onboarding--modal-body">
83
+ {!isCompact && headerImage && (
84
+ <div className="pf-chatbot__onboarding--header">
85
+ <img src={headerImage} className="pf-chatbot__onboarding--image" alt={headerImageAltText} />
86
+ </div>
87
+ )}
88
+ <div className="pf-chatbot__onboarding--modal-text">
89
+ <h1 className="pf-chatbot__onboarding--title">{title}</h1>
90
+ <Content>{children}</Content>
91
+ </div>
92
+ </ModalBody>
93
+ <ModalFooter className="pf-chatbot__onboarding--footer">
94
+ <Button
95
+ isBlock
96
+ key="onboarding-modal-primary"
97
+ variant="primary"
98
+ onClick={handlePrimaryAction}
99
+ form="onboarding-form"
100
+ size="lg"
101
+ >
102
+ {primaryActionBtn}
103
+ </Button>
104
+ <Button
105
+ isBlock
106
+ key="onboarding-modal-secondary"
107
+ variant="secondary"
108
+ onClick={handleSecondaryAction}
109
+ size="lg"
110
+ >
111
+ {secondaryActionBtn}
112
+ </Button>
113
+ </ModalFooter>
114
+ </>
115
+ </section>
116
+ </ChatbotModal>
117
+ );
118
+
119
+ return modal;
120
+ };
121
+
122
+ const Onboarding = forwardRef((props: OnboardingProps, ref: Ref<HTMLDivElement>) => (
123
+ <OnboardingBase innerRef={ref} {...props} />
124
+ ));
125
+
126
+ export default Onboarding;
@@ -0,0 +1,3 @@
1
+ export { default } from './Onboarding';
2
+
3
+ export * from './Onboarding';
@@ -16,12 +16,23 @@
16
16
  --pf-v6-c-button__icon--Color: var(--pf-t--global--icon--color--subtle);
17
17
  }
18
18
  &:focus {
19
- --pf-v6-c-button--hover--BackgroundColor: var(--pf-t--global--background--color--action--plain--alt--clicked);
20
19
  --pf-v6-c-button__icon--Color: var(--pf-t--global--icon--color--regular);
20
+ --pf-v6-c-button--BackgroundColor: var(--pf-v6-c-button--hover--BackgroundColor);
21
21
  }
22
22
  }
23
23
  }
24
24
 
25
+ .pf-chatbot__response-actions-groups {
26
+ display: grid;
27
+ grid-auto-flow: column;
28
+ grid-auto-columns: max-content;
29
+ gap: var(--pf-t--global--spacer--xs);
30
+
31
+ .pf-chatbot__response-actions {
32
+ display: flex;
33
+ }
34
+ }
35
+
25
36
  .pf-v6-c-button.pf-chatbot__button--response-action-clicked.pf-v6-c-button.pf-m-plain.pf-m-small {
26
37
  --pf-v6-c-button--m-plain--BackgroundColor: var(--pf-t--global--background--color--action--plain--alt--clicked);
27
38
  --pf-v6-c-button__icon--Color: var(--pf-t--global--icon--color--regular);