From 240c03c60796a2174cb1354d819ded273a0d1c2e Mon Sep 17 00:00:00 2001 From: nzambello Date: Thu, 29 Aug 2024 11:24:05 +0300 Subject: [PATCH] feat: add enableAudio prop, read also from config --- README.md | 1 + src/components/Header/Header.stories.tsx | 14 ++++ src/components/Header/Header.test.tsx | 22 +++++ src/components/Header/Header.tsx | 4 +- .../Header/__snapshots__/Header.test.tsx.snap | 80 ++++++++++++++++--- .../MemoriWidget/MemoriWidget.stories.tsx | 16 ++++ src/components/MemoriWidget/MemoriWidget.tsx | 13 ++- src/index.tsx | 4 + 8 files changed, 140 insertions(+), 14 deletions(-) diff --git a/README.md b/README.md index 13bf4511..444b27f8 100644 --- a/README.md +++ b/README.md @@ -85,6 +85,7 @@ const App = () => ( | `multilingual` | | `bool` | `false` | Enable multilingual mode, if enabled the user can switch between spoken languages | | `spokenLang` | | `string` | | Language of the spoken text, as defaults to user selection. Example: "en" or "it" | | `onStateChange` | | `function` | | Callback function called when the state of the Memori changes | +| `enableAudio` | | `boolean` | `true` | Enable audio output. Defaults to true if otherwise indicated by props or integration config. | | `defaultSpeakerActive` | | `boolean` | `true` | Default value for the speaker activation | | `disableTextEnteredEvents` | | `boolean` | `false` | Disable MemoriTextEntered events listeners for `typeMessage` functions, useful to avoid issues with multiple widgets in page. | | `AZURE_COGNITIVE_SERVICES_TTS_KEY` | | `string` | | Azure Cognitive Services TTS key, used to generate the audio of the Memori and for STT recognition | diff --git a/src/components/Header/Header.stories.tsx b/src/components/Header/Header.stories.tsx index 60def34f..7d6f03cb 100644 --- a/src/components/Header/Header.stories.tsx +++ b/src/components/Header/Header.stories.tsx @@ -123,6 +123,20 @@ SpeakerMuted.args = { showSettings: false, }; +export const WithoutAudio = Template.bind({}); +WithoutAudio.args = { + memori, + history, + setShowPositionDrawer: () => {}, + setShowSettingsDrawer: () => {}, + clearHistory: () => {}, + speakerMuted: true, + enableAudio: false, + hasUserActivatedSpeak: false, + showShare: false, + showSettings: false, +}; + export const WithShare = Template.bind({}); WithShare.args = { memori, diff --git a/src/components/Header/Header.test.tsx b/src/components/Header/Header.test.tsx index 104e9a33..0ee7a9e6 100644 --- a/src/components/Header/Header.test.tsx +++ b/src/components/Header/Header.test.tsx @@ -74,6 +74,28 @@ it('renders Header with speaker muted unchanged', () => { expect(container).toMatchSnapshot(); }); +it('renders Header with audio disabled unchanged', () => { + const { container } = render( +
+ ); + expect(container).toMatchSnapshot(); +}); + it('renders Header with share button unchanged', () => { const { container } = render(
void; setShowKnownFactsDrawer: (show: boolean) => void; setShowExpertsDrawer: (show: boolean) => void; + enableAudio?: boolean; speakerMuted: boolean; setSpeakerMuted: (mute: boolean) => void; hasUserActivatedSpeak?: boolean; @@ -59,6 +60,7 @@ const Header: React.FC = ({ setShowSettingsDrawer, setShowKnownFactsDrawer, setShowExpertsDrawer, + enableAudio = true, speakerMuted, setSpeakerMuted, hasUserActivatedSpeak = false, @@ -168,7 +170,7 @@ const Header: React.FC = ({ title={t('widget.showExpertsInTheBoard') || 'Experts in this board'} /> )} - {showSpeaker && ( + {enableAudio && showSpeaker && ( + + + + +`; + exports[`renders Header with clear button unchanged 1`] = `