@squiz/chat-ui
Advanced tools
Comparing version 1.2.2 to 1.3.0
# @squiz/chat-ui | ||
## 1.3.0 | ||
### Minor Changes | ||
- 9c4fb8e: Change chat handling in different circumstances | ||
## 1.2.2 | ||
@@ -4,0 +10,0 @@ |
import React from 'react'; | ||
import { DxpAiService } from '@squiz/dxp-ai-client'; | ||
import { ConversationItem } from './types'; | ||
export type ChatUIProps = { | ||
@@ -19,2 +20,3 @@ aiId: string; | ||
export declare const ChatUI: (props: ChatUIProps) => React.JSX.Element; | ||
export declare const isNewChatBreak: (item: ConversationItem) => boolean; | ||
export declare const ChatUIInner: (props: ChatUIProps) => React.JSX.Element; |
@@ -26,3 +26,3 @@ "use strict"; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
exports.ChatUIInner = exports.ChatUI = void 0; | ||
exports.ChatUIInner = exports.isNewChatBreak = exports.ChatUI = void 0; | ||
const react_1 = __importStar(require("react")); | ||
@@ -40,5 +40,12 @@ const ChatContext_1 = require("./context/ChatContext"); | ||
exports.ChatUI = ChatUI; | ||
const isControlMessage = (item) => { | ||
return item.type !== undefined; | ||
}; | ||
const isNewChatBreak = (item) => { | ||
return isControlMessage(item) && item.type === `newChatBreak`; | ||
}; | ||
exports.isNewChatBreak = isNewChatBreak; | ||
const ChatUIInner = (props) => { | ||
const { fullscreen = false, title, titleId, iconSrc, greeting, inputRef, maxMessageLength = ChatUI_constants_1.CHAT_INPUT_LIMITS.maxMessageLength, showNumCharactersTypedLength = ChatUI_constants_1.CHAT_INPUT_LIMITS.showNumCharactersTypedLength, } = props; | ||
const { rating, isProcessingRating, isWaitingResponse, conversation, onSend, onNewChatRequest, onNewChatConfirm, onRateChat, } = (0, react_1.useContext)(ChatContext_1.ChatContext); | ||
const { rating, isProcessingRating, isWaitingResponse, isWaitingUserInput, conversation, onSend, onNewChatRequest, onNewChatConfirm, onRateChat, } = (0, react_1.useContext)(ChatContext_1.ChatContext); | ||
return (react_1.default.createElement("div", { className: `squizChatUI ${fullscreen ? 'squizChatUI--fullScreen' : ''} ${conversation.length > 1 ? '' : 'squizChatUI--noMessages'}` }, | ||
@@ -48,5 +55,5 @@ react_1.default.createElement(ChatHeader_1.ChatHeader, { title: title, titleId: titleId, iconSrc: iconSrc }), | ||
react_1.default.createElement(ChatInput_1.ChatInput, { ref: inputRef, isWaitingResponse: isWaitingResponse, onSend: onSend, maxMessageLength: maxMessageLength, showNumCharactersTypedLength: showNumCharactersTypedLength }), | ||
react_1.default.createElement(ChatFooter_1.ChatFooter, { rating: rating, isProcessingRating: isProcessingRating, onNewChat: onNewChatRequest, onRateChat: onRateChat }))); | ||
react_1.default.createElement(ChatFooter_1.ChatFooter, { isNewChat: conversation.length <= 1 || (0, exports.isNewChatBreak)(conversation[conversation.length - 2]), rating: rating, isProcessingRating: isProcessingRating, isWaitingResponse: isWaitingResponse, isWaitingUserInput: isWaitingUserInput, onNewChat: onNewChatRequest, onRateChat: onRateChat }))); | ||
}; | ||
exports.ChatUIInner = ChatUIInner; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQ2hhdFVJLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL0NoYXRVSS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSwrQ0FBMEM7QUFHMUMsdURBQXlFO0FBQ3pFLG1FQUFnRTtBQUNoRSxxRkFBa0Y7QUFDbEYsZ0VBQTZEO0FBQzdELG1FQUFnRTtBQUNoRSx5REFBdUQ7QUFrQmhELE1BQU0sTUFBTSxHQUFHLENBQUMsS0FBa0IsRUFBRSxFQUFFO0lBQzNDLE9BQU8sQ0FDTCw4QkFBQyxpQ0FBbUIsSUFDbEIsSUFBSSxFQUFFLEtBQUssQ0FBQyxJQUFJLEVBQ2hCLFFBQVEsRUFBRSxLQUFLLENBQUMsUUFBUSxFQUN4QixTQUFTLEVBQUUsS0FBSyxDQUFDLFNBQVMsRUFDMUIsU0FBUyxFQUFFLEtBQUssQ0FBQyxTQUFTLEVBQzFCLFFBQVEsRUFBRSxLQUFLLENBQUMsUUFBUSxFQUN4QixhQUFhLEVBQUUsS0FBSyxDQUFDLGFBQWE7UUFFbEMsOEJBQUMsbUJBQVcsT0FBSyxLQUFLLEdBQUksQ0FDTixDQUN2QixDQUFDO0FBQ0osQ0FBQyxDQUFDO0FBYlcsUUFBQSxNQUFNLFVBYWpCO0FBRUssTUFBTSxXQUFXLEdBQUcsQ0FBQyxLQUFrQixFQUFFLEVBQUU7SUFDaEQsTUFBTSxFQUNKLFVBQVUsR0FBRyxLQUFLLEVBQ2xCLEtBQUssRUFDTCxPQUFPLEVBQ1AsT0FBTyxFQUNQLFFBQVEsRUFDUixRQUFRLEVBQ1IsZ0JBQWdCLEdBQUcsb0NBQWlCLENBQUMsZ0JBQWdCLEVBQ3JELDRCQUE0QixHQUFHLG9DQUFpQixDQUFDLDRCQUE0QixHQUM5RSxHQUFHLEtBQUssQ0FBQztJQUNWLE1BQU0sRUFDSixNQUFNLEVBQ04sa0JBQWtCLEVBQ2xCLGlCQUFpQixFQUNqQixZQUFZLEVBQ1osTUFBTSxFQUNOLGdCQUFnQixFQUNoQixnQkFBZ0IsRUFDaEIsVUFBVSxHQUNYLEdBQUcsSUFBQSxrQkFBVSxFQUFDLHlCQUFXLENBQUMsQ0FBQztJQUU1QixPQUFPLENBQ0wsdUNBQ0UsU0FBUyxFQUFFLGVBQWUsVUFBVSxDQUFDLENBQUMsQ0FBQyx5QkFBeUIsQ0FBQyxDQUFDLENBQUMsRUFBRSxJQUFJLFlBQVksQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLHlCQUF5QixFQUFFO1FBRW5JLDhCQUFDLHVCQUFVLElBQUMsS0FBSyxFQUFFLEtBQUssRUFBRSxPQUFPLEVBQUUsT0FBTyxFQUFFLE9BQU8sRUFBRSxPQUFPLEdBQUk7UUFDaEUsOEJBQUMsbUNBQWdCLElBQ2YsWUFBWSxFQUFFLFlBQVksRUFDMUIsaUJBQWlCLEVBQUUsaUJBQWlCLEVBQ3BDLFlBQVksRUFBRSxVQUFVLEVBQ3hCLHlCQUF5QixFQUFFLE9BQU8sRUFDbEMsa0JBQWtCLEVBQUUsUUFBUSxFQUM1QixnQkFBZ0IsRUFBRSxnQkFBZ0IsR0FDbEM7UUFDRiw4QkFBQyxxQkFBUyxJQUNSLEdBQUcsRUFBRSxRQUFRLEVBQ2IsaUJBQWlCLEVBQUUsaUJBQWlCLEVBQ3BDLE1BQU0sRUFBRSxNQUFNLEVBQ2QsZ0JBQWdCLEVBQUUsZ0JBQWdCLEVBQ2xDLDRCQUE0QixFQUFFLDRCQUE0QixHQUMxRDtRQUNGLDhCQUFDLHVCQUFVLElBQ1QsTUFBTSxFQUFFLE1BQU0sRUFDZCxrQkFBa0IsRUFBRSxrQkFBa0IsRUFDdEMsU0FBUyxFQUFFLGdCQUFnQixFQUMzQixVQUFVLEVBQUUsVUFBVSxHQUN0QixDQUNFLENBQ1AsQ0FBQztBQUNKLENBQUMsQ0FBQztBQWxEVyxRQUFBLFdBQVcsZUFrRHRCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IHVzZUNvbnRleHQgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBEeHBBaVNlcnZpY2UgfSBmcm9tICdAc3F1aXovZHhwLWFpLWNsaWVudCc7XG5cbmltcG9ydCB7IENoYXRDb250ZXh0UHJvdmlkZXIsIENoYXRDb250ZXh0IH0gZnJvbSAnLi9jb250ZXh0L0NoYXRDb250ZXh0JztcbmltcG9ydCB7IENoYXRIZWFkZXIgfSBmcm9tICcuL2NvbXBvbmVudHMvQ2hhdEhlYWRlci9DaGF0SGVhZGVyJztcbmltcG9ydCB7IENoYXRDb252ZXJzYXRpb24gfSBmcm9tICcuL2NvbXBvbmVudHMvQ2hhdENvbnZlcnNhdGlvbi9DaGF0Q29udmVyc2F0aW9uJztcbmltcG9ydCB7IENoYXRJbnB1dCB9IGZyb20gJy4vY29tcG9uZW50cy9DaGF0SW5wdXQvQ2hhdElucHV0JztcbmltcG9ydCB7IENoYXRGb290ZXIgfSBmcm9tICcuL2NvbXBvbmVudHMvQ2hhdEZvb3Rlci9DaGF0Rm9vdGVyJztcbmltcG9ydCB7IENIQVRfSU5QVVRfTElNSVRTIH0gZnJvbSAnLi9DaGF0VUkuY29uc3RhbnRzJztcblxuZXhwb3J0IHR5cGUgQ2hhdFVJUHJvcHMgPSB7XG4gIGFpSWQ6IHN0cmluZztcbiAgYWlBcGlVcmw/OiBzdHJpbmc7XG4gIGFpU2VydmljZT86IER4cEFpU2VydmljZTx1bmtub3duPjtcbiAgaXNQcmV2aWV3PzogYm9vbGVhbjtcbiAgZnVsbHNjcmVlbj86IGJvb2xlYW47XG4gIHRpdGxlPzogc3RyaW5nO1xuICB0aXRsZUlkPzogc3RyaW5nOyAvLyBDYW4gcHJvdmlkZSBhIHRpdGxlIGlkIGF0dHJpYnV0ZXMgZm9yIGFyaWEtZGVzY3JpYmVkYnkgaWYgcGxhY2VkIGluIGEgbW9kYWxcbiAgZ3JlZXRpbmc6IHN0cmluZztcbiAgaWNvblNyYz86IHN0cmluZztcbiAgaW5wdXRSZWY/OiBSZWFjdC5Gb3J3YXJkZWRSZWY8SFRNTElucHV0RWxlbWVudD47XG4gIG1heE1lc3NhZ2VMZW5ndGg/OiBudW1iZXI7IC8vIHNob3dzIHJlZCBtZXNzYWdlIGAke21lc3NhZ2VNYXhMZW5ndGggKyAxfS9tZXNzYWdlTWF4TGVuZ3RoYCBkZWZhdWx0IDUwMDtcbiAgcGVyc2lzdFRocmVhZD86IGJvb2xlYW47XG4gIHNob3dOdW1DaGFyYWN0ZXJzVHlwZWRMZW5ndGg/OiBudW1iZXI7IC8vIHNob3cgZ3JleSBtZXNzYWdlIGAke3Nob3dDaGFyYWN0ZXJzVHlwZWRMZW5ndGggKyAxfS9tZXNzYWdlTWF4TGVuZ3RoYCBkZWZhdWx0IDQwMDtcbn07XG5cbmV4cG9ydCBjb25zdCBDaGF0VUkgPSAocHJvcHM6IENoYXRVSVByb3BzKSA9PiB7XG4gIHJldHVybiAoXG4gICAgPENoYXRDb250ZXh0UHJvdmlkZXJcbiAgICAgIGFpSWQ9e3Byb3BzLmFpSWR9XG4gICAgICBhaUFwaVVybD17cHJvcHMuYWlBcGlVcmx9XG4gICAgICBhaVNlcnZpY2U9e3Byb3BzLmFpU2VydmljZX1cbiAgICAgIGlzUHJldmlldz17cHJvcHMuaXNQcmV2aWV3fVxuICAgICAgZ3JlZXRpbmc9e3Byb3BzLmdyZWV0aW5nfVxuICAgICAgcGVyc2lzdFRocmVhZD17cHJvcHMucGVyc2lzdFRocmVhZH1cbiAgICA+XG4gICAgICA8Q2hhdFVJSW5uZXIgey4uLnByb3BzfSAvPlxuICAgIDwvQ2hhdENvbnRleHRQcm92aWRlcj5cbiAgKTtcbn07XG5cbmV4cG9ydCBjb25zdCBDaGF0VUlJbm5lciA9IChwcm9wczogQ2hhdFVJUHJvcHMpID0+IHtcbiAgY29uc3Qge1xuICAgIGZ1bGxzY3JlZW4gPSBmYWxzZSxcbiAgICB0aXRsZSxcbiAgICB0aXRsZUlkLFxuICAgIGljb25TcmMsXG4gICAgZ3JlZXRpbmcsXG4gICAgaW5wdXRSZWYsXG4gICAgbWF4TWVzc2FnZUxlbmd0aCA9IENIQVRfSU5QVVRfTElNSVRTLm1heE1lc3NhZ2VMZW5ndGgsXG4gICAgc2hvd051bUNoYXJhY3RlcnNUeXBlZExlbmd0aCA9IENIQVRfSU5QVVRfTElNSVRTLnNob3dOdW1DaGFyYWN0ZXJzVHlwZWRMZW5ndGgsXG4gIH0gPSBwcm9wcztcbiAgY29uc3Qge1xuICAgIHJhdGluZyxcbiAgICBpc1Byb2Nlc3NpbmdSYXRpbmcsXG4gICAgaXNXYWl0aW5nUmVzcG9uc2UsXG4gICAgY29udmVyc2F0aW9uLFxuICAgIG9uU2VuZCxcbiAgICBvbk5ld0NoYXRSZXF1ZXN0LFxuICAgIG9uTmV3Q2hhdENvbmZpcm0sXG4gICAgb25SYXRlQ2hhdCxcbiAgfSA9IHVzZUNvbnRleHQoQ2hhdENvbnRleHQpO1xuXG4gIHJldHVybiAoXG4gICAgPGRpdlxuICAgICAgY2xhc3NOYW1lPXtgc3F1aXpDaGF0VUkgJHtmdWxsc2NyZWVuID8gJ3NxdWl6Q2hhdFVJLS1mdWxsU2NyZWVuJyA6ICcnfSAke2NvbnZlcnNhdGlvbi5sZW5ndGggPiAxID8gJycgOiAnc3F1aXpDaGF0VUktLW5vTWVzc2FnZXMnfWB9XG4gICAgPlxuICAgICAgPENoYXRIZWFkZXIgdGl0bGU9e3RpdGxlfSB0aXRsZUlkPXt0aXRsZUlkfSBpY29uU3JjPXtpY29uU3JjfSAvPlxuICAgICAgPENoYXRDb252ZXJzYXRpb25cbiAgICAgICAgY29udmVyc2F0aW9uPXtjb252ZXJzYXRpb259XG4gICAgICAgIGlzV2FpdGluZ1Jlc3BvbnNlPXtpc1dhaXRpbmdSZXNwb25zZX1cbiAgICAgICAgaXNGdWxsc2NyZWVuPXtmdWxsc2NyZWVufVxuICAgICAgICBmdWxsU2NyZWVuR3JlZXRpbmdJY29uU3JjPXtpY29uU3JjfVxuICAgICAgICBmdWxsU2NyZWVuR3JlZXRpbmc9e2dyZWV0aW5nfVxuICAgICAgICBvbk5ld0NoYXRDb25maXJtPXtvbk5ld0NoYXRDb25maXJtfVxuICAgICAgLz5cbiAgICAgIDxDaGF0SW5wdXRcbiAgICAgICAgcmVmPXtpbnB1dFJlZn1cbiAgICAgICAgaXNXYWl0aW5nUmVzcG9uc2U9e2lzV2FpdGluZ1Jlc3BvbnNlfVxuICAgICAgICBvblNlbmQ9e29uU2VuZH1cbiAgICAgICAgbWF4TWVzc2FnZUxlbmd0aD17bWF4TWVzc2FnZUxlbmd0aH1cbiAgICAgICAgc2hvd051bUNoYXJhY3RlcnNUeXBlZExlbmd0aD17c2hvd051bUNoYXJhY3RlcnNUeXBlZExlbmd0aH1cbiAgICAgIC8+XG4gICAgICA8Q2hhdEZvb3RlclxuICAgICAgICByYXRpbmc9e3JhdGluZ31cbiAgICAgICAgaXNQcm9jZXNzaW5nUmF0aW5nPXtpc1Byb2Nlc3NpbmdSYXRpbmd9XG4gICAgICAgIG9uTmV3Q2hhdD17b25OZXdDaGF0UmVxdWVzdH1cbiAgICAgICAgb25SYXRlQ2hhdD17b25SYXRlQ2hhdH1cbiAgICAgIC8+XG4gICAgPC9kaXY+XG4gICk7XG59O1xuIl19 | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQ2hhdFVJLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL0NoYXRVSS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSwrQ0FBMEM7QUFHMUMsdURBQXlFO0FBQ3pFLG1FQUFnRTtBQUNoRSxxRkFBa0Y7QUFDbEYsZ0VBQTZEO0FBQzdELG1FQUFnRTtBQUNoRSx5REFBdUQ7QUFtQmhELE1BQU0sTUFBTSxHQUFHLENBQUMsS0FBa0IsRUFBRSxFQUFFO0lBQzNDLE9BQU8sQ0FDTCw4QkFBQyxpQ0FBbUIsSUFDbEIsSUFBSSxFQUFFLEtBQUssQ0FBQyxJQUFJLEVBQ2hCLFFBQVEsRUFBRSxLQUFLLENBQUMsUUFBUSxFQUN4QixTQUFTLEVBQUUsS0FBSyxDQUFDLFNBQVMsRUFDMUIsU0FBUyxFQUFFLEtBQUssQ0FBQyxTQUFTLEVBQzFCLFFBQVEsRUFBRSxLQUFLLENBQUMsUUFBUSxFQUN4QixhQUFhLEVBQUUsS0FBSyxDQUFDLGFBQWE7UUFFbEMsOEJBQUMsbUJBQVcsT0FBSyxLQUFLLEdBQUksQ0FDTixDQUN2QixDQUFDO0FBQ0osQ0FBQyxDQUFDO0FBYlcsUUFBQSxNQUFNLFVBYWpCO0FBRUYsTUFBTSxnQkFBZ0IsR0FBRyxDQUFDLElBQXNCLEVBQTBCLEVBQUU7SUFDMUUsT0FBUSxJQUF1QixDQUFDLElBQUksS0FBSyxTQUFTLENBQUM7QUFDckQsQ0FBQyxDQUFDO0FBRUssTUFBTSxjQUFjLEdBQUcsQ0FBQyxJQUFzQixFQUFFLEVBQUU7SUFDdkQsT0FBTyxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsSUFBSSxJQUFJLENBQUMsSUFBSSxLQUFLLGNBQWMsQ0FBQztBQUNoRSxDQUFDLENBQUM7QUFGVyxRQUFBLGNBQWMsa0JBRXpCO0FBRUssTUFBTSxXQUFXLEdBQUcsQ0FBQyxLQUFrQixFQUFFLEVBQUU7SUFDaEQsTUFBTSxFQUNKLFVBQVUsR0FBRyxLQUFLLEVBQ2xCLEtBQUssRUFDTCxPQUFPLEVBQ1AsT0FBTyxFQUNQLFFBQVEsRUFDUixRQUFRLEVBQ1IsZ0JBQWdCLEdBQUcsb0NBQWlCLENBQUMsZ0JBQWdCLEVBQ3JELDRCQUE0QixHQUFHLG9DQUFpQixDQUFDLDRCQUE0QixHQUM5RSxHQUFHLEtBQUssQ0FBQztJQUNWLE1BQU0sRUFDSixNQUFNLEVBQ04sa0JBQWtCLEVBQ2xCLGlCQUFpQixFQUNqQixrQkFBa0IsRUFDbEIsWUFBWSxFQUNaLE1BQU0sRUFDTixnQkFBZ0IsRUFDaEIsZ0JBQWdCLEVBQ2hCLFVBQVUsR0FDWCxHQUFHLElBQUEsa0JBQVUsRUFBQyx5QkFBVyxDQUFDLENBQUM7SUFFNUIsT0FBTyxDQUNMLHVDQUNFLFNBQVMsRUFBRSxlQUFlLFVBQVUsQ0FBQyxDQUFDLENBQUMseUJBQXlCLENBQUMsQ0FBQyxDQUFDLEVBQUUsSUFBSSxZQUFZLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyx5QkFBeUIsRUFBRTtRQUVuSSw4QkFBQyx1QkFBVSxJQUFDLEtBQUssRUFBRSxLQUFLLEVBQUUsT0FBTyxFQUFFLE9BQU8sRUFBRSxPQUFPLEVBQUUsT0FBTyxHQUFJO1FBQ2hFLDhCQUFDLG1DQUFnQixJQUNmLFlBQVksRUFBRSxZQUFZLEVBQzFCLGlCQUFpQixFQUFFLGlCQUFpQixFQUNwQyxZQUFZLEVBQUUsVUFBVSxFQUN4Qix5QkFBeUIsRUFBRSxPQUFPLEVBQ2xDLGtCQUFrQixFQUFFLFFBQVEsRUFDNUIsZ0JBQWdCLEVBQUUsZ0JBQWdCLEdBQ2xDO1FBQ0YsOEJBQUMscUJBQVMsSUFDUixHQUFHLEVBQUUsUUFBUSxFQUNiLGlCQUFpQixFQUFFLGlCQUFpQixFQUNwQyxNQUFNLEVBQUUsTUFBTSxFQUNkLGdCQUFnQixFQUFFLGdCQUFnQixFQUNsQyw0QkFBNEIsRUFBRSw0QkFBNEIsR0FDMUQ7UUFDRiw4QkFBQyx1QkFBVSxJQUNULFNBQVMsRUFBRSxZQUFZLENBQUMsTUFBTSxJQUFJLENBQUMsSUFBSSxJQUFBLHNCQUFjLEVBQUMsWUFBWSxDQUFDLFlBQVksQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFDNUYsTUFBTSxFQUFFLE1BQU0sRUFDZCxrQkFBa0IsRUFBRSxrQkFBa0IsRUFDdEMsaUJBQWlCLEVBQUUsaUJBQWlCLEVBQ3BDLGtCQUFrQixFQUFFLGtCQUFrQixFQUN0QyxTQUFTLEVBQUUsZ0JBQWdCLEVBQzNCLFVBQVUsRUFBRSxVQUFVLEdBQ3RCLENBQ0UsQ0FDUCxDQUFDO0FBQ0osQ0FBQyxDQUFDO0FBdERXLFFBQUEsV0FBVyxlQXNEdEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlQ29udGV4dCB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IER4cEFpU2VydmljZSB9IGZyb20gJ0BzcXVpei9keHAtYWktY2xpZW50JztcblxuaW1wb3J0IHsgQ2hhdENvbnRleHRQcm92aWRlciwgQ2hhdENvbnRleHQgfSBmcm9tICcuL2NvbnRleHQvQ2hhdENvbnRleHQnO1xuaW1wb3J0IHsgQ2hhdEhlYWRlciB9IGZyb20gJy4vY29tcG9uZW50cy9DaGF0SGVhZGVyL0NoYXRIZWFkZXInO1xuaW1wb3J0IHsgQ2hhdENvbnZlcnNhdGlvbiB9IGZyb20gJy4vY29tcG9uZW50cy9DaGF0Q29udmVyc2F0aW9uL0NoYXRDb252ZXJzYXRpb24nO1xuaW1wb3J0IHsgQ2hhdElucHV0IH0gZnJvbSAnLi9jb21wb25lbnRzL0NoYXRJbnB1dC9DaGF0SW5wdXQnO1xuaW1wb3J0IHsgQ2hhdEZvb3RlciB9IGZyb20gJy4vY29tcG9uZW50cy9DaGF0Rm9vdGVyL0NoYXRGb290ZXInO1xuaW1wb3J0IHsgQ0hBVF9JTlBVVF9MSU1JVFMgfSBmcm9tICcuL0NoYXRVSS5jb25zdGFudHMnO1xuaW1wb3J0IHsgQ29udHJvbE1lc3NhZ2UsIENvbnZlcnNhdGlvbkl0ZW0gfSBmcm9tICcuL3R5cGVzJztcblxuZXhwb3J0IHR5cGUgQ2hhdFVJUHJvcHMgPSB7XG4gIGFpSWQ6IHN0cmluZztcbiAgYWlBcGlVcmw/OiBzdHJpbmc7XG4gIGFpU2VydmljZT86IER4cEFpU2VydmljZTx1bmtub3duPjtcbiAgaXNQcmV2aWV3PzogYm9vbGVhbjtcbiAgZnVsbHNjcmVlbj86IGJvb2xlYW47XG4gIHRpdGxlPzogc3RyaW5nO1xuICB0aXRsZUlkPzogc3RyaW5nOyAvLyBDYW4gcHJvdmlkZSBhIHRpdGxlIGlkIGF0dHJpYnV0ZXMgZm9yIGFyaWEtZGVzY3JpYmVkYnkgaWYgcGxhY2VkIGluIGEgbW9kYWxcbiAgZ3JlZXRpbmc6IHN0cmluZztcbiAgaWNvblNyYz86IHN0cmluZztcbiAgaW5wdXRSZWY/OiBSZWFjdC5Gb3J3YXJkZWRSZWY8SFRNTElucHV0RWxlbWVudD47XG4gIG1heE1lc3NhZ2VMZW5ndGg/OiBudW1iZXI7IC8vIHNob3dzIHJlZCBtZXNzYWdlIGAke21lc3NhZ2VNYXhMZW5ndGggKyAxfS9tZXNzYWdlTWF4TGVuZ3RoYCBkZWZhdWx0IDUwMDtcbiAgcGVyc2lzdFRocmVhZD86IGJvb2xlYW47XG4gIHNob3dOdW1DaGFyYWN0ZXJzVHlwZWRMZW5ndGg/OiBudW1iZXI7IC8vIHNob3cgZ3JleSBtZXNzYWdlIGAke3Nob3dDaGFyYWN0ZXJzVHlwZWRMZW5ndGggKyAxfS9tZXNzYWdlTWF4TGVuZ3RoYCBkZWZhdWx0IDQwMDtcbn07XG5cbmV4cG9ydCBjb25zdCBDaGF0VUkgPSAocHJvcHM6IENoYXRVSVByb3BzKSA9PiB7XG4gIHJldHVybiAoXG4gICAgPENoYXRDb250ZXh0UHJvdmlkZXJcbiAgICAgIGFpSWQ9e3Byb3BzLmFpSWR9XG4gICAgICBhaUFwaVVybD17cHJvcHMuYWlBcGlVcmx9XG4gICAgICBhaVNlcnZpY2U9e3Byb3BzLmFpU2VydmljZX1cbiAgICAgIGlzUHJldmlldz17cHJvcHMuaXNQcmV2aWV3fVxuICAgICAgZ3JlZXRpbmc9e3Byb3BzLmdyZWV0aW5nfVxuICAgICAgcGVyc2lzdFRocmVhZD17cHJvcHMucGVyc2lzdFRocmVhZH1cbiAgICA+XG4gICAgICA8Q2hhdFVJSW5uZXIgey4uLnByb3BzfSAvPlxuICAgIDwvQ2hhdENvbnRleHRQcm92aWRlcj5cbiAgKTtcbn07XG5cbmNvbnN0IGlzQ29udHJvbE1lc3NhZ2UgPSAoaXRlbTogQ29udmVyc2F0aW9uSXRlbSk6IGl0ZW0gaXMgQ29udHJvbE1lc3NhZ2UgPT4ge1xuICByZXR1cm4gKGl0ZW0gYXMgQ29udHJvbE1lc3NhZ2UpLnR5cGUgIT09IHVuZGVmaW5lZDtcbn07XG5cbmV4cG9ydCBjb25zdCBpc05ld0NoYXRCcmVhayA9IChpdGVtOiBDb252ZXJzYXRpb25JdGVtKSA9PiB7XG4gIHJldHVybiBpc0NvbnRyb2xNZXNzYWdlKGl0ZW0pICYmIGl0ZW0udHlwZSA9PT0gYG5ld0NoYXRCcmVha2A7XG59O1xuXG5leHBvcnQgY29uc3QgQ2hhdFVJSW5uZXIgPSAocHJvcHM6IENoYXRVSVByb3BzKSA9PiB7XG4gIGNvbnN0IHtcbiAgICBmdWxsc2NyZWVuID0gZmFsc2UsXG4gICAgdGl0bGUsXG4gICAgdGl0bGVJZCxcbiAgICBpY29uU3JjLFxuICAgIGdyZWV0aW5nLFxuICAgIGlucHV0UmVmLFxuICAgIG1heE1lc3NhZ2VMZW5ndGggPSBDSEFUX0lOUFVUX0xJTUlUUy5tYXhNZXNzYWdlTGVuZ3RoLFxuICAgIHNob3dOdW1DaGFyYWN0ZXJzVHlwZWRMZW5ndGggPSBDSEFUX0lOUFVUX0xJTUlUUy5zaG93TnVtQ2hhcmFjdGVyc1R5cGVkTGVuZ3RoLFxuICB9ID0gcHJvcHM7XG4gIGNvbnN0IHtcbiAgICByYXRpbmcsXG4gICAgaXNQcm9jZXNzaW5nUmF0aW5nLFxuICAgIGlzV2FpdGluZ1Jlc3BvbnNlLFxuICAgIGlzV2FpdGluZ1VzZXJJbnB1dCxcbiAgICBjb252ZXJzYXRpb24sXG4gICAgb25TZW5kLFxuICAgIG9uTmV3Q2hhdFJlcXVlc3QsXG4gICAgb25OZXdDaGF0Q29uZmlybSxcbiAgICBvblJhdGVDaGF0LFxuICB9ID0gdXNlQ29udGV4dChDaGF0Q29udGV4dCk7XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2XG4gICAgICBjbGFzc05hbWU9e2BzcXVpekNoYXRVSSAke2Z1bGxzY3JlZW4gPyAnc3F1aXpDaGF0VUktLWZ1bGxTY3JlZW4nIDogJyd9ICR7Y29udmVyc2F0aW9uLmxlbmd0aCA+IDEgPyAnJyA6ICdzcXVpekNoYXRVSS0tbm9NZXNzYWdlcyd9YH1cbiAgICA+XG4gICAgICA8Q2hhdEhlYWRlciB0aXRsZT17dGl0bGV9IHRpdGxlSWQ9e3RpdGxlSWR9IGljb25TcmM9e2ljb25TcmN9IC8+XG4gICAgICA8Q2hhdENvbnZlcnNhdGlvblxuICAgICAgICBjb252ZXJzYXRpb249e2NvbnZlcnNhdGlvbn1cbiAgICAgICAgaXNXYWl0aW5nUmVzcG9uc2U9e2lzV2FpdGluZ1Jlc3BvbnNlfVxuICAgICAgICBpc0Z1bGxzY3JlZW49e2Z1bGxzY3JlZW59XG4gICAgICAgIGZ1bGxTY3JlZW5HcmVldGluZ0ljb25TcmM9e2ljb25TcmN9XG4gICAgICAgIGZ1bGxTY3JlZW5HcmVldGluZz17Z3JlZXRpbmd9XG4gICAgICAgIG9uTmV3Q2hhdENvbmZpcm09e29uTmV3Q2hhdENvbmZpcm19XG4gICAgICAvPlxuICAgICAgPENoYXRJbnB1dFxuICAgICAgICByZWY9e2lucHV0UmVmfVxuICAgICAgICBpc1dhaXRpbmdSZXNwb25zZT17aXNXYWl0aW5nUmVzcG9uc2V9XG4gICAgICAgIG9uU2VuZD17b25TZW5kfVxuICAgICAgICBtYXhNZXNzYWdlTGVuZ3RoPXttYXhNZXNzYWdlTGVuZ3RofVxuICAgICAgICBzaG93TnVtQ2hhcmFjdGVyc1R5cGVkTGVuZ3RoPXtzaG93TnVtQ2hhcmFjdGVyc1R5cGVkTGVuZ3RofVxuICAgICAgLz5cbiAgICAgIDxDaGF0Rm9vdGVyXG4gICAgICAgIGlzTmV3Q2hhdD17Y29udmVyc2F0aW9uLmxlbmd0aCA8PSAxIHx8IGlzTmV3Q2hhdEJyZWFrKGNvbnZlcnNhdGlvbltjb252ZXJzYXRpb24ubGVuZ3RoIC0gMl0pfVxuICAgICAgICByYXRpbmc9e3JhdGluZ31cbiAgICAgICAgaXNQcm9jZXNzaW5nUmF0aW5nPXtpc1Byb2Nlc3NpbmdSYXRpbmd9XG4gICAgICAgIGlzV2FpdGluZ1Jlc3BvbnNlPXtpc1dhaXRpbmdSZXNwb25zZX1cbiAgICAgICAgaXNXYWl0aW5nVXNlcklucHV0PXtpc1dhaXRpbmdVc2VySW5wdXR9XG4gICAgICAgIG9uTmV3Q2hhdD17b25OZXdDaGF0UmVxdWVzdH1cbiAgICAgICAgb25SYXRlQ2hhdD17b25SYXRlQ2hhdH1cbiAgICAgIC8+XG4gICAgPC9kaXY+XG4gICk7XG59O1xuIl19 |
@@ -68,2 +68,3 @@ "use strict"; | ||
isWaitingResponse: false, | ||
isWaitingUserInput: false, | ||
conversation: [], | ||
@@ -83,2 +84,3 @@ onRateChat: () => { }, | ||
isWaitingResponse: false, | ||
isWaitingUserInput: false, | ||
conversation: [ | ||
@@ -99,3 +101,3 @@ { | ||
}); | ||
it('ChatUI will not add class conversation if user has added a', async () => { | ||
it('ChatUI will not add class conversation if user has added a message', async () => { | ||
const { container } = (0, react_2.render)(react_1.default.createElement(ChatContext.ChatContext.Provider, { value: { | ||
@@ -105,2 +107,3 @@ rating: null, | ||
isWaitingResponse: false, | ||
isWaitingUserInput: false, | ||
conversation: [ | ||
@@ -166,3 +169,34 @@ { | ||
}); | ||
describe(`isNewChatBreak() tests`, () => { | ||
const conversation = [ | ||
{ | ||
id: '1', | ||
text: 'greeting', | ||
sender: 'Frontend', | ||
}, | ||
{ | ||
id: '2', | ||
text: 'help me', | ||
sender: 'User', | ||
}, | ||
{ | ||
id: '3', | ||
type: `newChatBreak`, | ||
}, | ||
{ | ||
id: '4', | ||
text: 'welcome', | ||
sender: 'Frontend', | ||
}, | ||
]; | ||
it('should return false if item is not a new chat break', () => { | ||
expect((0, ChatUI_1.isNewChatBreak)(conversation[0])).toBe(false); | ||
expect((0, ChatUI_1.isNewChatBreak)(conversation[1])).toBe(false); | ||
expect((0, ChatUI_1.isNewChatBreak)(conversation[3])).toBe(false); | ||
}); | ||
it('should return true if 2nd previous message is a new chat break', () => { | ||
expect((0, ChatUI_1.isNewChatBreak)(conversation[2])).toBe(true); | ||
}); | ||
}); | ||
}); | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ChatUI.spec.js","sourceRoot":"","sources":["../src/ChatUI.spec.tsx"],"names":[],"mappings":"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","sourcesContent":["import React from 'react';\nimport { act, fireEvent, render, screen, waitFor } from '@testing-library/react';\nimport '@testing-library/jest-dom';\nimport { ChatUI, ChatUIInner } from './ChatUI';\nimport * as ChatHeaderModule from './components/ChatHeader/ChatHeader';\nimport * as ChatContext from './context/ChatContext';\nimport { faker } from '@faker-js/faker';\n\njest.spyOn(ChatHeaderModule, 'ChatHeader');\njest.spyOn(ChatContext, 'ChatContextProvider');\n\n// ChatConversation uses an element property jsdom doesn't define itself\nObject.defineProperty(window.Element.prototype, 'scrollTo', {\n  writable: true,\n  value: jest.fn(),\n});\n\njest.mock('@squiz/dxp-ai-client', () => {\n  return {\n    DxpAiService: jest.fn(),\n    createClient: jest.fn(),\n    ChatBotCommandExecutor: jest.fn(),\n  };\n});\n\ndescribe('ChatUI ', () => {\n  const defaultArgs = {\n    aiId: 'testAiId',\n    aiApiUrl: 'https://www.google.com',\n    greeting: 'How can i help?',\n  };\n  it('ChatUI will default to not fullscreen', async () => {\n    const { container } = render(<ChatUI {...defaultArgs} />);\n    expect(container.querySelectorAll('.squizChatUI--fullScreen').length).toEqual(0);\n  });\n\n  it('ChatUI will render fullscreen when instructed', async () => {\n    const { container } = render(<ChatUI {...defaultArgs} fullscreen={true} />);\n    expect(container.querySelectorAll('.squizChatUI--fullScreen').length).toEqual(1);\n  });\n\n  it('ChatUI will add class conversation has no messages', async () => {\n    const { container } = render(\n      <ChatContext.ChatContext.Provider\n        value={{\n          rating: null,\n          isProcessingRating: false,\n          isWaitingResponse: false,\n          conversation: [],\n          onRateChat: () => {},\n          onNewChatRequest: () => {},\n          onNewChatConfirm: () => {},\n          onSend: () => {},\n        }}\n      >\n        <ChatUIInner {...defaultArgs} />\n      </ChatContext.ChatContext.Provider>,\n    );\n    expect(container.querySelectorAll('.squizChatUI--noMessages').length).toEqual(1);\n  });\n\n  it('ChatUI will add class conversation has no messages (first message / greeting excluded)', async () => {\n    const { container } = render(\n      <ChatContext.ChatContext.Provider\n        value={{\n          rating: null,\n          isProcessingRating: false,\n          isWaitingResponse: false,\n          conversation: [\n            {\n              id: '1',\n              text: 'greeting',\n              sender: 'Frontend',\n            },\n          ],\n          onRateChat: () => {},\n          onNewChatRequest: () => {},\n          onNewChatConfirm: () => {},\n          onSend: () => {},\n        }}\n      >\n        <ChatUIInner {...defaultArgs} />\n      </ChatContext.ChatContext.Provider>,\n    );\n    expect(container.querySelectorAll('.squizChatUI--noMessages').length).toEqual(1);\n  });\n\n  it('ChatUI will not add class conversation if user has added a', async () => {\n    const { container } = render(\n      <ChatContext.ChatContext.Provider\n        value={{\n          rating: null,\n          isProcessingRating: false,\n          isWaitingResponse: false,\n          conversation: [\n            {\n              id: '1',\n              text: 'greeting',\n              sender: 'Frontend',\n            },\n            {\n              id: '2',\n              text: 'help me',\n              sender: 'User',\n            },\n          ],\n          onRateChat: () => {},\n          onNewChatRequest: () => {},\n          onNewChatConfirm: () => {},\n          onSend: () => {},\n        }}\n      >\n        <ChatUIInner {...defaultArgs} />\n      </ChatContext.ChatContext.Provider>,\n    );\n    expect(container.querySelectorAll('.squizChatUI--noMessages').length).toEqual(0);\n  });\n\n  it('ChatUI will pass title to ChatHeader', async () => {\n    render(<ChatUI {...defaultArgs} title=\"testTitle\" />);\n    expect(ChatHeaderModule.ChatHeader).toHaveBeenCalledWith(expect.objectContaining({ title: 'testTitle' }), {});\n  });\n\n  it('ChatUI will pass iconSrc to ChatHeader', async () => {\n    render(<ChatUI {...defaultArgs} iconSrc=\"testIconSrc\" />);\n    expect(ChatHeaderModule.ChatHeader).toHaveBeenCalledWith(expect.objectContaining({ iconSrc: 'testIconSrc' }), {});\n  });\n\n  it('ChatUI will pass context props to the ContextProvider', async () => {\n    render(<ChatUI {...defaultArgs} iconSrc=\"testIconSrc\" />);\n    expect(ChatContext.ChatContextProvider).toHaveBeenCalledWith(\n      expect.objectContaining({\n        aiId: defaultArgs.aiId,\n        aiApiUrl: defaultArgs.aiApiUrl,\n        greeting: defaultArgs.greeting,\n      }),\n      {},\n    );\n  });\n\n  it('ChatUI input validation limits can be overridden by maxMessageLength, showNumCharactersTypedLength', async () => {\n    const args = {\n      ...defaultArgs,\n      maxMessageLength: 100,\n      showNumCharactersTypedLength: 50,\n    };\n    render(<ChatUI {...args} iconSrc=\"testIconSrc\" />);\n\n    await act(async () => {\n      fireEvent.change(screen.getByRole('textbox', { name: 'message' }), {\n        target: { value: faker.lorem.words(8).slice(0, 51) },\n      });\n    });\n\n    await waitFor(() => {\n      expect(screen.getByTestId('chat-ui-validation-message')).toHaveTextContent('51/100');\n    });\n\n    await act(async () => {\n      fireEvent.change(screen.getByRole('textbox', { name: 'message' }), {\n        target: { value: faker.lorem.words(20).slice(0, 101) },\n      });\n    });\n\n    await waitFor(() => {\n      expect(screen.getByTestId('chat-ui-validation-message')).toHaveTextContent('101/100');\n    });\n  });\n});\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ChatUI.spec.js","sourceRoot":"","sources":["../src/ChatUI.spec.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,kDAA0B;AAC1B,kDAAiF;AACjF,qCAAmC;AACnC,qCAA+D;AAC/D,qFAAuE;AACvE,mEAAqD;AACrD,2CAAwC;AAGxC,IAAI,CAAC,KAAK,CAAC,gBAAgB,EAAE,YAAY,CAAC,CAAC;AAC3C,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE,qBAAqB,CAAC,CAAC;AAG/C,MAAM,CAAC,cAAc,CAAC,MAAM,CAAC,OAAO,CAAC,SAAS,EAAE,UAAU,EAAE;IAC1D,QAAQ,EAAE,IAAI;IACd,KAAK,EAAE,IAAI,CAAC,EAAE,EAAE;CACjB,CAAC,CAAC;AAEH,IAAI,CAAC,IAAI,CAAC,sBAAsB,EAAE,GAAG,EAAE;IACrC,OAAO;QACL,YAAY,EAAE,IAAI,CAAC,EAAE,EAAE;QACvB,YAAY,EAAE,IAAI,CAAC,EAAE,EAAE;QACvB,sBAAsB,EAAE,IAAI,CAAC,EAAE,EAAE;KAClC,CAAC;AACJ,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,SAAS,EAAE,GAAG,EAAE;IACvB,MAAM,WAAW,GAAG;QAClB,IAAI,EAAE,UAAU;QAChB,QAAQ,EAAE,wBAAwB;QAClC,QAAQ,EAAE,iBAAiB;KAC5B,CAAC;IACF,EAAE,CAAC,uCAAuC,EAAE,KAAK,IAAI,EAAE;QACrD,MAAM,EAAE,SAAS,EAAE,GAAG,IAAA,cAAM,EAAC,8BAAC,eAAM,OAAK,WAAW,GAAI,CAAC,CAAC;QAC1D,MAAM,CAAC,SAAS,CAAC,gBAAgB,CAAC,0BAA0B,CAAC,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;IACnF,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,+CAA+C,EAAE,KAAK,IAAI,EAAE;QAC7D,MAAM,EAAE,SAAS,EAAE,GAAG,IAAA,cAAM,EAAC,8BAAC,eAAM,OAAK,WAAW,EAAE,UAAU,EAAE,IAAI,GAAI,CAAC,CAAC;QAC5E,MAAM,CAAC,SAAS,CAAC,gBAAgB,CAAC,0BAA0B,CAAC,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;IACnF,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oDAAoD,EAAE,KAAK,IAAI,EAAE;QAClE,MAAM,EAAE,SAAS,EAAE,GAAG,IAAA,cAAM,EAC1B,8BAAC,WAAW,CAAC,WAAW,CAAC,QAAQ,IAC/B,KAAK,EAAE;gBACL,MAAM,EAAE,IAAI;gBACZ,kBAAkB,EAAE,KAAK;gBACzB,iBAAiB,EAAE,KAAK;gBACxB,kBAAkB,EAAE,KAAK;gBACzB,YAAY,EAAE,EAAE;gBAChB,UAAU,EAAE,GAAG,EAAE,GAAE,CAAC;gBACpB,gBAAgB,EAAE,GAAG,EAAE,GAAE,CAAC;gBAC1B,gBAAgB,EAAE,GAAG,EAAE,GAAE,CAAC;gBAC1B,MAAM,EAAE,GAAG,EAAE,GAAE,CAAC;aACjB;YAED,8BAAC,oBAAW,OAAK,WAAW,GAAI,CACC,CACpC,CAAC;QACF,MAAM,CAAC,SAAS,CAAC,gBAAgB,CAAC,0BAA0B,CAAC,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;IACnF,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,wFAAwF,EAAE,KAAK,IAAI,EAAE;QACtG,MAAM,EAAE,SAAS,EAAE,GAAG,IAAA,cAAM,EAC1B,8BAAC,WAAW,CAAC,WAAW,CAAC,QAAQ,IAC/B,KAAK,EAAE;gBACL,MAAM,EAAE,IAAI;gBACZ,kBAAkB,EAAE,KAAK;gBACzB,iBAAiB,EAAE,KAAK;gBACxB,kBAAkB,EAAE,KAAK;gBACzB,YAAY,EAAE;oBACZ;wBACE,EAAE,EAAE,GAAG;wBACP,IAAI,EAAE,UAAU;wBAChB,MAAM,EAAE,UAAU;qBACnB;iBACF;gBACD,UAAU,EAAE,GAAG,EAAE,GAAE,CAAC;gBACpB,gBAAgB,EAAE,GAAG,EAAE,GAAE,CAAC;gBAC1B,gBAAgB,EAAE,GAAG,EAAE,GAAE,CAAC;gBAC1B,MAAM,EAAE,GAAG,EAAE,GAAE,CAAC;aACjB;YAED,8BAAC,oBAAW,OAAK,WAAW,GAAI,CACC,CACpC,CAAC;QACF,MAAM,CAAC,SAAS,CAAC,gBAAgB,CAAC,0BAA0B,CAAC,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;IACnF,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oEAAoE,EAAE,KAAK,IAAI,EAAE;QAClF,MAAM,EAAE,SAAS,EAAE,GAAG,IAAA,cAAM,EAC1B,8BAAC,WAAW,CAAC,WAAW,CAAC,QAAQ,IAC/B,KAAK,EAAE;gBACL,MAAM,EAAE,IAAI;gBACZ,kBAAkB,EAAE,KAAK;gBACzB,iBAAiB,EAAE,KAAK;gBACxB,kBAAkB,EAAE,KAAK;gBACzB,YAAY,EAAE;oBACZ;wBACE,EAAE,EAAE,GAAG;wBACP,IAAI,EAAE,UAAU;wBAChB,MAAM,EAAE,UAAU;qBACnB;oBACD;wBACE,EAAE,EAAE,GAAG;wBACP,IAAI,EAAE,SAAS;wBACf,MAAM,EAAE,MAAM;qBACf;iBACF;gBACD,UAAU,EAAE,GAAG,EAAE,GAAE,CAAC;gBACpB,gBAAgB,EAAE,GAAG,EAAE,GAAE,CAAC;gBAC1B,gBAAgB,EAAE,GAAG,EAAE,GAAE,CAAC;gBAC1B,MAAM,EAAE,GAAG,EAAE,GAAE,CAAC;aACjB;YAED,8BAAC,oBAAW,OAAK,WAAW,GAAI,CACC,CACpC,CAAC;QACF,MAAM,CAAC,SAAS,CAAC,gBAAgB,CAAC,0BAA0B,CAAC,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;IACnF,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,sCAAsC,EAAE,KAAK,IAAI,EAAE;QACpD,IAAA,cAAM,EAAC,8BAAC,eAAM,OAAK,WAAW,EAAE,KAAK,EAAC,WAAW,GAAG,CAAC,CAAC;QACtD,MAAM,CAAC,gBAAgB,CAAC,UAAU,CAAC,CAAC,oBAAoB,CAAC,MAAM,CAAC,gBAAgB,CAAC,EAAE,KAAK,EAAE,WAAW,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC;IAChH,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,wCAAwC,EAAE,KAAK,IAAI,EAAE;QACtD,IAAA,cAAM,EAAC,8BAAC,eAAM,OAAK,WAAW,EAAE,OAAO,EAAC,aAAa,GAAG,CAAC,CAAC;QAC1D,MAAM,CAAC,gBAAgB,CAAC,UAAU,CAAC,CAAC,oBAAoB,CAAC,MAAM,CAAC,gBAAgB,CAAC,EAAE,OAAO,EAAE,aAAa,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC;IACpH,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,uDAAuD,EAAE,KAAK,IAAI,EAAE;QACrE,IAAA,cAAM,EAAC,8BAAC,eAAM,OAAK,WAAW,EAAE,OAAO,EAAC,aAAa,GAAG,CAAC,CAAC;QAC1D,MAAM,CAAC,WAAW,CAAC,mBAAmB,CAAC,CAAC,oBAAoB,CAC1D,MAAM,CAAC,gBAAgB,CAAC;YACtB,IAAI,EAAE,WAAW,CAAC,IAAI;YACtB,QAAQ,EAAE,WAAW,CAAC,QAAQ;YAC9B,QAAQ,EAAE,WAAW,CAAC,QAAQ;SAC/B,CAAC,EACF,EAAE,CACH,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oGAAoG,EAAE,KAAK,IAAI,EAAE;QAClH,MAAM,IAAI,GAAG;YACX,GAAG,WAAW;YACd,gBAAgB,EAAE,GAAG;YACrB,4BAA4B,EAAE,EAAE;SACjC,CAAC;QACF,IAAA,cAAM,EAAC,8BAAC,eAAM,OAAK,IAAI,EAAE,OAAO,EAAC,aAAa,GAAG,CAAC,CAAC;QAEnD,MAAM,IAAA,WAAG,EAAC,KAAK,IAAI,EAAE;YACnB,iBAAS,CAAC,MAAM,CAAC,cAAM,CAAC,SAAS,CAAC,SAAS,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC,EAAE;gBACjE,MAAM,EAAE,EAAE,KAAK,EAAE,aAAK,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE;aACrD,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;QAEH,MAAM,IAAA,eAAO,EAAC,GAAG,EAAE;YACjB,MAAM,CAAC,cAAM,CAAC,WAAW,CAAC,4BAA4B,CAAC,CAAC,CAAC,iBAAiB,CAAC,QAAQ,CAAC,CAAC;QACvF,CAAC,CAAC,CAAC;QAEH,MAAM,IAAA,WAAG,EAAC,KAAK,IAAI,EAAE;YACnB,iBAAS,CAAC,MAAM,CAAC,cAAM,CAAC,SAAS,CAAC,SAAS,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC,EAAE;gBACjE,MAAM,EAAE,EAAE,KAAK,EAAE,aAAK,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE;aACvD,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;QAEH,MAAM,IAAA,eAAO,EAAC,GAAG,EAAE;YACjB,MAAM,CAAC,cAAM,CAAC,WAAW,CAAC,4BAA4B,CAAC,CAAC,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC;QACxF,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,wBAAwB,EAAE,GAAG,EAAE;QACtC,MAAM,YAAY,GAA4B;YAC5C;gBACE,EAAE,EAAE,GAAG;gBACP,IAAI,EAAE,UAAU;gBAChB,MAAM,EAAE,UAAU;aACnB;YACD;gBACE,EAAE,EAAE,GAAG;gBACP,IAAI,EAAE,SAAS;gBACf,MAAM,EAAE,MAAM;aACf;YACD;gBACE,EAAE,EAAE,GAAG;gBACP,IAAI,EAAE,cAAc;aACrB;YACD;gBACE,EAAE,EAAE,GAAG;gBACP,IAAI,EAAE,SAAS;gBACf,MAAM,EAAE,UAAU;aACnB;SACF,CAAC;QAEF,EAAE,CAAC,qDAAqD,EAAE,GAAG,EAAE;YAC7D,MAAM,CAAC,IAAA,uBAAc,EAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACpD,MAAM,CAAC,IAAA,uBAAc,EAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACpD,MAAM,CAAC,IAAA,uBAAc,EAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACtD,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,gEAAgE,EAAE,GAAG,EAAE;YACxE,MAAM,CAAC,IAAA,uBAAc,EAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACrD,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC","sourcesContent":["import React from 'react';\nimport { act, fireEvent, render, screen, waitFor } from '@testing-library/react';\nimport '@testing-library/jest-dom';\nimport { ChatUI, ChatUIInner, isNewChatBreak } from './ChatUI';\nimport * as ChatHeaderModule from './components/ChatHeader/ChatHeader';\nimport * as ChatContext from './context/ChatContext';\nimport { faker } from '@faker-js/faker';\nimport { ConversationItem } from './types';\n\njest.spyOn(ChatHeaderModule, 'ChatHeader');\njest.spyOn(ChatContext, 'ChatContextProvider');\n\n// ChatConversation uses an element property jsdom doesn't define itself\nObject.defineProperty(window.Element.prototype, 'scrollTo', {\n  writable: true,\n  value: jest.fn(),\n});\n\njest.mock('@squiz/dxp-ai-client', () => {\n  return {\n    DxpAiService: jest.fn(),\n    createClient: jest.fn(),\n    ChatBotCommandExecutor: jest.fn(),\n  };\n});\n\ndescribe('ChatUI ', () => {\n  const defaultArgs = {\n    aiId: 'testAiId',\n    aiApiUrl: 'https://www.google.com',\n    greeting: 'How can i help?',\n  };\n  it('ChatUI will default to not fullscreen', async () => {\n    const { container } = render(<ChatUI {...defaultArgs} />);\n    expect(container.querySelectorAll('.squizChatUI--fullScreen').length).toEqual(0);\n  });\n\n  it('ChatUI will render fullscreen when instructed', async () => {\n    const { container } = render(<ChatUI {...defaultArgs} fullscreen={true} />);\n    expect(container.querySelectorAll('.squizChatUI--fullScreen').length).toEqual(1);\n  });\n\n  it('ChatUI will add class conversation has no messages', async () => {\n    const { container } = render(\n      <ChatContext.ChatContext.Provider\n        value={{\n          rating: null,\n          isProcessingRating: false,\n          isWaitingResponse: false,\n          isWaitingUserInput: false,\n          conversation: [],\n          onRateChat: () => {},\n          onNewChatRequest: () => {},\n          onNewChatConfirm: () => {},\n          onSend: () => {},\n        }}\n      >\n        <ChatUIInner {...defaultArgs} />\n      </ChatContext.ChatContext.Provider>,\n    );\n    expect(container.querySelectorAll('.squizChatUI--noMessages').length).toEqual(1);\n  });\n\n  it('ChatUI will add class conversation has no messages (first message / greeting excluded)', async () => {\n    const { container } = render(\n      <ChatContext.ChatContext.Provider\n        value={{\n          rating: null,\n          isProcessingRating: false,\n          isWaitingResponse: false,\n          isWaitingUserInput: false,\n          conversation: [\n            {\n              id: '1',\n              text: 'greeting',\n              sender: 'Frontend',\n            },\n          ],\n          onRateChat: () => {},\n          onNewChatRequest: () => {},\n          onNewChatConfirm: () => {},\n          onSend: () => {},\n        }}\n      >\n        <ChatUIInner {...defaultArgs} />\n      </ChatContext.ChatContext.Provider>,\n    );\n    expect(container.querySelectorAll('.squizChatUI--noMessages').length).toEqual(1);\n  });\n\n  it('ChatUI will not add class conversation if user has added a message', async () => {\n    const { container } = render(\n      <ChatContext.ChatContext.Provider\n        value={{\n          rating: null,\n          isProcessingRating: false,\n          isWaitingResponse: false,\n          isWaitingUserInput: false,\n          conversation: [\n            {\n              id: '1',\n              text: 'greeting',\n              sender: 'Frontend',\n            },\n            {\n              id: '2',\n              text: 'help me',\n              sender: 'User',\n            },\n          ],\n          onRateChat: () => {},\n          onNewChatRequest: () => {},\n          onNewChatConfirm: () => {},\n          onSend: () => {},\n        }}\n      >\n        <ChatUIInner {...defaultArgs} />\n      </ChatContext.ChatContext.Provider>,\n    );\n    expect(container.querySelectorAll('.squizChatUI--noMessages').length).toEqual(0);\n  });\n\n  it('ChatUI will pass title to ChatHeader', async () => {\n    render(<ChatUI {...defaultArgs} title=\"testTitle\" />);\n    expect(ChatHeaderModule.ChatHeader).toHaveBeenCalledWith(expect.objectContaining({ title: 'testTitle' }), {});\n  });\n\n  it('ChatUI will pass iconSrc to ChatHeader', async () => {\n    render(<ChatUI {...defaultArgs} iconSrc=\"testIconSrc\" />);\n    expect(ChatHeaderModule.ChatHeader).toHaveBeenCalledWith(expect.objectContaining({ iconSrc: 'testIconSrc' }), {});\n  });\n\n  it('ChatUI will pass context props to the ContextProvider', async () => {\n    render(<ChatUI {...defaultArgs} iconSrc=\"testIconSrc\" />);\n    expect(ChatContext.ChatContextProvider).toHaveBeenCalledWith(\n      expect.objectContaining({\n        aiId: defaultArgs.aiId,\n        aiApiUrl: defaultArgs.aiApiUrl,\n        greeting: defaultArgs.greeting,\n      }),\n      {},\n    );\n  });\n\n  it('ChatUI input validation limits can be overridden by maxMessageLength, showNumCharactersTypedLength', async () => {\n    const args = {\n      ...defaultArgs,\n      maxMessageLength: 100,\n      showNumCharactersTypedLength: 50,\n    };\n    render(<ChatUI {...args} iconSrc=\"testIconSrc\" />);\n\n    await act(async () => {\n      fireEvent.change(screen.getByRole('textbox', { name: 'message' }), {\n        target: { value: faker.lorem.words(8).slice(0, 51) },\n      });\n    });\n\n    await waitFor(() => {\n      expect(screen.getByTestId('chat-ui-validation-message')).toHaveTextContent('51/100');\n    });\n\n    await act(async () => {\n      fireEvent.change(screen.getByRole('textbox', { name: 'message' }), {\n        target: { value: faker.lorem.words(20).slice(0, 101) },\n      });\n    });\n\n    await waitFor(() => {\n      expect(screen.getByTestId('chat-ui-validation-message')).toHaveTextContent('101/100');\n    });\n  });\n\n  describe(`isNewChatBreak() tests`, () => {\n    const conversation: Array<ConversationItem> = [\n      {\n        id: '1',\n        text: 'greeting',\n        sender: 'Frontend',\n      },\n      {\n        id: '2',\n        text: 'help me',\n        sender: 'User',\n      },\n      {\n        id: '3',\n        type: `newChatBreak`,\n      },\n      {\n        id: '4',\n        text: 'welcome',\n        sender: 'Frontend',\n      },\n    ];\n\n    it('should return false if item is not a new chat break', () => {\n      expect(isNewChatBreak(conversation[0])).toBe(false);\n      expect(isNewChatBreak(conversation[1])).toBe(false);\n      expect(isNewChatBreak(conversation[3])).toBe(false);\n    });\n\n    it('should return true if 2nd previous message is a new chat break', () => {\n      expect(isNewChatBreak(conversation[2])).toBe(true);\n    });\n  });\n});\n"]} |
@@ -5,5 +5,8 @@ import React from 'react'; | ||
isProcessingRating: boolean; | ||
isWaitingResponse: boolean; | ||
isWaitingUserInput: boolean; | ||
isNewChat: boolean; | ||
onNewChat: () => void; | ||
onRateChat: (positiveRating: boolean) => void; | ||
}; | ||
export declare const ChatFooter: ({ rating, isProcessingRating, onNewChat, onRateChat }: ChatFooterProps) => React.JSX.Element; | ||
export declare const ChatFooter: ({ rating, isProcessingRating, isWaitingUserInput, isNewChat, onNewChat, onRateChat, }: ChatFooterProps) => React.JSX.Element; |
@@ -31,3 +31,3 @@ "use strict"; | ||
const ThumbDownIcon_1 = require("../../icons/ThumbDownIcon"); | ||
const ChatFooter = ({ rating, isProcessingRating, onNewChat, onRateChat }) => { | ||
const ChatFooter = ({ rating, isProcessingRating, isWaitingUserInput, isNewChat, onNewChat, onRateChat, }) => { | ||
const handleSetRating = (0, react_1.useCallback)((changeRating) => { | ||
@@ -43,3 +43,3 @@ try { | ||
return (react_1.default.createElement("div", { className: "squizChatUIFooter" }, | ||
react_1.default.createElement("button", { onClick: onNewChat, className: "squizChatUIFooter__newChat" }, | ||
react_1.default.createElement("button", { disabled: isWaitingUserInput || isNewChat, onClick: onNewChat, className: `squizChatUIFooter__newChat${isWaitingUserInput ? ` squizChatUIFooter__newChat--active` : ``}${isNewChat ? ` squizChatUIFooter__newChat--disabled` : ``}` }, | ||
react_1.default.createElement(NewChatIcon_1.NewChatIcon, null), | ||
@@ -49,5 +49,5 @@ react_1.default.createElement(NewChatIcon_1.NewChatIconHover, null), | ||
react_1.default.createElement("span", { className: "squizChatUIFooter__separator" }), | ||
react_1.default.createElement("div", { className: "squizChatUIFooter__rateChat" }, | ||
react_1.default.createElement("div", { className: `squizChatUIFooter__rateChat ${isNewChat ? 'squizChatUIFooter__rateChat--disabled' : ''}` }, | ||
react_1.default.createElement("span", { className: "squizChatUIFooter__rateChatLabel" }, "Rate chat"), | ||
react_1.default.createElement("button", { "aria-label": "Rate chat response good", "aria-checked": rating === true ? true : false, disabled: isProcessingRating, onClick: () => handleSetRating(true), className: "squizChatUIFooter__rateGood" }, | ||
react_1.default.createElement("button", { "aria-label": "Rate chat response good", "aria-checked": rating === true ? true : false, disabled: isProcessingRating || isNewChat, onClick: () => handleSetRating(true), className: "squizChatUIFooter__rateGood" }, | ||
rating !== true && (react_1.default.createElement(react_1.default.Fragment, null, | ||
@@ -57,3 +57,3 @@ react_1.default.createElement(ThumbUpIcon_1.ThumbUpIcon, null), | ||
rating === true && react_1.default.createElement(ThumbUpIcon_1.ThumbUpIconSelected, null)), | ||
react_1.default.createElement("button", { "aria-label": "Rate chat response bad", "aria-checked": rating === false ? true : false, disabled: isProcessingRating, onClick: () => handleSetRating(false), className: "squizChatUIFooter__rateBad" }, | ||
react_1.default.createElement("button", { "aria-label": "Rate chat response bad", "aria-checked": rating === false ? true : false, disabled: isProcessingRating || isNewChat, onClick: () => handleSetRating(false), className: "squizChatUIFooter__rateBad" }, | ||
rating !== false && (react_1.default.createElement(react_1.default.Fragment, null, | ||
@@ -65,2 +65,2 @@ react_1.default.createElement(ThumbDownIcon_1.ThumbDownIcon, null), | ||
exports.ChatFooter = ChatFooter; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQ2hhdEZvb3Rlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0NoYXRGb290ZXIvQ2hhdEZvb3Rlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSwrQ0FBMkM7QUFDM0MseURBQXdFO0FBQ3hFLHlEQUE2RjtBQUM3Riw2REFBcUc7QUFROUYsTUFBTSxVQUFVLEdBQUcsQ0FBQyxFQUFFLE1BQU0sRUFBRSxrQkFBa0IsRUFBRSxTQUFTLEVBQUUsVUFBVSxFQUFtQixFQUFFLEVBQUU7SUFDbkcsTUFBTSxlQUFlLEdBQUcsSUFBQSxtQkFBVyxFQUNqQyxDQUFDLFlBQXFCLEVBQUUsRUFBRTtRQUN4QixJQUFJLENBQUM7WUFFSCxJQUFJLFlBQVksS0FBSyxNQUFNLEVBQUUsQ0FBQztnQkFDNUIsVUFBVSxDQUFDLFlBQVksQ0FBQyxDQUFDO1lBQzNCLENBQUM7UUFDSCxDQUFDO1FBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQztRQUViLENBQUM7SUFDSCxDQUFDLEVBQ0QsQ0FBQyxNQUFNLEVBQUUsVUFBVSxDQUFDLENBQ3JCLENBQUM7SUFFRixPQUFPLENBQ0wsdUNBQUssU0FBUyxFQUFDLG1CQUFtQjtRQUNoQywwQ0FBUSxPQUFPLEVBQUUsU0FBUyxFQUFFLFNBQVMsRUFBQyw0QkFBNEI7WUFDaEUsOEJBQUMseUJBQVcsT0FBRztZQUNmLDhCQUFDLDhCQUFnQixPQUFHO1lBQ3BCLHdDQUFNLFNBQVMsRUFBQyxpQ0FBaUMsZUFBZ0IsQ0FDMUQ7UUFDVCx3Q0FBTSxTQUFTLEVBQUMsOEJBQThCLEdBQUc7UUFDakQsdUNBQUssU0FBUyxFQUFDLDZCQUE2QjtZQUMxQyx3Q0FBTSxTQUFTLEVBQUMsa0NBQWtDLGdCQUFpQjtZQUNuRSx3REFDYSx5QkFBeUIsa0JBQ3RCLE1BQU0sS0FBSyxJQUFJLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsS0FBSyxFQUM1QyxRQUFRLEVBQUUsa0JBQWtCLEVBQzVCLE9BQU8sRUFBRSxHQUFHLEVBQUUsQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLEVBQ3BDLFNBQVMsRUFBQyw2QkFBNkI7Z0JBRXRDLE1BQU0sS0FBSyxJQUFJLElBQUksQ0FDbEI7b0JBQ0UsOEJBQUMseUJBQVcsT0FBRztvQkFDZiw4QkFBQyw4QkFBZ0IsT0FBRyxDQUNuQixDQUNKO2dCQUNBLE1BQU0sS0FBSyxJQUFJLElBQUksOEJBQUMsaUNBQW1CLE9BQUcsQ0FDcEM7WUFDVCx3REFDYSx3QkFBd0Isa0JBQ3JCLE1BQU0sS0FBSyxLQUFLLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsS0FBSyxFQUM3QyxRQUFRLEVBQUUsa0JBQWtCLEVBQzVCLE9BQU8sRUFBRSxHQUFHLEVBQUUsQ0FBQyxlQUFlLENBQUMsS0FBSyxDQUFDLEVBQ3JDLFNBQVMsRUFBQyw0QkFBNEI7Z0JBRXJDLE1BQU0sS0FBSyxLQUFLLElBQUksQ0FDbkI7b0JBQ0UsOEJBQUMsNkJBQWEsT0FBRztvQkFDakIsOEJBQUMsa0NBQWtCLE9BQUcsQ0FDckIsQ0FDSjtnQkFDQSxNQUFNLEtBQUssS0FBSyxJQUFJLDhCQUFDLHFDQUFxQixPQUFHLENBQ3ZDLENBQ0wsQ0FDRixDQUNQLENBQUM7QUFDSixDQUFDLENBQUM7QUExRFcsUUFBQSxVQUFVLGNBMERyQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCwgeyB1c2VDYWxsYmFjayB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IE5ld0NoYXRJY29uLCBOZXdDaGF0SWNvbkhvdmVyIH0gZnJvbSAnLi4vLi4vaWNvbnMvTmV3Q2hhdEljb24nO1xuaW1wb3J0IHsgVGh1bWJVcEljb24sIFRodW1iVXBJY29uSG92ZXIsIFRodW1iVXBJY29uU2VsZWN0ZWQgfSBmcm9tICcuLi8uLi9pY29ucy9UaHVtYlVwSWNvbic7XG5pbXBvcnQgeyBUaHVtYkRvd25JY29uLCBUaHVtYkRvd25JY29uSG92ZXIsIFRodW1iRG93bkljb25TZWxlY3RlZCB9IGZyb20gJy4uLy4uL2ljb25zL1RodW1iRG93bkljb24nO1xuXG5leHBvcnQgdHlwZSBDaGF0Rm9vdGVyUHJvcHMgPSB7XG4gIHJhdGluZzogYm9vbGVhbiB8IG51bGw7XG4gIGlzUHJvY2Vzc2luZ1JhdGluZzogYm9vbGVhbjtcbiAgb25OZXdDaGF0OiAoKSA9PiB2b2lkO1xuICBvblJhdGVDaGF0OiAocG9zaXRpdmVSYXRpbmc6IGJvb2xlYW4pID0+IHZvaWQ7XG59O1xuZXhwb3J0IGNvbnN0IENoYXRGb290ZXIgPSAoeyByYXRpbmcsIGlzUHJvY2Vzc2luZ1JhdGluZywgb25OZXdDaGF0LCBvblJhdGVDaGF0IH06IENoYXRGb290ZXJQcm9wcykgPT4ge1xuICBjb25zdCBoYW5kbGVTZXRSYXRpbmcgPSB1c2VDYWxsYmFjayhcbiAgICAoY2hhbmdlUmF0aW5nOiBib29sZWFuKSA9PiB7XG4gICAgICB0cnkge1xuICAgICAgICAvLyBJdCBpcyBub3QgcG9zc2libGUgdG8gdW5zZXQgYSByYXRpbmdcbiAgICAgICAgaWYgKGNoYW5nZVJhdGluZyAhPT0gcmF0aW5nKSB7XG4gICAgICAgICAgb25SYXRlQ2hhdChjaGFuZ2VSYXRpbmcpO1xuICAgICAgICB9XG4gICAgICB9IGNhdGNoIChlKSB7XG4gICAgICAgIC8vIElmIG5vIHRocmVhZCBleGlzdHMgeWV0IGl0IGNhbm5vdCBiZSByYXRlZFxuICAgICAgfVxuICAgIH0sXG4gICAgW3JhdGluZywgb25SYXRlQ2hhdF0sXG4gICk7XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2IGNsYXNzTmFtZT1cInNxdWl6Q2hhdFVJRm9vdGVyXCI+XG4gICAgICA8YnV0dG9uIG9uQ2xpY2s9e29uTmV3Q2hhdH0gY2xhc3NOYW1lPVwic3F1aXpDaGF0VUlGb290ZXJfX25ld0NoYXRcIj5cbiAgICAgICAgPE5ld0NoYXRJY29uIC8+XG4gICAgICAgIDxOZXdDaGF0SWNvbkhvdmVyIC8+XG4gICAgICAgIDxzcGFuIGNsYXNzTmFtZT1cInNxdWl6Q2hhdFVJRm9vdGVyX19uZXdDaGF0TGFiZWxcIj5OZXcgY2hhdDwvc3Bhbj5cbiAgICAgIDwvYnV0dG9uPlxuICAgICAgPHNwYW4gY2xhc3NOYW1lPVwic3F1aXpDaGF0VUlGb290ZXJfX3NlcGFyYXRvclwiIC8+XG4gICAgICA8ZGl2IGNsYXNzTmFtZT1cInNxdWl6Q2hhdFVJRm9vdGVyX19yYXRlQ2hhdFwiPlxuICAgICAgICA8c3BhbiBjbGFzc05hbWU9XCJzcXVpekNoYXRVSUZvb3Rlcl9fcmF0ZUNoYXRMYWJlbFwiPlJhdGUgY2hhdDwvc3Bhbj5cbiAgICAgICAgPGJ1dHRvblxuICAgICAgICAgIGFyaWEtbGFiZWw9XCJSYXRlIGNoYXQgcmVzcG9uc2UgZ29vZFwiXG4gICAgICAgICAgYXJpYS1jaGVja2VkPXtyYXRpbmcgPT09IHRydWUgPyB0cnVlIDogZmFsc2V9XG4gICAgICAgICAgZGlzYWJsZWQ9e2lzUHJvY2Vzc2luZ1JhdGluZ31cbiAgICAgICAgICBvbkNsaWNrPXsoKSA9PiBoYW5kbGVTZXRSYXRpbmcodHJ1ZSl9XG4gICAgICAgICAgY2xhc3NOYW1lPVwic3F1aXpDaGF0VUlGb290ZXJfX3JhdGVHb29kXCJcbiAgICAgICAgPlxuICAgICAgICAgIHtyYXRpbmcgIT09IHRydWUgJiYgKFxuICAgICAgICAgICAgPD5cbiAgICAgICAgICAgICAgPFRodW1iVXBJY29uIC8+XG4gICAgICAgICAgICAgIDxUaHVtYlVwSWNvbkhvdmVyIC8+XG4gICAgICAgICAgICA8Lz5cbiAgICAgICAgICApfVxuICAgICAgICAgIHtyYXRpbmcgPT09IHRydWUgJiYgPFRodW1iVXBJY29uU2VsZWN0ZWQgLz59XG4gICAgICAgIDwvYnV0dG9uPlxuICAgICAgICA8YnV0dG9uXG4gICAgICAgICAgYXJpYS1sYWJlbD1cIlJhdGUgY2hhdCByZXNwb25zZSBiYWRcIlxuICAgICAgICAgIGFyaWEtY2hlY2tlZD17cmF0aW5nID09PSBmYWxzZSA/IHRydWUgOiBmYWxzZX1cbiAgICAgICAgICBkaXNhYmxlZD17aXNQcm9jZXNzaW5nUmF0aW5nfVxuICAgICAgICAgIG9uQ2xpY2s9eygpID0+IGhhbmRsZVNldFJhdGluZyhmYWxzZSl9XG4gICAgICAgICAgY2xhc3NOYW1lPVwic3F1aXpDaGF0VUlGb290ZXJfX3JhdGVCYWRcIlxuICAgICAgICA+XG4gICAgICAgICAge3JhdGluZyAhPT0gZmFsc2UgJiYgKFxuICAgICAgICAgICAgPD5cbiAgICAgICAgICAgICAgPFRodW1iRG93bkljb24gLz5cbiAgICAgICAgICAgICAgPFRodW1iRG93bkljb25Ib3ZlciAvPlxuICAgICAgICAgICAgPC8+XG4gICAgICAgICAgKX1cbiAgICAgICAgICB7cmF0aW5nID09PSBmYWxzZSAmJiA8VGh1bWJEb3duSWNvblNlbGVjdGVkIC8+fVxuICAgICAgICA8L2J1dHRvbj5cbiAgICAgIDwvZGl2PlxuICAgIDwvZGl2PlxuICApO1xufTtcbiJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQ2hhdEZvb3Rlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0NoYXRGb290ZXIvQ2hhdEZvb3Rlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSwrQ0FBMkM7QUFDM0MseURBQXdFO0FBQ3hFLHlEQUE2RjtBQUM3Riw2REFBcUc7QUFXOUYsTUFBTSxVQUFVLEdBQUcsQ0FBQyxFQUN6QixNQUFNLEVBQ04sa0JBQWtCLEVBQ2xCLGtCQUFrQixFQUNsQixTQUFTLEVBQ1QsU0FBUyxFQUNULFVBQVUsR0FDTSxFQUFFLEVBQUU7SUFDcEIsTUFBTSxlQUFlLEdBQUcsSUFBQSxtQkFBVyxFQUNqQyxDQUFDLFlBQXFCLEVBQUUsRUFBRTtRQUN4QixJQUFJLENBQUM7WUFFSCxJQUFJLFlBQVksS0FBSyxNQUFNLEVBQUUsQ0FBQztnQkFDNUIsVUFBVSxDQUFDLFlBQVksQ0FBQyxDQUFDO1lBQzNCLENBQUM7UUFDSCxDQUFDO1FBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQztRQUViLENBQUM7SUFDSCxDQUFDLEVBQ0QsQ0FBQyxNQUFNLEVBQUUsVUFBVSxDQUFDLENBQ3JCLENBQUM7SUFFRixPQUFPLENBQ0wsdUNBQUssU0FBUyxFQUFDLG1CQUFtQjtRQUNoQywwQ0FDRSxRQUFRLEVBQUUsa0JBQWtCLElBQUksU0FBUyxFQUN6QyxPQUFPLEVBQUUsU0FBUyxFQUNsQixTQUFTLEVBQUUsNkJBQTZCLGtCQUFrQixDQUFDLENBQUMsQ0FBQyxxQ0FBcUMsQ0FBQyxDQUFDLENBQUMsRUFBRSxHQUFHLFNBQVMsQ0FBQyxDQUFDLENBQUMsdUNBQXVDLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRTtZQUVwSyw4QkFBQyx5QkFBVyxPQUFHO1lBQ2YsOEJBQUMsOEJBQWdCLE9BQUc7WUFDcEIsd0NBQU0sU0FBUyxFQUFDLGlDQUFpQyxlQUFnQixDQUMxRDtRQUNULHdDQUFNLFNBQVMsRUFBQyw4QkFBOEIsR0FBRztRQUNqRCx1Q0FBSyxTQUFTLEVBQUUsK0JBQStCLFNBQVMsQ0FBQyxDQUFDLENBQUMsdUNBQXVDLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRTtZQUN2Ryx3Q0FBTSxTQUFTLEVBQUMsa0NBQWtDLGdCQUFpQjtZQUNuRSx3REFDYSx5QkFBeUIsa0JBQ3RCLE1BQU0sS0FBSyxJQUFJLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsS0FBSyxFQUM1QyxRQUFRLEVBQUUsa0JBQWtCLElBQUksU0FBUyxFQUN6QyxPQUFPLEVBQUUsR0FBRyxFQUFFLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxFQUNwQyxTQUFTLEVBQUMsNkJBQTZCO2dCQUV0QyxNQUFNLEtBQUssSUFBSSxJQUFJLENBQ2xCO29CQUNFLDhCQUFDLHlCQUFXLE9BQUc7b0JBQ2YsOEJBQUMsOEJBQWdCLE9BQUcsQ0FDbkIsQ0FDSjtnQkFDQSxNQUFNLEtBQUssSUFBSSxJQUFJLDhCQUFDLGlDQUFtQixPQUFHLENBQ3BDO1lBQ1Qsd0RBQ2Esd0JBQXdCLGtCQUNyQixNQUFNLEtBQUssS0FBSyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEtBQUssRUFDN0MsUUFBUSxFQUFFLGtCQUFrQixJQUFJLFNBQVMsRUFDekMsT0FBTyxFQUFFLEdBQUcsRUFBRSxDQUFDLGVBQWUsQ0FBQyxLQUFLLENBQUMsRUFDckMsU0FBUyxFQUFDLDRCQUE0QjtnQkFFckMsTUFBTSxLQUFLLEtBQUssSUFBSSxDQUNuQjtvQkFDRSw4QkFBQyw2QkFBYSxPQUFHO29CQUNqQiw4QkFBQyxrQ0FBa0IsT0FBRyxDQUNyQixDQUNKO2dCQUNBLE1BQU0sS0FBSyxLQUFLLElBQUksOEJBQUMscUNBQXFCLE9BQUcsQ0FDdkMsQ0FDTCxDQUNGLENBQ1AsQ0FBQztBQUNKLENBQUMsQ0FBQztBQXJFVyxRQUFBLFVBQVUsY0FxRXJCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IHVzZUNhbGxiYWNrIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgTmV3Q2hhdEljb24sIE5ld0NoYXRJY29uSG92ZXIgfSBmcm9tICcuLi8uLi9pY29ucy9OZXdDaGF0SWNvbic7XG5pbXBvcnQgeyBUaHVtYlVwSWNvbiwgVGh1bWJVcEljb25Ib3ZlciwgVGh1bWJVcEljb25TZWxlY3RlZCB9IGZyb20gJy4uLy4uL2ljb25zL1RodW1iVXBJY29uJztcbmltcG9ydCB7IFRodW1iRG93bkljb24sIFRodW1iRG93bkljb25Ib3ZlciwgVGh1bWJEb3duSWNvblNlbGVjdGVkIH0gZnJvbSAnLi4vLi4vaWNvbnMvVGh1bWJEb3duSWNvbic7XG5cbmV4cG9ydCB0eXBlIENoYXRGb290ZXJQcm9wcyA9IHtcbiAgcmF0aW5nOiBib29sZWFuIHwgbnVsbDtcbiAgaXNQcm9jZXNzaW5nUmF0aW5nOiBib29sZWFuO1xuICBpc1dhaXRpbmdSZXNwb25zZTogYm9vbGVhbjtcbiAgaXNXYWl0aW5nVXNlcklucHV0OiBib29sZWFuO1xuICBpc05ld0NoYXQ6IGJvb2xlYW47XG4gIG9uTmV3Q2hhdDogKCkgPT4gdm9pZDtcbiAgb25SYXRlQ2hhdDogKHBvc2l0aXZlUmF0aW5nOiBib29sZWFuKSA9PiB2b2lkO1xufTtcbmV4cG9ydCBjb25zdCBDaGF0Rm9vdGVyID0gKHtcbiAgcmF0aW5nLFxuICBpc1Byb2Nlc3NpbmdSYXRpbmcsXG4gIGlzV2FpdGluZ1VzZXJJbnB1dCxcbiAgaXNOZXdDaGF0LFxuICBvbk5ld0NoYXQsXG4gIG9uUmF0ZUNoYXQsXG59OiBDaGF0Rm9vdGVyUHJvcHMpID0+IHtcbiAgY29uc3QgaGFuZGxlU2V0UmF0aW5nID0gdXNlQ2FsbGJhY2soXG4gICAgKGNoYW5nZVJhdGluZzogYm9vbGVhbikgPT4ge1xuICAgICAgdHJ5IHtcbiAgICAgICAgLy8gSXQgaXMgbm90IHBvc3NpYmxlIHRvIHVuc2V0IGEgcmF0aW5nXG4gICAgICAgIGlmIChjaGFuZ2VSYXRpbmcgIT09IHJhdGluZykge1xuICAgICAgICAgIG9uUmF0ZUNoYXQoY2hhbmdlUmF0aW5nKTtcbiAgICAgICAgfVxuICAgICAgfSBjYXRjaCAoZSkge1xuICAgICAgICAvLyBJZiBubyB0aHJlYWQgZXhpc3RzIHlldCBpdCBjYW5ub3QgYmUgcmF0ZWRcbiAgICAgIH1cbiAgICB9LFxuICAgIFtyYXRpbmcsIG9uUmF0ZUNoYXRdLFxuICApO1xuXG4gIHJldHVybiAoXG4gICAgPGRpdiBjbGFzc05hbWU9XCJzcXVpekNoYXRVSUZvb3RlclwiPlxuICAgICAgPGJ1dHRvblxuICAgICAgICBkaXNhYmxlZD17aXNXYWl0aW5nVXNlcklucHV0IHx8IGlzTmV3Q2hhdH1cbiAgICAgICAgb25DbGljaz17b25OZXdDaGF0fVxuICAgICAgICBjbGFzc05hbWU9e2BzcXVpekNoYXRVSUZvb3Rlcl9fbmV3Q2hhdCR7aXNXYWl0aW5nVXNlcklucHV0ID8gYCBzcXVpekNoYXRVSUZvb3Rlcl9fbmV3Q2hhdC0tYWN0aXZlYCA6IGBgfSR7aXNOZXdDaGF0ID8gYCBzcXVpekNoYXRVSUZvb3Rlcl9fbmV3Q2hhdC0tZGlzYWJsZWRgIDogYGB9YH1cbiAgICAgID5cbiAgICAgICAgPE5ld0NoYXRJY29uIC8+XG4gICAgICAgIDxOZXdDaGF0SWNvbkhvdmVyIC8+XG4gICAgICAgIDxzcGFuIGNsYXNzTmFtZT1cInNxdWl6Q2hhdFVJRm9vdGVyX19uZXdDaGF0TGFiZWxcIj5OZXcgY2hhdDwvc3Bhbj5cbiAgICAgIDwvYnV0dG9uPlxuICAgICAgPHNwYW4gY2xhc3NOYW1lPVwic3F1aXpDaGF0VUlGb290ZXJfX3NlcGFyYXRvclwiIC8+XG4gICAgICA8ZGl2IGNsYXNzTmFtZT17YHNxdWl6Q2hhdFVJRm9vdGVyX19yYXRlQ2hhdCAke2lzTmV3Q2hhdCA/ICdzcXVpekNoYXRVSUZvb3Rlcl9fcmF0ZUNoYXQtLWRpc2FibGVkJyA6ICcnfWB9PlxuICAgICAgICA8c3BhbiBjbGFzc05hbWU9XCJzcXVpekNoYXRVSUZvb3Rlcl9fcmF0ZUNoYXRMYWJlbFwiPlJhdGUgY2hhdDwvc3Bhbj5cbiAgICAgICAgPGJ1dHRvblxuICAgICAgICAgIGFyaWEtbGFiZWw9XCJSYXRlIGNoYXQgcmVzcG9uc2UgZ29vZFwiXG4gICAgICAgICAgYXJpYS1jaGVja2VkPXtyYXRpbmcgPT09IHRydWUgPyB0cnVlIDogZmFsc2V9XG4gICAgICAgICAgZGlzYWJsZWQ9e2lzUHJvY2Vzc2luZ1JhdGluZyB8fCBpc05ld0NoYXR9XG4gICAgICAgICAgb25DbGljaz17KCkgPT4gaGFuZGxlU2V0UmF0aW5nKHRydWUpfVxuICAgICAgICAgIGNsYXNzTmFtZT1cInNxdWl6Q2hhdFVJRm9vdGVyX19yYXRlR29vZFwiXG4gICAgICAgID5cbiAgICAgICAgICB7cmF0aW5nICE9PSB0cnVlICYmIChcbiAgICAgICAgICAgIDw+XG4gICAgICAgICAgICAgIDxUaHVtYlVwSWNvbiAvPlxuICAgICAgICAgICAgICA8VGh1bWJVcEljb25Ib3ZlciAvPlxuICAgICAgICAgICAgPC8+XG4gICAgICAgICAgKX1cbiAgICAgICAgICB7cmF0aW5nID09PSB0cnVlICYmIDxUaHVtYlVwSWNvblNlbGVjdGVkIC8+fVxuICAgICAgICA8L2J1dHRvbj5cbiAgICAgICAgPGJ1dHRvblxuICAgICAgICAgIGFyaWEtbGFiZWw9XCJSYXRlIGNoYXQgcmVzcG9uc2UgYmFkXCJcbiAgICAgICAgICBhcmlhLWNoZWNrZWQ9e3JhdGluZyA9PT0gZmFsc2UgPyB0cnVlIDogZmFsc2V9XG4gICAgICAgICAgZGlzYWJsZWQ9e2lzUHJvY2Vzc2luZ1JhdGluZyB8fCBpc05ld0NoYXR9XG4gICAgICAgICAgb25DbGljaz17KCkgPT4gaGFuZGxlU2V0UmF0aW5nKGZhbHNlKX1cbiAgICAgICAgICBjbGFzc05hbWU9XCJzcXVpekNoYXRVSUZvb3Rlcl9fcmF0ZUJhZFwiXG4gICAgICAgID5cbiAgICAgICAgICB7cmF0aW5nICE9PSBmYWxzZSAmJiAoXG4gICAgICAgICAgICA8PlxuICAgICAgICAgICAgICA8VGh1bWJEb3duSWNvbiAvPlxuICAgICAgICAgICAgICA8VGh1bWJEb3duSWNvbkhvdmVyIC8+XG4gICAgICAgICAgICA8Lz5cbiAgICAgICAgICApfVxuICAgICAgICAgIHtyYXRpbmcgPT09IGZhbHNlICYmIDxUaHVtYkRvd25JY29uU2VsZWN0ZWQgLz59XG4gICAgICAgIDwvYnV0dG9uPlxuICAgICAgPC9kaXY+XG4gICAgPC9kaXY+XG4gICk7XG59O1xuIl19 |
@@ -14,10 +14,40 @@ "use strict"; | ||
const onRateChat = jest.fn(); | ||
(0, react_2.render)(react_1.default.createElement(ChatFooter_1.ChatFooter, { rating: null, isProcessingRating: false, onNewChat: onNewChat, onRateChat: onRateChat })); | ||
(0, react_2.render)(react_1.default.createElement(ChatFooter_1.ChatFooter, { rating: null, isProcessingRating: false, isWaitingUserInput: false, isNewChat: false, isWaitingResponse: false, onNewChat: onNewChat, onRateChat: onRateChat })); | ||
react_2.fireEvent.click(react_2.screen.getByText('New chat')); | ||
expect(onNewChat).toHaveBeenCalled(); | ||
}); | ||
it('ChatFooter will disable new chat button if its a new chat', async () => { | ||
const onNewChat = jest.fn(); | ||
const onRateChat = jest.fn(); | ||
(0, react_2.render)(react_1.default.createElement(ChatFooter_1.ChatFooter, { rating: null, isProcessingRating: false, isWaitingUserInput: false, isNewChat: true, isWaitingResponse: false, onNewChat: onNewChat, onRateChat: onRateChat })); | ||
react_2.fireEvent.click(react_2.screen.getByText('New chat')); | ||
expect(onNewChat).not.toHaveBeenCalled(); | ||
}); | ||
it('ChatFooter will not disable new chat button if waiting for response', async () => { | ||
const onNewChat = jest.fn(); | ||
const onRateChat = jest.fn(); | ||
(0, react_2.render)(react_1.default.createElement(ChatFooter_1.ChatFooter, { rating: null, isProcessingRating: false, isWaitingUserInput: false, isNewChat: false, isWaitingResponse: false, onNewChat: onNewChat, onRateChat: onRateChat })); | ||
react_2.fireEvent.click(react_2.screen.getByText('New chat')); | ||
expect(onNewChat).toHaveBeenCalledTimes(1); | ||
}); | ||
it('ChatFooter will disable new chat button if waiting for user input', async () => { | ||
const onNewChat = jest.fn(); | ||
const onRateChat = jest.fn(); | ||
(0, react_2.render)(react_1.default.createElement(ChatFooter_1.ChatFooter, { rating: null, isProcessingRating: false, isWaitingUserInput: true, isNewChat: false, isWaitingResponse: false, onNewChat: onNewChat, onRateChat: onRateChat })); | ||
react_2.fireEvent.click(react_2.screen.getByText('New chat')); | ||
expect(onNewChat).not.toHaveBeenCalled(); | ||
}); | ||
it('ChatFooter will disable rating button if its new chat', async () => { | ||
const onNewChat = jest.fn(); | ||
const onRateChat = jest.fn(); | ||
(0, react_2.render)(react_1.default.createElement(ChatFooter_1.ChatFooter, { rating: null, isProcessingRating: false, isWaitingUserInput: false, isNewChat: true, isWaitingResponse: false, onNewChat: onNewChat, onRateChat: onRateChat })); | ||
react_2.fireEvent.click(react_2.screen.getByLabelText('Rate chat response good')); | ||
expect(onRateChat).not.toHaveBeenCalledWith(); | ||
react_2.fireEvent.click(react_2.screen.getByLabelText('Rate chat response bad')); | ||
expect(onRateChat).not.toHaveBeenCalledWith(); | ||
}); | ||
it('ChatFooter will call context onRateChat with boolean true when good rating is pressed', async () => { | ||
const onNewChat = jest.fn(); | ||
const onRateChat = jest.fn(); | ||
(0, react_2.render)(react_1.default.createElement(ChatFooter_1.ChatFooter, { rating: null, isProcessingRating: false, onNewChat: onNewChat, onRateChat: onRateChat })); | ||
(0, react_2.render)(react_1.default.createElement(ChatFooter_1.ChatFooter, { rating: null, isProcessingRating: false, isWaitingUserInput: false, isNewChat: false, isWaitingResponse: false, onNewChat: onNewChat, onRateChat: onRateChat })); | ||
react_2.fireEvent.click(react_2.screen.getByLabelText('Rate chat response good')); | ||
@@ -29,3 +59,3 @@ expect(onRateChat).toHaveBeenCalledWith(true); | ||
const onRateChat = jest.fn(); | ||
(0, react_2.render)(react_1.default.createElement(ChatFooter_1.ChatFooter, { rating: true, isProcessingRating: false, onNewChat: onNewChat, onRateChat: onRateChat })); | ||
(0, react_2.render)(react_1.default.createElement(ChatFooter_1.ChatFooter, { rating: true, isProcessingRating: false, isWaitingUserInput: false, isNewChat: false, isWaitingResponse: false, onNewChat: onNewChat, onRateChat: onRateChat })); | ||
expect(react_2.screen.getByLabelText('Rate chat response good').getAttribute('aria-checked')).toEqual('true'); | ||
@@ -37,3 +67,3 @@ expect(react_2.screen.getByLabelText('Rate chat response bad').getAttribute('aria-checked')).toEqual('false'); | ||
const onRateChat = jest.fn(); | ||
(0, react_2.render)(react_1.default.createElement(ChatFooter_1.ChatFooter, { rating: null, isProcessingRating: false, onNewChat: onNewChat, onRateChat: onRateChat })); | ||
(0, react_2.render)(react_1.default.createElement(ChatFooter_1.ChatFooter, { rating: null, isProcessingRating: false, isWaitingUserInput: false, isNewChat: false, isWaitingResponse: false, onNewChat: onNewChat, onRateChat: onRateChat })); | ||
react_2.fireEvent.click(react_2.screen.getByLabelText('Rate chat response bad')); | ||
@@ -45,3 +75,3 @@ expect(onRateChat).toHaveBeenCalledWith(false); | ||
const onRateChat = jest.fn(); | ||
(0, react_2.render)(react_1.default.createElement(ChatFooter_1.ChatFooter, { rating: false, isProcessingRating: false, onNewChat: onNewChat, onRateChat: onRateChat })); | ||
(0, react_2.render)(react_1.default.createElement(ChatFooter_1.ChatFooter, { rating: false, isProcessingRating: false, isWaitingUserInput: false, isNewChat: false, isWaitingResponse: false, onNewChat: onNewChat, onRateChat: onRateChat })); | ||
expect(react_2.screen.getByLabelText('Rate chat response good').getAttribute('aria-checked')).toEqual('false'); | ||
@@ -51,2 +81,2 @@ expect(react_2.screen.getByLabelText('Rate chat response bad').getAttribute('aria-checked')).toEqual('true'); | ||
}); | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQ2hhdEZvb3Rlci5zcGVjLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvQ2hhdEZvb3Rlci9DaGF0Rm9vdGVyLnNwZWMudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsa0RBQTBCO0FBQzFCLGtEQUFtRTtBQUNuRSxxQ0FBbUM7QUFDbkMsNkNBQTBDO0FBRTFDLFFBQVEsQ0FBQyxhQUFhLEVBQUUsR0FBRyxFQUFFO0lBQzNCLEVBQUUsQ0FBQyxtRUFBbUUsRUFBRSxLQUFLLElBQUksRUFBRTtRQUNqRixNQUFNLFNBQVMsR0FBRyxJQUFJLENBQUMsRUFBRSxFQUFFLENBQUM7UUFDNUIsTUFBTSxVQUFVLEdBQUcsSUFBSSxDQUFDLEVBQUUsRUFBRSxDQUFDO1FBQzdCLElBQUEsY0FBTSxFQUFDLDhCQUFDLHVCQUFVLElBQUMsTUFBTSxFQUFFLElBQUksRUFBRSxrQkFBa0IsRUFBRSxLQUFLLEVBQUUsU0FBUyxFQUFFLFNBQVMsRUFBRSxVQUFVLEVBQUUsVUFBVSxHQUFJLENBQUMsQ0FBQztRQUM5RyxpQkFBUyxDQUFDLEtBQUssQ0FBQyxjQUFNLENBQUMsU0FBUyxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUM7UUFDOUMsTUFBTSxDQUFDLFNBQVMsQ0FBQyxDQUFDLGdCQUFnQixFQUFFLENBQUM7SUFDdkMsQ0FBQyxDQUFDLENBQUM7SUFFSCxFQUFFLENBQUMsdUZBQXVGLEVBQUUsS0FBSyxJQUFJLEVBQUU7UUFDckcsTUFBTSxTQUFTLEdBQUcsSUFBSSxDQUFDLEVBQUUsRUFBRSxDQUFDO1FBQzVCLE1BQU0sVUFBVSxHQUFHLElBQUksQ0FBQyxFQUFFLEVBQUUsQ0FBQztRQUM3QixJQUFBLGNBQU0sRUFBQyw4QkFBQyx1QkFBVSxJQUFDLE1BQU0sRUFBRSxJQUFJLEVBQUUsa0JBQWtCLEVBQUUsS0FBSyxFQUFFLFNBQVMsRUFBRSxTQUFTLEVBQUUsVUFBVSxFQUFFLFVBQVUsR0FBSSxDQUFDLENBQUM7UUFDOUcsaUJBQVMsQ0FBQyxLQUFLLENBQUMsY0FBTSxDQUFDLGNBQWMsQ0FBQyx5QkFBeUIsQ0FBQyxDQUFDLENBQUM7UUFDbEUsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFDLG9CQUFvQixDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ2hELENBQUMsQ0FBQyxDQUFDO0lBRUgsRUFBRSxDQUFDLG9FQUFvRSxFQUFFLEtBQUssSUFBSSxFQUFFO1FBQ2xGLE1BQU0sU0FBUyxHQUFHLElBQUksQ0FBQyxFQUFFLEVBQUUsQ0FBQztRQUM1QixNQUFNLFVBQVUsR0FBRyxJQUFJLENBQUMsRUFBRSxFQUFFLENBQUM7UUFDN0IsSUFBQSxjQUFNLEVBQUMsOEJBQUMsdUJBQVUsSUFBQyxNQUFNLEVBQUUsSUFBSSxFQUFFLGtCQUFrQixFQUFFLEtBQUssRUFBRSxTQUFTLEVBQUUsU0FBUyxFQUFFLFVBQVUsRUFBRSxVQUFVLEdBQUksQ0FBQyxDQUFDO1FBRTlHLE1BQU0sQ0FBQyxjQUFNLENBQUMsY0FBYyxDQUFDLHlCQUF5QixDQUFDLENBQUMsWUFBWSxDQUFDLGNBQWMsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQ3RHLE1BQU0sQ0FBQyxjQUFNLENBQUMsY0FBYyxDQUFDLHdCQUF3QixDQUFDLENBQUMsWUFBWSxDQUFDLGNBQWMsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQ3hHLENBQUMsQ0FBQyxDQUFDO0lBRUgsRUFBRSxDQUFDLHVGQUF1RixFQUFFLEtBQUssSUFBSSxFQUFFO1FBQ3JHLE1BQU0sU0FBUyxHQUFHLElBQUksQ0FBQyxFQUFFLEVBQUUsQ0FBQztRQUM1QixNQUFNLFVBQVUsR0FBRyxJQUFJLENBQUMsRUFBRSxFQUFFLENBQUM7UUFDN0IsSUFBQSxjQUFNLEVBQUMsOEJBQUMsdUJBQVUsSUFBQyxNQUFNLEVBQUUsSUFBSSxFQUFFLGtCQUFrQixFQUFFLEtBQUssRUFBRSxTQUFTLEVBQUUsU0FBUyxFQUFFLFVBQVUsRUFBRSxVQUFVLEdBQUksQ0FBQyxDQUFDO1FBQzlHLGlCQUFTLENBQUMsS0FBSyxDQUFDLGNBQU0sQ0FBQyxjQUFjLENBQUMsd0JBQXdCLENBQUMsQ0FBQyxDQUFDO1FBQ2pFLE1BQU0sQ0FBQyxVQUFVLENBQUMsQ0FBQyxvQkFBb0IsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUNqRCxDQUFDLENBQUMsQ0FBQztJQUVILEVBQUUsQ0FBQyxxRUFBcUUsRUFBRSxLQUFLLElBQUksRUFBRTtRQUNuRixNQUFNLFNBQVMsR0FBRyxJQUFJLENBQUMsRUFBRSxFQUFFLENBQUM7UUFDNUIsTUFBTSxVQUFVLEdBQUcsSUFBSSxDQUFDLEVBQUUsRUFBRSxDQUFDO1FBQzdCLElBQUEsY0FBTSxFQUFDLDhCQUFDLHVCQUFVLElBQUMsTUFBTSxFQUFFLEtBQUssRUFBRSxrQkFBa0IsRUFBRSxLQUFLLEVBQUUsU0FBUyxFQUFFLFNBQVMsRUFBRSxVQUFVLEVBQUUsVUFBVSxHQUFJLENBQUMsQ0FBQztRQUUvRyxNQUFNLENBQUMsY0FBTSxDQUFDLGNBQWMsQ0FBQyx5QkFBeUIsQ0FBQyxDQUFDLFlBQVksQ0FBQyxjQUFjLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUN2RyxNQUFNLENBQUMsY0FBTSxDQUFDLGNBQWMsQ0FBQyx3QkFBd0IsQ0FBQyxDQUFDLFlBQVksQ0FBQyxjQUFjLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUN2RyxDQUFDLENBQUMsQ0FBQztBQUNMLENBQUMsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IHNjcmVlbiwgcmVuZGVyLCBmaXJlRXZlbnQgfSBmcm9tICdAdGVzdGluZy1saWJyYXJ5L3JlYWN0JztcbmltcG9ydCAnQHRlc3RpbmctbGlicmFyeS9qZXN0LWRvbSc7XG5pbXBvcnQgeyBDaGF0Rm9vdGVyIH0gZnJvbSAnLi9DaGF0Rm9vdGVyJztcblxuZGVzY3JpYmUoJ0NoYXRGb290ZXIgJywgKCkgPT4ge1xuICBpdCgnQ2hhdEZvb3RlciB3aWxsIGNhbGwgY29udGV4dCBvbk5ld0NoYXQgd2hlbiBuZXcgY2hhdCBpcyByZXF1ZXN0ZWQnLCBhc3luYyAoKSA9PiB7XG4gICAgY29uc3Qgb25OZXdDaGF0ID0gamVzdC5mbigpO1xuICAgIGNvbnN0IG9uUmF0ZUNoYXQgPSBqZXN0LmZuKCk7XG4gICAgcmVuZGVyKDxDaGF0Rm9vdGVyIHJhdGluZz17bnVsbH0gaXNQcm9jZXNzaW5nUmF0aW5nPXtmYWxzZX0gb25OZXdDaGF0PXtvbk5ld0NoYXR9IG9uUmF0ZUNoYXQ9e29uUmF0ZUNoYXR9IC8+KTtcbiAgICBmaXJlRXZlbnQuY2xpY2soc2NyZWVuLmdldEJ5VGV4dCgnTmV3IGNoYXQnKSk7XG4gICAgZXhwZWN0KG9uTmV3Q2hhdCkudG9IYXZlQmVlbkNhbGxlZCgpO1xuICB9KTtcblxuICBpdCgnQ2hhdEZvb3RlciB3aWxsIGNhbGwgY29udGV4dCBvblJhdGVDaGF0IHdpdGggYm9vbGVhbiB0cnVlIHdoZW4gZ29vZCByYXRpbmcgaXMgcHJlc3NlZCcsIGFzeW5jICgpID0+IHtcbiAgICBjb25zdCBvbk5ld0NoYXQgPSBqZXN0LmZuKCk7XG4gICAgY29uc3Qgb25SYXRlQ2hhdCA9IGplc3QuZm4oKTtcbiAgICByZW5kZXIoPENoYXRGb290ZXIgcmF0aW5nPXtudWxsfSBpc1Byb2Nlc3NpbmdSYXRpbmc9e2ZhbHNlfSBvbk5ld0NoYXQ9e29uTmV3Q2hhdH0gb25SYXRlQ2hhdD17b25SYXRlQ2hhdH0gLz4pO1xuICAgIGZpcmVFdmVudC5jbGljayhzY3JlZW4uZ2V0QnlMYWJlbFRleHQoJ1JhdGUgY2hhdCByZXNwb25zZSBnb29kJykpO1xuICAgIGV4cGVjdChvblJhdGVDaGF0KS50b0hhdmVCZWVuQ2FsbGVkV2l0aCh0cnVlKTtcbiAgfSk7XG5cbiAgaXQoJ0NoYXRGb290ZXIgd2lsbCBzZXQgcmF0aW5nIGJ1dHRvbiBjaGVja2VkIGZyb20gaW5wdXQgcmF0aW5nICh0cnVlKScsIGFzeW5jICgpID0+IHtcbiAgICBjb25zdCBvbk5ld0NoYXQgPSBqZXN0LmZuKCk7XG4gICAgY29uc3Qgb25SYXRlQ2hhdCA9IGplc3QuZm4oKTtcbiAgICByZW5kZXIoPENoYXRGb290ZXIgcmF0aW5nPXt0cnVlfSBpc1Byb2Nlc3NpbmdSYXRpbmc9e2ZhbHNlfSBvbk5ld0NoYXQ9e29uTmV3Q2hhdH0gb25SYXRlQ2hhdD17b25SYXRlQ2hhdH0gLz4pO1xuXG4gICAgZXhwZWN0KHNjcmVlbi5nZXRCeUxhYmVsVGV4dCgnUmF0ZSBjaGF0IHJlc3BvbnNlIGdvb2QnKS5nZXRBdHRyaWJ1dGUoJ2FyaWEtY2hlY2tlZCcpKS50b0VxdWFsKCd0cnVlJyk7XG4gICAgZXhwZWN0KHNjcmVlbi5nZXRCeUxhYmVsVGV4dCgnUmF0ZSBjaGF0IHJlc3BvbnNlIGJhZCcpLmdldEF0dHJpYnV0ZSgnYXJpYS1jaGVja2VkJykpLnRvRXF1YWwoJ2ZhbHNlJyk7XG4gIH0pO1xuXG4gIGl0KCdDaGF0Rm9vdGVyIHdpbGwgY2FsbCBjb250ZXh0IG9uUmF0ZUNoYXQgd2l0aCBib29sZWFuIGZhbHNlIHdoZW4gYmFkIHJhdGluZyBpcyBwcmVzc2VkJywgYXN5bmMgKCkgPT4ge1xuICAgIGNvbnN0IG9uTmV3Q2hhdCA9IGplc3QuZm4oKTtcbiAgICBjb25zdCBvblJhdGVDaGF0ID0gamVzdC5mbigpO1xuICAgIHJlbmRlcig8Q2hhdEZvb3RlciByYXRpbmc9e251bGx9IGlzUHJvY2Vzc2luZ1JhdGluZz17ZmFsc2V9IG9uTmV3Q2hhdD17b25OZXdDaGF0fSBvblJhdGVDaGF0PXtvblJhdGVDaGF0fSAvPik7XG4gICAgZmlyZUV2ZW50LmNsaWNrKHNjcmVlbi5nZXRCeUxhYmVsVGV4dCgnUmF0ZSBjaGF0IHJlc3BvbnNlIGJhZCcpKTtcbiAgICBleHBlY3Qob25SYXRlQ2hhdCkudG9IYXZlQmVlbkNhbGxlZFdpdGgoZmFsc2UpO1xuICB9KTtcblxuICBpdCgnQ2hhdEZvb3RlciB3aWxsIHNldCByYXRpbmcgYnV0dG9uIGNoZWNrZWQgZnJvbSBpbnB1dCByYXRpbmcgKGZhbHNlKScsIGFzeW5jICgpID0+IHtcbiAgICBjb25zdCBvbk5ld0NoYXQgPSBqZXN0LmZuKCk7XG4gICAgY29uc3Qgb25SYXRlQ2hhdCA9IGplc3QuZm4oKTtcbiAgICByZW5kZXIoPENoYXRGb290ZXIgcmF0aW5nPXtmYWxzZX0gaXNQcm9jZXNzaW5nUmF0aW5nPXtmYWxzZX0gb25OZXdDaGF0PXtvbk5ld0NoYXR9IG9uUmF0ZUNoYXQ9e29uUmF0ZUNoYXR9IC8+KTtcblxuICAgIGV4cGVjdChzY3JlZW4uZ2V0QnlMYWJlbFRleHQoJ1JhdGUgY2hhdCByZXNwb25zZSBnb29kJykuZ2V0QXR0cmlidXRlKCdhcmlhLWNoZWNrZWQnKSkudG9FcXVhbCgnZmFsc2UnKTtcbiAgICBleHBlY3Qoc2NyZWVuLmdldEJ5TGFiZWxUZXh0KCdSYXRlIGNoYXQgcmVzcG9uc2UgYmFkJykuZ2V0QXR0cmlidXRlKCdhcmlhLWNoZWNrZWQnKSkudG9FcXVhbCgndHJ1ZScpO1xuICB9KTtcbn0pO1xuIl19 | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ChatFooter.spec.js","sourceRoot":"","sources":["../../../src/components/ChatFooter/ChatFooter.spec.tsx"],"names":[],"mappings":"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","sourcesContent":["import React from 'react';\nimport { screen, render, fireEvent } from '@testing-library/react';\nimport '@testing-library/jest-dom';\nimport { ChatFooter } from './ChatFooter';\n\ndescribe('ChatFooter ', () => {\n  it('ChatFooter will call context onNewChat when new chat is requested', async () => {\n    const onNewChat = jest.fn();\n    const onRateChat = jest.fn();\n    render(\n      <ChatFooter\n        rating={null}\n        isProcessingRating={false}\n        isWaitingUserInput={false}\n        isNewChat={false}\n        isWaitingResponse={false}\n        onNewChat={onNewChat}\n        onRateChat={onRateChat}\n      />,\n    );\n    fireEvent.click(screen.getByText('New chat'));\n    expect(onNewChat).toHaveBeenCalled();\n  });\n\n  it('ChatFooter will disable new chat button if its a new chat', async () => {\n    const onNewChat = jest.fn();\n    const onRateChat = jest.fn();\n    render(\n      <ChatFooter\n        rating={null}\n        isProcessingRating={false}\n        isWaitingUserInput={false}\n        isNewChat={true}\n        isWaitingResponse={false}\n        onNewChat={onNewChat}\n        onRateChat={onRateChat}\n      />,\n    );\n    fireEvent.click(screen.getByText('New chat'));\n    expect(onNewChat).not.toHaveBeenCalled();\n  });\n\n  it('ChatFooter will not disable new chat button if waiting for response', async () => {\n    const onNewChat = jest.fn();\n    const onRateChat = jest.fn();\n    render(\n      <ChatFooter\n        rating={null}\n        isProcessingRating={false}\n        isWaitingUserInput={false}\n        isNewChat={false}\n        isWaitingResponse={false}\n        onNewChat={onNewChat}\n        onRateChat={onRateChat}\n      />,\n    );\n    fireEvent.click(screen.getByText('New chat'));\n    expect(onNewChat).toHaveBeenCalledTimes(1);\n  });\n\n  it('ChatFooter will disable new chat button if waiting for user input', async () => {\n    const onNewChat = jest.fn();\n    const onRateChat = jest.fn();\n    render(\n      <ChatFooter\n        rating={null}\n        isProcessingRating={false}\n        isWaitingUserInput={true}\n        isNewChat={false}\n        isWaitingResponse={false}\n        onNewChat={onNewChat}\n        onRateChat={onRateChat}\n      />,\n    );\n    fireEvent.click(screen.getByText('New chat'));\n    expect(onNewChat).not.toHaveBeenCalled();\n  });\n\n  it('ChatFooter will disable rating button if its new chat', async () => {\n    const onNewChat = jest.fn();\n    const onRateChat = jest.fn();\n    render(\n      <ChatFooter\n        rating={null}\n        isProcessingRating={false}\n        isWaitingUserInput={false}\n        isNewChat={true}\n        isWaitingResponse={false}\n        onNewChat={onNewChat}\n        onRateChat={onRateChat}\n      />,\n    );\n    fireEvent.click(screen.getByLabelText('Rate chat response good'));\n    expect(onRateChat).not.toHaveBeenCalledWith();\n    fireEvent.click(screen.getByLabelText('Rate chat response bad'));\n    expect(onRateChat).not.toHaveBeenCalledWith();\n  });\n\n  it('ChatFooter will call context onRateChat with boolean true when good rating is pressed', async () => {\n    const onNewChat = jest.fn();\n    const onRateChat = jest.fn();\n    render(\n      <ChatFooter\n        rating={null}\n        isProcessingRating={false}\n        isWaitingUserInput={false}\n        isNewChat={false}\n        isWaitingResponse={false}\n        onNewChat={onNewChat}\n        onRateChat={onRateChat}\n      />,\n    );\n    fireEvent.click(screen.getByLabelText('Rate chat response good'));\n    expect(onRateChat).toHaveBeenCalledWith(true);\n  });\n\n  it('ChatFooter will set rating button checked from input rating (true)', async () => {\n    const onNewChat = jest.fn();\n    const onRateChat = jest.fn();\n    render(\n      <ChatFooter\n        rating={true}\n        isProcessingRating={false}\n        isWaitingUserInput={false}\n        isNewChat={false}\n        isWaitingResponse={false}\n        onNewChat={onNewChat}\n        onRateChat={onRateChat}\n      />,\n    );\n\n    expect(screen.getByLabelText('Rate chat response good').getAttribute('aria-checked')).toEqual('true');\n    expect(screen.getByLabelText('Rate chat response bad').getAttribute('aria-checked')).toEqual('false');\n  });\n\n  it('ChatFooter will call context onRateChat with boolean false when bad rating is pressed', async () => {\n    const onNewChat = jest.fn();\n    const onRateChat = jest.fn();\n    render(\n      <ChatFooter\n        rating={null}\n        isProcessingRating={false}\n        isWaitingUserInput={false}\n        isNewChat={false}\n        isWaitingResponse={false}\n        onNewChat={onNewChat}\n        onRateChat={onRateChat}\n      />,\n    );\n    fireEvent.click(screen.getByLabelText('Rate chat response bad'));\n    expect(onRateChat).toHaveBeenCalledWith(false);\n  });\n\n  it('ChatFooter will set rating button checked from input rating (false)', async () => {\n    const onNewChat = jest.fn();\n    const onRateChat = jest.fn();\n    render(\n      <ChatFooter\n        rating={false}\n        isProcessingRating={false}\n        isWaitingUserInput={false}\n        isNewChat={false}\n        isWaitingResponse={false}\n        onNewChat={onNewChat}\n        onRateChat={onRateChat}\n      />,\n    );\n\n    expect(screen.getByLabelText('Rate chat response good').getAttribute('aria-checked')).toEqual('false');\n    expect(screen.getByLabelText('Rate chat response bad').getAttribute('aria-checked')).toEqual('true');\n  });\n});\n"]} |
@@ -16,2 +16,3 @@ import React, { PropsWithChildren } from 'react'; | ||
isWaitingResponse: boolean; | ||
isWaitingUserInput: boolean; | ||
conversation: ConversationItem[]; | ||
@@ -18,0 +19,0 @@ onNewChatRequest: () => void; |
@@ -34,2 +34,3 @@ "use strict"; | ||
isWaitingResponse: false, | ||
isWaitingUserInput: false, | ||
conversation: [], | ||
@@ -49,2 +50,11 @@ onNewChatRequest: () => { | ||
}); | ||
const getSavedUserInputState = (sessionStorageId) => { | ||
const chatHistoryItem = sessionStorage.getItem(sessionStorageId); | ||
let isWaitingUserInput = false; | ||
if (chatHistoryItem) { | ||
const chatHistory = JSON.parse(chatHistoryItem); | ||
isWaitingUserInput = chatHistory.isWaitingUserInput; | ||
} | ||
return isWaitingUserInput; | ||
}; | ||
const ChatContextProvider = (props) => { | ||
@@ -56,2 +66,3 @@ const { aiId, aiApiUrl, aiService, isPreview, greeting, persistThread = false, children } = props; | ||
const [isWaitingResponse, setIsWaitingResponse] = (0, react_1.useState)(false); | ||
const [isWaitingUserInput, setIsWaitingUserInput] = (0, react_1.useState)(persistThread && getSavedUserInputState(sessionStorageId)); | ||
const [threadStartDate, setThreadStartDate] = (0, react_1.useState)(new Date()); | ||
@@ -136,2 +147,3 @@ const [conversation, setConversation] = (0, react_1.useState)([]); | ||
rating: newRating, | ||
...(isWaitingUserInput ? { isWaitingUserInput } : {}), | ||
})); | ||
@@ -161,2 +173,3 @@ } | ||
} | ||
setIsWaitingUserInput(chatHistory.isWaitingUserInput); | ||
return; | ||
@@ -181,2 +194,7 @@ } | ||
}, []); | ||
(0, react_1.useMemo)(() => { | ||
if (persistThread && isWaitingUserInput !== getSavedUserInputState(sessionStorageId)) { | ||
updateThreadSessionState({}); | ||
} | ||
}, [isWaitingUserInput]); | ||
const handleOnSend = (0, react_1.useCallback)(async (message) => { | ||
@@ -191,2 +209,3 @@ addMessagesToConversation([ | ||
setIsWaitingResponse(true); | ||
setIsWaitingUserInput(false); | ||
try { | ||
@@ -221,2 +240,4 @@ const response = await getCommandExecutor().execute(aiId, 'processChatMessage', { | ||
const handleOnNewChatRequest = (0, react_1.useCallback)(() => { | ||
setIsWaitingUserInput(true); | ||
setIsWaitingResponse(false); | ||
addMessagesToConversation([ | ||
@@ -238,2 +259,3 @@ { | ||
setIsWaitingResponse(false); | ||
setIsWaitingUserInput(false); | ||
setThreadStartDate(new Date()); | ||
@@ -277,2 +299,3 @@ setRating(null); | ||
else { | ||
setIsWaitingUserInput(false); | ||
alterConversation([ | ||
@@ -333,2 +356,3 @@ { | ||
isWaitingResponse, | ||
isWaitingUserInput, | ||
conversation, | ||
@@ -342,2 +366,2 @@ onNewChatRequest: handleOnNewChatRequest, | ||
exports.ChatContextProvider = ChatContextProvider; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ChatContext.js","sourceRoot":"","sources":["../../src/context/ChatContext.tsx"],"names":[],"mappings":"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","sourcesContent":["import React, { PropsWithChildren, useRef, useState, useEffect, useCallback } from 'react';\nimport { DxpAiService, ChatBotCommandExecutor, createClient } from '@squiz/dxp-ai-client';\nimport { v4 as uuidv4 } from 'uuid';\nimport { ConversationItem, ControlMessage } from '../types';\n\nexport type ChatProviderProps = {\n  aiId: string;\n  aiApiUrl?: string;\n  aiService?: DxpAiService<unknown>;\n  isPreview?: boolean;\n  greeting: string;\n  persistThread?: boolean;\n};\n\nexport type ChatContextProps = {\n  rating: boolean | null;\n  isProcessingRating: boolean;\n  isWaitingResponse: boolean;\n  conversation: ConversationItem[];\n  onNewChatRequest: () => void;\n  onNewChatConfirm: (yesResponse: boolean) => void;\n  onRateChat: (positiveRating: boolean) => void;\n  onSend: (message: string) => void;\n};\n\ntype ConversationInstruction = {\n  item: ConversationItem;\n  instruction: 'add' | 'removeSingleOfType';\n};\n\ntype ConversationPersistProps = {\n  conversation?: ConversationItem[];\n  rating?: boolean | null;\n  threadId?: string | null;\n};\n\nexport const ChatContext = React.createContext<ChatContextProps>({\n  rating: null,\n  isProcessingRating: false,\n  isWaitingResponse: false,\n  conversation: [],\n  onNewChatRequest: () => {\n    throw new Error('onNewChatRequest has not been configured.');\n  },\n  onNewChatConfirm: () => {\n    throw new Error('onNewChatConfirm has not been configured.');\n  },\n  onRateChat: () => {\n    throw new Error('onRateChat has not been configured.');\n  },\n  onSend: () => {\n    throw new Error('onSend has not been configured.');\n  },\n});\n\nexport const ChatContextProvider = (props: PropsWithChildren<ChatProviderProps>) => {\n  const { aiId, aiApiUrl, aiService, isPreview, greeting, persistThread = false, children } = props;\n  const sessionStorageId = `squiz-chat-ui-history-${aiId}`;\n  const dxpAiClient = useRef<DxpAiService<unknown> | null>(null);\n  const executor = useRef<ChatBotCommandExecutor | null>(null);\n  const [isWaitingResponse, setIsWaitingResponse] = useState<boolean>(false);\n  const [threadStartDate, setThreadStartDate] = useState<Date>(new Date());\n  const [conversation, setConversation] = useState<ConversationItem[]>([]);\n  const [rating, setRating] = useState<boolean | null>(null);\n  const [isProcessingRating, setIsProcessingRating] = useState<boolean>(false);\n\n  // Return the command executor or create if its not setup yet (workaround for useRef not taking an init function)\n  function getCommandExecutor() {\n    if (executor.current !== null) {\n      return executor.current;\n    }\n    if (aiService) {\n      dxpAiClient.current = aiService;\n    } else if (aiApiUrl) {\n      dxpAiClient.current = new DxpAiService(\n        createClient({\n          baseUrl: aiApiUrl,\n        }),\n      );\n    } else {\n      throw new Error('Requires: aiApiUrl or aiService for connection to the chatbot.');\n    }\n    executor.current = new ChatBotCommandExecutor(dxpAiClient.current);\n    return executor.current;\n  }\n\n  // Keep a ref to the conversation so callbacks from sendMessage have up to date history to insert into\n  const callbackStateRef = useRef<{\n    conversation: ConversationItem[];\n    threadId: string | null;\n    threadStartDate: Date;\n  }>({\n    conversation: [],\n    threadId: null,\n    threadStartDate,\n  });\n  callbackStateRef.current = {\n    conversation,\n    threadId: callbackStateRef.current.threadId,\n    threadStartDate,\n  };\n\n  // Simple add message function\n  const addMessagesToConversation = (messages: ConversationItem[]) => {\n    const newConversation = [...callbackStateRef.current.conversation, ...messages];\n    setConversation(newConversation);\n    updateThreadSessionState({ conversation: newConversation });\n  };\n\n  // Complex conversation change function\n  const alterConversation = (instructions: ConversationInstruction[]) => {\n    let newConversation = [...callbackStateRef.current.conversation];\n    instructions.forEach(({ item, instruction }) => {\n      // Add to end of conversation\n      if (instruction === 'add') {\n        newConversation = [...newConversation, item];\n      } else if (instruction === 'removeSingleOfType') {\n        const removeType = (item as ControlMessage).type;\n        const controlMessageIndex = callbackStateRef.current.conversation.findIndex((message) => {\n          const isControlMessage = Object.hasOwn(message, 'type');\n          const controlMessage = message as ControlMessage;\n\n          if (isControlMessage && controlMessage.type === removeType) {\n            return true;\n          }\n          return false;\n        });\n\n        // Remove the type from the conversation\n        if (controlMessageIndex) {\n          newConversation.splice(controlMessageIndex, 1);\n        }\n      }\n    });\n\n    setConversation(newConversation);\n    updateThreadSessionState({ conversation: newConversation });\n  };\n\n  // Helper function to persist the thread into the session storage if enabled\n  const updateThreadSessionState = ({ conversation, rating, threadId }: ConversationPersistProps) => {\n    if (persistThread) {\n      // Get the old history from the session so we can fill in missing details\n      const chatHistoryItem = sessionStorage.getItem(sessionStorageId);\n      let oldChatHistory;\n      if (chatHistoryItem) {\n        oldChatHistory = JSON.parse(chatHistoryItem);\n      }\n\n      // Determine what value to set the rating to, clearer than a triple ternary\n      let newRating = null;\n      if (rating !== undefined) {\n        newRating = rating;\n      } else if (oldChatHistory?.rating !== null) {\n        newRating = oldChatHistory?.rating;\n      }\n\n      sessionStorage.setItem(\n        sessionStorageId,\n        JSON.stringify({\n          currentThreadId: threadId || callbackStateRef.current.threadId,\n          conversation: conversation || oldChatHistory?.conversation,\n          rating: newRating,\n        }),\n      );\n    }\n  };\n\n  const addErrorMessageToConversation = () => {\n    addMessagesToConversation([\n      {\n        id: uuidv4(),\n        text: 'There was a problem responding to your message, please try again.',\n        sender: 'Frontend',\n        isError: true,\n      },\n    ]);\n  };\n\n  // Start up the chatbot executor and add the greeting into the conversation history\n  useEffect(() => {\n    getCommandExecutor(); // Start the command executor\n    if (persistThread) {\n      const chatHistoryItem = sessionStorage.getItem(sessionStorageId);\n      if (chatHistoryItem) {\n        const chatHistory = JSON.parse(chatHistoryItem);\n        callbackStateRef.current.threadId = chatHistory.currentThreadId;\n        addMessagesToConversation(chatHistory.conversation);\n        if (chatHistory.rating !== null) {\n          setRating(chatHistory.rating);\n        }\n        return;\n      }\n    }\n    addMessagesToConversation([\n      {\n        id: uuidv4(),\n        text: greeting,\n        sender: 'Frontend',\n      },\n    ]);\n  }, []);\n\n  useEffect(() => {\n    // On cleanup reset the threadStartDate so any in-flight messages get ignored\n    return () => {\n      callbackStateRef.current = {\n        ...callbackStateRef.current,\n        threadStartDate: new Date(),\n      };\n    };\n  }, []);\n\n  const handleOnSend = useCallback(\n    async (message: string) => {\n      // Add users message to conversation history\n      addMessagesToConversation([\n        {\n          id: uuidv4(),\n          text: message,\n          sender: 'User',\n        },\n      ]);\n\n      setIsWaitingResponse(true);\n      try {\n        const response = await getCommandExecutor().execute(aiId, 'processChatMessage', {\n          isPreview,\n          query: message,\n          threadId: callbackStateRef.current.threadId || undefined,\n        });\n\n        // Check this response is for this thread based on the threadStartDate, if not equal the response is for an old thread\n        if (threadStartDate === callbackStateRef.current.threadStartDate) {\n          // Update the threadId if we don't have one\n          if (!callbackStateRef.current.threadId) {\n            callbackStateRef.current.threadId = response.outputs.thread.id;\n          }\n\n          // Add server response to conversation history\n          addMessagesToConversation([\n            {\n              id: uuidv4(),\n              text: response.outputs.message.response,\n              sender: 'Server',\n            },\n          ]);\n        }\n      } catch (error: unknown) {\n        // Check this error is for this thread based on the threadStartDate, if not equal the error is for an old thread\n        if (threadStartDate === callbackStateRef.current.threadStartDate) {\n          // An error is stored in error.error.message but it might not be user safe\n          addErrorMessageToConversation();\n        }\n      }\n\n      if (threadStartDate === callbackStateRef.current.threadStartDate) {\n        setIsWaitingResponse(false);\n      }\n    },\n    [isPreview, threadStartDate],\n  );\n\n  const handleOnNewChatRequest = useCallback(() => {\n    addMessagesToConversation([\n      {\n        id: uuidv4(),\n        text: 'Are you sure you want to start a new chat?',\n        sender: 'Frontend',\n      },\n      {\n        id: uuidv4(),\n        type: 'newChatRequest',\n      },\n    ]);\n  }, [greeting]);\n\n  const handleOnNewChatConfirm = useCallback(\n    (yesResponse: boolean) => {\n      if (yesResponse) {\n        // Reset the thread to null\n        callbackStateRef.current.threadId = null;\n        setIsWaitingResponse(false);\n        setThreadStartDate(new Date()); // Restart the thread age\n        setRating(null);\n        setIsProcessingRating(false);\n        updateThreadSessionState({ threadId: null, rating: null });\n\n        alterConversation([\n          {\n            instruction: 'add',\n            item: {\n              id: uuidv4(),\n              text: 'Yes',\n              sender: 'User',\n            },\n          },\n          {\n            instruction: 'add',\n            item: {\n              id: uuidv4(),\n              type: 'newChatBreak',\n            },\n          },\n          {\n            instruction: 'add',\n            item: {\n              id: uuidv4(),\n              text: greeting,\n              sender: 'Frontend',\n            },\n          },\n          {\n            instruction: 'removeSingleOfType',\n            item: {\n              id: uuidv4(),\n              type: 'newChatRequest',\n            },\n          },\n        ]);\n      } else {\n        alterConversation([\n          {\n            instruction: 'add',\n            item: {\n              id: uuidv4(),\n              text: 'No',\n              sender: 'User',\n            },\n          },\n          {\n            instruction: 'add',\n            item: {\n              id: uuidv4(),\n              text: 'Ok, is there anything else I can help you with?',\n              sender: 'Frontend',\n            },\n          },\n          {\n            instruction: 'removeSingleOfType',\n            item: {\n              id: uuidv4(),\n              type: 'newChatRequest',\n            },\n          },\n        ]);\n      }\n    },\n    [greeting],\n  );\n\n  const handleOnRateChat = useCallback(\n    async (positiveRating: boolean) => {\n      if (dxpAiClient.current && callbackStateRef.current.threadId && !isProcessingRating) {\n        setIsProcessingRating(true);\n        setRating(positiveRating);\n        updateThreadSessionState({ rating: positiveRating });\n        if (positiveRating) {\n          await dxpAiClient.current.chatbot.rate(aiId, callbackStateRef.current.threadId, { rating: 'positive' });\n        } else {\n          await dxpAiClient.current.chatbot.rate(aiId, callbackStateRef.current.threadId, { rating: 'negative' });\n        }\n        if (threadStartDate === callbackStateRef.current.threadStartDate) {\n          setIsProcessingRating(false);\n        }\n      } else {\n        if (isProcessingRating) {\n          throw new Error('Previous rating is still processing');\n        } else {\n          throw new Error('Thread has not been started');\n        }\n      }\n    },\n    [aiId, threadStartDate, isProcessingRating],\n  );\n\n  return (\n    <ChatContext.Provider\n      value={{\n        rating,\n        isProcessingRating,\n        isWaitingResponse,\n        conversation,\n        onNewChatRequest: handleOnNewChatRequest,\n        onNewChatConfirm: handleOnNewChatConfirm,\n        onRateChat: handleOnRateChat,\n        onSend: handleOnSend,\n      }}\n    >\n      {children}\n    </ChatContext.Provider>\n  );\n};\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ChatContext.js","sourceRoot":"","sources":["../../src/context/ChatContext.tsx"],"names":[],"mappings":"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","sourcesContent":["import React, { PropsWithChildren, useRef, useState, useEffect, useCallback, useMemo } from 'react';\nimport { DxpAiService, ChatBotCommandExecutor, createClient } from '@squiz/dxp-ai-client';\nimport { v4 as uuidv4 } from 'uuid';\nimport { ConversationItem, ControlMessage } from '../types';\n\nexport type ChatProviderProps = {\n  aiId: string;\n  aiApiUrl?: string;\n  aiService?: DxpAiService<unknown>;\n  isPreview?: boolean;\n  greeting: string;\n  persistThread?: boolean;\n};\n\nexport type ChatContextProps = {\n  rating: boolean | null;\n  isProcessingRating: boolean;\n  isWaitingResponse: boolean;\n  isWaitingUserInput: boolean;\n  conversation: ConversationItem[];\n  onNewChatRequest: () => void;\n  onNewChatConfirm: (yesResponse: boolean) => void;\n  onRateChat: (positiveRating: boolean) => void;\n  onSend: (message: string) => void;\n};\n\ntype ConversationInstruction = {\n  item: ConversationItem;\n  instruction: 'add' | 'removeSingleOfType';\n};\n\ntype ConversationPersistProps = {\n  conversation?: ConversationItem[];\n  rating?: boolean | null;\n  threadId?: string | null;\n};\n\nexport const ChatContext = React.createContext<ChatContextProps>({\n  rating: null,\n  isProcessingRating: false,\n  isWaitingResponse: false,\n  isWaitingUserInput: false,\n  conversation: [],\n  onNewChatRequest: () => {\n    throw new Error('onNewChatRequest has not been configured.');\n  },\n  onNewChatConfirm: () => {\n    throw new Error('onNewChatConfirm has not been configured.');\n  },\n  onRateChat: () => {\n    throw new Error('onRateChat has not been configured.');\n  },\n  onSend: () => {\n    throw new Error('onSend has not been configured.');\n  },\n});\n\nconst getSavedUserInputState = (sessionStorageId: string): boolean => {\n  const chatHistoryItem = sessionStorage.getItem(sessionStorageId);\n  let isWaitingUserInput = false;\n\n  if (chatHistoryItem) {\n    const chatHistory = JSON.parse(chatHistoryItem);\n    isWaitingUserInput = chatHistory.isWaitingUserInput;\n  }\n\n  return isWaitingUserInput;\n};\n\nexport const ChatContextProvider = (props: PropsWithChildren<ChatProviderProps>) => {\n  const { aiId, aiApiUrl, aiService, isPreview, greeting, persistThread = false, children } = props;\n  const sessionStorageId = `squiz-chat-ui-history-${aiId}`;\n  const dxpAiClient = useRef<DxpAiService<unknown> | null>(null);\n  const executor = useRef<ChatBotCommandExecutor | null>(null);\n  const [isWaitingResponse, setIsWaitingResponse] = useState<boolean>(false);\n  const [isWaitingUserInput, setIsWaitingUserInput] = useState<boolean>(\n    persistThread && getSavedUserInputState(sessionStorageId),\n  );\n  const [threadStartDate, setThreadStartDate] = useState<Date>(new Date());\n  const [conversation, setConversation] = useState<ConversationItem[]>([]);\n  const [rating, setRating] = useState<boolean | null>(null);\n  const [isProcessingRating, setIsProcessingRating] = useState<boolean>(false);\n\n  // Return the command executor or create if its not setup yet (workaround for useRef not taking an init function)\n  function getCommandExecutor() {\n    if (executor.current !== null) {\n      return executor.current;\n    }\n    if (aiService) {\n      dxpAiClient.current = aiService;\n    } else if (aiApiUrl) {\n      dxpAiClient.current = new DxpAiService(\n        createClient({\n          baseUrl: aiApiUrl,\n        }),\n      );\n    } else {\n      throw new Error('Requires: aiApiUrl or aiService for connection to the chatbot.');\n    }\n    executor.current = new ChatBotCommandExecutor(dxpAiClient.current);\n    return executor.current;\n  }\n\n  // Keep a ref to the conversation so callbacks from sendMessage have up to date history to insert into\n  const callbackStateRef = useRef<{\n    conversation: ConversationItem[];\n    threadId: string | null;\n    threadStartDate: Date;\n  }>({\n    conversation: [],\n    threadId: null,\n    threadStartDate,\n  });\n  callbackStateRef.current = {\n    conversation,\n    threadId: callbackStateRef.current.threadId,\n    threadStartDate,\n  };\n\n  // Simple add message function\n  const addMessagesToConversation = (messages: ConversationItem[]) => {\n    const newConversation = [...callbackStateRef.current.conversation, ...messages];\n    setConversation(newConversation);\n    updateThreadSessionState({ conversation: newConversation });\n  };\n\n  // Complex conversation change function\n  const alterConversation = (instructions: ConversationInstruction[]) => {\n    let newConversation = [...callbackStateRef.current.conversation];\n    instructions.forEach(({ item, instruction }) => {\n      // Add to end of conversation\n      if (instruction === 'add') {\n        newConversation = [...newConversation, item];\n      } else if (instruction === 'removeSingleOfType') {\n        const removeType = (item as ControlMessage).type;\n        const controlMessageIndex = callbackStateRef.current.conversation.findIndex((message) => {\n          const isControlMessage = Object.hasOwn(message, 'type');\n          const controlMessage = message as ControlMessage;\n\n          if (isControlMessage && controlMessage.type === removeType) {\n            return true;\n          }\n          return false;\n        });\n\n        // Remove the type from the conversation\n        if (controlMessageIndex) {\n          newConversation.splice(controlMessageIndex, 1);\n        }\n      }\n    });\n\n    setConversation(newConversation);\n    updateThreadSessionState({ conversation: newConversation });\n  };\n\n  // Helper function to persist the thread into the session storage if enabled\n  const updateThreadSessionState = ({ conversation, rating, threadId }: ConversationPersistProps) => {\n    if (persistThread) {\n      // Get the old history from the session so we can fill in missing details\n      const chatHistoryItem = sessionStorage.getItem(sessionStorageId);\n      let oldChatHistory;\n      if (chatHistoryItem) {\n        oldChatHistory = JSON.parse(chatHistoryItem);\n      }\n\n      // Determine what value to set the rating to, clearer than a triple ternary\n      let newRating = null;\n      if (rating !== undefined) {\n        newRating = rating;\n      } else if (oldChatHistory?.rating !== null) {\n        newRating = oldChatHistory?.rating;\n      }\n\n      sessionStorage.setItem(\n        sessionStorageId,\n        JSON.stringify({\n          currentThreadId: threadId || callbackStateRef.current.threadId,\n          conversation: conversation || oldChatHistory?.conversation,\n          rating: newRating,\n          ...(isWaitingUserInput ? { isWaitingUserInput } : {}),\n        }),\n      );\n    }\n  };\n\n  const addErrorMessageToConversation = () => {\n    addMessagesToConversation([\n      {\n        id: uuidv4(),\n        text: 'There was a problem responding to your message, please try again.',\n        sender: 'Frontend',\n        isError: true,\n      },\n    ]);\n  };\n\n  // Start up the chatbot executor and add the greeting into the conversation history\n  useEffect(() => {\n    getCommandExecutor(); // Start the command executor\n    if (persistThread) {\n      const chatHistoryItem = sessionStorage.getItem(sessionStorageId);\n      if (chatHistoryItem) {\n        const chatHistory = JSON.parse(chatHistoryItem);\n        callbackStateRef.current.threadId = chatHistory.currentThreadId;\n        addMessagesToConversation(chatHistory.conversation);\n        if (chatHistory.rating !== null) {\n          setRating(chatHistory.rating);\n        }\n\n        setIsWaitingUserInput(chatHistory.isWaitingUserInput);\n\n        return;\n      }\n    }\n    addMessagesToConversation([\n      {\n        id: uuidv4(),\n        text: greeting,\n        sender: 'Frontend',\n      },\n    ]);\n  }, []);\n\n  useEffect(() => {\n    // On cleanup reset the threadStartDate so any in-flight messages get ignored\n    return () => {\n      callbackStateRef.current = {\n        ...callbackStateRef.current,\n        threadStartDate: new Date(),\n      };\n    };\n  }, []);\n\n  useMemo(() => {\n    if (persistThread && isWaitingUserInput !== getSavedUserInputState(sessionStorageId)) {\n      // Update waiting user input state in session.\n      updateThreadSessionState({});\n    }\n  }, [isWaitingUserInput]);\n\n  const handleOnSend = useCallback(\n    async (message: string) => {\n      // Add users message to conversation history\n      addMessagesToConversation([\n        {\n          id: uuidv4(),\n          text: message,\n          sender: 'User',\n        },\n      ]);\n\n      setIsWaitingResponse(true);\n      setIsWaitingUserInput(false);\n      try {\n        const response = await getCommandExecutor().execute(aiId, 'processChatMessage', {\n          isPreview,\n          query: message,\n          threadId: callbackStateRef.current.threadId || undefined,\n        });\n\n        // Check this response is for this thread based on the threadStartDate, if not equal the response is for an old thread\n        if (threadStartDate === callbackStateRef.current.threadStartDate) {\n          // Update the threadId if we don't have one\n          if (!callbackStateRef.current.threadId) {\n            callbackStateRef.current.threadId = response.outputs.thread.id;\n          }\n\n          // Add server response to conversation history\n          addMessagesToConversation([\n            {\n              id: uuidv4(),\n              text: response.outputs.message.response,\n              sender: 'Server',\n            },\n          ]);\n        }\n      } catch (error: unknown) {\n        // Check this error is for this thread based on the threadStartDate, if not equal the error is for an old thread\n        if (threadStartDate === callbackStateRef.current.threadStartDate) {\n          // An error is stored in error.error.message but it might not be user safe\n          addErrorMessageToConversation();\n        }\n      }\n\n      if (threadStartDate === callbackStateRef.current.threadStartDate) {\n        setIsWaitingResponse(false);\n      }\n    },\n    [isPreview, threadStartDate],\n  );\n\n  const handleOnNewChatRequest = useCallback(() => {\n    setIsWaitingUserInput(true);\n    setIsWaitingResponse(false);\n    addMessagesToConversation([\n      {\n        id: uuidv4(),\n        text: 'Are you sure you want to start a new chat?',\n        sender: 'Frontend',\n      },\n      {\n        id: uuidv4(),\n        type: 'newChatRequest',\n      },\n    ]);\n  }, [greeting]);\n\n  const handleOnNewChatConfirm = useCallback(\n    (yesResponse: boolean) => {\n      if (yesResponse) {\n        // Reset the thread to null\n        callbackStateRef.current.threadId = null;\n        setIsWaitingResponse(false);\n        setIsWaitingUserInput(false);\n        setThreadStartDate(new Date()); // Restart the thread age\n        setRating(null);\n        setIsProcessingRating(false);\n        updateThreadSessionState({ threadId: null, rating: null });\n\n        alterConversation([\n          {\n            instruction: 'add',\n            item: {\n              id: uuidv4(),\n              text: 'Yes',\n              sender: 'User',\n            },\n          },\n          {\n            instruction: 'add',\n            item: {\n              id: uuidv4(),\n              type: 'newChatBreak',\n            },\n          },\n          {\n            instruction: 'add',\n            item: {\n              id: uuidv4(),\n              text: greeting,\n              sender: 'Frontend',\n            },\n          },\n          {\n            instruction: 'removeSingleOfType',\n            item: {\n              id: uuidv4(),\n              type: 'newChatRequest',\n            },\n          },\n        ]);\n      } else {\n        setIsWaitingUserInput(false);\n        alterConversation([\n          {\n            instruction: 'add',\n            item: {\n              id: uuidv4(),\n              text: 'No',\n              sender: 'User',\n            },\n          },\n          {\n            instruction: 'add',\n            item: {\n              id: uuidv4(),\n              text: 'Ok, is there anything else I can help you with?',\n              sender: 'Frontend',\n            },\n          },\n          {\n            instruction: 'removeSingleOfType',\n            item: {\n              id: uuidv4(),\n              type: 'newChatRequest',\n            },\n          },\n        ]);\n      }\n    },\n    [greeting],\n  );\n\n  const handleOnRateChat = useCallback(\n    async (positiveRating: boolean) => {\n      if (dxpAiClient.current && callbackStateRef.current.threadId && !isProcessingRating) {\n        setIsProcessingRating(true);\n        setRating(positiveRating);\n        updateThreadSessionState({ rating: positiveRating });\n        if (positiveRating) {\n          await dxpAiClient.current.chatbot.rate(aiId, callbackStateRef.current.threadId, { rating: 'positive' });\n        } else {\n          await dxpAiClient.current.chatbot.rate(aiId, callbackStateRef.current.threadId, { rating: 'negative' });\n        }\n        if (threadStartDate === callbackStateRef.current.threadStartDate) {\n          setIsProcessingRating(false);\n        }\n      } else {\n        if (isProcessingRating) {\n          throw new Error('Previous rating is still processing');\n        } else {\n          throw new Error('Thread has not been started');\n        }\n      }\n    },\n    [aiId, threadStartDate, isProcessingRating],\n  );\n\n  return (\n    <ChatContext.Provider\n      value={{\n        rating,\n        isProcessingRating,\n        isWaitingResponse,\n        isWaitingUserInput,\n        conversation,\n        onNewChatRequest: handleOnNewChatRequest,\n        onNewChatConfirm: handleOnNewChatConfirm,\n        onRateChat: handleOnRateChat,\n        onSend: handleOnSend,\n      }}\n    >\n      {children}\n    </ChatContext.Provider>\n  );\n};\n"]} |
{ | ||
"name": "@squiz/chat-ui", | ||
"version": "1.2.2", | ||
"version": "1.3.0", | ||
"main": "dist/index.js", | ||
@@ -5,0 +5,0 @@ "types": "dist/index.d.ts", |
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
688819
7260