Fix outbound audio track attach for pre-media peers

This commit is contained in:
Jage9
2026-02-25 02:20:09 -05:00
parent 7b36014cea
commit b41e903fca
2 changed files with 13 additions and 6 deletions

View File

@@ -1,5 +1,5 @@
// Maintainer-controlled web client version. // Maintainer-controlled web client version.
// Format: YYYY.MM.DD Rn (example: 2026.02.20 R2) // Format: YYYY.MM.DD Rn (example: 2026.02.20 R2)
window.CHGRID_WEB_VERSION = "2026.02.25 R264"; window.CHGRID_WEB_VERSION = "2026.02.25 R265";
// Optional display timezone for timestamps. Falls back to America/Detroit if unset/invalid. // Optional display timezone for timestamps. Falls back to America/Detroit if unset/invalid.
window.CHGRID_TIME_ZONE = "America/Detroit"; window.CHGRID_TIME_ZONE = "America/Detroit";

View File

@@ -113,12 +113,19 @@ export class PeerManager {
} }
async replaceOutgoingTrack(stream: MediaStream): Promise<void> { async replaceOutgoingTrack(stream: MediaStream): Promise<void> {
for (const peer of this.peers.values()) {
const sender = peer.pc.getSenders().find((candidate) => candidate.track?.kind === 'audio');
const newTrack = stream.getAudioTracks()[0]; const newTrack = stream.getAudioTracks()[0];
if (sender && newTrack) { if (!newTrack) {
await sender.replaceTrack(newTrack); return;
} }
for (const peer of this.peers.values()) {
const sender =
peer.pc.getSenders().find((candidate) => candidate.track?.kind === 'audio') ??
peer.pc
.getTransceivers()
.find((transceiver) => transceiver.receiver.track?.kind === 'audio' || transceiver.sender.track?.kind === 'audio')
?.sender;
if (!sender) continue;
await sender.replaceTrack(newTrack);
} }
} }