<div class="non-autoplay-gifv" style="width: {width}px; height: {height}px;" on:mouseover="onMouseOver(event)" ref:node > {#if playing} <AutoplayVideo className={class} ariaLabel={label} {poster} {src} {width} {height} /> {:else} <LazyImage alt={label || ''} title={label || ''} src={staticSrc} fallback={oneTransparentPixel} {width} {height} background="var(--loading-bg)" className={class} /> {/if} <PlayVideoIcon className={playing ? 'hidden' : ''}/> </div> <style> .non-autoplay-gifv { cursor: zoom-in; position: relative; } :global(.non-autoplay-gifv .play-video-icon) { transition: opacity 0.2s linear; } </style> <script> import { mouseover } from '../_utils/events' import PlayVideoIcon from './PlayVideoIcon.html' import { ONE_TRANSPARENT_PIXEL } from '../_static/media' import LazyImage from './LazyImage.html' import AutoplayVideo from './AutoplayVideo.html' export default { methods: { onMouseOver (mouseOver) { this.set({ playing: mouseOver }) } }, events: { mouseover }, data: () => ({ oneTransparentPixel: ONE_TRANSPARENT_PIXEL }), components: { PlayVideoIcon, LazyImage, AutoplayVideo } } </script>