@patternfly/chatbot 2.2.0-prerelease.11 → 2.2.0-prerelease.13

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 (93) hide show
  1. package/dist/cjs/ChatbotConversationHistoryNav/ChatbotConversationHistoryDropdown.js +3 -1
  2. package/dist/cjs/ChatbotHeader/ChatbotHeaderCloseButton.js +3 -1
  3. package/dist/cjs/ChatbotHeader/ChatbotHeaderMenu.js +3 -1
  4. package/dist/cjs/ChatbotHeader/ChatbotHeaderOptionsDropdown.js +3 -1
  5. package/dist/cjs/ChatbotHeader/ChatbotHeaderSelectorDropdown.js +3 -1
  6. package/dist/cjs/ChatbotToggle/ChatbotToggle.js +3 -1
  7. package/dist/cjs/Message/Message.d.ts +12 -1
  8. package/dist/cjs/Message/Message.js +11 -6
  9. package/dist/cjs/Message/QuickResponse/QuickResponse.d.ts +3 -1
  10. package/dist/cjs/Message/QuickResponse/QuickResponse.js +2 -1
  11. package/dist/cjs/Message/UserFeedback/CloseButton.d.ts +10 -0
  12. package/dist/cjs/Message/UserFeedback/CloseButton.js +14 -0
  13. package/dist/cjs/Message/UserFeedback/UserFeedback.d.ts +39 -0
  14. package/dist/cjs/Message/UserFeedback/UserFeedback.js +55 -0
  15. package/dist/cjs/Message/UserFeedback/UserFeedback.test.d.ts +1 -0
  16. package/dist/cjs/Message/UserFeedback/UserFeedback.test.js +146 -0
  17. package/dist/cjs/Message/UserFeedback/UserFeedbackComplete.d.ts +42 -0
  18. package/dist/cjs/Message/UserFeedback/UserFeedbackComplete.js +117 -0
  19. package/dist/cjs/Message/UserFeedback/UserFeedbackComplete.test.d.ts +1 -0
  20. package/dist/cjs/Message/UserFeedback/UserFeedbackComplete.test.js +249 -0
  21. package/dist/cjs/MessageBar/AttachButton.js +3 -1
  22. package/dist/cjs/MessageBar/SendButton.js +3 -1
  23. package/dist/cjs/MessageBar/StopButton.js +3 -1
  24. package/dist/cjs/ResponseActions/ResponseActionButton.d.ts +4 -1
  25. package/dist/cjs/ResponseActions/ResponseActionButton.js +21 -6
  26. package/dist/cjs/ResponseActions/ResponseActions.d.ts +8 -2
  27. package/dist/cjs/ResponseActions/ResponseActions.js +7 -7
  28. package/dist/css/main.css +69 -11
  29. package/dist/css/main.css.map +1 -1
  30. package/dist/esm/ChatbotConversationHistoryNav/ChatbotConversationHistoryDropdown.js +3 -1
  31. package/dist/esm/ChatbotHeader/ChatbotHeaderCloseButton.js +3 -1
  32. package/dist/esm/ChatbotHeader/ChatbotHeaderMenu.js +3 -1
  33. package/dist/esm/ChatbotHeader/ChatbotHeaderOptionsDropdown.js +3 -1
  34. package/dist/esm/ChatbotHeader/ChatbotHeaderSelectorDropdown.js +3 -1
  35. package/dist/esm/ChatbotToggle/ChatbotToggle.js +3 -1
  36. package/dist/esm/Message/Message.d.ts +12 -1
  37. package/dist/esm/Message/Message.js +8 -3
  38. package/dist/esm/Message/QuickResponse/QuickResponse.d.ts +3 -1
  39. package/dist/esm/Message/QuickResponse/QuickResponse.js +2 -1
  40. package/dist/esm/Message/UserFeedback/CloseButton.d.ts +10 -0
  41. package/dist/esm/Message/UserFeedback/CloseButton.js +9 -0
  42. package/dist/esm/Message/UserFeedback/UserFeedback.d.ts +39 -0
  43. package/dist/esm/Message/UserFeedback/UserFeedback.js +50 -0
  44. package/dist/esm/Message/UserFeedback/UserFeedback.test.d.ts +1 -0
  45. package/dist/esm/Message/UserFeedback/UserFeedback.test.js +141 -0
  46. package/dist/esm/Message/UserFeedback/UserFeedbackComplete.d.ts +42 -0
  47. package/dist/esm/Message/UserFeedback/UserFeedbackComplete.js +112 -0
  48. package/dist/esm/Message/UserFeedback/UserFeedbackComplete.test.d.ts +1 -0
  49. package/dist/esm/Message/UserFeedback/UserFeedbackComplete.test.js +244 -0
  50. package/dist/esm/MessageBar/AttachButton.js +3 -1
  51. package/dist/esm/MessageBar/SendButton.js +3 -1
  52. package/dist/esm/MessageBar/StopButton.js +3 -1
  53. package/dist/esm/ResponseActions/ResponseActionButton.d.ts +4 -1
  54. package/dist/esm/ResponseActions/ResponseActionButton.js +18 -3
  55. package/dist/esm/ResponseActions/ResponseActions.d.ts +8 -2
  56. package/dist/esm/ResponseActions/ResponseActions.js +7 -7
  57. package/dist/tsconfig.tsbuildinfo +1 -1
  58. package/package.json +1 -1
  59. package/patternfly-docs/content/extensions/chatbot/examples/Messages/MessageWithFeedback.tsx +71 -0
  60. package/patternfly-docs/content/extensions/chatbot/examples/Messages/MessageWithFeedbackTimeout.tsx +27 -0
  61. package/patternfly-docs/content/extensions/chatbot/examples/Messages/Messages.md +37 -7
  62. package/patternfly-docs/content/extensions/chatbot/examples/UI/UI.md +3 -6
  63. package/patternfly-docs/content/extensions/chatbot/examples/demos/AttachmentDemos.md +14 -0
  64. package/patternfly-docs/content/extensions/chatbot/examples/demos/Feedback.tsx +104 -0
  65. package/src/AttachMenu/AttachMenu.scss +1 -1
  66. package/src/ChatbotConversationHistoryNav/ChatbotConversationHistoryDropdown.tsx +7 -1
  67. package/src/ChatbotConversationHistoryNav/ChatbotConversationHistoryNav.scss +8 -1
  68. package/src/ChatbotHeader/ChatbotHeaderCloseButton.tsx +7 -1
  69. package/src/ChatbotHeader/ChatbotHeaderMenu.tsx +7 -1
  70. package/src/ChatbotHeader/ChatbotHeaderOptionsDropdown.tsx +8 -1
  71. package/src/ChatbotHeader/ChatbotHeaderSelectorDropdown.tsx +8 -1
  72. package/src/ChatbotModal/ChatbotModal.scss +1 -1
  73. package/src/ChatbotToggle/ChatbotToggle.tsx +6 -1
  74. package/src/CodeModal/CodeModal.scss +1 -1
  75. package/src/FileDetails/FileDetails.scss +1 -1
  76. package/src/Message/CodeBlockMessage/CodeBlockMessage.scss +1 -1
  77. package/src/Message/Message.scss +1 -1
  78. package/src/Message/Message.tsx +24 -2
  79. package/src/Message/QuickResponse/QuickResponse.tsx +6 -2
  80. package/src/Message/UserFeedback/CloseButton.tsx +21 -0
  81. package/src/Message/UserFeedback/UserFeedback.scss +53 -0
  82. package/src/Message/UserFeedback/UserFeedback.test.tsx +257 -0
  83. package/src/Message/UserFeedback/UserFeedback.tsx +132 -0
  84. package/src/Message/UserFeedback/UserFeedbackComplete.test.tsx +255 -0
  85. package/src/Message/UserFeedback/UserFeedbackComplete.tsx +211 -0
  86. package/src/MessageBar/AttachButton.tsx +2 -0
  87. package/src/MessageBar/SendButton.tsx +2 -0
  88. package/src/MessageBar/StopButton.tsx +2 -0
  89. package/src/ResponseActions/ResponseActionButton.tsx +14 -2
  90. package/src/ResponseActions/ResponseActions.tsx +26 -2
  91. package/src/Settings/Settings.scss +2 -2
  92. package/src/SourceDetailsMenuItem/SourceDetailsMenuItem.scss +1 -1
  93. package/src/main.scss +1 -0
@@ -0,0 +1,117 @@
1
+ "use strict";
2
+ var __rest = (this && this.__rest) || function (s, e) {
3
+ var t = {};
4
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
5
+ t[p] = s[p];
6
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
7
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
8
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
9
+ t[p[i]] = s[p[i]];
10
+ }
11
+ return t;
12
+ };
13
+ var __importDefault = (this && this.__importDefault) || function (mod) {
14
+ return (mod && mod.__esModule) ? mod : { "default": mod };
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ // ============================================================================
18
+ // Chatbot Main - Messages - Feedback Complete Card
19
+ // ============================================================================
20
+ const react_1 = __importDefault(require("react"));
21
+ // Import PatternFly components
22
+ const react_core_1 = require("@patternfly/react-core");
23
+ const CloseButton_1 = __importDefault(require("./CloseButton"));
24
+ const UserFeedbackComplete = (_a) => {
25
+ var { className, title = 'Feedback submitted', body = "We've received your response. Thank you for sharing your feedback!", timestamp, timeout = false, timeoutAnimation = 3000, onTimeout, onClose, closeButtonAriaLabel = `Close feedback for message received at ${timestamp}`, onMouseEnter, onMouseLeave, ouiaId, ouiaSafe, isLiveRegion, id, focusOnLoad = true } = _a, props = __rest(_a, ["className", "title", "body", "timestamp", "timeout", "timeoutAnimation", "onTimeout", "onClose", "closeButtonAriaLabel", "onMouseEnter", "onMouseLeave", "ouiaId", "ouiaSafe", "isLiveRegion", "id", "focusOnLoad"]);
26
+ const [timedOut, setTimedOut] = react_1.default.useState(false);
27
+ const [timedOutAnimation, setTimedOutAnimation] = react_1.default.useState(true);
28
+ const [isMouseOver, setIsMouseOver] = react_1.default.useState();
29
+ const [containsFocus, setContainsFocus] = react_1.default.useState();
30
+ const dismissed = timedOut && timedOutAnimation && !isMouseOver && !containsFocus;
31
+ const divRef = react_1.default.useRef(null);
32
+ const ouiaProps = (0, react_core_1.useOUIAProps)('User Feedback Complete', ouiaId, ouiaSafe);
33
+ react_1.default.useEffect(() => {
34
+ var _a;
35
+ if (focusOnLoad) {
36
+ (_a = divRef.current) === null || _a === void 0 ? void 0 : _a.focus();
37
+ }
38
+ }, []);
39
+ react_1.default.useEffect(() => {
40
+ const calculatedTimeout = timeout === true ? 8000 : Number(timeout);
41
+ if (calculatedTimeout > 0) {
42
+ const timer = setTimeout(() => setTimedOut(true), calculatedTimeout);
43
+ return () => clearTimeout(timer);
44
+ }
45
+ }, [timeout]);
46
+ react_1.default.useEffect(() => {
47
+ const onDocumentFocus = () => {
48
+ if (divRef.current) {
49
+ if (divRef.current.contains(document.activeElement)) {
50
+ setContainsFocus(true);
51
+ setTimedOutAnimation(false);
52
+ }
53
+ else if (containsFocus) {
54
+ setContainsFocus(false);
55
+ }
56
+ }
57
+ };
58
+ document.addEventListener('focus', onDocumentFocus, true);
59
+ return () => document.removeEventListener('focus', onDocumentFocus, true);
60
+ }, [containsFocus]);
61
+ react_1.default.useEffect(() => {
62
+ if (containsFocus === false || isMouseOver === false) {
63
+ const timer = setTimeout(() => setTimedOutAnimation(true), timeoutAnimation);
64
+ return () => clearTimeout(timer);
65
+ }
66
+ }, [containsFocus, isMouseOver, timeoutAnimation]);
67
+ react_1.default.useEffect(() => {
68
+ dismissed && onTimeout && onTimeout();
69
+ }, [dismissed, onTimeout]);
70
+ if (dismissed) {
71
+ return null;
72
+ }
73
+ const myOnMouseEnter = (ev) => {
74
+ setIsMouseOver(true);
75
+ setTimedOutAnimation(false);
76
+ onMouseEnter && onMouseEnter(ev);
77
+ };
78
+ const myOnMouseLeave = (ev) => {
79
+ setIsMouseOver(false);
80
+ onMouseLeave && onMouseLeave(ev);
81
+ };
82
+ return (
83
+ /* card does not have ref forwarding; hence wrapper div */
84
+ react_1.default.createElement("div", Object.assign({ ref: divRef, onMouseEnter: myOnMouseEnter, onMouseLeave: myOnMouseLeave }, (isLiveRegion && {
85
+ 'aria-live': 'polite',
86
+ 'aria-atomic': 'false'
87
+ }), { id: id, tabIndex: 0, "aria-label": title }, ouiaProps),
88
+ react_1.default.createElement(react_core_1.Card, Object.assign({ className: `pf-chatbot__feedback-card ${className ? className : ''}` }, props),
89
+ react_1.default.createElement(react_core_1.CardHeader, { actions:
90
+ /* eslint-disable indent */
91
+ onClose
92
+ ? {
93
+ actions: react_1.default.createElement(CloseButton_1.default, { onClose: onClose, ariaLabel: closeButtonAriaLabel })
94
+ }
95
+ : undefined }),
96
+ react_1.default.createElement("div", { className: "pf-chatbot__feedback-complete-body" },
97
+ react_1.default.createElement("div", { className: "pf-chatbot__feedback-complete-image" },
98
+ react_1.default.createElement("svg", { width: "60", height: "64", viewBox: "0 0 60 64", fill: "none", xmlns: "http://www.w3.org/2000/svg" },
99
+ react_1.default.createElement("path", { d: "M53.0555 21.5975H6.94323C3.57013 21.5975 0.835693 24.3319 0.835693 27.705V57.8925C0.835693 61.2656 3.57013 64 6.94323 64H53.0555C56.4286 64 59.1631 61.2656 59.1631 57.8925V27.705C59.1631 24.3319 56.4286 21.5975 53.0555 21.5975Z", fill: "#F8AE54" }),
100
+ react_1.default.createElement("path", { d: "M55.8973 19.8247C52.5894 15.7926 29.9992 0 29.9992 0C29.9992 0 7.40996 15.7926 4.10102 19.8247C0.79312 23.8568 0.835476 25.7184 0.835476 27.8899H59.1629C59.1629 25.7184 59.2052 23.8578 55.8973 19.8257V19.8247Z", fill: "#FFCC17" }),
101
+ react_1.default.createElement("g", null,
102
+ react_1.default.createElement("path", { d: "M53.0567 8.48981H6.94336V61.8388H53.0567V8.48981Z", fill: "#F2F2F2" })),
103
+ react_1.default.createElement("path", { d: "M51.6589 7.49908H8.34204V60.8481H51.6589V7.49908Z", fill: "white" }),
104
+ react_1.default.createElement("path", { d: "M0.835693 29.1296V57.8925C0.835693 59.2375 1.27165 60.4803 2.00823 61.4896L23.0303 43.5462L0.835693 29.1296Z", fill: "#FFCC17" }),
105
+ react_1.default.createElement("path", { d: "M36.9695 43.5472L57.9905 61.4907C58.7271 60.4813 59.1631 59.2386 59.1631 57.8935V29.1306L36.9685 43.5472H36.9695Z", fill: "#FFF4CC" }),
106
+ react_1.default.createElement("path", { d: "M0.835693 57.8925V57.8067L22.4146 42.7992L29.9994 37.5244L37.5842 42.7992L59.1641 57.8067V57.8925C59.1641 61.2665 56.4296 64 53.0566 64H6.94323C3.57024 64 0.835693 61.2665 0.835693 57.8925Z", fill: "#FFE072" }),
107
+ react_1.default.createElement("g", null,
108
+ react_1.default.createElement("path", { d: "M22.1563 42.978L0.835693 57.8067V56.6993L22.1563 42.978Z", fill: "#FEF07C" })),
109
+ react_1.default.createElement("g", null,
110
+ react_1.default.createElement("path", { d: "M37.8425 42.978L59.1631 57.8067V56.6993L37.8425 42.978Z", fill: "#FEF07C" })),
111
+ react_1.default.createElement("path", { d: "M37.8037 32.2373C42.1136 27.9273 42.1136 20.9395 37.8037 16.6295C33.4937 12.3196 26.5059 12.3196 22.196 16.6295C17.886 20.9395 17.886 27.9273 22.196 32.2373C26.5059 36.5472 33.4937 36.5472 37.8037 32.2373Z", fill: "#0066CC" }),
112
+ react_1.default.createElement("path", { d: "M27.7803 30.1276C27.6098 30.1276 27.4497 30.0614 27.3298 29.9406L22.9465 25.5562C22.8267 25.4364 22.7595 25.2762 22.7595 25.1068C22.7595 24.9374 22.8256 24.7762 22.9465 24.6554L24.2379 23.364C24.3577 23.2442 24.5178 23.177 24.6883 23.177C24.8587 23.177 25.0168 23.2431 25.1377 23.363L27.7803 26.0056L34.861 18.9259C34.9808 18.8061 35.1409 18.7389 35.3103 18.7389C35.4798 18.7389 35.6389 18.8051 35.7597 18.9239L37.0531 20.2173C37.173 20.3361 37.2401 20.4962 37.2401 20.6677C37.2401 20.8392 37.174 20.9983 37.0531 21.1181L28.2317 29.9406C28.1119 30.0604 27.9518 30.1265 27.7823 30.1265L27.7803 30.1276Z", fill: "white" }))),
113
+ react_1.default.createElement("div", { className: "pf-chatbot__feedback-complete-text" },
114
+ react_1.default.createElement(react_core_1.CardTitle, { className: "pf-chatbot__feedback-complete-title" }, title),
115
+ react_1.default.createElement(react_core_1.CardBody, { className: `pf-chatbot__feedback-complete-body` }, body))))));
116
+ };
117
+ exports.default = UserFeedbackComplete;
@@ -0,0 +1 @@
1
+ import '@testing-library/jest-dom';
@@ -0,0 +1,249 @@
1
+ "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
11
+ var __importDefault = (this && this.__importDefault) || function (mod) {
12
+ return (mod && mod.__esModule) ? mod : { "default": mod };
13
+ };
14
+ Object.defineProperty(exports, "__esModule", { value: true });
15
+ const react_1 = __importDefault(require("react"));
16
+ const react_2 = require("@testing-library/react");
17
+ require("@testing-library/jest-dom");
18
+ const user_event_1 = __importDefault(require("@testing-library/user-event"));
19
+ const UserFeedbackComplete_1 = __importDefault(require("./UserFeedbackComplete"));
20
+ describe('UserFeedbackComplete', () => {
21
+ it('should render correctly', () => {
22
+ (0, react_2.render)(react_1.default.createElement(UserFeedbackComplete_1.default, { timestamp: "12/12/12" }));
23
+ expect(react_2.screen.getByText('Feedback submitted')).toBeTruthy();
24
+ react_2.screen.getByText(/We've received your response. Thank you for sharing your feedback!/i);
25
+ expect(react_2.screen.queryByRole('button', { name: /Close/i })).toBeFalsy();
26
+ });
27
+ it('should render different title correctly', () => {
28
+ (0, react_2.render)(react_1.default.createElement(UserFeedbackComplete_1.default, { timestamp: "12/12/12", title: "Thanks!" }));
29
+ expect(react_2.screen.getByText('Thanks!')).toBeTruthy();
30
+ react_2.screen.getByText(/We've received your response. Thank you for sharing your feedback!/i);
31
+ });
32
+ it('should render different string body correctly', () => {
33
+ (0, react_2.render)(react_1.default.createElement(UserFeedbackComplete_1.default, { timestamp: "12/12/12", body: "Thanks!" }));
34
+ expect(react_2.screen.getByText('Feedback submitted')).toBeTruthy();
35
+ expect(react_2.screen.getByText('Thanks!')).toBeTruthy();
36
+ });
37
+ it('should render different node body correctly', () => {
38
+ (0, react_2.render)(react_1.default.createElement(UserFeedbackComplete_1.default, { timestamp: "12/12/12", body: react_1.default.createElement("div", null, "Thanks!") }));
39
+ expect(react_2.screen.getByText('Feedback submitted')).toBeTruthy();
40
+ expect(react_2.screen.getByText('Thanks!')).toBeTruthy();
41
+ });
42
+ it('should handle onClose correctly', () => __awaiter(void 0, void 0, void 0, function* () {
43
+ const spy = jest.fn();
44
+ (0, react_2.render)(react_1.default.createElement(UserFeedbackComplete_1.default, { timestamp: "12/12/12", onClose: spy }));
45
+ const closeButton = react_2.screen.getByRole('button', { name: 'Close feedback for message received at 12/12/12' });
46
+ expect(closeButton).toBeTruthy();
47
+ yield user_event_1.default.click(closeButton);
48
+ expect(spy).toHaveBeenCalledTimes(1);
49
+ }));
50
+ it('should be able to change close button aria label', () => {
51
+ const spy = jest.fn();
52
+ (0, react_2.render)(react_1.default.createElement(UserFeedbackComplete_1.default, { timestamp: "12/12/12", onClose: spy, closeButtonAriaLabel: "Ima button" }));
53
+ expect(react_2.screen.getByRole('button', { name: /Ima button/i })).toBeTruthy();
54
+ });
55
+ it('should handle className', () => __awaiter(void 0, void 0, void 0, function* () {
56
+ (0, react_2.render)(react_1.default.createElement(UserFeedbackComplete_1.default, { timestamp: "12/12/12", className: "test", "data-testid": "card" }));
57
+ expect(react_2.screen.getByTestId('card')).toHaveClass('test');
58
+ }));
59
+ it('should apply id', () => __awaiter(void 0, void 0, void 0, function* () {
60
+ (0, react_2.render)(react_1.default.createElement(UserFeedbackComplete_1.default, { timestamp: "12/12/12", id: "test", "data-testid": "card" }));
61
+ expect(react_2.screen.getByTestId('card').parentElement).toHaveAttribute('id', 'test');
62
+ }));
63
+ it('renders with no timeout by default', () => {
64
+ jest.useFakeTimers();
65
+ (0, react_2.render)(react_1.default.createElement(UserFeedbackComplete_1.default, { timestamp: "12/12/12" }));
66
+ (0, react_2.act)(() => {
67
+ jest.advanceTimersByTime(8000);
68
+ });
69
+ expect(react_2.screen.getByText('Feedback submitted')).toBeVisible();
70
+ jest.useRealTimers();
71
+ });
72
+ it('should handle timeout correctly after 8000ms when timeout = true', () => __awaiter(void 0, void 0, void 0, function* () {
73
+ jest.useFakeTimers();
74
+ (0, react_2.render)(react_1.default.createElement(UserFeedbackComplete_1.default, { timestamp: "12/12/12", timeout: true }));
75
+ (0, react_2.act)(() => {
76
+ jest.advanceTimersByTime(7999);
77
+ });
78
+ expect(react_2.screen.getByText('Feedback submitted')).toBeVisible();
79
+ (0, react_2.act)(() => {
80
+ jest.advanceTimersByTime(1);
81
+ });
82
+ expect(react_2.screen.queryByText('Feedback submitted')).not.toBeInTheDocument();
83
+ jest.useRealTimers();
84
+ }));
85
+ it('should handle timeout correctly when timeout = numeric value', () => __awaiter(void 0, void 0, void 0, function* () {
86
+ jest.useFakeTimers();
87
+ (0, react_2.render)(react_1.default.createElement(UserFeedbackComplete_1.default, { timestamp: "12/12/12", timeout: 300 }));
88
+ (0, react_2.act)(() => {
89
+ jest.advanceTimersByTime(299);
90
+ });
91
+ expect(react_2.screen.getByText('Feedback submitted')).toBeVisible();
92
+ (0, react_2.act)(() => {
93
+ jest.advanceTimersByTime(1);
94
+ });
95
+ expect(react_2.screen.queryByText('Feedback submitted')).not.toBeInTheDocument();
96
+ jest.useRealTimers();
97
+ }));
98
+ it('does not get removed on timeout if the user is focused on the card', () => __awaiter(void 0, void 0, void 0, function* () {
99
+ const user = user_event_1.default.setup({
100
+ advanceTimers: (delay) => jest.advanceTimersByTime(delay)
101
+ });
102
+ jest.useFakeTimers();
103
+ (0, react_2.render)(react_1.default.createElement(UserFeedbackComplete_1.default, { timestamp: "12/12/12", timeout: true, "data-testid": "card" }));
104
+ expect(react_2.screen.getByText('Feedback submitted')).toBeTruthy();
105
+ yield user.click(react_2.screen.getByTestId('card'));
106
+ (0, react_2.act)(() => {
107
+ jest.advanceTimersByTime(8000);
108
+ });
109
+ expect(react_2.screen.getByText('Feedback submitted')).toBeTruthy();
110
+ jest.useRealTimers();
111
+ }));
112
+ it('does not remove the card on timeout if the user is hovered over it', () => __awaiter(void 0, void 0, void 0, function* () {
113
+ const user = user_event_1.default.setup({
114
+ advanceTimers: (delay) => jest.advanceTimersByTime(delay)
115
+ });
116
+ jest.useFakeTimers();
117
+ (0, react_2.render)(react_1.default.createElement(UserFeedbackComplete_1.default, { timestamp: "12/12/12", timeout: true, "data-testid": "card" }));
118
+ const card = react_2.screen.getByTestId('card');
119
+ yield user.hover(card);
120
+ (0, react_2.act)(() => {
121
+ jest.advanceTimersByTime(8000);
122
+ });
123
+ expect(card).toBeVisible();
124
+ jest.useRealTimers();
125
+ }));
126
+ it('removes the card after the user removes focus from the card and 3000ms have passed', () => __awaiter(void 0, void 0, void 0, function* () {
127
+ const user = user_event_1.default.setup({
128
+ advanceTimers: (delay) => jest.advanceTimersByTime(delay)
129
+ });
130
+ jest.useFakeTimers();
131
+ (0, react_2.render)(react_1.default.createElement("div", null,
132
+ react_1.default.createElement("input", null),
133
+ react_1.default.createElement(UserFeedbackComplete_1.default, { timestamp: "12/12/12", timeout: true, "data-testid": "card" })));
134
+ const card = react_2.screen.getByTestId('card');
135
+ yield user.click(card);
136
+ (0, react_2.act)(() => {
137
+ jest.advanceTimersByTime(8000);
138
+ });
139
+ yield user.click(react_2.screen.getByRole('textbox'));
140
+ (0, react_2.act)(() => {
141
+ jest.advanceTimersByTime(3000);
142
+ });
143
+ expect(react_2.screen.queryByText('Feedback submitted')).not.toBeInTheDocument();
144
+ jest.useRealTimers();
145
+ }));
146
+ it('removes the card after the user removes hover from the card and 3000ms have passed', () => __awaiter(void 0, void 0, void 0, function* () {
147
+ const user = user_event_1.default.setup({
148
+ advanceTimers: (delay) => jest.advanceTimersByTime(delay)
149
+ });
150
+ jest.useFakeTimers();
151
+ (0, react_2.render)(react_1.default.createElement("div", null,
152
+ react_1.default.createElement("input", null),
153
+ react_1.default.createElement(UserFeedbackComplete_1.default, { timestamp: "12/12/12", timeout: true, "data-testid": "card" })));
154
+ const card = react_2.screen.getByTestId('card');
155
+ yield user.hover(card);
156
+ (0, react_2.act)(() => {
157
+ jest.advanceTimersByTime(8000);
158
+ });
159
+ yield user.hover(react_2.screen.getByRole('textbox'));
160
+ (0, react_2.act)(() => {
161
+ jest.advanceTimersByTime(3000);
162
+ });
163
+ expect(react_2.screen.queryByText('Feedback submitted')).not.toBeInTheDocument();
164
+ jest.useRealTimers();
165
+ }));
166
+ it('removes the card after the user removes hover from the card and timeoutAnimation time has passed', () => __awaiter(void 0, void 0, void 0, function* () {
167
+ const user = user_event_1.default.setup({
168
+ advanceTimers: (delay) => jest.advanceTimersByTime(delay)
169
+ });
170
+ jest.useFakeTimers();
171
+ (0, react_2.render)(react_1.default.createElement("div", null,
172
+ react_1.default.createElement("input", null),
173
+ react_1.default.createElement(UserFeedbackComplete_1.default, { timestamp: "12/12/12", timeout: true, "data-testid": "card", timeoutAnimation: 1000 })));
174
+ const card = react_2.screen.getByTestId('card');
175
+ yield user.hover(card);
176
+ (0, react_2.act)(() => {
177
+ jest.advanceTimersByTime(8000);
178
+ });
179
+ yield user.hover(react_2.screen.getByRole('textbox'));
180
+ (0, react_2.act)(() => {
181
+ jest.advanceTimersByTime(1000);
182
+ });
183
+ expect(react_2.screen.queryByText('Feedback submitted')).not.toBeInTheDocument();
184
+ jest.useRealTimers();
185
+ }));
186
+ it('does not call the onTimeout callback before the timeout period has expired', () => {
187
+ const spy = jest.fn();
188
+ jest.useFakeTimers();
189
+ (0, react_2.render)(react_1.default.createElement(UserFeedbackComplete_1.default, { timestamp: "12/12/12", timeout: true, "data-testid": "card", onTimeout: spy }));
190
+ (0, react_2.act)(() => {
191
+ jest.advanceTimersByTime(7999);
192
+ });
193
+ expect(spy).not.toHaveBeenCalled();
194
+ jest.useRealTimers();
195
+ });
196
+ it('calls the onTimeout callback after the timeout period has expired', () => {
197
+ jest.useFakeTimers();
198
+ const spy = jest.fn();
199
+ (0, react_2.render)(react_1.default.createElement(UserFeedbackComplete_1.default, { timestamp: "12/12/12", timeout: true, "data-testid": "card", onTimeout: spy }));
200
+ (0, react_2.act)(() => {
201
+ jest.advanceTimersByTime(8000);
202
+ });
203
+ expect(spy).toHaveBeenCalledTimes(1);
204
+ jest.useRealTimers();
205
+ });
206
+ it('renders without aria-live and aria-atomic attributes by default', () => {
207
+ (0, react_2.render)(react_1.default.createElement(UserFeedbackComplete_1.default, { timestamp: "12/12/12", timeout: true, "data-testid": "card" }));
208
+ const card = react_2.screen.getByTestId('card').parentElement;
209
+ expect(card).not.toHaveAttribute('aria-live');
210
+ expect(card).not.toHaveAttribute('aria-atomic');
211
+ });
212
+ it('has an aria-live value of polite and aria-atomic value of false when isLiveRegion = true', () => {
213
+ (0, react_2.render)(react_1.default.createElement(UserFeedbackComplete_1.default, { timestamp: "12/12/12", timeout: true, "data-testid": "card", isLiveRegion: true }));
214
+ const card = react_2.screen.getByTestId('card').parentElement;
215
+ expect(card).toHaveAttribute('aria-live', 'polite');
216
+ expect(card).toHaveAttribute('aria-atomic', 'false');
217
+ });
218
+ it('calls onMouseEnter appropriately', () => __awaiter(void 0, void 0, void 0, function* () {
219
+ const spy = jest.fn();
220
+ const user = user_event_1.default.setup();
221
+ (0, react_2.render)(react_1.default.createElement("div", null,
222
+ react_1.default.createElement("input", null),
223
+ react_1.default.createElement(UserFeedbackComplete_1.default, { timestamp: "12/12/12", "data-testid": "card", onMouseEnter: spy })));
224
+ const card = react_2.screen.getByTestId('card');
225
+ expect(spy).toHaveBeenCalledTimes(0);
226
+ yield user.hover(card);
227
+ expect(spy).toHaveBeenCalledTimes(1);
228
+ }));
229
+ it('calls onMouseLeave appropriately', () => __awaiter(void 0, void 0, void 0, function* () {
230
+ const spy = jest.fn();
231
+ const user = user_event_1.default.setup();
232
+ (0, react_2.render)(react_1.default.createElement("div", null,
233
+ react_1.default.createElement("input", null),
234
+ react_1.default.createElement(UserFeedbackComplete_1.default, { timestamp: "12/12/12", "data-testid": "card", onMouseLeave: spy })));
235
+ const card = react_2.screen.getByTestId('card');
236
+ expect(spy).toHaveBeenCalledTimes(0);
237
+ yield user.hover(card);
238
+ yield user.hover(react_2.screen.getByRole('textbox'));
239
+ expect(spy).toHaveBeenCalledTimes(1);
240
+ }));
241
+ it('should focus on load by default', () => {
242
+ (0, react_2.render)(react_1.default.createElement(UserFeedbackComplete_1.default, { timestamp: "12/12/12", "data-testid": "card" }));
243
+ expect(react_2.screen.getByTestId('card').parentElement).toHaveFocus();
244
+ });
245
+ it('should not focus on load if focusOnLoad = false', () => {
246
+ (0, react_2.render)(react_1.default.createElement(UserFeedbackComplete_1.default, { timestamp: "12/12/12", "data-testid": "card", focusOnLoad: false }));
247
+ expect(react_2.screen.getByTestId('card').parentElement).not.toHaveFocus();
248
+ });
249
+ });
@@ -31,7 +31,9 @@ const AttachButtonBase = (_a) => {
31
31
  });
32
32
  return (react_1.default.createElement(react_1.default.Fragment, null,
33
33
  react_1.default.createElement("input", Object.assign({ "data-testid": inputTestId }, getInputProps())),
34
- react_1.default.createElement(react_core_1.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 }, tooltipProps),
34
+ react_1.default.createElement(react_core_1.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,
35
+ // prevents VO announcements of both aria label and tooltip
36
+ aria: "none" }, tooltipProps),
35
37
  react_1.default.createElement(react_core_1.Button, Object.assign({ variant: "plain", ref: innerRef, className: `pf-chatbot__button--attach ${className !== null && className !== void 0 ? className : ''}`, "aria-label": props['aria-label'] || 'Attach button', isDisabled: isDisabled, onClick: onClick !== null && onClick !== void 0 ? onClick : open, icon: react_1.default.createElement(react_core_1.Icon, { iconSize: "xl", isInline: true },
36
38
  react_1.default.createElement(paperclip_icon_1.PaperclipIcon, null)) }, props)))));
37
39
  };
@@ -24,7 +24,9 @@ const react_core_1 = require("@patternfly/react-core");
24
24
  const paper_plane_icon_1 = require("@patternfly/react-icons/dist/esm/icons/paper-plane-icon");
25
25
  const SendButton = (_a) => {
26
26
  var { className, onClick, tooltipProps, tooltipContent = 'Send' } = _a, props = __rest(_a, ["className", "onClick", "tooltipProps", "tooltipContent"]);
27
- return (react_1.default.createElement(react_core_1.Tooltip, Object.assign({ id: "pf-chatbot__tooltip--send", content: tooltipContent, position: (tooltipProps === null || tooltipProps === void 0 ? void 0 : tooltipProps.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 }, tooltipProps),
27
+ return (react_1.default.createElement(react_core_1.Tooltip, Object.assign({ id: "pf-chatbot__tooltip--send", content: tooltipContent, position: (tooltipProps === null || tooltipProps === void 0 ? void 0 : tooltipProps.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,
28
+ // prevents VO announcements of both aria label and tooltip
29
+ aria: "none" }, tooltipProps),
28
30
  react_1.default.createElement(react_core_1.Button, Object.assign({ variant: "plain", className: `pf-chatbot__button--send ${className !== null && className !== void 0 ? className : ''}`, "aria-label": props['aria-label'] || 'Send button', onClick: onClick, icon: react_1.default.createElement(react_core_1.Icon, { iconSize: "xl", isInline: true },
29
31
  react_1.default.createElement(paper_plane_icon_1.PaperPlaneIcon, null)) }, props))));
30
32
  };
@@ -23,7 +23,9 @@ const react_1 = __importDefault(require("react"));
23
23
  const react_core_1 = require("@patternfly/react-core");
24
24
  const StopButton = (_a) => {
25
25
  var { className, onClick, tooltipProps, tooltipContent = 'Stop' } = _a, props = __rest(_a, ["className", "onClick", "tooltipProps", "tooltipContent"]);
26
- return (react_1.default.createElement(react_core_1.Tooltip, Object.assign({ id: "pf-chatbot__tooltip--stop", content: tooltipContent, position: (tooltipProps === null || tooltipProps === void 0 ? void 0 : tooltipProps.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 }, tooltipProps),
26
+ return (react_1.default.createElement(react_core_1.Tooltip, Object.assign({ id: "pf-chatbot__tooltip--stop", content: tooltipContent, position: (tooltipProps === null || tooltipProps === void 0 ? void 0 : tooltipProps.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,
27
+ // prevents VO announcements of both aria label and tooltip
28
+ aria: "none" }, tooltipProps),
27
29
  react_1.default.createElement(react_core_1.Button, Object.assign({ className: `pf-chatbot__button--stop ${className !== null && className !== void 0 ? className : ''}`, variant: "link", "aria-label": props['aria-label'] || 'Stop button', onClick: onClick, icon: react_1.default.createElement(react_core_1.Icon, { iconSize: "xl", isInline: true },
28
30
  react_1.default.createElement("svg", { width: "16", height: "16", viewBox: "0 0 16 16", fill: "none", xmlns: "http://www.w3.org/2000/svg" },
29
31
  react_1.default.createElement("path", { d: "M0.5 3C0.5 1.62109 1.62109 0.5 3 0.5H13C14.3789 0.5 15.5 1.62109 15.5 3V13C15.5 14.3789 14.3789 15.5 13 15.5H3C1.62109 15.5 0.5 14.3789 0.5 13V3Z", fill: "currentColor" }))) }, props))));
@@ -21,6 +21,9 @@ export interface ResponseActionButtonProps {
21
21
  tooltipProps?: TooltipProps;
22
22
  /** Whether button is in clicked state */
23
23
  isClicked?: boolean;
24
+ /** Ref applied to button */
25
+ innerRef?: React.Ref<HTMLButtonElement>;
24
26
  }
25
- export declare const ResponseActionButton: React.FunctionComponent<ResponseActionButtonProps>;
27
+ export declare const ResponseActionButtonBase: React.FunctionComponent<ResponseActionButtonProps>;
28
+ declare const ResponseActionButton: React.ForwardRefExoticComponent<ResponseActionButtonProps & React.RefAttributes<HTMLButtonElement>>;
26
29
  export default ResponseActionButton;
@@ -1,20 +1,35 @@
1
1
  "use strict";
2
+ var __rest = (this && this.__rest) || function (s, e) {
3
+ var t = {};
4
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
5
+ t[p] = s[p];
6
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
7
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
8
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
9
+ t[p[i]] = s[p[i]];
10
+ }
11
+ return t;
12
+ };
2
13
  var __importDefault = (this && this.__importDefault) || function (mod) {
3
14
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
15
  };
5
16
  Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.ResponseActionButton = void 0;
17
+ exports.ResponseActionButtonBase = void 0;
7
18
  const react_1 = __importDefault(require("react"));
8
19
  const react_core_1 = require("@patternfly/react-core");
9
- const ResponseActionButton = ({ ariaLabel, clickedAriaLabel = ariaLabel, className, icon, isDisabled, onClick, tooltipContent, clickedTooltipContent = tooltipContent, tooltipProps, isClicked = false }) => {
20
+ const ResponseActionButtonBase = (_a) => {
21
+ var { ariaLabel, clickedAriaLabel = ariaLabel, className, icon, isDisabled, onClick, tooltipContent, clickedTooltipContent = tooltipContent, tooltipProps, isClicked = false, innerRef } = _a, props = __rest(_a, ["ariaLabel", "clickedAriaLabel", "className", "icon", "isDisabled", "onClick", "tooltipContent", "clickedTooltipContent", "tooltipProps", "isClicked", "innerRef"]);
10
22
  const generateAriaLabel = () => {
11
23
  if (ariaLabel) {
12
24
  return isClicked ? clickedAriaLabel : ariaLabel;
13
25
  }
14
26
  return isClicked ? clickedTooltipContent : tooltipContent;
15
27
  };
16
- return (react_1.default.createElement(react_core_1.Tooltip, Object.assign({ id: `pf-chatbot__tooltip-response-action-${tooltipContent}`, content: isClicked ? clickedTooltipContent : tooltipContent, "aria-live": "polite", position: "bottom", 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 }, tooltipProps),
17
- react_1.default.createElement(react_core_1.Button, { variant: "plain", className: `pf-chatbot__button--response-action ${isClicked ? 'pf-chatbot__button--response-action-clicked' : ''} ${className !== null && className !== void 0 ? className : ''}`, "aria-label": generateAriaLabel(), icon: react_1.default.createElement(react_core_1.Icon, { isInline: true, size: "lg" }, icon), isDisabled: isDisabled, onClick: onClick, size: "sm" })));
28
+ return (react_1.default.createElement(react_core_1.Tooltip, Object.assign({ id: `pf-chatbot__tooltip-response-action-${tooltipContent}`, content: isClicked ? clickedTooltipContent : tooltipContent, "aria-live": "polite", position: "bottom", 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
+ // prevents VO announcements of both aria label and tooltip
30
+ aria: "none" }, tooltipProps),
31
+ react_1.default.createElement(react_core_1.Button, Object.assign({ variant: "plain", className: `pf-chatbot__button--response-action ${isClicked ? 'pf-chatbot__button--response-action-clicked' : ''} ${className !== null && className !== void 0 ? className : ''}`, "aria-label": generateAriaLabel(), icon: react_1.default.createElement(react_core_1.Icon, { isInline: true, size: "lg" }, icon), isDisabled: isDisabled, onClick: onClick, size: "sm", ref: innerRef }, props))));
18
32
  };
19
- exports.ResponseActionButton = ResponseActionButton;
20
- exports.default = exports.ResponseActionButton;
33
+ exports.ResponseActionButtonBase = ResponseActionButtonBase;
34
+ const ResponseActionButton = react_1.default.forwardRef((props, ref) => (react_1.default.createElement(exports.ResponseActionButtonBase, Object.assign({ innerRef: ref }, props))));
35
+ exports.default = ResponseActionButton;
@@ -1,6 +1,6 @@
1
1
  import React from 'react';
2
- import { TooltipProps } from '@patternfly/react-core';
3
- export interface ActionProps {
2
+ import { ButtonProps, TooltipProps } from '@patternfly/react-core';
3
+ export interface ActionProps extends Omit<ButtonProps, 'ref'> {
4
4
  /** Aria-label for the button */
5
5
  ariaLabel?: string;
6
6
  /** Aria-label for the button, shown when the button is clicked. */
@@ -19,6 +19,12 @@ export interface ActionProps {
19
19
  tooltipProps?: TooltipProps;
20
20
  /** Icon for custom response action */
21
21
  icon?: React.ReactNode;
22
+ /** Ref for response action button */
23
+ ref?: React.Ref<HTMLButtonElement>;
24
+ /** Whether content launched by button, such as the feedback form, is expanded */
25
+ 'aria-expanded'?: boolean;
26
+ /** Id for content controlled by the button, such as the feedback form */
27
+ 'aria-controls'?: string;
22
28
  }
23
29
  export interface ResponseActionProps {
24
30
  /** Props for message actions, such as feedback (positive or negative), copy button, share, and listen */
@@ -39,14 +39,14 @@ const ResponseActions = ({ actions }) => {
39
39
  onClick && onClick(e);
40
40
  };
41
41
  return (react_1.default.createElement("div", { ref: responseActions, className: "pf-chatbot__response-actions" },
42
- positive && (react_1.default.createElement(ResponseActionButton_1.default, { ariaLabel: (_a = positive.ariaLabel) !== null && _a !== void 0 ? _a : 'Good response', clickedAriaLabel: (_b = positive.ariaLabel) !== null && _b !== void 0 ? _b : 'Response recorded', onClick: (e) => handleClick(e, 'positive', positive.onClick), className: positive.className, isDisabled: positive.isDisabled, tooltipContent: (_c = positive.tooltipContent) !== null && _c !== void 0 ? _c : 'Good response', clickedTooltipContent: (_d = positive.clickedTooltipContent) !== null && _d !== void 0 ? _d : 'Response recorded', tooltipProps: positive.tooltipProps, icon: react_1.default.createElement(react_icons_1.OutlinedThumbsUpIcon, null), isClicked: activeButton === 'positive' })),
43
- negative && (react_1.default.createElement(ResponseActionButton_1.default, { ariaLabel: (_e = negative.ariaLabel) !== null && _e !== void 0 ? _e : 'Bad response', clickedAriaLabel: (_f = negative.ariaLabel) !== null && _f !== void 0 ? _f : 'Response recorded', onClick: (e) => handleClick(e, 'negative', negative.onClick), className: negative.className, isDisabled: negative.isDisabled, tooltipContent: (_g = negative.tooltipContent) !== null && _g !== void 0 ? _g : 'Bad response', clickedTooltipContent: (_h = negative.clickedTooltipContent) !== null && _h !== void 0 ? _h : 'Response recorded', tooltipProps: negative.tooltipProps, icon: react_1.default.createElement(react_icons_1.OutlinedThumbsDownIcon, null), isClicked: activeButton === 'negative' })),
44
- copy && (react_1.default.createElement(ResponseActionButton_1.default, { ariaLabel: (_j = copy.ariaLabel) !== null && _j !== void 0 ? _j : 'Copy', clickedAriaLabel: (_k = copy.ariaLabel) !== null && _k !== void 0 ? _k : 'Copied', onClick: (e) => handleClick(e, 'copy', copy.onClick), className: copy.className, isDisabled: copy.isDisabled, tooltipContent: (_l = copy.tooltipContent) !== null && _l !== void 0 ? _l : 'Copy', clickedTooltipContent: (_m = copy.clickedTooltipContent) !== null && _m !== void 0 ? _m : 'Copied', tooltipProps: copy.tooltipProps, icon: react_1.default.createElement(react_icons_1.OutlinedCopyIcon, null), isClicked: activeButton === 'copy' })),
45
- share && (react_1.default.createElement(ResponseActionButton_1.default, { ariaLabel: (_o = share.ariaLabel) !== null && _o !== void 0 ? _o : 'Share', clickedAriaLabel: (_p = share.ariaLabel) !== null && _p !== void 0 ? _p : 'Shared', onClick: (e) => handleClick(e, 'share', share.onClick), className: share.className, isDisabled: share.isDisabled, tooltipContent: (_q = share.tooltipContent) !== null && _q !== void 0 ? _q : 'Share', clickedTooltipContent: (_r = share.clickedTooltipContent) !== null && _r !== void 0 ? _r : 'Shared', tooltipProps: share.tooltipProps, icon: react_1.default.createElement(react_icons_1.ExternalLinkAltIcon, null), isClicked: activeButton === 'share' })),
46
- listen && (react_1.default.createElement(ResponseActionButton_1.default, { ariaLabel: (_s = listen.ariaLabel) !== null && _s !== void 0 ? _s : 'Listen', clickedAriaLabel: (_t = listen.ariaLabel) !== null && _t !== void 0 ? _t : 'Listening', onClick: (e) => handleClick(e, 'listen', listen.onClick), className: listen.className, isDisabled: listen.isDisabled, tooltipContent: (_u = listen.tooltipContent) !== null && _u !== void 0 ? _u : 'Listen', clickedTooltipContent: (_v = listen.clickedTooltipContent) !== null && _v !== void 0 ? _v : 'Listening', tooltipProps: listen.tooltipProps, icon: react_1.default.createElement(react_icons_1.VolumeUpIcon, null), isClicked: activeButton === 'listen' })),
42
+ positive && (react_1.default.createElement(ResponseActionButton_1.default, { ariaLabel: (_a = positive.ariaLabel) !== null && _a !== void 0 ? _a : 'Good response', clickedAriaLabel: (_b = positive.ariaLabel) !== null && _b !== void 0 ? _b : 'Response recorded', onClick: (e) => handleClick(e, 'positive', positive.onClick), className: positive.className, isDisabled: positive.isDisabled, tooltipContent: (_c = positive.tooltipContent) !== null && _c !== void 0 ? _c : 'Good response', clickedTooltipContent: (_d = positive.clickedTooltipContent) !== null && _d !== void 0 ? _d : 'Response recorded', tooltipProps: positive.tooltipProps, icon: react_1.default.createElement(react_icons_1.OutlinedThumbsUpIcon, null), isClicked: activeButton === 'positive', ref: positive.ref, "aria-expanded": positive['aria-expanded'], "aria-controls": positive['aria-controls'] })),
43
+ negative && (react_1.default.createElement(ResponseActionButton_1.default, { ariaLabel: (_e = negative.ariaLabel) !== null && _e !== void 0 ? _e : 'Bad response', clickedAriaLabel: (_f = negative.ariaLabel) !== null && _f !== void 0 ? _f : 'Response recorded', onClick: (e) => handleClick(e, 'negative', negative.onClick), className: negative.className, isDisabled: negative.isDisabled, tooltipContent: (_g = negative.tooltipContent) !== null && _g !== void 0 ? _g : 'Bad response', clickedTooltipContent: (_h = negative.clickedTooltipContent) !== null && _h !== void 0 ? _h : 'Response recorded', tooltipProps: negative.tooltipProps, icon: react_1.default.createElement(react_icons_1.OutlinedThumbsDownIcon, null), isClicked: activeButton === 'negative', ref: negative.ref, "aria-expanded": negative['aria-expanded'], "aria-controls": negative['aria-controls'] })),
44
+ copy && (react_1.default.createElement(ResponseActionButton_1.default, { ariaLabel: (_j = copy.ariaLabel) !== null && _j !== void 0 ? _j : 'Copy', clickedAriaLabel: (_k = copy.ariaLabel) !== null && _k !== void 0 ? _k : 'Copied', onClick: (e) => handleClick(e, 'copy', copy.onClick), className: copy.className, isDisabled: copy.isDisabled, tooltipContent: (_l = copy.tooltipContent) !== null && _l !== void 0 ? _l : 'Copy', clickedTooltipContent: (_m = copy.clickedTooltipContent) !== null && _m !== void 0 ? _m : 'Copied', tooltipProps: copy.tooltipProps, icon: react_1.default.createElement(react_icons_1.OutlinedCopyIcon, null), isClicked: activeButton === 'copy', ref: copy.ref, "aria-expanded": copy['aria-expanded'], "aria-controls": copy['aria-controls'] })),
45
+ share && (react_1.default.createElement(ResponseActionButton_1.default, { ariaLabel: (_o = share.ariaLabel) !== null && _o !== void 0 ? _o : 'Share', clickedAriaLabel: (_p = share.ariaLabel) !== null && _p !== void 0 ? _p : 'Shared', onClick: (e) => handleClick(e, 'share', share.onClick), className: share.className, isDisabled: share.isDisabled, tooltipContent: (_q = share.tooltipContent) !== null && _q !== void 0 ? _q : 'Share', clickedTooltipContent: (_r = share.clickedTooltipContent) !== null && _r !== void 0 ? _r : 'Shared', tooltipProps: share.tooltipProps, icon: react_1.default.createElement(react_icons_1.ExternalLinkAltIcon, null), isClicked: activeButton === 'share', ref: share.ref, "aria-expanded": share['aria-expanded'], "aria-controls": share['aria-controls'] })),
46
+ listen && (react_1.default.createElement(ResponseActionButton_1.default, { ariaLabel: (_s = listen.ariaLabel) !== null && _s !== void 0 ? _s : 'Listen', clickedAriaLabel: (_t = listen.ariaLabel) !== null && _t !== void 0 ? _t : 'Listening', onClick: (e) => handleClick(e, 'listen', listen.onClick), className: listen.className, isDisabled: listen.isDisabled, tooltipContent: (_u = listen.tooltipContent) !== null && _u !== void 0 ? _u : 'Listen', clickedTooltipContent: (_v = listen.clickedTooltipContent) !== null && _v !== void 0 ? _v : 'Listening', tooltipProps: listen.tooltipProps, icon: react_1.default.createElement(react_icons_1.VolumeUpIcon, null), isClicked: activeButton === 'listen', ref: listen.ref, "aria-expanded": listen['aria-expanded'], "aria-controls": listen['aria-controls'] })),
47
47
  Object.keys(additionalActions).map((action) => {
48
- var _a, _b, _c, _d, _e, _f, _g, _h;
49
- return (react_1.default.createElement(ResponseActionButton_1.default, { key: action, ariaLabel: (_a = additionalActions[action]) === null || _a === void 0 ? void 0 : _a.ariaLabel, clickedAriaLabel: (_b = additionalActions[action]) === null || _b === void 0 ? void 0 : _b.clickedAriaLabel, onClick: (e) => { var _a; return handleClick(e, action, (_a = additionalActions[action]) === null || _a === void 0 ? void 0 : _a.onClick); }, className: (_c = additionalActions[action]) === null || _c === void 0 ? void 0 : _c.className, isDisabled: (_d = additionalActions[action]) === null || _d === void 0 ? void 0 : _d.isDisabled, tooltipContent: (_e = additionalActions[action]) === null || _e === void 0 ? void 0 : _e.tooltipContent, tooltipProps: (_f = additionalActions[action]) === null || _f === void 0 ? void 0 : _f.tooltipProps, clickedTooltipContent: (_g = additionalActions[action]) === null || _g === void 0 ? void 0 : _g.clickedTooltipContent, icon: (_h = additionalActions[action]) === null || _h === void 0 ? void 0 : _h.icon, isClicked: activeButton === action }));
48
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l;
49
+ return (react_1.default.createElement(ResponseActionButton_1.default, { key: action, ariaLabel: (_a = additionalActions[action]) === null || _a === void 0 ? void 0 : _a.ariaLabel, clickedAriaLabel: (_b = additionalActions[action]) === null || _b === void 0 ? void 0 : _b.clickedAriaLabel, onClick: (e) => { var _a; return handleClick(e, action, (_a = additionalActions[action]) === null || _a === void 0 ? void 0 : _a.onClick); }, className: (_c = additionalActions[action]) === null || _c === void 0 ? void 0 : _c.className, isDisabled: (_d = additionalActions[action]) === null || _d === void 0 ? void 0 : _d.isDisabled, tooltipContent: (_e = additionalActions[action]) === null || _e === void 0 ? void 0 : _e.tooltipContent, tooltipProps: (_f = additionalActions[action]) === null || _f === void 0 ? void 0 : _f.tooltipProps, clickedTooltipContent: (_g = additionalActions[action]) === null || _g === void 0 ? void 0 : _g.clickedTooltipContent, icon: (_h = additionalActions[action]) === null || _h === void 0 ? void 0 : _h.icon, isClicked: activeButton === action, ref: (_j = additionalActions[action]) === null || _j === void 0 ? void 0 : _j.ref, "aria-expanded": (_k = additionalActions[action]) === null || _k === void 0 ? void 0 : _k['aria-expanded'], "aria-controls": (_l = additionalActions[action]) === null || _l === void 0 ? void 0 : _l['aria-controls'] }));
50
50
  })));
51
51
  };
52
52
  exports.ResponseActions = ResponseActions;