@patternfly/chatbot 2.2.0-prerelease.8 → 2.2.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.
- package/dist/cjs/AttachmentEdit/AttachmentEdit.test.d.ts +1 -0
- package/dist/cjs/AttachmentEdit/AttachmentEdit.test.js +52 -0
- package/dist/cjs/Chatbot/Chatbot.d.ts +2 -1
- package/dist/cjs/Chatbot/Chatbot.js +1 -0
- package/dist/cjs/Chatbot/Chatbot.test.d.ts +1 -0
- package/dist/cjs/Chatbot/Chatbot.test.js +28 -0
- package/dist/cjs/ChatbotAlert/ChatbotAlert.test.d.ts +1 -0
- package/dist/cjs/ChatbotAlert/ChatbotAlert.test.js +27 -0
- package/dist/cjs/ChatbotContent/ChatbotContent.test.d.ts +1 -0
- package/dist/cjs/ChatbotContent/ChatbotContent.test.js +18 -0
- package/dist/cjs/ChatbotConversationHistoryNav/ChatbotConversationHistoryDropdown.d.ts +3 -3
- package/dist/cjs/ChatbotConversationHistoryNav/ChatbotConversationHistoryDropdown.js +3 -1
- package/dist/cjs/ChatbotConversationHistoryNav/ChatbotConversationHistoryNav.d.ts +27 -4
- package/dist/cjs/ChatbotConversationHistoryNav/ChatbotConversationHistoryNav.js +24 -12
- package/dist/cjs/ChatbotConversationHistoryNav/ChatbotConversationHistoryNav.test.js +99 -3
- package/dist/cjs/ChatbotConversationHistoryNav/EmptyState.d.ts +11 -0
- package/dist/cjs/ChatbotConversationHistoryNav/EmptyState.js +29 -0
- package/dist/cjs/ChatbotConversationHistoryNav/LoadingState.d.ts +4 -0
- package/dist/cjs/ChatbotConversationHistoryNav/LoadingState.js +45 -0
- package/dist/cjs/ChatbotFooter/ChatbotFooter.test.d.ts +1 -0
- package/dist/cjs/ChatbotFooter/ChatbotFooter.test.js +18 -0
- package/dist/cjs/ChatbotFooter/ChatbotFooternote.test.d.ts +1 -0
- package/dist/cjs/ChatbotFooter/ChatbotFooternote.test.js +87 -0
- package/dist/cjs/ChatbotFooter/ChatbotFootnote.d.ts +1 -1
- package/dist/cjs/ChatbotFooter/ChatbotFootnote.js +1 -1
- package/dist/cjs/ChatbotHeader/ChatbotHeader.test.d.ts +1 -0
- package/dist/cjs/ChatbotHeader/ChatbotHeader.test.js +18 -0
- package/dist/cjs/ChatbotHeader/ChatbotHeaderActions.test.d.ts +1 -0
- package/dist/cjs/ChatbotHeader/ChatbotHeaderActions.test.js +18 -0
- package/dist/cjs/ChatbotHeader/ChatbotHeaderCloseButton.js +3 -1
- package/dist/cjs/ChatbotHeader/ChatbotHeaderCloseButton.test.d.ts +1 -0
- package/dist/cjs/ChatbotHeader/ChatbotHeaderCloseButton.test.js +20 -0
- package/dist/cjs/ChatbotHeader/ChatbotHeaderMain.test.d.ts +1 -0
- package/dist/cjs/ChatbotHeader/ChatbotHeaderMain.test.js +18 -0
- package/dist/cjs/ChatbotHeader/ChatbotHeaderMenu.js +3 -1
- package/dist/cjs/ChatbotHeader/ChatbotHeaderMenu.test.d.ts +1 -0
- package/dist/cjs/ChatbotHeader/ChatbotHeaderMenu.test.js +20 -0
- package/dist/cjs/ChatbotHeader/ChatbotHeaderOptionsDropdown.js +3 -1
- package/dist/cjs/ChatbotHeader/ChatbotHeaderOptionsDropdown.test.d.ts +1 -0
- package/dist/cjs/ChatbotHeader/ChatbotHeaderOptionsDropdown.test.js +43 -0
- package/dist/cjs/ChatbotHeader/ChatbotHeaderSelectorDropdown.js +6 -4
- package/dist/cjs/ChatbotHeader/ChatbotHeaderSelectorDropdown.test.d.ts +1 -0
- package/dist/cjs/ChatbotHeader/ChatbotHeaderSelectorDropdown.test.js +41 -0
- package/dist/cjs/ChatbotHeader/ChatbotHeaderTitle.d.ts +3 -1
- package/dist/cjs/ChatbotHeader/ChatbotHeaderTitle.js +4 -2
- package/dist/cjs/ChatbotHeader/ChatbotHeaderTitle.test.d.ts +1 -0
- package/dist/cjs/ChatbotHeader/ChatbotHeaderTitle.test.js +55 -0
- package/dist/cjs/ChatbotToggle/ChatbotToggle.js +3 -1
- package/dist/cjs/ChatbotWelcomePrompt/ChatbotWelcomePrompt.test.js +19 -11
- package/dist/cjs/Compare/Compare.d.ts +17 -0
- package/dist/cjs/Compare/Compare.js +50 -0
- package/dist/cjs/Compare/Compare.test.d.ts +1 -0
- package/dist/cjs/Compare/Compare.test.js +20 -0
- package/dist/cjs/Compare/index.d.ts +2 -0
- package/dist/cjs/Compare/index.js +23 -0
- package/dist/cjs/Message/ErrorMessage/ErrorMessage.d.ts +4 -0
- package/dist/cjs/Message/ErrorMessage/ErrorMessage.js +26 -0
- package/dist/cjs/Message/ImageMessage/ImageMessage.d.ts +4 -0
- package/dist/cjs/Message/ImageMessage/ImageMessage.js +25 -0
- package/dist/cjs/Message/LinkMessage/LinkMessage.d.ts +4 -0
- package/dist/cjs/Message/LinkMessage/LinkMessage.js +30 -0
- package/dist/cjs/Message/Message.d.ts +49 -8
- package/dist/cjs/Message/Message.js +70 -18
- package/dist/cjs/Message/Message.test.js +269 -3
- package/dist/cjs/Message/QuickResponse/QuickResponse.d.ts +17 -0
- package/dist/cjs/Message/QuickResponse/QuickResponse.js +34 -0
- package/dist/cjs/Message/QuickStarts/FallbackImg.d.ts +13 -0
- package/dist/cjs/Message/QuickStarts/FallbackImg.js +34 -0
- package/dist/cjs/Message/QuickStarts/QuickStartTile.d.ts +27 -0
- package/dist/cjs/Message/QuickStarts/QuickStartTile.js +82 -0
- package/dist/cjs/Message/QuickStarts/QuickStartTileDescription.d.ts +23 -0
- package/dist/cjs/Message/QuickStarts/QuickStartTileDescription.js +64 -0
- package/dist/cjs/Message/QuickStarts/QuickStartTileDescription.test.d.ts +1 -0
- package/dist/cjs/Message/QuickStarts/QuickStartTileDescription.test.js +76 -0
- package/dist/cjs/Message/QuickStarts/QuickStartTileHeader.d.ts +11 -0
- package/dist/cjs/Message/QuickStarts/QuickStartTileHeader.js +30 -0
- package/dist/cjs/Message/QuickStarts/monitor-sampleapp-quickstart-with-image.d.ts +30 -0
- package/dist/cjs/Message/QuickStarts/monitor-sampleapp-quickstart-with-image.js +77 -0
- package/dist/cjs/Message/QuickStarts/monitor-sampleapp-quickstart.d.ts +30 -0
- package/dist/cjs/Message/QuickStarts/monitor-sampleapp-quickstart.js +77 -0
- package/dist/cjs/Message/QuickStarts/types.d.ts +132 -0
- package/dist/cjs/Message/QuickStarts/types.js +17 -0
- package/dist/cjs/Message/TableMessage/TableMessage.d.ts +20 -0
- package/dist/cjs/Message/TableMessage/TableMessage.js +67 -0
- package/dist/cjs/Message/TableMessage/TbodyMessage.d.ts +7 -0
- package/dist/cjs/Message/TableMessage/TbodyMessage.js +33 -0
- package/dist/cjs/Message/TableMessage/TdMessage.d.ts +5 -0
- package/dist/cjs/Message/TableMessage/TdMessage.js +26 -0
- package/dist/cjs/Message/TableMessage/ThMessage.d.ts +5 -0
- package/dist/cjs/Message/TableMessage/ThMessage.js +26 -0
- package/dist/cjs/Message/TableMessage/TheadMessage.d.ts +5 -0
- package/dist/cjs/Message/TableMessage/TheadMessage.js +26 -0
- package/dist/cjs/Message/TableMessage/TrMessage.d.ts +7 -0
- package/dist/cjs/Message/TableMessage/TrMessage.js +37 -0
- package/dist/cjs/Message/TextMessage/TextMessage.d.ts +2 -1
- package/dist/cjs/Message/TextMessage/TextMessage.js +2 -2
- package/dist/cjs/Message/UserFeedback/CloseButton.d.ts +10 -0
- package/dist/cjs/Message/UserFeedback/CloseButton.js +14 -0
- package/dist/cjs/Message/UserFeedback/UserFeedback.d.ts +39 -0
- package/dist/cjs/Message/UserFeedback/UserFeedback.js +54 -0
- package/dist/cjs/Message/UserFeedback/UserFeedback.test.d.ts +1 -0
- package/dist/cjs/Message/UserFeedback/UserFeedback.test.js +133 -0
- package/dist/cjs/Message/UserFeedback/UserFeedbackComplete.d.ts +42 -0
- package/dist/cjs/Message/UserFeedback/UserFeedbackComplete.js +117 -0
- package/dist/cjs/Message/UserFeedback/UserFeedbackComplete.test.d.ts +1 -0
- package/dist/cjs/Message/UserFeedback/UserFeedbackComplete.test.js +249 -0
- package/dist/cjs/MessageBar/AttachButton.js +4 -2
- package/dist/cjs/MessageBar/MessageBar.d.ts +11 -4
- package/dist/cjs/MessageBar/MessageBar.js +127 -46
- package/dist/cjs/MessageBar/MessageBar.test.js +12 -4
- package/dist/cjs/MessageBar/MicrophoneButton.d.ts +1 -1
- package/dist/cjs/MessageBar/SendButton.js +3 -1
- package/dist/cjs/MessageBar/StopButton.js +3 -1
- package/dist/cjs/MessageBox/MessageBox.test.d.ts +1 -0
- package/dist/cjs/MessageBox/MessageBox.test.js +22 -0
- package/dist/cjs/PreviewAttachment/PreviewAttachment.test.d.ts +1 -0
- package/dist/cjs/PreviewAttachment/PreviewAttachment.test.js +28 -0
- package/dist/cjs/ResponseActions/ResponseActionButton.d.ts +4 -1
- package/dist/cjs/ResponseActions/ResponseActionButton.js +21 -6
- package/dist/cjs/ResponseActions/ResponseActions.d.ts +8 -2
- package/dist/cjs/ResponseActions/ResponseActions.js +7 -7
- package/dist/cjs/ResponseActions/ResponseActions.test.js +2 -2
- package/dist/cjs/Settings/SettingsForm.test.d.ts +1 -0
- package/dist/cjs/Settings/SettingsForm.test.js +26 -0
- package/dist/cjs/__mocks__/rehype-external-links.d.ts +2 -0
- package/dist/cjs/__mocks__/rehype-external-links.js +4 -0
- package/dist/cjs/__mocks__/rehype-sanitize.d.ts +2 -0
- package/dist/cjs/__mocks__/rehype-sanitize.js +4 -0
- package/dist/cjs/__mocks__/rehype-unwrap-images.d.ts +2 -0
- package/dist/cjs/__mocks__/rehype-unwrap-images.js +4 -0
- package/dist/cjs/index.d.ts +4 -0
- package/dist/cjs/index.js +7 -1
- package/dist/cjs/tracking/console_tracking_provider.d.ts +10 -0
- package/dist/cjs/tracking/console_tracking_provider.js +27 -0
- package/dist/cjs/tracking/index.d.ts +2 -0
- package/dist/cjs/tracking/index.js +23 -0
- package/dist/cjs/tracking/posthog_tracking_provider.d.ts +9 -0
- package/dist/cjs/tracking/posthog_tracking_provider.js +37 -0
- package/dist/cjs/tracking/segment_tracking_provider.d.ts +10 -0
- package/dist/cjs/tracking/segment_tracking_provider.js +50 -0
- package/dist/cjs/tracking/trackingProviderProxy.d.ts +9 -0
- package/dist/cjs/tracking/trackingProviderProxy.js +24 -0
- package/dist/cjs/tracking/tracking_api.d.ts +8 -0
- package/dist/cjs/tracking/tracking_api.js +2 -0
- package/dist/cjs/tracking/tracking_registry.d.ts +4 -0
- package/dist/cjs/tracking/tracking_registry.js +33 -0
- package/dist/cjs/tracking/tracking_spi.d.ts +9 -0
- package/dist/cjs/tracking/tracking_spi.js +2 -0
- package/dist/cjs/tracking/umami_tracking_provider.d.ts +14 -0
- package/dist/cjs/tracking/umami_tracking_provider.js +44 -0
- package/dist/css/main.css +438 -147
- package/dist/css/main.css.map +1 -1
- package/dist/dynamic/Compare/package.json +1 -0
- package/dist/dynamic/tracking/package.json +1 -0
- package/dist/esm/AttachmentEdit/AttachmentEdit.test.d.ts +1 -0
- package/dist/esm/AttachmentEdit/AttachmentEdit.test.js +47 -0
- package/dist/esm/Chatbot/Chatbot.d.ts +2 -1
- package/dist/esm/Chatbot/Chatbot.js +1 -0
- package/dist/esm/Chatbot/Chatbot.test.d.ts +1 -0
- package/dist/esm/Chatbot/Chatbot.test.js +23 -0
- package/dist/esm/ChatbotAlert/ChatbotAlert.test.d.ts +1 -0
- package/dist/esm/ChatbotAlert/ChatbotAlert.test.js +22 -0
- package/dist/esm/ChatbotContent/ChatbotContent.test.d.ts +1 -0
- package/dist/esm/ChatbotContent/ChatbotContent.test.js +13 -0
- package/dist/esm/ChatbotConversationHistoryNav/ChatbotConversationHistoryDropdown.d.ts +3 -3
- package/dist/esm/ChatbotConversationHistoryNav/ChatbotConversationHistoryDropdown.js +3 -1
- package/dist/esm/ChatbotConversationHistoryNav/ChatbotConversationHistoryNav.d.ts +27 -4
- package/dist/esm/ChatbotConversationHistoryNav/ChatbotConversationHistoryNav.js +24 -12
- package/dist/esm/ChatbotConversationHistoryNav/ChatbotConversationHistoryNav.test.js +99 -3
- package/dist/esm/ChatbotConversationHistoryNav/EmptyState.d.ts +11 -0
- package/dist/esm/ChatbotConversationHistoryNav/EmptyState.js +22 -0
- package/dist/esm/ChatbotConversationHistoryNav/LoadingState.d.ts +4 -0
- package/dist/esm/ChatbotConversationHistoryNav/LoadingState.js +38 -0
- package/dist/esm/ChatbotFooter/ChatbotFooter.test.d.ts +1 -0
- package/dist/esm/ChatbotFooter/ChatbotFooter.test.js +13 -0
- package/dist/esm/ChatbotFooter/ChatbotFooternote.test.d.ts +1 -0
- package/dist/esm/ChatbotFooter/ChatbotFooternote.test.js +82 -0
- package/dist/esm/ChatbotFooter/ChatbotFootnote.d.ts +1 -1
- package/dist/esm/ChatbotFooter/ChatbotFootnote.js +1 -1
- package/dist/esm/ChatbotHeader/ChatbotHeader.test.d.ts +1 -0
- package/dist/esm/ChatbotHeader/ChatbotHeader.test.js +13 -0
- package/dist/esm/ChatbotHeader/ChatbotHeaderActions.test.d.ts +1 -0
- package/dist/esm/ChatbotHeader/ChatbotHeaderActions.test.js +13 -0
- package/dist/esm/ChatbotHeader/ChatbotHeaderCloseButton.js +3 -1
- package/dist/esm/ChatbotHeader/ChatbotHeaderCloseButton.test.d.ts +1 -0
- package/dist/esm/ChatbotHeader/ChatbotHeaderCloseButton.test.js +15 -0
- package/dist/esm/ChatbotHeader/ChatbotHeaderMain.test.d.ts +1 -0
- package/dist/esm/ChatbotHeader/ChatbotHeaderMain.test.js +13 -0
- package/dist/esm/ChatbotHeader/ChatbotHeaderMenu.js +3 -1
- package/dist/esm/ChatbotHeader/ChatbotHeaderMenu.test.d.ts +1 -0
- package/dist/esm/ChatbotHeader/ChatbotHeaderMenu.test.js +15 -0
- package/dist/esm/ChatbotHeader/ChatbotHeaderOptionsDropdown.js +3 -1
- package/dist/esm/ChatbotHeader/ChatbotHeaderOptionsDropdown.test.d.ts +1 -0
- package/dist/esm/ChatbotHeader/ChatbotHeaderOptionsDropdown.test.js +38 -0
- package/dist/esm/ChatbotHeader/ChatbotHeaderSelectorDropdown.js +6 -4
- package/dist/esm/ChatbotHeader/ChatbotHeaderSelectorDropdown.test.d.ts +1 -0
- package/dist/esm/ChatbotHeader/ChatbotHeaderSelectorDropdown.test.js +36 -0
- package/dist/esm/ChatbotHeader/ChatbotHeaderTitle.d.ts +3 -1
- package/dist/esm/ChatbotHeader/ChatbotHeaderTitle.js +4 -2
- package/dist/esm/ChatbotHeader/ChatbotHeaderTitle.test.d.ts +1 -0
- package/dist/esm/ChatbotHeader/ChatbotHeaderTitle.test.js +50 -0
- package/dist/esm/ChatbotToggle/ChatbotToggle.js +3 -1
- package/dist/esm/ChatbotWelcomePrompt/ChatbotWelcomePrompt.test.js +19 -11
- package/dist/esm/Compare/Compare.d.ts +17 -0
- package/dist/esm/Compare/Compare.js +43 -0
- package/dist/esm/Compare/Compare.test.d.ts +1 -0
- package/dist/esm/Compare/Compare.test.js +15 -0
- package/dist/esm/Compare/index.d.ts +2 -0
- package/dist/esm/Compare/index.js +2 -0
- package/dist/esm/Message/ErrorMessage/ErrorMessage.d.ts +4 -0
- package/dist/esm/Message/ErrorMessage/ErrorMessage.js +21 -0
- package/dist/esm/Message/ImageMessage/ImageMessage.d.ts +4 -0
- package/dist/esm/Message/ImageMessage/ImageMessage.js +20 -0
- package/dist/esm/Message/LinkMessage/LinkMessage.d.ts +4 -0
- package/dist/esm/Message/LinkMessage/LinkMessage.js +25 -0
- package/dist/esm/Message/Message.d.ts +49 -8
- package/dist/esm/Message/Message.js +68 -16
- package/dist/esm/Message/Message.test.js +269 -3
- package/dist/esm/Message/QuickResponse/QuickResponse.d.ts +17 -0
- package/dist/esm/Message/QuickResponse/QuickResponse.js +27 -0
- package/dist/esm/Message/QuickStarts/FallbackImg.d.ts +13 -0
- package/dist/esm/Message/QuickStarts/FallbackImg.js +9 -0
- package/dist/esm/Message/QuickStarts/QuickStartTile.d.ts +27 -0
- package/dist/esm/Message/QuickStarts/QuickStartTile.js +52 -0
- package/dist/esm/Message/QuickStarts/QuickStartTileDescription.d.ts +23 -0
- package/dist/esm/Message/QuickStarts/QuickStartTileDescription.js +35 -0
- package/dist/esm/Message/QuickStarts/QuickStartTileDescription.test.d.ts +1 -0
- package/dist/esm/Message/QuickStarts/QuickStartTileDescription.test.js +48 -0
- package/dist/esm/Message/QuickStarts/QuickStartTileHeader.d.ts +11 -0
- package/dist/esm/Message/QuickStarts/QuickStartTileHeader.js +5 -0
- package/dist/esm/Message/QuickStarts/monitor-sampleapp-quickstart-with-image.d.ts +30 -0
- package/dist/esm/Message/QuickStarts/monitor-sampleapp-quickstart-with-image.js +74 -0
- package/dist/esm/Message/QuickStarts/monitor-sampleapp-quickstart.d.ts +30 -0
- package/dist/esm/Message/QuickStarts/monitor-sampleapp-quickstart.js +74 -0
- package/dist/esm/Message/QuickStarts/types.d.ts +132 -0
- package/dist/esm/Message/QuickStarts/types.js +14 -0
- package/dist/esm/Message/TableMessage/TableMessage.d.ts +20 -0
- package/dist/esm/Message/TableMessage/TableMessage.js +62 -0
- package/dist/esm/Message/TableMessage/TbodyMessage.d.ts +7 -0
- package/dist/esm/Message/TableMessage/TbodyMessage.js +28 -0
- package/dist/esm/Message/TableMessage/TdMessage.d.ts +5 -0
- package/dist/esm/Message/TableMessage/TdMessage.js +21 -0
- package/dist/esm/Message/TableMessage/ThMessage.d.ts +5 -0
- package/dist/esm/Message/TableMessage/ThMessage.js +21 -0
- package/dist/esm/Message/TableMessage/TheadMessage.d.ts +5 -0
- package/dist/esm/Message/TableMessage/TheadMessage.js +21 -0
- package/dist/esm/Message/TableMessage/TrMessage.d.ts +7 -0
- package/dist/esm/Message/TableMessage/TrMessage.js +32 -0
- package/dist/esm/Message/TextMessage/TextMessage.d.ts +2 -1
- package/dist/esm/Message/TextMessage/TextMessage.js +3 -3
- package/dist/esm/Message/UserFeedback/CloseButton.d.ts +10 -0
- package/dist/esm/Message/UserFeedback/CloseButton.js +9 -0
- package/dist/esm/Message/UserFeedback/UserFeedback.d.ts +39 -0
- package/dist/esm/Message/UserFeedback/UserFeedback.js +49 -0
- package/dist/esm/Message/UserFeedback/UserFeedback.test.d.ts +1 -0
- package/dist/esm/Message/UserFeedback/UserFeedback.test.js +128 -0
- package/dist/esm/Message/UserFeedback/UserFeedbackComplete.d.ts +42 -0
- package/dist/esm/Message/UserFeedback/UserFeedbackComplete.js +112 -0
- package/dist/esm/Message/UserFeedback/UserFeedbackComplete.test.d.ts +1 -0
- package/dist/esm/Message/UserFeedback/UserFeedbackComplete.test.js +244 -0
- package/dist/esm/MessageBar/AttachButton.js +4 -2
- package/dist/esm/MessageBar/MessageBar.d.ts +11 -4
- package/dist/esm/MessageBar/MessageBar.js +127 -46
- package/dist/esm/MessageBar/MessageBar.test.js +12 -4
- package/dist/esm/MessageBar/MicrophoneButton.d.ts +1 -1
- package/dist/esm/MessageBar/SendButton.js +3 -1
- package/dist/esm/MessageBar/StopButton.js +3 -1
- package/dist/esm/MessageBox/MessageBox.test.d.ts +1 -0
- package/dist/esm/MessageBox/MessageBox.test.js +17 -0
- package/dist/esm/PreviewAttachment/PreviewAttachment.test.d.ts +1 -0
- package/dist/esm/PreviewAttachment/PreviewAttachment.test.js +23 -0
- package/dist/esm/ResponseActions/ResponseActionButton.d.ts +4 -1
- package/dist/esm/ResponseActions/ResponseActionButton.js +18 -3
- package/dist/esm/ResponseActions/ResponseActions.d.ts +8 -2
- package/dist/esm/ResponseActions/ResponseActions.js +7 -7
- package/dist/esm/ResponseActions/ResponseActions.test.js +2 -2
- package/dist/esm/Settings/SettingsForm.test.d.ts +1 -0
- package/dist/esm/Settings/SettingsForm.test.js +21 -0
- package/dist/esm/__mocks__/rehype-external-links.d.ts +2 -0
- package/dist/esm/__mocks__/rehype-external-links.js +2 -0
- package/dist/esm/__mocks__/rehype-sanitize.d.ts +2 -0
- package/dist/esm/__mocks__/rehype-sanitize.js +2 -0
- package/dist/esm/__mocks__/rehype-unwrap-images.d.ts +2 -0
- package/dist/esm/__mocks__/rehype-unwrap-images.js +2 -0
- package/dist/esm/index.d.ts +4 -0
- package/dist/esm/index.js +4 -0
- package/dist/esm/tracking/console_tracking_provider.d.ts +10 -0
- package/dist/esm/tracking/console_tracking_provider.js +23 -0
- package/dist/esm/tracking/index.d.ts +2 -0
- package/dist/esm/tracking/index.js +2 -0
- package/dist/esm/tracking/posthog_tracking_provider.d.ts +9 -0
- package/dist/esm/tracking/posthog_tracking_provider.js +33 -0
- package/dist/esm/tracking/segment_tracking_provider.d.ts +10 -0
- package/dist/esm/tracking/segment_tracking_provider.js +46 -0
- package/dist/esm/tracking/trackingProviderProxy.d.ts +9 -0
- package/dist/esm/tracking/trackingProviderProxy.js +22 -0
- package/dist/esm/tracking/tracking_api.d.ts +8 -0
- package/dist/esm/tracking/tracking_api.js +1 -0
- package/dist/esm/tracking/tracking_registry.d.ts +4 -0
- package/dist/esm/tracking/tracking_registry.js +26 -0
- package/dist/esm/tracking/tracking_spi.d.ts +9 -0
- package/dist/esm/tracking/tracking_spi.js +1 -0
- package/dist/esm/tracking/umami_tracking_provider.d.ts +14 -0
- package/dist/esm/tracking/umami_tracking_provider.js +40 -0
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +8 -9
- package/patternfly-docs/content/extensions/chatbot/about-chatbot.md +8 -2
- package/patternfly-docs/content/extensions/chatbot/design-guidelines.md +192 -15
- package/patternfly-docs/content/extensions/chatbot/examples/Analytics/Analytics.md +219 -0
- package/patternfly-docs/content/extensions/chatbot/examples/Messages/AttachmentError.tsx +2 -2
- package/patternfly-docs/content/extensions/chatbot/examples/Messages/BotMessage.tsx +214 -12
- package/patternfly-docs/content/extensions/chatbot/examples/Messages/FileDropZone.tsx +2 -1
- package/patternfly-docs/content/extensions/chatbot/examples/Messages/MessageWithAttachment.tsx +2 -2
- package/patternfly-docs/content/extensions/chatbot/examples/Messages/MessageWithCustomResponseActions.tsx +1 -1
- package/patternfly-docs/content/extensions/chatbot/examples/Messages/MessageWithFeedback.tsx +71 -0
- package/patternfly-docs/content/extensions/chatbot/examples/Messages/MessageWithFeedbackTimeout.tsx +27 -0
- package/patternfly-docs/content/extensions/chatbot/examples/Messages/MessageWithQuickResponses.tsx +1 -1
- package/patternfly-docs/content/extensions/chatbot/examples/Messages/MessageWithQuickStart.tsx +31 -0
- package/patternfly-docs/content/extensions/chatbot/examples/Messages/MessageWithResponseActions.tsx +1 -1
- package/patternfly-docs/content/extensions/chatbot/examples/Messages/MessageWithSources.tsx +1 -1
- package/patternfly-docs/content/extensions/chatbot/examples/Messages/Messages.md +61 -9
- package/patternfly-docs/content/extensions/chatbot/examples/Messages/UserMessage.tsx +244 -14
- package/patternfly-docs/content/extensions/chatbot/examples/Messages/UserMessageWithExtraContent.tsx +54 -0
- package/patternfly-docs/content/extensions/chatbot/examples/Messages/explore-pipeline-quickstart.ts +65 -0
- package/patternfly-docs/content/extensions/chatbot/examples/UI/ChatbotFooter.tsx +1 -1
- package/patternfly-docs/content/extensions/chatbot/examples/UI/ChatbotFootnote.tsx +5 -5
- package/patternfly-docs/content/extensions/chatbot/examples/UI/ChatbotHeaderBasic.tsx +1 -1
- package/patternfly-docs/content/extensions/chatbot/examples/UI/ChatbotHeaderDrawer.tsx +36 -3
- package/patternfly-docs/content/extensions/chatbot/examples/UI/ChatbotHeaderDrawerNavigation.tsx +67 -0
- package/patternfly-docs/content/extensions/chatbot/examples/UI/ChatbotHeaderDrawerResizable.tsx +94 -0
- package/patternfly-docs/content/extensions/chatbot/examples/UI/ChatbotMessageBarAttach.tsx +1 -1
- package/patternfly-docs/content/extensions/chatbot/examples/UI/ChatbotWelcomeInteraction.tsx +1 -1
- package/patternfly-docs/content/extensions/chatbot/examples/UI/ChatbotWelcomePrompt.tsx +7 -7
- package/patternfly-docs/content/extensions/chatbot/examples/UI/SquareChatbotToggle.tsx +1 -1
- package/patternfly-docs/content/extensions/chatbot/examples/UI/UI.md +21 -6
- package/patternfly-docs/content/extensions/chatbot/examples/demos/AttachmentDemos.md +14 -0
- package/patternfly-docs/content/extensions/chatbot/examples/demos/Chatbot.md +39 -1
- package/patternfly-docs/content/extensions/chatbot/examples/demos/Chatbot.tsx +48 -35
- package/patternfly-docs/content/extensions/chatbot/examples/demos/ChatbotAttachment.tsx +2 -2
- package/patternfly-docs/content/extensions/chatbot/examples/demos/ChatbotAttachmentMenu.tsx +3 -3
- package/patternfly-docs/content/extensions/chatbot/examples/demos/ChatbotInDrawer.tsx +453 -0
- package/patternfly-docs/content/extensions/chatbot/examples/demos/EmbeddedChatbot.tsx +11 -11
- package/patternfly-docs/content/extensions/chatbot/examples/demos/EmbeddedComparisonChatbot.tsx +206 -0
- package/patternfly-docs/content/extensions/chatbot/examples/demos/Feedback.tsx +104 -0
- package/patternfly-docs/content/extensions/chatbot/img/ai-action-inpage.svg +85 -0
- package/patternfly-docs/content/extensions/chatbot/img/ai-action-message.svg +63 -0
- package/patternfly-docs/content/extensions/chatbot/img/analytics-example.svg +127 -0
- package/patternfly-docs/content/extensions/chatbot/img/attached-file.svg +24 -29
- package/patternfly-docs/content/extensions/chatbot/img/attachment-menu.svg +4 -4
- package/patternfly-docs/content/extensions/chatbot/img/attachment-unsent.svg +30 -58
- package/patternfly-docs/content/extensions/chatbot/img/chatbot-analytics.svg +51 -0
- package/patternfly-docs/content/extensions/chatbot/img/chatbot-elements.svg +11 -12
- package/patternfly-docs/content/extensions/chatbot/img/chatbot-quickstarts-tile.svg +58 -0
- package/patternfly-docs/content/extensions/chatbot/img/chatbot-settings.svg +83 -0
- package/patternfly-docs/content/extensions/chatbot/img/comparison.svg +45 -0
- package/patternfly-docs/content/extensions/chatbot/img/conversation-history.svg +6 -29
- package/patternfly-docs/content/extensions/chatbot/img/docked.svg +259 -241
- package/patternfly-docs/content/extensions/chatbot/img/drawer.svg +255 -0
- package/patternfly-docs/content/extensions/chatbot/img/error-state.svg +30 -0
- package/patternfly-docs/content/extensions/chatbot/img/feedback-form.svg +88 -0
- package/patternfly-docs/content/extensions/chatbot/img/footnote.svg +1 -1
- package/patternfly-docs/content/extensions/chatbot/img/fullscreen.svg +25 -16
- package/patternfly-docs/content/extensions/chatbot/img/listening-pulse.svg +22 -0
- package/patternfly-docs/content/extensions/chatbot/img/listening.svg +1 -1
- package/patternfly-docs/content/extensions/chatbot/img/loading-state.svg +28 -0
- package/patternfly-docs/content/extensions/chatbot/img/masthead-toggle-notification.svg +49 -0
- package/patternfly-docs/content/extensions/chatbot/img/masthead-toggle.svg +75 -0
- package/patternfly-docs/content/extensions/chatbot/img/message-bar-elements.svg +3 -3
- package/patternfly-docs/content/extensions/chatbot/img/message-elements.svg +84 -142
- package/patternfly-docs/content/extensions/chatbot/img/message-feedback.svg +52 -0
- package/patternfly-docs/content/extensions/chatbot/img/message-responses.svg +54 -0
- package/patternfly-docs/content/extensions/chatbot/img/new-chat-emptystate.svg +27 -0
- package/patternfly-docs/content/extensions/chatbot/img/no-results-emptystate.svg +27 -0
- package/patternfly-docs/content/extensions/chatbot/img/overlay.svg +54 -39
- package/patternfly-docs/content/extensions/chatbot/img/posthog.svg +30 -0
- package/patternfly-docs/content/extensions/chatbot/img/segment.svg +36 -0
- package/patternfly-docs/content/extensions/chatbot/img/settings-menu.svg +122 -0
- package/patternfly-docs/content/extensions/chatbot/img/source-tile.svg +62 -0
- package/patternfly-docs/content/extensions/chatbot/img/thank-you-card.svg +81 -0
- package/patternfly-docs/content/extensions/chatbot/img/toggle-customizations.svg +12 -0
- package/patternfly-docs/content/extensions/chatbot/img/toggle-tooltips.svg +38 -0
- package/patternfly-docs/content/extensions/chatbot/img/umami.svg +30 -0
- package/patternfly-docs/content/extensions/chatbot/img/welcome-elements.svg +82 -0
- package/patternfly-docs/content/extensions/chatbot/img/welcome-message.svg +94 -0
- package/src/AttachMenu/AttachMenu.scss +1 -1
- package/src/AttachmentEdit/AttachmentEdit.test.tsx +55 -0
- package/src/Chatbot/Chatbot.scss +20 -1
- package/src/Chatbot/Chatbot.test.tsx +31 -0
- package/src/Chatbot/Chatbot.tsx +2 -1
- package/src/ChatbotAlert/ChatbotAlert.test.tsx +31 -0
- package/src/ChatbotContent/ChatbotContent.scss +1 -0
- package/src/ChatbotContent/ChatbotContent.test.tsx +15 -0
- package/src/ChatbotConversationHistoryNav/ChatbotConversationHistoryDropdown.tsx +10 -4
- package/src/ChatbotConversationHistoryNav/ChatbotConversationHistoryNav.scss +24 -1
- package/src/ChatbotConversationHistoryNav/ChatbotConversationHistoryNav.test.tsx +242 -3
- package/src/ChatbotConversationHistoryNav/ChatbotConversationHistoryNav.tsx +94 -26
- package/src/ChatbotConversationHistoryNav/EmptyState.tsx +44 -0
- package/src/ChatbotConversationHistoryNav/LoadingState.tsx +38 -0
- package/src/ChatbotFooter/ChatbotFooter.scss +8 -4
- package/src/ChatbotFooter/ChatbotFooter.test.tsx +15 -0
- package/src/ChatbotFooter/ChatbotFooternote.test.tsx +84 -0
- package/src/ChatbotFooter/ChatbotFootnote.tsx +2 -2
- package/src/ChatbotHeader/ChatbotHeader.scss +5 -6
- package/src/ChatbotHeader/ChatbotHeader.test.tsx +15 -0
- package/src/ChatbotHeader/ChatbotHeaderActions.test.tsx +17 -0
- package/src/ChatbotHeader/ChatbotHeaderCloseButton.test.tsx +20 -0
- package/src/ChatbotHeader/ChatbotHeaderCloseButton.tsx +7 -1
- package/src/ChatbotHeader/ChatbotHeaderMain.test.tsx +17 -0
- package/src/ChatbotHeader/ChatbotHeaderMenu.test.tsx +19 -0
- package/src/ChatbotHeader/ChatbotHeaderMenu.tsx +7 -1
- package/src/ChatbotHeader/ChatbotHeaderOptionsDropdown.test.tsx +45 -0
- package/src/ChatbotHeader/ChatbotHeaderOptionsDropdown.tsx +8 -1
- package/src/ChatbotHeader/ChatbotHeaderSelectorDropdown.test.tsx +43 -0
- package/src/ChatbotHeader/ChatbotHeaderSelectorDropdown.tsx +11 -4
- package/src/ChatbotHeader/ChatbotHeaderTitle.test.tsx +75 -0
- package/src/ChatbotHeader/ChatbotHeaderTitle.tsx +7 -2
- package/src/ChatbotModal/ChatbotModal.scss +12 -12
- package/src/ChatbotToggle/ChatbotToggle.tsx +6 -1
- package/src/ChatbotWelcomePrompt/ChatbotWelcomePrompt.scss +2 -0
- package/src/ChatbotWelcomePrompt/ChatbotWelcomePrompt.test.tsx +26 -18
- package/src/ChatbotWelcomePrompt/__snapshots__/ChatbotWelcomePrompt.test.tsx.snap +2 -2
- package/src/CodeModal/CodeModal.scss +7 -4
- package/src/Compare/Compare.scss +72 -0
- package/src/Compare/Compare.test.tsx +31 -0
- package/src/Compare/Compare.tsx +98 -0
- package/src/Compare/index.ts +2 -0
- package/src/FileDetails/FileDetails.scss +1 -1
- package/src/FileDetailsLabel/FileDetailsLabel.scss +2 -2
- package/src/Message/CodeBlockMessage/CodeBlockMessage.scss +4 -4
- package/src/Message/ErrorMessage/ErrorMessage.tsx +14 -0
- package/src/Message/ImageMessage/ImageMessage.scss +9 -0
- package/src/Message/ImageMessage/ImageMessage.tsx +14 -0
- package/src/Message/LinkMessage/LinkMessage.tsx +34 -0
- package/src/Message/ListMessage/ListMessage.scss +6 -6
- package/src/Message/Message.scss +4 -26
- package/src/Message/Message.test.tsx +367 -3
- package/src/Message/Message.tsx +157 -31
- package/src/Message/MessageLoading.scss +2 -2
- package/src/Message/QuickResponse/QuickResponse.scss +33 -0
- package/src/Message/QuickResponse/QuickResponse.tsx +54 -0
- package/src/Message/QuickStarts/FallbackImg.tsx +24 -0
- package/src/Message/QuickStarts/QuickStartTile.scss +24 -0
- package/src/Message/QuickStarts/QuickStartTile.tsx +147 -0
- package/src/Message/QuickStarts/QuickStartTileDescription.test.tsx +57 -0
- package/src/Message/QuickStarts/QuickStartTileDescription.tsx +81 -0
- package/src/Message/QuickStarts/QuickStartTileHeader.tsx +21 -0
- package/src/Message/QuickStarts/monitor-sampleapp-quickstart-with-image.ts +75 -0
- package/src/Message/QuickStarts/monitor-sampleapp-quickstart.ts +75 -0
- package/src/Message/QuickStarts/types.ts +154 -0
- package/src/Message/TableMessage/TableMessage.scss +23 -0
- package/src/Message/TableMessage/TableMessage.tsx +83 -0
- package/src/Message/TableMessage/TbodyMessage.tsx +20 -0
- package/src/Message/TableMessage/TdMessage.tsx +11 -0
- package/src/Message/TableMessage/ThMessage.tsx +11 -0
- package/src/Message/TableMessage/TheadMessage.tsx +11 -0
- package/src/Message/TableMessage/TrMessage.tsx +27 -0
- package/src/Message/TextMessage/TextMessage.scss +21 -12
- package/src/Message/TextMessage/TextMessage.tsx +3 -3
- package/src/Message/UserFeedback/CloseButton.tsx +21 -0
- package/src/Message/UserFeedback/UserFeedback.scss +53 -0
- package/src/Message/UserFeedback/UserFeedback.test.tsx +236 -0
- package/src/Message/UserFeedback/UserFeedback.tsx +128 -0
- package/src/Message/UserFeedback/UserFeedbackComplete.test.tsx +255 -0
- package/src/Message/UserFeedback/UserFeedbackComplete.tsx +211 -0
- package/src/MessageBar/AttachButton.scss +19 -3
- package/src/MessageBar/AttachButton.tsx +3 -1
- package/src/MessageBar/MessageBar.scss +58 -24
- package/src/MessageBar/MessageBar.test.tsx +12 -4
- package/src/MessageBar/MessageBar.tsx +164 -65
- package/src/MessageBar/MicrophoneButton.scss +8 -8
- package/src/MessageBar/MicrophoneButton.tsx +1 -1
- package/src/MessageBar/SendButton.tsx +2 -0
- package/src/MessageBar/StopButton.scss +17 -3
- package/src/MessageBar/StopButton.tsx +2 -0
- package/src/MessageBox/JumpButton.scss +6 -6
- package/src/MessageBox/MessageBox.scss +1 -0
- package/src/MessageBox/MessageBox.test.tsx +26 -0
- package/src/PreviewAttachment/PreviewAttachment.test.tsx +51 -0
- package/src/ResponseActions/ResponseActionButton.tsx +14 -2
- package/src/ResponseActions/ResponseActions.scss +2 -2
- package/src/ResponseActions/ResponseActions.test.tsx +4 -2
- package/src/ResponseActions/ResponseActions.tsx +26 -2
- package/src/Settings/Settings.scss +2 -2
- package/src/Settings/SettingsForm.test.tsx +28 -0
- package/src/SourceDetailsMenuItem/SourceDetailsMenuItem.scss +2 -2
- package/src/SourcesCard/SourcesCard.scss +9 -3
- package/src/TermsOfUse/TermsOfUse.scss +1 -1
- package/src/__mocks__/rehype-external-links.ts +3 -0
- package/src/__mocks__/rehype-sanitize.ts +3 -0
- package/src/__mocks__/rehype-unwrap-images.tsx +3 -0
- package/src/index.ts +6 -0
- package/src/main.scss +6 -6
- package/src/tracking/console_tracking_provider.ts +30 -0
- package/src/tracking/index.ts +3 -0
- package/src/tracking/posthog_tracking_provider.ts +42 -0
- package/src/tracking/segment_tracking_provider.ts +62 -0
- package/src/tracking/trackingProviderProxy.ts +28 -0
- package/src/tracking/tracking_api.ts +11 -0
- package/src/tracking/tracking_registry.ts +33 -0
- package/src/tracking/tracking_spi.ts +14 -0
- package/src/tracking/umami_tracking_provider.ts +54 -0
@@ -2,9 +2,43 @@ import React from 'react';
|
|
2
2
|
import Message from '@patternfly/chatbot/dist/dynamic/Message';
|
3
3
|
import patternflyAvatar from './patternfly_avatar.jpg';
|
4
4
|
import squareImg from './PF-social-color-square.svg';
|
5
|
+
import { AlertActionLink, Form, FormGroup, Radio } from '@patternfly/react-core';
|
5
6
|
|
6
7
|
export const BotMessageExample: React.FunctionComponent = () => {
|
7
|
-
const
|
8
|
+
const [variant, setVariant] = React.useState('code');
|
9
|
+
|
10
|
+
/* eslint-disable indent */
|
11
|
+
const renderContent = () => {
|
12
|
+
switch (variant) {
|
13
|
+
case 'code':
|
14
|
+
return code;
|
15
|
+
case 'heading':
|
16
|
+
return heading;
|
17
|
+
case 'emphasis':
|
18
|
+
return emphasis;
|
19
|
+
case 'blockQuotes':
|
20
|
+
return blockQuotes;
|
21
|
+
case 'orderedList':
|
22
|
+
return orderedList;
|
23
|
+
case 'unorderedList':
|
24
|
+
return unorderedList;
|
25
|
+
case 'moreComplexList':
|
26
|
+
return moreComplexList;
|
27
|
+
case 'inlineCode':
|
28
|
+
return inlineCode;
|
29
|
+
case 'link':
|
30
|
+
return link;
|
31
|
+
case 'table':
|
32
|
+
return table;
|
33
|
+
case 'image':
|
34
|
+
return image;
|
35
|
+
default:
|
36
|
+
return;
|
37
|
+
}
|
38
|
+
};
|
39
|
+
/* eslint-enable indent */
|
40
|
+
|
41
|
+
const code = `
|
8
42
|
Here is some YAML code:
|
9
43
|
|
10
44
|
~~~yaml
|
@@ -35,6 +69,36 @@ export default MessageLoading;
|
|
35
69
|
~~~
|
36
70
|
`;
|
37
71
|
|
72
|
+
const heading = `
|
73
|
+
# h1 Heading
|
74
|
+
|
75
|
+
## h2 Heading
|
76
|
+
|
77
|
+
### h3 Heading
|
78
|
+
|
79
|
+
#### h4 Heading
|
80
|
+
|
81
|
+
##### h5 Heading
|
82
|
+
|
83
|
+
###### h6 Heading
|
84
|
+
`;
|
85
|
+
|
86
|
+
const emphasis = `
|
87
|
+
**Bold text, formatted with double asterisks**
|
88
|
+
|
89
|
+
__Bold text, formatted with double underscores__
|
90
|
+
|
91
|
+
*Italic text, formatted with single asterisks*
|
92
|
+
|
93
|
+
_Italic text, formatted with single underscores_
|
94
|
+
|
95
|
+
~~Strikethrough~~
|
96
|
+
`;
|
97
|
+
|
98
|
+
const blockQuotes = `> Blockquotes can also be nested...
|
99
|
+
>> ...by using additional greater-than signs (>) right next to each other...
|
100
|
+
> > > ...or with spaces between each sign.`;
|
101
|
+
|
38
102
|
const orderedList = `
|
39
103
|
Here is an ordered list:
|
40
104
|
|
@@ -53,43 +117,181 @@ export default MessageLoading;
|
|
53
117
|
|
54
118
|
1. **Using a \`toaster\`:**
|
55
119
|
|
56
|
-
- Place \`bread\` in a \`toaster
|
57
|
-
- Once \`bread\` is lightly browned, remove from \`toaster
|
120
|
+
- Place \`bread\` in a \`toaster\`.
|
121
|
+
- Once \`bread\` is lightly browned, remove from \`toaster\`.
|
58
122
|
|
59
123
|
2. **Using a \`knife\`:**
|
60
124
|
|
61
125
|
Acquire 1 tablespoon of room temperature \`butter\`. Use \`knife\` to spread butter on \`toast\`. Bon appétit!
|
62
126
|
`;
|
63
127
|
|
128
|
+
const link = `A paragraph with a URL: https://reactjs.org.`;
|
129
|
+
|
130
|
+
const inlineCode = `Here is an inline code - \`() => void\``;
|
131
|
+
|
132
|
+
const table = `To customize your table, you can use [PatternFly TableProps](/components/table#table)
|
133
|
+
|
134
|
+
| Version | GA date | User role
|
135
|
+
|-|-|-|
|
136
|
+
| 2.5 | September 30, 2024 | Administrator |
|
137
|
+
| 2.5 | June 27, 2023 | Editor |
|
138
|
+
| 3.0 | April 1, 2025 | Administrator
|
139
|
+
`;
|
140
|
+
|
141
|
+
const image = ``;
|
142
|
+
|
143
|
+
const error = {
|
144
|
+
title: 'Could not load chat',
|
145
|
+
children: 'Wait a few minutes and check your network settings. If the issue persists: ',
|
146
|
+
actionLinks: (
|
147
|
+
<React.Fragment>
|
148
|
+
<AlertActionLink component="a" href="#">
|
149
|
+
Start a new chat
|
150
|
+
</AlertActionLink>
|
151
|
+
<AlertActionLink component="a" href="#">
|
152
|
+
Contact support
|
153
|
+
</AlertActionLink>
|
154
|
+
</React.Fragment>
|
155
|
+
)
|
156
|
+
};
|
157
|
+
|
64
158
|
return (
|
65
159
|
<>
|
66
|
-
<Message name="Bot" role="bot" avatar={patternflyAvatar} content={`Text-based message from a bot named "Bot"`} />
|
67
160
|
<Message
|
68
161
|
name="Bot"
|
69
162
|
role="bot"
|
70
163
|
avatar={patternflyAvatar}
|
71
|
-
content={`
|
164
|
+
content={`This is a text-based message from a bot named "Bot."`}
|
165
|
+
/>
|
166
|
+
<Message
|
167
|
+
name="Bot"
|
168
|
+
role="bot"
|
169
|
+
avatar={patternflyAvatar}
|
170
|
+
content={`This is a text-based message from "Bot," with an updated timestamp.`}
|
72
171
|
timestamp="1 hour ago"
|
73
172
|
/>
|
74
|
-
<Message name="Bot" role="bot" avatar={patternflyAvatar} content={markdown} />
|
75
|
-
<Message name="Bot" role="bot" avatar={patternflyAvatar} content={orderedList} />
|
76
|
-
<Message name="Bot" role="bot" avatar={patternflyAvatar} content={unorderedList} />
|
77
|
-
<Message name="Bot" role="bot" avatar={patternflyAvatar} content={moreComplexList} />
|
78
173
|
<Message name="Bot" role="bot" avatar={patternflyAvatar} content="Example content" isLoading />
|
79
|
-
<Message role="bot" avatar={patternflyAvatar} content="
|
174
|
+
<Message role="bot" avatar={patternflyAvatar} content="This message is from a nameless bot." />
|
80
175
|
<Message
|
81
176
|
name="Default Openshift Container Platform Assistant That Can Help With Any Query You Might Need Help With"
|
82
177
|
role="bot"
|
83
178
|
avatar={patternflyAvatar}
|
84
|
-
content="
|
179
|
+
content="This is a message from a bot with really long name: it's truncated!"
|
85
180
|
/>
|
86
181
|
<Message
|
87
182
|
name="Bot"
|
88
183
|
role="bot"
|
89
184
|
avatar={squareImg}
|
90
|
-
content="
|
185
|
+
content="This bot has a square avatar. You can further customize the avatar by applying an additional class or passing [PatternFly avatar props](/components/avatar) to the `<Message>` component via `avatarProps`."
|
91
186
|
hasRoundAvatar={false}
|
92
187
|
/>
|
188
|
+
<Message
|
189
|
+
name="Bot"
|
190
|
+
role="bot"
|
191
|
+
avatar={patternflyAvatar}
|
192
|
+
content={`Text-based message from a bot named "Bot," with updated timestamp`}
|
193
|
+
timestamp="1 hour ago"
|
194
|
+
/>
|
195
|
+
<Message name="Bot" role="bot" avatar={patternflyAvatar} content="Example content" isLoading />
|
196
|
+
|
197
|
+
<Form>
|
198
|
+
<FormGroup role="radiogroup" isInline fieldId="bot-message-type" label="Message content type">
|
199
|
+
<Radio
|
200
|
+
isChecked={variant === 'code'}
|
201
|
+
onChange={() => setVariant('code')}
|
202
|
+
name="bot-message-type"
|
203
|
+
label="Code"
|
204
|
+
id="code"
|
205
|
+
/>
|
206
|
+
<Radio
|
207
|
+
isChecked={variant === 'inlineCode'}
|
208
|
+
onChange={() => setVariant('inlineCode')}
|
209
|
+
name="bot-message-type"
|
210
|
+
label="Inline code"
|
211
|
+
id="inline-code"
|
212
|
+
/>
|
213
|
+
<Radio
|
214
|
+
isChecked={variant === 'heading'}
|
215
|
+
onChange={() => setVariant('heading')}
|
216
|
+
name="bot-message-type"
|
217
|
+
label="Heading"
|
218
|
+
id="heading"
|
219
|
+
/>
|
220
|
+
<Radio
|
221
|
+
isChecked={variant === 'blockQuotes'}
|
222
|
+
onChange={() => setVariant('blockQuotes')}
|
223
|
+
name="bot-message-type"
|
224
|
+
label="Block quote"
|
225
|
+
id="block-quotes"
|
226
|
+
/>
|
227
|
+
<Radio
|
228
|
+
isChecked={variant === 'emphasis'}
|
229
|
+
onChange={() => setVariant('emphasis')}
|
230
|
+
name="bot-message-type"
|
231
|
+
label="Emphasis"
|
232
|
+
id="emphasis"
|
233
|
+
/>
|
234
|
+
<Radio
|
235
|
+
isChecked={variant === 'link'}
|
236
|
+
onChange={() => setVariant('link')}
|
237
|
+
name="bot-message-type"
|
238
|
+
label="Link"
|
239
|
+
id="link"
|
240
|
+
/>
|
241
|
+
<Radio
|
242
|
+
isChecked={variant === 'unorderedList'}
|
243
|
+
onChange={() => setVariant('unorderedList')}
|
244
|
+
name="bot-message-type"
|
245
|
+
label="Unordered list"
|
246
|
+
id="unordered-list"
|
247
|
+
/>
|
248
|
+
<Radio
|
249
|
+
isChecked={variant === 'orderedList'}
|
250
|
+
onChange={() => setVariant('orderedList')}
|
251
|
+
name="bot-message-type"
|
252
|
+
label="Ordered list"
|
253
|
+
id="ordered-list"
|
254
|
+
/>
|
255
|
+
<Radio
|
256
|
+
isChecked={variant === 'moreComplexList'}
|
257
|
+
onChange={() => setVariant('moreComplexList')}
|
258
|
+
name="bot-message-type"
|
259
|
+
label="More complex list"
|
260
|
+
id="more-complex-list"
|
261
|
+
/>
|
262
|
+
<Radio
|
263
|
+
isChecked={variant === 'table'}
|
264
|
+
onChange={() => setVariant('table')}
|
265
|
+
name="bot-message-type"
|
266
|
+
label="Table"
|
267
|
+
id="table"
|
268
|
+
/>
|
269
|
+
<Radio
|
270
|
+
isChecked={variant === 'image'}
|
271
|
+
onChange={() => setVariant('image')}
|
272
|
+
name="bot-message-type"
|
273
|
+
label="Image"
|
274
|
+
id="image"
|
275
|
+
/>
|
276
|
+
<Radio
|
277
|
+
isChecked={variant === 'error'}
|
278
|
+
onChange={() => setVariant('error')}
|
279
|
+
name="bot-message-error"
|
280
|
+
label="Error"
|
281
|
+
id="error"
|
282
|
+
/>
|
283
|
+
</FormGroup>
|
284
|
+
</Form>
|
285
|
+
<Message
|
286
|
+
name="Bot"
|
287
|
+
role="bot"
|
288
|
+
avatar={patternflyAvatar}
|
289
|
+
content={renderContent()}
|
290
|
+
tableProps={
|
291
|
+
variant === 'table' ? { 'aria-label': 'App information and user roles for bot messages' } : undefined
|
292
|
+
}
|
293
|
+
error={variant === 'error' ? error : undefined}
|
294
|
+
/>
|
93
295
|
</>
|
94
296
|
);
|
95
297
|
};
|
@@ -53,7 +53,8 @@ export const DropzoneExample: React.FunctionComponent = () => {
|
|
53
53
|
return (
|
54
54
|
<FileDropZone onFileDrop={handleFileDrop} displayMode="fullscreen">
|
55
55
|
<div className="pf-chatbot__file-drop-zone-example">
|
56
|
-
|
56
|
+
This is example content that would be shown when no dragging is happening. To see the drop zone, start to drag
|
57
|
+
an item into this section. The static content will be replaced by an active drop zone message.
|
57
58
|
</div>
|
58
59
|
</FileDropZone>
|
59
60
|
);
|
package/patternfly-docs/content/extensions/chatbot/examples/Messages/MessageWithAttachment.tsx
CHANGED
@@ -32,14 +32,14 @@ export const AttachmentMenuExample: React.FunctionComponent = () => {
|
|
32
32
|
name="User"
|
33
33
|
role="user"
|
34
34
|
avatar={userAvatar}
|
35
|
-
content="Here is an uploaded file"
|
35
|
+
content="Here is an uploaded file:"
|
36
36
|
attachments={[{ name: 'auth-operator.yml', id: '1', onClick, onClose }]}
|
37
37
|
/>
|
38
38
|
<Message
|
39
39
|
name="User"
|
40
40
|
role="user"
|
41
41
|
avatar={userAvatar}
|
42
|
-
content="Here are
|
42
|
+
content="Here are 2 uploaded files:"
|
43
43
|
attachments={[
|
44
44
|
{ name: 'auth-operator.yml', id: '1' },
|
45
45
|
{ name: 'patternfly.svg', id: '2' }
|
@@ -11,7 +11,7 @@ export const CustomActionExample: React.FunctionComponent = () => (
|
|
11
11
|
name="Bot"
|
12
12
|
role="bot"
|
13
13
|
avatar={patternflyAvatar}
|
14
|
-
content="
|
14
|
+
content="I updated your account with those settings. You're ready to set up your first dashboard!"
|
15
15
|
actions={{
|
16
16
|
regenerate: {
|
17
17
|
ariaLabel: 'Regenerate',
|
@@ -0,0 +1,71 @@
|
|
1
|
+
import React from 'react';
|
2
|
+
import Message from '@patternfly/chatbot/dist/dynamic/Message';
|
3
|
+
import patternflyAvatar from './patternfly_avatar.jpg';
|
4
|
+
import { Checkbox, FormGroup, Stack } from '@patternfly/react-core';
|
5
|
+
|
6
|
+
export const MessageWithFeedbackExample: React.FunctionComponent = () => {
|
7
|
+
const [hasCloseButton, setHasCloseButton] = React.useState(false);
|
8
|
+
const [hasTextArea, setHasTextArea] = React.useState(false);
|
9
|
+
|
10
|
+
return (
|
11
|
+
<>
|
12
|
+
<Stack hasGutter>
|
13
|
+
<FormGroup role="radiogroup" isInline fieldId="feedback-card" label="Variant">
|
14
|
+
<Checkbox
|
15
|
+
isChecked={hasTextArea}
|
16
|
+
onChange={() => {
|
17
|
+
setHasTextArea(!hasTextArea);
|
18
|
+
}}
|
19
|
+
name="basic-inline-radio"
|
20
|
+
label="Has text area"
|
21
|
+
id="has-text-area"
|
22
|
+
/>
|
23
|
+
</FormGroup>
|
24
|
+
<Message
|
25
|
+
name="Bot"
|
26
|
+
role="bot"
|
27
|
+
avatar={patternflyAvatar}
|
28
|
+
content="This is a message with the feedback card:"
|
29
|
+
userFeedbackForm={{
|
30
|
+
quickResponses: [
|
31
|
+
{ id: '1', content: 'Helpful information' },
|
32
|
+
{ id: '2', content: 'Easy to understand' },
|
33
|
+
{ id: '3', content: 'Resolved my issue' }
|
34
|
+
],
|
35
|
+
onSubmit: (quickResponse, additionalFeedback) =>
|
36
|
+
alert(`Selected ${quickResponse} and received the additional feedback: ${additionalFeedback}`),
|
37
|
+
hasTextArea,
|
38
|
+
// eslint-disable-next-line no-console
|
39
|
+
onClose: () => console.log('closed feedback form'),
|
40
|
+
focusOnLoad: false
|
41
|
+
}}
|
42
|
+
/>
|
43
|
+
</Stack>
|
44
|
+
<Stack hasGutter>
|
45
|
+
<FormGroup role="radiogroup" isInline fieldId="feedback-thank-you" label="Variant">
|
46
|
+
<Checkbox
|
47
|
+
isChecked={hasCloseButton}
|
48
|
+
onChange={() => {
|
49
|
+
setHasCloseButton(!hasCloseButton);
|
50
|
+
}}
|
51
|
+
name="basic-inline-radio"
|
52
|
+
label="Has close button"
|
53
|
+
id="has-close"
|
54
|
+
/>
|
55
|
+
</FormGroup>
|
56
|
+
<Message
|
57
|
+
name="Bot"
|
58
|
+
role="bot"
|
59
|
+
avatar={patternflyAvatar}
|
60
|
+
content="This is a thank-you message, which is displayed once the feedback card is submitted:"
|
61
|
+
// eslint-disable-next-line no-console
|
62
|
+
userFeedbackComplete={{
|
63
|
+
// eslint-disable-next-line no-console
|
64
|
+
onClose: hasCloseButton ? () => console.log('closed completion message') : undefined,
|
65
|
+
focusOnLoad: false
|
66
|
+
}}
|
67
|
+
/>
|
68
|
+
</Stack>
|
69
|
+
</>
|
70
|
+
);
|
71
|
+
};
|
package/patternfly-docs/content/extensions/chatbot/examples/Messages/MessageWithFeedbackTimeout.tsx
ADDED
@@ -0,0 +1,27 @@
|
|
1
|
+
import React from 'react';
|
2
|
+
import Message from '@patternfly/chatbot/dist/dynamic/Message';
|
3
|
+
import patternflyAvatar from './patternfly_avatar.jpg';
|
4
|
+
import { Button } from '@patternfly/react-core';
|
5
|
+
|
6
|
+
export const MessageWithFeedbackTimeoutExample: React.FunctionComponent = () => {
|
7
|
+
const [hasFeedback, setHasFeedback] = React.useState(false);
|
8
|
+
|
9
|
+
return (
|
10
|
+
<>
|
11
|
+
<Button variant="secondary" onClick={() => setHasFeedback(true)}>
|
12
|
+
Show card
|
13
|
+
</Button>
|
14
|
+
<Button variant="secondary" onClick={() => setHasFeedback(false)}>
|
15
|
+
Remove card
|
16
|
+
</Button>
|
17
|
+
<Message
|
18
|
+
name="Bot"
|
19
|
+
role="bot"
|
20
|
+
avatar={patternflyAvatar}
|
21
|
+
content="This completion message times out after you click **Show card**:"
|
22
|
+
userFeedbackComplete={hasFeedback ? { timeout: true, onTimeout: () => setHasFeedback(false) } : undefined}
|
23
|
+
isLiveRegion
|
24
|
+
/>
|
25
|
+
</>
|
26
|
+
);
|
27
|
+
};
|
package/patternfly-docs/content/extensions/chatbot/examples/Messages/MessageWithQuickResponses.tsx
CHANGED
@@ -31,7 +31,7 @@ export const MessageWithQuickResponsesExample: React.FunctionComponent = () => (
|
|
31
31
|
name="Bot"
|
32
32
|
role="bot"
|
33
33
|
avatar={patternflyAvatar}
|
34
|
-
content="Welcome back! How can I help?"
|
34
|
+
content="Welcome back, User! How can I help you today?"
|
35
35
|
quickResponses={[
|
36
36
|
{ id: '1', content: 'Help me with an access issue', onClick: () => alert('Clicked id 1') },
|
37
37
|
{ id: '2', content: 'Show my critical vulnerabilities', onClick: () => alert('Clicked id 2') },
|
package/patternfly-docs/content/extensions/chatbot/examples/Messages/MessageWithQuickStart.tsx
ADDED
@@ -0,0 +1,31 @@
|
|
1
|
+
import React from 'react';
|
2
|
+
import Message from '@patternfly/chatbot/dist/dynamic/Message';
|
3
|
+
import patternflyAvatar from './patternfly_avatar.jpg';
|
4
|
+
import { explorePipelinesQuickStart } from './explore-pipeline-quickstart.ts';
|
5
|
+
import { monitorSampleAppQuickStart } from '@patternfly/chatbot/src/Message/QuickStarts/monitor-sampleapp-quickstart.ts';
|
6
|
+
import { QuickStart } from '@patternfly/chatbot/dist/esm/Message/QuickStarts/types';
|
7
|
+
|
8
|
+
export const MessageWithQuickStartExample: React.FunctionComponent = () => (
|
9
|
+
<>
|
10
|
+
<Message
|
11
|
+
name="Bot"
|
12
|
+
role="bot"
|
13
|
+
avatar={patternflyAvatar}
|
14
|
+
content="Follow this quick guide to install the Pipelines Operator."
|
15
|
+
quickStarts={{
|
16
|
+
quickStart: explorePipelinesQuickStart as QuickStart,
|
17
|
+
onSelectQuickStart: (id) => alert(id)
|
18
|
+
}}
|
19
|
+
/>
|
20
|
+
<Message
|
21
|
+
name="Bot"
|
22
|
+
role="bot"
|
23
|
+
avatar={patternflyAvatar}
|
24
|
+
content="This quick start tile includes prerequisites and a default icon."
|
25
|
+
quickStarts={{
|
26
|
+
quickStart: monitorSampleAppQuickStart,
|
27
|
+
onSelectQuickStart: (id) => alert(id)
|
28
|
+
}}
|
29
|
+
/>
|
30
|
+
</>
|
31
|
+
);
|
package/patternfly-docs/content/extensions/chatbot/examples/Messages/MessageWithResponseActions.tsx
CHANGED
@@ -8,7 +8,7 @@ export const ResponseActionExample: React.FunctionComponent = () => (
|
|
8
8
|
name="Bot"
|
9
9
|
role="bot"
|
10
10
|
avatar={patternflyAvatar}
|
11
|
-
content="
|
11
|
+
content="I updated your account with those settings. You're ready to set up your first dashboard!"
|
12
12
|
actions={{
|
13
13
|
// eslint-disable-next-line no-console
|
14
14
|
positive: { onClick: () => console.log('Good response') },
|
@@ -14,14 +14,18 @@ propComponents:
|
|
14
14
|
[
|
15
15
|
'AttachMenu',
|
16
16
|
'AttachmentEdit',
|
17
|
-
'
|
18
|
-
'
|
17
|
+
'FileDetailsProps',
|
18
|
+
'FileDetailsLabelProps',
|
19
19
|
'FileDropZone',
|
20
20
|
'PreviewAttachment',
|
21
21
|
'Message',
|
22
|
+
'MessageExtraContent',
|
22
23
|
'PreviewAttachment',
|
23
24
|
'ActionProps',
|
24
|
-
'SourcesCardProps'
|
25
|
+
'SourcesCardProps',
|
26
|
+
'UserFeedbackProps',
|
27
|
+
'UserFeedbackCompleteProps',
|
28
|
+
'QuickResponseProps'
|
25
29
|
]
|
26
30
|
sortValue: 3
|
27
31
|
---
|
@@ -39,7 +43,8 @@ import FileDetailsLabel from '@patternfly/chatbot/dist/dynamic/FileDetailsLabel'
|
|
39
43
|
import FileDropZone from '@patternfly/chatbot/dist/dynamic/FileDropZone';
|
40
44
|
import { PreviewAttachment } from '@patternfly/chatbot/dist/dynamic/PreviewAttachment';
|
41
45
|
import ChatbotAlert from '@patternfly/chatbot/dist/dynamic/ChatbotAlert';
|
42
|
-
|
46
|
+
import { explorePipelinesQuickStart } from './explore-pipeline-quickstart.ts';
|
47
|
+
import { monitorSampleAppQuickStart } from '@patternfly/chatbot/src/Message/QuickStarts/monitor-sampleapp-quickstart.ts';
|
43
48
|
import userAvatar from './user_avatar.svg';
|
44
49
|
import squareImg from './PF-social-color-square.svg';
|
45
50
|
|
@@ -51,12 +56,8 @@ The `content` prop of the `<Message>` component is passed to a `<Markdown>` comp
|
|
51
56
|
|
52
57
|
Messages from the ChatBot will be marked with an "AI" label to clearly communicate the use of AI to users. The ChatBot can display different `content` types, including plain text, code, or a loading animation (via `isLoading`).
|
53
58
|
|
54
|
-
<br />
|
55
|
-
|
56
59
|
By default, a date and timestamp is displayed with each message. We recommend using the `timestamp` prop in real ChatBots, since it will allow you to set persistent dates and times on messages, even if the messages re-render. You can update `timestamp` with a different [date and time format](/ux-writing/numerics) as needed.
|
57
60
|
|
58
|
-
<br />
|
59
|
-
|
60
61
|
You can further customize the avatar by applying an additional class or passing [PatternFly avatar props](/components/avatar) to the `<Message>` component via `avatarProps`.
|
61
62
|
|
62
63
|
```js file="./BotMessage.tsx"
|
@@ -96,9 +97,40 @@ You can apply a `clickedAriaLabel` and `clickedTooltipContent` once a button is
|
|
96
97
|
|
97
98
|
```
|
98
99
|
|
100
|
+
### Message feedback
|
101
|
+
|
102
|
+
When a user selects a positive or negative [message action](#message-actions), you can display a message feedback card that acknowledges their response and provides space for additional written feedback. These cards can be manually dismissed via the close button and the thank-you card can be [configured to time out automatically](/patternfly-ai/chatbot/messages#message-feedback-with-timeouts).
|
103
|
+
|
104
|
+
You can see the full feedback flow [in the message demos](/patternfly-ai/chatbot/messages/demo#message-feedback).
|
105
|
+
|
106
|
+
The message feedback cards will immediately receive focus by default, but you can remove this behavior by passing `focusOnLoad: false` to the `<Message>` (as shown in the following examples). For better usability, you should generally keep the default focus behavior.
|
107
|
+
|
108
|
+
The following examples demonstrate:
|
109
|
+
|
110
|
+
- A basic feedback card. To toggle the text input area, select the **Has text area** checkbox.
|
111
|
+
- A thank-you card. To toggle the close button, select the **Has close button** checkbox.
|
112
|
+
|
113
|
+
```js file="./MessageWithFeedback.tsx"
|
114
|
+
|
115
|
+
```
|
116
|
+
|
117
|
+
### Message feedback with timeouts
|
118
|
+
|
119
|
+
The feedback thank-you message can be configured to time out and automatically close after a period of time. The default time-out period is 8000 ms, but it can be customized via `timeout`.
|
120
|
+
|
121
|
+
To display the thank-you message in this example, click **Show card**.
|
122
|
+
|
123
|
+
The card will not dismiss within the default time if a user is hovering over it or if it has keyboard focus. Instead, it will dismiss after they remove focus, via `timeoutAnimation`, which is 3000 ms by default. You can adjust this duration and set an `onTimeout` callback, as well as optional `onMouseEnter` and `onMouseLeave` callbacks.
|
124
|
+
|
125
|
+
For accessibility purposes, be sure to announce when new content appears onscreen. `isLiveRegion` is set to true by default on `<Message>` so it will make appropriate announcements for you when the thank-you card appears.
|
126
|
+
|
127
|
+
```js file="./MessageWithFeedbackTimeout.tsx"
|
128
|
+
|
129
|
+
```
|
130
|
+
|
99
131
|
### Messages with quick responses
|
100
132
|
|
101
|
-
You can offer convenient, clickable responses to messages in the form of quick actions. Quick actions are [PatternFly labels](/components/label/) in a label group, configured to display up to 5 visible labels.
|
133
|
+
You can offer convenient, clickable responses to messages in the form of quick actions. Quick actions are [PatternFly labels](/components/label/) in a label group, configured to display up to 5 visible labels. Only 1 response can be selected at a time.
|
102
134
|
|
103
135
|
To add quick actions, pass `quickResponses` to `<Message>`. This can be overridden by passing additional `<LabelGroup>` props to `quickResponseContainerProps`, or additional `<Label>` props to `quickResponses`.
|
104
136
|
|
@@ -116,6 +148,16 @@ The API for a source requires a link at minimum, but we strongly recommend provi
|
|
116
148
|
|
117
149
|
```
|
118
150
|
|
151
|
+
### Messages with quick start tiles
|
152
|
+
|
153
|
+
[Quick start](/extensions/quick-starts/) tiles can be added to messages via the `quickStarts` prop. Users can initiate the quick start from a link within the message tile.
|
154
|
+
|
155
|
+
The quick start tile displayed below the message is based on the tile included in the [PatternFly quick starts extension](https://github.com/patternfly/patternfly-quickstarts), but with slightly more limited functionality. For example, it does not track the state of the extension. However, it supports an additional `onSelectQuickStart` prop, so that the name of the quick start can be captured on click. This can be used to trigger other behavior in your application, such as launching that quick start in your main UI.
|
156
|
+
|
157
|
+
```js file="./MessageWithQuickStart.tsx"
|
158
|
+
|
159
|
+
```
|
160
|
+
|
119
161
|
### User messages
|
120
162
|
|
121
163
|
Messages from users have a different background color to differentiate them from bot messages. You can also display a custom avatar that is uploaded by the user. You can further customize the avatar by applying an additional class or passing [PatternFly avatar props](/components/avatar) to the `<Message>` component via `avatarProps`.
|
@@ -124,6 +166,16 @@ Messages from users have a different background color to differentiate them from
|
|
124
166
|
|
125
167
|
```
|
126
168
|
|
169
|
+
### Custom message content
|
170
|
+
|
171
|
+
**Caution:** Take care when using this feature. It can cause you to stray from accessibility and design best practice standards. If you frequently need add the same component via custom message content, reach out to the PatternFly team. If there's a consistent need for a certain component, we can look into adding native support for additional features.
|
172
|
+
|
173
|
+
You can add custom content to specific parts of a `<Message>` via the `extraContent` prop, including additional components (like timestamps, badges, or custom elements). This prop allows you to create dynamic and reusable elements for various use cases, without changing the default message layout.
|
174
|
+
|
175
|
+
```js file="./UserMessageWithExtraContent.tsx"
|
176
|
+
|
177
|
+
```
|
178
|
+
|
127
179
|
## File attachments
|
128
180
|
|
129
181
|
### Messages with attachments
|