@opendaw/studio-core 0.0.83 → 0.0.85
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/EffectFactories.d.ts +0 -2
- package/dist/EffectFactories.d.ts.map +1 -1
- package/dist/EffectFactories.js +1 -1
- package/dist/Engine.d.ts +2 -1
- package/dist/Engine.d.ts.map +1 -1
- package/dist/EngineFacade.d.ts +2 -1
- package/dist/EngineFacade.d.ts.map +1 -1
- package/dist/EngineFacade.js +3 -1
- package/dist/EngineWorklet.d.ts +2 -1
- package/dist/EngineWorklet.d.ts.map +1 -1
- package/dist/EngineWorklet.js +5 -2
- package/dist/ExternalLib.d.ts +3 -2
- package/dist/ExternalLib.d.ts.map +1 -1
- package/dist/ExternalLib.js +2 -2
- package/dist/Preferences.d.ts +6 -0
- package/dist/Preferences.d.ts.map +1 -1
- package/dist/Preferences.js +5 -2
- package/dist/Storage.d.ts.map +1 -1
- package/dist/Storage.js +14 -5
- package/dist/capture/Capture.d.ts +4 -1
- package/dist/capture/Capture.d.ts.map +1 -1
- package/dist/capture/Capture.js +4 -0
- package/dist/capture/CaptureDevices.js +1 -1
- package/dist/capture/RecordAudio.d.ts.map +1 -1
- package/dist/capture/RecordAudio.js +20 -10
- package/dist/capture/RecordMidi.d.ts.map +1 -1
- package/dist/capture/RecordMidi.js +1 -0
- package/dist/capture/Recording.d.ts.map +1 -1
- package/dist/capture/Recording.js +1 -0
- package/dist/dawproject/BuiltinDevices.d.ts +1 -1
- package/dist/dawproject/DawProject.d.ts.map +1 -1
- package/dist/dawproject/DawProject.js +17 -3
- package/dist/midi/MIDILearning.d.ts +4 -16
- package/dist/midi/MIDILearning.d.ts.map +1 -1
- package/dist/midi/MIDILearning.js +94 -62
- package/dist/processors.js +17 -17
- package/dist/processors.js.map +4 -4
- package/dist/project/Project.d.ts +2 -2
- package/dist/project/Project.d.ts.map +1 -1
- package/dist/project/Project.js +16 -9
- package/dist/project/ProjectApi.js +2 -2
- package/dist/project/ProjectBundle.d.ts.map +1 -1
- package/dist/project/ProjectBundle.js +21 -6
- package/dist/project/ProjectMigration.d.ts.map +1 -1
- package/dist/project/ProjectMigration.js +20 -4
- package/dist/project/ProjectValidation.d.ts.map +1 -1
- package/dist/project/ProjectValidation.js +15 -13
- package/dist/project/audio/AudioContentFactory.d.ts.map +1 -1
- package/dist/project/audio/AudioContentFactory.js +3 -3
- package/dist/project/audio/AudioContentModifier.d.ts.map +1 -1
- package/dist/project/audio/AudioContentModifier.js +15 -3
- package/dist/project/audio/AudioFileBoxFactory.d.ts.map +1 -1
- package/dist/project/audio/AudioFileBoxFactory.js +5 -0
- package/dist/samples/DefaultSampleLoader.d.ts.map +1 -1
- package/dist/samples/DefaultSampleLoader.js +8 -4
- package/dist/samples/DefaultSampleLoaderManager.d.ts.map +1 -1
- package/dist/samples/DefaultSampleLoaderManager.js +5 -2
- package/dist/soundfont/DefaultSoundfontLoader.d.ts.map +1 -1
- package/dist/soundfont/DefaultSoundfontLoader.js +16 -11
- package/dist/soundfont/SoundfontService.d.ts.map +1 -1
- package/dist/soundfont/SoundfontService.js +3 -6
- package/dist/ui/RegionClipResolver.d.ts.map +1 -1
- package/dist/ui/RegionClipResolver.js +15 -6
- package/dist/ui/RegionModifyStrategies.js +3 -3
- package/dist/ui/TimeGrid.d.ts +2 -1
- package/dist/ui/TimeGrid.d.ts.map +1 -1
- package/dist/ui/TimeGrid.js +28 -14
- package/dist/workers-main.js +1 -1
- package/dist/workers-main.js.map +3 -3
- package/package.json +16 -16
|
@@ -30,7 +30,6 @@ export declare namespace EffectFactories {
|
|
|
30
30
|
Crusher: EffectFactory;
|
|
31
31
|
Fold: EffectFactory;
|
|
32
32
|
Tidal: EffectFactory;
|
|
33
|
-
Modular: EffectFactory;
|
|
34
33
|
};
|
|
35
34
|
const MidiList: ReadonlyArray<Readonly<EffectFactory>>;
|
|
36
35
|
const AudioList: ReadonlyArray<Readonly<EffectFactory>>;
|
|
@@ -44,7 +43,6 @@ export declare namespace EffectFactories {
|
|
|
44
43
|
Crusher: EffectFactory;
|
|
45
44
|
Fold: EffectFactory;
|
|
46
45
|
Tidal: EffectFactory;
|
|
47
|
-
Modular: EffectFactory;
|
|
48
46
|
Arpeggio: EffectFactory;
|
|
49
47
|
Pitch: EffectFactory;
|
|
50
48
|
Velocity: EffectFactory;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"EffectFactories.d.ts","sourceRoot":"","sources":["../src/EffectFactories.ts"],"names":[],"mappings":"AAuBA,OAAO,EAAC,aAAa,EAAC,MAAM,iBAAiB,CAAA;AAG7C,yBAAiB,eAAe,CAAC;IACtB,MAAM,QAAQ,EAAE,aAWtB,CAAA;IAEM,MAAM,KAAK,EAAE,aAWnB,CAAA;IAEM,MAAM,QAAQ,EAAE,aAYtB,CAAA;IAEM,MAAM,SAAS,EAAE,aAqBvB,CAAA;IAEM,MAAM,UAAU,EAAE,aAYxB,CAAA;IAEM,MAAM,KAAK,EAAE,aAYnB,CAAA;IAEM,MAAM,cAAc,EAAE,aAY5B,CAAA;IAEM,MAAM,UAAU,EAAE,aAYxB,CAAA;IAEM,MAAM,MAAM,EAAE,aAapB,CAAA;IAEM,MAAM,OAAO,EAAE,aAYrB,CAAA;IAEM,MAAM,IAAI,EAAE,aAYlB,CAAA;IAEM,MAAM,KAAK,EAAE,aAanB,CAAA;IAEM,MAAM,MAAM,EAAE,aAYpB,CAAA;IAEM,MAAM,OAAO,EAAE,aAoCrB,CAAA;IAEM,MAAM,SAAS;;;;;KAAyC,CAAA;IACxD,MAAM,UAAU
|
|
1
|
+
{"version":3,"file":"EffectFactories.d.ts","sourceRoot":"","sources":["../src/EffectFactories.ts"],"names":[],"mappings":"AAuBA,OAAO,EAAC,aAAa,EAAC,MAAM,iBAAiB,CAAA;AAG7C,yBAAiB,eAAe,CAAC;IACtB,MAAM,QAAQ,EAAE,aAWtB,CAAA;IAEM,MAAM,KAAK,EAAE,aAWnB,CAAA;IAEM,MAAM,QAAQ,EAAE,aAYtB,CAAA;IAEM,MAAM,SAAS,EAAE,aAqBvB,CAAA;IAEM,MAAM,UAAU,EAAE,aAYxB,CAAA;IAEM,MAAM,KAAK,EAAE,aAYnB,CAAA;IAEM,MAAM,cAAc,EAAE,aAY5B,CAAA;IAEM,MAAM,UAAU,EAAE,aAYxB,CAAA;IAEM,MAAM,MAAM,EAAE,aAapB,CAAA;IAEM,MAAM,OAAO,EAAE,aAYrB,CAAA;IAEM,MAAM,IAAI,EAAE,aAYlB,CAAA;IAEM,MAAM,KAAK,EAAE,aAanB,CAAA;IAEM,MAAM,MAAM,EAAE,aAYpB,CAAA;IAEM,MAAM,OAAO,EAAE,aAoCrB,CAAA;IAEM,MAAM,SAAS;;;;;KAAyC,CAAA;IACxD,MAAM,UAAU;;;;;;;;;;KAEtB,CAAA;IACM,MAAM,QAAQ,EAAE,aAAa,CAAC,QAAQ,CAAC,aAAa,CAAC,CAA4B,CAAA;IACjF,MAAM,SAAS,EAAE,aAAa,CAAC,QAAQ,CAAC,aAAa,CAAC,CAA6B,CAAA;IACnF,MAAM,WAAW;;;;;;;;;;;;;;KAAgC,CAAA;IACxD,KAAY,cAAc,GAAG,MAAM,OAAO,SAAS,CAAA;IACnD,KAAY,eAAe,GAAG,MAAM,OAAO,UAAU,CAAA;CACxD"}
|
package/dist/EffectFactories.js
CHANGED
|
@@ -212,7 +212,7 @@ export var EffectFactories;
|
|
|
212
212
|
};
|
|
213
213
|
EffectFactories.MidiNamed = { Arpeggio: EffectFactories.Arpeggio, Pitch: EffectFactories.Pitch, Velocity: EffectFactories.Velocity, Zeitgeist: EffectFactories.Zeitgeist };
|
|
214
214
|
EffectFactories.AudioNamed = {
|
|
215
|
-
StereoTool: EffectFactories.StereoTool, Compressor: EffectFactories.Compressor, Delay: EffectFactories.Delay, Reverb: EffectFactories.Reverb, DattorroReverb: EffectFactories.DattorroReverb, Revamp: EffectFactories.Revamp, Crusher: EffectFactories.Crusher, Fold: EffectFactories.Fold, Tidal: EffectFactories.Tidal
|
|
215
|
+
StereoTool: EffectFactories.StereoTool, Compressor: EffectFactories.Compressor, Delay: EffectFactories.Delay, Reverb: EffectFactories.Reverb, DattorroReverb: EffectFactories.DattorroReverb, Revamp: EffectFactories.Revamp, Crusher: EffectFactories.Crusher, Fold: EffectFactories.Fold, Tidal: EffectFactories.Tidal
|
|
216
216
|
};
|
|
217
217
|
EffectFactories.MidiList = Object.values(EffectFactories.MidiNamed);
|
|
218
218
|
EffectFactories.AudioList = Object.values(EffectFactories.AudioNamed);
|
package/dist/Engine.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { int, MutableObservableValue, Nullable, ObservableValue, Observer, Subscription, Terminable, UUID } from "@opendaw/lib-std";
|
|
2
|
-
import { ppqn } from "@opendaw/lib-dsp";
|
|
2
|
+
import { bpm, ppqn } from "@opendaw/lib-dsp";
|
|
3
3
|
import { ClipNotification, NoteSignal } from "@opendaw/studio-adapters";
|
|
4
4
|
import { Project } from "./project";
|
|
5
5
|
export interface Engine extends Terminable {
|
|
@@ -21,6 +21,7 @@ export interface Engine extends Terminable {
|
|
|
21
21
|
scheduleClipStop(trackIds: ReadonlyArray<UUID.Bytes>): void;
|
|
22
22
|
subscribeClipNotification(observer: Observer<ClipNotification>): Subscription;
|
|
23
23
|
get position(): ObservableValue<ppqn>;
|
|
24
|
+
get bpm(): ObservableValue<bpm>;
|
|
24
25
|
get isPlaying(): ObservableValue<boolean>;
|
|
25
26
|
get isRecording(): ObservableValue<boolean>;
|
|
26
27
|
get isCountingIn(): ObservableValue<boolean>;
|
package/dist/Engine.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Engine.d.ts","sourceRoot":"","sources":["../src/Engine.ts"],"names":[],"mappings":"AAAA,OAAO,EACH,GAAG,EACH,sBAAsB,EACtB,QAAQ,EACR,eAAe,EACf,QAAQ,EACR,YAAY,EACZ,UAAU,EACV,IAAI,EACP,MAAM,kBAAkB,CAAA;AACzB,OAAO,EAAC,IAAI,EAAC,MAAM,kBAAkB,CAAA;
|
|
1
|
+
{"version":3,"file":"Engine.d.ts","sourceRoot":"","sources":["../src/Engine.ts"],"names":[],"mappings":"AAAA,OAAO,EACH,GAAG,EACH,sBAAsB,EACtB,QAAQ,EACR,eAAe,EACf,QAAQ,EACR,YAAY,EACZ,UAAU,EACV,IAAI,EACP,MAAM,kBAAkB,CAAA;AACzB,OAAO,EAAC,GAAG,EAAE,IAAI,EAAC,MAAM,kBAAkB,CAAA;AAC1C,OAAO,EAAC,gBAAgB,EAAE,UAAU,EAAC,MAAM,0BAA0B,CAAA;AACrE,OAAO,EAAC,OAAO,EAAC,MAAM,WAAW,CAAA;AAEjC,MAAM,WAAW,MAAO,SAAQ,UAAU;IACtC,IAAI,IAAI,IAAI,CAAA;IACZ,IAAI,IAAI,IAAI,CAAA;IACZ,WAAW,CAAC,QAAQ,EAAE,IAAI,GAAG,IAAI,CAAA;IACjC,qBAAqB,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI,CAAA;IAC7C,aAAa,IAAI,IAAI,CAAA;IACrB,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC,CAAA;IACxB,oBAAoB,IAAI,OAAO,CAAC,OAAO,CAAC,CAAA;IACxC,IAAI,IAAI,IAAI,CAAA;IACZ,KAAK,IAAI,IAAI,CAAA;IACb,KAAK,IAAI,IAAI,CAAA;IACb,IAAI,IAAI,IAAI,CAAA;IACZ,UAAU,CAAC,MAAM,EAAE,UAAU,GAAG,IAAI,CAAA;IACpC,cAAc,CAAC,QAAQ,EAAE,QAAQ,CAAC,UAAU,CAAC,GAAG,YAAY,CAAA;IAC5D,gBAAgB,CAAC,IAAI,EAAE,IAAI,CAAC,KAAK,GAAG,IAAI,CAAA;IACxC,gBAAgB,CAAC,OAAO,EAAE,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,IAAI,CAAA;IAC1D,gBAAgB,CAAC,QAAQ,EAAE,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,IAAI,CAAA;IAC3D,yBAAyB,CAAC,QAAQ,EAAE,QAAQ,CAAC,gBAAgB,CAAC,GAAG,YAAY,CAAA;IAE7E,IAAI,QAAQ,IAAI,eAAe,CAAC,IAAI,CAAC,CAAA;IACrC,IAAI,GAAG,IAAI,eAAe,CAAC,GAAG,CAAC,CAAA;IAC/B,IAAI,SAAS,IAAI,eAAe,CAAC,OAAO,CAAC,CAAA;IACzC,IAAI,WAAW,IAAI,eAAe,CAAC,OAAO,CAAC,CAAA;IAC3C,IAAI,YAAY,IAAI,eAAe,CAAC,OAAO,CAAC,CAAA;IAC5C,IAAI,gBAAgB,IAAI,sBAAsB,CAAC,OAAO,CAAC,CAAA;IACvD,IAAI,iBAAiB,IAAI,eAAe,CAAC,IAAI,CAAC,CAAA;IAC9C,IAAI,wBAAwB,IAAI,sBAAsB,CAAC,OAAO,CAAC,CAAA;IAC/D,IAAI,gBAAgB,IAAI,eAAe,CAAC,GAAG,CAAC,CAAA;IAC5C,IAAI,qBAAqB,IAAI,eAAe,CAAC,MAAM,CAAC,CAAA;IACpD,IAAI,WAAW,IAAI,eAAe,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC,CAAC,CAAA;IAC/D,IAAI,OAAO,IAAI,OAAO,CAAA;CACzB"}
|
package/dist/EngineFacade.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { DefaultObservableValue, int, MutableObservableValue, Nullable, ObservableValue, Observer, Subscription, UUID } from "@opendaw/lib-std";
|
|
2
|
-
import { ppqn } from "@opendaw/lib-dsp";
|
|
2
|
+
import { bpm, ppqn } from "@opendaw/lib-dsp";
|
|
3
3
|
import { ClipNotification, NoteSignal } from "@opendaw/studio-adapters";
|
|
4
4
|
import { Engine } from "./Engine";
|
|
5
5
|
import { EngineWorklet } from "./EngineWorklet";
|
|
@@ -16,6 +16,7 @@ export declare class EngineFacade implements Engine {
|
|
|
16
16
|
prepareRecordingState(countIn: boolean): void;
|
|
17
17
|
stopRecording(): void;
|
|
18
18
|
get position(): ObservableValue<ppqn>;
|
|
19
|
+
get bpm(): ObservableValue<bpm>;
|
|
19
20
|
get isPlaying(): ObservableValue<boolean>;
|
|
20
21
|
get isRecording(): ObservableValue<boolean>;
|
|
21
22
|
get isCountingIn(): ObservableValue<boolean>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"EngineFacade.d.ts","sourceRoot":"","sources":["../src/EngineFacade.ts"],"names":[],"mappings":"AAAA,OAAO,EACH,sBAAsB,EACtB,GAAG,EACH,sBAAsB,EACtB,QAAQ,EACR,eAAe,EACf,QAAQ,EAER,YAAY,EAEZ,IAAI,EACP,MAAM,kBAAkB,CAAA;AACzB,OAAO,EAAC,IAAI,EAAC,MAAM,kBAAkB,CAAA;
|
|
1
|
+
{"version":3,"file":"EngineFacade.d.ts","sourceRoot":"","sources":["../src/EngineFacade.ts"],"names":[],"mappings":"AAAA,OAAO,EACH,sBAAsB,EACtB,GAAG,EACH,sBAAsB,EACtB,QAAQ,EACR,eAAe,EACf,QAAQ,EAER,YAAY,EAEZ,IAAI,EACP,MAAM,kBAAkB,CAAA;AACzB,OAAO,EAAC,GAAG,EAAE,IAAI,EAAC,MAAM,kBAAkB,CAAA;AAC1C,OAAO,EAAC,gBAAgB,EAAE,UAAU,EAAC,MAAM,0BAA0B,CAAA;AACrE,OAAO,EAAC,MAAM,EAAC,MAAM,UAAU,CAAA;AAC/B,OAAO,EAAC,aAAa,EAAC,MAAM,iBAAiB,CAAA;AAC7C,OAAO,EAAC,OAAO,EAAC,MAAM,WAAW,CAAA;AAEjC,qBAAa,YAAa,YAAW,MAAM;;;IAoBvC,UAAU,CAAC,OAAO,EAAE,aAAa;IAqBjC,aAAa,IAAI,IAAI;IAErB,cAAc,IAAI,IAAI;IAMtB,IAAI,IAAI,IAAI;IACZ,IAAI,CAAC,KAAK,GAAE,OAAe,GAAG,IAAI;IAClC,WAAW,CAAC,QAAQ,EAAE,IAAI,GAAG,IAAI;IACjC,qBAAqB,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI;IAC7C,aAAa,IAAI,IAAI;IAErB,IAAI,QAAQ,IAAI,eAAe,CAAC,IAAI,CAAC,CAAwB;IAC7D,IAAI,GAAG,IAAI,eAAe,CAAC,GAAG,CAAC,CAAmB;IAClD,IAAI,SAAS,IAAI,eAAe,CAAC,OAAO,CAAC,CAAyB;IAClE,IAAI,WAAW,IAAI,eAAe,CAAC,OAAO,CAAC,CAA2B;IACtE,IAAI,YAAY,IAAI,eAAe,CAAC,OAAO,CAAC,CAA4B;IACxE,IAAI,gBAAgB,IAAI,sBAAsB,CAAC,OAAO,CAAC,CAAgC;IACvF,IAAI,iBAAiB,IAAI,eAAe,CAAC,IAAI,CAAC,CAAiC;IAC/E,IAAI,wBAAwB,IAAI,sBAAsB,CAAC,OAAO,CAAC,CAAwC;IACvG,IAAI,gBAAgB,IAAI,sBAAsB,CAAC,GAAG,CAAC,CAAgC;IACnF,IAAI,qBAAqB,IAAI,eAAe,CAAC,GAAG,CAAC,CAAqC;IACtF,IAAI,WAAW,IAAI,sBAAsB,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC,CAAC,CAA2B;IACjG,IAAI,OAAO,IAAI,OAAO,CAAmE;IACzF,IAAI,UAAU,IAAI,MAAM,CAAsF;IAE9G,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;IACxB,oBAAoB,IAAI,OAAO,CAAC,OAAO,CAAC;IAGxC,KAAK,IAAI,IAAI;IACb,KAAK,IAAI,IAAI;IACb,IAAI,IAAI,IAAI;IACZ,yBAAyB,CAAC,QAAQ,EAAE,QAAQ,CAAC,gBAAgB,CAAC,GAAG,YAAY;IAG7E,cAAc,CAAC,QAAQ,EAAE,QAAQ,CAAC,UAAU,CAAC,GAAG,YAAY;IAG5D,gBAAgB,CAAC,IAAI,EAAE,IAAI,CAAC,KAAK,GAAG,IAAI;IAGxC,UAAU,CAAC,MAAM,EAAE,UAAU,GAAG,IAAI;IAGpC,gBAAgB,CAAC,OAAO,EAAE,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,IAAI;IAG1D,gBAAgB,CAAC,QAAQ,EAAE,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,IAAI;IAI3D,SAAS,IAAI,IAAI;CAIpB"}
|
package/dist/EngineFacade.js
CHANGED
|
@@ -7,6 +7,7 @@ export class EngineFacade {
|
|
|
7
7
|
#countInBarsTotal = new DefaultObservableValue(1);
|
|
8
8
|
#countInBeatsRemaining = new DefaultObservableValue(0);
|
|
9
9
|
#position = new DefaultObservableValue(0.0);
|
|
10
|
+
#bpm = new DefaultObservableValue(12.0);
|
|
10
11
|
#isPlaying = new DefaultObservableValue(false);
|
|
11
12
|
#isRecording = new DefaultObservableValue(false);
|
|
12
13
|
#isCountingIn = new DefaultObservableValue(false);
|
|
@@ -17,7 +18,7 @@ export class EngineFacade {
|
|
|
17
18
|
setWorklet(worklet) {
|
|
18
19
|
this.#worklet = Option.wrap(worklet);
|
|
19
20
|
this.#lifecycle.terminate();
|
|
20
|
-
this.#lifecycle.ownAll(worklet.playbackTimestamp.catchupAndSubscribe(owner => this.#playbackTimestamp.setValue(owner.getValue())), worklet.playbackTimestampEnabled.catchupAndSubscribe(owner => this.#playbackTimestampEnabled.setValue(owner.getValue())), worklet.countInBarsTotal.catchupAndSubscribe(owner => this.#countInBarsTotal.setValue(owner.getValue())), worklet.countInBeatsRemaining.catchupAndSubscribe(owner => this.#countInBeatsRemaining.setValue(owner.getValue())), worklet.position.catchupAndSubscribe(owner => this.#position.setValue(owner.getValue())), worklet.isPlaying.catchupAndSubscribe(owner => this.#isPlaying.setValue(owner.getValue())), worklet.isRecording.catchupAndSubscribe(owner => this.#isRecording.setValue(owner.getValue())), worklet.isCountingIn.catchupAndSubscribe(owner => this.#isCountingIn.setValue(owner.getValue())), worklet.metronomeEnabled.catchupAndSubscribe(owner => this.#metronomeEnabled.setValue(owner.getValue())), worklet.markerState.catchupAndSubscribe(owner => this.#markerState.setValue(owner.getValue())), this.#metronomeEnabled.catchupAndSubscribe(owner => worklet.metronomeEnabled.setValue(owner.getValue())), this.#playbackTimestampEnabled.catchupAndSubscribe(owner => worklet.playbackTimestampEnabled.setValue(owner.getValue())), this.#countInBarsTotal.catchupAndSubscribe(owner => worklet.countInBarsTotal.setValue(owner.getValue())));
|
|
21
|
+
this.#lifecycle.ownAll(worklet.playbackTimestamp.catchupAndSubscribe(owner => this.#playbackTimestamp.setValue(owner.getValue())), worklet.playbackTimestampEnabled.catchupAndSubscribe(owner => this.#playbackTimestampEnabled.setValue(owner.getValue())), worklet.countInBarsTotal.catchupAndSubscribe(owner => this.#countInBarsTotal.setValue(owner.getValue())), worklet.countInBeatsRemaining.catchupAndSubscribe(owner => this.#countInBeatsRemaining.setValue(owner.getValue())), worklet.position.catchupAndSubscribe(owner => this.#position.setValue(owner.getValue())), worklet.bpm.catchupAndSubscribe(owner => this.#bpm.setValue(owner.getValue())), worklet.isPlaying.catchupAndSubscribe(owner => this.#isPlaying.setValue(owner.getValue())), worklet.isRecording.catchupAndSubscribe(owner => this.#isRecording.setValue(owner.getValue())), worklet.isCountingIn.catchupAndSubscribe(owner => this.#isCountingIn.setValue(owner.getValue())), worklet.metronomeEnabled.catchupAndSubscribe(owner => this.#metronomeEnabled.setValue(owner.getValue())), worklet.markerState.catchupAndSubscribe(owner => this.#markerState.setValue(owner.getValue())), this.#metronomeEnabled.catchupAndSubscribe(owner => worklet.metronomeEnabled.setValue(owner.getValue())), this.#playbackTimestampEnabled.catchupAndSubscribe(owner => worklet.playbackTimestampEnabled.setValue(owner.getValue())), this.#countInBarsTotal.catchupAndSubscribe(owner => worklet.countInBarsTotal.setValue(owner.getValue())));
|
|
21
22
|
}
|
|
22
23
|
assertWorklet() { this.#worklet.unwrap("No worklet available"); }
|
|
23
24
|
releaseWorklet() {
|
|
@@ -31,6 +32,7 @@ export class EngineFacade {
|
|
|
31
32
|
prepareRecordingState(countIn) { this.#worklet.ifSome(worklet => worklet.prepareRecordingState(countIn)); }
|
|
32
33
|
stopRecording() { this.#worklet.ifSome(worklet => worklet.stopRecording()); }
|
|
33
34
|
get position() { return this.#position; }
|
|
35
|
+
get bpm() { return this.#bpm; }
|
|
34
36
|
get isPlaying() { return this.#isPlaying; }
|
|
35
37
|
get isRecording() { return this.#isRecording; }
|
|
36
38
|
get isCountingIn() { return this.#isCountingIn; }
|
package/dist/EngineWorklet.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { int, MutableObservableValue, Nullable, ObservableValue, Observer, Subscription, UUID } from "@opendaw/lib-std";
|
|
2
|
-
import { ppqn } from "@opendaw/lib-dsp";
|
|
2
|
+
import { bpm, ppqn } from "@opendaw/lib-dsp";
|
|
3
3
|
import { ClipNotification, ExportStemsConfiguration, NoteSignal, ProcessorOptions } from "@opendaw/studio-adapters";
|
|
4
4
|
import { Engine } from "./Engine";
|
|
5
5
|
import { Project } from "./project";
|
|
@@ -22,6 +22,7 @@ export declare class EngineWorklet extends AudioWorkletNode implements Engine {
|
|
|
22
22
|
get countInBarsTotal(): MutableObservableValue<int>;
|
|
23
23
|
get countInBeatsRemaining(): ObservableValue<number>;
|
|
24
24
|
get position(): ObservableValue<ppqn>;
|
|
25
|
+
get bpm(): ObservableValue<bpm>;
|
|
25
26
|
get playbackTimestamp(): MutableObservableValue<number>;
|
|
26
27
|
get playbackTimestampEnabled(): MutableObservableValue<boolean>;
|
|
27
28
|
get metronomeEnabled(): MutableObservableValue<boolean>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"EngineWorklet.d.ts","sourceRoot":"","sources":["../src/EngineWorklet.ts"],"names":[],"mappings":"AAAA,OAAO,EAGH,GAAG,EACH,sBAAsB,EAEtB,QAAQ,EACR,eAAe,EACf,QAAQ,EAER,YAAY,EAGZ,IAAI,EACP,MAAM,kBAAkB,CAAA;AACzB,OAAO,EAAY,IAAI,EAAC,MAAM,kBAAkB,CAAA;
|
|
1
|
+
{"version":3,"file":"EngineWorklet.d.ts","sourceRoot":"","sources":["../src/EngineWorklet.ts"],"names":[],"mappings":"AAAA,OAAO,EAGH,GAAG,EACH,sBAAsB,EAEtB,QAAQ,EACR,eAAe,EACf,QAAQ,EAER,YAAY,EAGZ,IAAI,EACP,MAAM,kBAAkB,CAAA;AACzB,OAAO,EAAY,GAAG,EAAE,IAAI,EAAC,MAAM,kBAAkB,CAAA;AAIrD,OAAO,EACH,gBAAgB,EAOhB,wBAAwB,EACxB,UAAU,EACV,gBAAgB,EACnB,MAAM,0BAA0B,CAAA;AAEjC,OAAO,EAAC,MAAM,EAAC,MAAM,UAAU,CAAA;AAC/B,OAAO,EAAC,OAAO,EAAC,MAAM,WAAW,CAAA;AAIjC,qBAAa,aAAc,SAAQ,gBAAiB,YAAW,MAAM;;IACjE,MAAM,CAAC,EAAE,EAAE,GAAG,CAAQ;IAEtB,QAAQ,CAAC,EAAE,SAAqB;gBAwBpB,OAAO,EAAE,gBAAgB,EACzB,OAAO,EAAE,OAAO,EAChB,mBAAmB,CAAC,EAAE,wBAAwB,EAC9C,OAAO,CAAC,EAAE,gBAAgB;IA4ItC,IAAI,IAAI,IAAI;IACZ,IAAI,CAAC,KAAK,GAAE,OAAe,GAAG,IAAI;IAClC,WAAW,CAAC,QAAQ,EAAE,IAAI,GAAG,IAAI;IACjC,qBAAqB,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI;IAC7C,aAAa,IAAI,IAAI;IACrB,KAAK,IAAI,IAAI;IACb,KAAK,IAAI,IAAI;IAIb,IAAI,IAAI,IAAI;IAEZ,IAAI,SAAS,IAAI,eAAe,CAAC,OAAO,CAAC,CAAyB;IAClE,IAAI,WAAW,IAAI,eAAe,CAAC,OAAO,CAAC,CAA2B;IACtE,IAAI,YAAY,IAAI,eAAe,CAAC,OAAO,CAAC,CAA4B;IACxE,IAAI,gBAAgB,IAAI,sBAAsB,CAAC,GAAG,CAAC,CAAgC;IACnF,IAAI,qBAAqB,IAAI,eAAe,CAAC,MAAM,CAAC,CAAqC;IACzF,IAAI,QAAQ,IAAI,eAAe,CAAC,IAAI,CAAC,CAAwB;IAC7D,IAAI,GAAG,IAAI,eAAe,CAAC,GAAG,CAAC,CAAmB;IAClD,IAAI,iBAAiB,IAAI,sBAAsB,CAAC,MAAM,CAAC,CAAiC;IACxF,IAAI,wBAAwB,IAAI,sBAAsB,CAAC,OAAO,CAAC,CAAwC;IACvG,IAAI,gBAAgB,IAAI,sBAAsB,CAAC,OAAO,CAAC,CAAgC;IACvF,IAAI,WAAW,IAAI,eAAe,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC,CAAC,CAA2B;IAC1F,IAAI,OAAO,IAAI,OAAO,CAAuB;IAE7C,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;IACxB,oBAAoB,IAAI,OAAO,CAAC,OAAO,CAAC;IACxC,UAAU,CAAC,MAAM,EAAE,UAAU,GAAG,IAAI;IACpC,cAAc,CAAC,QAAQ,EAAE,QAAQ,CAAC,UAAU,CAAC,GAAG,YAAY;IAC5D,gBAAgB,CAAC,IAAI,EAAE,IAAI,CAAC,KAAK,GAAG,IAAI;IACxC,gBAAgB,CAAC,OAAO,EAAE,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,IAAI;IAI1D,gBAAgB,CAAC,QAAQ,EAAE,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,IAAI;IAG3D,yBAAyB,CAAC,QAAQ,EAAE,QAAQ,CAAC,gBAAgB,CAAC,GAAG,YAAY;IAQ7E,SAAS,IAAI,IAAI;CAKpB"}
|
package/dist/EngineWorklet.js
CHANGED
|
@@ -12,6 +12,7 @@ export class EngineWorklet extends AudioWorkletNode {
|
|
|
12
12
|
#playbackTimestamp = new DefaultObservableValue(0.0);
|
|
13
13
|
#playbackTimestampEnabled = new DefaultObservableValue(true);
|
|
14
14
|
#position = new DefaultObservableValue(0.0);
|
|
15
|
+
#bpm = new DefaultObservableValue(120.0);
|
|
15
16
|
#isPlaying = new DefaultObservableValue(false);
|
|
16
17
|
#isRecording = new DefaultObservableValue(false);
|
|
17
18
|
#isCountingIn = new DefaultObservableValue(false);
|
|
@@ -33,6 +34,7 @@ export class EngineWorklet extends AudioWorkletNode {
|
|
|
33
34
|
this.#isCountingIn.setValue(state.isCountingIn);
|
|
34
35
|
this.#countInBeatsRemaining.setValue(state.countInBeatsRemaining);
|
|
35
36
|
this.#playbackTimestamp.setValue(state.playbackTimestamp);
|
|
37
|
+
this.#bpm.setValue(state.bpm);
|
|
36
38
|
this.#position.setValue(state.position); // This must be the last to handle the state values before
|
|
37
39
|
});
|
|
38
40
|
const controlFlagsSAB = new SharedArrayBuffer(4); // 4 bytes minimum
|
|
@@ -105,7 +107,7 @@ export class EngineWorklet extends AudioWorkletNode {
|
|
|
105
107
|
const handler = project.sampleManager.getOrCreate(uuid);
|
|
106
108
|
const subscription = handler.subscribe(state => {
|
|
107
109
|
if (state.type === "error") {
|
|
108
|
-
reject(state.reason);
|
|
110
|
+
reject(new Error(state.reason));
|
|
109
111
|
subscription.terminate();
|
|
110
112
|
}
|
|
111
113
|
else if (state.type === "loaded") {
|
|
@@ -120,7 +122,7 @@ export class EngineWorklet extends AudioWorkletNode {
|
|
|
120
122
|
const handler = project.soundfontManager.getOrCreate(uuid);
|
|
121
123
|
const subscription = handler.subscribe(state => {
|
|
122
124
|
if (state.type === "error") {
|
|
123
|
-
reject(state.reason);
|
|
125
|
+
reject(new Error(state.reason));
|
|
124
126
|
subscription.terminate();
|
|
125
127
|
}
|
|
126
128
|
else if (state.type === "loaded") {
|
|
@@ -163,6 +165,7 @@ export class EngineWorklet extends AudioWorkletNode {
|
|
|
163
165
|
get countInBarsTotal() { return this.#countInBarsTotal; }
|
|
164
166
|
get countInBeatsRemaining() { return this.#countInBeatsRemaining; }
|
|
165
167
|
get position() { return this.#position; }
|
|
168
|
+
get bpm() { return this.#bpm; }
|
|
166
169
|
get playbackTimestamp() { return this.#playbackTimestamp; }
|
|
167
170
|
get playbackTimestampEnabled() { return this.#playbackTimestampEnabled; }
|
|
168
171
|
get metronomeEnabled() { return this.#metronomeEnabled; }
|
package/dist/ExternalLib.d.ts
CHANGED
|
@@ -1,5 +1,6 @@
|
|
|
1
|
+
import { Promises } from "@opendaw/lib-runtime";
|
|
1
2
|
export declare namespace ExternalLib {
|
|
2
|
-
const JSZip: () => Promise<import("jszip")
|
|
3
|
-
const SoundFont2: () => Promise<typeof import("soundfont2").SoundFont2
|
|
3
|
+
const JSZip: () => Promise<Promises.RejectedResult | Promises.ResolveResult<import("jszip")>>;
|
|
4
|
+
const SoundFont2: () => Promise<Promises.RejectedResult | Promises.ResolveResult<typeof import("soundfont2").SoundFont2>>;
|
|
4
5
|
}
|
|
5
6
|
//# sourceMappingURL=ExternalLib.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ExternalLib.d.ts","sourceRoot":"","sources":["../src/ExternalLib.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"ExternalLib.d.ts","sourceRoot":"","sources":["../src/ExternalLib.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,QAAQ,EAAC,MAAM,sBAAsB,CAAA;AAG7C,yBAAiB,WAAW,CAAC;IAMlB,MAAM,KAAK,kFAC+C,CAAA;IAE1D,MAAM,UAAU,yGACgD,CAAA;CAC1E"}
|
package/dist/ExternalLib.js
CHANGED
|
@@ -5,6 +5,6 @@ export var ExternalLib;
|
|
|
5
5
|
console.debug(`ExternalLib.importFailure count: ${count}, online: ${navigator.onLine}`, error);
|
|
6
6
|
return count < 10;
|
|
7
7
|
};
|
|
8
|
-
ExternalLib.JSZip = async () => await Promises.guardedRetry(() => import("jszip").then(({ default: JSZip }) => JSZip), callback);
|
|
9
|
-
ExternalLib.SoundFont2 = async () => await Promises.guardedRetry(() => import("soundfont2").then(({ SoundFont2 }) => SoundFont2), callback);
|
|
8
|
+
ExternalLib.JSZip = async () => await Promises.tryCatch(Promises.guardedRetry(() => import("jszip").then(({ default: JSZip }) => JSZip), callback));
|
|
9
|
+
ExternalLib.SoundFont2 = async () => await Promises.tryCatch(Promises.guardedRetry(() => import("soundfont2").then(({ SoundFont2 }) => SoundFont2), callback));
|
|
10
10
|
})(ExternalLib || (ExternalLib = {}));
|
package/dist/Preferences.d.ts
CHANGED
|
@@ -2,10 +2,13 @@ import { z } from "zod";
|
|
|
2
2
|
import { Observer, Subscription } from "@opendaw/lib-std";
|
|
3
3
|
declare const PreferencesSchema: z.ZodObject<{
|
|
4
4
|
"visible-help-hints": z.ZodDefault<z.ZodBoolean>;
|
|
5
|
+
"note-audition-while-editing": z.ZodDefault<z.ZodBoolean>;
|
|
6
|
+
"modifying-controls-wheel": z.ZodDefault<z.ZodBoolean>;
|
|
5
7
|
"auto-open-clips": z.ZodDefault<z.ZodBoolean>;
|
|
6
8
|
"auto-create-output-compressor": z.ZodDefault<z.ZodBoolean>;
|
|
7
9
|
"footer-show-fps-meter": z.ZodDefault<z.ZodBoolean>;
|
|
8
10
|
"footer-show-build-infos": z.ZodDefault<z.ZodBoolean>;
|
|
11
|
+
"normalize-mouse-wheel": z.ZodDefault<z.ZodBoolean>;
|
|
9
12
|
"dragging-use-pointer-lock": z.ZodDefault<z.ZodBoolean>;
|
|
10
13
|
"enable-beta-features": z.ZodDefault<z.ZodBoolean>;
|
|
11
14
|
}, z.core.$strip>;
|
|
@@ -13,10 +16,13 @@ export type Preferences = z.infer<typeof PreferencesSchema>;
|
|
|
13
16
|
export declare const Preferences: {
|
|
14
17
|
values: {
|
|
15
18
|
"visible-help-hints": boolean;
|
|
19
|
+
"note-audition-while-editing": boolean;
|
|
20
|
+
"modifying-controls-wheel": boolean;
|
|
16
21
|
"auto-open-clips": boolean;
|
|
17
22
|
"auto-create-output-compressor": boolean;
|
|
18
23
|
"footer-show-fps-meter": boolean;
|
|
19
24
|
"footer-show-build-infos": boolean;
|
|
25
|
+
"normalize-mouse-wheel": boolean;
|
|
20
26
|
"dragging-use-pointer-lock": boolean;
|
|
21
27
|
"enable-beta-features": boolean;
|
|
22
28
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Preferences.d.ts","sourceRoot":"","sources":["../src/Preferences.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,CAAC,EAAC,MAAM,KAAK,CAAA;AACrB,OAAO,EAAsB,QAAQ,EAAE,YAAY,EAAW,MAAM,kBAAkB,CAAA;AAEtF,QAAA,MAAM,iBAAiB
|
|
1
|
+
{"version":3,"file":"Preferences.d.ts","sourceRoot":"","sources":["../src/Preferences.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,CAAC,EAAC,MAAM,KAAK,CAAA;AACrB,OAAO,EAAsB,QAAQ,EAAE,YAAY,EAAW,MAAM,kBAAkB,CAAA;AAEtF,QAAA,MAAM,iBAAiB;;;;;;;;;;;iBAWrB,CAAA;AAEF,MAAM,MAAM,WAAW,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,iBAAiB,CAAC,CAAA;AAE3D,eAAO,MAAM,WAAW;;;;;;;;;;;;;0BAkCM,GAAG,SAAS,MAAM,WAAW,YACrC,QAAQ,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,YAAY,GAAG,KAAG,YAAY;CAK1E,CAAA"}
|
package/dist/Preferences.js
CHANGED
|
@@ -2,12 +2,15 @@ import { z } from "zod";
|
|
|
2
2
|
import { isDefined, Notifier, tryCatch } from "@opendaw/lib-std";
|
|
3
3
|
const PreferencesSchema = z.object({
|
|
4
4
|
"visible-help-hints": z.boolean().default(true),
|
|
5
|
-
"
|
|
5
|
+
"note-audition-while-editing": z.boolean().default(true),
|
|
6
|
+
"modifying-controls-wheel": z.boolean().default(false),
|
|
7
|
+
"auto-open-clips": z.boolean().default(true),
|
|
6
8
|
"auto-create-output-compressor": z.boolean().default(true),
|
|
7
9
|
"footer-show-fps-meter": z.boolean().default(false),
|
|
8
10
|
"footer-show-build-infos": z.boolean().default(false),
|
|
11
|
+
"normalize-mouse-wheel": z.boolean().default(false),
|
|
9
12
|
"dragging-use-pointer-lock": z.boolean().default(false),
|
|
10
|
-
"enable-beta-features": z.boolean().default(false)
|
|
13
|
+
"enable-beta-features": z.boolean().default(false)
|
|
11
14
|
});
|
|
12
15
|
export const Preferences = (() => {
|
|
13
16
|
const STORAGE_KEY = "preferences";
|
package/dist/Storage.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Storage.d.ts","sourceRoot":"","sources":["../src/Storage.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,IAAI,EAAC,MAAM,kBAAkB,CAAA;AAIrC,8BAAsB,OAAO,CAAC,IAAI,SAAS;IAAE,IAAI,EAAE,IAAI,CAAC,MAAM,CAAA;CAAE,GAAG,IAAI,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK;IAC/D,QAAQ,CAAC,MAAM,EAAE,MAAM;IAA7C,SAAS,aAAsB,MAAM,EAAE,MAAM;IAE7C,QAAQ,CAAC,IAAI,CAAC,IAAI,EAAE,GAAG,GAAG,OAAO,CAAC,IAAI,CAAC;IACvC,QAAQ,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC;IAEzC,UAAU,CAAC,IAAI,EAAE,IAAI,CAAC,KAAK,GAAG,OAAO,CAAC,IAAI,CAAC;IAQ3C,cAAc,IAAI,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAK7C,cAAc,CAAC,GAAG,EAAE,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;IAK9D,IAAI,IAAI,OAAO,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"Storage.d.ts","sourceRoot":"","sources":["../src/Storage.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,IAAI,EAAC,MAAM,kBAAkB,CAAA;AAIrC,8BAAsB,OAAO,CAAC,IAAI,SAAS;IAAE,IAAI,EAAE,IAAI,CAAC,MAAM,CAAA;CAAE,GAAG,IAAI,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK;IAC/D,QAAQ,CAAC,MAAM,EAAE,MAAM;IAA7C,SAAS,aAAsB,MAAM,EAAE,MAAM;IAE7C,QAAQ,CAAC,IAAI,CAAC,IAAI,EAAE,GAAG,GAAG,OAAO,CAAC,IAAI,CAAC;IACvC,QAAQ,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC;IAEzC,UAAU,CAAC,IAAI,EAAE,IAAI,CAAC,KAAK,GAAG,OAAO,CAAC,IAAI,CAAC;IAQ3C,cAAc,IAAI,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAK7C,cAAc,CAAC,GAAG,EAAE,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;IAK9D,IAAI,IAAI,OAAO,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;CAgB7C"}
|
package/dist/Storage.js
CHANGED
|
@@ -23,10 +23,19 @@ export class Storage {
|
|
|
23
23
|
}
|
|
24
24
|
async list() {
|
|
25
25
|
return Workers.Opfs.list(this.folder)
|
|
26
|
-
.then(
|
|
27
|
-
.
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
26
|
+
.then(async (files) => {
|
|
27
|
+
const results = await Promise.all(files.filter(file => file.kind === "directory")
|
|
28
|
+
.map(async ({ name }) => {
|
|
29
|
+
try {
|
|
30
|
+
const array = await Workers.Opfs.read(`${this.folder}/${name}/meta.json`);
|
|
31
|
+
return { uuid: name, ...JSON.parse(new TextDecoder().decode(array)) };
|
|
32
|
+
}
|
|
33
|
+
catch (e) {
|
|
34
|
+
console.warn(`Skipping corrupted entry: ${this.folder}/${name}`, e);
|
|
35
|
+
return null;
|
|
36
|
+
}
|
|
37
|
+
}));
|
|
38
|
+
return results.filter((item) => item !== null);
|
|
39
|
+
}, () => []);
|
|
31
40
|
}
|
|
32
41
|
}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { MutableObservableValue, Option, Terminable, UUID } from "@opendaw/lib-std";
|
|
2
2
|
import { AudioUnitBox } from "@opendaw/studio-boxes";
|
|
3
|
-
import { CaptureBox } from "@opendaw/studio-adapters";
|
|
3
|
+
import { AnyRegionBox, CaptureBox } from "@opendaw/studio-adapters";
|
|
4
4
|
import { CaptureDevices } from "./CaptureDevices";
|
|
5
5
|
export declare abstract class Capture<BOX extends CaptureBox = CaptureBox> implements Terminable {
|
|
6
6
|
#private;
|
|
@@ -18,5 +18,8 @@ export declare abstract class Capture<BOX extends CaptureBox = CaptureBox> imple
|
|
|
18
18
|
own<T extends Terminable>(terminable: T): T;
|
|
19
19
|
ownAll<T extends Terminable>(...terminables: ReadonlyArray<T>): void;
|
|
20
20
|
terminate(): void;
|
|
21
|
+
addRecordedRegion(region: AnyRegionBox): void;
|
|
22
|
+
recordedRegions(): ReadonlyArray<AnyRegionBox>;
|
|
23
|
+
clearRecordedRegions(): void;
|
|
21
24
|
}
|
|
22
25
|
//# sourceMappingURL=Capture.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Capture.d.ts","sourceRoot":"","sources":["../../src/capture/Capture.ts"],"names":[],"mappings":"AAAA,OAAO,EAGH,sBAAsB,EACtB,MAAM,EACN,UAAU,EAEV,IAAI,EACP,MAAM,kBAAkB,CAAA;AACzB,OAAO,EAAC,YAAY,EAAC,MAAM,uBAAuB,CAAA;AAClD,OAAO,EAAC,UAAU,EAAC,MAAM,0BAA0B,CAAA;
|
|
1
|
+
{"version":3,"file":"Capture.d.ts","sourceRoot":"","sources":["../../src/capture/Capture.ts"],"names":[],"mappings":"AAAA,OAAO,EAGH,sBAAsB,EACtB,MAAM,EACN,UAAU,EAEV,IAAI,EACP,MAAM,kBAAkB,CAAA;AACzB,OAAO,EAAC,YAAY,EAAC,MAAM,uBAAuB,CAAA;AAClD,OAAO,EAAC,YAAY,EAAE,UAAU,EAAC,MAAM,0BAA0B,CAAA;AACjE,OAAO,EAAC,cAAc,EAAC,MAAM,kBAAkB,CAAA;AAE/C,8BAAsB,OAAO,CAAC,GAAG,SAAS,UAAU,GAAG,UAAU,CAAE,YAAW,UAAU;;IAWpF,SAAS,aAAa,OAAO,EAAE,cAAc,EAAE,YAAY,EAAE,YAAY,EAAE,UAAU,EAAE,GAAG;IAmB1F,QAAQ,KAAK,KAAK,IAAI,MAAM,CAAA;IAC5B,QAAQ,KAAK,WAAW,IAAI,MAAM,CAAC,MAAM,CAAC,CAAA;IAC1C,QAAQ,CAAC,gBAAgB,IAAI,OAAO,CAAC,IAAI,CAAC;IAC1C,QAAQ,CAAC,cAAc,IAAI,UAAU;IAErC,IAAI,IAAI,IAAI,IAAI,CAAC,KAAK,CAAyC;IAC/D,IAAI,OAAO,IAAI,cAAc,CAAuB;IACpD,IAAI,YAAY,IAAI,YAAY,CAA4B;IAC5D,IAAI,UAAU,IAAI,GAAG,CAA0B;IAC/C,IAAI,KAAK,IAAI,sBAAsB,CAAC,OAAO,CAAC,CAAqB;IACjE,IAAI,QAAQ,IAAI,sBAAsB,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAwB;IAE9E,GAAG,CAAC,CAAC,SAAS,UAAU,EAAE,UAAU,EAAE,CAAC,GAAG,CAAC;IAC3C,MAAM,CAAC,CAAC,SAAS,UAAU,EAAE,GAAG,WAAW,EAAE,aAAa,CAAC,CAAC,CAAC,GAAG,IAAI;IACpE,SAAS,IAAI,IAAI;IAEjB,iBAAiB,CAAC,MAAM,EAAE,YAAY,GAAG,IAAI;IAC7C,eAAe,IAAI,aAAa,CAAC,YAAY,CAAC;IAC9C,oBAAoB,IAAI,IAAI;CAC/B"}
|
package/dist/capture/Capture.js
CHANGED
|
@@ -6,6 +6,7 @@ export class Capture {
|
|
|
6
6
|
#captureBox;
|
|
7
7
|
#deviceId;
|
|
8
8
|
#armed;
|
|
9
|
+
#recordedRegions = [];
|
|
9
10
|
constructor(manager, audioUnitBox, captureBox) {
|
|
10
11
|
this.#manager = manager;
|
|
11
12
|
this.#audioUnitBox = audioUnitBox;
|
|
@@ -29,4 +30,7 @@ export class Capture {
|
|
|
29
30
|
own(terminable) { return this.#terminator.own(terminable); }
|
|
30
31
|
ownAll(...terminables) { this.#terminator.ownAll(...terminables); }
|
|
31
32
|
terminate() { this.#terminator.terminate(); }
|
|
33
|
+
addRecordedRegion(region) { this.#recordedRegions.push(region); }
|
|
34
|
+
recordedRegions() { return this.#recordedRegions; }
|
|
35
|
+
clearRecordedRegions() { this.#recordedRegions.length = 0; }
|
|
32
36
|
}
|
|
@@ -31,7 +31,7 @@ export class CaptureDevices {
|
|
|
31
31
|
},
|
|
32
32
|
onRemoved: ({ box: { address: { uuid } } }) => {
|
|
33
33
|
this.#captures.removeByKeyIfExist(uuid)?.terminate();
|
|
34
|
-
this.#captureSubscriptions.
|
|
34
|
+
this.#captureSubscriptions.removeByKeyIfExist(uuid)?.subscription.terminate();
|
|
35
35
|
}
|
|
36
36
|
});
|
|
37
37
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"RecordAudio.d.ts","sourceRoot":"","sources":["../../src/capture/RecordAudio.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"RecordAudio.d.ts","sourceRoot":"","sources":["../../src/capture/RecordAudio.ts"],"names":[],"mappings":"AAAA,OAAO,EAA6B,UAAU,EAAmB,MAAM,kBAAkB,CAAA;AAUzF,OAAO,EAAa,mBAAmB,EAAY,MAAM,0BAA0B,CAAA;AACnF,OAAO,EAAC,OAAO,EAAC,MAAM,YAAY,CAAA;AAClC,OAAO,EAAC,gBAAgB,EAAC,MAAM,qBAAqB,CAAA;AACpD,OAAO,EAAC,OAAO,EAAC,MAAM,WAAW,CAAA;AAGjC,yBAAiB,WAAW,CAAC;IACzB,KAAK,kBAAkB,GAAG;QACtB,gBAAgB,EAAE,gBAAgB,CAAA;QAClC,WAAW,EAAE,WAAW,CAAA;QACxB,aAAa,EAAE,mBAAmB,CAAA;QAClC,YAAY,EAAE,YAAY,CAAA;QAC1B,OAAO,EAAE,OAAO,CAAA;QAChB,OAAO,EAAE,OAAO,CAAA;QAChB,MAAM,EAAE,MAAM,CAAA;KACjB,CAAA;IAED,MAAM,CAAC,MAAM,KAAK,GACd,0FAAwF,kBAAkB,KACxG,UAyFL,CAAA;;CACJ"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import { Option,
|
|
2
|
-
import { dbToGain, PPQN } from "@opendaw/lib-dsp";
|
|
3
|
-
import { AudioFileBox, AudioRegionBox, ValueEventCollectionBox } from "@opendaw/studio-boxes";
|
|
1
|
+
import { Option, quantizeFloor, Terminable, Terminator, UUID } from "@opendaw/lib-std";
|
|
2
|
+
import { dbToGain, PPQN, TimeBase } from "@opendaw/lib-dsp";
|
|
3
|
+
import { AudioFileBox, AudioPitchStretchBox, AudioRegionBox, ValueEventCollectionBox, WarpMarkerBox } from "@opendaw/studio-boxes";
|
|
4
4
|
import { ColorCodes, TrackType } from "@opendaw/studio-adapters";
|
|
5
5
|
import { RecordTrack } from "./RecordTrack";
|
|
6
6
|
export var RecordAudio;
|
|
@@ -31,17 +31,23 @@ export var RecordAudio;
|
|
|
31
31
|
const fileName = `Recording-${fileDateString}`;
|
|
32
32
|
const fileBox = AudioFileBox.create(boxGraph, uuid, box => box.fileName.setValue(fileName));
|
|
33
33
|
const collectionBox = ValueEventCollectionBox.create(boxGraph, UUID.generate());
|
|
34
|
+
const stretchBox = AudioPitchStretchBox.create(boxGraph, UUID.generate());
|
|
35
|
+
WarpMarkerBox.create(boxGraph, UUID.generate(), box => box.owner.refer(stretchBox.warpMarkers));
|
|
36
|
+
const warpMarkerBox = WarpMarkerBox.create(boxGraph, UUID.generate(), box => box.owner.refer(stretchBox.warpMarkers));
|
|
34
37
|
const regionBox = AudioRegionBox.create(boxGraph, UUID.generate(), box => {
|
|
35
38
|
box.file.refer(fileBox);
|
|
36
39
|
box.events.refer(collectionBox.owners);
|
|
37
40
|
box.regions.refer(trackBox.regions);
|
|
38
41
|
box.position.setValue(position);
|
|
39
42
|
box.hue.setValue(ColorCodes.forTrackType(TrackType.Audio));
|
|
43
|
+
box.timeBase.setValue(TimeBase.Musical);
|
|
40
44
|
box.label.setValue("Recording");
|
|
45
|
+
box.playMode.refer(stretchBox);
|
|
41
46
|
});
|
|
47
|
+
capture.addRecordedRegion(regionBox);
|
|
42
48
|
project.selection.select(regionBox);
|
|
43
|
-
return { fileBox, regionBox };
|
|
44
|
-
});
|
|
49
|
+
return { fileBox, regionBox, warpMarkerBox };
|
|
50
|
+
}, false);
|
|
45
51
|
const { tempoMap, env: { audioContext: { sampleRate } } } = project;
|
|
46
52
|
terminator.ownAll(Terminable.create(() => {
|
|
47
53
|
if (recordingWorklet.numberOfFrames === 0 || recordingData.isEmpty()) {
|
|
@@ -62,15 +68,19 @@ export var RecordAudio;
|
|
|
62
68
|
streamGain.connect(recordingWorklet);
|
|
63
69
|
recordingData = createRecordingData(quantizeFloor(owner.getValue(), beats));
|
|
64
70
|
}
|
|
65
|
-
const { regionBox } = recordingData.unwrap();
|
|
71
|
+
const { fileBox, regionBox, warpMarkerBox } = recordingData.unwrap();
|
|
66
72
|
editing.modify(() => {
|
|
67
73
|
if (regionBox.isAttached()) {
|
|
68
74
|
const { duration, loopDuration } = regionBox;
|
|
69
|
-
const
|
|
70
|
-
duration.setValue(
|
|
71
|
-
loopDuration.setValue(
|
|
72
|
-
|
|
75
|
+
const distanceInPPQN = Math.floor(engine.position.getValue() - regionBox.position.getValue());
|
|
76
|
+
duration.setValue(distanceInPPQN);
|
|
77
|
+
loopDuration.setValue(distanceInPPQN);
|
|
78
|
+
warpMarkerBox.position.setValue(distanceInPPQN);
|
|
79
|
+
const seconds = tempoMap.intervalToSeconds(0, distanceInPPQN);
|
|
80
|
+
const totalSamples = Math.ceil(seconds * sampleRate);
|
|
73
81
|
recordingWorklet.setFillLength(totalSamples);
|
|
82
|
+
fileBox.endInSeconds.setValue(seconds);
|
|
83
|
+
warpMarkerBox.seconds.setValue(seconds);
|
|
74
84
|
}
|
|
75
85
|
else {
|
|
76
86
|
terminator.terminate();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"RecordMidi.d.ts","sourceRoot":"","sources":["../../src/capture/RecordMidi.ts"],"names":[],"mappings":"AAAA,OAAO,EAAO,QAAQ,EAAuC,UAAU,EAAmB,MAAM,kBAAkB,CAAA;AAGlH,OAAO,EAAa,UAAU,EAAY,MAAM,0BAA0B,CAAA;AAC1E,OAAO,EAAC,OAAO,EAAC,MAAM,YAAY,CAAA;AAClC,OAAO,EAAC,OAAO,EAAC,MAAM,WAAW,CAAA;AAGjC,yBAAiB,UAAU,CAAC;IACxB,KAAK,iBAAiB,GAAG;QACrB,QAAQ,EAAE,QAAQ,CAAC,UAAU,CAAC,CAAC;QAC/B,OAAO,EAAE,OAAO,CAAC;QACjB,OAAO,EAAE,OAAO,CAAA;KACnB,CAAA;IAID,MAAM,CAAC,MAAM,KAAK,GAAI,gCAA8B,iBAAiB,KAAG,
|
|
1
|
+
{"version":3,"file":"RecordMidi.d.ts","sourceRoot":"","sources":["../../src/capture/RecordMidi.ts"],"names":[],"mappings":"AAAA,OAAO,EAAO,QAAQ,EAAuC,UAAU,EAAmB,MAAM,kBAAkB,CAAA;AAGlH,OAAO,EAAa,UAAU,EAAY,MAAM,0BAA0B,CAAA;AAC1E,OAAO,EAAC,OAAO,EAAC,MAAM,YAAY,CAAA;AAClC,OAAO,EAAC,OAAO,EAAC,MAAM,WAAW,CAAA;AAGjC,yBAAiB,UAAU,CAAC;IACxB,KAAK,iBAAiB,GAAG;QACrB,QAAQ,EAAE,QAAQ,CAAC,UAAU,CAAC,CAAC;QAC/B,OAAO,EAAE,OAAO,CAAC;QACjB,OAAO,EAAE,OAAO,CAAA;KACnB,CAAA;IAID,MAAM,CAAC,MAAM,KAAK,GAAI,gCAA8B,iBAAiB,KAAG,UAyEvE,CAAA;;CACJ"}
|
|
@@ -25,6 +25,7 @@ export var RecordMidi;
|
|
|
25
25
|
box.position.setValue(Math.max(quantizeRound(writePosition, beats), 0));
|
|
26
26
|
box.hue.setValue(ColorCodes.forTrackType(TrackType.Notes));
|
|
27
27
|
});
|
|
28
|
+
capture.addRecordedRegion(regionBox);
|
|
28
29
|
project.selection.select(regionBox);
|
|
29
30
|
engine.ignoreNoteRegion(regionBox.address.uuid);
|
|
30
31
|
writing = Option.wrap({ region: regionBox, collection });
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Recording.d.ts","sourceRoot":"","sources":["../../src/capture/Recording.ts"],"names":[],"mappings":"AAAA,OAAO,EAAuC,UAAU,EAAa,MAAM,kBAAkB,CAAA;AAK7F,OAAO,EAAC,OAAO,EAAC,MAAM,YAAY,CAAA;AAElC,qBAAa,SAAS;;IAClB,MAAM,KAAK,WAAW,IAAI,OAAO,CAA2B;WAE/C,KAAK,CAAC,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,GAAG,OAAO,CAAC,UAAU,CAAC;
|
|
1
|
+
{"version":3,"file":"Recording.d.ts","sourceRoot":"","sources":["../../src/capture/Recording.ts"],"names":[],"mappings":"AAAA,OAAO,EAAuC,UAAU,EAAa,MAAM,kBAAkB,CAAA;AAK7F,OAAO,EAAC,OAAO,EAAC,MAAM,YAAY,CAAA;AAElC,qBAAa,SAAS;;IAClB,MAAM,KAAK,WAAW,IAAI,OAAO,CAA2B;WAE/C,KAAK,CAAC,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,GAAG,OAAO,CAAC,UAAU,CAAC;IA8D3E,OAAO;CACV"}
|
|
@@ -24,6 +24,7 @@ export class Recording {
|
|
|
24
24
|
this.#isRecording = false;
|
|
25
25
|
return Errors.warn(String(error));
|
|
26
26
|
}
|
|
27
|
+
captures.forEach(capture => capture.clearRecordedRegions());
|
|
27
28
|
terminator.ownAll(...captures.map(capture => capture.startRecording()));
|
|
28
29
|
engine.prepareRecordingState(countIn);
|
|
29
30
|
const { isRecording, isCountingIn } = engine;
|
|
@@ -4,6 +4,6 @@ import { EqualizerSchema } from "@opendaw/lib-dawproject";
|
|
|
4
4
|
import { Pointers } from "@opendaw/studio-enums";
|
|
5
5
|
import { RevampDeviceBox } from "@opendaw/studio-boxes";
|
|
6
6
|
export declare namespace BuiltinDevices {
|
|
7
|
-
const equalizer: (boxGraph: BoxGraph, equalizer: EqualizerSchema, field: Field<Pointers.
|
|
7
|
+
const equalizer: (boxGraph: BoxGraph, equalizer: EqualizerSchema, field: Field<Pointers.MIDIEffectHost> | Field<Pointers.AudioEffectHost>, index: int) => RevampDeviceBox;
|
|
8
8
|
}
|
|
9
9
|
//# sourceMappingURL=BuiltinDevices.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DawProject.d.ts","sourceRoot":"","sources":["../../src/dawproject/DawProject.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"DawProject.d.ts","sourceRoot":"","sources":["../../src/dawproject/DawProject.ts"],"names":[],"mappings":"AAAA,OAAO,EAA+C,IAAI,EAAC,MAAM,kBAAkB,CAAA;AAEnF,OAAO,EAAsB,cAAc,EAAE,aAAa,EAAC,MAAM,yBAAyB,CAAA;AAC1F,OAAO,EAAC,eAAe,EAAE,mBAAmB,EAAC,MAAM,0BAA0B,CAAA;AAI7E,yBAAiB,UAAU,CAAC;IACxB,KAAY,QAAQ,GAAG;QAAE,IAAI,EAAE,IAAI,CAAC,KAAK,CAAC;QAAC,IAAI,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,WAAW,CAAA;KAAE,CAAA;IAE5F,UAAiB,gBAAgB;QAC7B,QAAQ,CAAC,IAAI,EAAE,MAAM,GAAG,QAAQ,CAAA;QAChC,QAAQ,CAAC,IAAI,EAAE,IAAI,CAAC,KAAK,GAAG,QAAQ,CAAA;KACvC;IAEM,MAAM,MAAM,GAAU,QAAQ,WAAW,GAAG,MAAM,CAAC,WAAW,CAAC,KAAG,OAAO,CAAC;QAC7E,QAAQ,EAAE,cAAc,CAAC;QACzB,OAAO,EAAE,aAAa,CAAC;QACvB,SAAS,EAAE,gBAAgB,CAAA;KAC9B,CAgCA,CAAA;IAEM,MAAM,MAAM,GAAU,UAAU,eAAe,EACzB,eAAe,mBAAmB,EAClC,UAAU,cAAc,KAAG,OAAO,CAAC,WAAW,CAwB1E,CAAA;CACJ"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { asDefined, isDefined, panic, UUID } from "@opendaw/lib-std";
|
|
1
|
+
import { asDefined, isDefined, panic, RuntimeNotifier, UUID } from "@opendaw/lib-std";
|
|
2
2
|
import { Xml } from "@opendaw/lib-xml";
|
|
3
3
|
import { FileReferenceSchema, MetaDataSchema, ProjectSchema } from "@opendaw/lib-dawproject";
|
|
4
4
|
import { DawProjectExporter } from "./DawProjectExporter";
|
|
@@ -6,7 +6,14 @@ import { ExternalLib } from "../ExternalLib";
|
|
|
6
6
|
export var DawProject;
|
|
7
7
|
(function (DawProject) {
|
|
8
8
|
DawProject.decode = async (buffer) => {
|
|
9
|
-
const JSZip = await ExternalLib.JSZip();
|
|
9
|
+
const { status, value: JSZip, error } = await ExternalLib.JSZip();
|
|
10
|
+
if (status === "rejected") {
|
|
11
|
+
await RuntimeNotifier.info({
|
|
12
|
+
headline: "Error",
|
|
13
|
+
message: `Could not load JSZip: ${String(error)}`
|
|
14
|
+
});
|
|
15
|
+
return Promise.reject(error);
|
|
16
|
+
}
|
|
10
17
|
const zip = await JSZip.loadAsync(buffer);
|
|
11
18
|
const metaDataXml = await zip.file("metadata.xml")?.async("string");
|
|
12
19
|
const metaData = isDefined(metaDataXml) ? Xml.parse(metaDataXml, MetaDataSchema) : Xml.element({}, MetaDataSchema);
|
|
@@ -30,7 +37,14 @@ export var DawProject;
|
|
|
30
37
|
};
|
|
31
38
|
};
|
|
32
39
|
DawProject.encode = async (skeleton, sampleManager, metaData) => {
|
|
33
|
-
const JSZip = await ExternalLib.JSZip();
|
|
40
|
+
const { status, value: JSZip, error } = await ExternalLib.JSZip();
|
|
41
|
+
if (status === "rejected") {
|
|
42
|
+
await RuntimeNotifier.info({
|
|
43
|
+
headline: "Error",
|
|
44
|
+
message: `Could not load JSZip: ${String(error)}`
|
|
45
|
+
});
|
|
46
|
+
return Promise.reject(error);
|
|
47
|
+
}
|
|
34
48
|
const zip = new JSZip();
|
|
35
49
|
const projectSchema = DawProjectExporter.write(skeleton, sampleManager, {
|
|
36
50
|
write: (path, buffer) => {
|
|
@@ -1,26 +1,14 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { Address,
|
|
1
|
+
import { Terminable } from "@opendaw/lib-std";
|
|
2
|
+
import { Address, Field, PrimitiveField, PrimitiveValues } from "@opendaw/lib-box";
|
|
3
3
|
import { Pointers } from "@opendaw/studio-enums";
|
|
4
4
|
import { Project } from "../project";
|
|
5
|
-
export type MIDIConnectionJSON = ({
|
|
6
|
-
type: "control";
|
|
7
|
-
controlId: byte;
|
|
8
|
-
}) & {
|
|
9
|
-
address: AddressJSON;
|
|
10
|
-
channel: byte;
|
|
11
|
-
} & JSONValue;
|
|
12
|
-
export interface MIDIConnection extends Terminable {
|
|
13
|
-
address: Address;
|
|
14
|
-
label: Provider<string>;
|
|
15
|
-
toJSON(): MIDIConnectionJSON;
|
|
16
|
-
}
|
|
17
5
|
export declare class MIDILearning implements Terminable {
|
|
18
6
|
#private;
|
|
19
7
|
constructor(project: Project);
|
|
8
|
+
followUser(field: Field<Pointers.MIDIControllers>): void;
|
|
20
9
|
hasMidiConnection(address: Address): boolean;
|
|
21
10
|
forgetMidiConnection(address: Address): void;
|
|
22
|
-
learnMIDIControls(field: PrimitiveField<PrimitiveValues, Pointers.
|
|
23
|
-
toJSON(): ReadonlyArray<MIDIConnectionJSON>;
|
|
11
|
+
learnMIDIControls(field: PrimitiveField<PrimitiveValues, Pointers.MIDIControl | Pointers>): Promise<void>;
|
|
24
12
|
terminate(): void;
|
|
25
13
|
}
|
|
26
14
|
//# sourceMappingURL=MIDILearning.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MIDILearning.d.ts","sourceRoot":"","sources":["../../src/midi/MIDILearning.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"MIDILearning.d.ts","sourceRoot":"","sources":["../../src/midi/MIDILearning.ts"],"names":[],"mappings":"AAAA,OAAO,EAYH,UAAU,EAGb,MAAM,kBAAkB,CAAA;AACzB,OAAO,EAAC,OAAO,EAAE,KAAK,EAAE,cAAc,EAAE,eAAe,EAAC,MAAM,kBAAkB,CAAA;AAEhF,OAAO,EAAC,QAAQ,EAAC,MAAM,uBAAuB,CAAA;AAC9C,OAAO,EAAC,OAAO,EAAC,MAAM,YAAY,CAAA;AAelC,qBAAa,YAAa,YAAW,UAAU;;gBAS/B,OAAO,EAAE,OAAO;IAK5B,UAAU,CAAC,KAAK,EAAE,KAAK,CAAC,QAAQ,CAAC,eAAe,CAAC,GAAG,IAAI;IAkBxD,iBAAiB,CAAC,OAAO,EAAE,OAAO,GAAG,OAAO;IAI5C,oBAAoB,CAAC,OAAO,EAAE,OAAO;IAK/B,iBAAiB,CAAC,KAAK,EAAE,cAAc,CAAC,eAAe,EAAE,QAAQ,CAAC,WAAW,GAAG,QAAQ,CAAC;IAsC/F,SAAS,IAAI,IAAI;CA8DpB"}
|