agent-ecosystem/landing/product-docs/.vitepress/theme/DocsHeroVisual.vue
2026-05-04 17:21:05 +03:00

80 lines
2.2 KiB
Vue

<script setup lang="ts">
import { withBase } from "vitepress";
</script>
<template>
<div class="docs-hero-visual">
<video
class="docs-hero-visual__video no-zoom"
autoplay
muted
loop
playsinline
preload="metadata"
:poster="withBase('/screenshots/1.jpg')"
>
<source :src="withBase('/video/demo.mp4')" type="video/mp4">
</video>
<div class="docs-hero-visual__wash" />
<div class="docs-hero-visual__edge" />
</div>
</template>
<style scoped>
.docs-hero-visual {
position: absolute;
inset: -130px -120px -110px;
overflow: hidden;
pointer-events: none;
}
.docs-hero-visual__video {
position: absolute;
inset: 0;
display: block;
width: 100%;
height: 100%;
object-fit: cover;
filter: blur(14px) saturate(1.32) contrast(1.14);
opacity: 0.62;
mix-blend-mode: multiply;
transform: scale(1.04);
}
.docs-hero-visual__wash {
position: absolute;
inset: 0;
background:
linear-gradient(90deg, var(--vp-c-bg) 0%, color-mix(in srgb, var(--vp-c-bg) 84%, transparent) 34%, color-mix(in srgb, var(--vp-c-bg) 24%, transparent) 64%, color-mix(in srgb, var(--vp-c-bg) 50%, transparent) 100%),
linear-gradient(180deg, color-mix(in srgb, var(--vp-c-bg) 52%, transparent) 0%, color-mix(in srgb, var(--vp-c-bg) 64%, transparent) 58%, var(--vp-c-bg) 96%);
}
.docs-hero-visual__edge {
position: absolute;
inset: auto 0 0;
height: 42%;
background: linear-gradient(180deg, transparent, var(--vp-c-bg));
}
.dark .docs-hero-visual__video {
opacity: 0.52;
filter: blur(16px) saturate(1.38) contrast(1.14);
mix-blend-mode: normal;
}
.dark .docs-hero-visual__wash {
background:
linear-gradient(90deg, var(--vp-c-bg) 0%, color-mix(in srgb, var(--vp-c-bg) 78%, transparent) 34%, color-mix(in srgb, var(--vp-c-bg) 26%, transparent) 64%, color-mix(in srgb, var(--vp-c-bg) 58%, transparent) 100%),
linear-gradient(180deg, color-mix(in srgb, var(--vp-c-bg) 50%, transparent) 0%, color-mix(in srgb, var(--vp-c-bg) 68%, transparent) 58%, var(--vp-c-bg) 96%);
}
@media (max-width: 768px) {
.docs-hero-visual {
inset: -90px -72px -80px;
}
.docs-hero-visual__video {
opacity: 0.16;
}
}
</style>