mirror of https://github.com/sveltejs/svelte
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
146 lines
4.4 KiB
146 lines
4.4 KiB
/* generated by Svelte vX.Y.Z */
|
|
import {
|
|
SvelteComponent,
|
|
add_iframe_resize_listener,
|
|
add_render_callback,
|
|
detach,
|
|
element,
|
|
init,
|
|
insert,
|
|
listen,
|
|
noop,
|
|
raf,
|
|
run_all,
|
|
safe_not_equal
|
|
} from "svelte/internal";
|
|
|
|
function create_fragment(ctx) {
|
|
let video;
|
|
let video_updating = false;
|
|
let video_animationframe;
|
|
let video_resize_listener;
|
|
let mounted;
|
|
let dispose;
|
|
|
|
function video_timeupdate_handler() {
|
|
cancelAnimationFrame(video_animationframe);
|
|
|
|
if (!video.paused) {
|
|
video_animationframe = raf(video_timeupdate_handler);
|
|
video_updating = true;
|
|
}
|
|
|
|
/*video_timeupdate_handler*/ ctx[5].call(video);
|
|
}
|
|
|
|
return {
|
|
c() {
|
|
video = element("video");
|
|
if (/*videoHeight*/ ctx[1] === void 0 || /*videoWidth*/ ctx[2] === void 0) add_render_callback(() => /*video_resize_handler*/ ctx[6].call(video));
|
|
add_render_callback(() => /*video_elementresize_handler*/ ctx[7].call(video));
|
|
if (/*readyState*/ ctx[4] === void 0) add_render_callback(() => /*video_loadedmetadata_loadeddata_canplay_canplaythrough_playing_waiting_emptied_handler*/ ctx[8].call(video));
|
|
},
|
|
m(target, anchor) {
|
|
insert(target, video, anchor);
|
|
video_resize_listener = add_iframe_resize_listener(video, /*video_elementresize_handler*/ ctx[7].bind(video));
|
|
|
|
if (!mounted) {
|
|
dispose = [
|
|
listen(video, "timeupdate", video_timeupdate_handler),
|
|
listen(video, "resize", /*video_resize_handler*/ ctx[6]),
|
|
listen(video, "loadedmetadata", /*video_loadedmetadata_loadeddata_canplay_canplaythrough_playing_waiting_emptied_handler*/ ctx[8]),
|
|
listen(video, "loadeddata", /*video_loadedmetadata_loadeddata_canplay_canplaythrough_playing_waiting_emptied_handler*/ ctx[8]),
|
|
listen(video, "canplay", /*video_loadedmetadata_loadeddata_canplay_canplaythrough_playing_waiting_emptied_handler*/ ctx[8]),
|
|
listen(video, "canplaythrough", /*video_loadedmetadata_loadeddata_canplay_canplaythrough_playing_waiting_emptied_handler*/ ctx[8]),
|
|
listen(video, "playing", /*video_loadedmetadata_loadeddata_canplay_canplaythrough_playing_waiting_emptied_handler*/ ctx[8]),
|
|
listen(video, "waiting", /*video_loadedmetadata_loadeddata_canplay_canplaythrough_playing_waiting_emptied_handler*/ ctx[8]),
|
|
listen(video, "emptied", /*video_loadedmetadata_loadeddata_canplay_canplaythrough_playing_waiting_emptied_handler*/ ctx[8])
|
|
];
|
|
|
|
mounted = true;
|
|
}
|
|
},
|
|
p(ctx, [dirty]) {
|
|
if (!video_updating && dirty & /*currentTime*/ 1 && !isNaN(/*currentTime*/ ctx[0])) {
|
|
video.currentTime = /*currentTime*/ ctx[0];
|
|
}
|
|
|
|
video_updating = false;
|
|
},
|
|
i: noop,
|
|
o: noop,
|
|
d(detaching) {
|
|
if (detaching) detach(video);
|
|
video_resize_listener();
|
|
mounted = false;
|
|
run_all(dispose);
|
|
}
|
|
};
|
|
}
|
|
|
|
function instance($$self, $$props, $$invalidate) {
|
|
let { currentTime } = $$props;
|
|
let { videoHeight } = $$props;
|
|
let { videoWidth } = $$props;
|
|
let { offsetWidth } = $$props;
|
|
let { readyState } = $$props;
|
|
|
|
function video_timeupdate_handler() {
|
|
currentTime = this.currentTime;
|
|
$$invalidate(0, currentTime);
|
|
}
|
|
|
|
function video_resize_handler() {
|
|
videoHeight = this.videoHeight;
|
|
videoWidth = this.videoWidth;
|
|
$$invalidate(1, videoHeight);
|
|
$$invalidate(2, videoWidth);
|
|
}
|
|
|
|
function video_elementresize_handler() {
|
|
offsetWidth = this.offsetWidth;
|
|
$$invalidate(3, offsetWidth);
|
|
}
|
|
|
|
function video_loadedmetadata_loadeddata_canplay_canplaythrough_playing_waiting_emptied_handler() {
|
|
readyState = this.readyState;
|
|
$$invalidate(4, readyState);
|
|
}
|
|
|
|
$$self.$$set = $$props => {
|
|
if ('currentTime' in $$props) $$invalidate(0, currentTime = $$props.currentTime);
|
|
if ('videoHeight' in $$props) $$invalidate(1, videoHeight = $$props.videoHeight);
|
|
if ('videoWidth' in $$props) $$invalidate(2, videoWidth = $$props.videoWidth);
|
|
if ('offsetWidth' in $$props) $$invalidate(3, offsetWidth = $$props.offsetWidth);
|
|
if ('readyState' in $$props) $$invalidate(4, readyState = $$props.readyState);
|
|
};
|
|
|
|
return [
|
|
currentTime,
|
|
videoHeight,
|
|
videoWidth,
|
|
offsetWidth,
|
|
readyState,
|
|
video_timeupdate_handler,
|
|
video_resize_handler,
|
|
video_elementresize_handler,
|
|
video_loadedmetadata_loadeddata_canplay_canplaythrough_playing_waiting_emptied_handler
|
|
];
|
|
}
|
|
|
|
class Component extends SvelteComponent {
|
|
constructor(options) {
|
|
super();
|
|
|
|
init(this, options, instance, create_fragment, safe_not_equal, {
|
|
currentTime: 0,
|
|
videoHeight: 1,
|
|
videoWidth: 2,
|
|
offsetWidth: 3,
|
|
readyState: 4
|
|
});
|
|
}
|
|
}
|
|
|
|
export default Component;
|