Merge pull request #3363 from element-hq/toger5/fix-initial-device-selection-in-controlled-devices-mode

Fix initial selection when using controlled media
This commit is contained in:
Robin
2025-06-25 13:47:42 -04:00
committed by GitHub
2 changed files with 15 additions and 12 deletions

View File

@@ -50,7 +50,7 @@ export const setPipEnabled$ = new Subject<boolean>();
export const availableOutputDevices$ = new Subject<OutputDevice[]>();
export const outputDevice$ = new Subject<string | undefined>();
export const outputDevice$ = new Subject<string>();
/**
* This allows the os to mute the call if the user

View File

@@ -269,18 +269,21 @@ class ControlledAudioOutput
this.deviceSelection$.next(id);
}
public readonly selected$ = merge(
this.deviceSelection$,
controlledOutputSelection$,
).pipe(
startWith<string | undefined>(undefined),
map((id) =>
id === undefined
public readonly selected$ = combineLatest(
[
this.available$,
merge(
controlledOutputSelection$.pipe(startWith(undefined)),
this.deviceSelection$,
),
],
(available, preferredId) => {
const id = preferredId ?? available.keys().next().value;
return id === undefined
? undefined
: { id, virtualEarpiece: id === EARPIECE_CONFIG_ID },
),
this.scope.state(),
);
: { id, virtualEarpiece: id === EARPIECE_CONFIG_ID };
},
).pipe(this.scope.state());
public constructor(private readonly scope: ObservableScope) {
this.selected$.subscribe((device) => {