botframework-webchat 4.15.5-main.20220927.f9dd67a → 4.15.5-main.20221005.d4c4aad

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/lib/addVersion.js CHANGED
@@ -28,7 +28,7 @@ function setMetaTag(name, content) {
28
28
 
29
29
  function addVersion(variant) {
30
30
  setMetaTag('botframework-webchat:bundle:variant', variant);
31
- setMetaTag('botframework-webchat:bundle:version', "4.15.5-main.20220927.f9dd67a");
31
+ setMetaTag('botframework-webchat:bundle:version', "4.15.5-main.20221005.d4c4aad");
32
32
  setMetaTag('botframework-webchat:core:version', _botframeworkWebchatCore.version);
33
33
  setMetaTag('botframework-webchat:ui:version', _botframeworkWebchatComponent.version);
34
34
  }
@@ -1 +1 @@
1
- {"version":3,"file":"createMicrophoneAudioConfigAndAudioContext.d.ts","sourceRoot":"","sources":["../../src/speech/createMicrophoneAudioConfigAndAudioContext.ts"],"names":[],"mappings":"AA6HA,MAAM,CAAC,OAAO,UAAU,0CAA0C,CAAC,EACjE,YAAY,EACZ,kBAAkB,EAClB,eAAe,EAChB,EAAE;IACD,YAAY,CAAC,EAAE,YAAY,CAAC;IAC5B,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,eAAe,CAAC,EAAE,IAAI,CAAC;CACxB;;;EAcA"}
1
+ {"version":3,"file":"createMicrophoneAudioConfigAndAudioContext.d.ts","sourceRoot":"","sources":["../../src/speech/createMicrophoneAudioConfigAndAudioContext.ts"],"names":[],"mappings":"AA6HA,MAAM,CAAC,OAAO,UAAU,0CAA0C,CAAC,EACjE,YAAY,EACZ,kBAAkB,EAClB,eAAe,EAChB,EAAE;IACD,YAAY,CAAC,EAAE,YAAY,CAAC;IAC5B,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,eAAe,CAAC,EAAE,IAAI,CAAC;CACxB;;;EAiBA"}
@@ -51,7 +51,7 @@ function createMicrophoneAudioConfig(options) {
51
51
  enableTelemetry = options.enableTelemetry,
52
52
  pcmRecorderWorkletUrl = options.pcmRecorderWorkletUrl;
53
53
  var bufferDurationInMS = options.bufferDurationInMS || DEFAULT_BUFFER_DURATION_IN_MS;
54
- var pcmRecorder = new _Exports2.PcmRecorder();
54
+ var pcmRecorder = new _Exports2.PcmRecorder(true);
55
55
  pcmRecorderWorkletUrl && pcmRecorder.setWorkletUrl(pcmRecorderWorkletUrl);
56
56
  return (0, _createAudioConfig.default)({
57
57
  attach: function attach(audioNodeId) {
@@ -143,6 +143,9 @@ function createMicrophoneAudioConfigAndAudioContext(_ref) {
143
143
  // Web Chat has an implementation of AudioConfig for microphone that would enable better support on Safari:
144
144
  // - Maintain same instance of `AudioContext` across recognitions;
145
145
  // - Resume suspended `AudioContext` on user gestures.
146
+ //
147
+ // This is filed as https://github.com/microsoft/cognitive-services-speech-sdk-js/issues/571.
148
+ // Before Speech SDK team take our suggestion, we need to continue using a custom AudioConfig object to persist the blessing.
146
149
  audioContext || (audioContext = (0, _createAudioContext.default)());
147
150
  return {
148
151
  audioConfig: createMicrophoneAudioConfig({
@@ -155,4 +158,4 @@ function createMicrophoneAudioConfigAndAudioContext(_ref) {
155
158
  audioContext: audioContext
156
159
  };
157
160
  }
158
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["DEFAULT_BUFFER_DURATION_IN_MS","PCM_RECORDER_HARDCODED_SETTINGS","Object","freeze","channelCount","sampleRate","sampleSize","PCM_RECORDER_HARDCODED_FORMAT","bitsPerSample","channels","samplesPerSec","createMicrophoneAudioConfig","options","audioConstraints","audioContext","debug","enableTelemetry","pcmRecorderWorkletUrl","bufferDurationInMS","pcmRecorder","PcmRecorder","setWorkletUrl","createAudioConfig","attach","audioNodeId","getUserMedia","audio","video","mediaStream","getAudioTracks","firstAudioTrack","Error","outputStream","ChunkedArrayBufferStream","bytesPerSample","record","audioStreamNode","detach","readEnded","close","releaseMediaResources","getTracks","forEach","track","removeTrack","id","read","deviceInfo","manufacturer","model","label","type","format","createMicrophoneAudioConfigAndAudioContext","audioInputDeviceId","createAudioContext","audioConfig","deviceId","undefined"],"sourceRoot":"bundle:///","sources":["../../src/speech/createMicrophoneAudioConfigAndAudioContext.ts"],"sourcesContent":["import { ChunkedArrayBufferStream } from 'microsoft-cognitiveservices-speech-sdk/distrib/lib/src/common/Exports';\nimport { PcmRecorder } from 'microsoft-cognitiveservices-speech-sdk/distrib/lib/src/common.browser/Exports';\n\nimport { AudioStreamNode, DeviceInfo, Format } from './CustomAudioInputStream';\nimport bytesPerSample from './bytesPerSample';\nimport createAudioConfig from './createAudioConfig';\nimport createAudioContext from './createAudioContext';\nimport getUserMedia from './getUserMedia';\n\n// This is how often we are flushing audio buffer to the network. Modify this value will affect latency.\nconst DEFAULT_BUFFER_DURATION_IN_MS = 100;\n\n// TODO: [P2] #3975 We should consider building our own PcmRecorder:\n//       - Use Audio Worklet via blob URL\n//       - Not hardcoding the sample rate or other values\n// PcmRecorder always downscale to 16000 Hz. We cannot use the dynamic value from MediaConstraints or MediaTrackSettings.\nconst PCM_RECORDER_HARDCODED_SETTINGS: MediaTrackSettings = Object.freeze({\n  channelCount: 1,\n  sampleRate: 16000,\n  sampleSize: 16\n});\n\nconst PCM_RECORDER_HARDCODED_FORMAT: Format = Object.freeze({\n  bitsPerSample: PCM_RECORDER_HARDCODED_SETTINGS.sampleSize,\n  // `channelCount` is not on @types/web@0.0.54 yet, related to https://github.com/microsoft/TypeScript-DOM-lib-generator/issues/1290.\n  // @ts-ignore\n  channels: PCM_RECORDER_HARDCODED_SETTINGS.channelCount,\n  samplesPerSec: PCM_RECORDER_HARDCODED_SETTINGS.sampleRate\n});\n\ntype MicrophoneAudioInputStreamOptions = {\n  /** Specifies the constraints for selecting an audio device. */\n  audioConstraints?: true | MediaTrackConstraints;\n\n  /** Specifies the `AudioContext` to use. This object must be primed and ready to use. */\n  audioContext: AudioContext;\n\n  /** Specifies the buffering delay on how often to flush audio data to network. Increasing the value will increase audio latency. Default is 100 ms. */\n  bufferDurationInMS?: number;\n\n  /** Specifies whether to display diagnostic information. */\n  debug?: true;\n\n  /** Specifies if telemetry data should be sent. If not specified, telemetry data will NOT be sent. */\n  enableTelemetry?: true;\n\n  /** Specifies the `AudioWorklet` URL for `PcmRecorder`. If not specified, will use script processor on UI thread instead. */\n  pcmRecorderWorkletUrl?: string;\n};\n\nfunction createMicrophoneAudioConfig(options: MicrophoneAudioInputStreamOptions) {\n  const { audioConstraints, audioContext, debug, enableTelemetry, pcmRecorderWorkletUrl } = options;\n  const bufferDurationInMS = options.bufferDurationInMS || DEFAULT_BUFFER_DURATION_IN_MS;\n\n  const pcmRecorder = new PcmRecorder();\n\n  pcmRecorderWorkletUrl && pcmRecorder.setWorkletUrl(pcmRecorderWorkletUrl);\n\n  return createAudioConfig({\n    async attach(audioNodeId: string): Promise<{\n      audioStreamNode: AudioStreamNode;\n      deviceInfo: DeviceInfo;\n      format: Format;\n    }> {\n      // We need to get new MediaStream on every attach().\n      // This is because PcmRecorder.releaseMediaResources() disconnected/stopped them.\n      const mediaStream = await getUserMedia({ audio: audioConstraints, video: false });\n\n      const [firstAudioTrack] = mediaStream.getAudioTracks();\n\n      if (!firstAudioTrack) {\n        throw new Error('No audio device is found.');\n      }\n\n      const outputStream = new ChunkedArrayBufferStream(\n        // Speech SDK quirks: PcmRecorder hardcoded sample rate of 16000 Hz.\n        bytesPerSample(PCM_RECORDER_HARDCODED_SETTINGS) *\n          // eslint-disable-next-line no-magic-numbers\n          ((bufferDurationInMS || DEFAULT_BUFFER_DURATION_IN_MS) / 1000),\n        audioNodeId\n      );\n\n      pcmRecorder.record(audioContext, mediaStream, outputStream);\n\n      return {\n        audioStreamNode: {\n          // Speech SDK quirks: In SDK's original MicAudioSource implementation, it call turnOff() during detach().\n          //                    That means, it call turnOff(), then detach(), then turnOff() again. Seems redundant.\n          //                    When using with Direct Line Speech, turnOff() is never called.\n          detach: (): Promise<void> => {\n            // Speech SDK quirks: In SDK, it call outputStream.close() in turnOff() before outputStream.readEnded() in detach().\n            //                    I think it make sense to call readEnded() before close().\n            outputStream.readEnded();\n            outputStream.close();\n\n            // PcmRecorder.releaseMediaResources() will disconnect/stop the MediaStream.\n            // We cannot use MediaStream again after turned off.\n            pcmRecorder.releaseMediaResources(audioContext);\n\n            // MediaStream will become inactive after all tracks are removed.\n            mediaStream.getTracks().forEach(track => mediaStream.removeTrack(track));\n\n            // ESLint: \"return\" is required by TypeScript\n            // eslint-disable-next-line no-useless-return\n            return;\n          },\n          id: () => audioNodeId,\n          read: () => outputStream.read()\n        },\n        deviceInfo: {\n          manufacturer: 'Bot Framework Web Chat',\n          model: enableTelemetry ? firstAudioTrack.label : '',\n          type: enableTelemetry ? 'Microphones' : 'Unknown'\n        },\n        // Speech SDK quirks: PcmRecorder hardcoded sample rate of 16000 Hz.\n        //                    We cannot obtain this number other than looking at their source code.\n        //                    I.e. no getter property.\n        // PcmRecorder always downscale to 16000 Hz. We cannot use the dynamic value from MediaConstraints or MediaTrackSettings.\n        format: PCM_RECORDER_HARDCODED_FORMAT\n      };\n    },\n    debug\n  });\n}\n\nexport default function createMicrophoneAudioConfigAndAudioContext({\n  audioContext,\n  audioInputDeviceId,\n  enableTelemetry\n}: {\n  audioContext?: AudioContext;\n  audioInputDeviceId?: string;\n  enableTelemetry?: true;\n}) {\n  // Web Chat has an implementation of AudioConfig for microphone that would enable better support on Safari:\n  // - Maintain same instance of `AudioContext` across recognitions;\n  // - Resume suspended `AudioContext` on user gestures.\n  audioContext || (audioContext = createAudioContext());\n\n  return {\n    audioConfig: createMicrophoneAudioConfig({\n      audioConstraints: audioInputDeviceId ? { deviceId: audioInputDeviceId } : true,\n      audioContext,\n      enableTelemetry: enableTelemetry ? true : undefined\n    }),\n    audioContext\n  };\n}\n"],"mappings":"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"}
161
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["DEFAULT_BUFFER_DURATION_IN_MS","PCM_RECORDER_HARDCODED_SETTINGS","Object","freeze","channelCount","sampleRate","sampleSize","PCM_RECORDER_HARDCODED_FORMAT","bitsPerSample","channels","samplesPerSec","createMicrophoneAudioConfig","options","audioConstraints","audioContext","debug","enableTelemetry","pcmRecorderWorkletUrl","bufferDurationInMS","pcmRecorder","PcmRecorder","setWorkletUrl","createAudioConfig","attach","audioNodeId","getUserMedia","audio","video","mediaStream","getAudioTracks","firstAudioTrack","Error","outputStream","ChunkedArrayBufferStream","bytesPerSample","record","audioStreamNode","detach","readEnded","close","releaseMediaResources","getTracks","forEach","track","removeTrack","id","read","deviceInfo","manufacturer","model","label","type","format","createMicrophoneAudioConfigAndAudioContext","audioInputDeviceId","createAudioContext","audioConfig","deviceId","undefined"],"sourceRoot":"bundle:///","sources":["../../src/speech/createMicrophoneAudioConfigAndAudioContext.ts"],"sourcesContent":["import { ChunkedArrayBufferStream } from 'microsoft-cognitiveservices-speech-sdk/distrib/lib/src/common/Exports';\nimport { PcmRecorder } from 'microsoft-cognitiveservices-speech-sdk/distrib/lib/src/common.browser/Exports';\n\nimport { AudioStreamNode, DeviceInfo, Format } from './CustomAudioInputStream';\nimport bytesPerSample from './bytesPerSample';\nimport createAudioConfig from './createAudioConfig';\nimport createAudioContext from './createAudioContext';\nimport getUserMedia from './getUserMedia';\n\n// This is how often we are flushing audio buffer to the network. Modify this value will affect latency.\nconst DEFAULT_BUFFER_DURATION_IN_MS = 100;\n\n// TODO: [P2] #3975 We should consider building our own PcmRecorder:\n//       - Use Audio Worklet via blob URL\n//       - Not hardcoding the sample rate or other values\n// PcmRecorder always downscale to 16000 Hz. We cannot use the dynamic value from MediaConstraints or MediaTrackSettings.\nconst PCM_RECORDER_HARDCODED_SETTINGS: MediaTrackSettings = Object.freeze({\n  channelCount: 1,\n  sampleRate: 16000,\n  sampleSize: 16\n});\n\nconst PCM_RECORDER_HARDCODED_FORMAT: Format = Object.freeze({\n  bitsPerSample: PCM_RECORDER_HARDCODED_SETTINGS.sampleSize,\n  // `channelCount` is not on @types/web@0.0.54 yet, related to https://github.com/microsoft/TypeScript-DOM-lib-generator/issues/1290.\n  // @ts-ignore\n  channels: PCM_RECORDER_HARDCODED_SETTINGS.channelCount,\n  samplesPerSec: PCM_RECORDER_HARDCODED_SETTINGS.sampleRate\n});\n\ntype MicrophoneAudioInputStreamOptions = {\n  /** Specifies the constraints for selecting an audio device. */\n  audioConstraints?: true | MediaTrackConstraints;\n\n  /** Specifies the `AudioContext` to use. This object must be primed and ready to use. */\n  audioContext: AudioContext;\n\n  /** Specifies the buffering delay on how often to flush audio data to network. Increasing the value will increase audio latency. Default is 100 ms. */\n  bufferDurationInMS?: number;\n\n  /** Specifies whether to display diagnostic information. */\n  debug?: true;\n\n  /** Specifies if telemetry data should be sent. If not specified, telemetry data will NOT be sent. */\n  enableTelemetry?: true;\n\n  /** Specifies the `AudioWorklet` URL for `PcmRecorder`. If not specified, will use script processor on UI thread instead. */\n  pcmRecorderWorkletUrl?: string;\n};\n\nfunction createMicrophoneAudioConfig(options: MicrophoneAudioInputStreamOptions) {\n  const { audioConstraints, audioContext, debug, enableTelemetry, pcmRecorderWorkletUrl } = options;\n  const bufferDurationInMS = options.bufferDurationInMS || DEFAULT_BUFFER_DURATION_IN_MS;\n\n  const pcmRecorder = new PcmRecorder(true);\n\n  pcmRecorderWorkletUrl && pcmRecorder.setWorkletUrl(pcmRecorderWorkletUrl);\n\n  return createAudioConfig({\n    async attach(audioNodeId: string): Promise<{\n      audioStreamNode: AudioStreamNode;\n      deviceInfo: DeviceInfo;\n      format: Format;\n    }> {\n      // We need to get new MediaStream on every attach().\n      // This is because PcmRecorder.releaseMediaResources() disconnected/stopped them.\n      const mediaStream = await getUserMedia({ audio: audioConstraints, video: false });\n\n      const [firstAudioTrack] = mediaStream.getAudioTracks();\n\n      if (!firstAudioTrack) {\n        throw new Error('No audio device is found.');\n      }\n\n      const outputStream = new ChunkedArrayBufferStream(\n        // Speech SDK quirks: PcmRecorder hardcoded sample rate of 16000 Hz.\n        bytesPerSample(PCM_RECORDER_HARDCODED_SETTINGS) *\n          // eslint-disable-next-line no-magic-numbers\n          ((bufferDurationInMS || DEFAULT_BUFFER_DURATION_IN_MS) / 1000),\n        audioNodeId\n      );\n\n      pcmRecorder.record(audioContext, mediaStream, outputStream);\n\n      return {\n        audioStreamNode: {\n          // Speech SDK quirks: In SDK's original MicAudioSource implementation, it call turnOff() during detach().\n          //                    That means, it call turnOff(), then detach(), then turnOff() again. Seems redundant.\n          //                    When using with Direct Line Speech, turnOff() is never called.\n          detach: (): Promise<void> => {\n            // Speech SDK quirks: In SDK, it call outputStream.close() in turnOff() before outputStream.readEnded() in detach().\n            //                    I think it make sense to call readEnded() before close().\n            outputStream.readEnded();\n            outputStream.close();\n\n            // PcmRecorder.releaseMediaResources() will disconnect/stop the MediaStream.\n            // We cannot use MediaStream again after turned off.\n            pcmRecorder.releaseMediaResources(audioContext);\n\n            // MediaStream will become inactive after all tracks are removed.\n            mediaStream.getTracks().forEach(track => mediaStream.removeTrack(track));\n\n            // ESLint: \"return\" is required by TypeScript\n            // eslint-disable-next-line no-useless-return\n            return;\n          },\n          id: () => audioNodeId,\n          read: () => outputStream.read()\n        },\n        deviceInfo: {\n          manufacturer: 'Bot Framework Web Chat',\n          model: enableTelemetry ? firstAudioTrack.label : '',\n          type: enableTelemetry ? 'Microphones' : 'Unknown'\n        },\n        // Speech SDK quirks: PcmRecorder hardcoded sample rate of 16000 Hz.\n        //                    We cannot obtain this number other than looking at their source code.\n        //                    I.e. no getter property.\n        // PcmRecorder always downscale to 16000 Hz. We cannot use the dynamic value from MediaConstraints or MediaTrackSettings.\n        format: PCM_RECORDER_HARDCODED_FORMAT\n      };\n    },\n    debug\n  });\n}\n\nexport default function createMicrophoneAudioConfigAndAudioContext({\n  audioContext,\n  audioInputDeviceId,\n  enableTelemetry\n}: {\n  audioContext?: AudioContext;\n  audioInputDeviceId?: string;\n  enableTelemetry?: true;\n}) {\n  // Web Chat has an implementation of AudioConfig for microphone that would enable better support on Safari:\n  // - Maintain same instance of `AudioContext` across recognitions;\n  // - Resume suspended `AudioContext` on user gestures.\n  //\n  // This is filed as https://github.com/microsoft/cognitive-services-speech-sdk-js/issues/571.\n  // Before Speech SDK team take our suggestion, we need to continue using a custom AudioConfig object to persist the blessing.\n  audioContext || (audioContext = createAudioContext());\n\n  return {\n    audioConfig: createMicrophoneAudioConfig({\n      audioConstraints: audioInputDeviceId ? { deviceId: audioInputDeviceId } : true,\n      audioContext,\n      enableTelemetry: enableTelemetry ? true : undefined\n    }),\n    audioContext\n  };\n}\n"],"mappings":";;;;;;;;;;;;;;;AAAA;;AACA;;AAGA;;AACA;;AACA;;AACA;;AAEA;AACA,IAAMA,6BAA6B,GAAG,GAAtC,C,CAEA;AACA;AACA;AACA;;AACA,IAAMC,+BAAmD,GAAGC,MAAM,CAACC,MAAP,CAAc;EACxEC,YAAY,EAAE,CAD0D;EAExEC,UAAU,EAAE,KAF4D;EAGxEC,UAAU,EAAE;AAH4D,CAAd,CAA5D;AAMA,IAAMC,6BAAqC,GAAGL,MAAM,CAACC,MAAP,CAAc;EAC1DK,aAAa,EAAEP,+BAA+B,CAACK,UADW;EAE1D;EACA;EACAG,QAAQ,EAAER,+BAA+B,CAACG,YAJgB;EAK1DM,aAAa,EAAET,+BAA+B,CAACI;AALW,CAAd,CAA9C;;AA4BA,SAASM,2BAAT,CAAqCC,OAArC,EAAiF;EAC/E,IAAQC,gBAAR,GAA0FD,OAA1F,CAAQC,gBAAR;EAAA,IAA0BC,YAA1B,GAA0FF,OAA1F,CAA0BE,YAA1B;EAAA,IAAwCC,KAAxC,GAA0FH,OAA1F,CAAwCG,KAAxC;EAAA,IAA+CC,eAA/C,GAA0FJ,OAA1F,CAA+CI,eAA/C;EAAA,IAAgEC,qBAAhE,GAA0FL,OAA1F,CAAgEK,qBAAhE;EACA,IAAMC,kBAAkB,GAAGN,OAAO,CAACM,kBAAR,IAA8BlB,6BAAzD;EAEA,IAAMmB,WAAW,GAAG,IAAIC,qBAAJ,CAAgB,IAAhB,CAApB;EAEAH,qBAAqB,IAAIE,WAAW,CAACE,aAAZ,CAA0BJ,qBAA1B,CAAzB;EAEA,OAAO,IAAAK,0BAAA,EAAkB;IACjBC,MADiB,kBACVC,WADU,EAKpB;MAAA;QAAA;;QAAA;UAAA;YAAA;cAAA;gBAAA;gBAAA,OAGyB,IAAAC,qBAAA,EAAa;kBAAEC,KAAK,EAAEb,gBAAT;kBAA2Bc,KAAK,EAAE;gBAAlC,CAAb,CAHzB;;cAAA;gBAGKC,WAHL;gBAAA,wBAKyBA,WAAW,CAACC,cAAZ,EALzB,mFAKMC,eALN;;gBAAA,IAOIA,eAPJ;kBAAA;kBAAA;gBAAA;;gBAAA,MAQO,IAAIC,KAAJ,CAAU,2BAAV,CARP;;cAAA;gBAWKC,YAXL,GAWoB,IAAIC,iCAAJ,EACnB;gBACA,IAAAC,uBAAA,EAAejC,+BAAf,MACE;gBACC,CAACiB,kBAAkB,IAAIlB,6BAAvB,IAAwD,IAF3D,CAFmB,EAKnBwB,WALmB,CAXpB;gBAmBDL,WAAW,CAACgB,MAAZ,CAAmBrB,YAAnB,EAAiCc,WAAjC,EAA8CI,YAA9C;gBAnBC,iCAqBM;kBACLI,eAAe,EAAE;oBACf;oBACA;oBACA;oBACAC,MAAM,EAAE,kBAAqB;sBAC3B;sBACA;sBACAL,YAAY,CAACM,SAAb;sBACAN,YAAY,CAACO,KAAb,GAJ2B,CAM3B;sBACA;;sBACApB,WAAW,CAACqB,qBAAZ,CAAkC1B,YAAlC,EAR2B,CAU3B;;sBACAc,WAAW,CAACa,SAAZ,GAAwBC,OAAxB,CAAgC,UAAAC,KAAK;wBAAA,OAAIf,WAAW,CAACgB,WAAZ,CAAwBD,KAAxB,CAAJ;sBAAA,CAArC,EAX2B,CAa3B;sBACA;;sBACA;oBACD,CApBc;oBAqBfE,EAAE,EAAE;sBAAA,OAAMrB,WAAN;oBAAA,CArBW;oBAsBfsB,IAAI,EAAE;sBAAA,OAAMd,YAAY,CAACc,IAAb,EAAN;oBAAA;kBAtBS,CADZ;kBAyBLC,UAAU,EAAE;oBACVC,YAAY,EAAE,wBADJ;oBAEVC,KAAK,EAAEjC,eAAe,GAAGc,eAAe,CAACoB,KAAnB,GAA2B,EAFvC;oBAGVC,IAAI,EAAEnC,eAAe,GAAG,aAAH,GAAmB;kBAH9B,CAzBP;kBA8BL;kBACA;kBACA;kBACA;kBACAoC,MAAM,EAAE7C;gBAlCH,CArBN;;cAAA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA;IAyDF,CA9DsB;IA+DvBQ,KAAK,EAALA;EA/DuB,CAAlB,CAAP;AAiED;;AAEc,SAASsC,0CAAT,OAQZ;EAAA,IAPDvC,YAOC,QAPDA,YAOC;EAAA,IANDwC,kBAMC,QANDA,kBAMC;EAAA,IALDtC,eAKC,QALDA,eAKC;EACD;EACA;EACA;EACA;EACA;EACA;EACAF,YAAY,KAAKA,YAAY,GAAG,IAAAyC,2BAAA,GAApB,CAAZ;EAEA,OAAO;IACLC,WAAW,EAAE7C,2BAA2B,CAAC;MACvCE,gBAAgB,EAAEyC,kBAAkB,GAAG;QAAEG,QAAQ,EAAEH;MAAZ,CAAH,GAAsC,IADnC;MAEvCxC,YAAY,EAAZA,YAFuC;MAGvCE,eAAe,EAAEA,eAAe,GAAG,IAAH,GAAU0C;IAHH,CAAD,CADnC;IAML5C,YAAY,EAAZA;EANK,CAAP;AAQD"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "botframework-webchat",
3
- "version": "4.15.5-main.20220927.f9dd67a",
3
+ "version": "4.15.5-main.20221005.d4c4aad",
4
4
  "description": "A highly-customizable web-based chat client for Azure Bot Services.",
5
5
  "main": "lib/index.js",
6
6
  "typings": "lib/index.d.ts",
@@ -47,12 +47,12 @@
47
47
  },
48
48
  "dependencies": {
49
49
  "@babel/runtime": "7.19.0",
50
- "adaptivecards": "2.10.0",
50
+ "adaptivecards": "2.11.1",
51
51
  "botframework-directlinejs": "0.15.1",
52
- "botframework-directlinespeech-sdk": "4.15.5-main.20220927.f9dd67a",
53
- "botframework-webchat-api": "4.15.5-main.20220927.f9dd67a",
54
- "botframework-webchat-component": "4.15.5-main.20220927.f9dd67a",
55
- "botframework-webchat-core": "4.15.5-main.20220927.f9dd67a",
52
+ "botframework-directlinespeech-sdk": "4.15.5-main.20221005.d4c4aad",
53
+ "botframework-webchat-api": "4.15.5-main.20221005.d4c4aad",
54
+ "botframework-webchat-component": "4.15.5-main.20221005.d4c4aad",
55
+ "botframework-webchat-core": "4.15.5-main.20221005.d4c4aad",
56
56
  "classnames": "2.3.2",
57
57
  "core-js": "3.25.3",
58
58
  "markdown-it": "13.0.1",
@@ -61,12 +61,12 @@
61
61
  "markdown-it-for-inline": "0.1.1",
62
62
  "math-random": "2.0.1",
63
63
  "memoize-one": "6.0.0",
64
- "microsoft-cognitiveservices-speech-sdk": "1.17.0",
64
+ "microsoft-cognitiveservices-speech-sdk": "1.23.0",
65
65
  "prop-types": "15.8.1",
66
66
  "sanitize-html": "2.7.2",
67
67
  "url-search-params-polyfill": "8.1.1",
68
68
  "uuid": "8.3.2",
69
- "web-speech-cognitive-services": "7.1.1",
69
+ "web-speech-cognitive-services": "7.1.2",
70
70
  "whatwg-fetch": "3.6.2"
71
71
  },
72
72
  "devDependencies": {
@@ -85,8 +85,8 @@
85
85
  "babel-plugin-transform-inline-environment-variables": "^0.4.4",
86
86
  "concurrently": "^7.4.0",
87
87
  "esbuild": "^0.15.9",
88
- "isomorphic-react": "4.15.5-main.20220927.f9dd67a",
89
- "isomorphic-react-dom": "4.15.5-main.20220927.f9dd67a",
88
+ "isomorphic-react": "4.15.5-main.20221005.d4c4aad",
89
+ "isomorphic-react-dom": "4.15.5-main.20221005.d4c4aad",
90
90
  "source-map-loader": "^4.0.0",
91
91
  "terser-webpack-plugin": "^5.3.6",
92
92
  "typescript": "^4.8.3",
@@ -14,6 +14,17 @@ let originalConsole;
14
14
 
15
15
  beforeEach(() => {
16
16
  jest.mock('web-speech-cognitive-services/lib/SpeechServices', () => jest.fn(() => ({})));
17
+ jest.mock('microsoft-cognitiveservices-speech-sdk/distrib/lib/src/common.browser/Exports', () => ({
18
+ ...jest.requireActual('microsoft-cognitiveservices-speech-sdk/distrib/lib/src/common.browser/Exports'),
19
+ PcmRecorder: class MockPcmRecorder {
20
+ // eslint-disable-next-line class-methods-use-this, no-empty-function
21
+ record() {}
22
+ // eslint-disable-next-line class-methods-use-this, no-empty-function
23
+ releaseMediaResources() {}
24
+ // eslint-disable-next-line class-methods-use-this, no-empty-function
25
+ setWorkletUrl() {}
26
+ }
27
+ }));
17
28
 
18
29
  originalConsole = console;
19
30
  consoleWarns = [];
@@ -52,7 +52,7 @@ function createMicrophoneAudioConfig(options: MicrophoneAudioInputStreamOptions)
52
52
  const { audioConstraints, audioContext, debug, enableTelemetry, pcmRecorderWorkletUrl } = options;
53
53
  const bufferDurationInMS = options.bufferDurationInMS || DEFAULT_BUFFER_DURATION_IN_MS;
54
54
 
55
- const pcmRecorder = new PcmRecorder();
55
+ const pcmRecorder = new PcmRecorder(true);
56
56
 
57
57
  pcmRecorderWorkletUrl && pcmRecorder.setWorkletUrl(pcmRecorderWorkletUrl);
58
58
 
@@ -135,6 +135,9 @@ export default function createMicrophoneAudioConfigAndAudioContext({
135
135
  // Web Chat has an implementation of AudioConfig for microphone that would enable better support on Safari:
136
136
  // - Maintain same instance of `AudioContext` across recognitions;
137
137
  // - Resume suspended `AudioContext` on user gestures.
138
+ //
139
+ // This is filed as https://github.com/microsoft/cognitive-services-speech-sdk-js/issues/571.
140
+ // Before Speech SDK team take our suggestion, we need to continue using a custom AudioConfig object to persist the blessing.
138
141
  audioContext || (audioContext = createAudioContext());
139
142
 
140
143
  return {