@gcorevideo/player 2.22.26 → 2.22.28

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/index.js CHANGED
@@ -12680,7 +12680,7 @@ var PlaybackEvents;
12680
12680
  // https://github.com/clappr/clappr/blob/8752995ea439321ac7ca3cd35e8c64de7a3c3d17/LICENSE
12681
12681
  const AUTO$1 = -1;
12682
12682
  const { now: now$2 } = Utils;
12683
- const T$n = 'playback.dash';
12683
+ const T$m = 'playback.dash';
12684
12684
  class DashPlayback extends BasePlayback {
12685
12685
  _levels = null;
12686
12686
  _currentLevel = null;
@@ -12955,10 +12955,10 @@ class DashPlayback extends BasePlayback {
12955
12955
  }
12956
12956
  _onPlaybackError = (event) => {
12957
12957
  // TODO
12958
- trace(`${T$n} _onPlaybackError`, { event });
12958
+ trace(`${T$m} _onPlaybackError`, { event });
12959
12959
  };
12960
12960
  _onDASHJSSError = (event) => {
12961
- trace(`${T$n} _onDASHJSSError`, { event });
12961
+ trace(`${T$m} _onDASHJSSError`, { event });
12962
12962
  this._stopTimeUpdateTimer();
12963
12963
  // Note that the other error types are deprecated
12964
12964
  const e = event.error;
@@ -12993,7 +12993,7 @@ class DashPlayback extends BasePlayback {
12993
12993
  }
12994
12994
  };
12995
12995
  triggerError(error) {
12996
- trace(`${T$n} triggerError`, { error });
12996
+ trace(`${T$m} triggerError`, { error });
12997
12997
  // this triggers Events.ERROR to be handled by the UI
12998
12998
  this.trigger(Events$1.PLAYBACK_ERROR, this.createError(error, {
12999
12999
  useCodePrefix: false,
@@ -13032,10 +13032,10 @@ class DashPlayback extends BasePlayback {
13032
13032
  }
13033
13033
  get dvrEnabled() {
13034
13034
  if (!this._dash) {
13035
- trace(`${T$n} dvrEnable no dash player instance`);
13035
+ trace(`${T$m} dvrEnable no dash player instance`);
13036
13036
  return false;
13037
13037
  }
13038
- trace(`${T$n} get.dvrEnabled`, {
13038
+ trace(`${T$m} get.dvrEnabled`, {
13039
13039
  dvrWindowSize: this._dash?.getDVRWindowSize(),
13040
13040
  minDvrSize: this._minDvrSize,
13041
13041
  playbackType: this.getPlaybackType(),
@@ -13057,7 +13057,7 @@ class DashPlayback extends BasePlayback {
13057
13057
  this.trigger(Events$1.PLAYBACK_PROGRESS, progress, {});
13058
13058
  }
13059
13059
  play() {
13060
- trace(`${T$n} play`, { dash: !!this._dash });
13060
+ trace(`${T$m} play`, { dash: !!this._dash });
13061
13061
  if (!this._dash) {
13062
13062
  this._setup();
13063
13063
  }
@@ -13143,7 +13143,7 @@ class DashPlayback extends BasePlayback {
13143
13143
  }
13144
13144
  // @ts-expect-error
13145
13145
  get currentAudioTrack() {
13146
- trace(`${T$n} get currentAudioTrack`);
13146
+ trace(`${T$m} get currentAudioTrack`);
13147
13147
  assert.ok(this._dash, 'DASH.js MediaPlayer is not initialized');
13148
13148
  const t = this._dash.getCurrentTrackFor('audio');
13149
13149
  if (!t) {
@@ -41844,7 +41844,7 @@ const AUTO = -1;
41844
41844
  const DEFAULT_RECOVER_ATTEMPTS = 16;
41845
41845
  Events$1.register('PLAYBACK_FRAGMENT_CHANGED');
41846
41846
  Events$1.register('PLAYBACK_FRAGMENT_PARSING_METADATA');
41847
- const T$m = 'playback.hls';
41847
+ const T$l = 'playback.hls';
41848
41848
  class HlsPlayback extends BasePlayback {
41849
41849
  _ccIsSetup = false;
41850
41850
  _ccTracksUpdated = false;
@@ -42073,7 +42073,7 @@ class HlsPlayback extends BasePlayback {
42073
42073
  maxBufferLength: 2,
42074
42074
  maxMaxBufferLength: 4,
42075
42075
  }, this.options.playback.hlsjsConfig);
42076
- trace(`${T$m} _createHLSInstance`, { config });
42076
+ trace(`${T$l} _createHLSInstance`, { config });
42077
42077
  this._hls = new Hls(config);
42078
42078
  }
42079
42079
  _attachHLSMedia() {
@@ -42164,7 +42164,7 @@ class HlsPlayback extends BasePlayback {
42164
42164
  }
42165
42165
  else {
42166
42166
  Log.error('hlsjs: failed to recover', { evt, data });
42167
- trace(`${T$m} _recover failed to recover`, {
42167
+ trace(`${T$l} _recover failed to recover`, {
42168
42168
  type: data.type,
42169
42169
  details: data.details,
42170
42170
  });
@@ -42250,7 +42250,7 @@ class HlsPlayback extends BasePlayback {
42250
42250
  this.trigger(Events$1.PLAYBACK_SETTINGSUPDATE);
42251
42251
  }
42252
42252
  _onHLSJSError(evt, data) {
42253
- trace(`${T$m} _onHLSJSError`, {
42253
+ trace(`${T$l} _onHLSJSError`, {
42254
42254
  fatal: data.fatal,
42255
42255
  type: data.type,
42256
42256
  details: data.details,
@@ -42298,7 +42298,7 @@ class HlsPlayback extends BasePlayback {
42298
42298
  evt,
42299
42299
  data,
42300
42300
  });
42301
- trace(`${T$m} _onHLSJSError trying to recover from network error`, {
42301
+ trace(`${T$l} _onHLSJSError trying to recover from network error`, {
42302
42302
  details: data.details,
42303
42303
  });
42304
42304
  error.level = PlayerError.Levels.WARN;
@@ -42311,7 +42311,7 @@ class HlsPlayback extends BasePlayback {
42311
42311
  evt,
42312
42312
  data,
42313
42313
  });
42314
- trace(`${T$m} _onHLSJSError trying to recover from media error`, {
42314
+ trace(`${T$l} _onHLSJSError trying to recover from media error`, {
42315
42315
  details: data.details,
42316
42316
  });
42317
42317
  error.level = PlayerError.Levels.WARN;
@@ -42341,7 +42341,7 @@ class HlsPlayback extends BasePlayback {
42341
42341
  return;
42342
42342
  }
42343
42343
  Log.warn('hlsjs: non-fatal error occurred', { evt, data });
42344
- trace(`${T$m} _onHLSJSError non-fatal error occurred`, {
42344
+ trace(`${T$l} _onHLSJSError non-fatal error occurred`, {
42345
42345
  type: data.type,
42346
42346
  details: data.details,
42347
42347
  });
@@ -42675,11 +42675,11 @@ class HlsPlayback extends BasePlayback {
42675
42675
  this._hls.audioTrack = Number(id); // TODO or find index by .id == id?
42676
42676
  }
42677
42677
  _onAudioTracksUpdated(_, data) {
42678
- trace(`${T$m} onAudioTracksUpdated`);
42678
+ trace(`${T$l} onAudioTracksUpdated`);
42679
42679
  this.trigger(Events$1.PLAYBACK_AUDIO_AVAILABLE, data.audioTracks.map(toClapprTrack));
42680
42680
  }
42681
42681
  _onAudioTrackSwitched(_, data) {
42682
- trace(`${T$m} onAudioTrackSwitched`);
42682
+ trace(`${T$l} onAudioTrackSwitched`);
42683
42683
  // @ts-ignore
42684
42684
  const track = this._hls.audioTracks[data.id];
42685
42685
  this.trigger(Events$1.PLAYBACK_AUDIO_CHANGED, toClapprTrack(track));
@@ -42700,7 +42700,7 @@ function toClapprTrack(t) {
42700
42700
  };
42701
42701
  }
42702
42702
 
42703
- const T$l = 'playback.html5_video';
42703
+ const T$k = 'playback.html5_video';
42704
42704
  const STALL_TIMEOUT = 15000;
42705
42705
  class HTML5Video extends BasePlayback {
42706
42706
  stallTimerId = null;
@@ -42708,7 +42708,7 @@ class HTML5Video extends BasePlayback {
42708
42708
  * @internal
42709
42709
  */
42710
42710
  createError(errorData, options) {
42711
- trace(`${T$l} createError`, {
42711
+ trace(`${T$k} createError`, {
42712
42712
  errorData: { ...errorData },
42713
42713
  });
42714
42714
  const i18n = this.i18n ||
@@ -42724,11 +42724,11 @@ class HTML5Video extends BasePlayback {
42724
42724
  return super.createError(errorData, { ...options, useCodePrefix: false });
42725
42725
  }
42726
42726
  _onWaiting() {
42727
- trace(`${T$l} _onWaiting`);
42727
+ trace(`${T$k} _onWaiting`);
42728
42728
  super._onWaiting();
42729
42729
  }
42730
42730
  _onEnded() {
42731
- trace(`${T$l} _onEnded`);
42731
+ trace(`${T$k} _onEnded`);
42732
42732
  if (this.stallTimerId) {
42733
42733
  clearTimeout(this.stallTimerId);
42734
42734
  this.stallTimerId = null;
@@ -42736,12 +42736,12 @@ class HTML5Video extends BasePlayback {
42736
42736
  super._onEnded();
42737
42737
  }
42738
42738
  _handleBufferingEvents() {
42739
- trace(`${T$l} _handleBufferingEvents`, {
42739
+ trace(`${T$k} _handleBufferingEvents`, {
42740
42740
  networkState: this.el.networkState,
42741
42741
  });
42742
42742
  if (!this.stallTimerId) {
42743
42743
  this.stallTimerId = setTimeout(() => {
42744
- trace(`${T$l} _handleBufferingEvents stall timeout`, {
42744
+ trace(`${T$k} _handleBufferingEvents stall timeout`, {
42745
42745
  buffering: this.buffering,
42746
42746
  ended: this.ended,
42747
42747
  });
@@ -42759,7 +42759,7 @@ class HTML5Video extends BasePlayback {
42759
42759
  super._handleBufferingEvents();
42760
42760
  }
42761
42761
  _onPlaying() {
42762
- trace(`${T$l} _onPlaying`);
42762
+ trace(`${T$k} _onPlaying`);
42763
42763
  if (this.stallTimerId) {
42764
42764
  clearTimeout(this.stallTimerId);
42765
42765
  this.stallTimerId = null;
@@ -42767,7 +42767,7 @@ class HTML5Video extends BasePlayback {
42767
42767
  super._onPlaying();
42768
42768
  }
42769
42769
  _onPause() {
42770
- trace(`${T$l} _onPause`);
42770
+ trace(`${T$k} _onPause`);
42771
42771
  super._onPause();
42772
42772
  if (this.stallTimerId) {
42773
42773
  clearTimeout(this.stallTimerId);
@@ -42777,7 +42777,7 @@ class HTML5Video extends BasePlayback {
42777
42777
  get audioTracks() {
42778
42778
  const tracks = this.el.audioTracks;
42779
42779
  const supported = !!tracks;
42780
- trace(`${T$l} get audioTracks`, { supported });
42780
+ trace(`${T$k} get audioTracks`, { supported });
42781
42781
  const retval = [];
42782
42782
  if (supported) {
42783
42783
  for (let i = 0; i < tracks.length; i++) {
@@ -42796,7 +42796,7 @@ class HTML5Video extends BasePlayback {
42796
42796
  get currentAudioTrack() {
42797
42797
  const tracks = this.el.audioTracks;
42798
42798
  const supported = !!tracks;
42799
- trace(`${T$l} get currentAudioTrack`, {
42799
+ trace(`${T$k} get currentAudioTrack`, {
42800
42800
  supported,
42801
42801
  });
42802
42802
  if (supported) {
@@ -42817,7 +42817,7 @@ class HTML5Video extends BasePlayback {
42817
42817
  switchAudioTrack(id) {
42818
42818
  const tracks = this.el.audioTracks;
42819
42819
  const supported = !!tracks;
42820
- trace(`${T$l} switchAudioTrack`, {
42820
+ trace(`${T$k} switchAudioTrack`, {
42821
42821
  supported,
42822
42822
  });
42823
42823
  if (supported) {
@@ -42836,7 +42836,7 @@ function registerPlaybacks() {
42836
42836
  Loader.registerPlayback(DashPlayback);
42837
42837
  }
42838
42838
 
42839
- const T$k = 'GPlayer';
42839
+ const T$j = 'GPlayer';
42840
42840
  const DEFAULT_OPTIONS = {
42841
42841
  autoPlay: false,
42842
42842
  debug: 'none',
@@ -42924,7 +42924,7 @@ class Player {
42924
42924
  * ```
42925
42925
  */
42926
42926
  attachTo(playerElement) {
42927
- trace(`${T$k} attachTo`, {
42927
+ trace(`${T$j} attachTo`, {
42928
42928
  player: !!this.player,
42929
42929
  });
42930
42930
  assert.ok(!this.player, 'Player already initialized');
@@ -42934,7 +42934,7 @@ class Player {
42934
42934
  }
42935
42935
  const coreOpts = this.buildCoreOptions(playerElement);
42936
42936
  const { core, container } = Player.getRegisteredPlugins();
42937
- trace(`${T$k} init`, {
42937
+ trace(`${T$j} init`, {
42938
42938
  registeredPlaybacks: Loader.registeredPlaybacks.map((p) => p.prototype.name),
42939
42939
  });
42940
42940
  coreOpts.plugins = {
@@ -42948,7 +42948,7 @@ class Player {
42948
42948
  * Destroys the player, releasing all resources and unmounting its UI from the DOM.
42949
42949
  */
42950
42950
  destroy() {
42951
- trace(`${T$k} destroy`, {
42951
+ trace(`${T$j} destroy`, {
42952
42952
  player: !!this.player,
42953
42953
  });
42954
42954
  if (this.player) {
@@ -43135,7 +43135,7 @@ class Player {
43135
43135
  this.config = $.extend(true, this.config, config);
43136
43136
  }
43137
43137
  initPlayer(coreOptions) {
43138
- trace(`${T$k} initPlayer`, {
43138
+ trace(`${T$j} initPlayer`, {
43139
43139
  autoPlay: coreOptions.autoPlay,
43140
43140
  sources: coreOptions.sources,
43141
43141
  player: !!this.player,
@@ -43160,7 +43160,7 @@ class Player {
43160
43160
  }
43161
43161
  }
43162
43162
  triggerAutoPlay() {
43163
- trace(`${T$k} triggerAutoPlay`);
43163
+ trace(`${T$j} triggerAutoPlay`);
43164
43164
  setTimeout(() => {
43165
43165
  this.player?.play({
43166
43166
  autoPlay: true,
@@ -43178,7 +43178,7 @@ class Player {
43178
43178
  // TODO test
43179
43179
  events = {
43180
43180
  onReady: () => {
43181
- trace(`${T$k} onReady`, {
43181
+ trace(`${T$j} onReady`, {
43182
43182
  ready: this.ready,
43183
43183
  });
43184
43184
  if (this.ready) {
@@ -43212,7 +43212,7 @@ class Player {
43212
43212
  buildCoreOptions(rootNode) {
43213
43213
  const sources = this.buildMediaSourcesList();
43214
43214
  const source = sources[0];
43215
- trace(`${T$k} buildCoreOptions`, {
43215
+ trace(`${T$j} buildCoreOptions`, {
43216
43216
  source,
43217
43217
  sources,
43218
43218
  });
@@ -43273,7 +43273,7 @@ class Player {
43273
43273
  assert.ok(this.player, 'Player is not initialized');
43274
43274
  const core = this.player.core;
43275
43275
  core.on(Events$1.CORE_SCREEN_ORIENTATION_CHANGED, ({ orientation }) => {
43276
- trace(`${T$k} on CORE_SCREEN_ORIENTATION_CHANGED`, {
43276
+ trace(`${T$j} on CORE_SCREEN_ORIENTATION_CHANGED`, {
43277
43277
  orientation,
43278
43278
  rootNode: {
43279
43279
  width: this.rootNode?.clientWidth,
@@ -43288,14 +43288,14 @@ class Player {
43288
43288
  }
43289
43289
  }, null);
43290
43290
  core.on(Events$1.CORE_RESIZE, ({ width, height }) => {
43291
- trace(`${T$k} on CORE_RESIZE`, {
43291
+ trace(`${T$j} on CORE_RESIZE`, {
43292
43292
  width,
43293
43293
  height,
43294
43294
  });
43295
43295
  this.safeTriggerEvent(PlayerEvent.Resize, { width, height });
43296
43296
  }, null);
43297
43297
  core.on(Events$1.CORE_FULLSCREEN, (isFullscreen) => {
43298
- trace(`${T$k} CORE_FULLSCREEN`, {
43298
+ trace(`${T$j} CORE_FULLSCREEN`, {
43299
43299
  isFullscreen,
43300
43300
  });
43301
43301
  this.safeTriggerEvent(PlayerEvent.Fullscreen, isFullscreen);
@@ -43303,7 +43303,7 @@ class Player {
43303
43303
  }
43304
43304
  }
43305
43305
 
43306
- var version$1 = "2.22.26";
43306
+ var version$1 = "2.22.28";
43307
43307
 
43308
43308
  var packages = {
43309
43309
  "node_modules/@clappr/core": {
@@ -43627,7 +43627,7 @@ const INITIAL_SETTINGS = {
43627
43627
  default: [],
43628
43628
  seekEnabled: false,
43629
43629
  };
43630
- const T$j = 'plugins.media_control';
43630
+ const T$i = 'plugins.media_control';
43631
43631
  const LEFT_ORDER = [
43632
43632
  'playpause',
43633
43633
  'playstop',
@@ -43760,7 +43760,7 @@ class MediaControl extends UICorePlugin {
43760
43760
  'click [data-stop]': 'stop',
43761
43761
  'click [data-playstop]': 'togglePlayStop',
43762
43762
  'click [data-fullscreen]': 'handleFullScreenOnBtn',
43763
- 'click .bar-container[data-seekbar]': 'seek',
43763
+ // 'click .bar-container[data-seekbar]': 'seek', // This together with global window.bind causes duplicate seeks events
43764
43764
  'click .bar-container[data-volume]': 'onVolumeClick',
43765
43765
  'click .drawer-icon[data-volume]': 'toggleMute',
43766
43766
  'mouseenter .drawer-container[data-volume]': 'showVolumeBar',
@@ -43878,7 +43878,7 @@ class MediaControl extends UICorePlugin {
43878
43878
  * Hides the media control UI
43879
43879
  */
43880
43880
  disable() {
43881
- trace(`${T$j} disable`);
43881
+ trace(`${T$i} disable`);
43882
43882
  this.userDisabled = true; // TODO distinguish between user and system (e.g., unplayable) disabled?
43883
43883
  this.hide();
43884
43884
  this.unbindKeyEvents();
@@ -43888,7 +43888,7 @@ class MediaControl extends UICorePlugin {
43888
43888
  * Reenables the plugin disabled earlier with the {@link MediaControl.disable} method
43889
43889
  */
43890
43890
  enable() {
43891
- trace(`${T$j} enable`);
43891
+ trace(`${T$i} enable`);
43892
43892
  if (this.options.chromeless) {
43893
43893
  return;
43894
43894
  }
@@ -44067,12 +44067,14 @@ class MediaControl extends UICorePlugin {
44067
44067
  event && event.preventDefault();
44068
44068
  }
44069
44069
  stopDrag = (event) => {
44070
- this.draggingSeekBar && this.seek(event);
44070
+ if (this.draggingSeekBar) {
44071
+ this.draggingSeekBar = false;
44072
+ this.seek(event);
44073
+ }
44071
44074
  this.$el.removeClass('dragging');
44072
44075
  this.$seekBarLoaded?.removeClass('media-control-notransition');
44073
44076
  this.$seekBarPosition?.removeClass('media-control-notransition');
44074
44077
  this.$seekBarScrubber?.removeClass('media-control-notransition dragging');
44075
- this.draggingSeekBar = false;
44076
44078
  this.draggingVolumeBar = false;
44077
44079
  };
44078
44080
  updateDrag = (event) => {
@@ -44084,8 +44086,9 @@ class MediaControl extends UICorePlugin {
44084
44086
  let pos = (offsetX / this.$seekBarContainer.width()) * 100;
44085
44087
  pos = Math.min(100, Math.max(pos, 0));
44086
44088
  this.setSeekPercentage(pos);
44089
+ return;
44087
44090
  }
44088
- else if (this.draggingVolumeBar) {
44091
+ if (this.draggingVolumeBar) {
44089
44092
  event.preventDefault();
44090
44093
  this.setVolume(this.getVolumeFromUIEvent(event));
44091
44094
  }
@@ -44255,13 +44258,13 @@ class MediaControl extends UICorePlugin {
44255
44258
  if (!this.settings.seekEnabled) {
44256
44259
  return;
44257
44260
  }
44261
+ // TODO prevent double seek
44258
44262
  assert.ok(this.$seekBarContainer, 'seek bar container must be present');
44259
44263
  const offsetX = MediaControl.getPageX(event) - this.$seekBarContainer.offset().left;
44260
44264
  let pos = (offsetX / this.$seekBarContainer.width()) * 100;
44261
44265
  pos = Math.min(100, Math.max(pos, 0));
44262
44266
  this.core.activeContainer && this.core.activeContainer.seekPercentage(pos);
44263
44267
  this.setSeekPercentage(pos);
44264
- return false;
44265
44268
  }
44266
44269
  setUserKeepVisible() {
44267
44270
  this.userKeepVisible = true;
@@ -44334,13 +44337,11 @@ class MediaControl extends UICorePlugin {
44334
44337
  }
44335
44338
  }
44336
44339
  updateSettings() {
44337
- trace(`${T$j} updateSettings`, { settings: this.settings });
44338
44340
  const newSettings = $.extend(true, {
44339
44341
  left: [],
44340
44342
  default: [],
44341
44343
  right: [],
44342
44344
  }, this.core.activeContainer.settings);
44343
- trace(`${T$j} updateSettings`, { newSettings });
44344
44345
  newSettings.left.push('clips'); // TODO settings
44345
44346
  // TODO make order controlled via CSS
44346
44347
  newSettings.left = orderByOrderPattern([...newSettings.left, 'volume', 'clips'], LEFT_ORDER);
@@ -44352,11 +44353,6 @@ class MediaControl extends UICorePlugin {
44352
44353
  newSettings.right = DEFAULT_SETTINGS.right; // TODO get from the options
44353
44354
  if ((!this.fullScreenOnVideoTagSupported && !fullscreenEnabled()) ||
44354
44355
  this.options.fullscreenDisable) {
44355
- trace(`${T$j} updateSettings removing fullscreen`, {
44356
- supported: this.fullScreenOnVideoTagSupported,
44357
- enabled: Fullscreen.fullscreenEnabled(),
44358
- optionsDisable: this.options.fullscreenDisable,
44359
- });
44360
44356
  // remove fullscreen from settings if it is not available
44361
44357
  removeArrayItem(newSettings.default, 'fullscreen');
44362
44358
  removeArrayItem(newSettings.left, 'fullscreen');
@@ -44419,7 +44415,6 @@ class MediaControl extends UICorePlugin {
44419
44415
  */
44420
44416
  mount(name, element) {
44421
44417
  const panel = this.getElementLocation(name);
44422
- trace(`${T$j} mount`, { name, panel: !!panel });
44423
44418
  if (panel) {
44424
44419
  const current = panel.find(`[data-${name}]`);
44425
44420
  element.attr(`data-${name}`, '');
@@ -44615,14 +44610,11 @@ class MediaControl extends UICorePlugin {
44615
44610
  * @internal
44616
44611
  */
44617
44612
  render() {
44618
- trace(`${T$j} render`, {
44619
- needsUpdate: this.hasUpdate,
44620
- metadataLoaded: this.metadataLoaded,
44621
- });
44622
44613
  if (!this.hasUpdate || !this.metadataLoaded) {
44623
44614
  return this;
44624
44615
  }
44625
44616
  const timeout = this.options.hideMediaControlDelay || 2000;
44617
+ trace(`${T$i} render`, { settings: this.settings });
44626
44618
  this.$el.html(MediaControl.template({ settings: this.settings }));
44627
44619
  // const style = Styler.getStyleFor(mediaControlStyle, { baseUrl: this.options.baseUrl });
44628
44620
  // this.$el.append(style[0]);
@@ -44745,12 +44737,6 @@ class MediaControl extends UICorePlugin {
44745
44737
  return isFinite(this.core.activePlayback.getDuration());
44746
44738
  }
44747
44739
  getElementLocation(name) {
44748
- trace(`${T$j} getElementLocation`, {
44749
- name,
44750
- right: this.settings.right,
44751
- left: this.settings.left,
44752
- default: this.settings.default,
44753
- });
44754
44740
  if (this.settings.right?.includes(name)) {
44755
44741
  return this.getRightPanel();
44756
44742
  }
@@ -44784,7 +44770,7 @@ function serializeSettings(s) {
44784
44770
  }
44785
44771
 
44786
44772
  const VERSION$7 = '2.22.4';
44787
- const T$i = 'plugins.audiotracks';
44773
+ const T$h = 'plugins.audiotracks';
44788
44774
  /**
44789
44775
  * `PLUGIN` that makes possible to switch audio tracks via the media control UI.
44790
44776
  * @beta
@@ -44906,7 +44892,7 @@ class AudioTracks extends UICorePlugin {
44906
44892
  this.updateText();
44907
44893
  }
44908
44894
  hideMenu() {
44909
- trace(`${T$i} hideMenu`);
44895
+ trace(`${T$h} hideMenu`);
44910
44896
  this.$el.find('#audiotracks-select').addClass('hidden');
44911
44897
  this.$el.find('#audiotracks-button').attr('aria-expanded', 'false');
44912
44898
  }
@@ -44959,7 +44945,7 @@ class AudioTracks extends UICorePlugin {
44959
44945
 
44960
44946
  const pluginHtml$6 = "<div class=\"big-mute-icon-wrapper\" data-big-mute>\n <div class=\"big-mute-icon gcore-skin-border-color\" data-big-mute-icon></div>\n</div>\n";
44961
44947
 
44962
- const T$h = 'plugins.big_mute_button';
44948
+ const T$g = 'plugins.big_mute_button';
44963
44949
  // TODO rewrite as a container plugin
44964
44950
  /**
44965
44951
  * `PLUGIN` that displays a big mute button over the video when it's muted.
@@ -45000,7 +44986,7 @@ class BigMuteButton extends UICorePlugin {
45000
44986
  this.listenTo(this.core, Events$1.CORE_READY, this.onCoreReady);
45001
44987
  this.listenTo(this.core, 'core:advertisement:start', this.onStartAd);
45002
44988
  this.listenTo(this.core, 'core:advertisement:finish', this.onFinishAd);
45003
- trace(`${T$h} bindEvents`, {
44989
+ trace(`${T$g} bindEvents`, {
45004
44990
  mediacontrol: !!this.core.mediaControl,
45005
44991
  });
45006
44992
  this.listenTo(this.core.mediaControl, Events$1.MEDIACONTROL_RENDERED, this.mediaControlRendered);
@@ -45025,12 +45011,12 @@ class BigMuteButton extends UICorePlugin {
45025
45011
  }
45026
45012
  mediaControlRendered() {
45027
45013
  const container = this.core.activeContainer;
45028
- trace(`${T$h} mediaControlRendered`, {
45014
+ trace(`${T$g} mediaControlRendered`, {
45029
45015
  container: !!container,
45030
45016
  });
45031
45017
  if (container) {
45032
45018
  this.listenTo(container.playback, Events$1.PLAYBACK_PLAY, () => {
45033
- trace(`${T$h} PLAYBACK_PLAY`);
45019
+ trace(`${T$g} PLAYBACK_PLAY`);
45034
45020
  this.render();
45035
45021
  });
45036
45022
  }
@@ -45054,7 +45040,7 @@ class BigMuteButton extends UICorePlugin {
45054
45040
  }
45055
45041
  const { autoPlay, wasMuted } = this.options;
45056
45042
  const volume = container.volume;
45057
- trace(`${T$h} shouldRender`, {
45043
+ trace(`${T$g} shouldRender`, {
45058
45044
  autoPlay,
45059
45045
  wasMuted,
45060
45046
  volume,
@@ -45066,7 +45052,7 @@ class BigMuteButton extends UICorePlugin {
45066
45052
  */
45067
45053
  render() {
45068
45054
  if (this.shouldRender()) {
45069
- trace(`${T$h} render`, {
45055
+ trace(`${T$g} render`, {
45070
45056
  el: !!this.$el,
45071
45057
  });
45072
45058
  this.$el.html(BigMuteButton.template());
@@ -45112,7 +45098,7 @@ const gearIcon = "<svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"n
45112
45098
  const gearHdIcon = "<svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <g clip-path=\"url(#clip0_28_1567)\">\n <path\n d=\"M19.14 12.94C19.18 12.64 19.2 12.33 19.2 12C19.2 11.68 19.18 11.36 19.13 11.06L21.16 9.47999C21.34 9.33999 21.39 9.06999 21.28 8.86999L19.36 5.54999C19.24 5.32999 18.99 5.25999 18.77 5.32999L16.38 6.28999C15.88 5.90999 15.35 5.58999 14.76 5.34999L14.4 2.80999C14.36 2.56999 14.16 2.39999 13.92 2.39999H10.08C9.83999 2.39999 9.64999 2.56999 9.60999 2.80999L9.24999 5.34999C8.65999 5.58999 8.11999 5.91999 7.62999 6.28999L5.23999 5.32999C5.01999 5.24999 4.76999 5.32999 4.64999 5.54999L2.73999 8.86999C2.61999 9.07999 2.65999 9.33999 2.85999 9.47999L4.88999 11.06C4.83999 11.36 4.79999 11.69 4.79999 12C4.79999 12.31 4.81999 12.64 4.86999 12.94L2.83999 14.52C2.65999 14.66 2.60999 14.93 2.71999 15.13L4.63999 18.45C4.75999 18.67 5.00999 18.74 5.22999 18.67L7.61999 17.71C8.11999 18.09 8.64999 18.41 9.23999 18.65L9.59999 21.19C9.64999 21.43 9.83999 21.6 10.08 21.6H13.92C14.16 21.6 14.36 21.43 14.39 21.19L14.75 18.65C15.34 18.41 15.88 18.09 16.37 17.71L18.76 18.67C18.98 18.75 19.23 18.67 19.35 18.45L21.27 15.13C21.39 14.91 21.34 14.66 21.15 14.52L19.14 12.94ZM12 15.6C10.02 15.6 8.39999 13.98 8.39999 12C8.39999 10.02 10.02 8.39999 12 8.39999C13.98 8.39999 15.6 10.02 15.6 12C15.6 13.98 13.98 15.6 12 15.6Z\"\n fill=\"#C9C9C9\"/>\n <rect x=\"13\" width=\"11\" height=\"7\" rx=\"1\" fill=\"#F6413B\"/>\n <path\n d=\"M14.6962 6V1.63636H15.3546V3.53267H17.53V1.63636H18.1905V6H17.53V4.0973H15.3546V6H14.6962ZM20.562 6H19.1493V1.63636H20.6067C21.0343 1.63636 21.4015 1.72372 21.7083 1.89844C22.0151 2.07173 22.2502 2.32102 22.4135 2.64631C22.5783 2.97017 22.6607 3.35866 22.6607 3.81179C22.6607 4.26634 22.5776 4.65696 22.4114 4.98366C22.2466 5.31037 22.008 5.56179 21.6955 5.73793C21.383 5.91264 21.0051 6 20.562 6ZM19.8077 5.42472H20.5257C20.8581 5.42472 21.1344 5.36222 21.3546 5.23722C21.5748 5.1108 21.7395 4.92827 21.8489 4.68963C21.9583 4.44957 22.013 4.15696 22.013 3.81179C22.013 3.46946 21.9583 3.17898 21.8489 2.94034C21.7409 2.7017 21.5797 2.5206 21.3652 2.39702C21.1507 2.27344 20.8844 2.21165 20.5662 2.21165H19.8077V5.42472Z\"\n fill=\"#C9C9C9\"/>\n </g>\n <defs>\n <clipPath id=\"clip0_28_1567\">\n <rect width=\"24\" height=\"24\" fill=\"white\"/>\n </clipPath>\n </defs>\n</svg>\n";
45113
45099
 
45114
45100
  const VERSION$6 = '2.19.12';
45115
- const T$g = 'plugins.bottom_gear';
45101
+ const T$f = 'plugins.bottom_gear';
45116
45102
  /**
45117
45103
  * Events triggered by the plugin
45118
45104
  * @beta
@@ -45262,20 +45248,20 @@ class BottomGear extends UICorePlugin {
45262
45248
  addItem(name, $subMenu) {
45263
45249
  const $existingItem = this.$el.find(`#gear-options li[data-${name}`);
45264
45250
  if ($existingItem.length) {
45265
- trace(`${T$g} addItem already exists`, { name });
45251
+ trace(`${T$f} addItem already exists`, { name });
45266
45252
  return $existingItem;
45267
45253
  }
45268
45254
  const $item = $('<li></li>')
45269
45255
  .attr(`data-${name}`, '')
45270
45256
  .appendTo(this.$el.find('#gear-options'));
45271
45257
  if ($subMenu) {
45272
- trace(`${T$g} addItem adding submenu`, { name });
45258
+ trace(`${T$f} addItem adding submenu`, { name });
45273
45259
  $subMenu
45274
45260
  .addClass('gear-sub-menu-wrapper')
45275
45261
  .hide()
45276
45262
  .appendTo(this.$el.find('#gear-options-wrapper'));
45277
45263
  $item.on('click', (e) => {
45278
- trace(`${T$g} addItem submenu clicked`, { name });
45264
+ trace(`${T$f} addItem submenu clicked`, { name });
45279
45265
  e.stopPropagation();
45280
45266
  $subMenu.show();
45281
45267
  this.$el.find('#gear-options').hide();
@@ -45284,15 +45270,15 @@ class BottomGear extends UICorePlugin {
45284
45270
  return $item;
45285
45271
  }
45286
45272
  onActiveContainerChanged() {
45287
- trace(`${T$g} onActiveContainerChanged`);
45273
+ trace(`${T$f} onActiveContainerChanged`);
45288
45274
  this.bindContainerEvents();
45289
45275
  }
45290
45276
  bindContainerEvents() {
45291
- trace(`${T$g} bindContainerEvents`);
45277
+ trace(`${T$f} bindContainerEvents`);
45292
45278
  this.listenTo(this.core.activeContainer, Events$1.CONTAINER_HIGHDEFINITIONUPDATE, this.highDefinitionUpdate);
45293
45279
  }
45294
45280
  highDefinitionUpdate(isHd) {
45295
- trace(`${T$g} highDefinitionUpdate`, { isHd });
45281
+ trace(`${T$f} highDefinitionUpdate`, { isHd });
45296
45282
  this.hd = isHd;
45297
45283
  this.$el.find('.gear-icon').html(isHd ? gearHdIcon : gearIcon);
45298
45284
  }
@@ -45300,7 +45286,7 @@ class BottomGear extends UICorePlugin {
45300
45286
  * @internal
45301
45287
  */
45302
45288
  render() {
45303
- trace(`${T$g} render`);
45289
+ trace(`${T$f} render`);
45304
45290
  const mediaControl = this.core.getPlugin('media_control');
45305
45291
  if (!mediaControl) {
45306
45292
  return this; // TODO test
@@ -45332,11 +45318,11 @@ class BottomGear extends UICorePlugin {
45332
45318
  this.$el.find('#gear-options-wrapper').toggle();
45333
45319
  }
45334
45320
  hide() {
45335
- trace(`${T$g} hide`);
45321
+ trace(`${T$f} hide`);
45336
45322
  this.$el.find('#gear-options-wrapper').hide();
45337
45323
  }
45338
45324
  onCoreReady() {
45339
- trace(`${T$g} onCoreReady`);
45325
+ trace(`${T$f} onCoreReady`);
45340
45326
  const mediaControl = this.core.getPlugin('media_control');
45341
45327
  assert(mediaControl, 'media_control plugin is required');
45342
45328
  this.listenTo(mediaControl, Events$1.MEDIACONTROL_RENDERED, this.onMediaControlRendered);
@@ -45348,7 +45334,7 @@ class BottomGear extends UICorePlugin {
45348
45334
  });
45349
45335
  }
45350
45336
  onMediaControlRendered() {
45351
- trace(`${T$g} onMediaControlRendered`);
45337
+ trace(`${T$f} onMediaControlRendered`);
45352
45338
  const mediaControl = this.core.getPlugin('media_control');
45353
45339
  mediaControl.mount('gear', this.$el);
45354
45340
  }
@@ -45512,7 +45498,11 @@ class ClapprStats extends ContainerPlugin {
45512
45498
  this.listenToOnce(this.container, Events$1.CONTAINER_STATE_BUFFERING, this.onBuffering);
45513
45499
  this.listenTo(this.container, Events$1.CONTAINER_SEEK, this.onSeek);
45514
45500
  this.listenTo(this.container, Events$1.CONTAINER_ERROR, () => this.inc(ClapprStatsCounter.Error));
45515
- this.listenTo(this.container, Events$1.CONTAINER_FULLSCREEN, () => this.inc(ClapprStatsCounter.Fullscreen));
45501
+ this.listenTo(this.container, Events$1.CONTAINER_FULLSCREEN, () => {
45502
+ if (isFullscreen(this.container.el)) {
45503
+ this.inc(ClapprStatsCounter.Fullscreen);
45504
+ }
45505
+ });
45516
45506
  this.listenTo(this.container, Events$1.CONTAINER_PLAYBACKDVRSTATECHANGED, (dvrInUse) => {
45517
45507
  dvrInUse && this.inc(ClapprStatsCounter.DvrUsage);
45518
45508
  });
@@ -45580,8 +45570,9 @@ class ClapprStats extends ContainerPlugin {
45580
45570
  this.stopListening(this.container, Events$1.CONTAINER_TIMEUPDATE, this.onContainerUpdateWhilePlaying);
45581
45571
  }
45582
45572
  onSeek(e) {
45573
+ const ms = e * 1000;
45583
45574
  this.inc(ClapprStatsCounter.Seek);
45584
- this.metrics.extra.watchHistory.push([e * 1000, e * 1000]);
45575
+ this.metrics.extra.watchHistory.push([ms, ms]);
45585
45576
  }
45586
45577
  onTimeUpdate(e) {
45587
45578
  const current = e.current * 1000, total = e.total * 1000, l = this.metrics.extra.watchHistory.length;
@@ -47503,9 +47494,7 @@ class Speedtest {
47503
47494
  if (e.data === this._prevData) {
47504
47495
  return;
47505
47496
  }
47506
- else {
47507
- this._prevData = e.data;
47508
- }
47497
+ this._prevData = e.data;
47509
47498
  const data = e.data;
47510
47499
  try {
47511
47500
  if (this.onupdate) {
@@ -47586,7 +47575,7 @@ class Speedtest {
47586
47575
  const DIGITS_THRESHOLD = 99999;
47587
47576
  const DEFAULT_DOWNLOAD_SPEED = '0.00';
47588
47577
  const DRAW_SIZE = 5;
47589
- const T$f = 'plugins.clappr_nerd_stats.speedtest';
47578
+ // const T = 'plugins.clappr_nerd_stats.speedtest';
47590
47579
  function limitDigits(value) {
47591
47580
  return value > DIGITS_THRESHOLD ? '> ' + DIGITS_THRESHOLD : value.toFixed(2);
47592
47581
  }
@@ -47614,7 +47603,6 @@ const getColor = (speedValue) => {
47614
47603
  }
47615
47604
  };
47616
47605
  function drawSpeedTestResults() {
47617
- trace(`${T$f} drawSpeedTestResults`);
47618
47606
  const canvas = document.getElementById('nerd-stats-speed-test-canvas');
47619
47607
  if (!canvas) {
47620
47608
  return;
@@ -47637,7 +47625,6 @@ const initSpeedTest = (customMetrics) => {
47637
47625
  return inited;
47638
47626
  }
47639
47627
  inited = (async () => {
47640
- trace(`${T$f} initSpeedTest run`);
47641
47628
  // TODO: fix server selection
47642
47629
  // const response = await fetch('https://iam.gcdn.co/info/json');
47643
47630
  // const data = await response.json();
@@ -47692,7 +47679,6 @@ const initSpeedTest = (customMetrics) => {
47692
47679
  await fetch('https://iam.gcdn.co/info/json')
47693
47680
  .then(r => r.json())
47694
47681
  .then(data => {
47695
- trace(`${T$f} initSpeedTest fetched`);
47696
47682
  const country = data['Server Country code'].toLowerCase();
47697
47683
  const server = serversList.find(s => s.country === country) || serversList[0];
47698
47684
  if (!server) {
@@ -47700,7 +47686,6 @@ const initSpeedTest = (customMetrics) => {
47700
47686
  }
47701
47687
  speedTest.addTestPoint(server);
47702
47688
  speedTest.setSelectedServer(server);
47703
- trace(`${T$f} initSpeedTest done`);
47704
47689
  });
47705
47690
  })();
47706
47691
  return inited;
@@ -47716,7 +47701,6 @@ const startSpeedtest = () => {
47716
47701
  }
47717
47702
  };
47718
47703
  const clearSpeedTestResults = () => {
47719
- trace(`${T$f} clearSpeedTestResults`);
47720
47704
  speedtestResults.splice(0, speedtestResults.length);
47721
47705
  };
47722
47706
  function configureSpeedTest(servers) {
@@ -47968,7 +47952,6 @@ class NerdStats extends UICorePlugin {
47968
47952
  this.$el.show();
47969
47953
  this.statsBoxElem.scrollTop(this.statsBoxElem.scrollTop());
47970
47954
  this.open = true;
47971
- this.refreshSpeedTest();
47972
47955
  initSpeedTest(this.speedtestMetrics)
47973
47956
  .then(() => {
47974
47957
  startSpeedtest();
@@ -48000,7 +47983,6 @@ class NerdStats extends UICorePlugin {
48000
47983
  .text(this.metrics.general.resolution.height);
48001
47984
  }
48002
47985
  estimateQuality() {
48003
- trace(`${T$e} estimateQuality`);
48004
47986
  const videoQualityNames = [
48005
47987
  'SD (480p)',
48006
47988
  'HD (720p)',
@@ -48025,7 +48007,6 @@ class NerdStats extends UICorePlugin {
48025
48007
  prefix + videoQualityNames[liveQuality - 1];
48026
48008
  }
48027
48009
  updateMetrics(metrics) {
48028
- trace(`${T$e} updateMetrics`, { custom: this.speedtestMetrics });
48029
48010
  Object.assign(this.metrics, metrics);
48030
48011
  this.metrics.custom = {
48031
48012
  ...this.speedtestMetrics,
@@ -48156,6 +48137,7 @@ class NerdStats extends UICorePlugin {
48156
48137
  });
48157
48138
  }
48158
48139
  clearSpeedtestMetrics() {
48140
+ trace(`${T$e} clearSpeedtestMetrics`);
48159
48141
  const clapprStats = this.container?.getPlugin('clappr_stats');
48160
48142
  this.speedtestMetrics.connectionSpeed = 0;
48161
48143
  this.speedtestMetrics.ping = 0;