Files
indee-demo/src/components/SplashIntro.vue
Dorian 5ebb3e20f9 Add heavily staggered border drawing animation
Draw sequence (cascading):
- 0.0s: Top left block starts
- 0.2s: Top right block
- 0.4s: Center circle
- 0.6s: Diagonal 1
- 0.8s: Diagonal 2
- 1.0s: Diagonal 3
- 1.2s: Diagonal 4
- 1.4s: Bottom left block
- 1.6s: Bottom center block
- 1.8s: Bottom right block

Undraw mirrors this in perfect reverse!
Creates a beautiful cascading effect.

Co-authored-by: Cursor <cursoragent@cursor.com>
2026-02-03 00:15:26 +00:00

385 lines
13 KiB
Vue

<template>
<Transition name="splash-fade">
<div v-if="showSplash" class="splash-screen">
<div class="splash-content">
<svg
width="400"
height="400"
viewBox="0 0 1374 1401"
fill="none"
xmlns="http://www.w3.org/2000/svg"
class="splash-logo"
>
<!-- Top Left Block -->
<path
class="logo-stroke logo-block-1"
d="M321.5 2.5V417.5H1.5V2.5H321.5Z"
stroke="url(#paint1_linear_548_65)"
stroke-width="3"
fill="transparent"
/>
<path
class="logo-fill logo-fill-1"
d="M321.5 2.5V417.5H1.5V2.5H321.5Z"
fill="url(#paint0_linear_548_65)"
/>
<!-- Top Right Block -->
<path
class="logo-stroke logo-block-2"
d="M1372.5 1.5V416.5H1052.5V1.5H1372.5Z"
stroke="url(#paint3_linear_548_65)"
stroke-width="3"
fill="transparent"
/>
<path
class="logo-fill logo-fill-2"
d="M1372.5 1.5V416.5H1052.5V1.5H1372.5Z"
fill="url(#paint2_linear_548_65)"
/>
<!-- Bottom Left Block -->
<path
class="logo-stroke logo-block-3"
d="M321.5 984.5V1399.5H1.5V984.5H321.5Z"
stroke="url(#paint5_linear_548_65)"
stroke-width="3"
fill="transparent"
/>
<path
class="logo-fill logo-fill-3"
d="M321.5 984.5V1399.5H1.5V984.5H321.5Z"
fill="url(#paint4_linear_548_65)"
/>
<!-- Center Bottom Block (Dark) -->
<path
class="logo-stroke logo-block-4"
d="M909.5 984.5V1399.5H464.5V984.5H909.5Z"
stroke="url(#paint6_linear_548_65)"
stroke-width="3"
fill="transparent"
/>
<path
class="logo-fill logo-fill-4"
d="M909.5 984.5V1399.5H464.5V984.5H909.5Z"
fill="#1D1D1D"
/>
<!-- Bottom Right Block -->
<path
class="logo-stroke logo-block-5"
d="M1372.5 983.5V1398.5H1052.5V983.5H1372.5Z"
stroke="url(#paint8_linear_548_65)"
stroke-width="3"
fill="transparent"
/>
<path
class="logo-fill logo-fill-5"
d="M1372.5 983.5V1398.5H1052.5V983.5H1372.5Z"
fill="url(#paint7_linear_548_65)"
/>
<!-- Center Diagonals -->
<path
class="logo-stroke logo-diagonal logo-diagonal-1"
d="M467.042 558.5L630.433 841.5H469.695L306.305 558.5H467.042Z"
stroke="url(#paint10_linear_548_65)"
stroke-width="3"
fill="transparent"
/>
<path
class="logo-fill logo-fill-6"
d="M467.042 558.5L630.433 841.5H469.695L306.305 558.5H467.042Z"
fill="url(#paint9_linear_548_65)"
/>
<path
class="logo-stroke logo-diagonal logo-diagonal-2"
d="M832.507 558.5L995.897 841.5H835.092L671.701 558.5H832.507Z"
stroke="url(#paint12_linear_548_65)"
stroke-width="3"
fill="transparent"
/>
<path
class="logo-fill logo-fill-7"
d="M832.507 558.5L995.897 841.5H835.092L671.701 558.5H832.507Z"
fill="url(#paint11_linear_548_65)"
/>
<path
class="logo-stroke logo-diagonal logo-diagonal-3"
d="M1372.5 558.5V841.5H1200.56L1037.17 558.5H1372.5Z"
stroke="url(#paint14_linear_548_65)"
stroke-width="3"
fill="transparent"
/>
<path
class="logo-fill logo-fill-8"
d="M1372.5 558.5V841.5H1200.56L1037.17 558.5H1372.5Z"
fill="url(#paint13_linear_548_65)"
/>
<path
class="logo-stroke logo-diagonal logo-diagonal-4"
d="M101.646 558.5L265.036 841.5H1.5V558.5H101.646Z"
stroke="url(#paint16_linear_548_65)"
stroke-width="3"
fill="transparent"
/>
<path
class="logo-fill logo-fill-9"
d="M101.646 558.5L265.036 841.5H1.5V558.5H101.646Z"
fill="url(#paint15_linear_548_65)"
/>
<!-- Center Circle -->
<circle
class="logo-stroke logo-circle"
cx="687.5"
cy="210.5"
r="209"
stroke="url(#paint17_linear_548_65)"
stroke-width="3"
fill="transparent"
/>
<circle
class="logo-fill logo-fill-10"
cx="687.5"
cy="210.5"
r="209"
fill="#1D1D1D"
/>
<defs>
<linearGradient id="paint0_linear_548_65" x1="124.804" y1="-297.569" x2="1351.77" y2="-186.399" gradientUnits="userSpaceOnUse">
<stop stop-color="#F0003D"/>
<stop offset="0.369792" stop-color="#FA4727"/>
<stop offset="0.776042" stop-color="#6B90F4"/>
</linearGradient>
<linearGradient id="paint1_linear_548_65" x1="0" y1="1" x2="323" y2="419" gradientUnits="userSpaceOnUse">
<stop stop-color="white"/>
<stop offset="1" stop-color="#F52532"/>
</linearGradient>
<linearGradient id="paint2_linear_548_65" x1="1175.8" y1="-298.569" x2="2402.77" y2="-187.399" gradientUnits="userSpaceOnUse">
<stop stop-color="#F0003D"/>
<stop offset="0.369792" stop-color="#FA4727"/>
<stop offset="0.776042" stop-color="#6B90F4"/>
</linearGradient>
<linearGradient id="paint3_linear_548_65" x1="1051" y1="0" x2="1374" y2="418" gradientUnits="userSpaceOnUse">
<stop stop-color="white"/>
<stop offset="1" stop-color="#F52532"/>
</linearGradient>
<linearGradient id="paint4_linear_548_65" x1="124.804" y1="684.431" x2="1351.77" y2="795.601" gradientUnits="userSpaceOnUse">
<stop stop-color="#F0003D"/>
<stop offset="0.369792" stop-color="#FA4727"/>
<stop offset="0.776042" stop-color="#6B90F4"/>
</linearGradient>
<linearGradient id="paint5_linear_548_65" x1="323" y1="1067.2" x2="6.09023e-06" y2="1316.8" gradientUnits="userSpaceOnUse">
<stop stop-color="white"/>
<stop offset="1" stop-color="#F52532"/>
</linearGradient>
<linearGradient id="paint6_linear_548_65" x1="687" y1="1401" x2="687" y2="983" gradientUnits="userSpaceOnUse">
<stop/>
<stop offset="1" stop-color="#666666"/>
</linearGradient>
<linearGradient id="paint7_linear_548_65" x1="1175.8" y1="683.431" x2="2402.77" y2="794.601" gradientUnits="userSpaceOnUse">
<stop stop-color="#F0003D"/>
<stop offset="0.369792" stop-color="#FA4727"/>
<stop offset="0.776042" stop-color="#6B90F4"/>
</linearGradient>
<linearGradient id="paint8_linear_548_65" x1="1374" y1="1066.2" x2="1051" y2="1315.8" gradientUnits="userSpaceOnUse">
<stop stop-color="white"/>
<stop offset="1" stop-color="#F52532"/>
</linearGradient>
<linearGradient id="paint9_linear_548_65" x1="-202.64" y1="492.439" x2="1176.93" y2="666.265" gradientUnits="userSpaceOnUse">
<stop stop-color="#F0003D"/>
<stop offset="0.369792" stop-color="#FA4727"/>
<stop offset="0.776042" stop-color="#6B90F4"/>
</linearGradient>
<linearGradient id="paint10_linear_548_65" x1="303.707" y1="557" x2="562.607" y2="896.973" gradientUnits="userSpaceOnUse">
<stop stop-color="#FAFAFA"/>
<stop offset="1" stop-color="#A5729F"/>
</linearGradient>
<linearGradient id="paint11_linear_548_65" x1="162.651" y1="492.439" x2="1542.49" y2="666.336" gradientUnits="userSpaceOnUse">
<stop stop-color="#F0003D"/>
<stop offset="0.369792" stop-color="#FA4727"/>
<stop offset="0.776042" stop-color="#6B90F4"/>
</linearGradient>
<linearGradient id="paint12_linear_548_65" x1="669.104" y1="557" x2="927.989" y2="897.025" gradientUnits="userSpaceOnUse">
<stop stop-color="#FAFAFA"/>
<stop offset="1" stop-color="#A5729F"/>
</linearGradient>
<linearGradient id="paint13_linear_548_65" x1="512.679" y1="492.439" x2="1933.21" y2="676.92" gradientUnits="userSpaceOnUse">
<stop stop-color="#F0003D"/>
<stop offset="0.369792" stop-color="#FA4727"/>
<stop offset="0.776042" stop-color="#6B90F4"/>
</linearGradient>
<linearGradient id="paint14_linear_548_65" x1="1034.57" y1="557" x2="1291.29" y2="904.456" gradientUnits="userSpaceOnUse">
<stop stop-color="#FAFAFA"/>
<stop offset="1" stop-color="#A5729F"/>
</linearGradient>
<linearGradient id="paint15_linear_548_65" x1="-411.498" y1="492.439" x2="715.627" y2="607.854" gradientUnits="userSpaceOnUse">
<stop stop-color="#F0003D"/>
<stop offset="0.369792" stop-color="#FA4727"/>
<stop offset="0.776042" stop-color="#6B90F4"/>
</linearGradient>
<linearGradient id="paint16_linear_548_65" x1="0" y1="557" x2="268" y2="843" gradientUnits="userSpaceOnUse">
<stop stop-color="#FAFAFA"/>
<stop offset="1" stop-color="#A5729F"/>
</linearGradient>
<linearGradient id="paint17_linear_548_65" x1="687.5" y1="0" x2="687.5" y2="421" gradientUnits="userSpaceOnUse">
<stop/>
<stop offset="1" stop-color="#666666"/>
</linearGradient>
</defs>
</svg>
</div>
</div>
</Transition>
</template>
<script setup lang="ts">
import { ref, onMounted } from 'vue'
const showSplash = ref(true)
onMounted(() => {
// Hide splash after animation completes (5s total animation)
setTimeout(() => {
showSplash.value = false
}, 5000)
})
</script>
<style scoped>
.splash-screen {
position: fixed;
inset: 0;
z-index: 9999;
background: #0a0a0a;
display: flex;
align-items: center;
justify-content: center;
}
.splash-content {
display: flex;
align-items: center;
justify-content: center;
}
.splash-logo {
width: 400px;
height: 400px;
}
/* Stroke Drawing Animation - Staggered timing */
.logo-stroke {
stroke-dasharray: 2000;
stroke-dashoffset: 2000;
fill: transparent;
}
/* Top blocks draw first */
.logo-block-1 {
animation: drawStroke 1.5s ease-out 0s forwards, undrawStroke 1.5s ease-in 3.4s forwards;
}
.logo-block-2 {
animation: drawStroke 1.5s ease-out 0.2s forwards, undrawStroke 1.5s ease-in 3.2s forwards;
}
/* Center circle draws after top blocks */
.logo-circle {
animation: drawStroke 2s ease-out 0.4s forwards, undrawStroke 2s ease-in 2.5s forwards;
}
/* Diagonals draw in sequence */
.logo-diagonal-1 {
animation: drawStroke 1.5s ease-out 0.6s forwards, undrawStroke 1.5s ease-in 2.8s forwards;
}
.logo-diagonal-2 {
animation: drawStroke 1.5s ease-out 0.8s forwards, undrawStroke 1.5s ease-in 2.6s forwards;
}
.logo-diagonal-3 {
animation: drawStroke 1.5s ease-out 1.0s forwards, undrawStroke 1.5s ease-in 2.4s forwards;
}
.logo-diagonal-4 {
animation: drawStroke 1.5s ease-out 1.2s forwards, undrawStroke 1.5s ease-in 2.2s forwards;
}
/* Bottom blocks draw last */
.logo-block-3 {
animation: drawStroke 1.5s ease-out 1.4s forwards, undrawStroke 1.5s ease-in 2.0s forwards;
}
.logo-block-4 {
animation: drawStroke 1.5s ease-out 1.6s forwards, undrawStroke 1.5s ease-in 1.8s forwards;
}
.logo-block-5 {
animation: drawStroke 1.5s ease-out 1.8s forwards, undrawStroke 1.5s ease-in 1.6s forwards;
}
@keyframes drawStroke {
to {
stroke-dashoffset: 0;
}
}
@keyframes undrawStroke {
from {
stroke-dashoffset: 0;
}
to {
stroke-dashoffset: 2000;
}
}
/* Fill Appearance Animation - starts after strokes mostly drawn */
.logo-fill {
opacity: 0;
animation: fillAppear 0.8s ease-out 1.2s forwards, fillDisappear 0.8s ease-in 3s forwards;
}
/* Stagger fill animations slightly for draw */
.logo-fill-1 { animation-delay: 1.2s, 3.9s; }
.logo-fill-2 { animation-delay: 1.3s, 3.8s; }
.logo-fill-3 { animation-delay: 1.4s, 3.7s; }
.logo-fill-4 { animation-delay: 1.5s, 3.6s; }
.logo-fill-5 { animation-delay: 1.6s, 3.5s; }
.logo-fill-6 { animation-delay: 1.7s, 3.4s; }
.logo-fill-7 { animation-delay: 1.8s, 3.3s; }
.logo-fill-8 { animation-delay: 1.9s, 3.2s; }
.logo-fill-9 { animation-delay: 2.0s, 3.1s; }
.logo-fill-10 { animation-delay: 2.1s, 3.0s; }
@keyframes fillAppear {
to {
opacity: 1;
}
}
@keyframes fillDisappear {
from {
opacity: 1;
}
to {
opacity: 0;
}
}
/* Splash Fade Out Transition */
.splash-fade-leave-active {
transition: opacity 1.5s ease;
}
.splash-fade-leave-to {
opacity: 0;
}
</style>