twilio-video
Version:
Twilio Video JavaScript Library
198 lines (179 loc) • 5.83 kB
JavaScript
'use strict';
const TrackPublication = require('./trackpublication');
/**
* A {@link RemoteTrackPublication} represents a {@link RemoteTrack} that has
* been published to a {@link Room}.
* @extends TrackPublication
* @property {boolean} isSubscribed - whether the published {@link RemoteTrack}
* is subscribed to
* @property {boolean} isTrackEnabled - whether the published
* {@link RemoteTrack} is enabled
* @property {Track.Kind} kind - kind of the published {@link RemoteTrack}
* @property {Track.Priority} publishPriority - the {@link Track.Priority} of the published
* {@link RemoteTrack} set by the {@link RemoteParticipant}
* @property {?RemoteTrack} track - Unless you have subscribed to the
* {@link RemoteTrack}, this property is null
* @emits RemoteTrackPublication#publishPriorityChanged
* @emits RemoteTrackPublication#subscribed
* @emits RemoteTrackPublication#subscriptionFailed
* @emits RemoteTrackPublication#trackDisabled
* @emits RemoteTrackPublication#trackEnabled
* @emits RemoteTrackPublication#trackSwitchedOff
* @emits RemoteTrackPublication#trackSwitchedOn
* @emits RemoteTrackPublication#unsubscribed
*
*/
class RemoteTrackPublication extends TrackPublication {
/**
* Construct a {@link RemoteTrackPublication}.
* @param {RemoteTrackPublicationSignaling} signaling - {@link RemoteTrackPublication} signaling
* @param {RemoteTrackPublicationOptions} options - {@link RemoteTrackPublication}
* options
*/
constructor(signaling, options) {
super(signaling.name, signaling.sid, options);
Object.defineProperties(this, {
_signaling: {
value: signaling
},
_track: {
value: null,
writable: true
},
isSubscribed: {
enumerable: true,
get() {
return !!this._track;
}
},
isTrackEnabled: {
enumerable: true,
get() {
return signaling.isEnabled;
}
},
kind: {
enumerable: true,
value: signaling.kind
},
publishPriority: {
enumerable: true,
get() {
return signaling.priority;
}
},
track: {
enumerable: true,
get() {
return this._track;
}
}
});
// remember original state, and fire events only on change.
let {
error,
isEnabled,
isSwitchedOff,
priority
} = signaling;
signaling.on('updated', () => {
if (error !== signaling.error) {
error = signaling.error;
this.emit('subscriptionFailed', signaling.error);
return;
}
if (isEnabled !== signaling.isEnabled) {
isEnabled = signaling.isEnabled;
if (this.track) {
this.track._setEnabled(signaling.isEnabled);
}
this.emit(signaling.isEnabled ? 'trackEnabled' : 'trackDisabled');
}
if (isSwitchedOff !== signaling.isSwitchedOff) {
this._log.debug(`${this.trackSid}: ${isSwitchedOff ? 'OFF' : 'ON'} => ${signaling.isSwitchedOff ? 'OFF' : 'ON'}`);
isSwitchedOff = signaling.isSwitchedOff;
if (this.track) {
this.track._setSwitchedOff(signaling.isSwitchedOff);
this.emit(isSwitchedOff ? 'trackSwitchedOff' : 'trackSwitchedOn', this.track);
} else if (isSwitchedOff) {
this._log.warn('Track was not subscribed when switched Off.');
}
}
if (priority !== signaling.priority) {
priority = signaling.priority;
this.emit('publishPriorityChanged', priority);
}
});
}
toString() {
return `[RemoteTrackPublication #${this._instanceId}: ${this.trackSid}]`;
}
/**
* @private
* @param {RemoteTrack} track
*/
_subscribed(track) {
if (!this._track && track) {
this._track = track;
this.emit('subscribed', track);
}
}
/**
* @private
*/
_unsubscribe() {
if (this._track) {
const track = this._track;
this._track = null;
this.emit('unsubscribed', track);
}
}
}
/**
* The {@link RemoteTrack}'s publish {@link Track.Priority} was changed by the
* {@link RemoteParticipant}.
* @param {Track.Priority} priority - the {@link RemoteTrack}'s new publish
* {@link Track.Priority}; RemoteTrackPublication#publishPriority is also
* updated accordingly
* @event RemoteTrackPublication#publishPriorityChanged
*/
/**
* Your {@link LocalParticipant} subscribed to the {@link RemoteTrack}.
* @param {RemoteTrack} track - the {@link RemoteTrack} that was subscribed to
* @event RemoteTrackPublication#subscribed
*/
/**
* Your {@link LocalParticipant} failed to subscribe to the {@link RemoteTrack}.
* @param {TwilioError} error - the reason the {@link RemoteTrack} could not be
* subscribed to
* @event RemoteTrackPublication#subscriptionFailed
*/
/**
* The {@link RemoteTrack} was disabled.
* @event RemoteTrackPublication#trackDisabled
*/
/**
* The {@link RemoteTrack} was enabled.
* @event RemoteTrackPublication#trackEnabled
*/
/**
* The {@link RemoteTrack} was switched off.
* @param {RemoteTrack} track - the {@link RemoteTrack} that was switched off
* @event RemoteTrackPublication#trackSwitchedOff
*/
/**
* The {@link RemoteTrack} was switched on.
* @param {RemoteTrack} track - the {@link RemoteTrack} that was switched on
* @event RemoteTrackPublication#trackSwitchedOn
*/
/**
* Your {@link LocalParticipant} unsubscribed from the {@link RemoteTrack}.
* @param {RemoteTrack} track - the {@link RemoteTrack} that was unsubscribed from
* @event RemoteTrackPublication#unsubscribed
*/
/**
* {@link RemoteTrackPublication} options
* @typedef {object} RemoteTrackPublicationOptions
* @property {LogLevel|LogLevels} logLevel - Log level for 'media' modules
*/
module.exports = RemoteTrackPublication;