@opendaw/studio-adapters 0.0.35 → 0.0.37
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/AutomatableParameterFieldAdapter.js +3 -3
- package/dist/BoxAdapterCollection.js +3 -3
- package/dist/BoxAdapters.d.ts.map +1 -1
- package/dist/BoxAdapters.js +4 -0
- package/dist/IconSymbol.d.ts +116 -114
- package/dist/IconSymbol.d.ts.map +1 -1
- package/dist/IconSymbol.js +116 -114
- package/dist/IndexedBoxAdapterCollection.js +3 -3
- package/dist/ParameterAdapterSet.d.ts.map +1 -1
- package/dist/audio-unit/AudioUnitInput.d.ts.map +1 -1
- package/dist/audio-unit/AudioUnitInput.js +3 -4
- package/dist/devices/audio-effects/CompressorDeviceBoxAdapter.d.ts +39 -0
- package/dist/devices/audio-effects/CompressorDeviceBoxAdapter.d.ts.map +1 -0
- package/dist/devices/audio-effects/CompressorDeviceBoxAdapter.js +47 -0
- package/dist/devices/audio-effects/CrusherDeviceBoxAdapter.d.ts +31 -0
- package/dist/devices/audio-effects/CrusherDeviceBoxAdapter.d.ts.map +1 -0
- package/dist/devices/audio-effects/CrusherDeviceBoxAdapter.js +39 -0
- package/dist/devices/audio-effects/ModularDeviceBoxAdapter.d.ts.map +1 -1
- package/dist/devices/audio-effects/RevampDeviceBoxAdapter.js +3 -3
- package/dist/devices/instruments/Playfield/PlayfieldSampleBoxAdapter.d.ts.map +1 -1
- package/dist/devices/instruments/SoundfontDeviceBoxAdapter.d.ts.map +1 -1
- package/dist/devices/instruments/SoundfontDeviceBoxAdapter.js +12 -7
- package/dist/devices/instruments/VaporisateurDeviceBoxAdapter.js +1 -1
- package/dist/devices/midi-effects/PitchDeviceBoxAdapter.d.ts.map +1 -1
- package/dist/editing/UserEditing.d.ts +2 -2
- package/dist/editing/UserEditing.d.ts.map +1 -1
- package/dist/editing/UserEditingManager.d.ts +2 -2
- package/dist/editing/UserEditingManager.d.ts.map +1 -1
- package/dist/index.d.ts +2 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +2 -0
- package/dist/modular/modular.js +2 -2
- package/dist/modular/module.d.ts.map +1 -1
- package/dist/project/ProjectDecoder.d.ts.map +1 -1
- package/dist/project/ProjectDecoder.js +17 -41
- package/dist/project/ProjectMandatoryBoxes.d.ts +3 -3
- package/dist/project/ProjectMandatoryBoxes.d.ts.map +1 -1
- package/dist/protocols.d.ts +2 -1
- package/dist/protocols.d.ts.map +1 -1
- package/dist/sample/Sample.d.ts +14 -5
- package/dist/sample/Sample.d.ts.map +1 -1
- package/dist/sample/Sample.js +6 -1
- package/dist/sample/SampleMetaData.d.ts +13 -7
- package/dist/sample/SampleMetaData.d.ts.map +1 -1
- package/dist/sample/SampleMetaData.js +8 -1
- package/dist/selection/VertexSelection.d.ts +3 -3
- package/dist/selection/VertexSelection.d.ts.map +1 -1
- package/dist/selection/VertexSelection.js +3 -3
- package/dist/soundfont/Soundfont.d.ts +13 -5
- package/dist/soundfont/Soundfont.d.ts.map +1 -1
- package/dist/soundfont/Soundfont.js +6 -1
- package/dist/soundfont/SoundfontLoader.d.ts +1 -0
- package/dist/soundfont/SoundfontLoader.d.ts.map +1 -1
- package/dist/soundfont/SoundfontLoaderManager.d.ts +1 -0
- package/dist/soundfont/SoundfontLoaderManager.d.ts.map +1 -1
- package/dist/soundfont/SoundfontMetaData.d.ts +12 -6
- package/dist/soundfont/SoundfontMetaData.d.ts.map +1 -1
- package/dist/soundfont/SoundfontMetaData.js +8 -1
- package/dist/timeline/MarkerTrackAdapter.js +3 -3
- package/dist/timeline/TrackRegions.d.ts +5 -0
- package/dist/timeline/TrackRegions.d.ts.map +1 -1
- package/dist/timeline/TrackRegions.js +14 -5
- package/dist/timeline/TrackType.d.ts +1 -1
- package/dist/timeline/clip/AudioClipBoxAdapter.d.ts.map +1 -1
- package/dist/timeline/clip/AudioClipBoxAdapter.js +3 -3
- package/dist/timeline/clip/NoteClipBoxAdapter.d.ts.map +1 -1
- package/dist/timeline/clip/NoteClipBoxAdapter.js +8 -4
- package/dist/timeline/clip/ValueClipBoxAdapter.d.ts.map +1 -1
- package/dist/timeline/clip/ValueClipBoxAdapter.js +8 -4
- package/dist/timeline/collection/NoteEventCollectionBoxAdapter.js +6 -6
- package/dist/timeline/collection/ValueEventCollectionBoxAdapter.js +6 -6
- package/dist/timeline/event/ValueEventBoxAdapter.js +3 -3
- package/dist/timeline/region/AudioRegionBoxAdapter.d.ts.map +1 -1
- package/dist/timeline/region/AudioRegionBoxAdapter.js +3 -3
- package/dist/timeline/region/NoteRegionBoxAdapter.d.ts.map +1 -1
- package/dist/timeline/region/NoteRegionBoxAdapter.js +3 -3
- package/dist/timeline/region/ValueRegionBoxAdapter.d.ts.map +1 -1
- package/dist/timeline/region/ValueRegionBoxAdapter.js +3 -3
- package/package.json +37 -37
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { Bijective, int, Predicate, Selection, SelectionListener, Subscription } from "@opendaw/lib-std";
|
|
2
|
-
import { Addressable, BoxGraph,
|
|
2
|
+
import { Addressable, BoxGraph, BoxEditing, Field } from "@opendaw/lib-box";
|
|
3
3
|
import { Pointers } from "@opendaw/studio-enums";
|
|
4
4
|
import { SelectableVertex } from "./SelectableVertex";
|
|
5
5
|
import { FilteredSelection } from "./FilteredSelection";
|
|
@@ -9,9 +9,9 @@ import { FilteredSelection } from "./FilteredSelection";
|
|
|
9
9
|
*/
|
|
10
10
|
export declare class VertexSelection implements Selection<SelectableVertex> {
|
|
11
11
|
#private;
|
|
12
|
-
readonly editing:
|
|
12
|
+
readonly editing: BoxEditing;
|
|
13
13
|
readonly boxGraph: BoxGraph;
|
|
14
|
-
constructor(editing:
|
|
14
|
+
constructor(editing: BoxEditing, boxGraph: BoxGraph);
|
|
15
15
|
switch(target: Field<Pointers.Selection>): this;
|
|
16
16
|
release(): void;
|
|
17
17
|
createFilteredSelection<T extends Addressable>(affiliate: Predicate<SelectableVertex>, map: Bijective<T, SelectableVertex>): FilteredSelection<T>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"VertexSelection.d.ts","sourceRoot":"","sources":["../../src/selection/VertexSelection.ts"],"names":[],"mappings":"AAAA,OAAO,EAGH,SAAS,EACT,GAAG,EAGH,SAAS,EACT,SAAS,EACT,iBAAiB,EAEjB,YAAY,EAGf,MAAM,kBAAkB,CAAA;AACzB,OAAO,EAAU,WAAW,EAAE,QAAQ,EAAE,
|
|
1
|
+
{"version":3,"file":"VertexSelection.d.ts","sourceRoot":"","sources":["../../src/selection/VertexSelection.ts"],"names":[],"mappings":"AAAA,OAAO,EAGH,SAAS,EACT,GAAG,EAGH,SAAS,EACT,SAAS,EACT,iBAAiB,EAEjB,YAAY,EAGf,MAAM,kBAAkB,CAAA;AACzB,OAAO,EAAU,WAAW,EAAE,QAAQ,EAAE,UAAU,EAAE,KAAK,EAAe,MAAM,kBAAkB,CAAA;AAChG,OAAO,EAAC,QAAQ,EAAC,MAAM,uBAAuB,CAAA;AAE9C,OAAO,EAAC,gBAAgB,EAAC,MAAM,oBAAoB,CAAA;AAEnD,OAAO,EAAC,iBAAiB,EAAC,MAAM,qBAAqB,CAAA;AAErD;;;GAGG;AACH,qBAAa,eAAgB,YAAW,SAAS,CAAC,gBAAgB,CAAC;;IAQnD,QAAQ,CAAC,OAAO,EAAE,UAAU;IAAE,QAAQ,CAAC,QAAQ,EAAE,QAAQ;gBAAhD,OAAO,EAAE,UAAU,EAAW,QAAQ,EAAE,QAAQ;IAOrE,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,QAAQ,CAAC,SAAS,CAAC,GAAG,IAAI;IAQ/C,OAAO,IAAI,IAAI;IASf,uBAAuB,CAAC,CAAC,SAAS,WAAW,EAAE,SAAS,EAAE,SAAS,CAAC,gBAAgB,CAAC,EACtC,GAAG,EAAE,SAAS,CAAC,CAAC,EAAE,gBAAgB,CAAC,GAAG,iBAAiB,CAAC,CAAC,CAAC;IAIzG,MAAM,CAAC,GAAG,WAAW,EAAE,aAAa,CAAC,gBAAgB,CAAC,GAAG,IAAI;IAmB7D,QAAQ,CAAC,GAAG,WAAW,EAAE,aAAa,CAAC,gBAAgB,CAAC,GAAG,IAAI;IAU/D,WAAW,IAAI,IAAI;IAInB,QAAQ,CAAC,SAAS,EAAE,QAAQ,CAAC,gBAAgB,CAAC,GAAG,aAAa,CAAC,gBAAgB,CAAC;IAQhF,OAAO,IAAI,OAAO;IAElB,KAAK,IAAI,GAAG;IAEZ,UAAU,CAAC,UAAU,EAAE,gBAAgB,GAAG,OAAO;IAEjD,QAAQ,IAAI,aAAa,CAAC,gBAAgB,CAAC;IAE3C,SAAS,CAAC,QAAQ,EAAE,iBAAiB,CAAC,gBAAgB,CAAC,GAAG,YAAY;IAEtE,mBAAmB,CAAC,QAAQ,EAAE,iBAAiB,CAAC,gBAAgB,CAAC,GAAG,YAAY;CA4BnF"}
|
|
@@ -96,8 +96,8 @@ export class VertexSelection {
|
|
|
96
96
|
return this.#listeners.subscribe(listener);
|
|
97
97
|
}
|
|
98
98
|
#watch(target) {
|
|
99
|
-
return target.pointerHub.
|
|
100
|
-
|
|
99
|
+
return target.pointerHub.catchupAndSubscribe({
|
|
100
|
+
onAdded: (pointer) => {
|
|
101
101
|
const box = asInstanceOf(pointer.box, SelectionBox);
|
|
102
102
|
assert(box.isAttached(), "SelectionBox is not attached");
|
|
103
103
|
const selectable = box.selectable.targetVertex
|
|
@@ -108,7 +108,7 @@ export class VertexSelection {
|
|
|
108
108
|
assert(this.#entityMap.add(entry), "Could not add to entityMap");
|
|
109
109
|
assert(this.#selectableMap.add(entry), "Could not add to selectableMap");
|
|
110
110
|
},
|
|
111
|
-
|
|
111
|
+
onRemoved: (pointer) => {
|
|
112
112
|
const box = asInstanceOf(pointer.box, SelectionBox);
|
|
113
113
|
const entry = this.#entityMap.removeByKey(box.address.uuid);
|
|
114
114
|
assert(entry.box === box, "Broken selection");
|
|
@@ -1,6 +1,14 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
1
|
+
import { z } from "zod";
|
|
2
|
+
export declare const Soundfont: z.ZodObject<{
|
|
3
|
+
name: z.ZodString;
|
|
4
|
+
size: z.ZodNumber;
|
|
5
|
+
url: z.ZodString;
|
|
6
|
+
license: z.ZodString;
|
|
7
|
+
origin: z.ZodEnum<{
|
|
8
|
+
openDAW: "openDAW";
|
|
9
|
+
import: "import";
|
|
10
|
+
}>;
|
|
11
|
+
uuid: z.ZodPipe<z.ZodString, z.ZodTransform<`${string}-${string}-${string}-${string}-${string}`, string>>;
|
|
12
|
+
}, z.core.$strip>;
|
|
13
|
+
export type Soundfont = z.infer<typeof Soundfont>;
|
|
6
14
|
//# sourceMappingURL=Soundfont.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Soundfont.d.ts","sourceRoot":"","sources":["../../src/soundfont/Soundfont.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"Soundfont.d.ts","sourceRoot":"","sources":["../../src/soundfont/Soundfont.ts"],"names":[],"mappings":"AAEA,OAAO,EAAC,CAAC,EAAC,MAAM,KAAK,CAAA;AAErB,eAAO,MAAM,SAAS;;;;;;;;;;iBAEpB,CAAA;AAEF,MAAM,MAAM,SAAS,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,SAAS,CAAC,CAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SoundfontLoader.d.ts","sourceRoot":"","sources":["../../src/soundfont/SoundfontLoader.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,QAAQ,EAAE,MAAM,EAAE,YAAY,EAAE,IAAI,EAAC,MAAM,kBAAkB,CAAA;AACrE,OAAO,KAAK,EAAC,UAAU,EAAC,MAAM,YAAY,CAAA;AAC1C,OAAO,EAAC,oBAAoB,EAAC,MAAM,wBAAwB,CAAA;AAE3D,MAAM,WAAW,eAAe;IAC5B,IAAI,SAAS,IAAI,MAAM,CAAC,UAAU,CAAC,CAAA;IACnC,IAAI,IAAI,IAAI,IAAI,CAAC,KAAK,CAAA;IACtB,IAAI,KAAK,IAAI,oBAAoB,CAAA;IACjC,SAAS,CAAC,QAAQ,EAAE,QAAQ,CAAC,oBAAoB,CAAC,GAAG,YAAY,CAAA;
|
|
1
|
+
{"version":3,"file":"SoundfontLoader.d.ts","sourceRoot":"","sources":["../../src/soundfont/SoundfontLoader.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,QAAQ,EAAE,MAAM,EAAE,YAAY,EAAE,IAAI,EAAC,MAAM,kBAAkB,CAAA;AACrE,OAAO,KAAK,EAAC,UAAU,EAAC,MAAM,YAAY,CAAA;AAC1C,OAAO,EAAC,oBAAoB,EAAC,MAAM,wBAAwB,CAAA;AAE3D,MAAM,WAAW,eAAe;IAC5B,IAAI,SAAS,IAAI,MAAM,CAAC,UAAU,CAAC,CAAA;IACnC,IAAI,IAAI,IAAI,IAAI,CAAC,KAAK,CAAA;IACtB,IAAI,KAAK,IAAI,oBAAoB,CAAA;IACjC,SAAS,CAAC,QAAQ,EAAE,QAAQ,CAAC,oBAAoB,CAAC,GAAG,YAAY,CAAA;IACjE,UAAU,IAAI,IAAI,CAAA;CACrB"}
|
|
@@ -3,5 +3,6 @@ import { SoundfontLoader } from "./SoundfontLoader";
|
|
|
3
3
|
export interface SoundfontLoaderManager {
|
|
4
4
|
getOrCreate(uuid: UUID.Bytes): SoundfontLoader;
|
|
5
5
|
remove(uuid: UUID.Bytes): void;
|
|
6
|
+
invalidate(uuid: UUID.Bytes): void;
|
|
6
7
|
}
|
|
7
8
|
//# sourceMappingURL=SoundfontLoaderManager.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SoundfontLoaderManager.d.ts","sourceRoot":"","sources":["../../src/soundfont/SoundfontLoaderManager.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,IAAI,EAAC,MAAM,kBAAkB,CAAA;AACrC,OAAO,EAAC,eAAe,EAAC,MAAM,mBAAmB,CAAA;AAEjD,MAAM,WAAW,sBAAsB;IACnC,WAAW,CAAC,IAAI,EAAE,IAAI,CAAC,KAAK,GAAG,eAAe,CAAA;IAC9C,MAAM,CAAC,IAAI,EAAE,IAAI,CAAC,KAAK,GAAG,IAAI,CAAA;
|
|
1
|
+
{"version":3,"file":"SoundfontLoaderManager.d.ts","sourceRoot":"","sources":["../../src/soundfont/SoundfontLoaderManager.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,IAAI,EAAC,MAAM,kBAAkB,CAAA;AACrC,OAAO,EAAC,eAAe,EAAC,MAAM,mBAAmB,CAAA;AAEjD,MAAM,WAAW,sBAAsB;IACnC,WAAW,CAAC,IAAI,EAAE,IAAI,CAAC,KAAK,GAAG,eAAe,CAAA;IAC9C,MAAM,CAAC,IAAI,EAAE,IAAI,CAAC,KAAK,GAAG,IAAI,CAAA;IAC9B,UAAU,CAAC,IAAI,EAAE,IAAI,CAAC,KAAK,GAAG,IAAI,CAAA;CACrC"}
|
|
@@ -1,7 +1,13 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
1
|
+
import { z } from "zod";
|
|
2
|
+
export declare const SoundfontMetaData: z.ZodObject<{
|
|
3
|
+
name: z.ZodString;
|
|
4
|
+
size: z.ZodNumber;
|
|
5
|
+
url: z.ZodString;
|
|
6
|
+
license: z.ZodString;
|
|
7
|
+
origin: z.ZodEnum<{
|
|
8
|
+
openDAW: "openDAW";
|
|
9
|
+
import: "import";
|
|
10
|
+
}>;
|
|
11
|
+
}, z.core.$strip>;
|
|
12
|
+
export type SoundfontMetaData = z.infer<typeof SoundfontMetaData>;
|
|
7
13
|
//# sourceMappingURL=SoundfontMetaData.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SoundfontMetaData.d.ts","sourceRoot":"","sources":["../../src/soundfont/SoundfontMetaData.ts"],"names":[],"mappings":"AAAA,
|
|
1
|
+
{"version":3,"file":"SoundfontMetaData.d.ts","sourceRoot":"","sources":["../../src/soundfont/SoundfontMetaData.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,CAAC,EAAC,MAAM,KAAK,CAAA;AAErB,eAAO,MAAM,iBAAiB;;;;;;;;;iBAM5B,CAAA;AAEF,MAAM,MAAM,iBAAiB,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,iBAAiB,CAAC,CAAA"}
|
|
@@ -15,8 +15,8 @@ export class MarkerTrackAdapter {
|
|
|
15
15
|
this.changeNotifier = new Notifier();
|
|
16
16
|
this.#adapters = UUID.newSet(adapter => adapter.uuid);
|
|
17
17
|
this.#events = EventCollection.create(MarkerBoxAdapter.Comparator);
|
|
18
|
-
this.#subscription = this.#object.markers.pointerHub.
|
|
19
|
-
|
|
18
|
+
this.#subscription = this.#object.markers.pointerHub.catchupAndSubscribe({
|
|
19
|
+
onAdded: ({ box }) => {
|
|
20
20
|
if (box instanceof MarkerBox) {
|
|
21
21
|
const adapter = this.#context.boxAdapters.adapterFor(box, MarkerBoxAdapter);
|
|
22
22
|
const added = this.#adapters.add(adapter);
|
|
@@ -25,7 +25,7 @@ export class MarkerTrackAdapter {
|
|
|
25
25
|
this.dispatchChange();
|
|
26
26
|
}
|
|
27
27
|
},
|
|
28
|
-
|
|
28
|
+
onRemoved: ({ box: { address: { uuid } } }) => {
|
|
29
29
|
this.#events.remove(this.#adapters.removeByKey(uuid));
|
|
30
30
|
this.dispatchChange();
|
|
31
31
|
}
|
|
@@ -3,6 +3,10 @@ import { Observer, SortedSet, Subscription } from "@opendaw/lib-std";
|
|
|
3
3
|
import { TrackBoxAdapter } from "./TrackBoxAdapter";
|
|
4
4
|
import { AnyRegionBoxAdapter } from "../UnionAdapterTypes";
|
|
5
5
|
import { BoxAdapters } from "../BoxAdapters";
|
|
6
|
+
export interface TrackRegionsListener {
|
|
7
|
+
onAdded(region: AnyRegionBoxAdapter): void;
|
|
8
|
+
onRemoved(region: AnyRegionBoxAdapter): void;
|
|
9
|
+
}
|
|
6
10
|
export declare class TrackRegions {
|
|
7
11
|
#private;
|
|
8
12
|
constructor(adapter: TrackBoxAdapter, boxAdapters: BoxAdapters);
|
|
@@ -10,6 +14,7 @@ export declare class TrackRegions {
|
|
|
10
14
|
get collection(): RegionCollection<AnyRegionBoxAdapter>;
|
|
11
15
|
get adapters(): SortedSet<Readonly<Uint8Array>, AnyRegionBoxAdapter>;
|
|
12
16
|
onIndexingChanged(): void;
|
|
17
|
+
catchupAndSubscribe(listener: TrackRegionsListener): Subscription;
|
|
13
18
|
subscribeChanges(observer: Observer<void>): Subscription;
|
|
14
19
|
dispatchChange(): void;
|
|
15
20
|
terminate(): void;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TrackRegions.d.ts","sourceRoot":"","sources":["../../src/timeline/TrackRegions.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,gBAAgB,EAAC,MAAM,kBAAkB,CAAA;AACjD,OAAO,
|
|
1
|
+
{"version":3,"file":"TrackRegions.d.ts","sourceRoot":"","sources":["../../src/timeline/TrackRegions.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,gBAAgB,EAAC,MAAM,kBAAkB,CAAA;AACjD,OAAO,EAA8B,QAAQ,EAAE,SAAS,EAAE,YAAY,EAAmB,MAAM,kBAAkB,CAAA;AAEjH,OAAO,EAAC,eAAe,EAAC,MAAM,mBAAmB,CAAA;AACjD,OAAO,EAAC,mBAAmB,EAAC,MAAM,sBAAsB,CAAA;AACxD,OAAO,EAAC,WAAW,EAAC,MAAM,gBAAgB,CAAA;AAG1C,MAAM,WAAW,oBAAoB;IACjC,OAAO,CAAC,MAAM,EAAE,mBAAmB,GAAG,IAAI,CAAA;IAC1C,SAAS,CAAC,MAAM,EAAE,mBAAmB,GAAG,IAAI,CAAA;CAC/C;AAED,qBAAa,YAAY;;gBAST,OAAO,EAAE,eAAe,EAAE,WAAW,EAAE,WAAW;IA4B9D,IAAI,eAAe,IAAI,eAAe,CAA+B;IACrE,IAAI,UAAU,IAAI,gBAAgB,CAAC,mBAAmB,CAAC,CAA0B;IACjF,IAAI,QAAQ,IAAI,SAAS,CAAC,QAAQ,CAAC,UAAU,CAAC,EAAE,mBAAmB,CAAC,CAAwB;IAE5F,iBAAiB,IAAI,IAAI;IAKzB,mBAAmB,CAAC,QAAQ,EAAE,oBAAoB,GAAG,YAAY;IAKjE,gBAAgB,CAAC,QAAQ,EAAE,QAAQ,CAAC,IAAI,CAAC,GAAG,YAAY;IACxD,cAAc,IAAI,IAAI;IACtB,SAAS;CACZ"}
|
|
@@ -1,29 +1,34 @@
|
|
|
1
1
|
import { RegionCollection } from "@opendaw/lib-dsp";
|
|
2
|
-
import { assert, Notifier, Terminator, UUID } from "@opendaw/lib-std";
|
|
2
|
+
import { assert, Listeners, Notifier, Terminator, UUID } from "@opendaw/lib-std";
|
|
3
3
|
import { Pointers } from "@opendaw/studio-enums";
|
|
4
4
|
import { RegionAdapters, RegionComparator } from "./RegionBoxAdapter";
|
|
5
5
|
export class TrackRegions {
|
|
6
6
|
#trackBoxAdapter;
|
|
7
7
|
#terminator;
|
|
8
8
|
#changeNotifier;
|
|
9
|
+
#regionsListeners;
|
|
9
10
|
#collection;
|
|
10
11
|
#adapters;
|
|
11
12
|
constructor(adapter, boxAdapters) {
|
|
12
13
|
this.#trackBoxAdapter = adapter;
|
|
13
14
|
this.#terminator = new Terminator();
|
|
14
15
|
this.#changeNotifier = this.#terminator.own(new Notifier());
|
|
16
|
+
this.#regionsListeners = this.#terminator.own(new Listeners());
|
|
15
17
|
this.#collection = RegionCollection.create(RegionComparator);
|
|
16
18
|
this.#adapters = UUID.newSet(adapter => adapter.uuid);
|
|
17
|
-
this.#terminator.ownAll(this.#trackBoxAdapter.box.regions.pointerHub.
|
|
18
|
-
|
|
19
|
+
this.#terminator.ownAll(this.#trackBoxAdapter.box.regions.pointerHub.catchupAndSubscribe({
|
|
20
|
+
onAdded: ({ box }) => {
|
|
19
21
|
const adapter = RegionAdapters.for(boxAdapters, box);
|
|
20
22
|
const added = this.#adapters.add(adapter);
|
|
21
23
|
assert(added, `Cannot add ${box}`);
|
|
22
24
|
this.#collection.add(adapter);
|
|
25
|
+
this.#regionsListeners.forEach(listener => listener.onAdded(adapter));
|
|
23
26
|
this.dispatchChange();
|
|
24
27
|
},
|
|
25
|
-
|
|
26
|
-
this.#
|
|
28
|
+
onRemoved: ({ box: { address: { uuid } } }) => {
|
|
29
|
+
const adapter = this.#adapters.removeByKey(uuid);
|
|
30
|
+
this.#collection.remove(adapter);
|
|
31
|
+
this.#regionsListeners.forEach(listener => listener.onRemoved(adapter));
|
|
27
32
|
this.dispatchChange();
|
|
28
33
|
}
|
|
29
34
|
}, Pointers.RegionCollection));
|
|
@@ -35,6 +40,10 @@ export class TrackRegions {
|
|
|
35
40
|
this.#collection.onIndexingChanged();
|
|
36
41
|
this.dispatchChange();
|
|
37
42
|
}
|
|
43
|
+
catchupAndSubscribe(listener) {
|
|
44
|
+
this.collection.asArray().forEach(listener.onAdded);
|
|
45
|
+
return this.#regionsListeners.subscribe(listener);
|
|
46
|
+
}
|
|
38
47
|
subscribeChanges(observer) { return this.#changeNotifier.subscribe(observer); }
|
|
39
48
|
dispatchChange() { this.#changeNotifier.notify(); }
|
|
40
49
|
terminate() { this.#terminator.terminate(); }
|
|
@@ -7,6 +7,6 @@ export declare enum TrackType {
|
|
|
7
7
|
}
|
|
8
8
|
export declare namespace TrackType {
|
|
9
9
|
const toLabelString: (type: TrackType) => string;
|
|
10
|
-
const toIconSymbol: (type: TrackType) => IconSymbol.
|
|
10
|
+
const toIconSymbol: (type: TrackType) => IconSymbol.AudioBus | IconSymbol.Automation | IconSymbol.Piano | IconSymbol.Unknown | IconSymbol.Waveform;
|
|
11
11
|
}
|
|
12
12
|
//# sourceMappingURL=TrackType.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AudioClipBoxAdapter.d.ts","sourceRoot":"","sources":["../../../src/timeline/clip/AudioClipBoxAdapter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,IAAI,EAAO,MAAM,kBAAkB,CAAA;AAC3C,OAAO,EAEH,GAAG,
|
|
1
|
+
{"version":3,"file":"AudioClipBoxAdapter.d.ts","sourceRoot":"","sources":["../../../src/timeline/clip/AudioClipBoxAdapter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,IAAI,EAAO,MAAM,kBAAkB,CAAA;AAC3C,OAAO,EAEH,GAAG,EACH,KAAK,EAEL,eAAe,EACf,QAAQ,EACR,MAAM,EAEN,YAAY,EAEZ,IAAI,EACP,MAAM,kBAAkB,CAAA;AACzB,OAAO,EAAC,YAAY,EAAC,MAAM,uBAAuB,CAAA;AAClD,OAAO,EAAC,OAAO,EAAE,UAAU,EAAoC,MAAM,kBAAkB,CAAA;AACvF,OAAO,EAAC,cAAc,EAAE,qBAAqB,EAAC,MAAM,mBAAmB,CAAA;AAEvE,OAAO,EAAC,eAAe,EAAC,MAAM,oBAAoB,CAAA;AAClD,OAAO,EAAC,kBAAkB,EAAC,MAAM,0BAA0B,CAAA;AAC3D,OAAO,EAAC,mBAAmB,EAAC,MAAM,iCAAiC,CAAA;AAEnE,qBAAa,mBAAoB,YAAW,cAAc,CAAC,KAAK,CAAC;;IAC7D,QAAQ,CAAC,IAAI,gBAAe;gBAehB,OAAO,EAAE,kBAAkB,EAAE,GAAG,EAAE,YAAY;IA+B1D,2BAA2B,CAAC,QAAQ,EAAE,QAAQ,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC,GAAG,YAAY;IAIvF,eAAe,CAAC,QAAQ,EAAE,QAAQ,CAAC,IAAI,CAAC,GAAG,YAAY;IACvD,MAAM,CAAC,CAAC,EAAE,OAAO,EAAE,qBAAqB,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;IAEtD,WAAW,IAAI,IAAI;IACnB,KAAK,CAAC,SAAS,EAAE,OAAO,GAAG,IAAI;IAa/B,UAAU,IAAI,IAAI;IAClB,YAAY,IAAI,IAAI;IAEpB,IAAI,UAAU,IAAI,OAAO,CAAwC;IAEjE,SAAS,IAAI,IAAI;IAEjB,IAAI,GAAG,IAAI,YAAY,CAAmB;IAC1C,IAAI,IAAI,IAAI,IAAI,CAAC,KAAK,CAAgC;IACtD,IAAI,OAAO,IAAI,OAAO,CAA2B;IACjD,IAAI,UAAU,IAAI,UAAU,CAAyB;IACrD,IAAI,QAAQ,IAAI,IAAI,CAAuC;IAC3D,IAAI,IAAI,IAAI,OAAO,CAAmC;IACtD,IAAI,GAAG,IAAI,GAAG,CAAkC;IAChD,IAAI,IAAI,IAAI,MAAM,CAAmC;IACrD,IAAI,IAAI,IAAI,mBAAmB,CAAyD;IACxF,IAAI,aAAa,YAAyC;IAC1D,IAAI,aAAa,IAAI,MAAM,CAAC,KAAK,CAAC,CAAqB;IACvD,IAAI,KAAK,IAAI,MAAM,CAAoC;IACvD,IAAI,eAAe,IAAI,MAAM,CAAC,eAAe,CAAC,CAI7C;IACD,IAAI,UAAU,IAAI,OAAO,CAAe;IACxC,IAAI,SAAS,IAAI,OAAO,CAAe;IAEvC,QAAQ,IAAI,MAAM;CAMrB"}
|
|
@@ -20,9 +20,9 @@ export class AudioClipBoxAdapter {
|
|
|
20
20
|
this.#isConstructing = true;
|
|
21
21
|
this.#selectedValue = this.#terminator.own(new DefaultObservableValue(false));
|
|
22
22
|
this.#changeNotifier = this.#terminator.own(new Notifier());
|
|
23
|
-
this.#terminator.ownAll(this.#box.pointerHub.
|
|
24
|
-
|
|
25
|
-
|
|
23
|
+
this.#terminator.ownAll(this.#box.pointerHub.subscribe({
|
|
24
|
+
onAdded: () => this.#dispatchChange(),
|
|
25
|
+
onRemoved: () => this.#dispatchChange()
|
|
26
26
|
}), this.#box.file.catchupAndSubscribe((pointerField) => {
|
|
27
27
|
this.#fileAdapter = pointerField.targetVertex
|
|
28
28
|
.map(vertex => this.#context.boxAdapters.adapterFor(vertex.box, AudioFileBoxAdapter));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"NoteClipBoxAdapter.d.ts","sourceRoot":"","sources":["../../../src/timeline/clip/NoteClipBoxAdapter.ts"],"names":[],"mappings":"AAAA,OAAO,EAEH,GAAG,
|
|
1
|
+
{"version":3,"file":"NoteClipBoxAdapter.d.ts","sourceRoot":"","sources":["../../../src/timeline/clip/NoteClipBoxAdapter.ts"],"names":[],"mappings":"AAAA,OAAO,EAEH,GAAG,EACH,KAAK,EAEL,eAAe,EACf,QAAQ,EACR,MAAM,EAEN,YAAY,EAGZ,IAAI,EACP,MAAM,kBAAkB,CAAA;AACzB,OAAO,EAAC,eAAe,EAAE,IAAI,EAAO,MAAM,kBAAkB,CAAA;AAC5D,OAAO,EAAC,OAAO,EAAE,UAAU,EAAsB,MAAM,kBAAkB,CAAA;AACzE,OAAO,EAAC,WAAW,EAAC,MAAM,uBAAuB,CAAA;AACjD,OAAO,EAAC,6BAA6B,EAAC,MAAM,6CAA6C,CAAA;AACzF,OAAO,EAAC,cAAc,EAAE,qBAAqB,EAAC,MAAM,mBAAmB,CAAA;AACvE,OAAO,EAAC,kBAAkB,EAAC,MAAM,0BAA0B,CAAA;AAC3D,OAAO,EAAC,mBAAmB,EAAC,MAAM,8BAA8B,CAAA;AAChE,OAAO,EAAC,eAAe,EAAC,MAAM,oBAAoB,CAAA;AAElD,qBAAa,kBAAmB,YAAW,cAAc,CAAC,6BAA6B,CAAC;;IACpF,QAAQ,CAAC,IAAI,eAAc;gBAcf,OAAO,EAAE,kBAAkB,EAAE,GAAG,EAAE,WAAW;IA2BzD,2BAA2B,CAAC,QAAQ,EAAE,QAAQ,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC,GAAG,YAAY;IAIvF,eAAe,CAAC,QAAQ,EAAE,QAAQ,CAAC,IAAI,CAAC,GAAG,YAAY;IACvD,MAAM,CAAC,CAAC,EAAE,OAAO,EAAE,qBAAqB,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;IAEtD,WAAW,IAAI,IAAI;IAInB,KAAK,CAAC,WAAW,EAAE,OAAO,GAAG,IAAI;IAajC,UAAU,IAAI,IAAI;IAClB,YAAY,IAAI,IAAI;IAEpB,IAAI,UAAU,IAAI,OAAO,CAAwC;IAEjE,SAAS,IAAI,IAAI;IAKjB,IAAI,GAAG,IAAI,WAAW,CAAmB;IACzC,IAAI,IAAI,IAAI,IAAI,CAAC,KAAK,CAAgC;IACtD,IAAI,OAAO,IAAI,OAAO,CAA2B;IACjD,IAAI,UAAU,IAAI,UAAU,CAAyB;IACrD,IAAI,QAAQ,IAAI,IAAI,CAAuC;IAC3D,IAAI,IAAI,IAAI,OAAO,CAAmC;IACtD,IAAI,GAAG,IAAI,GAAG,CAAkC;IAChD,IAAI,MAAM,IAAI,MAAM,CAAC,eAAe,CAAC,mBAAmB,CAAC,CAAC,CAEzD;IACD,IAAI,aAAa,YAAyC;IAC1D,IAAI,aAAa,IAAI,MAAM,CAAC,6BAA6B,CAAC,CAGzD;IACD,IAAI,KAAK,IAAI,MAAM,CAAoC;IACvD,IAAI,eAAe,IAAI,MAAM,CAAC,eAAe,CAAC,CAI7C;IACD,IAAI,UAAU,IAAI,OAAO,CAA2E;IACpG,IAAI,SAAS,IAAI,OAAO,CAAc;IAEtC,QAAQ,IAAI,MAAM;CAMrB"}
|
|
@@ -19,9 +19,9 @@ export class NoteClipBoxAdapter {
|
|
|
19
19
|
this.#isConstructing = true;
|
|
20
20
|
this.#selectedValue = this.#terminator.own(new DefaultObservableValue(false));
|
|
21
21
|
this.#changeNotifier = this.#terminator.own(new Notifier());
|
|
22
|
-
this.#terminator.ownAll(this.#box.pointerHub.
|
|
23
|
-
|
|
24
|
-
|
|
22
|
+
this.#terminator.ownAll(this.#box.pointerHub.subscribe({
|
|
23
|
+
onAdded: () => this.#dispatchChange(),
|
|
24
|
+
onRemoved: () => this.#dispatchChange()
|
|
25
25
|
}), this.#box.subscribe(Propagation.Children, (_update) => this.#dispatchChange()), this.#box.events.catchupAndSubscribe(({ targetVertex }) => {
|
|
26
26
|
this.#eventCollectionSubscription.terminate();
|
|
27
27
|
this.#eventCollectionSubscription = targetVertex.match({
|
|
@@ -39,7 +39,11 @@ export class NoteClipBoxAdapter {
|
|
|
39
39
|
}
|
|
40
40
|
subscribeChange(observer) { return this.#changeNotifier.subscribe(observer); }
|
|
41
41
|
accept(visitor) { return safeExecute(visitor.visitNoteClipBoxAdapter, this); }
|
|
42
|
-
consolidate() {
|
|
42
|
+
consolidate() {
|
|
43
|
+
if (this.isMirrowed) {
|
|
44
|
+
this.#box.events.refer(this.optCollection.unwrap().copy().box.owners);
|
|
45
|
+
}
|
|
46
|
+
}
|
|
43
47
|
clone(consolidate) {
|
|
44
48
|
const events = consolidate ? this.optCollection.unwrap().copy().box.owners : this.#box.events.targetVertex.unwrap();
|
|
45
49
|
NoteClipBox.create(this.#context.boxGraph, UUID.generate(), box => {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ValueClipBoxAdapter.d.ts","sourceRoot":"","sources":["../../../src/timeline/clip/ValueClipBoxAdapter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,eAAe,EAAE,IAAI,EAAO,MAAM,kBAAkB,CAAA;AAC5D,OAAO,EAEH,GAAG,
|
|
1
|
+
{"version":3,"file":"ValueClipBoxAdapter.d.ts","sourceRoot":"","sources":["../../../src/timeline/clip/ValueClipBoxAdapter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,eAAe,EAAE,IAAI,EAAO,MAAM,kBAAkB,CAAA;AAC5D,OAAO,EAEH,GAAG,EACH,KAAK,EAEL,eAAe,EACf,QAAQ,EACR,MAAM,EAEN,YAAY,EAGZ,SAAS,EACT,IAAI,EACP,MAAM,kBAAkB,CAAA;AACzB,OAAO,EAAC,OAAO,EAAE,UAAU,EAAsB,MAAM,kBAAkB,CAAA;AACzE,OAAO,EAAC,cAAc,EAAE,qBAAqB,EAAC,MAAM,mBAAmB,CAAA;AACvE,OAAO,EAAC,eAAe,EAAC,MAAM,oBAAoB,CAAA;AAClD,OAAO,EAAC,8BAA8B,EAAC,MAAM,8CAA8C,CAAA;AAC3F,OAAO,EAAC,kBAAkB,EAAC,MAAM,0BAA0B,CAAA;AAC3D,OAAO,EAAC,YAAY,EAAC,MAAM,uBAAuB,CAAA;AAClD,OAAO,EAAC,oBAAoB,EAAC,MAAM,+BAA+B,CAAA;AAElE,qBAAa,mBAAoB,YAAW,cAAc,CAAC,8BAA8B,CAAC;;IACtF,QAAQ,CAAC,IAAI,gBAAe;gBAahB,OAAO,EAAE,kBAAkB,EAAE,GAAG,EAAE,YAAY;IA4B1D,OAAO,CAAC,QAAQ,EAAE,IAAI,EAAE,QAAQ,EAAE,SAAS,GAAG,SAAS;IAKvD,2BAA2B,CAAC,QAAQ,EAAE,QAAQ,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC,GAAG,YAAY;IAGvF,eAAe,CAAC,QAAQ,EAAE,QAAQ,CAAC,IAAI,CAAC,GAAG,YAAY;IACvD,MAAM,CAAC,CAAC,EAAE,OAAO,EAAE,qBAAqB,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;IAEtD,WAAW,IAAI,IAAI;IAInB,KAAK,CAAC,WAAW,EAAE,OAAO,GAAG,IAAI;IAajC,UAAU,IAAI,IAAI;IAClB,YAAY,IAAI,IAAI;IAEpB,IAAI,UAAU,IAAI,OAAO,CAAwC;IAEjE,SAAS,IAAI,IAAI;IAKjB,IAAI,GAAG,IAAI,YAAY,CAAmB;IAC1C,IAAI,IAAI,IAAI,IAAI,CAAC,KAAK,CAAgC;IACtD,IAAI,OAAO,IAAI,OAAO,CAA2B;IACjD,IAAI,UAAU,IAAI,UAAU,CAAyB;IACrD,IAAI,QAAQ,IAAI,IAAI,CAAuC;IAC3D,IAAI,IAAI,IAAI,OAAO,CAAmC;IACtD,IAAI,GAAG,IAAI,GAAG,CAAkC;IAChD,IAAI,aAAa,YAAyC;IAC1D,IAAI,MAAM,IAAI,MAAM,CAAC,eAAe,CAAC,oBAAoB,CAAC,CAAC,CAE1D;IACD,IAAI,aAAa,IAAI,MAAM,CAAC,8BAA8B,CAAC,CAG1D;IACD,IAAI,KAAK,IAAI,MAAM,CAAoC;IACvD,IAAI,eAAe,IAAI,MAAM,CAAC,eAAe,CAAC,CAI7C;IACD,IAAI,UAAU,IAAI,OAAO,CAA2E;IACpG,IAAI,SAAS,IAAI,OAAO,CAAc;IAEtC,QAAQ,IAAI,MAAM;CAMrB"}
|
|
@@ -19,9 +19,9 @@ export class ValueClipBoxAdapter {
|
|
|
19
19
|
this.#isConstructing = true;
|
|
20
20
|
this.#selectedValue = this.#terminator.own(new DefaultObservableValue(false));
|
|
21
21
|
this.#changeNotifier = this.#terminator.own(new Notifier());
|
|
22
|
-
this.#terminator.own(this.#box.pointerHub.
|
|
23
|
-
|
|
24
|
-
|
|
22
|
+
this.#terminator.own(this.#box.pointerHub.subscribe({
|
|
23
|
+
onAdded: () => this.#dispatchChange(),
|
|
24
|
+
onRemoved: () => this.#dispatchChange()
|
|
25
25
|
}));
|
|
26
26
|
this.#terminator.own(this.#box.subscribe(Propagation.Children, (_update) => this.#dispatchChange()));
|
|
27
27
|
this.#terminator.own(this.#box.events.catchupAndSubscribe(({ targetVertex }) => {
|
|
@@ -45,7 +45,11 @@ export class ValueClipBoxAdapter {
|
|
|
45
45
|
}
|
|
46
46
|
subscribeChange(observer) { return this.#changeNotifier.subscribe(observer); }
|
|
47
47
|
accept(visitor) { return safeExecute(visitor.visitValueClipBoxAdapter, this); }
|
|
48
|
-
consolidate() {
|
|
48
|
+
consolidate() {
|
|
49
|
+
if (this.isMirrowed) {
|
|
50
|
+
this.#box.events.refer(this.optCollection.unwrap().copy().box.owners);
|
|
51
|
+
}
|
|
52
|
+
}
|
|
49
53
|
clone(consolidate) {
|
|
50
54
|
const events = consolidate ? this.optCollection.unwrap().copy().box.owners : this.#box.events.targetVertex.unwrap();
|
|
51
55
|
ValueClipBox.create(this.#context.boxGraph, UUID.generate(), box => {
|
|
@@ -30,16 +30,16 @@ export class NoteEventCollectionBoxAdapter {
|
|
|
30
30
|
}
|
|
31
31
|
};
|
|
32
32
|
this.#box.events.pointerHub.incoming().forEach(({ box }) => addNoteProcedure(box));
|
|
33
|
-
this.#terminator.own(this.#box.events.pointerHub.
|
|
34
|
-
|
|
35
|
-
|
|
33
|
+
this.#terminator.own(this.#box.events.pointerHub.subscribe({
|
|
34
|
+
onAdded: ({ box }) => addNoteProcedure(box),
|
|
35
|
+
onRemoved: ({ box: { address: { uuid } } }) => {
|
|
36
36
|
this.#events.remove(this.#adapters.removeByKey(uuid));
|
|
37
37
|
this.#onEventsChanged();
|
|
38
38
|
}
|
|
39
39
|
}));
|
|
40
|
-
this.#terminator.own(this.#box.owners.pointerHub.
|
|
41
|
-
|
|
42
|
-
|
|
40
|
+
this.#terminator.own(this.#box.owners.pointerHub.subscribe({
|
|
41
|
+
onAdded: () => this.#changeNotifier.notify(this),
|
|
42
|
+
onRemoved: () => this.#changeNotifier.notify(this)
|
|
43
43
|
}));
|
|
44
44
|
}
|
|
45
45
|
copy() {
|
|
@@ -27,16 +27,16 @@ export class ValueEventCollectionBoxAdapter {
|
|
|
27
27
|
}
|
|
28
28
|
};
|
|
29
29
|
this.#box.events.pointerHub.incoming().forEach(({ box }) => addValueProcedure(box));
|
|
30
|
-
this.#terminator.own(this.#box.events.pointerHub.
|
|
31
|
-
|
|
32
|
-
|
|
30
|
+
this.#terminator.own(this.#box.events.pointerHub.subscribe({
|
|
31
|
+
onAdded: ({ box }) => addValueProcedure(box),
|
|
32
|
+
onRemoved: ({ box: { address: { uuid } } }) => {
|
|
33
33
|
this.#events.remove(this.#adapters.removeByKey(uuid));
|
|
34
34
|
this.#onEventsChanged();
|
|
35
35
|
}
|
|
36
36
|
}));
|
|
37
|
-
this.#terminator.own(this.#box.owners.pointerHub.
|
|
38
|
-
|
|
39
|
-
|
|
37
|
+
this.#terminator.own(this.#box.owners.pointerHub.subscribe({
|
|
38
|
+
onAdded: () => this.#changeNotifier.notify(this),
|
|
39
|
+
onRemoved: () => this.#changeNotifier.notify(this)
|
|
40
40
|
}));
|
|
41
41
|
}
|
|
42
42
|
valueAt(position, fallback) { return ValueEvent.valueAt(this.#events, position, fallback); }
|
|
@@ -47,13 +47,13 @@ export class ValueEventBoxAdapter {
|
|
|
47
47
|
collection.onEventPropertyChanged();
|
|
48
48
|
}
|
|
49
49
|
}
|
|
50
|
-
}), this.#box.interpolation.subscribe(invalidateInterpolation), this.#box.interpolation.pointerHub.
|
|
51
|
-
|
|
50
|
+
}), this.#box.interpolation.subscribe(invalidateInterpolation), this.#box.interpolation.pointerHub.subscribe({
|
|
51
|
+
onAdded: ({ box }) => {
|
|
52
52
|
this.#interpolationSubscription.terminate();
|
|
53
53
|
this.#interpolationSubscription = box.subscribe(Propagation.Children, invalidateInterpolation);
|
|
54
54
|
invalidateInterpolation();
|
|
55
55
|
},
|
|
56
|
-
|
|
56
|
+
onRemoved: () => {
|
|
57
57
|
this.#interpolationSubscription.terminate();
|
|
58
58
|
this.#interpolationSubscription = Terminable.Empty;
|
|
59
59
|
invalidateInterpolation();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AudioRegionBoxAdapter.d.ts","sourceRoot":"","sources":["../../../src/timeline/region/AudioRegionBoxAdapter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,cAAc,EAAC,MAAM,uBAAuB,CAAA;AACpD,OAAO,EAAC,GAAG,
|
|
1
|
+
{"version":3,"file":"AudioRegionBoxAdapter.d.ts","sourceRoot":"","sources":["../../../src/timeline/region/AudioRegionBoxAdapter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,cAAc,EAAC,MAAM,uBAAuB,CAAA;AACpD,OAAO,EAAC,GAAG,EAAE,KAAK,EAAY,QAAQ,EAAE,MAAM,EAAe,YAAY,EAAc,IAAI,EAAC,MAAM,kBAAkB,CAAA;AACpH,OAAO,EAAC,QAAQ,EAAC,MAAM,uBAAuB,CAAA;AAC9C,OAAO,EAAC,OAAO,EAAE,KAAK,EAAoC,MAAM,kBAAkB,CAAA;AAClF,OAAO,EAAO,IAAI,EAAC,MAAM,kBAAkB,CAAA;AAC3C,OAAO,EAAC,eAAe,EAAC,MAAM,oBAAoB,CAAA;AAClD,OAAO,EAAC,wBAAwB,EAAE,gBAAgB,EAAE,uBAAuB,EAAC,MAAM,qBAAqB,CAAA;AACvG,OAAO,EAAC,kBAAkB,EAAC,MAAM,0BAA0B,CAAA;AAC3D,OAAO,EAAC,mBAAmB,EAAC,MAAM,iCAAiC,CAAA;AAEnE,KAAK,YAAY,GAAG;IAChB,KAAK,CAAC,EAAE,KAAK,CAAC,QAAQ,CAAC,gBAAgB,CAAC,CAAA;IACxC,QAAQ,CAAC,EAAE,IAAI,CAAA;IACf,QAAQ,CAAC,EAAE,IAAI,CAAA;IACf,UAAU,CAAC,EAAE,IAAI,CAAA;IACjB,YAAY,CAAC,EAAE,IAAI,CAAA;CACtB,CAAA;AAED,qBAAa,qBAAsB,YAAW,wBAAwB,CAAC,KAAK,CAAC;;IACzE,QAAQ,CAAC,IAAI,kBAAiB;gBAelB,OAAO,EAAE,kBAAkB,EAAE,GAAG,EAAE,cAAc;IA+C5D,eAAe,CAAC,QAAQ,EAAE,QAAQ,CAAC,IAAI,CAAC,GAAG,YAAY;IAEvD,MAAM,CAAC,CAAC,EAAE,OAAO,EAAE,uBAAuB,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;IAIxD,UAAU,IAAI,IAAI;IAKlB,YAAY,IAAI,IAAI;IAKpB,IAAI,UAAU,IAAI,OAAO,CAA0B;IAEnD,SAAS;IAET,IAAI,GAAG,IAAI,cAAc,CAAmB;IAE5C,IAAI,IAAI,IAAI,IAAI,CAAC,KAAK,CAAgC;IACtD,IAAI,OAAO,IAAI,OAAO,CAA2B;IACjD,IAAI,QAAQ,IAAI,GAAG,CAAuC;IAC1D,IAAI,QAAQ,IAAI,GAAG,CAUlB;IACD,IAAI,QAAQ,IAAI,GAAG,CAAuC;IAC1D,IAAI,UAAU,IAAI,IAAI,CAAyC;IAC/D,IAAI,YAAY,IAAI,IAAI,CAA2C;IACnE,IAAI,MAAM,IAAI,IAAI,CAAyC;IAC3D,IAAI,IAAI,IAAI,OAAO,CAAmC;IACtD,IAAI,GAAG,IAAI,GAAG,CAAkC;IAChD,IAAI,IAAI,IAAI,MAAM,CAAmC;IACrD,IAAI,IAAI,IAAI,mBAAmB,CAAyD;IACxF,IAAI,aAAa,YAAwC;IACzD,IAAI,aAAa,IAAI,MAAM,CAAC,KAAK,CAAC,CAAqB;IACvD,IAAI,KAAK,IAAI,MAAM,CAMlB;IACD,IAAI,UAAU,IAAI,OAAO,CAAe;IACxC,IAAI,SAAS,IAAI,OAAO,CAAe;IACvC,IAAI,eAAe,IAAI,MAAM,CAAC,eAAe,CAAC,CAG7C;IAED,MAAM,CAAC,MAAM,CAAC,EAAE,YAAY,GAAG,qBAAqB;IAepD,WAAW,IAAI,IAAI;IAGnB,UAAU,CAAC,QAAQ,EAAE,aAAa,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,GAAG,OAAO;IACvE,OAAO,CAAC,QAAQ,EAAE,aAAa,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,GAAG,MAAM,CAAC,cAAc,CAAC;IAInF,QAAQ,IAAI,MAAM;CAOrB"}
|
|
@@ -23,9 +23,9 @@ export class AudioRegionBoxAdapter {
|
|
|
23
23
|
this.#constructing = true;
|
|
24
24
|
// TODO For unsyned audio samples
|
|
25
25
|
// this.#terminator.own(this.#project.timelineBox.bpm.subscribe(() => this.trackAdapter.unwrapOrNull()?.dispatchChange()))
|
|
26
|
-
this.#terminator.ownAll(this.#box.pointerHub.
|
|
27
|
-
|
|
28
|
-
|
|
26
|
+
this.#terminator.ownAll(this.#box.pointerHub.subscribe({
|
|
27
|
+
onAdded: () => this.#dispatchChange(),
|
|
28
|
+
onRemoved: () => this.#dispatchChange()
|
|
29
29
|
}), this.#box.file.catchupAndSubscribe((pointerField) => {
|
|
30
30
|
this.#fileAdapter = pointerField.targetVertex.map(vertex => this.#context.boxAdapters.adapterFor(vertex.box, AudioFileBoxAdapter));
|
|
31
31
|
this.#fileSubscription.ifSome(subscription => subscription.terminate());
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"NoteRegionBoxAdapter.d.ts","sourceRoot":"","sources":["../../../src/timeline/region/NoteRegionBoxAdapter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAiB,SAAS,EAAE,IAAI,EAAyB,MAAM,kBAAkB,CAAA;AACxF,OAAO,EAEH,GAAG,
|
|
1
|
+
{"version":3,"file":"NoteRegionBoxAdapter.d.ts","sourceRoot":"","sources":["../../../src/timeline/region/NoteRegionBoxAdapter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAiB,SAAS,EAAE,IAAI,EAAyB,MAAM,kBAAkB,CAAA;AACxF,OAAO,EAEH,GAAG,EACH,KAAK,EAEL,QAAQ,EACR,MAAM,EAEN,YAAY,EAGZ,IAAI,EACP,MAAM,kBAAkB,CAAA;AACzB,OAAO,EAAC,OAAO,EAAE,KAAK,EAAsB,MAAM,kBAAkB,CAAA;AACpE,OAAO,EAAC,QAAQ,EAAC,MAAM,uBAAuB,CAAA;AAC9C,OAAO,EAAyB,aAAa,EAAC,MAAM,uBAAuB,CAAA;AAC3E,OAAO,EAAC,eAAe,EAAC,MAAM,oBAAoB,CAAA;AAClD,OAAO,EAAC,wBAAwB,EAAE,gBAAgB,EAAE,uBAAuB,EAAC,MAAM,qBAAqB,CAAA;AACvG,OAAO,EAAC,6BAA6B,EAAC,MAAM,6CAA6C,CAAA;AACzF,OAAO,EAAC,kBAAkB,EAAC,MAAM,0BAA0B,CAAA;AAE3D,KAAK,YAAY,GAAG;IAChB,KAAK,CAAC,EAAE,KAAK,CAAC,QAAQ,CAAC,gBAAgB,CAAC,CAAA;IACxC,QAAQ,CAAC,EAAE,IAAI,CAAA;IACf,QAAQ,CAAC,EAAE,IAAI,CAAA;IACf,UAAU,CAAC,EAAE,IAAI,CAAA;IACjB,YAAY,CAAC,EAAE,IAAI,CAAA;IACnB,WAAW,CAAC,EAAE,OAAO,CAAA;CACxB,CAAA;AAED,qBAAa,oBAAqB,YAAW,wBAAwB,CAAC,6BAA6B,CAAC;;IAChG,QAAQ,CAAC,IAAI,iBAAgB;gBAajB,OAAO,EAAE,kBAAkB,EAAE,GAAG,EAAE,aAAa;IAsC3D,eAAe,CAAC,QAAQ,EAAE,QAAQ,CAAC,IAAI,CAAC,GAAG,YAAY;IACvD,MAAM,CAAC,CAAC,EAAE,OAAO,EAAE,uBAAuB,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;IAExD,UAAU,IAAI,IAAI;IAKlB,YAAY,IAAI,IAAI;IAKpB,IAAI,UAAU,IAAI,OAAO,CAA0B;IAEjD,oBAAoB,CAAC,QAAQ,EAAE,IAAI,GAAG,SAAS,CAAC,SAAS,CAAC;IAa5D,SAAS,IAAI,IAAI;IAKjB,IAAI,GAAG,IAAI,aAAa,CAAmB;IAC3C,IAAI,IAAI,IAAI,IAAI,CAAC,KAAK,CAAgC;IACtD,IAAI,OAAO,IAAI,OAAO,CAA2B;IACjD,IAAI,QAAQ,IAAI,IAAI,CAAuC;IAC3D,IAAI,QAAQ,IAAI,IAAI,CAAuC;IAC3D,IAAI,UAAU,IAAI,IAAI,CAAyC;IAC/D,IAAI,YAAY,IAAI,IAAI,CAA2C;IACnE,IAAI,MAAM,IAAI,IAAI,CAAyC;IAC3D,IAAI,QAAQ,IAAI,IAAI,CAAuC;IAC3D,IAAI,IAAI,IAAI,OAAO,CAAmC;IACtD,IAAI,GAAG,IAAI,GAAG,CAAkC;IAChD,IAAI,aAAa,YAAyC;IAC1D,IAAI,aAAa,IAAI,MAAM,CAAC,6BAA6B,CAAC,CAGzD;IACD,IAAI,KAAK,IAAI,MAAM,CAAoC;IACvD,IAAI,eAAe,IAAI,MAAM,CAAC,eAAe,CAAC,CAI7C;IACD,IAAI,UAAU,IAAI,OAAO,CAA2E;IACpG,IAAI,SAAS,IAAI,OAAO,CAAc;IAEtC,MAAM,CAAC,MAAM,CAAC,EAAE,YAAY,GAAG,oBAAoB;IAkBnD,WAAW,IAAI,IAAI;IAUnB,UAAU,CAAC,OAAO,EAAE,aAAa,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,GAAG,OAAO;IAKtE,OAAO,CAAC,OAAO,EAAE,aAAa,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,GAAG,MAAM,CAAC,aAAa,CAAC;IA6CjF,QAAQ,IAAI,MAAM;CAMrB"}
|
|
@@ -19,9 +19,9 @@ export class NoteRegionBoxAdapter {
|
|
|
19
19
|
this.#changeNotifier = new Notifier();
|
|
20
20
|
this.#isSelected = false;
|
|
21
21
|
this.#isConstructing = true;
|
|
22
|
-
this.#terminator.ownAll(this.#box.pointerHub.
|
|
23
|
-
|
|
24
|
-
|
|
22
|
+
this.#terminator.ownAll(this.#box.pointerHub.subscribe({
|
|
23
|
+
onAdded: () => this.#dispatchChange(),
|
|
24
|
+
onRemoved: () => this.#dispatchChange()
|
|
25
25
|
}), this.#box.subscribe(Propagation.Children, (update) => {
|
|
26
26
|
if (this.trackBoxAdapter.isEmpty()) {
|
|
27
27
|
return;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ValueRegionBoxAdapter.d.ts","sourceRoot":"","sources":["../../../src/timeline/region/ValueRegionBoxAdapter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,eAAe,EAAkB,IAAI,EAAyB,MAAM,kBAAkB,CAAA;AAC9F,OAAO,EAEH,GAAG,
|
|
1
|
+
{"version":3,"file":"ValueRegionBoxAdapter.d.ts","sourceRoot":"","sources":["../../../src/timeline/region/ValueRegionBoxAdapter.ts"],"names":[],"mappings":"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"}
|
|
@@ -19,9 +19,9 @@ export class ValueRegionBoxAdapter {
|
|
|
19
19
|
this.#isConstructing = true;
|
|
20
20
|
this.#changeNotifier = new Notifier();
|
|
21
21
|
this.#isSelected = false;
|
|
22
|
-
this.#terminator.own(this.#box.pointerHub.
|
|
23
|
-
|
|
24
|
-
|
|
22
|
+
this.#terminator.own(this.#box.pointerHub.subscribe({
|
|
23
|
+
onAdded: () => this.#dispatchChange(),
|
|
24
|
+
onRemoved: () => this.#dispatchChange()
|
|
25
25
|
}));
|
|
26
26
|
this.#terminator.own(this.#box.subscribe(Propagation.Children, (update) => {
|
|
27
27
|
if (this.trackBoxAdapter.isEmpty()) {
|
package/package.json
CHANGED
|
@@ -1,39 +1,39 @@
|
|
|
1
1
|
{
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
2
|
+
"name": "@opendaw/studio-adapters",
|
|
3
|
+
"version": "0.0.37",
|
|
4
|
+
"license": "LGPL-3.0-or-later",
|
|
5
|
+
"publishConfig": {
|
|
6
|
+
"access": "public"
|
|
7
|
+
},
|
|
8
|
+
"main": "./dist/index.js",
|
|
9
|
+
"types": "./dist/index.d.ts",
|
|
10
|
+
"exports": {
|
|
11
|
+
".": {
|
|
12
|
+
"types": "./dist/index.d.ts",
|
|
13
|
+
"default": "./dist/index.js"
|
|
14
|
+
}
|
|
15
|
+
},
|
|
16
|
+
"files": [
|
|
17
|
+
"dist/**/*"
|
|
18
|
+
],
|
|
19
|
+
"scripts": {
|
|
20
|
+
"generate-exports": "node generate-exports.mjs",
|
|
21
|
+
"build": "npm run generate-exports && tsc",
|
|
22
|
+
"lint": "eslint \"**/*.ts\"",
|
|
23
|
+
"test": "echo \"No tests to run\""
|
|
24
|
+
},
|
|
25
|
+
"dependencies": {
|
|
26
|
+
"@opendaw/lib-box": "^0.0.36",
|
|
27
|
+
"@opendaw/lib-dsp": "^0.0.36",
|
|
28
|
+
"@opendaw/lib-runtime": "^0.0.36",
|
|
29
|
+
"@opendaw/lib-std": "^0.0.36",
|
|
30
|
+
"@opendaw/studio-boxes": "^0.0.36",
|
|
31
|
+
"@opendaw/studio-enums": "^0.0.27",
|
|
32
|
+
"soundfont2": "^0.5.0"
|
|
33
|
+
},
|
|
34
|
+
"devDependencies": {
|
|
35
|
+
"@opendaw/eslint-config": "^0.0.20",
|
|
36
|
+
"@opendaw/typescript-config": "^0.0.20"
|
|
37
|
+
},
|
|
38
|
+
"gitHead": "a3c95d33522ce3b35c1a67af0fd6064488d35c97"
|
|
39
39
|
}
|