@patternfly/chatbot 6.3.0-prerelease.13 → 6.3.0-prerelease.14
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/AttachMenu/AttachMenu.d.ts +2 -2
- package/dist/cjs/AttachMenu/AttachMenu.js +2 -12
- package/dist/cjs/AttachmentEdit/AttachmentEdit.d.ts +12 -2
- package/dist/cjs/AttachmentEdit/AttachmentEdit.js +3 -6
- package/dist/cjs/AttachmentEdit/AttachmentEdit.test.d.ts +1 -1
- package/dist/cjs/AttachmentEdit/AttachmentEdit.test.js +33 -8
- package/dist/cjs/Chatbot/Chatbot.d.ts +1 -2
- package/dist/cjs/Chatbot/Chatbot.js +4 -9
- package/dist/cjs/Chatbot/Chatbot.test.js +11 -11
- package/dist/cjs/ChatbotAlert/ChatbotAlert.d.ts +2 -2
- package/dist/cjs/ChatbotAlert/ChatbotAlert.js +4 -8
- package/dist/cjs/ChatbotAlert/ChatbotAlert.test.js +10 -10
- package/dist/cjs/ChatbotContent/ChatbotContent.d.ts +3 -3
- package/dist/cjs/ChatbotContent/ChatbotContent.js +2 -8
- package/dist/cjs/ChatbotContent/ChatbotContent.test.js +5 -5
- package/dist/cjs/ChatbotConversationHistoryNav/ChatbotConversationHistoryDropdown.d.ts +2 -2
- package/dist/cjs/ChatbotConversationHistoryNav/ChatbotConversationHistoryDropdown.js +7 -11
- package/dist/cjs/ChatbotConversationHistoryNav/ChatbotConversationHistoryDropdown.test.js +31 -33
- package/dist/cjs/ChatbotConversationHistoryNav/ChatbotConversationHistoryNav.d.ts +2 -2
- package/dist/cjs/ChatbotConversationHistoryNav/ChatbotConversationHistoryNav.js +16 -33
- package/dist/cjs/ChatbotConversationHistoryNav/ChatbotConversationHistoryNav.test.js +56 -64
- package/dist/cjs/ChatbotConversationHistoryNav/EmptyState.d.ts +2 -2
- package/dist/cjs/ChatbotConversationHistoryNav/EmptyState.js +2 -9
- package/dist/cjs/ChatbotConversationHistoryNav/LoadingState.d.ts +2 -2
- package/dist/cjs/ChatbotConversationHistoryNav/LoadingState.js +2 -25
- package/dist/cjs/ChatbotFooter/ChatbotFooter.d.ts +3 -3
- package/dist/cjs/ChatbotFooter/ChatbotFooter.js +2 -15
- package/dist/cjs/ChatbotFooter/ChatbotFooter.test.js +7 -7
- package/dist/cjs/ChatbotFooter/ChatbotFooternote.test.js +28 -28
- package/dist/cjs/ChatbotFooter/ChatbotFootnote.d.ts +3 -3
- package/dist/cjs/ChatbotFooter/ChatbotFootnote.js +10 -23
- package/dist/cjs/ChatbotHeader/ChatbotHeader.d.ts +3 -3
- package/dist/cjs/ChatbotHeader/ChatbotHeader.js +2 -7
- package/dist/cjs/ChatbotHeader/ChatbotHeader.test.js +5 -5
- package/dist/cjs/ChatbotHeader/ChatbotHeaderActions.d.ts +2 -2
- package/dist/cjs/ChatbotHeader/ChatbotHeaderActions.js +2 -5
- package/dist/cjs/ChatbotHeader/ChatbotHeaderActions.test.js +5 -5
- package/dist/cjs/ChatbotHeader/ChatbotHeaderCloseButton.d.ts +1 -2
- package/dist/cjs/ChatbotHeader/ChatbotHeaderCloseButton.js +5 -10
- package/dist/cjs/ChatbotHeader/ChatbotHeaderCloseButton.test.js +7 -10
- package/dist/cjs/ChatbotHeader/ChatbotHeaderMain.d.ts +2 -2
- package/dist/cjs/ChatbotHeader/ChatbotHeaderMain.js +2 -5
- package/dist/cjs/ChatbotHeader/ChatbotHeaderMain.test.js +5 -5
- package/dist/cjs/ChatbotHeader/ChatbotHeaderMenu.d.ts +2 -2
- package/dist/cjs/ChatbotHeader/ChatbotHeaderMenu.js +5 -7
- package/dist/cjs/ChatbotHeader/ChatbotHeaderMenu.test.js +7 -10
- package/dist/cjs/ChatbotHeader/ChatbotHeaderOptionsDropdown.d.ts +6 -3
- package/dist/cjs/ChatbotHeader/ChatbotHeaderOptionsDropdown.js +8 -9
- package/dist/cjs/ChatbotHeader/ChatbotHeaderOptionsDropdown.test.js +19 -21
- package/dist/cjs/ChatbotHeader/ChatbotHeaderSelectorDropdown.d.ts +6 -3
- package/dist/cjs/ChatbotHeader/ChatbotHeaderSelectorDropdown.js +9 -12
- package/dist/cjs/ChatbotHeader/ChatbotHeaderSelectorDropdown.test.js +17 -19
- package/dist/cjs/ChatbotHeader/ChatbotHeaderTitle.d.ts +2 -2
- package/dist/cjs/ChatbotHeader/ChatbotHeaderTitle.js +2 -5
- package/dist/cjs/ChatbotHeader/ChatbotHeaderTitle.test.js +23 -23
- package/dist/cjs/ChatbotModal/ChatbotModal.d.ts +2 -2
- package/dist/cjs/ChatbotModal/ChatbotModal.js +3 -9
- package/dist/cjs/ChatbotModal/ChatbotModal.test.js +4 -16
- package/dist/cjs/ChatbotPopover/ChatbotPopover.d.ts +2 -2
- package/dist/cjs/ChatbotPopover/ChatbotPopover.js +2 -8
- package/dist/cjs/ChatbotToggle/ChatbotToggle.d.ts +1 -2
- package/dist/cjs/ChatbotToggle/ChatbotToggle.js +8 -13
- package/dist/cjs/ChatbotToggle/ChatbotToggle.test.js +25 -25
- package/dist/cjs/ChatbotWelcomePrompt/ChatbotWelcomePrompt.d.ts +2 -2
- package/dist/cjs/ChatbotWelcomePrompt/ChatbotWelcomePrompt.js +6 -20
- package/dist/cjs/ChatbotWelcomePrompt/ChatbotWelcomePrompt.test.js +16 -16
- package/dist/cjs/CodeModal/CodeModal.d.ts +8 -2
- package/dist/cjs/CodeModal/CodeModal.js +8 -20
- package/dist/cjs/CodeModal/CodeModal.test.js +23 -4
- package/dist/cjs/Compare/Compare.d.ts +2 -2
- package/dist/cjs/Compare/Compare.js +7 -16
- package/dist/cjs/Compare/Compare.test.js +7 -9
- package/dist/cjs/FileDetails/FileDetails.d.ts +2 -2
- package/dist/cjs/FileDetails/FileDetails.js +2 -15
- package/dist/cjs/FileDetails/FileDetails.test.js +10 -10
- package/dist/cjs/FileDetailsLabel/FileDetailsLabel.d.ts +2 -2
- package/dist/cjs/FileDetailsLabel/FileDetailsLabel.js +2 -5
- package/dist/cjs/FileDetailsLabel/FileDetailsLabel.test.js +21 -21
- package/dist/cjs/FileDropZone/FileDropZone.d.ts +2 -2
- package/dist/cjs/FileDropZone/FileDropZone.js +5 -8
- package/dist/cjs/FileDropZone/FileDropZone.test.js +5 -5
- package/dist/cjs/LoadingMessage/LoadingMessage.d.ts +2 -2
- package/dist/cjs/LoadingMessage/LoadingMessage.js +2 -10
- package/dist/cjs/LoadingMessage/LoadingMessage.test.js +6 -6
- package/dist/cjs/Message/CodeBlockMessage/CodeBlockMessage.d.ts +1 -2
- package/dist/cjs/Message/CodeBlockMessage/CodeBlockMessage.js +10 -15
- package/dist/cjs/Message/ErrorMessage/ErrorMessage.d.ts +1 -2
- package/dist/cjs/Message/ErrorMessage/ErrorMessage.js +5 -8
- package/dist/cjs/Message/ImageMessage/ImageMessage.d.ts +1 -2
- package/dist/cjs/Message/ImageMessage/ImageMessage.js +2 -8
- package/dist/cjs/Message/LinkMessage/LinkMessage.d.ts +1 -2
- package/dist/cjs/Message/LinkMessage/LinkMessage.js +6 -9
- package/dist/cjs/Message/ListMessage/ListItemMessage.d.ts +1 -2
- package/dist/cjs/Message/ListMessage/ListItemMessage.js +2 -8
- package/dist/cjs/Message/ListMessage/OrderedListMessage.d.ts +1 -2
- package/dist/cjs/Message/ListMessage/OrderedListMessage.js +2 -9
- package/dist/cjs/Message/ListMessage/UnorderedListMessage.d.ts +1 -2
- package/dist/cjs/Message/ListMessage/UnorderedListMessage.js +2 -9
- package/dist/cjs/Message/Message.d.ts +8 -7
- package/dist/cjs/Message/Message.js +47 -70
- package/dist/cjs/Message/Message.test.js +75 -79
- package/dist/cjs/Message/MessageInput.d.ts +2 -2
- package/dist/cjs/Message/MessageInput.js +5 -14
- package/dist/cjs/Message/MessageLoading.d.ts +1 -2
- package/dist/cjs/Message/MessageLoading.js +3 -8
- package/dist/cjs/Message/QuickResponse/QuickResponse.d.ts +2 -2
- package/dist/cjs/Message/QuickResponse/QuickResponse.js +7 -9
- package/dist/cjs/Message/QuickStarts/FallbackImg.d.ts +2 -2
- package/dist/cjs/Message/QuickStarts/FallbackImg.js +5 -27
- package/dist/cjs/Message/QuickStarts/QuickStartTile.d.ts +2 -2
- package/dist/cjs/Message/QuickStarts/QuickStartTile.js +7 -43
- package/dist/cjs/Message/QuickStarts/QuickStartTileDescription.d.ts +2 -2
- package/dist/cjs/Message/QuickStarts/QuickStartTileDescription.js +9 -38
- package/dist/cjs/Message/QuickStarts/QuickStartTileDescription.test.js +16 -16
- package/dist/cjs/Message/QuickStarts/QuickStartTileHeader.d.ts +2 -2
- package/dist/cjs/Message/QuickStarts/QuickStartTileHeader.js +2 -26
- package/dist/cjs/Message/QuickStarts/types.d.ts +4 -3
- package/dist/cjs/Message/TableMessage/TableMessage.d.ts +1 -2
- package/dist/cjs/Message/TableMessage/TableMessage.js +8 -10
- package/dist/cjs/Message/TableMessage/TbodyMessage.d.ts +2 -3
- package/dist/cjs/Message/TableMessage/TbodyMessage.js +7 -9
- package/dist/cjs/Message/TableMessage/TdMessage.d.ts +1 -2
- package/dist/cjs/Message/TableMessage/TdMessage.js +2 -8
- package/dist/cjs/Message/TableMessage/ThMessage.d.ts +1 -2
- package/dist/cjs/Message/TableMessage/ThMessage.js +2 -8
- package/dist/cjs/Message/TableMessage/TheadMessage.d.ts +1 -2
- package/dist/cjs/Message/TableMessage/TheadMessage.js +2 -8
- package/dist/cjs/Message/TableMessage/TrMessage.d.ts +2 -3
- package/dist/cjs/Message/TableMessage/TrMessage.js +8 -10
- package/dist/cjs/Message/TextMessage/TextMessage.d.ts +1 -2
- package/dist/cjs/Message/TextMessage/TextMessage.js +2 -9
- package/dist/cjs/Message/UserFeedback/CloseButton.d.ts +2 -2
- package/dist/cjs/Message/UserFeedback/CloseButton.js +2 -8
- package/dist/cjs/Message/UserFeedback/UserFeedback.d.ts +2 -2
- package/dist/cjs/Message/UserFeedback/UserFeedback.js +12 -23
- package/dist/cjs/Message/UserFeedback/UserFeedback.test.js +53 -53
- package/dist/cjs/Message/UserFeedback/UserFeedbackComplete.d.ts +2 -2
- package/dist/cjs/Message/UserFeedback/UserFeedbackComplete.js +20 -44
- package/dist/cjs/Message/UserFeedback/UserFeedbackComplete.test.js +81 -91
- package/dist/cjs/MessageBar/AttachButton.d.ts +1 -2
- package/dist/cjs/MessageBar/AttachButton.js +6 -15
- package/dist/cjs/MessageBar/AttachButton.test.js +24 -24
- package/dist/cjs/MessageBar/MessageBar.d.ts +2 -2
- package/dist/cjs/MessageBar/MessageBar.js +21 -27
- package/dist/cjs/MessageBar/MessageBar.test.js +101 -115
- package/dist/cjs/MessageBar/MicrophoneButton.d.ts +2 -2
- package/dist/cjs/MessageBar/MicrophoneButton.js +7 -14
- package/dist/cjs/MessageBar/SendButton.d.ts +3 -2
- package/dist/cjs/MessageBar/SendButton.js +3 -11
- package/dist/cjs/MessageBar/SendButton.test.js +15 -15
- package/dist/cjs/MessageBar/StopButton.d.ts +3 -2
- package/dist/cjs/MessageBar/StopButton.js +3 -12
- package/dist/cjs/MessageBar/StopButton.test.js +15 -15
- package/dist/cjs/MessageBox/JumpButton.d.ts +2 -2
- package/dist/cjs/MessageBox/JumpButton.js +2 -10
- package/dist/cjs/MessageBox/JumpButton.test.js +10 -10
- package/dist/cjs/MessageBox/MessageBox.d.ts +3 -3
- package/dist/cjs/MessageBox/MessageBox.js +13 -20
- package/dist/cjs/MessageBox/MessageBox.test.js +7 -10
- package/dist/cjs/PreviewAttachment/PreviewAttachment.d.ts +12 -2
- package/dist/cjs/PreviewAttachment/PreviewAttachment.js +3 -6
- package/dist/cjs/PreviewAttachment/PreviewAttachment.test.d.ts +1 -1
- package/dist/cjs/PreviewAttachment/PreviewAttachment.test.js +34 -12
- package/dist/cjs/ResponseActions/ResponseActionButton.d.ts +3 -3
- package/dist/cjs/ResponseActions/ResponseActionButton.js +5 -8
- package/dist/cjs/ResponseActions/ResponseActionButton.test.js +19 -19
- package/dist/cjs/ResponseActions/ResponseActions.d.ts +2 -2
- package/dist/cjs/ResponseActions/ResponseActions.js +10 -14
- package/dist/cjs/ResponseActions/ResponseActions.test.js +42 -42
- package/dist/cjs/Settings/SettingsForm.d.ts +2 -2
- package/dist/cjs/Settings/SettingsForm.js +2 -8
- package/dist/cjs/Settings/SettingsForm.test.js +9 -12
- package/dist/cjs/SourceDetailsMenuItem/SourceDetailsMenuItem.d.ts +2 -2
- package/dist/cjs/SourceDetailsMenuItem/SourceDetailsMenuItem.js +2 -11
- package/dist/cjs/SourcesCard/SourcesCard.d.ts +2 -2
- package/dist/cjs/SourcesCard/SourcesCard.js +16 -42
- package/dist/cjs/SourcesCard/SourcesCard.test.js +60 -60
- package/dist/cjs/TermsOfUse/TermsOfUse.d.ts +3 -3
- package/dist/cjs/TermsOfUse/TermsOfUse.js +4 -16
- package/dist/cjs/TermsOfUse/TermsOfUse.test.js +31 -33
- package/dist/esm/AttachMenu/AttachMenu.d.ts +2 -2
- package/dist/esm/AttachMenu/AttachMenu.js +2 -9
- package/dist/esm/AttachmentEdit/AttachmentEdit.d.ts +12 -2
- package/dist/esm/AttachmentEdit/AttachmentEdit.js +3 -6
- package/dist/esm/AttachmentEdit/AttachmentEdit.test.d.ts +1 -1
- package/dist/esm/AttachmentEdit/AttachmentEdit.test.js +30 -5
- package/dist/esm/Chatbot/Chatbot.d.ts +1 -2
- package/dist/esm/Chatbot/Chatbot.js +4 -6
- package/dist/esm/Chatbot/Chatbot.test.js +6 -6
- package/dist/esm/ChatbotAlert/ChatbotAlert.d.ts +2 -2
- package/dist/esm/ChatbotAlert/ChatbotAlert.js +4 -5
- package/dist/esm/ChatbotAlert/ChatbotAlert.test.js +4 -4
- package/dist/esm/ChatbotContent/ChatbotContent.d.ts +3 -3
- package/dist/esm/ChatbotContent/ChatbotContent.js +2 -5
- package/dist/esm/ChatbotContent/ChatbotContent.test.js +3 -3
- package/dist/esm/ChatbotConversationHistoryNav/ChatbotConversationHistoryDropdown.d.ts +2 -2
- package/dist/esm/ChatbotConversationHistoryNav/ChatbotConversationHistoryDropdown.js +7 -11
- package/dist/esm/ChatbotConversationHistoryNav/ChatbotConversationHistoryDropdown.test.js +8 -10
- package/dist/esm/ChatbotConversationHistoryNav/ChatbotConversationHistoryNav.d.ts +2 -2
- package/dist/esm/ChatbotConversationHistoryNav/ChatbotConversationHistoryNav.js +16 -33
- package/dist/esm/ChatbotConversationHistoryNav/ChatbotConversationHistoryNav.test.js +26 -34
- package/dist/esm/ChatbotConversationHistoryNav/EmptyState.d.ts +2 -2
- package/dist/esm/ChatbotConversationHistoryNav/EmptyState.js +2 -6
- package/dist/esm/ChatbotConversationHistoryNav/LoadingState.d.ts +2 -2
- package/dist/esm/ChatbotConversationHistoryNav/LoadingState.js +2 -22
- package/dist/esm/ChatbotFooter/ChatbotFooter.d.ts +3 -3
- package/dist/esm/ChatbotFooter/ChatbotFooter.js +2 -12
- package/dist/esm/ChatbotFooter/ChatbotFooter.test.js +4 -4
- package/dist/esm/ChatbotFooter/ChatbotFooternote.test.js +5 -5
- package/dist/esm/ChatbotFooter/ChatbotFootnote.d.ts +3 -3
- package/dist/esm/ChatbotFooter/ChatbotFootnote.js +10 -23
- package/dist/esm/ChatbotHeader/ChatbotHeader.d.ts +3 -3
- package/dist/esm/ChatbotHeader/ChatbotHeader.js +2 -4
- package/dist/esm/ChatbotHeader/ChatbotHeader.test.js +3 -3
- package/dist/esm/ChatbotHeader/ChatbotHeaderActions.d.ts +2 -2
- package/dist/esm/ChatbotHeader/ChatbotHeaderActions.js +2 -2
- package/dist/esm/ChatbotHeader/ChatbotHeaderActions.test.js +3 -3
- package/dist/esm/ChatbotHeader/ChatbotHeaderCloseButton.d.ts +1 -2
- package/dist/esm/ChatbotHeader/ChatbotHeaderCloseButton.js +5 -7
- package/dist/esm/ChatbotHeader/ChatbotHeaderCloseButton.test.js +4 -4
- package/dist/esm/ChatbotHeader/ChatbotHeaderMain.d.ts +2 -2
- package/dist/esm/ChatbotHeader/ChatbotHeaderMain.js +2 -2
- package/dist/esm/ChatbotHeader/ChatbotHeaderMain.test.js +3 -3
- package/dist/esm/ChatbotHeader/ChatbotHeaderMenu.d.ts +2 -2
- package/dist/esm/ChatbotHeader/ChatbotHeaderMenu.js +5 -7
- package/dist/esm/ChatbotHeader/ChatbotHeaderMenu.test.js +4 -4
- package/dist/esm/ChatbotHeader/ChatbotHeaderOptionsDropdown.d.ts +6 -3
- package/dist/esm/ChatbotHeader/ChatbotHeaderOptionsDropdown.js +8 -9
- package/dist/esm/ChatbotHeader/ChatbotHeaderOptionsDropdown.test.js +9 -8
- package/dist/esm/ChatbotHeader/ChatbotHeaderSelectorDropdown.d.ts +6 -3
- package/dist/esm/ChatbotHeader/ChatbotHeaderSelectorDropdown.js +9 -9
- package/dist/esm/ChatbotHeader/ChatbotHeaderSelectorDropdown.test.js +9 -8
- package/dist/esm/ChatbotHeader/ChatbotHeaderTitle.d.ts +2 -2
- package/dist/esm/ChatbotHeader/ChatbotHeaderTitle.js +2 -2
- package/dist/esm/ChatbotHeader/ChatbotHeaderTitle.test.js +12 -12
- package/dist/esm/ChatbotModal/ChatbotModal.d.ts +2 -2
- package/dist/esm/ChatbotModal/ChatbotModal.js +3 -6
- package/dist/esm/ChatbotModal/ChatbotModal.test.js +2 -14
- package/dist/esm/ChatbotPopover/ChatbotPopover.d.ts +2 -2
- package/dist/esm/ChatbotPopover/ChatbotPopover.js +2 -5
- package/dist/esm/ChatbotToggle/ChatbotToggle.d.ts +1 -2
- package/dist/esm/ChatbotToggle/ChatbotToggle.js +8 -13
- package/dist/esm/ChatbotToggle/ChatbotToggle.test.js +8 -8
- package/dist/esm/ChatbotWelcomePrompt/ChatbotWelcomePrompt.d.ts +2 -2
- package/dist/esm/ChatbotWelcomePrompt/ChatbotWelcomePrompt.js +6 -17
- package/dist/esm/ChatbotWelcomePrompt/ChatbotWelcomePrompt.test.js +8 -8
- package/dist/esm/CodeModal/CodeModal.d.ts +8 -2
- package/dist/esm/CodeModal/CodeModal.js +8 -20
- package/dist/esm/CodeModal/CodeModal.test.js +22 -3
- package/dist/esm/Compare/Compare.d.ts +2 -2
- package/dist/esm/Compare/Compare.js +7 -13
- package/dist/esm/Compare/Compare.test.js +4 -6
- package/dist/esm/FileDetails/FileDetails.d.ts +2 -2
- package/dist/esm/FileDetails/FileDetails.js +2 -15
- package/dist/esm/FileDetails/FileDetails.test.js +4 -4
- package/dist/esm/FileDetailsLabel/FileDetailsLabel.d.ts +2 -2
- package/dist/esm/FileDetailsLabel/FileDetailsLabel.js +2 -5
- package/dist/esm/FileDetailsLabel/FileDetailsLabel.test.js +9 -9
- package/dist/esm/FileDropZone/FileDropZone.d.ts +2 -2
- package/dist/esm/FileDropZone/FileDropZone.js +5 -5
- package/dist/esm/FileDropZone/FileDropZone.test.js +3 -3
- package/dist/esm/LoadingMessage/LoadingMessage.d.ts +2 -2
- package/dist/esm/LoadingMessage/LoadingMessage.js +2 -10
- package/dist/esm/LoadingMessage/LoadingMessage.test.js +3 -3
- package/dist/esm/Message/CodeBlockMessage/CodeBlockMessage.d.ts +1 -2
- package/dist/esm/Message/CodeBlockMessage/CodeBlockMessage.js +10 -15
- package/dist/esm/Message/ErrorMessage/ErrorMessage.d.ts +1 -2
- package/dist/esm/Message/ErrorMessage/ErrorMessage.js +5 -5
- package/dist/esm/Message/ImageMessage/ImageMessage.d.ts +1 -2
- package/dist/esm/Message/ImageMessage/ImageMessage.js +2 -5
- package/dist/esm/Message/LinkMessage/LinkMessage.d.ts +1 -2
- package/dist/esm/Message/LinkMessage/LinkMessage.js +6 -6
- package/dist/esm/Message/ListMessage/ListItemMessage.d.ts +1 -2
- package/dist/esm/Message/ListMessage/ListItemMessage.js +2 -5
- package/dist/esm/Message/ListMessage/OrderedListMessage.d.ts +1 -2
- package/dist/esm/Message/ListMessage/OrderedListMessage.js +2 -6
- package/dist/esm/Message/ListMessage/UnorderedListMessage.d.ts +1 -2
- package/dist/esm/Message/ListMessage/UnorderedListMessage.js +2 -6
- package/dist/esm/Message/Message.d.ts +8 -7
- package/dist/esm/Message/Message.js +47 -70
- package/dist/esm/Message/Message.test.js +75 -79
- package/dist/esm/Message/MessageInput.d.ts +2 -2
- package/dist/esm/Message/MessageInput.js +5 -11
- package/dist/esm/Message/MessageLoading.d.ts +1 -2
- package/dist/esm/Message/MessageLoading.js +2 -4
- package/dist/esm/Message/QuickResponse/QuickResponse.d.ts +2 -2
- package/dist/esm/Message/QuickResponse/QuickResponse.js +7 -6
- package/dist/esm/Message/QuickStarts/FallbackImg.d.ts +2 -2
- package/dist/esm/Message/QuickStarts/FallbackImg.js +5 -4
- package/dist/esm/Message/QuickStarts/QuickStartTile.d.ts +2 -2
- package/dist/esm/Message/QuickStarts/QuickStartTile.js +7 -20
- package/dist/esm/Message/QuickStarts/QuickStartTileDescription.d.ts +2 -2
- package/dist/esm/Message/QuickStarts/QuickStartTileDescription.js +9 -15
- package/dist/esm/Message/QuickStarts/QuickStartTileDescription.test.js +5 -5
- package/dist/esm/Message/QuickStarts/QuickStartTileHeader.d.ts +2 -2
- package/dist/esm/Message/QuickStarts/QuickStartTileHeader.js +2 -3
- package/dist/esm/Message/QuickStarts/types.d.ts +4 -3
- package/dist/esm/Message/TableMessage/TableMessage.d.ts +1 -2
- package/dist/esm/Message/TableMessage/TableMessage.js +8 -7
- package/dist/esm/Message/TableMessage/TbodyMessage.d.ts +2 -3
- package/dist/esm/Message/TableMessage/TbodyMessage.js +7 -6
- package/dist/esm/Message/TableMessage/TdMessage.d.ts +1 -2
- package/dist/esm/Message/TableMessage/TdMessage.js +2 -5
- package/dist/esm/Message/TableMessage/ThMessage.d.ts +1 -2
- package/dist/esm/Message/TableMessage/ThMessage.js +2 -5
- package/dist/esm/Message/TableMessage/TheadMessage.d.ts +1 -2
- package/dist/esm/Message/TableMessage/TheadMessage.js +2 -5
- package/dist/esm/Message/TableMessage/TrMessage.d.ts +2 -3
- package/dist/esm/Message/TableMessage/TrMessage.js +8 -7
- package/dist/esm/Message/TextMessage/TextMessage.d.ts +1 -2
- package/dist/esm/Message/TextMessage/TextMessage.js +2 -6
- package/dist/esm/Message/UserFeedback/CloseButton.d.ts +2 -2
- package/dist/esm/Message/UserFeedback/CloseButton.js +2 -5
- package/dist/esm/Message/UserFeedback/UserFeedback.d.ts +2 -2
- package/dist/esm/Message/UserFeedback/UserFeedback.js +12 -23
- package/dist/esm/Message/UserFeedback/UserFeedback.test.js +21 -21
- package/dist/esm/Message/UserFeedback/UserFeedbackComplete.d.ts +2 -2
- package/dist/esm/Message/UserFeedback/UserFeedbackComplete.js +20 -44
- package/dist/esm/Message/UserFeedback/UserFeedbackComplete.test.js +26 -36
- package/dist/esm/MessageBar/AttachButton.d.ts +1 -2
- package/dist/esm/MessageBar/AttachButton.js +6 -12
- package/dist/esm/MessageBar/AttachButton.test.js +10 -10
- package/dist/esm/MessageBar/MessageBar.d.ts +2 -2
- package/dist/esm/MessageBar/MessageBar.js +21 -27
- package/dist/esm/MessageBar/MessageBar.test.js +34 -48
- package/dist/esm/MessageBar/MicrophoneButton.d.ts +2 -2
- package/dist/esm/MessageBar/MicrophoneButton.js +7 -11
- package/dist/esm/MessageBar/SendButton.d.ts +3 -2
- package/dist/esm/MessageBar/SendButton.js +3 -8
- package/dist/esm/MessageBar/SendButton.test.js +4 -4
- package/dist/esm/MessageBar/StopButton.d.ts +3 -2
- package/dist/esm/MessageBar/StopButton.js +3 -9
- package/dist/esm/MessageBar/StopButton.test.js +4 -4
- package/dist/esm/MessageBox/JumpButton.d.ts +2 -2
- package/dist/esm/MessageBox/JumpButton.js +2 -7
- package/dist/esm/MessageBox/JumpButton.test.js +5 -5
- package/dist/esm/MessageBox/MessageBox.d.ts +3 -3
- package/dist/esm/MessageBox/MessageBox.js +13 -20
- package/dist/esm/MessageBox/MessageBox.test.js +7 -10
- package/dist/esm/PreviewAttachment/PreviewAttachment.d.ts +12 -2
- package/dist/esm/PreviewAttachment/PreviewAttachment.js +3 -6
- package/dist/esm/PreviewAttachment/PreviewAttachment.test.d.ts +1 -1
- package/dist/esm/PreviewAttachment/PreviewAttachment.test.js +30 -5
- package/dist/esm/ResponseActions/ResponseActionButton.d.ts +3 -3
- package/dist/esm/ResponseActions/ResponseActionButton.js +5 -5
- package/dist/esm/ResponseActions/ResponseActionButton.test.js +7 -7
- package/dist/esm/ResponseActions/ResponseActions.d.ts +2 -2
- package/dist/esm/ResponseActions/ResponseActions.js +10 -14
- package/dist/esm/ResponseActions/ResponseActions.test.js +15 -15
- package/dist/esm/Settings/SettingsForm.d.ts +2 -2
- package/dist/esm/Settings/SettingsForm.js +2 -5
- package/dist/esm/Settings/SettingsForm.test.js +6 -6
- package/dist/esm/SourceDetailsMenuItem/SourceDetailsMenuItem.d.ts +2 -2
- package/dist/esm/SourceDetailsMenuItem/SourceDetailsMenuItem.js +2 -8
- package/dist/esm/SourcesCard/SourcesCard.d.ts +2 -2
- package/dist/esm/SourcesCard/SourcesCard.js +16 -39
- package/dist/esm/SourcesCard/SourcesCard.test.js +19 -19
- package/dist/esm/TermsOfUse/TermsOfUse.d.ts +3 -3
- package/dist/esm/TermsOfUse/TermsOfUse.js +4 -16
- package/dist/esm/TermsOfUse/TermsOfUse.test.js +10 -12
- package/package.json +3 -5
- package/patternfly-docs/content/extensions/chatbot/examples/Messages/AttachMenu.tsx +9 -9
- package/patternfly-docs/content/extensions/chatbot/examples/Messages/AttachmentEdit.tsx +5 -5
- package/patternfly-docs/content/extensions/chatbot/examples/Messages/AttachmentError.tsx +2 -2
- package/patternfly-docs/content/extensions/chatbot/examples/Messages/BotMessage.tsx +10 -12
- package/patternfly-docs/content/extensions/chatbot/examples/Messages/FileDetails.tsx +2 -2
- package/patternfly-docs/content/extensions/chatbot/examples/Messages/FileDetailsLabel.tsx +9 -9
- package/patternfly-docs/content/extensions/chatbot/examples/Messages/FileDropZone.tsx +4 -4
- package/patternfly-docs/content/extensions/chatbot/examples/Messages/MessageWithAttachment.tsx +7 -7
- package/patternfly-docs/content/extensions/chatbot/examples/Messages/MessageWithCustomResponseActions.tsx +2 -2
- package/patternfly-docs/content/extensions/chatbot/examples/Messages/MessageWithFeedback.tsx +4 -4
- package/patternfly-docs/content/extensions/chatbot/examples/Messages/MessageWithFeedbackTimeout.tsx +3 -3
- package/patternfly-docs/content/extensions/chatbot/examples/Messages/MessageWithQuickResponses.tsx +2 -2
- package/patternfly-docs/content/extensions/chatbot/examples/Messages/MessageWithQuickStart.tsx +2 -2
- package/patternfly-docs/content/extensions/chatbot/examples/Messages/MessageWithResponseActions.tsx +2 -2
- package/patternfly-docs/content/extensions/chatbot/examples/Messages/MessageWithSources.tsx +3 -3
- package/patternfly-docs/content/extensions/chatbot/examples/Messages/Messages.md +1 -0
- package/patternfly-docs/content/extensions/chatbot/examples/Messages/PreviewAttachment.tsx +5 -5
- package/patternfly-docs/content/extensions/chatbot/examples/Messages/UserMessage.tsx +11 -14
- package/patternfly-docs/content/extensions/chatbot/examples/Messages/UserMessageWithExtraContent.tsx +4 -4
- package/patternfly-docs/content/extensions/chatbot/examples/UI/ChatbotContainer.tsx +59 -36
- package/patternfly-docs/content/extensions/chatbot/examples/UI/ChatbotFooter.tsx +2 -2
- package/patternfly-docs/content/extensions/chatbot/examples/UI/ChatbotFootnote.tsx +2 -2
- package/patternfly-docs/content/extensions/chatbot/examples/UI/ChatbotHeaderBasic.tsx +10 -13
- package/patternfly-docs/content/extensions/chatbot/examples/UI/ChatbotHeaderDrawer.tsx +10 -10
- package/patternfly-docs/content/extensions/chatbot/examples/UI/ChatbotHeaderDrawerNavigation.tsx +5 -5
- package/patternfly-docs/content/extensions/chatbot/examples/UI/ChatbotHeaderDrawerResizable.tsx +5 -5
- package/patternfly-docs/content/extensions/chatbot/examples/UI/ChatbotHeaderDrawerWithActions.tsx +4 -4
- package/patternfly-docs/content/extensions/chatbot/examples/UI/ChatbotHeaderDrawerWithSelection.tsx +5 -5
- package/patternfly-docs/content/extensions/chatbot/examples/UI/ChatbotHeaderTitle.tsx +59 -34
- package/patternfly-docs/content/extensions/chatbot/examples/UI/ChatbotMessageBar.tsx +2 -2
- package/patternfly-docs/content/extensions/chatbot/examples/UI/ChatbotMessageBarAttach.tsx +9 -9
- package/patternfly-docs/content/extensions/chatbot/examples/UI/ChatbotMessageBarDisabled.tsx +3 -3
- package/patternfly-docs/content/extensions/chatbot/examples/UI/ChatbotMessageBarLanguage.tsx +2 -2
- package/patternfly-docs/content/extensions/chatbot/examples/UI/ChatbotMessageBarStop.tsx +2 -2
- package/patternfly-docs/content/extensions/chatbot/examples/UI/ChatbotModal.tsx +74 -37
- package/patternfly-docs/content/extensions/chatbot/examples/UI/ChatbotToggleBasic.tsx +3 -3
- package/patternfly-docs/content/extensions/chatbot/examples/UI/ChatbotWelcomeInteraction.tsx +7 -7
- package/patternfly-docs/content/extensions/chatbot/examples/UI/ChatbotWelcomePrompt.tsx +3 -3
- package/patternfly-docs/content/extensions/chatbot/examples/UI/CompactSettings.tsx +16 -23
- package/patternfly-docs/content/extensions/chatbot/examples/UI/CustomClosedIcon.tsx +3 -3
- package/patternfly-docs/content/extensions/chatbot/examples/UI/Settings.tsx +16 -23
- package/patternfly-docs/content/extensions/chatbot/examples/UI/SkipToContent.tsx +5 -5
- package/patternfly-docs/content/extensions/chatbot/examples/UI/SquareChatbotToggle.tsx +3 -3
- package/patternfly-docs/content/extensions/chatbot/examples/UI/TermsOfUse.tsx +91 -48
- package/patternfly-docs/content/extensions/chatbot/examples/UI/TermsOfUseCompact.tsx +82 -39
- package/patternfly-docs/content/extensions/chatbot/examples/UI/UI.md +3 -0
- package/patternfly-docs/content/extensions/chatbot/examples/demos/AttachmentDemos.md +1 -0
- package/patternfly-docs/content/extensions/chatbot/examples/demos/Chatbot.md +1 -0
- package/patternfly-docs/content/extensions/chatbot/examples/demos/Chatbot.tsx +17 -23
- package/patternfly-docs/content/extensions/chatbot/examples/demos/ChatbotAttachment.tsx +13 -13
- package/patternfly-docs/content/extensions/chatbot/examples/demos/ChatbotAttachmentMenu.tsx +14 -14
- package/patternfly-docs/content/extensions/chatbot/examples/demos/ChatbotCompact.tsx +17 -23
- package/patternfly-docs/content/extensions/chatbot/examples/demos/ChatbotInDrawer.tsx +15 -20
- package/patternfly-docs/content/extensions/chatbot/examples/demos/EmbeddedChatbot.tsx +15 -20
- package/patternfly-docs/content/extensions/chatbot/examples/demos/EmbeddedComparisonChatbot.tsx +12 -12
- package/patternfly-docs/content/extensions/chatbot/examples/demos/Feedback.tsx +7 -7
- package/src/AttachMenu/AttachMenu.tsx +2 -2
- package/src/AttachmentEdit/AttachmentEdit.test.tsx +46 -2
- package/src/AttachmentEdit/AttachmentEdit.tsx +25 -7
- package/src/Chatbot/Chatbot.test.tsx +0 -1
- package/src/Chatbot/Chatbot.tsx +5 -3
- package/src/ChatbotAlert/ChatbotAlert.test.tsx +0 -1
- package/src/ChatbotAlert/ChatbotAlert.tsx +2 -2
- package/src/ChatbotContent/ChatbotContent.test.tsx +0 -1
- package/src/ChatbotContent/ChatbotContent.tsx +3 -3
- package/src/ChatbotConversationHistoryNav/ChatbotConversationHistoryDropdown.test.tsx +0 -1
- package/src/ChatbotConversationHistoryNav/ChatbotConversationHistoryDropdown.tsx +6 -4
- package/src/ChatbotConversationHistoryNav/ChatbotConversationHistoryNav.test.tsx +3 -3
- package/src/ChatbotConversationHistoryNav/ChatbotConversationHistoryNav.tsx +8 -6
- package/src/ChatbotConversationHistoryNav/EmptyState.tsx +2 -2
- package/src/ChatbotConversationHistoryNav/LoadingState.tsx +2 -2
- package/src/ChatbotFooter/ChatbotFooter.test.tsx +0 -1
- package/src/ChatbotFooter/ChatbotFooter.tsx +3 -3
- package/src/ChatbotFooter/ChatbotFooternote.test.tsx +0 -1
- package/src/ChatbotFooter/ChatbotFootnote.tsx +6 -4
- package/src/ChatbotHeader/ChatbotHeader.test.tsx +0 -1
- package/src/ChatbotHeader/ChatbotHeader.tsx +3 -6
- package/src/ChatbotHeader/ChatbotHeaderActions.test.tsx +0 -1
- package/src/ChatbotHeader/ChatbotHeaderActions.tsx +2 -2
- package/src/ChatbotHeader/ChatbotHeaderCloseButton.test.tsx +0 -1
- package/src/ChatbotHeader/ChatbotHeaderCloseButton.tsx +5 -4
- package/src/ChatbotHeader/ChatbotHeaderMain.test.tsx +0 -1
- package/src/ChatbotHeader/ChatbotHeaderMain.tsx +2 -2
- package/src/ChatbotHeader/ChatbotHeaderMenu.test.tsx +0 -1
- package/src/ChatbotHeader/ChatbotHeaderMenu.tsx +7 -7
- package/src/ChatbotHeader/ChatbotHeaderOptionsDropdown.test.tsx +9 -1
- package/src/ChatbotHeader/ChatbotHeaderOptionsDropdown.tsx +12 -5
- package/src/ChatbotHeader/ChatbotHeaderSelectorDropdown.test.tsx +9 -1
- package/src/ChatbotHeader/ChatbotHeaderSelectorDropdown.tsx +20 -6
- package/src/ChatbotHeader/ChatbotHeaderTitle.test.tsx +0 -1
- package/src/ChatbotHeader/ChatbotHeaderTitle.tsx +2 -2
- package/src/ChatbotModal/ChatbotModal.test.tsx +0 -1
- package/src/ChatbotModal/ChatbotModal.tsx +2 -2
- package/src/ChatbotPopover/ChatbotPopover.tsx +3 -3
- package/src/ChatbotToggle/ChatbotToggle.test.tsx +0 -1
- package/src/ChatbotToggle/ChatbotToggle.tsx +5 -3
- package/src/ChatbotWelcomePrompt/ChatbotWelcomePrompt.test.tsx +0 -1
- package/src/ChatbotWelcomePrompt/ChatbotWelcomePrompt.tsx +2 -2
- package/src/CodeModal/CodeModal.test.tsx +29 -2
- package/src/CodeModal/CodeModal.tsx +18 -8
- package/src/Compare/Compare.test.tsx +0 -1
- package/src/Compare/Compare.tsx +7 -6
- package/src/FileDetails/FileDetails.test.tsx +0 -1
- package/src/FileDetails/FileDetails.tsx +1 -1
- package/src/FileDetailsLabel/FileDetailsLabel.test.tsx +0 -1
- package/src/FileDetailsLabel/FileDetailsLabel.tsx +1 -1
- package/src/FileDropZone/FileDropZone.test.tsx +0 -1
- package/src/FileDropZone/FileDropZone.tsx +4 -3
- package/src/LoadingMessage/LoadingMessage.test.tsx +0 -1
- package/src/LoadingMessage/LoadingMessage.tsx +2 -2
- package/src/Message/CodeBlockMessage/CodeBlockMessage.tsx +7 -7
- package/src/Message/ErrorMessage/ErrorMessage.tsx +0 -1
- package/src/Message/ImageMessage/ImageMessage.tsx +1 -2
- package/src/Message/LinkMessage/LinkMessage.tsx +0 -1
- package/src/Message/ListMessage/ListItemMessage.tsx +0 -1
- package/src/Message/ListMessage/OrderedListMessage.tsx +0 -1
- package/src/Message/ListMessage/UnorderedListMessage.tsx +0 -1
- package/src/Message/Message.test.tsx +3 -3
- package/src/Message/Message.tsx +12 -13
- package/src/Message/MessageInput.tsx +5 -5
- package/src/Message/MessageLoading.tsx +0 -2
- package/src/Message/QuickResponse/QuickResponse.tsx +4 -3
- package/src/Message/QuickStarts/FallbackImg.tsx +4 -3
- package/src/Message/QuickStarts/QuickStartTile.tsx +3 -3
- package/src/Message/QuickStarts/QuickStartTileDescription.test.tsx +0 -1
- package/src/Message/QuickStarts/QuickStartTileDescription.tsx +4 -3
- package/src/Message/QuickStarts/QuickStartTileHeader.tsx +2 -2
- package/src/Message/QuickStarts/types.ts +4 -3
- package/src/Message/TableMessage/TableMessage.tsx +4 -4
- package/src/Message/TableMessage/TbodyMessage.tsx +3 -3
- package/src/Message/TableMessage/TdMessage.tsx +1 -2
- package/src/Message/TableMessage/ThMessage.tsx +1 -2
- package/src/Message/TableMessage/TheadMessage.tsx +3 -2
- package/src/Message/TableMessage/TrMessage.tsx +4 -4
- package/src/Message/TextMessage/TextMessage.tsx +1 -2
- package/src/Message/UserFeedback/CloseButton.tsx +2 -2
- package/src/Message/UserFeedback/UserFeedback.test.tsx +0 -1
- package/src/Message/UserFeedback/UserFeedback.tsx +8 -6
- package/src/Message/UserFeedback/UserFeedbackComplete.test.tsx +0 -1
- package/src/Message/UserFeedback/UserFeedbackComplete.tsx +16 -14
- package/src/MessageBar/AttachButton.test.tsx +0 -1
- package/src/MessageBar/AttachButton.tsx +5 -3
- package/src/MessageBar/MessageBar.test.tsx +0 -1
- package/src/MessageBar/MessageBar.tsx +19 -18
- package/src/MessageBar/MicrophoneButton.tsx +8 -6
- package/src/MessageBar/SendButton.test.tsx +0 -1
- package/src/MessageBar/SendButton.tsx +3 -2
- package/src/MessageBar/StopButton.test.tsx +0 -1
- package/src/MessageBar/StopButton.tsx +3 -2
- package/src/MessageBox/JumpButton.test.tsx +0 -1
- package/src/MessageBox/JumpButton.tsx +2 -2
- package/src/MessageBox/MessageBox.test.tsx +2 -2
- package/src/MessageBox/MessageBox.tsx +15 -13
- package/src/PreviewAttachment/PreviewAttachment.test.tsx +44 -2
- package/src/PreviewAttachment/PreviewAttachment.tsx +24 -6
- package/src/ResponseActions/ResponseActionButton.test.tsx +0 -1
- package/src/ResponseActions/ResponseActionButton.tsx +4 -3
- package/src/ResponseActions/ResponseActions.test.tsx +0 -1
- package/src/ResponseActions/ResponseActions.tsx +8 -7
- package/src/Settings/SettingsForm.test.tsx +0 -1
- package/src/Settings/SettingsForm.tsx +2 -7
- package/src/SourceDetailsMenuItem/SourceDetailsMenuItem.tsx +2 -2
- package/src/SourcesCard/SourcesCard.test.tsx +0 -1
- package/src/SourcesCard/SourcesCard.tsx +7 -7
- package/src/TermsOfUse/TermsOfUse.test.tsx +0 -1
- package/src/TermsOfUse/TermsOfUse.tsx +6 -5
- package/tsconfig.cjs.json +0 -1
- package/tsconfig.json +3 -3
@@ -7,7 +7,8 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
|
|
7
7
|
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
8
8
|
});
|
9
9
|
};
|
10
|
-
import
|
10
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
11
|
+
import { Fragment } from 'react';
|
11
12
|
import { render, screen } from '@testing-library/react';
|
12
13
|
import '@testing-library/jest-dom';
|
13
14
|
import Message from './Message';
|
@@ -138,9 +139,7 @@ const IMAGE = `,
|
143
|
-
React.createElement(AlertActionLink, { component: "a", href: "#" }, "Contact support")))
|
142
|
+
actionLinks: (_jsxs(Fragment, { children: [_jsx(AlertActionLink, { component: "a", href: "#", children: "Start a new chat" }), _jsx(AlertActionLink, { component: "a", href: "#", children: "Contact support" })] }))
|
144
143
|
};
|
145
144
|
const checkListItemsRendered = () => {
|
146
145
|
const items = ['Item 1', 'Item 2', 'Item 3'];
|
@@ -155,7 +154,7 @@ describe('Message', () => {
|
|
155
154
|
jest.clearAllMocks();
|
156
155
|
});
|
157
156
|
it('should render user messages correctly', () => {
|
158
|
-
render(
|
157
|
+
render(_jsx(Message, { avatar: "./img", role: "user", name: "User", content: "Hi" }));
|
159
158
|
expect(screen.getByText('User')).toBeTruthy();
|
160
159
|
expect(screen.getByText('Hi')).toBeTruthy();
|
161
160
|
const date = new Date();
|
@@ -169,7 +168,7 @@ describe('Message', () => {
|
|
169
168
|
expect(screen.getByRole('img')).toHaveAttribute('src', './img');
|
170
169
|
});
|
171
170
|
it('should render bot messages correctly', () => {
|
172
|
-
render(
|
171
|
+
render(_jsx(Message, { avatar: "./img", role: "bot", name: "Bot", content: "Hi" }));
|
173
172
|
expect(screen.getByText('Bot')).toBeTruthy();
|
174
173
|
expect(screen.getByText('AI')).toBeTruthy();
|
175
174
|
expect(screen.getByText('Hi')).toBeTruthy();
|
@@ -182,18 +181,18 @@ describe('Message', () => {
|
|
182
181
|
})).toBeInTheDocument();
|
183
182
|
});
|
184
183
|
it('should render avatar correctly', () => {
|
185
|
-
render(
|
184
|
+
render(_jsx(Message, { avatar: "./testImg", role: "bot", name: "Bot", content: "Hi" }));
|
186
185
|
expect(screen.getByRole('img')).toHaveAttribute('src', './testImg');
|
187
186
|
});
|
188
187
|
it('should render botWord correctly', () => {
|
189
|
-
render(
|
188
|
+
render(_jsx(Message, { avatar: "./img", role: "bot", name: "Bot", content: "Hi", botWord: "\u4EBA\u5DE5\u77E5\u80FD" }));
|
190
189
|
expect(screen.getByText('Bot')).toBeTruthy();
|
191
190
|
expect(screen.getByText('人工知能')).toBeTruthy();
|
192
191
|
expect(screen.queryByText('AI')).toBeFalsy();
|
193
192
|
expect(screen.getByText('Hi')).toBeTruthy();
|
194
193
|
});
|
195
194
|
it('should render timestamps', () => {
|
196
|
-
render(
|
195
|
+
render(_jsx(Message, { avatar: "./img", role: "bot", name: "Bot", content: "Hi", timestamp: "2 hours ago" }));
|
197
196
|
expect(screen.getByText('Bot')).toBeTruthy();
|
198
197
|
expect(screen.getByText('AI')).toBeTruthy();
|
199
198
|
expect(screen.getByText('Hi')).toBeTruthy();
|
@@ -207,13 +206,13 @@ describe('Message', () => {
|
|
207
206
|
})).not.toBeInTheDocument();
|
208
207
|
});
|
209
208
|
it('should render attachments', () => {
|
210
|
-
render(
|
209
|
+
render(_jsx(Message, { avatar: "./img", role: "user", content: "Hi", attachments: [{ name: 'testAttachment' }] }));
|
211
210
|
expect(screen.getByText('Hi')).toBeTruthy();
|
212
211
|
expect(screen.getByText('testAttachment')).toBeTruthy();
|
213
212
|
});
|
214
213
|
it('should be able to click attachments', () => __awaiter(void 0, void 0, void 0, function* () {
|
215
214
|
const spy = jest.fn();
|
216
|
-
render(
|
215
|
+
render(_jsx(Message, { avatar: "./img", role: "user", content: "Hi", attachments: [{ name: 'testAttachment', onClick: spy }] }));
|
217
216
|
expect(screen.getByText('Hi')).toBeTruthy();
|
218
217
|
expect(screen.getByText('testAttachment')).toBeTruthy();
|
219
218
|
yield userEvent.click(screen.getByRole('button', { name: /testAttachment/i }));
|
@@ -221,7 +220,7 @@ describe('Message', () => {
|
|
221
220
|
}));
|
222
221
|
it('should be able to close attachments', () => __awaiter(void 0, void 0, void 0, function* () {
|
223
222
|
const spy = jest.fn();
|
224
|
-
render(
|
223
|
+
render(_jsx(Message, { avatar: "./img", role: "user", content: "Hi", attachments: [{ name: 'testAttachment', onClose: spy }] }));
|
225
224
|
expect(screen.getByText('Hi')).toBeTruthy();
|
226
225
|
expect(screen.getByText('testAttachment')).toBeTruthy();
|
227
226
|
expect(screen.getByRole('button', { name: /close testAttachment/i })).toBeTruthy();
|
@@ -229,7 +228,7 @@ describe('Message', () => {
|
|
229
228
|
expect(spy).toHaveBeenCalledTimes(1);
|
230
229
|
}));
|
231
230
|
it('should render loading state', () => {
|
232
|
-
render(
|
231
|
+
render(_jsx(Message, { avatar: "./img", role: "bot", name: "Bot", content: "Hi", isLoading: true }));
|
233
232
|
expect(screen.getByText('Bot')).toBeTruthy();
|
234
233
|
expect(screen.getByText('AI')).toBeTruthy();
|
235
234
|
expect(screen.queryByText('Hi')).toBeFalsy();
|
@@ -243,7 +242,7 @@ describe('Message', () => {
|
|
243
242
|
expect(screen.getByText('Loading message')).toBeTruthy();
|
244
243
|
});
|
245
244
|
it('should be able to show sources', () => __awaiter(void 0, void 0, void 0, function* () {
|
246
|
-
render(
|
245
|
+
render(_jsx(Message, { avatar: "./img", role: "bot", name: "Bot", content: "Hi", sources: {
|
247
246
|
sources: [
|
248
247
|
{
|
249
248
|
title: 'Getting started with Red Hat OpenShift',
|
@@ -255,7 +254,7 @@ describe('Message', () => {
|
|
255
254
|
expect(screen.getByText('Getting started with Red Hat OpenShift')).toBeTruthy();
|
256
255
|
}));
|
257
256
|
it('should not show sources if loading', () => {
|
258
|
-
render(
|
257
|
+
render(_jsx(Message, { avatar: "./img", role: "bot", name: "Bot", content: "Hi", isLoading: true, sources: {
|
259
258
|
sources: [
|
260
259
|
{
|
261
260
|
title: 'Getting started with Red Hat OpenShift',
|
@@ -269,7 +268,7 @@ describe('Message', () => {
|
|
269
268
|
});
|
270
269
|
it('should be able to show quick response', () => __awaiter(void 0, void 0, void 0, function* () {
|
271
270
|
const spy = jest.fn();
|
272
|
-
render(
|
271
|
+
render(_jsx(Message, { avatar: "./img", role: "bot", name: "Bot", content: "Hi", quickResponses: [
|
273
272
|
{
|
274
273
|
id: '1',
|
275
274
|
content: 'Yes',
|
@@ -283,7 +282,7 @@ describe('Message', () => {
|
|
283
282
|
expect(spy).toHaveBeenCalledTimes(1);
|
284
283
|
}));
|
285
284
|
it('should be able to handle isCompact', () => __awaiter(void 0, void 0, void 0, function* () {
|
286
|
-
render(
|
285
|
+
render(_jsx(Message, { avatar: "./img", role: "bot", name: "Bot", content: "Hi", quickResponses: [
|
287
286
|
{
|
288
287
|
id: '1',
|
289
288
|
content: 'Yes',
|
@@ -296,7 +295,7 @@ describe('Message', () => {
|
|
296
295
|
}));
|
297
296
|
it('should be able to show more than 1 quick response', () => __awaiter(void 0, void 0, void 0, function* () {
|
298
297
|
const spy = jest.fn();
|
299
|
-
render(
|
298
|
+
render(_jsx(Message, { avatar: "./img", role: "bot", name: "Bot", content: "Hi", quickResponses: [
|
300
299
|
{
|
301
300
|
id: '1',
|
302
301
|
content: 'Yes',
|
@@ -313,7 +312,7 @@ describe('Message', () => {
|
|
313
312
|
}));
|
314
313
|
it('should be able to spread quickResponseContainerProps', () => __awaiter(void 0, void 0, void 0, function* () {
|
315
314
|
const spy = jest.fn();
|
316
|
-
render(
|
315
|
+
render(_jsx(Message, { avatar: "./img", role: "bot", name: "Bot", content: "Hi", quickResponses: [
|
317
316
|
{
|
318
317
|
id: '1',
|
319
318
|
content: 'Yes',
|
@@ -333,7 +332,7 @@ describe('Message', () => {
|
|
333
332
|
expect(screen.getByRole('button', { name: /1 more/i }));
|
334
333
|
}));
|
335
334
|
it('should be able to show actions', () => __awaiter(void 0, void 0, void 0, function* () {
|
336
|
-
render(
|
335
|
+
render(_jsx(Message, { avatar: "./img", role: "bot", name: "Bot", content: "Hi", actions: {
|
337
336
|
// eslint-disable-next-line no-console
|
338
337
|
positive: { onClick: () => console.log('Good response') },
|
339
338
|
// eslint-disable-next-line no-console
|
@@ -350,7 +349,7 @@ describe('Message', () => {
|
|
350
349
|
});
|
351
350
|
}));
|
352
351
|
it('should not show actions if loading', () => __awaiter(void 0, void 0, void 0, function* () {
|
353
|
-
render(
|
352
|
+
render(_jsx(Message, { avatar: "./img", role: "bot", name: "Bot", content: "Hi", isLoading: true, actions: {
|
354
353
|
// eslint-disable-next-line no-console
|
355
354
|
positive: { onClick: () => console.log('Good response') },
|
356
355
|
// eslint-disable-next-line no-console
|
@@ -368,28 +367,28 @@ describe('Message', () => {
|
|
368
367
|
});
|
369
368
|
}));
|
370
369
|
it('should render unordered lists correctly', () => {
|
371
|
-
render(
|
370
|
+
render(_jsx(Message, { avatar: "./img", role: "user", name: "User", content: UNORDERED_LIST }));
|
372
371
|
expect(screen.getByText('Here is an unordered list:')).toBeTruthy();
|
373
372
|
checkListItemsRendered();
|
374
373
|
});
|
375
374
|
it('should render ordered lists correctly', () => {
|
376
|
-
render(
|
375
|
+
render(_jsx(Message, { avatar: "./img", role: "user", name: "User", content: ORDERED_LIST }));
|
377
376
|
expect(screen.getByText('Here is an ordered list:')).toBeTruthy();
|
378
377
|
checkListItemsRendered();
|
379
378
|
});
|
380
379
|
it('should render ordered lists correctly if there is interstitial content', () => {
|
381
|
-
render(
|
380
|
+
render(_jsx(Message, { avatar: "./img", role: "user", name: "User", content: ORDERED_LIST_WITH_CODE }));
|
382
381
|
checkListItemsRendered();
|
383
382
|
const list = screen.getAllByRole('list')[1];
|
384
383
|
expect(list).toHaveAttribute('start', '3');
|
385
384
|
});
|
386
385
|
it('should render inline code', () => {
|
387
|
-
render(
|
386
|
+
render(_jsx(Message, { avatar: "./img", role: "user", name: "User", content: INLINE_CODE }));
|
388
387
|
expect(screen.getByText(/() => void/i)).toBeTruthy();
|
389
388
|
expect(screen.queryByRole('button', { name: 'Copy code button' })).toBeFalsy();
|
390
389
|
});
|
391
390
|
it('should render code correctly', () => {
|
392
|
-
render(
|
391
|
+
render(_jsx(Message, { avatar: "./img", role: "user", name: "User", content: CODE_MESSAGE }));
|
393
392
|
expect(screen.getByText('Here is some YAML code:')).toBeTruthy();
|
394
393
|
expect(screen.getByRole('button', { name: 'Copy code' })).toBeTruthy();
|
395
394
|
expect(screen.getByText(/yaml/)).toBeTruthy();
|
@@ -406,41 +405,41 @@ describe('Message', () => {
|
|
406
405
|
it('can click copy code button', () => __awaiter(void 0, void 0, void 0, function* () {
|
407
406
|
// need explicit setup since RTL stubs clipboard if you do this
|
408
407
|
const user = userEvent.setup();
|
409
|
-
render(
|
408
|
+
render(_jsx(Message, { avatar: "./img", role: "user", name: "User", content: CODE_MESSAGE }));
|
410
409
|
expect(screen.getByRole('button', { name: 'Copy code' })).toBeTruthy();
|
411
410
|
yield user.click(screen.getByRole('button', { name: 'Copy code' }));
|
412
411
|
const clipboardText = yield navigator.clipboard.readText();
|
413
412
|
expect(clipboardText.trim()).toEqual(CODE.trim());
|
414
413
|
}));
|
415
414
|
it('should handle codeBlockProps correctly by spreading it onto the CodeMessage', () => {
|
416
|
-
render(
|
415
|
+
render(_jsx(Message, { avatar: "./img", role: "user", name: "User", content: CODE_MESSAGE, codeBlockProps: { 'aria-label': 'test' } }));
|
417
416
|
expect(screen.getByRole('button', { name: 'test' })).toBeTruthy();
|
418
417
|
});
|
419
418
|
it('should handle hasRoundAvatar correctly when it is true', () => {
|
420
|
-
render(
|
419
|
+
render(_jsx(Message, { avatar: "./img", role: "user", name: "User", content: "Hi", hasRoundAvatar: true }));
|
421
420
|
expect(screen.getByRole('img')).toBeTruthy();
|
422
421
|
expect(screen.getByRole('img')).toHaveClass('pf-chatbot__message-avatar');
|
423
422
|
expect(screen.getByRole('img')).toHaveClass('pf-chatbot__message-avatar--round');
|
424
423
|
});
|
425
424
|
it('should handle hasRoundAvatar correctly when it is false', () => {
|
426
|
-
render(
|
425
|
+
render(_jsx(Message, { avatar: "./img", role: "user", name: "User", content: "Hi", hasRoundAvatar: false }));
|
427
426
|
expect(screen.getByRole('img')).toBeTruthy();
|
428
427
|
expect(screen.getByRole('img')).toHaveClass('pf-chatbot__message-avatar');
|
429
428
|
expect(screen.getByRole('img')).not.toHaveClass('pf-chatbot__message-avatar--round');
|
430
429
|
});
|
431
430
|
it('should handle avatarProps correctly by spreading it onto the Message Avatar', () => {
|
432
|
-
render(
|
431
|
+
render(_jsx(Message, { avatar: "./img", role: "user", name: "User", content: "Hi", avatarProps: { className: 'test' } }));
|
433
432
|
expect(screen.getByRole('img')).toBeTruthy();
|
434
433
|
expect(screen.getByRole('img')).toHaveClass('test');
|
435
434
|
});
|
436
435
|
it('should handle avatarProps and hasRoundAvatar correctly', () => {
|
437
|
-
render(
|
436
|
+
render(_jsx(Message, { avatar: "./img", role: "user", name: "User", content: "Hi", avatarProps: { className: 'test' }, hasRoundAvatar: false }));
|
438
437
|
expect(screen.getByRole('img')).toBeTruthy();
|
439
438
|
expect(screen.getByRole('img')).toHaveClass('test');
|
440
439
|
expect(screen.getByRole('img')).toHaveClass('pf-chatbot__message-avatar');
|
441
440
|
});
|
442
441
|
it('should handle QuickStart tile correctly', () => {
|
443
|
-
render(
|
442
|
+
render(_jsx(Message, { avatar: "./img", role: "user", name: "User", content: "Hi", quickStarts: {
|
444
443
|
quickStart: monitorSampleAppQuickStart,
|
445
444
|
onSelectQuickStart: (id) => alert(id)
|
446
445
|
} }));
|
@@ -451,7 +450,7 @@ describe('Message', () => {
|
|
451
450
|
});
|
452
451
|
it('should handle click on QuickStart tile correctly', () => __awaiter(void 0, void 0, void 0, function* () {
|
453
452
|
const spy = jest.fn();
|
454
|
-
render(
|
453
|
+
render(_jsx(Message, { avatar: "./img", role: "user", name: "User", content: "Hi", quickStarts: {
|
455
454
|
quickStart: monitorSampleAppQuickStart,
|
456
455
|
onSelectQuickStart: (id) => spy(id)
|
457
456
|
} }));
|
@@ -461,20 +460,20 @@ describe('Message', () => {
|
|
461
460
|
}));
|
462
461
|
it('should handle QuickStart tile with image correctly', () => __awaiter(void 0, void 0, void 0, function* () {
|
463
462
|
const spy = jest.fn();
|
464
|
-
render(
|
463
|
+
render(_jsx(Message, { avatar: "./img", role: "user", name: "User", content: "Hi", quickStarts: {
|
465
464
|
quickStart: monitorSampleAppQuickStartWithImage,
|
466
465
|
onSelectQuickStart: (id) => spy(id)
|
467
466
|
} }));
|
468
467
|
expect(screen.getAllByRole('img')[1]).toHaveAttribute('src', 'test.png');
|
469
468
|
}));
|
470
469
|
it('should handle block quote correctly', () => {
|
471
|
-
render(
|
470
|
+
render(_jsx(Message, { avatar: "./img", role: "user", name: "User", content: BLOCK_QUOTES }));
|
472
471
|
expect(screen.getByText(/Blockquotes can also be nested.../)).toBeTruthy();
|
473
472
|
expect(screen.getByText('...by using additional greater-than signs (>) right next to each other...')).toBeTruthy();
|
474
473
|
expect(screen.getByText(/...or with spaces between each sign./)).toBeTruthy();
|
475
474
|
});
|
476
475
|
it('should handle heading correctly', () => {
|
477
|
-
render(
|
476
|
+
render(_jsx(Message, { avatar: "./img", role: "user", name: "User", content: HEADING }));
|
478
477
|
expect(screen.getByRole('heading', { name: /h1 Heading/i })).toBeTruthy();
|
479
478
|
expect(screen.getByRole('heading', { name: /h2 Heading/i })).toBeTruthy();
|
480
479
|
expect(screen.getByRole('heading', { name: /h3 Heading/i })).toBeTruthy();
|
@@ -483,7 +482,7 @@ describe('Message', () => {
|
|
483
482
|
expect(screen.getByRole('heading', { name: /h6 Heading/i })).toBeTruthy();
|
484
483
|
});
|
485
484
|
it('should render table correctly', () => {
|
486
|
-
render(
|
485
|
+
render(_jsx(Message, { avatar: "./img", role: "user", name: "User", content: TABLE }));
|
487
486
|
expect(screen.getByRole('row', { name: /Column 1 Column 2/i })).toBeTruthy();
|
488
487
|
expect(screen.getByRole('row', { name: /Cell 1 Cell 2/i })).toBeTruthy();
|
489
488
|
expect(screen.getByRole('row', { name: /Cell 3 Cell 4/i })).toBeTruthy();
|
@@ -495,7 +494,7 @@ describe('Message', () => {
|
|
495
494
|
expect(screen.getByRole('cell', { name: /Cell 4/i })).toBeTruthy();
|
496
495
|
});
|
497
496
|
it('should render table data labels correctly for mobile breakpoint', () => {
|
498
|
-
render(
|
497
|
+
render(_jsx(Message, { avatar: "./img", role: "user", name: "User", content: TABLE }));
|
499
498
|
expect(screen.getByRole('row', { name: /Cell 1 Cell 2/i })).toHaveAttribute('extraHeaders', 'Column 1,Column 2');
|
500
499
|
expect(screen.getByRole('row', { name: /Cell 3 Cell 4/i })).toHaveAttribute('extraHeaders', 'Column 1,Column 2');
|
501
500
|
expect(screen.getByRole('cell', { name: /Cell 1/i })).toHaveAttribute('data-label', 'Column 1');
|
@@ -504,70 +503,70 @@ describe('Message', () => {
|
|
504
503
|
expect(screen.getByRole('cell', { name: /Cell 4/i })).toHaveAttribute('data-label', 'Column 2');
|
505
504
|
});
|
506
505
|
it('should render table data labels correctly for mobile breakpoint for one column table', () => {
|
507
|
-
render(
|
506
|
+
render(_jsx(Message, { avatar: "./img", role: "user", name: "User", content: ONE_COLUMN_TABLE }));
|
508
507
|
expect(screen.getByRole('row', { name: /Cell 1/i })).toHaveAttribute('extraHeaders', 'Column 1');
|
509
508
|
expect(screen.getByRole('row', { name: /Cell 2/i })).toHaveAttribute('extraHeaders', 'Column 1');
|
510
509
|
expect(screen.getByRole('cell', { name: /Cell 1/i })).toHaveAttribute('data-label', 'Column 1');
|
511
510
|
expect(screen.getByRole('cell', { name: /Cell 2/i })).toHaveAttribute('data-label', 'Column 1');
|
512
511
|
});
|
513
512
|
it('should render table data labels correctly for mobile breakpoint for one cell table', () => {
|
514
|
-
render(
|
513
|
+
render(_jsx(Message, { avatar: "./img", role: "user", name: "User", content: ONE_CELL_TABLE }));
|
515
514
|
expect(screen.getByRole('row', { name: /Cell 1/i })).toHaveAttribute('extraHeaders', 'Column 1');
|
516
515
|
expect(screen.getByRole('cell', { name: /Cell 1/i })).toHaveAttribute('data-label', 'Column 1');
|
517
516
|
});
|
518
517
|
it('should render table data labels correctly for mobile breakpoint for headerless', () => {
|
519
|
-
render(
|
518
|
+
render(_jsx(Message, { avatar: "./img", role: "user", name: "User", content: HEADERLESS_TABLE }));
|
520
519
|
expect(screen.getByRole('row', { name: /Cell 1/i })).toHaveAttribute('extraHeaders', '');
|
521
520
|
expect(screen.getByRole('cell', { name: /Cell 1/i })).not.toHaveAttribute('data-label');
|
522
521
|
});
|
523
522
|
it('should render table data labels correctly for mobile breakpoint for childless', () => {
|
524
|
-
render(
|
523
|
+
render(_jsx(Message, { avatar: "./img", role: "user", name: "User", content: CHILDLESS_TABLE }));
|
525
524
|
expect(screen.getByRole('cell')).not.toHaveAttribute('extraHeaders', 'Column 1');
|
526
525
|
});
|
527
526
|
it('should render table data labels correctly for mobile breakpoint for empty', () => {
|
528
|
-
render(
|
527
|
+
render(_jsx(Message, { avatar: "./img", role: "user", name: "User", content: EMPTY_TABLE }));
|
529
528
|
expect(screen.getByRole('cell')).not.toHaveAttribute('extraHeaders', '');
|
530
529
|
});
|
531
530
|
it('should render custom table aria label correctly', () => {
|
532
|
-
render(
|
531
|
+
render(_jsx(Message, { avatar: "./img", role: "user", name: "User", content: TABLE, tableProps: { 'aria-label': 'Test' } }));
|
533
532
|
expect(screen.getByRole('grid', { name: /Test/i })).toBeTruthy();
|
534
533
|
});
|
535
534
|
it('should render beforeMainContent with main content', () => {
|
536
535
|
const mainContent = 'Main message content';
|
537
536
|
const beforeMainContentText = 'Before main content';
|
538
|
-
const beforeMainContent =
|
539
|
-
render(
|
537
|
+
const beforeMainContent = _jsx("div", { children: beforeMainContentText });
|
538
|
+
render(_jsx(Message, { avatar: "./img", role: "user", name: "User", content: mainContent, extraContent: { beforeMainContent } }));
|
540
539
|
expect(screen.getByText(beforeMainContentText)).toBeTruthy();
|
541
540
|
expect(screen.getByText(mainContent)).toBeTruthy();
|
542
541
|
});
|
543
542
|
it('should render afterMainContent with main content', () => {
|
544
543
|
const mainContent = 'Main message content';
|
545
544
|
const afterMainContentText = 'After main content';
|
546
|
-
const afterMainContent =
|
547
|
-
render(
|
545
|
+
const afterMainContent = _jsx("div", { children: afterMainContentText });
|
546
|
+
render(_jsx(Message, { avatar: "./img", role: "user", name: "User", content: mainContent, extraContent: { afterMainContent } }));
|
548
547
|
expect(screen.getByText(afterMainContentText)).toBeTruthy();
|
549
548
|
expect(screen.getByText(mainContent)).toBeTruthy();
|
550
549
|
});
|
551
550
|
it('should render endContent with main content', () => {
|
552
551
|
const mainContent = 'Main message content';
|
553
552
|
const endMainContentText = 'End content';
|
554
|
-
const endContent =
|
555
|
-
render(
|
553
|
+
const endContent = _jsx("div", { children: endMainContentText });
|
554
|
+
render(_jsx(Message, { avatar: "./img", role: "user", name: "User", content: mainContent, extraContent: { endContent } }));
|
556
555
|
expect(screen.getByText(endMainContentText)).toBeTruthy();
|
557
556
|
expect(screen.getByText(mainContent)).toBeTruthy();
|
558
557
|
});
|
559
558
|
it('should render all parts of extraContent with main content', () => {
|
560
|
-
const beforeMainContent =
|
561
|
-
const afterMainContent =
|
562
|
-
const endContent =
|
563
|
-
render(
|
559
|
+
const beforeMainContent = _jsx("div", { children: "Before main content" });
|
560
|
+
const afterMainContent = _jsx("div", { children: "After main content" });
|
561
|
+
const endContent = _jsx("div", { children: "End content" });
|
562
|
+
render(_jsx(Message, { avatar: "./img", role: "user", name: "User", content: "Main message content", extraContent: { beforeMainContent, afterMainContent, endContent } }));
|
564
563
|
expect(screen.getByText('Before main content')).toBeTruthy();
|
565
564
|
expect(screen.getByText('Main message content')).toBeTruthy();
|
566
565
|
expect(screen.getByText('After main content')).toBeTruthy();
|
567
566
|
expect(screen.getByText('End content')).toBeTruthy();
|
568
567
|
});
|
569
568
|
it('should not render extraContent when not provided', () => {
|
570
|
-
render(
|
569
|
+
render(_jsx(Message, { avatar: "./img", role: "user", name: "User", content: "Main message content" }));
|
571
570
|
// Ensure no extraContent is rendered
|
572
571
|
expect(screen.getByText('Main message content')).toBeTruthy();
|
573
572
|
expect(screen.queryByText('Before main content')).toBeFalsy();
|
@@ -575,7 +574,7 @@ describe('Message', () => {
|
|
575
574
|
expect(screen.queryByText('end message content')).toBeFalsy();
|
576
575
|
});
|
577
576
|
it('should handle undefined or null values in extraContent gracefully', () => {
|
578
|
-
render(
|
577
|
+
render(_jsx(Message, { avatar: "./img", role: "user", name: "User", content: "Main message content", extraContent: { beforeMainContent: null, afterMainContent: undefined, endContent: null } }));
|
579
578
|
// Ensure that no extraContent is rendered if they are null or undefined
|
580
579
|
expect(screen.getByText('Main message content')).toBeTruthy();
|
581
580
|
expect(screen.queryByText('Before main content')).toBeFalsy();
|
@@ -583,64 +582,61 @@ describe('Message', () => {
|
|
583
582
|
expect(screen.queryByText('end message content')).toBeFalsy();
|
584
583
|
});
|
585
584
|
it('should render JSX in extraContent correctly', () => {
|
586
|
-
const beforeMainContent = (
|
587
|
-
|
588
|
-
const
|
589
|
-
|
590
|
-
const endContent = (React.createElement("div", { "data-testid": "end-main-content" },
|
591
|
-
React.createElement("strong", null, "Bold end content")));
|
592
|
-
render(React.createElement(Message, { avatar: "./img", role: "user", name: "User", content: "Main message content", extraContent: { beforeMainContent, afterMainContent, endContent } }));
|
585
|
+
const beforeMainContent = (_jsx("div", { "data-testid": "before-main-content", children: _jsx("strong", { children: "Bold before content" }) }));
|
586
|
+
const afterMainContent = (_jsx("div", { "data-testid": "after-main-content", children: _jsx("strong", { children: "Bold after content" }) }));
|
587
|
+
const endContent = (_jsx("div", { "data-testid": "end-main-content", children: _jsx("strong", { children: "Bold end content" }) }));
|
588
|
+
render(_jsx(Message, { avatar: "./img", role: "user", name: "User", content: "Main message content", extraContent: { beforeMainContent, afterMainContent, endContent } }));
|
593
589
|
// Check that the JSX is correctly rendered
|
594
590
|
expect(screen.getByTestId('before-main-content')).toContainHTML('<strong>Bold before content</strong>');
|
595
591
|
expect(screen.getByTestId('after-main-content')).toContainHTML('<strong>Bold after content</strong>');
|
596
592
|
expect(screen.getByTestId('end-main-content')).toContainHTML('<strong>Bold end content</strong>');
|
597
593
|
});
|
598
594
|
it('should handle image correctly', () => {
|
599
|
-
render(
|
595
|
+
render(_jsx(Message, { avatar: "./img", role: "user", name: "User", content: IMAGE }));
|
600
596
|
expect(screen.getByRole('img', { name: /Multi-colored wavy lines on a black background/i })).toBeTruthy();
|
601
597
|
});
|
602
598
|
it('should handle external links correctly', () => {
|
603
|
-
render(
|
599
|
+
render(_jsx(Message, { avatar: "./img", role: "user", name: "User", content: `[PatternFly](https://www.patternfly.org/)` }));
|
604
600
|
// we are mocking rehype libraries, so we can't test target _blank addition on links directly with RTL
|
605
601
|
expect(rehypeExternalLinks).toHaveBeenCalledTimes(1);
|
606
602
|
});
|
607
603
|
it('should handle external links correctly', () => {
|
608
|
-
render(
|
604
|
+
render(_jsx(Message, { avatar: "./img", role: "user", name: "User", content: `[PatternFly](https://www.patternfly.org/)`, openLinkInNewTab: false }));
|
609
605
|
// we are mocking rehype libraries, so we can't test target _blank addition on links directly with RTL
|
610
606
|
expect(rehypeExternalLinks).not.toHaveBeenCalled();
|
611
607
|
});
|
612
608
|
it('should handle extra link props correctly', () => __awaiter(void 0, void 0, void 0, function* () {
|
613
609
|
const spy = jest.fn();
|
614
|
-
render(
|
610
|
+
render(_jsx(Message, { avatar: "./img", role: "user", name: "User", content: `[PatternFly](https://www.patternfly.org/)`, linkProps: { onClick: spy } }));
|
615
611
|
yield userEvent.click(screen.getByRole('link', { name: /PatternFly/i }));
|
616
612
|
expect(spy).toHaveBeenCalledTimes(1);
|
617
613
|
}));
|
618
614
|
it('should handle error correctly', () => {
|
619
|
-
render(
|
615
|
+
render(_jsx(Message, { avatar: "./img", role: "user", name: "User", error: ERROR }));
|
620
616
|
expect(screen.getByRole('heading', { name: /Could not load chat/i })).toBeTruthy();
|
621
617
|
expect(screen.getByRole('link', { name: /Start a new chat/i })).toBeTruthy();
|
622
618
|
expect(screen.getByRole('link', { name: /Contact support/i })).toBeTruthy();
|
623
619
|
expect(screen.getByText('Wait a few minutes and check your network settings. If the issue persists:')).toBeTruthy();
|
624
620
|
});
|
625
621
|
it('should handle error correctly when loading', () => {
|
626
|
-
render(
|
622
|
+
render(_jsx(Message, { avatar: "./img", role: "user", name: "User", error: ERROR, isLoading: true }));
|
627
623
|
expect(screen.queryByRole('heading', { name: /Could not load chat/i })).toBeFalsy();
|
628
624
|
expect(screen.getByText('Loading message')).toBeTruthy();
|
629
625
|
});
|
630
626
|
it('should handle error correctly when these is content', () => {
|
631
|
-
render(
|
627
|
+
render(_jsx(Message, { avatar: "./img", role: "user", name: "User", error: ERROR, content: "Test" }));
|
632
628
|
expect(screen.getByRole('heading', { name: /Could not load chat/i })).toBeTruthy();
|
633
629
|
expect(screen.queryByText('Test')).toBeFalsy();
|
634
630
|
});
|
635
631
|
it('should handle isEditable when there is message content', () => {
|
636
|
-
render(
|
632
|
+
render(_jsx(Message, { avatar: "./img", role: "user", name: "User", isEditable: true, content: "Test" }));
|
637
633
|
expect(screen.getByRole('textbox')).toBeTruthy();
|
638
634
|
expect(screen.getByRole('textbox')).toHaveValue('Test');
|
639
635
|
expect(screen.getByRole('button', { name: /Update/i })).toBeTruthy();
|
640
636
|
expect(screen.getByRole('button', { name: /Cancel/i })).toBeTruthy();
|
641
637
|
});
|
642
638
|
it('should handle isEditable when there is no message content', () => {
|
643
|
-
render(
|
639
|
+
render(_jsx(Message, { avatar: "./img", role: "user", name: "User", isEditable: true }));
|
644
640
|
expect(screen.getByRole('textbox')).toBeTruthy();
|
645
641
|
expect(screen.getByRole('textbox')).toHaveValue('');
|
646
642
|
expect(screen.getByRole('textbox')).toHaveAttribute('placeholder', 'Edit prompt message...');
|
@@ -648,33 +644,33 @@ describe('Message', () => {
|
|
648
644
|
expect(screen.getByRole('button', { name: /Cancel/i })).toBeTruthy();
|
649
645
|
});
|
650
646
|
it('should be able to change edit placeholder', () => {
|
651
|
-
render(
|
647
|
+
render(_jsx(Message, { avatar: "./img", role: "user", name: "User", isEditable: true, editPlaceholder: "I am a placeholder" }));
|
652
648
|
expect(screen.getByRole('textbox')).toBeTruthy();
|
653
649
|
expect(screen.getByRole('textbox')).toHaveValue('');
|
654
650
|
expect(screen.getByRole('textbox')).toHaveAttribute('placeholder', 'I am a placeholder');
|
655
651
|
});
|
656
652
|
it('should be able to change updateWord', () => {
|
657
|
-
render(
|
653
|
+
render(_jsx(Message, { avatar: "./img", role: "user", name: "User", isEditable: true, updateWord: "Submit" }));
|
658
654
|
expect(screen.getByRole('button', { name: /Submit/i })).toBeTruthy();
|
659
655
|
});
|
660
656
|
it('should be able to change cancelWord', () => {
|
661
|
-
render(
|
657
|
+
render(_jsx(Message, { avatar: "./img", role: "user", name: "User", isEditable: true, cancelWord: "Don't submit" }));
|
662
658
|
expect(screen.getByRole('button', { name: /Don't submit/i })).toBeTruthy();
|
663
659
|
});
|
664
660
|
it('should be able to add onEditUpdate', () => __awaiter(void 0, void 0, void 0, function* () {
|
665
661
|
const spy = jest.fn();
|
666
|
-
render(
|
662
|
+
render(_jsx(Message, { avatar: "./img", role: "user", name: "User", isEditable: true, onEditUpdate: spy }));
|
667
663
|
yield userEvent.click(screen.getByRole('button', { name: /Update/i }));
|
668
664
|
expect(spy).toHaveBeenCalledTimes(1);
|
669
665
|
}));
|
670
666
|
it('should be able to add onEditCancel', () => __awaiter(void 0, void 0, void 0, function* () {
|
671
667
|
const spy = jest.fn();
|
672
|
-
render(
|
668
|
+
render(_jsx(Message, { avatar: "./img", role: "user", name: "User", isEditable: true, onEditCancel: spy }));
|
673
669
|
yield userEvent.click(screen.getByRole('button', { name: /Cancel/i }));
|
674
670
|
expect(spy).toHaveBeenCalledTimes(1);
|
675
671
|
}));
|
676
672
|
it('should be able to add editFormProps', () => {
|
677
|
-
const { container } = render(
|
673
|
+
const { container } = render(_jsx(Message, { avatar: "./img", role: "user", name: "User", isEditable: true, editFormProps: { className: 'test' } }));
|
678
674
|
const form = container.querySelector('form');
|
679
675
|
expect(form).toHaveClass('test');
|
680
676
|
});
|
@@ -1,4 +1,4 @@
|
|
1
|
-
import
|
1
|
+
import type { FunctionComponent } from 'react';
|
2
2
|
import { FormProps } from '@patternfly/react-core';
|
3
3
|
export interface MessageInputProps extends FormProps {
|
4
4
|
/** Placeholder for edit input */
|
@@ -14,5 +14,5 @@ export interface MessageInputProps extends FormProps {
|
|
14
14
|
/** Message text */
|
15
15
|
content?: string;
|
16
16
|
}
|
17
|
-
declare const MessageInput:
|
17
|
+
declare const MessageInput: FunctionComponent<MessageInputProps>;
|
18
18
|
export default MessageInput;
|
@@ -1,6 +1,3 @@
|
|
1
|
-
// ============================================================================
|
2
|
-
// Chatbot Main - Message Input
|
3
|
-
// ============================================================================
|
4
1
|
var __rest = (this && this.__rest) || function (s, e) {
|
5
2
|
var t = {};
|
6
3
|
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
|
@@ -12,18 +9,15 @@ var __rest = (this && this.__rest) || function (s, e) {
|
|
12
9
|
}
|
13
10
|
return t;
|
14
11
|
};
|
15
|
-
import
|
12
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
13
|
+
import { useState } from 'react';
|
16
14
|
import { ActionGroup, Button, Form, TextArea } from '@patternfly/react-core';
|
17
15
|
const MessageInput = (_a) => {
|
18
16
|
var { editPlaceholder = 'Edit prompt message...', updateWord = 'Update', cancelWord = 'Cancel', onEditUpdate, onEditCancel, content } = _a, props = __rest(_a, ["editPlaceholder", "updateWord", "cancelWord", "onEditUpdate", "onEditCancel", "content"]);
|
19
|
-
const [messageText, setMessageText] =
|
20
|
-
const onChange = (
|
17
|
+
const [messageText, setMessageText] = useState(content !== null && content !== void 0 ? content : '');
|
18
|
+
const onChange = (_event, value) => {
|
21
19
|
setMessageText(value);
|
22
20
|
};
|
23
|
-
return (
|
24
|
-
React.createElement(TextArea, { placeholder: editPlaceholder, value: messageText, onChange: onChange, "aria-label": editPlaceholder, autoResize: true }),
|
25
|
-
React.createElement(ActionGroup, { className: "pf-chatbot__message-edit-buttons" },
|
26
|
-
React.createElement(Button, { variant: "primary", onClick: (event) => onEditUpdate && onEditUpdate(event, messageText) }, updateWord),
|
27
|
-
React.createElement(Button, { variant: "secondary", onClick: onEditCancel }, cancelWord))));
|
21
|
+
return (_jsxs(Form, Object.assign({}, props, { children: [_jsx(TextArea, { placeholder: editPlaceholder, value: messageText, onChange: onChange, "aria-label": editPlaceholder, autoResize: true }), _jsxs(ActionGroup, { className: "pf-chatbot__message-edit-buttons", children: [_jsx(Button, { variant: "primary", onClick: (event) => onEditUpdate && onEditUpdate(event, messageText), children: updateWord }), _jsx(Button, { variant: "secondary", onClick: onEditCancel, children: cancelWord })] })] })));
|
28
22
|
};
|
29
23
|
export default MessageInput;
|
@@ -1,8 +1,6 @@
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
1
2
|
// ============================================================================
|
2
3
|
// Chatbot Main - Message - Processing
|
3
4
|
// ============================================================================
|
4
|
-
|
5
|
-
const MessageLoading = ({ loadingWord }) => (React.createElement("div", { className: "pf-chatbot__message-loading" },
|
6
|
-
React.createElement("span", { className: "pf-chatbot__message-loading-dots" },
|
7
|
-
React.createElement("span", { className: "pf-v6-screen-reader" }, loadingWord))));
|
5
|
+
const MessageLoading = ({ loadingWord }) => (_jsx("div", { className: "pf-chatbot__message-loading", children: _jsx("span", { className: "pf-chatbot__message-loading-dots", children: _jsx("span", { className: "pf-v6-screen-reader", children: loadingWord }) }) }));
|
8
6
|
export default MessageLoading;
|
@@ -1,4 +1,4 @@
|
|
1
|
-
import
|
1
|
+
import type { FunctionComponent } from 'react';
|
2
2
|
import { LabelGroupProps, LabelProps } from '@patternfly/react-core';
|
3
3
|
export interface QuickResponse extends Omit<LabelProps, 'children'> {
|
4
4
|
content: string;
|
@@ -15,5 +15,5 @@ export interface QuickResponseProps {
|
|
15
15
|
/** Sets the quick responses to compact styling */
|
16
16
|
isCompact?: boolean;
|
17
17
|
}
|
18
|
-
export declare const QuickResponse:
|
18
|
+
export declare const QuickResponse: FunctionComponent<QuickResponseProps>;
|
19
19
|
export default QuickResponse;
|