@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.
- package/LICENSE +21 -0
- package/README.md +3 -0
- package/dist/HybridDoublyLinkedList.d.ts +20 -0
- package/dist/HybridDoublyLinkedList.js +90 -0
- package/dist/HybridDoublyLinkedList.js.map +1 -0
- package/dist/HybridLinkedList.d.ts +18 -0
- package/dist/HybridLinkedList.js +90 -0
- package/dist/HybridLinkedList.js.map +1 -0
- package/dist/core/HLSLoader.d.ts +18 -0
- package/dist/core/HLSLoader.js +144 -0
- package/dist/core/HLSLoader.js.map +1 -0
- package/dist/core/LoaderInterface.d.ts +37 -0
- package/dist/core/LoaderInterface.js +27 -0
- package/dist/core/LoaderInterface.js.map +1 -0
- package/dist/core/Playlist.d.ts +60 -0
- package/dist/core/Playlist.js +141 -0
- package/dist/core/Playlist.js.map +1 -0
- package/dist/core/PlaylistPlayer.d.ts +29 -0
- package/dist/core/PlaylistPlayer.js +82 -0
- package/dist/core/PlaylistPlayer.js.map +1 -0
- package/dist/core/QualityLevel.d.ts +7 -0
- package/dist/core/QualityLevel.js +1 -0
- package/dist/core/QualityLevel.js.map +1 -0
- package/dist/core/VideoPlayer.d.ts +104 -0
- package/dist/core/VideoPlayer.js +342 -0
- package/dist/core/VideoPlayer.js.map +1 -0
- package/dist/index.d.ts +0 -0
- package/dist/index.js +1 -0
- package/dist/ui/LoadingIndicator.svelte +74 -0
- package/dist/ui/LoadingIndicator.svelte.d.ts +18 -0
- package/dist/ui/ProgressBar.svelte +283 -0
- package/dist/ui/ProgressBar.svelte.d.ts +17 -0
- package/dist/ui/utils/duration.d.ts +1 -0
- package/dist/ui/utils/duration.js +23 -0
- package/dist/ui/utils/duration.js.map +1 -0
- package/dist/ui/utils/slider.d.ts +25 -0
- package/dist/ui/utils/slider.js +132 -0
- package/dist/ui/utils/slider.js.map +1 -0
- 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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"}
|
package/dist/index.d.ts
ADDED
|
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 {};
|