@patternfly/chatbot 2.1.0-prerelease.23 → 2.1.0-prerelease.25
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/MessageBar/MessageBar.d.ts +1 -0
- package/dist/cjs/MessageBar/MessageBar.js +4 -3
- package/dist/cjs/MessageBar/MicrophoneButton.d.ts +2 -0
- package/dist/cjs/MessageBar/MicrophoneButton.js +4 -2
- package/dist/css/main.css +1 -0
- package/dist/css/main.css.map +1 -1
- package/dist/esm/MessageBar/MessageBar.d.ts +1 -0
- package/dist/esm/MessageBar/MessageBar.js +4 -3
- package/dist/esm/MessageBar/MicrophoneButton.d.ts +2 -0
- package/dist/esm/MessageBar/MicrophoneButton.js +4 -2
- package/package.json +1 -1
- package/patternfly-docs/content/extensions/chatbot/design-guidelines.md +216 -0
- package/patternfly-docs/content/extensions/chatbot/examples/UI/ChatbotMessageBarLanguage.tsx +17 -0
- package/patternfly-docs/content/extensions/chatbot/examples/UI/UI.md +10 -0
- package/patternfly-docs/content/extensions/chatbot/images.css +6 -0
- package/patternfly-docs/content/extensions/chatbot/img/attached-file.svg +46 -0
- package/patternfly-docs/content/extensions/chatbot/img/attachment-error.svg +12 -0
- package/patternfly-docs/content/extensions/chatbot/img/attachment-menu.svg +150 -0
- package/patternfly-docs/content/extensions/chatbot/img/attachment-unsent.svg +88 -0
- package/patternfly-docs/content/extensions/chatbot/img/chatbot-elements.svg +136 -0
- package/patternfly-docs/content/extensions/chatbot/img/chatbot-toggle-notification.svg +8 -0
- package/patternfly-docs/content/extensions/chatbot/img/chatbot-toggle.svg +10 -0
- package/patternfly-docs/content/extensions/chatbot/img/conversation-history.svg +154 -0
- package/patternfly-docs/content/extensions/chatbot/img/display-menu.svg +82 -0
- package/patternfly-docs/content/extensions/chatbot/img/docked.svg +350 -0
- package/patternfly-docs/content/extensions/chatbot/img/embedded.svg +156 -0
- package/patternfly-docs/content/extensions/chatbot/img/footnote.svg +75 -0
- package/patternfly-docs/content/extensions/chatbot/img/fullscreen.svg +109 -0
- package/patternfly-docs/content/extensions/chatbot/img/listening.svg +65 -0
- package/patternfly-docs/content/extensions/chatbot/img/message-bar-elements.svg +23 -0
- package/patternfly-docs/content/extensions/chatbot/img/message-elements.svg +162 -0
- package/patternfly-docs/content/extensions/chatbot/img/overlay.svg +276 -0
- package/patternfly-docs/content/extensions/chatbot/img/stop-button.svg +64 -0
- package/src/MessageBar/MessageBar.scss +1 -0
- package/src/MessageBar/MessageBar.tsx +3 -0
- package/src/MessageBar/MicrophoneButton.tsx +6 -1
@@ -58,6 +58,7 @@ export interface MessageBarProps {
|
|
58
58
|
send?: { tooltipContent?: string; props?: ButtonProps };
|
59
59
|
microphone?: {
|
60
60
|
tooltipContent?: { active?: string; inactive?: string };
|
61
|
+
language?: string;
|
61
62
|
props?: ButtonProps;
|
62
63
|
};
|
63
64
|
};
|
@@ -146,6 +147,7 @@ export const MessageBar: React.FunctionComponent<MessageBarProps> = ({
|
|
146
147
|
textarea.focus();
|
147
148
|
textarea.textContent = DOMPurify.sanitize(message);
|
148
149
|
}
|
150
|
+
onChange && onChange({} as React.ChangeEvent<HTMLDivElement>, message);
|
149
151
|
};
|
150
152
|
|
151
153
|
const renderButtons = () => {
|
@@ -184,6 +186,7 @@ export const MessageBar: React.FunctionComponent<MessageBarProps> = ({
|
|
184
186
|
onIsListeningChange={setIsListeningMessage}
|
185
187
|
onSpeechRecognition={handleSpeechRecognition}
|
186
188
|
tooltipContent={buttonProps?.microphone?.tooltipContent}
|
189
|
+
language={buttonProps?.microphone?.language}
|
187
190
|
{...buttonProps?.microphone?.props}
|
188
191
|
/>
|
189
192
|
)}
|
@@ -22,6 +22,8 @@ export interface MicrophoneButtonProps extends ButtonProps {
|
|
22
22
|
tooltipProps?: TooltipProps;
|
23
23
|
/** English text "Use microphone" and "Stop listening" used in the tooltip */
|
24
24
|
tooltipContent?: { active?: string; inactive?: string };
|
25
|
+
/** Locale code for language speech recognition is conducted in. This should be in the format 'en-US', a.k.a. the ISO 639-1 code, a dash, and the ISO_3166-1 code. */
|
26
|
+
language?: string;
|
25
27
|
}
|
26
28
|
|
27
29
|
export const MicrophoneButton: React.FunctionComponent<MicrophoneButtonProps> = ({
|
@@ -31,6 +33,7 @@ export const MicrophoneButton: React.FunctionComponent<MicrophoneButtonProps> =
|
|
31
33
|
className,
|
32
34
|
tooltipProps,
|
33
35
|
tooltipContent = { active: 'Stop listening', inactive: 'Use microphone' },
|
36
|
+
language = 'en-US',
|
34
37
|
...props
|
35
38
|
}: MicrophoneButtonProps) => {
|
36
39
|
// Microphone
|
@@ -60,12 +63,14 @@ export const MicrophoneButton: React.FunctionComponent<MicrophoneButtonProps> =
|
|
60
63
|
const recognition: SpeechRecognition = new (window.SpeechRecognition || window.webkitSpeechRecognition)();
|
61
64
|
recognition.continuous = false;
|
62
65
|
recognition.interimResults = false;
|
63
|
-
recognition.lang =
|
66
|
+
recognition.lang = language;
|
64
67
|
|
65
68
|
recognition.onresult = (event) => {
|
66
69
|
const result = event.results[0][0].transcript;
|
67
70
|
onSpeechRecognition(result);
|
68
71
|
recognition.stop();
|
72
|
+
// turn button off
|
73
|
+
onIsListeningChange(false);
|
69
74
|
};
|
70
75
|
|
71
76
|
recognition.onerror = (event) => {
|