@easyv/biz-components 0.0.49 → 0.0.50
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/utils/voskBrowserManager/AudioManager/AudioManager.d.ts +1 -1
- package/dist/utils/voskBrowserManager/AudioManager/AudioManager.es.js +10 -7
- package/dist/utils/voskBrowserManager/AudioManager/AudioManager.es.js.map +1 -1
- package/dist/utils/voskBrowserManager/voskBrowserManager.d.ts +5 -1
- package/dist/utils/voskBrowserManager/voskBrowserManager.es.js +37 -6
- package/dist/utils/voskBrowserManager/voskBrowserManager.es.js.map +1 -1
- package/package.json +1 -1
|
@@ -18,11 +18,11 @@ export interface AudiManagerConfig {
|
|
|
18
18
|
export declare class AudioManager {
|
|
19
19
|
workletUrl?: string;
|
|
20
20
|
sampleRate?: SampleRate;
|
|
21
|
-
status: 'init' | 'starting' | 'running' | 'closed';
|
|
22
21
|
audioContext?: AudioContext;
|
|
23
22
|
mediaSource?: MediaStreamAudioSourceNode;
|
|
24
23
|
mediaStream?: MediaStream;
|
|
25
24
|
config: AudiManagerConfig;
|
|
25
|
+
status: 'init' | 'starting' | 'started';
|
|
26
26
|
constructor(config: AudiManagerConfig);
|
|
27
27
|
start(): Promise<void>;
|
|
28
28
|
stop(): Promise<void>;
|
|
@@ -13,11 +13,11 @@ class AudioManager {
|
|
|
13
13
|
constructor(config) {
|
|
14
14
|
__publicField(this, "workletUrl");
|
|
15
15
|
__publicField(this, "sampleRate", defaultSampleRate);
|
|
16
|
-
__publicField(this, "status", "init");
|
|
17
16
|
__publicField(this, "audioContext");
|
|
18
17
|
__publicField(this, "mediaSource");
|
|
19
18
|
__publicField(this, "mediaStream");
|
|
20
19
|
__publicField(this, "config", {});
|
|
20
|
+
__publicField(this, "status", "init");
|
|
21
21
|
console.log("audio manager constructor: ====", config);
|
|
22
22
|
const processorStr = config.workletProcessor || defaultWorkletProcessorStr;
|
|
23
23
|
this.workletUrl = generateWorkletUrl(processorStr);
|
|
@@ -25,9 +25,14 @@ class AudioManager {
|
|
|
25
25
|
this.config = config;
|
|
26
26
|
}
|
|
27
27
|
async start() {
|
|
28
|
-
var _a, _b;
|
|
28
|
+
var _a, _b, _c;
|
|
29
29
|
try {
|
|
30
|
-
|
|
30
|
+
console.log(
|
|
31
|
+
"%c 🐶 dog ==== audio manager start:",
|
|
32
|
+
"color: green; font-size: 16px;",
|
|
33
|
+
this.audioContext
|
|
34
|
+
);
|
|
35
|
+
if (((_a = this.audioContext) == null ? void 0 : _a.state) === "running" || this.status === "starting") {
|
|
31
36
|
return;
|
|
32
37
|
}
|
|
33
38
|
this.status = "starting";
|
|
@@ -53,8 +58,8 @@ class AudioManager {
|
|
|
53
58
|
this.audioContext = audioContext;
|
|
54
59
|
this.mediaSource = mediaSource;
|
|
55
60
|
this.mediaStream = mediaStream;
|
|
56
|
-
this.
|
|
57
|
-
|
|
61
|
+
(_c = (_b = this.config).onStart) == null ? void 0 : _c.call(_b);
|
|
62
|
+
this.status = "started";
|
|
58
63
|
} catch (error) {
|
|
59
64
|
console.error("Failed to start recording:", error);
|
|
60
65
|
throw error;
|
|
@@ -62,7 +67,6 @@ class AudioManager {
|
|
|
62
67
|
}
|
|
63
68
|
async stop() {
|
|
64
69
|
var _a, _b, _c;
|
|
65
|
-
this.status = "closed";
|
|
66
70
|
if (((_a = this.audioContext) == null ? void 0 : _a.state) === "running") {
|
|
67
71
|
await this.audioContext.suspend();
|
|
68
72
|
}
|
|
@@ -71,7 +75,6 @@ class AudioManager {
|
|
|
71
75
|
close() {
|
|
72
76
|
var _a, _b, _c;
|
|
73
77
|
(_a = this.mediaSource) == null ? void 0 : _a.disconnect();
|
|
74
|
-
this.status = "closed";
|
|
75
78
|
if (((_b = this.audioContext) == null ? void 0 : _b.state) !== "closed") {
|
|
76
79
|
return (_c = this.audioContext) == null ? void 0 : _c.close();
|
|
77
80
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AudioManager.es.js","sources":["../../../../src/utils/voskBrowserManager/AudioManager/AudioManager.ts"],"sourcesContent":["import { requestMicrophonePermission } from '../../xunFeiVoice/utils';\nimport { SampleRate } from './types';\nimport defaultWorkletProcessorStr from './workletProcessor.js?raw';\n\nexport const defaultSampleRate = 48000;\n\nexport interface AudiManagerConfig {\n /** 一个转换成 string js 文件。其内容要符合 AudioWorkletProcessor 的要求。\n * - 需使用 registerProcessor 注册,第一个参数为 “audio-worklet-processor”,如: registerProcessor('audio-worklet-processor', audioToFloat32Processor);\n * - 参考:https://developer.mozilla.org/en-US/docs/Web/API/AudioWorkletProcessor\n */\n workletProcessor?: string;\n /** 采样率(每秒采样数)的浮点数,常用值:16000, 32000, 44100, 48000 */\n sampleRate?: SampleRate;\n onFrameRecorded?: (data: Float32Array) => void;\n onStart?: () => void;\n onStop?: () => void;\n frameSize?: number;\n}\n\nconst generateWorkletUrl = (jsStr: string) => {\n const blob = new Blob([jsStr], { type: 'application/javascript' });\n const scriptUrl = URL.createObjectURL(blob);\n return scriptUrl;\n};\n\n/** 对实时音频录制进行管理。 */\nexport class AudioManager {\n workletUrl?: string;\n sampleRate?: SampleRate = defaultSampleRate;\n
|
|
1
|
+
{"version":3,"file":"AudioManager.es.js","sources":["../../../../src/utils/voskBrowserManager/AudioManager/AudioManager.ts"],"sourcesContent":["import { requestMicrophonePermission } from '../../xunFeiVoice/utils';\nimport { SampleRate } from './types';\nimport defaultWorkletProcessorStr from './workletProcessor.js?raw';\n\nexport const defaultSampleRate = 48000;\n\nexport interface AudiManagerConfig {\n /** 一个转换成 string js 文件。其内容要符合 AudioWorkletProcessor 的要求。\n * - 需使用 registerProcessor 注册,第一个参数为 “audio-worklet-processor”,如: registerProcessor('audio-worklet-processor', audioToFloat32Processor);\n * - 参考:https://developer.mozilla.org/en-US/docs/Web/API/AudioWorkletProcessor\n */\n workletProcessor?: string;\n /** 采样率(每秒采样数)的浮点数,常用值:16000, 32000, 44100, 48000 */\n sampleRate?: SampleRate;\n onFrameRecorded?: (data: Float32Array) => void;\n onStart?: () => void;\n onStop?: () => void;\n frameSize?: number;\n}\n\nconst generateWorkletUrl = (jsStr: string) => {\n const blob = new Blob([jsStr], { type: 'application/javascript' });\n const scriptUrl = URL.createObjectURL(blob);\n return scriptUrl;\n};\n\n/** 对实时音频录制进行管理。 */\nexport class AudioManager {\n workletUrl?: string;\n sampleRate?: SampleRate = defaultSampleRate;\n audioContext?: AudioContext;\n mediaSource?: MediaStreamAudioSourceNode;\n mediaStream?: MediaStream;\n config: AudiManagerConfig = {};\n status: 'init' | 'starting' | 'started' = 'init';\n\n constructor(config: AudiManagerConfig) {\n console.log('audio manager constructor: ====', config);\n const processorStr = config.workletProcessor || defaultWorkletProcessorStr;\n this.workletUrl = generateWorkletUrl(processorStr);\n this.sampleRate = config.sampleRate;\n this.config = config;\n }\n\n async start() {\n try {\n console.log(\n '%c 🐶 dog ==== audio manager start:',\n 'color: green; font-size: 16px;',\n this.audioContext,\n );\n if (this.audioContext?.state === 'running' || this.status === 'starting') {\n return;\n }\n this.status = 'starting';\n // 1. 创建 AudioContext\n const audioContext = new window.AudioContext({\n sampleRate: this.sampleRate,\n });\n if (!this.workletUrl) {\n throw Error('加载 workletProcessor 失败!');\n }\n // 加载给定 JavaScript 文件中的模块,并将其添加到当前 Worklet 中\n await audioContext.audioWorklet.addModule(this.workletUrl);\n const audioWorkletNode = new AudioWorkletNode(audioContext, 'audio-worklet-processor');\n // 获取音频流并创建处理节点\n const mediaStream = await requestMicrophonePermission();\n const mediaSource = audioContext.createMediaStreamSource(mediaStream);\n // 发送配置给 workletProcessor\n audioWorkletNode.port.postMessage({\n type: 'init',\n frameSize: this.config.frameSize,\n });\n // 监听消息\n audioWorkletNode.port.onmessage = (e) => {\n this.config.onFrameRecorded?.(e.data);\n };\n // 连接音频节点\n mediaSource.connect(audioWorkletNode);\n // 赋值到 this 上\n this.audioContext = audioContext;\n this.mediaSource = mediaSource;\n this.mediaStream = mediaStream;\n this.config.onStart?.();\n this.status = 'started';\n } catch (error) {\n console.error('Failed to start recording:', error);\n throw error;\n }\n }\n\n async stop() {\n /** 暂停音频上下文对象中的进度,并暂时剥离进程对音频设备硬件的访问权限,减少 CPU 和电池的使用 */\n if (this.audioContext?.state === 'running') {\n await this.audioContext.suspend();\n }\n this.config.onStop?.();\n }\n\n close() {\n this.mediaSource?.disconnect();\n if (this.audioContext?.state !== 'closed') {\n return this.audioContext?.close();\n }\n }\n\n destroy() {\n this.close();\n this.mediaStream?.getTracks()?.forEach((track) => track.stop());\n }\n}\n"],"names":["_b","_a"],"mappings":";;;;;AAIO,MAAM,oBAAoB;AAgBjC,MAAM,qBAAqB,CAAC,UAAkB;AACtC,QAAA,OAAO,IAAI,KAAK,CAAC,KAAK,GAAG,EAAE,MAAM,0BAA0B;AAC3D,QAAA,YAAY,IAAI,gBAAgB,IAAI;AACnC,SAAA;AACT;AAGO,MAAM,aAAa;AAAA,EASxB,YAAY,QAA2B;AARvC;AACA,sCAA0B;AAC1B;AACA;AACA;AACA,kCAA4B,CAAC;AAC7B,kCAA0C;AAGhC,YAAA,IAAI,mCAAmC,MAAM;AAC/C,UAAA,eAAe,OAAO,oBAAoB;AAC3C,SAAA,aAAa,mBAAmB,YAAY;AACjD,SAAK,aAAa,OAAO;AACzB,SAAK,SAAS;AAAA,EAAA;AAAA,EAGhB,MAAM,QAAQ;;AACR,QAAA;AACM,cAAA;AAAA,QACN;AAAA,QACA;AAAA,QACA,KAAK;AAAA,MACP;AACA,YAAI,UAAK,iBAAL,mBAAmB,WAAU,aAAa,KAAK,WAAW,YAAY;AACxE;AAAA,MAAA;AAEF,WAAK,SAAS;AAER,YAAA,eAAe,IAAI,OAAO,aAAa;AAAA,QAC3C,YAAY,KAAK;AAAA,MAAA,CAClB;AACG,UAAA,CAAC,KAAK,YAAY;AACpB,cAAM,MAAM,yBAAyB;AAAA,MAAA;AAGvC,YAAM,aAAa,aAAa,UAAU,KAAK,UAAU;AACzD,YAAM,mBAAmB,IAAI,iBAAiB,cAAc,yBAAyB;AAE/E,YAAA,cAAc,MAAM,4BAA4B;AAChD,YAAA,cAAc,aAAa,wBAAwB,WAAW;AAEpE,uBAAiB,KAAK,YAAY;AAAA,QAChC,MAAM;AAAA,QACN,WAAW,KAAK,OAAO;AAAA,MAAA,CACxB;AAEgB,uBAAA,KAAK,YAAY,CAAC,MAAM;;AAClC,SAAAA,OAAAC,MAAA,KAAA,QAAO,oBAAP,gBAAAD,IAAA,KAAAC,KAAyB,EAAE;AAAA,MAClC;AAEA,kBAAY,QAAQ,gBAAgB;AAEpC,WAAK,eAAe;AACpB,WAAK,cAAc;AACnB,WAAK,cAAc;AACnB,uBAAK,QAAO,YAAZ;AACA,WAAK,SAAS;AAAA,aACP,OAAO;AACN,cAAA,MAAM,8BAA8B,KAAK;AAC3C,YAAA;AAAA,IAAA;AAAA,EACR;AAAA,EAGF,MAAM,OAAO;;AAEP,UAAA,UAAK,iBAAL,mBAAmB,WAAU,WAAW;AACpC,YAAA,KAAK,aAAa,QAAQ;AAAA,IAAA;AAElC,qBAAK,QAAO,WAAZ;AAAA,EAAqB;AAAA,EAGvB,QAAQ;;AACN,eAAK,gBAAL,mBAAkB;AACd,UAAA,UAAK,iBAAL,mBAAmB,WAAU,UAAU;AAClC,cAAA,UAAK,iBAAL,mBAAmB;AAAA,IAAM;AAAA,EAClC;AAAA,EAGF,UAAU;;AACR,SAAK,MAAM;AACN,qBAAA,gBAAA,mBAAa,gBAAb,mBAA0B,QAAQ,CAAC,UAAU,MAAM;EAAM;AAElE;"}
|
|
@@ -15,11 +15,15 @@ export declare class VoskBrowserManager {
|
|
|
15
15
|
/** 采样率(每秒采样数)的浮点数,常用值:16000, 32000, 44100, 48000 */
|
|
16
16
|
sampleRate: SampleRate;
|
|
17
17
|
audioManager?: AudioManager;
|
|
18
|
+
model?: Vosk.Model;
|
|
18
19
|
autoStart: boolean;
|
|
20
|
+
startResolve?: (value?: unknown) => void;
|
|
21
|
+
status?: 'initializing' | 'initialized';
|
|
19
22
|
constructor(config: VoskBrowserManagerConfig);
|
|
20
23
|
setConfig(config: Partial<Pick<VoskBrowserManagerConfig, 'onResult' | 'onPartialResult'>>): void;
|
|
21
24
|
init(vosk: typeof Vosk): Promise<void>;
|
|
22
|
-
start(): void
|
|
25
|
+
start(): Promise<void>;
|
|
23
26
|
stop(): void;
|
|
27
|
+
destroy(): void;
|
|
24
28
|
}
|
|
25
29
|
export {};
|
|
@@ -19,7 +19,10 @@ class VoskBrowserManager {
|
|
|
19
19
|
/** 采样率(每秒采样数)的浮点数,常用值:16000, 32000, 44100, 48000 */
|
|
20
20
|
__publicField(this, "sampleRate", defaultSampleRate);
|
|
21
21
|
__publicField(this, "audioManager");
|
|
22
|
+
__publicField(this, "model");
|
|
22
23
|
__publicField(this, "autoStart", true);
|
|
24
|
+
__publicField(this, "startResolve");
|
|
25
|
+
__publicField(this, "status");
|
|
23
26
|
this.config = config;
|
|
24
27
|
this.sampleRate = config.sampleRate || defaultSampleRate;
|
|
25
28
|
this.autoStart = config.autoStart || true;
|
|
@@ -32,11 +35,15 @@ class VoskBrowserManager {
|
|
|
32
35
|
};
|
|
33
36
|
}
|
|
34
37
|
async init(vosk) {
|
|
35
|
-
var _a, _b;
|
|
38
|
+
var _a, _b, _c;
|
|
39
|
+
if (this.model) {
|
|
40
|
+
this.model.terminate();
|
|
41
|
+
}
|
|
42
|
+
this.status = "initializing";
|
|
36
43
|
console.time("load model:");
|
|
37
|
-
|
|
44
|
+
this.model = await vosk.createModel(this.config.modelUrl);
|
|
38
45
|
console.timeEnd("load model:");
|
|
39
|
-
const recognizer = new model.KaldiRecognizer(this.sampleRate);
|
|
46
|
+
const recognizer = new this.model.KaldiRecognizer(this.sampleRate);
|
|
40
47
|
recognizer.on("result", (message) => {
|
|
41
48
|
var _a2, _b2;
|
|
42
49
|
const resultText = message.result.text;
|
|
@@ -47,6 +54,9 @@ class VoskBrowserManager {
|
|
|
47
54
|
const partialText = message.result.partial;
|
|
48
55
|
(_b2 = (_a2 = this.config).onPartialResult) == null ? void 0 : _b2.call(_a2, partialText);
|
|
49
56
|
});
|
|
57
|
+
if (this.audioManager) {
|
|
58
|
+
this.audioManager.destroy();
|
|
59
|
+
}
|
|
50
60
|
this.audioManager = new AudioManager({
|
|
51
61
|
...pickAudioManagerConfig(this.config),
|
|
52
62
|
sampleRate: this.sampleRate,
|
|
@@ -57,18 +67,39 @@ class VoskBrowserManager {
|
|
|
57
67
|
}
|
|
58
68
|
});
|
|
59
69
|
(_b = (_a = this.config).onInitialized) == null ? void 0 : _b.call(_a);
|
|
70
|
+
(_c = this.startResolve) == null ? void 0 : _c.call(this);
|
|
71
|
+
this.status = "initialized";
|
|
72
|
+
console.log("%c 🐱 cat ==== init:", "color: orange; font-size: 16px;", this);
|
|
60
73
|
if (this.autoStart) {
|
|
61
74
|
this.start();
|
|
62
75
|
}
|
|
63
76
|
}
|
|
64
|
-
start() {
|
|
65
|
-
var _a;
|
|
66
|
-
|
|
77
|
+
async start() {
|
|
78
|
+
var _a, _b, _c, _d;
|
|
79
|
+
console.log(
|
|
80
|
+
"vosk manager start ====",
|
|
81
|
+
this.audioManager,
|
|
82
|
+
(_b = (_a = this.audioManager) == null ? void 0 : _a.audioContext) == null ? void 0 : _b.state
|
|
83
|
+
);
|
|
84
|
+
if (this.status === "initialized") {
|
|
85
|
+
await ((_c = this.audioManager) == null ? void 0 : _c.start());
|
|
86
|
+
} else {
|
|
87
|
+
await new Promise((resolve) => {
|
|
88
|
+
this.startResolve = resolve;
|
|
89
|
+
});
|
|
90
|
+
console.log("%c 🐱 cat ==== start resolved", "color: orange; font-size: 16px;");
|
|
91
|
+
await ((_d = this.audioManager) == null ? void 0 : _d.start());
|
|
92
|
+
}
|
|
67
93
|
}
|
|
68
94
|
stop() {
|
|
69
95
|
var _a;
|
|
70
96
|
(_a = this.audioManager) == null ? void 0 : _a.stop();
|
|
71
97
|
}
|
|
98
|
+
destroy() {
|
|
99
|
+
var _a, _b;
|
|
100
|
+
(_a = this.audioManager) == null ? void 0 : _a.destroy();
|
|
101
|
+
(_b = this.model) == null ? void 0 : _b.terminate();
|
|
102
|
+
}
|
|
72
103
|
}
|
|
73
104
|
export {
|
|
74
105
|
VoskBrowserManager
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"voskBrowserManager.es.js","sources":["../../../src/utils/voskBrowserManager/voskBrowserManager.ts"],"sourcesContent":["import { omit } from 'lodash-es';\nimport type * as Vosk from 'vosk-browser';\nimport { AudiManagerConfig, AudioManager, defaultSampleRate } from './AudioManager/AudioManager';\nimport { SampleRate } from './AudioManager/types';\n\ninterface VoskBrowserManagerConfig extends AudiManagerConfig {\n vosk: typeof Vosk;\n modelUrl: string;\n /** 加载模型等初始化配置完成后,自动开始监听 */\n autoStart?: boolean;\n onInitialized?: () => void;\n onResult?: (text: string) => void;\n onPartialResult?: (text: string) => void;\n}\n\nconst pickAudioManagerConfig = (config: VoskBrowserManagerConfig) => {\n return omit(config, [\n 'vosk',\n 'modelUrl',\n 'autoStart',\n 'onResult',\n 'onPartialResult',\n 'onInitialized',\n ]);\n};\n\nexport class VoskBrowserManager {\n config: VoskBrowserManagerConfig;\n /** 采样率(每秒采样数)的浮点数,常用值:16000, 32000, 44100, 48000 */\n sampleRate: SampleRate = defaultSampleRate;\n audioManager?: AudioManager;\n autoStart = true;\n\n constructor(config: VoskBrowserManagerConfig) {\n this.config = config;\n this.sampleRate = config.sampleRate || defaultSampleRate;\n this.autoStart = config.autoStart || true;\n this.init(config.vosk);\n }\n\n setConfig(config: Partial<Pick<VoskBrowserManagerConfig, 'onResult' | 'onPartialResult'>>) {\n this.config = {\n ...this.config,\n ...config,\n };\n }\n\n async init(vosk: typeof Vosk) {\n console.time('load model:');\n
|
|
1
|
+
{"version":3,"file":"voskBrowserManager.es.js","sources":["../../../src/utils/voskBrowserManager/voskBrowserManager.ts"],"sourcesContent":["import { omit } from 'lodash-es';\nimport type * as Vosk from 'vosk-browser';\nimport { AudiManagerConfig, AudioManager, defaultSampleRate } from './AudioManager/AudioManager';\nimport { SampleRate } from './AudioManager/types';\n\ninterface VoskBrowserManagerConfig extends AudiManagerConfig {\n vosk: typeof Vosk;\n modelUrl: string;\n /** 加载模型等初始化配置完成后,自动开始监听 */\n autoStart?: boolean;\n onInitialized?: () => void;\n onResult?: (text: string) => void;\n onPartialResult?: (text: string) => void;\n}\n\nconst pickAudioManagerConfig = (config: VoskBrowserManagerConfig) => {\n return omit(config, [\n 'vosk',\n 'modelUrl',\n 'autoStart',\n 'onResult',\n 'onPartialResult',\n 'onInitialized',\n ]);\n};\n\nexport class VoskBrowserManager {\n config: VoskBrowserManagerConfig;\n /** 采样率(每秒采样数)的浮点数,常用值:16000, 32000, 44100, 48000 */\n sampleRate: SampleRate = defaultSampleRate;\n audioManager?: AudioManager;\n model?: Vosk.Model;\n autoStart = true;\n startResolve?: (value?: unknown) => void;\n status?: 'initializing' | 'initialized';\n\n constructor(config: VoskBrowserManagerConfig) {\n this.config = config;\n this.sampleRate = config.sampleRate || defaultSampleRate;\n this.autoStart = config.autoStart || true;\n this.init(config.vosk);\n }\n\n setConfig(config: Partial<Pick<VoskBrowserManagerConfig, 'onResult' | 'onPartialResult'>>) {\n this.config = {\n ...this.config,\n ...config,\n };\n }\n\n async init(vosk: typeof Vosk) {\n if (this.model) {\n this.model.terminate();\n }\n this.status = 'initializing';\n console.time('load model:');\n this.model = await vosk.createModel(this.config.modelUrl);\n console.timeEnd('load model:');\n\n const recognizer = new this.model.KaldiRecognizer(this.sampleRate);\n recognizer.on('result', (message) => {\n const resultText = (message as any).result.text;\n this.config.onResult?.(resultText);\n });\n recognizer.on('partialresult', (message) => {\n const partialText = (message as any).result.partial;\n this.config.onPartialResult?.(partialText);\n });\n\n if (this.audioManager) {\n this.audioManager.destroy();\n }\n this.audioManager = new AudioManager({\n ...pickAudioManagerConfig(this.config),\n sampleRate: this.sampleRate,\n onFrameRecorded: (data) => {\n recognizer.acceptWaveformFloat(data, this.sampleRate);\n this.config.onFrameRecorded?.(data);\n },\n });\n\n this.config.onInitialized?.();\n this.startResolve?.();\n this.status = 'initialized';\n console.log('%c 🐱 cat ==== init:', 'color: orange; font-size: 16px;', this);\n if (this.autoStart) {\n this.start();\n }\n }\n\n async start() {\n console.log(\n 'vosk manager start ====',\n this.audioManager,\n this.audioManager?.audioContext?.state,\n );\n if (this.status === 'initialized') {\n await this.audioManager?.start();\n } else {\n await new Promise((resolve) => {\n this.startResolve = resolve;\n });\n console.log('%c 🐱 cat ==== start resolved', 'color: orange; font-size: 16px;');\n await this.audioManager?.start();\n }\n }\n\n stop() {\n this.audioManager?.stop();\n }\n\n destroy() {\n this.audioManager?.destroy();\n this.model?.terminate();\n }\n}\n"],"names":["_b","_a"],"mappings":";;;;;AAeA,MAAM,yBAAyB,CAAC,WAAqC;AACnE,SAAO,KAAK,QAAQ;AAAA,IAClB;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EAAA,CACD;AACH;AAEO,MAAM,mBAAmB;AAAA,EAU9B,YAAY,QAAkC;AAT9C;AAEA;AAAA,sCAAyB;AACzB;AACA;AACA,qCAAY;AACZ;AACA;AAGE,SAAK,SAAS;AACT,SAAA,aAAa,OAAO,cAAc;AAClC,SAAA,YAAY,OAAO,aAAa;AAChC,SAAA,KAAK,OAAO,IAAI;AAAA,EAAA;AAAA,EAGvB,UAAU,QAAiF;AACzF,SAAK,SAAS;AAAA,MACZ,GAAG,KAAK;AAAA,MACR,GAAG;AAAA,IACL;AAAA,EAAA;AAAA,EAGF,MAAM,KAAK,MAAmB;;AAC5B,QAAI,KAAK,OAAO;AACd,WAAK,MAAM,UAAU;AAAA,IAAA;AAEvB,SAAK,SAAS;AACd,YAAQ,KAAK,aAAa;AAC1B,SAAK,QAAQ,MAAM,KAAK,YAAY,KAAK,OAAO,QAAQ;AACxD,YAAQ,QAAQ,aAAa;AAE7B,UAAM,aAAa,IAAI,KAAK,MAAM,gBAAgB,KAAK,UAAU;AACtD,eAAA,GAAG,UAAU,CAAC,YAAY;;AAC7B,YAAA,aAAc,QAAgB,OAAO;AACtC,OAAAA,OAAAC,MAAA,KAAA,QAAO,aAAP,gBAAAD,IAAA,KAAAC,KAAkB;AAAA,IAAU,CAClC;AACU,eAAA,GAAG,iBAAiB,CAAC,YAAY;;AACpC,YAAA,cAAe,QAAgB,OAAO;AACvC,OAAAD,OAAAC,MAAA,KAAA,QAAO,oBAAP,gBAAAD,IAAA,KAAAC,KAAyB;AAAA,IAAW,CAC1C;AAED,QAAI,KAAK,cAAc;AACrB,WAAK,aAAa,QAAQ;AAAA,IAAA;AAEvB,SAAA,eAAe,IAAI,aAAa;AAAA,MACnC,GAAG,uBAAuB,KAAK,MAAM;AAAA,MACrC,YAAY,KAAK;AAAA,MACjB,iBAAiB,CAAC,SAAS;;AACd,mBAAA,oBAAoB,MAAM,KAAK,UAAU;AAC/C,SAAAD,OAAAC,MAAA,KAAA,QAAO,oBAAP,gBAAAD,IAAA,KAAAC,KAAyB;AAAA,MAAI;AAAA,IACpC,CACD;AAED,qBAAK,QAAO,kBAAZ;AACA,eAAK,iBAAL;AACA,SAAK,SAAS;AACN,YAAA,IAAI,0BAA0B,mCAAmC,IAAI;AAC7E,QAAI,KAAK,WAAW;AAClB,WAAK,MAAM;AAAA,IAAA;AAAA,EACb;AAAA,EAGF,MAAM,QAAQ;;AACJ,YAAA;AAAA,MACN;AAAA,MACA,KAAK;AAAA,OACL,gBAAK,iBAAL,mBAAmB,iBAAnB,mBAAiC;AAAA,IACnC;AACI,QAAA,KAAK,WAAW,eAAe;AAC3B,cAAA,UAAK,iBAAL,mBAAmB;AAAA,IAAM,OAC1B;AACC,YAAA,IAAI,QAAQ,CAAC,YAAY;AAC7B,aAAK,eAAe;AAAA,MAAA,CACrB;AACO,cAAA,IAAI,mCAAmC,iCAAiC;AAC1E,cAAA,UAAK,iBAAL,mBAAmB;AAAA,IAAM;AAAA,EACjC;AAAA,EAGF,OAAO;;AACL,eAAK,iBAAL,mBAAmB;AAAA,EAAK;AAAA,EAG1B,UAAU;;AACR,eAAK,iBAAL,mBAAmB;AACnB,eAAK,UAAL,mBAAY;AAAA,EAAU;AAE1B;"}
|