@codercms/web-player 0.0.1

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.
Files changed (39) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +3 -0
  3. package/dist/HybridDoublyLinkedList.d.ts +20 -0
  4. package/dist/HybridDoublyLinkedList.js +90 -0
  5. package/dist/HybridDoublyLinkedList.js.map +1 -0
  6. package/dist/HybridLinkedList.d.ts +18 -0
  7. package/dist/HybridLinkedList.js +90 -0
  8. package/dist/HybridLinkedList.js.map +1 -0
  9. package/dist/core/HLSLoader.d.ts +18 -0
  10. package/dist/core/HLSLoader.js +144 -0
  11. package/dist/core/HLSLoader.js.map +1 -0
  12. package/dist/core/LoaderInterface.d.ts +37 -0
  13. package/dist/core/LoaderInterface.js +27 -0
  14. package/dist/core/LoaderInterface.js.map +1 -0
  15. package/dist/core/Playlist.d.ts +60 -0
  16. package/dist/core/Playlist.js +141 -0
  17. package/dist/core/Playlist.js.map +1 -0
  18. package/dist/core/PlaylistPlayer.d.ts +29 -0
  19. package/dist/core/PlaylistPlayer.js +82 -0
  20. package/dist/core/PlaylistPlayer.js.map +1 -0
  21. package/dist/core/QualityLevel.d.ts +7 -0
  22. package/dist/core/QualityLevel.js +1 -0
  23. package/dist/core/QualityLevel.js.map +1 -0
  24. package/dist/core/VideoPlayer.d.ts +104 -0
  25. package/dist/core/VideoPlayer.js +342 -0
  26. package/dist/core/VideoPlayer.js.map +1 -0
  27. package/dist/index.d.ts +0 -0
  28. package/dist/index.js +1 -0
  29. package/dist/ui/LoadingIndicator.svelte +74 -0
  30. package/dist/ui/LoadingIndicator.svelte.d.ts +18 -0
  31. package/dist/ui/ProgressBar.svelte +283 -0
  32. package/dist/ui/ProgressBar.svelte.d.ts +17 -0
  33. package/dist/ui/utils/duration.d.ts +1 -0
  34. package/dist/ui/utils/duration.js +23 -0
  35. package/dist/ui/utils/duration.js.map +1 -0
  36. package/dist/ui/utils/slider.d.ts +25 -0
  37. package/dist/ui/utils/slider.js +132 -0
  38. package/dist/ui/utils/slider.js.map +1 -0
  39. package/package.json +54 -0
@@ -0,0 +1,342 @@
1
+ import { EventEmitter } from 'eventemitter3';
2
+ import { HLSLoader, isHlsJsSupported } from './HLSLoader.js';
3
+ import { LoaderEvents } from './LoaderInterface.js';
4
+ import { BROWSER } from 'esm-env';
5
+ export var PlayerEvents;
6
+ (function (PlayerEvents) {
7
+ PlayerEvents["Play"] = "player.play";
8
+ PlayerEvents["Pause"] = "player.pause";
9
+ PlayerEvents["Ended"] = "player.ended";
10
+ PlayerEvents["Error"] = "player.error";
11
+ PlayerEvents["Playing"] = "player.playing";
12
+ PlayerEvents["LoadingStarted"] = "player.loadingStarted";
13
+ PlayerEvents["LoadingEnded"] = "player.loadingEnded";
14
+ PlayerEvents["PlaybackBufferingProgress"] = "player.bufferingProgress";
15
+ PlayerEvents["PlaybackDurationChange"] = "player.durationChange";
16
+ PlayerEvents["PlaybackTimeUpdate"] = "player.timeUpdate";
17
+ PlayerEvents["PlaybackRateChange"] = "player.playbackRateChange";
18
+ PlayerEvents["VolumeChange"] = "player.volumeChange";
19
+ PlayerEvents["MuteChange"] = "player.muteChange";
20
+ PlayerEvents["VolumeStateChange"] = "player.volumeStateChange";
21
+ PlayerEvents["QualityLevelsUpdated"] = "player.qualityLevelsUpdated";
22
+ PlayerEvents["QualityLevelSwitched"] = "player.qualityLevelSwitched";
23
+ })(PlayerEvents || (PlayerEvents = {}));
24
+ export var PlayerActions;
25
+ (function (PlayerActions) {
26
+ PlayerActions["PlayItem"] = "player.playItem";
27
+ })(PlayerActions || (PlayerActions = {}));
28
+ export var Loader;
29
+ (function (Loader) {
30
+ Loader[Loader["Native"] = 0] = "Native";
31
+ Loader[Loader["HLS"] = 1] = "HLS";
32
+ Loader[Loader["DASH"] = 2] = "DASH";
33
+ })(Loader || (Loader = {}));
34
+ export class VideoPlayer {
35
+ el;
36
+ emitter;
37
+ loadAbortController = null;
38
+ currentLoader = null;
39
+ hlsLoader = null;
40
+ _isLoading = false;
41
+ _duration = 0;
42
+ _paused = true;
43
+ _currentTime = 0;
44
+ _playbackRate = 0;
45
+ _muted = false;
46
+ _volume = 1;
47
+ _buffered = new Array();
48
+ _isAutoQuality = true;
49
+ _currentQualityLevel = null;
50
+ _qualityLevels = [];
51
+ constructor(el, emitter = new EventEmitter()) {
52
+ this.el = el;
53
+ this.emitter = emitter;
54
+ // Do nothing in SSR environment
55
+ if (!BROWSER) {
56
+ return;
57
+ }
58
+ this._paused = el.paused;
59
+ this._muted = el.muted;
60
+ this._volume = el.volume;
61
+ this._currentTime = el.currentTime;
62
+ this._playbackRate = el.playbackRate;
63
+ // Setup HLS.js loader
64
+ if (isHlsJsSupported()) {
65
+ // @ts-ignore
66
+ this.hlsLoader = new HLSLoader(this.emitter, this.el, {
67
+ progressive: true
68
+ });
69
+ }
70
+ this.emitter.on(LoaderEvents.QualityLevelsUpdated, (newLevels) => {
71
+ console.log('Quality levels updated', newLevels);
72
+ this._qualityLevels = newLevels;
73
+ this.emitter.emit(PlayerEvents.QualityLevelsUpdated, newLevels);
74
+ });
75
+ this.emitter.on(LoaderEvents.QualityLevelSwitched, (newLevelId) => {
76
+ const newLevel = this._qualityLevels.find((lvl) => lvl.id === newLevelId);
77
+ if (!newLevel) {
78
+ console.error(`Quality level switch to unknown level`, {
79
+ newLevelId,
80
+ levels: this._qualityLevels
81
+ });
82
+ return;
83
+ }
84
+ this._currentQualityLevel = newLevel;
85
+ this.emitter.emit(PlayerEvents.QualityLevelSwitched, newLevel);
86
+ });
87
+ this.emitter.on(LoaderEvents.QualityLevelsUpdated, () => { });
88
+ // this.emitter.on(PlayerEvents.Playing, () => {
89
+ // console.log('Playing...');
90
+ // });
91
+ //
92
+ // this.emitter.on(PlayerEvents.Play, () => {
93
+ // console.log('Play!');
94
+ // });
95
+ //
96
+ // this.emitter.on(PlayerEvents.Pause, () => {
97
+ // console.log('Pause!');
98
+ // });
99
+ //
100
+ // this.emitter.on(PlayerEvents.MuteChange, (muted: boolean) => {
101
+ // console.log('Mute change', { muted });
102
+ // });
103
+ //
104
+ // this.emitter.on(PlayerEvents.VolumeChange, (volume: number) => {
105
+ // console.log('Volume change', { volume });
106
+ // });
107
+ //
108
+ // this.emitter.on(PlayerEvents.PlaybackRateChange, (rate: number) => {
109
+ // console.log('Playback rate change', { rate });
110
+ // });
111
+ //
112
+ // this.emitter.on(PlayerEvents.LoadingStarted, () => {
113
+ // console.log('Video Loading...');
114
+ // });
115
+ //
116
+ // this.emitter.on(PlayerEvents.LoadingEnded, () => {
117
+ // console.log('Video Loaded...');
118
+ // });
119
+ this._registerVideoEvents();
120
+ }
121
+ _registerVideoEvents() {
122
+ this.el.addEventListener('play', () => {
123
+ this._paused = false;
124
+ this.emitter.emit(PlayerEvents.Play);
125
+ });
126
+ this.el.addEventListener('pause', () => this._onPause());
127
+ this.el.addEventListener('playing', () => {
128
+ // Playing event can occur before canplaythrough event, so send loaded event there too
129
+ this._onLoaded();
130
+ this.emitter.emit(PlayerEvents.Playing);
131
+ });
132
+ this.el.addEventListener('waiting', () => {
133
+ // Loading event is already sent
134
+ if (this._isLoading) {
135
+ return;
136
+ }
137
+ this._isLoading = true;
138
+ this.emitter.emit(PlayerEvents.LoadingStarted);
139
+ });
140
+ this.el.addEventListener('ended', () => this.emitter.emit(PlayerEvents.Ended));
141
+ this.el.addEventListener('progress', () => this._onProgress());
142
+ this.el.addEventListener('canplaythrough', () => {
143
+ this._onLoaded();
144
+ });
145
+ this.el.addEventListener('durationchange', () => {
146
+ let newDur = this.el.duration;
147
+ if (!isFinite(newDur) || isNaN(newDur)) {
148
+ newDur = 0;
149
+ }
150
+ if (this._duration !== newDur) {
151
+ this._duration = newDur;
152
+ this.emitter.emit(PlayerEvents.PlaybackDurationChange, newDur);
153
+ }
154
+ });
155
+ this.el.addEventListener('timeupdate', () => {
156
+ let newTime = this.el.currentTime;
157
+ if (!isFinite(newTime) || isNaN(newTime)) {
158
+ newTime = 0;
159
+ }
160
+ if (this._currentTime !== newTime) {
161
+ this._currentTime = newTime;
162
+ this.emitter.emit(PlayerEvents.PlaybackTimeUpdate, newTime);
163
+ }
164
+ // Buffered parts may not be dispatched in on progress event
165
+ // so take care that there is always fresh buffered parts
166
+ this._onProgress();
167
+ });
168
+ this.el.addEventListener('ratechange', () => {
169
+ const newRate = this.el.playbackRate;
170
+ if (this._playbackRate !== newRate) {
171
+ this._playbackRate = newRate;
172
+ this.emitter.emit(PlayerEvents.PlaybackRateChange, newRate);
173
+ }
174
+ });
175
+ this.el.addEventListener('volumechange', () => {
176
+ const newVol = this.el.volume;
177
+ const newMuted = this.el.muted;
178
+ const isVolChanged = this._volume !== newVol;
179
+ const isMuteChanged = this._muted !== newMuted;
180
+ if (isVolChanged) {
181
+ this._volume = newVol;
182
+ this.emitter.emit(PlayerEvents.VolumeChange, newVol);
183
+ }
184
+ if (isMuteChanged) {
185
+ this._muted = newMuted;
186
+ this.emitter.emit(PlayerEvents.MuteChange, newMuted);
187
+ }
188
+ if (isVolChanged || isMuteChanged) {
189
+ this.emitter.emit(PlayerEvents.VolumeStateChange, newVol, newMuted);
190
+ }
191
+ });
192
+ this.el.addEventListener('error', (ev) => {
193
+ this.emitter.emit(PlayerEvents.Error, ev.error ?? 'unknown playback error');
194
+ });
195
+ }
196
+ _onPause() {
197
+ this._paused = true;
198
+ this.emitter.emit(PlayerEvents.Pause);
199
+ }
200
+ _onProgress() {
201
+ const newBuf = this.el.buffered;
202
+ const parts = [];
203
+ if (newBuf.length !== this._buffered.length) {
204
+ for (let i = 0; i < newBuf.length; i++) {
205
+ parts.push({ start: newBuf.start(i), end: newBuf.end(i) });
206
+ }
207
+ this._buffered = parts;
208
+ this.emitter.emit(PlayerEvents.PlaybackBufferingProgress, parts);
209
+ return;
210
+ }
211
+ let isChanged = false;
212
+ for (let i = 0; i < newBuf.length; i++) {
213
+ const start = newBuf.start(i);
214
+ const end = newBuf.end(i);
215
+ isChanged = start !== this._buffered[i].start || end !== this._buffered[i].end;
216
+ parts.push({ start, end });
217
+ }
218
+ if (!isChanged) {
219
+ return;
220
+ }
221
+ this._buffered = parts;
222
+ this.emitter.emit(PlayerEvents.PlaybackBufferingProgress, parts);
223
+ }
224
+ _onLoaded() {
225
+ if (this._isLoading) {
226
+ this._isLoading = false;
227
+ this.emitter.emit(PlayerEvents.LoadingEnded);
228
+ }
229
+ }
230
+ async load(params) {
231
+ if (this.loadAbortController) {
232
+ this.loadAbortController.abort('next loadPlaylistItem call');
233
+ this.loadAbortController = null;
234
+ }
235
+ this._isLoading = true;
236
+ this.emitter.emit(PlayerEvents.LoadingStarted);
237
+ this.loadAbortController = new AbortController();
238
+ let neededLoader = null;
239
+ if (params.loader !== undefined) {
240
+ switch (params.loader) {
241
+ case Loader.HLS:
242
+ neededLoader = this.hlsLoader;
243
+ break;
244
+ default:
245
+ throw Error('unknown loader selected');
246
+ }
247
+ }
248
+ else {
249
+ // TODO: detect loader
250
+ neededLoader = this.hlsLoader;
251
+ }
252
+ if (neededLoader === null) {
253
+ throw Error('Cannot find suitable loader');
254
+ }
255
+ if (this.currentLoader && this.currentLoader !== neededLoader) {
256
+ this.currentLoader.stop();
257
+ }
258
+ // Send video loading event
259
+ this._isLoading = true;
260
+ this.emitter.emit(PlayerEvents.LoadingStarted);
261
+ this.currentLoader = neededLoader;
262
+ return neededLoader.load({
263
+ abortSignal: this.loadAbortController.signal,
264
+ url: params.url,
265
+ getUrlCb: params.getUrlCb,
266
+ startLevel: params.startLevel,
267
+ startPosition: params.startPosition,
268
+ audioTrack: params.audioTrack
269
+ });
270
+ }
271
+ async togglePlay() {
272
+ if (this.el.paused) {
273
+ return this.play();
274
+ }
275
+ this.el.pause();
276
+ return Promise.resolve();
277
+ }
278
+ async play() {
279
+ return this.el.play();
280
+ }
281
+ pause() {
282
+ this.el.pause();
283
+ }
284
+ seekTo(pos) {
285
+ this.el.currentTime = pos;
286
+ }
287
+ setQualityLevel(id, graceful) {
288
+ const found = this._qualityLevels.find((lvl) => lvl.id === id);
289
+ if (!found) {
290
+ throw Error(`Quality level not found: ${id}`);
291
+ }
292
+ if (!this.currentLoader) {
293
+ throw Error('Loader is not set');
294
+ }
295
+ this.currentLoader.switchQualityLevel(id, graceful);
296
+ }
297
+ setAutoQualityLevel(graceful) {
298
+ if (!this.currentLoader) {
299
+ throw Error('Loader is not set');
300
+ }
301
+ this.currentLoader.switchQualityLevel(this.currentLoader.getAutoQualityLevelId(), graceful);
302
+ }
303
+ subscribe(ev, cb) {
304
+ this.emitter.on(ev, cb);
305
+ }
306
+ unsubscribe(ev, cb) {
307
+ this.emitter.off(ev, cb);
308
+ }
309
+ get isLoading() {
310
+ return this._isLoading;
311
+ }
312
+ get qualityLevels() {
313
+ return this._qualityLevels;
314
+ }
315
+ get isAutoQuality() {
316
+ return this._isAutoQuality;
317
+ }
318
+ get qualityLevel() {
319
+ return this._currentQualityLevel;
320
+ }
321
+ get duration() {
322
+ return this._duration;
323
+ }
324
+ get paused() {
325
+ return this._paused;
326
+ }
327
+ get currentTime() {
328
+ return this._currentTime;
329
+ }
330
+ get buffered() {
331
+ return this._buffered;
332
+ }
333
+ get playbackRate() {
334
+ return this._playbackRate;
335
+ }
336
+ get volume() {
337
+ return this._volume;
338
+ }
339
+ get muted() {
340
+ return this._muted;
341
+ }
342
+ }
@@ -0,0 +1 @@
1
+ {"version":3,"file":"VideoPlayer.js","sourceRoot":"","sources":["VideoPlayer.ts"],"names":[],"mappings":"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"}
File without changes
package/dist/index.js ADDED
@@ -0,0 +1 @@
1
+ // Reexport your entry components here
@@ -0,0 +1,74 @@
1
+ <script>import { PlayerEvents, VideoPlayer } from "../core/VideoPlayer";
2
+ import { onMount } from "svelte";
3
+ export let player;
4
+ export let loadThreshold = 200;
5
+ let loading = false;
6
+ let timeoutId = 0;
7
+ const setLoading = () => {
8
+ if (timeoutId) {
9
+ return;
10
+ }
11
+ timeoutId = window.setTimeout(() => {
12
+ loading = true;
13
+ }, loadThreshold);
14
+ };
15
+ const setLoaded = () => {
16
+ if (timeoutId) {
17
+ window.clearTimeout(timeoutId);
18
+ timeoutId = 0;
19
+ }
20
+ loading = false;
21
+ };
22
+ onMount(() => {
23
+ player.subscribe(PlayerEvents.LoadingStarted, setLoading);
24
+ player.subscribe(PlayerEvents.LoadingEnded, setLoaded);
25
+ });
26
+ </script>
27
+
28
+ <div class="loading-container" style:visibility={loading ? `visible` : `hidden`}>
29
+ <div class="loader" />
30
+ </div>
31
+
32
+ <style>
33
+ /* Define CSS variables to control the animation */
34
+ :root {
35
+ --loader-size: 40px; /* Size of the loader */
36
+ --loader-border-width: 4px; /* Border width of the loader */
37
+ --loader-border-color: #3498db; /* Border color of the loader */
38
+ --loader-speed: 1s; /* Animation speed */
39
+ }
40
+
41
+ /* Styling for the loading indicator container */
42
+ .loading-container {
43
+ position: absolute;
44
+ visibility: hidden;
45
+ left: 0;
46
+ top: 0;
47
+ right: 0; /* Ensure the container spans the full width */
48
+ display: flex;
49
+ justify-content: center;
50
+ align-items: center;
51
+ height: 100%;
52
+ pointer-events: none; /* Make the loader non-interactive */
53
+ }
54
+
55
+ /* Styling for the loader */
56
+ .loader {
57
+ width: var(--loader-size);
58
+ height: var(--loader-size);
59
+ border: var(--loader-border-width) solid var(--loader-border-color);
60
+ border-top: var(--loader-border-width) solid transparent;
61
+ border-radius: 50%;
62
+ animation: spin var(--loader-speed) linear infinite;
63
+ }
64
+
65
+ /* Keyframes for the loader animation */
66
+ @keyframes spin {
67
+ 0% {
68
+ transform: rotate(0deg);
69
+ }
70
+ 100% {
71
+ transform: rotate(360deg);
72
+ }
73
+ }
74
+ </style>
@@ -0,0 +1,18 @@
1
+ import { SvelteComponent } from "svelte";
2
+ import { VideoPlayer } from '../core/VideoPlayer';
3
+ declare const __propDef: {
4
+ props: {
5
+ player: VideoPlayer;
6
+ loadThreshold?: number | undefined;
7
+ };
8
+ events: {
9
+ [evt: string]: CustomEvent<any>;
10
+ };
11
+ slots: {};
12
+ };
13
+ export type LoadingIndicatorProps = typeof __propDef.props;
14
+ export type LoadingIndicatorEvents = typeof __propDef.events;
15
+ export type LoadingIndicatorSlots = typeof __propDef.slots;
16
+ export default class LoadingIndicator extends SvelteComponent<LoadingIndicatorProps, LoadingIndicatorEvents, LoadingIndicatorSlots> {
17
+ }
18
+ export {};