@patternfly/chatbot 2.2.0-prerelease.16 → 2.2.0-prerelease.18

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (114) hide show
  1. package/dist/cjs/AttachmentEdit/AttachmentEdit.test.d.ts +1 -0
  2. package/dist/cjs/AttachmentEdit/AttachmentEdit.test.js +52 -0
  3. package/dist/cjs/Chatbot/Chatbot.test.d.ts +1 -0
  4. package/dist/cjs/Chatbot/Chatbot.test.js +28 -0
  5. package/dist/cjs/ChatbotAlert/ChatbotAlert.test.d.ts +1 -0
  6. package/dist/cjs/ChatbotAlert/ChatbotAlert.test.js +27 -0
  7. package/dist/cjs/ChatbotContent/ChatbotContent.test.d.ts +1 -0
  8. package/dist/cjs/ChatbotContent/ChatbotContent.test.js +18 -0
  9. package/dist/cjs/ChatbotFooter/ChatbotFooter.test.d.ts +1 -0
  10. package/dist/cjs/ChatbotFooter/ChatbotFooter.test.js +18 -0
  11. package/dist/cjs/ChatbotFooter/ChatbotFooternote.test.d.ts +1 -0
  12. package/dist/cjs/ChatbotFooter/ChatbotFooternote.test.js +87 -0
  13. package/dist/cjs/ChatbotHeader/ChatbotHeader.test.d.ts +1 -0
  14. package/dist/cjs/ChatbotHeader/ChatbotHeader.test.js +18 -0
  15. package/dist/cjs/ChatbotHeader/ChatbotHeaderActions.test.d.ts +1 -0
  16. package/dist/cjs/ChatbotHeader/ChatbotHeaderActions.test.js +18 -0
  17. package/dist/cjs/ChatbotHeader/ChatbotHeaderCloseButton.test.d.ts +1 -0
  18. package/dist/cjs/ChatbotHeader/ChatbotHeaderCloseButton.test.js +20 -0
  19. package/dist/cjs/ChatbotHeader/ChatbotHeaderMain.test.d.ts +1 -0
  20. package/dist/cjs/ChatbotHeader/ChatbotHeaderMain.test.js +18 -0
  21. package/dist/cjs/ChatbotHeader/ChatbotHeaderMenu.test.d.ts +1 -0
  22. package/dist/cjs/ChatbotHeader/ChatbotHeaderMenu.test.js +20 -0
  23. package/dist/cjs/ChatbotHeader/ChatbotHeaderOptionsDropdown.test.d.ts +1 -0
  24. package/dist/cjs/ChatbotHeader/ChatbotHeaderOptionsDropdown.test.js +43 -0
  25. package/dist/cjs/ChatbotHeader/ChatbotHeaderSelectorDropdown.test.d.ts +1 -0
  26. package/dist/cjs/ChatbotHeader/ChatbotHeaderSelectorDropdown.test.js +41 -0
  27. package/dist/cjs/ChatbotHeader/ChatbotHeaderTitle.test.d.ts +1 -0
  28. package/dist/cjs/ChatbotHeader/ChatbotHeaderTitle.test.js +47 -0
  29. package/dist/cjs/MessageBar/AttachButton.js +1 -1
  30. package/dist/cjs/MessageBar/MessageBar.test.js +4 -4
  31. package/dist/cjs/MessageBox/MessageBox.test.d.ts +1 -0
  32. package/dist/cjs/MessageBox/MessageBox.test.js +22 -0
  33. package/dist/cjs/PreviewAttachment/PreviewAttachment.test.d.ts +1 -0
  34. package/dist/cjs/PreviewAttachment/PreviewAttachment.test.js +28 -0
  35. package/dist/cjs/Settings/SettingsForm.test.d.ts +1 -0
  36. package/dist/cjs/Settings/SettingsForm.test.js +26 -0
  37. package/dist/esm/AttachmentEdit/AttachmentEdit.test.d.ts +1 -0
  38. package/dist/esm/AttachmentEdit/AttachmentEdit.test.js +47 -0
  39. package/dist/esm/Chatbot/Chatbot.test.d.ts +1 -0
  40. package/dist/esm/Chatbot/Chatbot.test.js +23 -0
  41. package/dist/esm/ChatbotAlert/ChatbotAlert.test.d.ts +1 -0
  42. package/dist/esm/ChatbotAlert/ChatbotAlert.test.js +22 -0
  43. package/dist/esm/ChatbotContent/ChatbotContent.test.d.ts +1 -0
  44. package/dist/esm/ChatbotContent/ChatbotContent.test.js +13 -0
  45. package/dist/esm/ChatbotFooter/ChatbotFooter.test.d.ts +1 -0
  46. package/dist/esm/ChatbotFooter/ChatbotFooter.test.js +13 -0
  47. package/dist/esm/ChatbotFooter/ChatbotFooternote.test.d.ts +1 -0
  48. package/dist/esm/ChatbotFooter/ChatbotFooternote.test.js +82 -0
  49. package/dist/esm/ChatbotHeader/ChatbotHeader.test.d.ts +1 -0
  50. package/dist/esm/ChatbotHeader/ChatbotHeader.test.js +13 -0
  51. package/dist/esm/ChatbotHeader/ChatbotHeaderActions.test.d.ts +1 -0
  52. package/dist/esm/ChatbotHeader/ChatbotHeaderActions.test.js +13 -0
  53. package/dist/esm/ChatbotHeader/ChatbotHeaderCloseButton.test.d.ts +1 -0
  54. package/dist/esm/ChatbotHeader/ChatbotHeaderCloseButton.test.js +15 -0
  55. package/dist/esm/ChatbotHeader/ChatbotHeaderMain.test.d.ts +1 -0
  56. package/dist/esm/ChatbotHeader/ChatbotHeaderMain.test.js +13 -0
  57. package/dist/esm/ChatbotHeader/ChatbotHeaderMenu.test.d.ts +1 -0
  58. package/dist/esm/ChatbotHeader/ChatbotHeaderMenu.test.js +15 -0
  59. package/dist/esm/ChatbotHeader/ChatbotHeaderOptionsDropdown.test.d.ts +1 -0
  60. package/dist/esm/ChatbotHeader/ChatbotHeaderOptionsDropdown.test.js +38 -0
  61. package/dist/esm/ChatbotHeader/ChatbotHeaderSelectorDropdown.test.d.ts +1 -0
  62. package/dist/esm/ChatbotHeader/ChatbotHeaderSelectorDropdown.test.js +36 -0
  63. package/dist/esm/ChatbotHeader/ChatbotHeaderTitle.test.d.ts +1 -0
  64. package/dist/esm/ChatbotHeader/ChatbotHeaderTitle.test.js +42 -0
  65. package/dist/esm/MessageBar/AttachButton.js +1 -1
  66. package/dist/esm/MessageBar/MessageBar.test.js +4 -4
  67. package/dist/esm/MessageBox/MessageBox.test.d.ts +1 -0
  68. package/dist/esm/MessageBox/MessageBox.test.js +17 -0
  69. package/dist/esm/PreviewAttachment/PreviewAttachment.test.d.ts +1 -0
  70. package/dist/esm/PreviewAttachment/PreviewAttachment.test.js +23 -0
  71. package/dist/esm/Settings/SettingsForm.test.d.ts +1 -0
  72. package/dist/esm/Settings/SettingsForm.test.js +21 -0
  73. package/dist/tsconfig.tsbuildinfo +1 -1
  74. package/package.json +1 -1
  75. package/patternfly-docs/content/extensions/chatbot/about-chatbot.md +5 -2
  76. package/patternfly-docs/content/extensions/chatbot/design-guidelines.md +41 -4
  77. package/patternfly-docs/content/extensions/chatbot/examples/UI/ChatbotMessageBarAttach.tsx +1 -1
  78. package/patternfly-docs/content/extensions/chatbot/examples/demos/ChatbotAttachmentMenu.tsx +1 -1
  79. package/patternfly-docs/content/extensions/chatbot/img/attached-file.svg +24 -29
  80. package/patternfly-docs/content/extensions/chatbot/img/attachment-menu.svg +4 -4
  81. package/patternfly-docs/content/extensions/chatbot/img/attachment-unsent.svg +30 -57
  82. package/patternfly-docs/content/extensions/chatbot/img/chatbot-elements.svg +5 -5
  83. package/patternfly-docs/content/extensions/chatbot/img/chatbot-quickstarts-tile.svg +58 -0
  84. package/patternfly-docs/content/extensions/chatbot/img/chatbot-settings.svg +83 -0
  85. package/patternfly-docs/content/extensions/chatbot/img/conversation-history.svg +6 -29
  86. package/patternfly-docs/content/extensions/chatbot/img/docked.svg +68 -49
  87. package/patternfly-docs/content/extensions/chatbot/img/footnote.svg +1 -1
  88. package/patternfly-docs/content/extensions/chatbot/img/fullscreen.svg +25 -16
  89. package/patternfly-docs/content/extensions/chatbot/img/listening.svg +1 -1
  90. package/patternfly-docs/content/extensions/chatbot/img/message-bar-elements.svg +3 -3
  91. package/patternfly-docs/content/extensions/chatbot/img/message-elements.svg +85 -142
  92. package/patternfly-docs/content/extensions/chatbot/img/overlay.svg +52 -36
  93. package/patternfly-docs/content/extensions/chatbot/img/settings-menu.svg +122 -0
  94. package/patternfly-docs/content/extensions/chatbot/img/source-tile.svg +62 -0
  95. package/patternfly-docs/content/extensions/chatbot/img/toggle-customizations.svg +12 -0
  96. package/src/AttachmentEdit/AttachmentEdit.test.tsx +55 -0
  97. package/src/Chatbot/Chatbot.test.tsx +31 -0
  98. package/src/ChatbotAlert/ChatbotAlert.test.tsx +31 -0
  99. package/src/ChatbotContent/ChatbotContent.test.tsx +15 -0
  100. package/src/ChatbotFooter/ChatbotFooter.test.tsx +15 -0
  101. package/src/ChatbotFooter/ChatbotFooternote.test.tsx +84 -0
  102. package/src/ChatbotHeader/ChatbotHeader.test.tsx +15 -0
  103. package/src/ChatbotHeader/ChatbotHeaderActions.test.tsx +17 -0
  104. package/src/ChatbotHeader/ChatbotHeaderCloseButton.test.tsx +20 -0
  105. package/src/ChatbotHeader/ChatbotHeaderMain.test.tsx +17 -0
  106. package/src/ChatbotHeader/ChatbotHeaderMenu.test.tsx +19 -0
  107. package/src/ChatbotHeader/ChatbotHeaderOptionsDropdown.test.tsx +45 -0
  108. package/src/ChatbotHeader/ChatbotHeaderSelectorDropdown.test.tsx +43 -0
  109. package/src/ChatbotHeader/ChatbotHeaderTitle.test.tsx +59 -0
  110. package/src/MessageBar/AttachButton.tsx +1 -1
  111. package/src/MessageBar/MessageBar.test.tsx +4 -4
  112. package/src/MessageBox/MessageBox.test.tsx +26 -0
  113. package/src/PreviewAttachment/PreviewAttachment.test.tsx +51 -0
  114. package/src/Settings/SettingsForm.test.tsx +28 -0
@@ -0,0 +1,26 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const react_1 = __importDefault(require("react"));
7
+ const react_core_1 = require("@patternfly/react-core");
8
+ const react_2 = require("@testing-library/react");
9
+ const SettingsForm_1 = require("./SettingsForm");
10
+ describe('SettingsForm', () => {
11
+ it('should render settingsForm with custom classname', () => {
12
+ const { container } = (0, react_2.render)(react_1.default.createElement(SettingsForm_1.SettingsForm, { className: "custom-settings" }));
13
+ expect(container.querySelector('.custom-settings')).toBeTruthy();
14
+ });
15
+ it('should render settingsForm with fields', () => {
16
+ const fields = [
17
+ {
18
+ id: 'archived-chat',
19
+ label: 'Archive chat',
20
+ field: (react_1.default.createElement(react_core_1.Button, { id: "archived-chat", variant: "secondary" }, "Archive chat"))
21
+ }
22
+ ];
23
+ (0, react_2.render)(react_1.default.createElement(SettingsForm_1.SettingsForm, { fields: fields }));
24
+ expect(react_2.screen.getByRole('button', { name: 'Archive chat' })).toBeTruthy();
25
+ });
26
+ });
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,47 @@
1
+ import React from 'react';
2
+ import { fireEvent, render, screen } from '@testing-library/react';
3
+ import AttachmentEdit from './AttachmentEdit';
4
+ describe('AttachmentEdit', () => {
5
+ it('should open AttachmentEdit modal', () => {
6
+ const props = {
7
+ code: 'code',
8
+ fileName: 'fileName',
9
+ onCancel: jest.fn(),
10
+ onSave: jest.fn(),
11
+ isModalOpen: true,
12
+ handleModalToggle: jest.fn()
13
+ };
14
+ render(React.createElement(AttachmentEdit, Object.assign({}, props)));
15
+ expect(screen.getByText('Edit attachment')).toBeTruthy();
16
+ });
17
+ it('should call onSave handler when the save button is clicked', () => {
18
+ const onSaveHandler = jest.fn();
19
+ const props = {
20
+ code: 'code',
21
+ fileName: 'fileName',
22
+ onCancel: jest.fn(),
23
+ onSave: onSaveHandler,
24
+ isModalOpen: true,
25
+ handleModalToggle: jest.fn()
26
+ };
27
+ render(React.createElement(AttachmentEdit, Object.assign({}, props)));
28
+ // Click on save button
29
+ fireEvent.click(screen.getByText('Save'));
30
+ expect(onSaveHandler).toHaveBeenCalledWith(expect.any(Object), 'code');
31
+ });
32
+ it('should call cancel handler when the cancel button is clicked', () => {
33
+ const onCancelHandler = jest.fn();
34
+ const props = {
35
+ code: 'code',
36
+ fileName: 'fileName',
37
+ onCancel: onCancelHandler,
38
+ onSave: jest.fn(),
39
+ isModalOpen: true,
40
+ handleModalToggle: jest.fn()
41
+ };
42
+ render(React.createElement(AttachmentEdit, Object.assign({}, props)));
43
+ // Click on cancel button
44
+ fireEvent.click(screen.getByText('Cancel'));
45
+ expect(onCancelHandler).toHaveBeenCalled();
46
+ });
47
+ });
@@ -0,0 +1 @@
1
+ import '@testing-library/jest-dom';
@@ -0,0 +1,23 @@
1
+ import '@testing-library/jest-dom';
2
+ import React from 'react';
3
+ import { render, screen } from '@testing-library/react';
4
+ import Chatbot from './Chatbot';
5
+ describe('Chatbot', () => {
6
+ it('should render Chatbot with default display mode', () => {
7
+ render(React.createElement(Chatbot, null, "Chatbot Content"));
8
+ expect(screen.getByText('Chatbot Content')).toBeTruthy();
9
+ });
10
+ it('should render Chatbot with custom ariaLabel', () => {
11
+ render(React.createElement(Chatbot, { ariaLabel: "Chatbot" }, "Chatbot Content"));
12
+ expect(screen.getByLabelText('Chatbot')).toBeTruthy();
13
+ });
14
+ it('should render Chatbot with custom className', () => {
15
+ const { container } = render(React.createElement(Chatbot, { ariaLabel: "Chatbot", className: "custom-class" }, "Chatbot Content"));
16
+ const chatbotElement = container.querySelector('.custom-class');
17
+ expect(chatbotElement).toBeInTheDocument();
18
+ });
19
+ it('should not render Chatbot', () => {
20
+ render(React.createElement(Chatbot, { isVisible: false }, "Chatbot Content"));
21
+ expect(screen.queryByLabelText('Chatbot')).toBeFalsy();
22
+ });
23
+ });
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,22 @@
1
+ import React from 'react';
2
+ import { fireEvent, render, screen } from '@testing-library/react';
3
+ import ChatbotAlert from './ChatbotAlert';
4
+ describe('ChatbotAlert', () => {
5
+ it('should render ChatbotAlert with default variant', () => {
6
+ render(React.createElement(ChatbotAlert, { title: "Chatbot Alert" }));
7
+ expect(screen.getByText('Chatbot Alert')).toBeTruthy();
8
+ });
9
+ it('should render ChatbotAlert with children', () => {
10
+ render(React.createElement(ChatbotAlert, { title: "Chatbot Alert" }, "Chatbot Alert Content"));
11
+ expect(screen.getByText('Chatbot Alert Content')).toBeTruthy();
12
+ });
13
+ it('should call onClose handler when onClose button is clicked', () => {
14
+ const onCloseHandler = jest.fn();
15
+ render(React.createElement(ChatbotAlert, { title: "Chatbot Alert", onClose: onCloseHandler }, "Chatbot Alert Content"));
16
+ expect(screen.getByText('Chatbot Alert')).toBeTruthy();
17
+ expect(screen.getByText('Chatbot Alert Content')).toBeTruthy();
18
+ // click on the close button
19
+ fireEvent.click(screen.getByRole('button'));
20
+ expect(onCloseHandler).toHaveBeenCalled();
21
+ });
22
+ });
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,13 @@
1
+ import React from 'react';
2
+ import { render, screen } from '@testing-library/react';
3
+ import ChatbotContent from './ChatbotContent';
4
+ describe('ChatbotContent', () => {
5
+ it('should render ChatbotContent with children', () => {
6
+ render(React.createElement(ChatbotContent, null, "Chatbot Content"));
7
+ expect(screen.getByText('Chatbot Content')).toBeTruthy();
8
+ });
9
+ it('should render ChatbotContent with custom classname', () => {
10
+ const { container } = render(React.createElement(ChatbotContent, { className: "custom-class" }, "Chatbot Content"));
11
+ expect(container.querySelector('.custom-class')).toBeTruthy();
12
+ });
13
+ });
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,13 @@
1
+ import React from 'react';
2
+ import { render, screen } from '@testing-library/react';
3
+ import ChatbotFooter from './ChatbotFooter';
4
+ describe('ChatbotFooter', () => {
5
+ it('should render ChatbotFooter with children', () => {
6
+ render(React.createElement(ChatbotFooter, null, "Chatbot Content"));
7
+ expect(screen.getByText('Chatbot Content')).toBeTruthy();
8
+ });
9
+ it('should render ChatbotFooter with custom classname', () => {
10
+ const { container } = render(React.createElement(ChatbotFooter, { className: "custom-class" }, "Chatbot Content"));
11
+ expect(container.querySelector('.custom-class')).toBeTruthy();
12
+ });
13
+ });
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,82 @@
1
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
2
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
3
+ return new (P || (P = Promise))(function (resolve, reject) {
4
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
5
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
6
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
7
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
8
+ });
9
+ };
10
+ import React from 'react';
11
+ import { act, fireEvent, render, screen, waitFor } from '@testing-library/react';
12
+ import ChatbotFootnote from './ChatbotFootnote';
13
+ describe('ChatbotFooternote', () => {
14
+ const onClick = jest.fn();
15
+ const popoverProps = {
16
+ title: 'Verify accuracy',
17
+ description: 'description',
18
+ bannerImage: {
19
+ src: 'src',
20
+ alt: 'alt'
21
+ },
22
+ cta: {
23
+ label: 'Got it',
24
+ onClick
25
+ },
26
+ link: {
27
+ label: 'label',
28
+ url: 'url'
29
+ }
30
+ };
31
+ it('should render ChatbotFooternote', () => {
32
+ render(React.createElement(ChatbotFootnote, { label: "Chatbot footer" }));
33
+ expect(screen.getByText('Chatbot footer')).toBeTruthy();
34
+ });
35
+ it('should render ChatbotFooternote with popover', () => __awaiter(void 0, void 0, void 0, function* () {
36
+ render(React.createElement(ChatbotFootnote, { label: "Chatbot footer", popover: popoverProps }));
37
+ // click on the footer button
38
+ act(() => {
39
+ fireEvent.click(screen.getByRole('button'));
40
+ });
41
+ yield waitFor(() => {
42
+ // Check if the popover is visible and click on the cta button
43
+ screen.getByLabelText('More information');
44
+ screen.getByText('Verify accuracy');
45
+ fireEvent.click(screen.getByRole('button', { name: 'Got it' }));
46
+ expect(onClick).toHaveBeenCalled();
47
+ });
48
+ }));
49
+ it('should call onClick handler when popover cta button is clicked', () => __awaiter(void 0, void 0, void 0, function* () {
50
+ render(React.createElement(ChatbotFootnote, { label: "Chatbot footer", popover: popoverProps }));
51
+ // click on the footer button
52
+ act(() => {
53
+ fireEvent.click(screen.getByRole('button'));
54
+ });
55
+ yield waitFor(() => {
56
+ // Check if the popover is visible and click on the cta button
57
+ screen.getByLabelText('More information');
58
+ screen.getByText('Verify accuracy');
59
+ fireEvent.click(screen.getByRole('button', { name: 'Got it' }));
60
+ expect(onClick).toHaveBeenCalled();
61
+ });
62
+ }));
63
+ it('should close the popover when escape is pressed', () => __awaiter(void 0, void 0, void 0, function* () {
64
+ render(React.createElement(ChatbotFootnote, { label: "Chatbot footer", popover: popoverProps }));
65
+ // click on the footer button
66
+ act(() => {
67
+ fireEvent.click(screen.getByRole('button'));
68
+ });
69
+ yield waitFor(() => {
70
+ // Check if the popover is visible and click on the cta button
71
+ screen.getByLabelText('More information');
72
+ screen.getByText('Verify accuracy');
73
+ });
74
+ act(() => {
75
+ // trigger escape to close the popover
76
+ fireEvent.keyDown(document, { key: 'Escape', code: 'Escape' });
77
+ });
78
+ yield waitFor(() => {
79
+ expect(screen.queryByText('Verify accuracy')).toBeFalsy();
80
+ });
81
+ }));
82
+ });
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,13 @@
1
+ import React from 'react';
2
+ import { render, screen } from '@testing-library/react';
3
+ import ChatbotHeader from './ChatbotHeader';
4
+ describe('ChatbotHeader', () => {
5
+ it('should render ChatbotHeader with children', () => {
6
+ render(React.createElement(ChatbotHeader, null, "Chatbot Header"));
7
+ expect(screen.getByText('Chatbot Header')).toBeTruthy();
8
+ });
9
+ it('should render ChatbotHeader with custom classname', () => {
10
+ const { container } = render(React.createElement(ChatbotHeader, { className: "custom-header-class" }, "Chatbot Content"));
11
+ expect(container.querySelector('.custom-header-class')).toBeTruthy();
12
+ });
13
+ });
@@ -0,0 +1,13 @@
1
+ import React from 'react';
2
+ import { render, screen } from '@testing-library/react';
3
+ import ChatbotHeaderActions from './ChatbotHeaderActions';
4
+ describe('ChatbotHeaderActions', () => {
5
+ it('should render ChatbotHeaderActions with children', () => {
6
+ render(React.createElement(ChatbotHeaderActions, null, "Chatbot Header"));
7
+ expect(screen.getByText('Chatbot Header')).toBeTruthy();
8
+ });
9
+ it('should render ChatbotHeaderActions with custom classname', () => {
10
+ const { container } = render(React.createElement(ChatbotHeaderActions, { className: "custom-header-action-class" }, "Chatbot Content"));
11
+ expect(container.querySelector('.custom-header-action-class')).toBeTruthy();
12
+ });
13
+ });
@@ -0,0 +1,15 @@
1
+ import React from 'react';
2
+ import { fireEvent, render, screen } from '@testing-library/react';
3
+ import { ChatbotHeaderCloseButton } from './ChatbotHeaderCloseButton';
4
+ describe('ChatbotHeaderCloseButton', () => {
5
+ it('should render ChatbotHeaderCloseButton', () => {
6
+ const { container } = render(React.createElement(ChatbotHeaderCloseButton, { className: "custom-header-close-button", onClick: jest.fn() }));
7
+ expect(container.querySelector('.custom-header-close-button')).toBeTruthy();
8
+ });
9
+ it('should call onClick handler when close button is pressed', () => {
10
+ const onClick = jest.fn();
11
+ render(React.createElement(ChatbotHeaderCloseButton, { className: "custom-header-close-button", onClick: onClick }));
12
+ fireEvent.click(screen.getByRole('button', { name: 'Close' }));
13
+ expect(onClick).toHaveBeenCalled();
14
+ });
15
+ });
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,13 @@
1
+ import React from 'react';
2
+ import { render, screen } from '@testing-library/react';
3
+ import ChatbotHeaderMain from './ChatbotHeaderMain';
4
+ describe('ChatbotHeaderMain', () => {
5
+ it('should render ChatbotHeaderMain with children', () => {
6
+ render(React.createElement(ChatbotHeaderMain, null, "Chatbot Header Main"));
7
+ expect(screen.getByText('Chatbot Header Main')).toBeTruthy();
8
+ });
9
+ it('should render ChatbotHeaderMain with custom classname', () => {
10
+ const { container } = render(React.createElement(ChatbotHeaderMain, { className: "custom-header-class" }, "Chatbot Content"));
11
+ expect(container.querySelector('.custom-header-class')).toBeTruthy();
12
+ });
13
+ });
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,15 @@
1
+ import React from 'react';
2
+ import { fireEvent, render, screen } from '@testing-library/react';
3
+ import { ChatbotHeaderMenu } from './ChatbotHeaderMenu';
4
+ describe('ChatbotHeaderMenu', () => {
5
+ it('should render ChatbotHeaderMenu with custom class', () => {
6
+ const { container } = render(React.createElement(ChatbotHeaderMenu, { className: "custom-header-menu", onMenuToggle: jest.fn() }));
7
+ expect(container.querySelector('.custom-header-menu')).toBeTruthy();
8
+ });
9
+ it('should call onMenuToggle when ChatbotHeaderMenu button is clicked', () => {
10
+ const onMenuToggle = jest.fn();
11
+ render(React.createElement(ChatbotHeaderMenu, { className: "custom-header-menu", onMenuToggle: onMenuToggle }));
12
+ fireEvent.click(screen.getByRole('button', { name: 'Toggle menu' }));
13
+ expect(onMenuToggle).toHaveBeenCalled();
14
+ });
15
+ });
@@ -0,0 +1,38 @@
1
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
2
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
3
+ return new (P || (P = Promise))(function (resolve, reject) {
4
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
5
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
6
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
7
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
8
+ });
9
+ };
10
+ import React from 'react';
11
+ import { DropdownItem } from '@patternfly/react-core';
12
+ import { act, fireEvent, render, screen, waitFor } from '@testing-library/react';
13
+ import { ChatbotHeaderOptionsDropdown } from './ChatbotHeaderOptionsDropdown';
14
+ describe('ChatbotHeaderOptionsDropdown', () => {
15
+ const dropdownItems = (React.createElement(React.Fragment, null,
16
+ React.createElement(DropdownItem, null, "Option 1"),
17
+ React.createElement(DropdownItem, null, "Option 2"),
18
+ React.createElement(DropdownItem, null, "Option 3")));
19
+ it('should render ChatbotHeaderOptionsDropdown', () => {
20
+ render(React.createElement(ChatbotHeaderOptionsDropdown, null, dropdownItems));
21
+ expect(screen.getByRole('button', { name: 'Chatbot options' })).toBeTruthy();
22
+ });
23
+ it('should call onselect handler when a dropdown item is clicked', () => __awaiter(void 0, void 0, void 0, function* () {
24
+ const onSelect = jest.fn();
25
+ const { container } = render(React.createElement(ChatbotHeaderOptionsDropdown, { className: "custom-header-options-dropdown", onSelect: onSelect }, dropdownItems));
26
+ act(() => {
27
+ fireEvent.click(screen.getByRole('button', { name: 'Chatbot options' }));
28
+ });
29
+ yield waitFor(() => {
30
+ expect(container.querySelector('.custom-header-options-dropdown')).toBeTruthy();
31
+ expect(screen.getByText('Option 1'));
32
+ expect(screen.getByText('Option 2'));
33
+ expect(screen.getByText('Option 3'));
34
+ fireEvent.click(screen.getByText('Option 3'));
35
+ expect(onSelect).toHaveBeenCalled();
36
+ });
37
+ }));
38
+ });
@@ -0,0 +1,36 @@
1
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
2
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
3
+ return new (P || (P = Promise))(function (resolve, reject) {
4
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
5
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
6
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
7
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
8
+ });
9
+ };
10
+ import React from 'react';
11
+ import { DropdownItem } from '@patternfly/react-core';
12
+ import { act, fireEvent, render, screen, waitFor } from '@testing-library/react';
13
+ import { ChatbotHeaderSelectorDropdown } from './ChatbotHeaderSelectorDropdown';
14
+ describe('ChatbotHeaderSelectorDropdown', () => {
15
+ const dropdownItems = (React.createElement(React.Fragment, null,
16
+ React.createElement(DropdownItem, null, "Option 1"),
17
+ React.createElement(DropdownItem, null, "Option 2"),
18
+ React.createElement(DropdownItem, null, "Option 3")));
19
+ it('should render ChatbotHeaderSelectorDropdown', () => {
20
+ render(React.createElement(ChatbotHeaderSelectorDropdown, { value: "Option 1" }, dropdownItems));
21
+ expect(screen.getByRole('button', { name: 'Chatbot selector' })).toBeTruthy();
22
+ });
23
+ it('should call onselect handler when a dropdown item is clicked', () => __awaiter(void 0, void 0, void 0, function* () {
24
+ const onSelect = jest.fn();
25
+ const { container } = render(React.createElement(ChatbotHeaderSelectorDropdown, { value: "Option 1", className: "custom-header-selector-dropdown", onSelect: onSelect }, dropdownItems));
26
+ act(() => {
27
+ fireEvent.click(screen.getByRole('button', { name: 'Chatbot selector' }));
28
+ });
29
+ yield waitFor(() => {
30
+ expect(container.querySelector('.custom-header-selector-dropdown')).toBeTruthy();
31
+ expect(screen.getByText('Option 3'));
32
+ fireEvent.click(screen.getByText('Option 3'));
33
+ expect(onSelect).toHaveBeenCalled();
34
+ });
35
+ }));
36
+ });
@@ -0,0 +1,42 @@
1
+ import React from 'react';
2
+ import { render, screen } from '@testing-library/react';
3
+ import { ChatbotDisplayMode } from '../Chatbot/Chatbot';
4
+ import ChatbotHeaderTitle from './ChatbotHeaderTitle';
5
+ describe('ChatbotHeaderTitle', () => {
6
+ it('should render ChatbotHeaderTitle with children', () => {
7
+ render(React.createElement(ChatbotHeaderTitle, null, "Chatbot Header Title"));
8
+ expect(screen.getByText('Chatbot Header Title')).toBeTruthy();
9
+ });
10
+ it('should render ChatbotHeaderTitle with custom classname', () => {
11
+ const { container } = render(React.createElement(ChatbotHeaderTitle, { className: "custom-header-class" }, "Chatbot Header Title"));
12
+ expect(container.querySelector('.custom-header-class')).toBeTruthy();
13
+ });
14
+ it('should render title for default display mode', () => {
15
+ render(React.createElement(ChatbotHeaderTitle, { displayMode: ChatbotDisplayMode.default, showOnDefault: 'Default header title' }));
16
+ expect(screen.getByText('Default header title')).toBeTruthy();
17
+ });
18
+ it('should render title for docked display mode', () => {
19
+ render(React.createElement(ChatbotHeaderTitle, { displayMode: ChatbotDisplayMode.docked, showOnDocked: 'Docked header title' }));
20
+ expect(screen.getByText('Docked header title')).toBeTruthy();
21
+ });
22
+ it('should fallback to default title when docked display mode title is not configured', () => {
23
+ render(React.createElement(ChatbotHeaderTitle, { displayMode: ChatbotDisplayMode.docked, showOnDefault: 'Default header title' }));
24
+ expect(screen.getByText('Default header title')).toBeTruthy();
25
+ });
26
+ it('should render title for embedded display mode', () => {
27
+ render(React.createElement(ChatbotHeaderTitle, { displayMode: ChatbotDisplayMode.embedded, showOnEmbedded: 'Embedded header title' }));
28
+ expect(screen.getByText('Embedded header title')).toBeTruthy();
29
+ });
30
+ it('should fallback to default title when embedded display mode title is not configured', () => {
31
+ render(React.createElement(ChatbotHeaderTitle, { displayMode: ChatbotDisplayMode.embedded, showOnDefault: 'Default header title' }));
32
+ expect(screen.getByText('Default header title')).toBeTruthy();
33
+ });
34
+ it('should render title for fullscreen display mode', () => {
35
+ render(React.createElement(ChatbotHeaderTitle, { displayMode: ChatbotDisplayMode.fullscreen, showOnFullScreen: 'Fullscreen header title', className: "custom-header-class" }));
36
+ expect(screen.getByText('Fullscreen header title')).toBeTruthy();
37
+ });
38
+ it('should fallback to default title when fullscreen display mode title is not configured', () => {
39
+ render(React.createElement(ChatbotHeaderTitle, { displayMode: ChatbotDisplayMode.fullscreen, showOnDefault: 'Default header title' }));
40
+ expect(screen.getByText('Default header title')).toBeTruthy();
41
+ });
42
+ });
@@ -24,7 +24,7 @@ const AttachButtonBase = (_a) => {
24
24
  onDropAccepted: onAttachAccepted
25
25
  });
26
26
  return (React.createElement(React.Fragment, null,
27
- React.createElement("input", Object.assign({ "data-testid": inputTestId }, getInputProps())),
27
+ React.createElement("input", Object.assign({ "data-testid": inputTestId }, getInputProps(), { hidden: true })),
28
28
  React.createElement(Tooltip, Object.assign({ id: "pf-chatbot__tooltip--attach", content: tooltipContent, position: "top", entryDelay: (tooltipProps === null || tooltipProps === void 0 ? void 0 : tooltipProps.entryDelay) || 0, exitDelay: (tooltipProps === null || tooltipProps === void 0 ? void 0 : tooltipProps.exitDelay) || 0, distance: (tooltipProps === null || tooltipProps === void 0 ? void 0 : tooltipProps.distance) || 8, animationDuration: (tooltipProps === null || tooltipProps === void 0 ? void 0 : tooltipProps.animationDuration) || 0,
29
29
  // prevents VO announcements of both aria label and tooltip
30
30
  aria: "none" }, tooltipProps),
@@ -7,14 +7,14 @@ 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 '@testing-library/jest-dom';
10
11
  import React from 'react';
12
+ import { DropdownGroup, DropdownItem, DropdownList } from '@patternfly/react-core';
13
+ import { BellIcon, CalendarAltIcon, ClipboardIcon, CodeIcon } from '@patternfly/react-icons';
11
14
  import { render, screen } from '@testing-library/react';
12
- import '@testing-library/jest-dom';
13
15
  import userEvent from '@testing-library/user-event';
14
- import { MessageBar } from './MessageBar';
15
- import { DropdownGroup, DropdownItem, DropdownList } from '@patternfly/react-core';
16
16
  import SourceDetailsMenuItem from '../SourceDetailsMenuItem';
17
- import { BellIcon, CalendarAltIcon, ClipboardIcon, CodeIcon } from '@patternfly/react-icons';
17
+ import { MessageBar } from './MessageBar';
18
18
  const ATTACH_MENU_ITEMS = [
19
19
  React.createElement(DropdownList, { key: "list-1" },
20
20
  React.createElement(DropdownItem, { className: "pf-chatbot-source-details-dropdown-item", value: "auth-operator Pod", id: "0" },
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,17 @@
1
+ import React from 'react';
2
+ import { render, screen } from '@testing-library/react';
3
+ import { MessageBox } from './MessageBox';
4
+ describe('MessageBox', () => {
5
+ it('should render Message box', () => {
6
+ render(React.createElement(MessageBox, null,
7
+ React.createElement(React.Fragment, null, "Chatbot Messages")));
8
+ expect(screen.getByText('Chatbot Messages')).toBeTruthy();
9
+ });
10
+ it('should assign ref to Message box', () => {
11
+ const ref = React.createRef();
12
+ render(React.createElement(MessageBox, { ref: ref },
13
+ React.createElement("div", null, "Test message content")));
14
+ expect(ref.current).not.toBeNull();
15
+ expect(ref.current).toBeInstanceOf(HTMLDivElement);
16
+ });
17
+ });
@@ -0,0 +1,23 @@
1
+ import React from 'react';
2
+ import { fireEvent, render, screen } from '@testing-library/react';
3
+ import { PreviewAttachment } from './PreviewAttachment';
4
+ describe('PreviewAttachment', () => {
5
+ it('should render PreviewAttachment', () => {
6
+ render(React.createElement(PreviewAttachment, { code: "Hello world", fileName: "greetings.txt", isModalOpen: true, onEdit: jest.fn(), handleModalToggle: jest.fn() }));
7
+ expect(screen.getByText('Preview attachment')).toBeTruthy();
8
+ expect(screen.getByText('greetings')).toBeTruthy();
9
+ expect(screen.getAllByText('TEXT')).toBeTruthy();
10
+ });
11
+ it('should call onEdit handler when edit button is pressed', () => {
12
+ const onEdit = jest.fn();
13
+ render(React.createElement(PreviewAttachment, { code: "Hello world", fileName: "greetings.txt", isModalOpen: true, onEdit: onEdit, handleModalToggle: jest.fn() }));
14
+ fireEvent.click(screen.getByText('Edit'));
15
+ expect(onEdit).toHaveBeenCalled();
16
+ });
17
+ it('should call onDismiss handler when dismiss button is pressed', () => {
18
+ const onDismiss = jest.fn();
19
+ render(React.createElement(PreviewAttachment, { code: "Hello world", fileName: "greetings.txt", isModalOpen: true, onEdit: jest.fn(), handleModalToggle: onDismiss }));
20
+ fireEvent.click(screen.getByText('Dismiss'));
21
+ expect(onDismiss).toHaveBeenCalled();
22
+ });
23
+ });
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,21 @@
1
+ import React from 'react';
2
+ import { Button } from '@patternfly/react-core';
3
+ import { render, screen } from '@testing-library/react';
4
+ import { SettingsForm } from './SettingsForm';
5
+ describe('SettingsForm', () => {
6
+ it('should render settingsForm with custom classname', () => {
7
+ const { container } = render(React.createElement(SettingsForm, { className: "custom-settings" }));
8
+ expect(container.querySelector('.custom-settings')).toBeTruthy();
9
+ });
10
+ it('should render settingsForm with fields', () => {
11
+ const fields = [
12
+ {
13
+ id: 'archived-chat',
14
+ label: 'Archive chat',
15
+ field: (React.createElement(Button, { id: "archived-chat", variant: "secondary" }, "Archive chat"))
16
+ }
17
+ ];
18
+ render(React.createElement(SettingsForm, { fields: fields }));
19
+ expect(screen.getByRole('button', { name: 'Archive chat' })).toBeTruthy();
20
+ });
21
+ });
@@ -1 +1 @@
1
- {"root":["../src/index.ts","../src/AttachMenu/AttachMenu.tsx","../src/AttachMenu/index.ts","../src/AttachmentEdit/AttachmentEdit.tsx","../src/AttachmentEdit/index.ts","../src/Chatbot/Chatbot.tsx","../src/Chatbot/index.ts","../src/ChatbotAlert/ChatbotAlert.tsx","../src/ChatbotAlert/index.ts","../src/ChatbotContent/ChatbotContent.tsx","../src/ChatbotContent/index.ts","../src/ChatbotConversationHistoryNav/ChatbotConversationHistoryDropdown.test.tsx","../src/ChatbotConversationHistoryNav/ChatbotConversationHistoryDropdown.tsx","../src/ChatbotConversationHistoryNav/ChatbotConversationHistoryNav.test.tsx","../src/ChatbotConversationHistoryNav/ChatbotConversationHistoryNav.tsx","../src/ChatbotConversationHistoryNav/index.ts","../src/ChatbotFooter/ChatbotFooter.tsx","../src/ChatbotFooter/ChatbotFootnote.tsx","../src/ChatbotFooter/index.ts","../src/ChatbotHeader/ChatbotHeader.tsx","../src/ChatbotHeader/ChatbotHeaderActions.tsx","../src/ChatbotHeader/ChatbotHeaderCloseButton.tsx","../src/ChatbotHeader/ChatbotHeaderMain.tsx","../src/ChatbotHeader/ChatbotHeaderMenu.tsx","../src/ChatbotHeader/ChatbotHeaderOptionsDropdown.tsx","../src/ChatbotHeader/ChatbotHeaderSelectorDropdown.tsx","../src/ChatbotHeader/ChatbotHeaderTitle.tsx","../src/ChatbotHeader/index.ts","../src/ChatbotModal/ChatbotModal.tsx","../src/ChatbotModal/index.ts","../src/ChatbotPopover/ChatbotPopover.tsx","../src/ChatbotPopover/index.ts","../src/ChatbotToggle/ChatbotToggle.test.tsx","../src/ChatbotToggle/ChatbotToggle.tsx","../src/ChatbotToggle/index.ts","../src/ChatbotWelcomePrompt/ChatbotWelcomePrompt.test.tsx","../src/ChatbotWelcomePrompt/ChatbotWelcomePrompt.tsx","../src/ChatbotWelcomePrompt/index.ts","../src/CodeModal/CodeModal.tsx","../src/CodeModal/index.ts","../src/Compare/Compare.test.tsx","../src/Compare/Compare.tsx","../src/Compare/index.ts","../src/FileDetails/FileDetails.test.tsx","../src/FileDetails/FileDetails.tsx","../src/FileDetails/index.ts","../src/FileDetailsLabel/FileDetailsLabel.test.tsx","../src/FileDetailsLabel/FileDetailsLabel.tsx","../src/FileDetailsLabel/index.ts","../src/FileDropZone/FileDropZone.test.tsx","../src/FileDropZone/FileDropZone.tsx","../src/FileDropZone/index.ts","../src/LoadingMessage/LoadingMessage.test.tsx","../src/LoadingMessage/LoadingMessage.tsx","../src/LoadingMessage/index.ts","../src/Message/Message.test.tsx","../src/Message/Message.tsx","../src/Message/MessageLoading.tsx","../src/Message/index.ts","../src/Message/CodeBlockMessage/CodeBlockMessage.tsx","../src/Message/ListMessage/ListItemMessage.tsx","../src/Message/ListMessage/OrderedListMessage.tsx","../src/Message/ListMessage/UnorderedListMessage.tsx","../src/Message/QuickResponse/QuickResponse.tsx","../src/Message/QuickStarts/FallbackImg.tsx","../src/Message/QuickStarts/QuickStartTile.tsx","../src/Message/QuickStarts/QuickStartTileDescription.test.tsx","../src/Message/QuickStarts/QuickStartTileDescription.tsx","../src/Message/QuickStarts/QuickStartTileHeader.tsx","../src/Message/QuickStarts/monitor-sampleapp-quickstart-with-image.ts","../src/Message/QuickStarts/monitor-sampleapp-quickstart.ts","../src/Message/QuickStarts/types.ts","../src/Message/TextMessage/TextMessage.tsx","../src/Message/UserFeedback/CloseButton.tsx","../src/Message/UserFeedback/UserFeedback.test.tsx","../src/Message/UserFeedback/UserFeedback.tsx","../src/Message/UserFeedback/UserFeedbackComplete.test.tsx","../src/Message/UserFeedback/UserFeedbackComplete.tsx","../src/MessageBar/AttachButton.test.tsx","../src/MessageBar/AttachButton.tsx","../src/MessageBar/MessageBar.test.tsx","../src/MessageBar/MessageBar.tsx","../src/MessageBar/MicrophoneButton.tsx","../src/MessageBar/SendButton.test.tsx","../src/MessageBar/SendButton.tsx","../src/MessageBar/StopButton.test.tsx","../src/MessageBar/StopButton.tsx","../src/MessageBar/index.ts","../src/MessageBox/JumpButton.test.tsx","../src/MessageBox/JumpButton.tsx","../src/MessageBox/MessageBox.tsx","../src/MessageBox/index.ts","../src/PreviewAttachment/PreviewAttachment.tsx","../src/PreviewAttachment/index.ts","../src/ResponseActions/ResponseActionButton.test.tsx","../src/ResponseActions/ResponseActionButton.tsx","../src/ResponseActions/ResponseActions.test.tsx","../src/ResponseActions/ResponseActions.tsx","../src/ResponseActions/index.ts","../src/Settings/SettingsForm.tsx","../src/Settings/index.ts","../src/SourceDetailsMenuItem/SourceDetailsMenuItem.tsx","../src/SourceDetailsMenuItem/index.ts","../src/SourcesCard/SourcesCard.test.tsx","../src/SourcesCard/SourcesCard.tsx","../src/SourcesCard/index.ts","../src/TermsOfUse/TermsOfUse.test.tsx","../src/TermsOfUse/TermsOfUse.tsx","../src/TermsOfUse/index.ts"],"version":"5.6.3"}
1
+ {"root":["../src/index.ts","../src/AttachMenu/AttachMenu.tsx","../src/AttachMenu/index.ts","../src/AttachmentEdit/AttachmentEdit.test.tsx","../src/AttachmentEdit/AttachmentEdit.tsx","../src/AttachmentEdit/index.ts","../src/Chatbot/Chatbot.test.tsx","../src/Chatbot/Chatbot.tsx","../src/Chatbot/index.ts","../src/ChatbotAlert/ChatbotAlert.test.tsx","../src/ChatbotAlert/ChatbotAlert.tsx","../src/ChatbotAlert/index.ts","../src/ChatbotContent/ChatbotContent.test.tsx","../src/ChatbotContent/ChatbotContent.tsx","../src/ChatbotContent/index.ts","../src/ChatbotConversationHistoryNav/ChatbotConversationHistoryDropdown.test.tsx","../src/ChatbotConversationHistoryNav/ChatbotConversationHistoryDropdown.tsx","../src/ChatbotConversationHistoryNav/ChatbotConversationHistoryNav.test.tsx","../src/ChatbotConversationHistoryNav/ChatbotConversationHistoryNav.tsx","../src/ChatbotConversationHistoryNav/index.ts","../src/ChatbotFooter/ChatbotFooter.test.tsx","../src/ChatbotFooter/ChatbotFooter.tsx","../src/ChatbotFooter/ChatbotFooternote.test.tsx","../src/ChatbotFooter/ChatbotFootnote.tsx","../src/ChatbotFooter/index.ts","../src/ChatbotHeader/ChatbotHeader.test.tsx","../src/ChatbotHeader/ChatbotHeader.tsx","../src/ChatbotHeader/ChatbotHeaderActions.test.tsx","../src/ChatbotHeader/ChatbotHeaderActions.tsx","../src/ChatbotHeader/ChatbotHeaderCloseButton.test.tsx","../src/ChatbotHeader/ChatbotHeaderCloseButton.tsx","../src/ChatbotHeader/ChatbotHeaderMain.test.tsx","../src/ChatbotHeader/ChatbotHeaderMain.tsx","../src/ChatbotHeader/ChatbotHeaderMenu.test.tsx","../src/ChatbotHeader/ChatbotHeaderMenu.tsx","../src/ChatbotHeader/ChatbotHeaderOptionsDropdown.test.tsx","../src/ChatbotHeader/ChatbotHeaderOptionsDropdown.tsx","../src/ChatbotHeader/ChatbotHeaderSelectorDropdown.test.tsx","../src/ChatbotHeader/ChatbotHeaderSelectorDropdown.tsx","../src/ChatbotHeader/ChatbotHeaderTitle.test.tsx","../src/ChatbotHeader/ChatbotHeaderTitle.tsx","../src/ChatbotHeader/index.ts","../src/ChatbotModal/ChatbotModal.tsx","../src/ChatbotModal/index.ts","../src/ChatbotPopover/ChatbotPopover.tsx","../src/ChatbotPopover/index.ts","../src/ChatbotToggle/ChatbotToggle.test.tsx","../src/ChatbotToggle/ChatbotToggle.tsx","../src/ChatbotToggle/index.ts","../src/ChatbotWelcomePrompt/ChatbotWelcomePrompt.test.tsx","../src/ChatbotWelcomePrompt/ChatbotWelcomePrompt.tsx","../src/ChatbotWelcomePrompt/index.ts","../src/CodeModal/CodeModal.tsx","../src/CodeModal/index.ts","../src/Compare/Compare.test.tsx","../src/Compare/Compare.tsx","../src/Compare/index.ts","../src/FileDetails/FileDetails.test.tsx","../src/FileDetails/FileDetails.tsx","../src/FileDetails/index.ts","../src/FileDetailsLabel/FileDetailsLabel.test.tsx","../src/FileDetailsLabel/FileDetailsLabel.tsx","../src/FileDetailsLabel/index.ts","../src/FileDropZone/FileDropZone.test.tsx","../src/FileDropZone/FileDropZone.tsx","../src/FileDropZone/index.ts","../src/LoadingMessage/LoadingMessage.test.tsx","../src/LoadingMessage/LoadingMessage.tsx","../src/LoadingMessage/index.ts","../src/Message/Message.test.tsx","../src/Message/Message.tsx","../src/Message/MessageLoading.tsx","../src/Message/index.ts","../src/Message/CodeBlockMessage/CodeBlockMessage.tsx","../src/Message/ListMessage/ListItemMessage.tsx","../src/Message/ListMessage/OrderedListMessage.tsx","../src/Message/ListMessage/UnorderedListMessage.tsx","../src/Message/QuickResponse/QuickResponse.tsx","../src/Message/QuickStarts/FallbackImg.tsx","../src/Message/QuickStarts/QuickStartTile.tsx","../src/Message/QuickStarts/QuickStartTileDescription.test.tsx","../src/Message/QuickStarts/QuickStartTileDescription.tsx","../src/Message/QuickStarts/QuickStartTileHeader.tsx","../src/Message/QuickStarts/monitor-sampleapp-quickstart-with-image.ts","../src/Message/QuickStarts/monitor-sampleapp-quickstart.ts","../src/Message/QuickStarts/types.ts","../src/Message/TextMessage/TextMessage.tsx","../src/Message/UserFeedback/CloseButton.tsx","../src/Message/UserFeedback/UserFeedback.test.tsx","../src/Message/UserFeedback/UserFeedback.tsx","../src/Message/UserFeedback/UserFeedbackComplete.test.tsx","../src/Message/UserFeedback/UserFeedbackComplete.tsx","../src/MessageBar/AttachButton.test.tsx","../src/MessageBar/AttachButton.tsx","../src/MessageBar/MessageBar.test.tsx","../src/MessageBar/MessageBar.tsx","../src/MessageBar/MicrophoneButton.tsx","../src/MessageBar/SendButton.test.tsx","../src/MessageBar/SendButton.tsx","../src/MessageBar/StopButton.test.tsx","../src/MessageBar/StopButton.tsx","../src/MessageBar/index.ts","../src/MessageBox/JumpButton.test.tsx","../src/MessageBox/JumpButton.tsx","../src/MessageBox/MessageBox.test.tsx","../src/MessageBox/MessageBox.tsx","../src/MessageBox/index.ts","../src/PreviewAttachment/PreviewAttachment.test.tsx","../src/PreviewAttachment/PreviewAttachment.tsx","../src/PreviewAttachment/index.ts","../src/ResponseActions/ResponseActionButton.test.tsx","../src/ResponseActions/ResponseActionButton.tsx","../src/ResponseActions/ResponseActions.test.tsx","../src/ResponseActions/ResponseActions.tsx","../src/ResponseActions/index.ts","../src/Settings/SettingsForm.test.tsx","../src/Settings/SettingsForm.tsx","../src/Settings/index.ts","../src/SourceDetailsMenuItem/SourceDetailsMenuItem.tsx","../src/SourceDetailsMenuItem/index.ts","../src/SourcesCard/SourcesCard.test.tsx","../src/SourcesCard/SourcesCard.tsx","../src/SourcesCard/index.ts","../src/TermsOfUse/TermsOfUse.test.tsx","../src/TermsOfUse/TermsOfUse.tsx","../src/TermsOfUse/index.ts"],"version":"5.6.3"}