@voidzero-dev/vitepress-theme 0.0.1 → 0.0.2
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/assets/checkmark.svg +1 -0
- package/assets/primary-button-background.jpg +0 -0
- package/assets/terminal-background.jpg +0 -0
- package/components/Eyebrow.vue +11 -0
- package/components/Footer.vue +44 -0
- package/components/Header.vue +38 -0
- package/components/RiveAnimation.vue +144 -0
- package/components/Terminal.vue +165 -0
- package/components/terminal-animations/TerminalAnimation1.vue +53 -0
- package/components/terminal-animations/TerminalAnimation2.vue +58 -0
- package/components/terminal-animations/TerminalAnimation3.vue +45 -0
- package/components/terminal-animations/TerminalAnimation4.vue +49 -0
- package/components/terminal-animations/TerminalAnimation5.vue +50 -0
- package/components/terminal-animations/TerminalAnimation6.vue +54 -0
- package/fonts/APK-Protocol-Medium.woff2 +0 -0
- package/fonts/KHTeka-Medium.woff2 +0 -0
- package/fonts/KHTeka-Regular.woff2 +0 -0
- package/fonts/KHTekaMono-Medium.woff2 +0 -0
- package/fonts/KHTekaMono-Regular.woff2 +0 -0
- package/index.ts +44 -0
- package/package.json +19 -20
- package/{dist/index.css → style.css} +7 -7
- package/dist/_virtual/_/plugin-vue/export-helper.js +0 -9
- package/dist/index.d.ts +0 -2
- package/dist/index.js +0 -3
- package/dist/vitepress/components/Eyebrow.js +0 -7
- package/dist/vitepress/components/Eyebrow.vue_vue_type_script_setup_true_lang.js +0 -17
- package/dist/vitepress/components/Footer.js +0 -7
- package/dist/vitepress/components/Footer.vue_vue_type_script_setup_true_lang.js +0 -57
- package/dist/vitepress/components/Header.js +0 -7
- package/dist/vitepress/components/Header.vue_vue_type_script_setup_true_lang.js +0 -33
- package/dist/vitepress/components/RiveAnimation.js +0 -7
- package/dist/vitepress/components/RiveAnimation.vue_vue_type_script_setup_true_lang.js +0 -110
- package/dist/vitepress/components/Terminal.js +0 -7
- package/dist/vitepress/components/Terminal.vue_vue_type_script_setup_true_lang.js +0 -152
- package/dist/vitepress/components/icons/VZIconBluesky.js +0 -21
- package/dist/vitepress/components/icons/VZIconGitHub.js +0 -21
- package/dist/vitepress/components/icons/VZIconLogo.js +0 -24
- package/dist/vitepress/components/icons/VZIconTwitter.js +0 -21
- package/dist/vitepress/components/terminal-animations/TerminalAnimation1.js +0 -7
- package/dist/vitepress/components/terminal-animations/TerminalAnimation1.vue_vue_type_script_setup_true_lang.js +0 -31
- package/dist/vitepress/components/terminal-animations/TerminalAnimation2.js +0 -7
- package/dist/vitepress/components/terminal-animations/TerminalAnimation2.vue_vue_type_script_setup_true_lang.js +0 -38
- package/dist/vitepress/components/terminal-animations/TerminalAnimation3.js +0 -7
- package/dist/vitepress/components/terminal-animations/TerminalAnimation3.vue_vue_type_script_setup_true_lang.js +0 -31
- package/dist/vitepress/components/terminal-animations/TerminalAnimation4.js +0 -7
- package/dist/vitepress/components/terminal-animations/TerminalAnimation4.vue_vue_type_script_setup_true_lang.js +0 -31
- package/dist/vitepress/components/terminal-animations/TerminalAnimation5.js +0 -7
- package/dist/vitepress/components/terminal-animations/TerminalAnimation5.vue_vue_type_script_setup_true_lang.js +0 -31
- package/dist/vitepress/components/terminal-animations/TerminalAnimation6.js +0 -7
- package/dist/vitepress/components/terminal-animations/TerminalAnimation6.vue_vue_type_script_setup_true_lang.js +0 -31
- package/dist/vitepress/index.d.ts +0 -33
- package/dist/vitepress/index.js +0 -21
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
<script setup lang="ts">
|
|
2
|
+
import Typewriter from 'typewriter-effect/dist/core'
|
|
3
|
+
import {onMounted, onUnmounted} from "vue";
|
|
4
|
+
|
|
5
|
+
const props = defineProps<{
|
|
6
|
+
onAnimationComplete?: () => void
|
|
7
|
+
}>()
|
|
8
|
+
|
|
9
|
+
let typewriter;
|
|
10
|
+
|
|
11
|
+
onMounted(() => {
|
|
12
|
+
const target = document.getElementById('terminal-code');
|
|
13
|
+
typewriter = new Typewriter(target, {
|
|
14
|
+
loop: false,
|
|
15
|
+
delay: 1,
|
|
16
|
+
})
|
|
17
|
+
typewriter
|
|
18
|
+
.typeString(`<span>$ vite build</span>`)
|
|
19
|
+
.pauseFor(200)
|
|
20
|
+
.pasteString(`<span class="block w-full h-[1rem]"></span>`)
|
|
21
|
+
.pasteString(`<div class="block"><span class="text-vite">VITE+ v1.0.0</span> <span class="text-aqua">building for production</span></div>`)
|
|
22
|
+
.pauseFor(100)
|
|
23
|
+
.pasteString(`<div class="block">transforming...</div>`)
|
|
24
|
+
.pauseFor(400)
|
|
25
|
+
.pasteString(`<div class="block"><span class="text-zest">✓</span> <span class="text-grey">32 modules transformed...</span></div>`)
|
|
26
|
+
.pauseFor(300)
|
|
27
|
+
.pasteString(`<div class="block">rendering chunks...</div>`)
|
|
28
|
+
.pasteString(`<div class="block">computing gzip size...</div>`)
|
|
29
|
+
.pasteString(`<div class="block text-grey"><span class="w-72 inline-block">dist/<span class="text-white">index.html</span></span> 0.46 kB | gzip: 0.30 kB</div>`)
|
|
30
|
+
.pasteString(`<div class="block text-grey"><span class="w-72 inline-block">dist/assets/<span class="text-vite">react-CHdo91hT.svg</span></span> 4.13 kB | gzip: 2.05 kB</div>`)
|
|
31
|
+
.pasteString(`<div class="block text-grey"><span class="w-72 inline-block">dist/assets/<span class="text-electric">index-D8b4DHJx.css</span></span> 1.39 kB | gzip: 0.71 kB</div>`)
|
|
32
|
+
.pasteString(`<div class="block text-grey"><span class="w-72 inline-block">dist/assets/<span class="text-aqua">index-CAl1KfkQ.js</span></span>188.06 kB | gzip: 59.21 kB</div>`)
|
|
33
|
+
.pasteString(`<div class="block"><span class="text-zest">✓ built in 308ms</span></div>`)
|
|
34
|
+
.pasteString(`<span class="block w-full h-[1rem]"></span>`)
|
|
35
|
+
.callFunction(() => {
|
|
36
|
+
if (props.onAnimationComplete) {
|
|
37
|
+
props.onAnimationComplete()
|
|
38
|
+
}
|
|
39
|
+
})
|
|
40
|
+
.start();
|
|
41
|
+
})
|
|
42
|
+
|
|
43
|
+
onUnmounted(() => {
|
|
44
|
+
if(typewriter){
|
|
45
|
+
typewriter.stop()
|
|
46
|
+
}
|
|
47
|
+
})
|
|
48
|
+
</script>
|
|
49
|
+
|
|
50
|
+
<template>
|
|
51
|
+
<p class="font-mono text-sm text-white leading-[1.5rem]">
|
|
52
|
+
<span id="terminal-code"></span>
|
|
53
|
+
</p>
|
|
54
|
+
</template>
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
package/index.ts
ADDED
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @voidzero-dev/vitepress-theme
|
|
3
|
+
*
|
|
4
|
+
* Shared VitePress theme providing base styles, fonts, and design tokens
|
|
5
|
+
* for VoidZero projects.
|
|
6
|
+
*
|
|
7
|
+
* Usage:
|
|
8
|
+
* Extend this theme in your project's VitePress theme.
|
|
9
|
+
*
|
|
10
|
+
* @example
|
|
11
|
+
* ```ts
|
|
12
|
+
* // In your-project/.vitepress/theme/index.ts
|
|
13
|
+
* import Theme from '@voidzero-dev/vitepress-theme'
|
|
14
|
+
* import './overrides.css' // Your project-specific styles
|
|
15
|
+
*
|
|
16
|
+
* export default {
|
|
17
|
+
* extends: Theme,
|
|
18
|
+
* Layout: YourLayout
|
|
19
|
+
* }
|
|
20
|
+
* ```
|
|
21
|
+
*/
|
|
22
|
+
|
|
23
|
+
import type { Theme } from 'vitepress'
|
|
24
|
+
import Footer from './components/Footer.vue'
|
|
25
|
+
import Header from './components/Header.vue'
|
|
26
|
+
import Terminal from './components/Terminal.vue'
|
|
27
|
+
import Eyebrow from './components/Eyebrow.vue'
|
|
28
|
+
import RiveAnimation from './components/RiveAnimation.vue'
|
|
29
|
+
|
|
30
|
+
// NOTE: We don't import style.css here because the consuming theme
|
|
31
|
+
// needs to import Tailwind first, then our styles.
|
|
32
|
+
// See the usage example in the JSDoc comment above.
|
|
33
|
+
|
|
34
|
+
export default {
|
|
35
|
+
Layout: () => null, // Base theme provides no layout, consuming themes must provide one
|
|
36
|
+
enhanceApp({ app }) {
|
|
37
|
+
// Register shared components globally - available in all consuming projects
|
|
38
|
+
app.component('Footer', Footer)
|
|
39
|
+
app.component('Header', Header)
|
|
40
|
+
app.component('Terminal', Terminal)
|
|
41
|
+
app.component('Eyebrow', Eyebrow)
|
|
42
|
+
app.component('RiveAnimation', RiveAnimation)
|
|
43
|
+
}
|
|
44
|
+
} satisfies Theme
|
package/package.json
CHANGED
|
@@ -1,20 +1,21 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@voidzero-dev/vitepress-theme",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.2",
|
|
4
4
|
"description": "Shared VitePress theme for VoidZero projects",
|
|
5
5
|
"type": "module",
|
|
6
|
-
"
|
|
7
|
-
"main": "./dist/index.js",
|
|
8
|
-
"types": "./dist/index.d.ts",
|
|
6
|
+
"main": "./index.ts",
|
|
9
7
|
"exports": {
|
|
10
8
|
".": {
|
|
11
|
-
"
|
|
12
|
-
"import": "./
|
|
13
|
-
}
|
|
14
|
-
"./index.css": "./dist/index.css"
|
|
9
|
+
"style": "./style.css",
|
|
10
|
+
"import": "./index.ts"
|
|
11
|
+
}
|
|
15
12
|
},
|
|
16
13
|
"files": [
|
|
17
|
-
"
|
|
14
|
+
"index.ts",
|
|
15
|
+
"style.css",
|
|
16
|
+
"fonts",
|
|
17
|
+
"assets",
|
|
18
|
+
"components"
|
|
18
19
|
],
|
|
19
20
|
"peerDependencies": {
|
|
20
21
|
"vitepress": "^2.0.0-alpha.12",
|
|
@@ -24,17 +25,15 @@
|
|
|
24
25
|
"@rive-app/canvas": "^2.31.6",
|
|
25
26
|
"@tailwindcss/typography": "^0.5.19",
|
|
26
27
|
"@tailwindcss/vite": "^4.1.13",
|
|
27
|
-
"reka-ui": "^2.5.1",
|
|
28
28
|
"tailwindcss": "^4.1.13",
|
|
29
|
+
"reka-ui": "^2.5.1",
|
|
29
30
|
"typewriter-effect": "^2.22.0"
|
|
30
31
|
},
|
|
31
|
-
"
|
|
32
|
-
"
|
|
33
|
-
"
|
|
34
|
-
"
|
|
35
|
-
"
|
|
36
|
-
|
|
37
|
-
"
|
|
38
|
-
|
|
39
|
-
}
|
|
40
|
-
}
|
|
32
|
+
"keywords": [
|
|
33
|
+
"vitepress",
|
|
34
|
+
"theme",
|
|
35
|
+
"voidzero",
|
|
36
|
+
"tailwind"
|
|
37
|
+
],
|
|
38
|
+
"license": "MIT"
|
|
39
|
+
}
|
|
@@ -13,31 +13,31 @@
|
|
|
13
13
|
@font-face {
|
|
14
14
|
font-family: 'APK Protocol';
|
|
15
15
|
font-weight: 500;
|
|
16
|
-
src: url('
|
|
16
|
+
src: url('./fonts/APK-Protocol-Medium.woff2') format('woff2');
|
|
17
17
|
}
|
|
18
18
|
|
|
19
19
|
@font-face {
|
|
20
20
|
font-family: 'KH Teka';
|
|
21
21
|
font-weight: 400;
|
|
22
|
-
src: url('
|
|
22
|
+
src: url('./fonts/KHTeka-Regular.woff2') format('woff2');
|
|
23
23
|
}
|
|
24
24
|
|
|
25
25
|
@font-face {
|
|
26
26
|
font-family: 'KH Teka';
|
|
27
27
|
font-weight: 500;
|
|
28
|
-
src: url('
|
|
28
|
+
src: url('./fonts/KHTeka-Medium.woff2') format('woff2');
|
|
29
29
|
}
|
|
30
30
|
|
|
31
31
|
@font-face {
|
|
32
32
|
font-family: 'KH Teka Mono';
|
|
33
33
|
font-weight: 400;
|
|
34
|
-
src: url('
|
|
34
|
+
src: url('./fonts/KHTekaMono-Regular.woff2') format('woff2');
|
|
35
35
|
}
|
|
36
36
|
|
|
37
37
|
@font-face {
|
|
38
38
|
font-family: 'KH Teka Mono';
|
|
39
39
|
font-weight: 500;
|
|
40
|
-
src: url('
|
|
40
|
+
src: url('./fonts/KHTekaMono-Medium.woff2') format('woff2');
|
|
41
41
|
}
|
|
42
42
|
|
|
43
43
|
@custom-variant dark (&:where([data-theme=dark], [data-theme=dark] *));
|
|
@@ -178,7 +178,7 @@
|
|
|
178
178
|
right: -3px;
|
|
179
179
|
bottom: -3px;
|
|
180
180
|
background-color: #CCCCCC;
|
|
181
|
-
background-image: url('
|
|
181
|
+
background-image: url('./assets/primary-button-background.jpg');
|
|
182
182
|
background-size: 150% 150%;
|
|
183
183
|
background-position: center;
|
|
184
184
|
border-radius: calc(0.5rem + 3px);
|
|
@@ -273,7 +273,7 @@
|
|
|
273
273
|
transform: translateY(-50%);
|
|
274
274
|
width: 20px;
|
|
275
275
|
height: 20px;
|
|
276
|
-
background-image: url('
|
|
276
|
+
background-image: url('./assets/checkmark.svg');
|
|
277
277
|
background-size: contain;
|
|
278
278
|
background-repeat: no-repeat;
|
|
279
279
|
background-position: center;
|
package/dist/index.d.ts
DELETED
package/dist/index.js
DELETED
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
import Eyebrow_vue_vue_type_script_setup_true_lang_default from "./Eyebrow.vue_vue_type_script_setup_true_lang.js";
|
|
2
|
-
|
|
3
|
-
//#region src/vitepress/components/Eyebrow.vue
|
|
4
|
-
var Eyebrow_default = Eyebrow_vue_vue_type_script_setup_true_lang_default;
|
|
5
|
-
|
|
6
|
-
//#endregion
|
|
7
|
-
export { Eyebrow_default as default };
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
import { createElementBlock, createElementVNode, defineComponent, openBlock, toDisplayString } from "vue";
|
|
2
|
-
|
|
3
|
-
//#region src/vitepress/components/Eyebrow.vue?vue&type=script&setup=true&lang.ts
|
|
4
|
-
const _hoisted_1 = { class: "wrapper wrapper--ticks border-t p-5 pl-10" };
|
|
5
|
-
const _hoisted_2 = { class: "text-nickel dark:text-white text-xs font-medium font-mono uppercase tracking-wide" };
|
|
6
|
-
var Eyebrow_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defineComponent({
|
|
7
|
-
__name: "Eyebrow",
|
|
8
|
-
props: { title: {} },
|
|
9
|
-
setup(__props) {
|
|
10
|
-
return (_ctx, _cache) => {
|
|
11
|
-
return openBlock(), createElementBlock("section", _hoisted_1, [createElementVNode("span", _hoisted_2, toDisplayString(__props.title), 1)]);
|
|
12
|
-
};
|
|
13
|
-
}
|
|
14
|
-
});
|
|
15
|
-
|
|
16
|
-
//#endregion
|
|
17
|
-
export { Eyebrow_vue_vue_type_script_setup_true_lang_default as default };
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
import Footer_vue_vue_type_script_setup_true_lang_default from "./Footer.vue_vue_type_script_setup_true_lang.js";
|
|
2
|
-
|
|
3
|
-
//#region src/vitepress/components/Footer.vue
|
|
4
|
-
var Footer_default = Footer_vue_vue_type_script_setup_true_lang_default;
|
|
5
|
-
|
|
6
|
-
//#endregion
|
|
7
|
-
export { Footer_default as default };
|
|
@@ -1,57 +0,0 @@
|
|
|
1
|
-
import VZIconGitHub_default from "./icons/VZIconGitHub.js";
|
|
2
|
-
import VZIconBluesky_default from "./icons/VZIconBluesky.js";
|
|
3
|
-
import VZIconTwitter_default from "./icons/VZIconTwitter.js";
|
|
4
|
-
import { createElementBlock, createElementVNode, createStaticVNode, createTextVNode, createVNode, defineComponent, openBlock, toDisplayString } from "vue";
|
|
5
|
-
|
|
6
|
-
//#region src/vitepress/components/Footer.vue?vue&type=script&setup=true&lang.ts
|
|
7
|
-
const _hoisted_1 = {
|
|
8
|
-
class: "bg-primary",
|
|
9
|
-
"data-theme": "dark"
|
|
10
|
-
};
|
|
11
|
-
const _hoisted_2 = { class: "wrapper" };
|
|
12
|
-
const _hoisted_3 = { class: "px-5 md:px-24 pt-10 md:pt-16 pb-16 md:pb-30 flex flex-col md:flex-row gap-10 md:gap-0 md:justify-between" };
|
|
13
|
-
const _hoisted_4 = { class: "flex flex-col gap-3" };
|
|
14
|
-
const _hoisted_5 = {
|
|
15
|
-
href: "https://github.com/voidzero-dev",
|
|
16
|
-
target: "_blank",
|
|
17
|
-
rel: "noopener noreferrer",
|
|
18
|
-
class: "text-white text-base flex gap-3 items-center"
|
|
19
|
-
};
|
|
20
|
-
const _hoisted_6 = {
|
|
21
|
-
href: "https://web-cdn.bsky.app/profile/voidzero.dev",
|
|
22
|
-
target: "_blank",
|
|
23
|
-
rel: "noopener noreferrer",
|
|
24
|
-
class: "text-white text-base flex gap-3 items-center"
|
|
25
|
-
};
|
|
26
|
-
const _hoisted_7 = {
|
|
27
|
-
href: "https://x.com/voidzerodev",
|
|
28
|
-
target: "_blank",
|
|
29
|
-
rel: "noopener noreferrer",
|
|
30
|
-
class: "text-white text-base flex gap-3 items-center"
|
|
31
|
-
};
|
|
32
|
-
const _hoisted_8 = { class: "wrapper wrapper--ticks border-t py-5 px-5 md:px-24" };
|
|
33
|
-
const _hoisted_9 = { class: "text-sm" };
|
|
34
|
-
var Footer_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defineComponent({
|
|
35
|
-
__name: "Footer",
|
|
36
|
-
setup(__props) {
|
|
37
|
-
return (_ctx, _cache) => {
|
|
38
|
-
return openBlock(), createElementBlock("footer", _hoisted_1, [createElementVNode("section", _hoisted_2, [_cache[5] || (_cache[5] = createStaticVNode("<div class=\"bg-wine bg-[url(../assets/cta-background.jpg)] bg-cover py-16 md:py-30 px-5 md:px-0 overflow-clip flex flex-col items-center justify-center gap-8 md:gap-12\"><h2 class=\"text-white w-full md:w-2xl text-center text-balance\">Take your team's productivity to the next level with Vite+</h2><div class=\"flex items-center gap-5\"><a href=\"https://tally.so/r/nGWebL\" target=\"_blank\" rel=\"noopener noreferrer\" class=\"button\">Register your interest</a><a href=\"https://voidzero.dev/posts/announcing-vite-plus?utm_source=viteplusdev&utm_content=bottom_learn_more\" target=\"_blank\" rel=\"noopener noreferrer\" class=\"button\"> Learn more </a></div></div>", 1)), createElementVNode("div", _hoisted_3, [_cache[4] || (_cache[4] = createStaticVNode("<div><p class=\"text-grey text-xs font-mono uppercase tracking-wide mb-8\">Company</p><ul class=\"flex flex-col gap-3\"><li><a href=\"https://voidzero.dev/\" target=\"_blank\" rel=\"noopener noreferrer\" class=\"text-white text-base\">VoidZero</a></li><li><a href=\"https://vite.dev/\" target=\"_blank\" rel=\"noopener noreferrer\" class=\"text-white text-base\">Vite</a></li><li><a href=\"https://rolldown.rs/\" target=\"_blank\" rel=\"noopener noreferrer\" class=\"text-white text-base\">Rolldown</a></li><li><a href=\"https://vitest.dev/\" target=\"_blank\" rel=\"noopener noreferrer\" class=\"text-white text-base\">Vitest</a></li><li><a href=\"https://oxc.rs/\" target=\"_blank\" rel=\"noopener noreferrer\" class=\"text-white text-base\">Oxc</a></li></ul></div>", 1)), createElementVNode("div", null, [_cache[3] || (_cache[3] = createElementVNode("p", { class: "text-grey text-xs font-mono uppercase tracking-wide mb-8" }, "Social", -1)), createElementVNode("ul", _hoisted_4, [
|
|
39
|
-
createElementVNode("li", null, [createElementVNode("a", _hoisted_5, [createVNode(VZIconGitHub_default, {
|
|
40
|
-
class: "size-5",
|
|
41
|
-
"aria-label": "GitHub"
|
|
42
|
-
}), _cache[0] || (_cache[0] = createTextVNode("GitHub", -1))])]),
|
|
43
|
-
createElementVNode("li", null, [createElementVNode("a", _hoisted_6, [createVNode(VZIconBluesky_default, {
|
|
44
|
-
class: "size-5",
|
|
45
|
-
"aria-label": "Bluesky"
|
|
46
|
-
}), _cache[1] || (_cache[1] = createTextVNode("Bluesky", -1))])]),
|
|
47
|
-
createElementVNode("li", null, [createElementVNode("a", _hoisted_7, [createVNode(VZIconTwitter_default, {
|
|
48
|
-
class: "size-5",
|
|
49
|
-
"aria-label": "Twitter"
|
|
50
|
-
}), _cache[2] || (_cache[2] = createTextVNode("X.com", -1))])])
|
|
51
|
-
])])])]), createElementVNode("section", _hoisted_8, [createElementVNode("p", _hoisted_9, [createTextVNode("© " + toDisplayString((/* @__PURE__ */ new Date()).getFullYear()) + " VoidZero Inc. ", 1), _cache[6] || (_cache[6] = createElementVNode("span", { class: "hidden sm:inline" }, "All Rights Reserved.", -1))])])]);
|
|
52
|
-
};
|
|
53
|
-
}
|
|
54
|
-
});
|
|
55
|
-
|
|
56
|
-
//#endregion
|
|
57
|
-
export { Footer_vue_vue_type_script_setup_true_lang_default as default };
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
import Header_vue_vue_type_script_setup_true_lang_default from "./Header.vue_vue_type_script_setup_true_lang.js";
|
|
2
|
-
|
|
3
|
-
//#region src/vitepress/components/Header.vue
|
|
4
|
-
var Header_default = Header_vue_vue_type_script_setup_true_lang_default;
|
|
5
|
-
|
|
6
|
-
//#endregion
|
|
7
|
-
export { Header_default as default };
|
|
@@ -1,33 +0,0 @@
|
|
|
1
|
-
import VZIconLogo_default from "./icons/VZIconLogo.js";
|
|
2
|
-
import { Fragment, createCommentVNode, createElementBlock, createElementVNode, createVNode, defineComponent, normalizeClass, openBlock, renderList, renderSlot, toDisplayString, unref } from "vue";
|
|
3
|
-
import { useData, useRoute } from "vitepress";
|
|
4
|
-
|
|
5
|
-
//#region src/vitepress/components/Header.vue?vue&type=script&setup=true&lang.ts
|
|
6
|
-
const _hoisted_1 = { class: "wrapper px-6 py-7 flex items-center justify-between" };
|
|
7
|
-
const _hoisted_2 = { class: "flex items-center gap-10" };
|
|
8
|
-
const _hoisted_3 = { href: "/" };
|
|
9
|
-
const _hoisted_4 = { class: "nav" };
|
|
10
|
-
const _hoisted_5 = ["href"];
|
|
11
|
-
const _hoisted_6 = { class: "flex items-center gap-6" };
|
|
12
|
-
var Header_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defineComponent({
|
|
13
|
-
__name: "Header",
|
|
14
|
-
setup(__props) {
|
|
15
|
-
const { site, theme } = useData();
|
|
16
|
-
const nav = theme.value.nav;
|
|
17
|
-
const route = useRoute();
|
|
18
|
-
return (_ctx, _cache) => {
|
|
19
|
-
return openBlock(), createElementBlock("header", _hoisted_1, [createElementVNode("div", _hoisted_2, [createElementVNode("a", _hoisted_3, [createVNode(VZIconLogo_default, {
|
|
20
|
-
class: "h-4",
|
|
21
|
-
"aria-label": unref(site).title
|
|
22
|
-
}, null, 8, ["aria-label"])]), createElementVNode("ul", _hoisted_4, [(openBlock(true), createElementBlock(Fragment, null, renderList(unref(nav), (navItem) => {
|
|
23
|
-
return openBlock(), createElementBlock("li", { key: navItem.link }, [createElementVNode("a", {
|
|
24
|
-
class: normalizeClass({ active: unref(route).path === navItem.link }),
|
|
25
|
-
href: navItem.link
|
|
26
|
-
}, toDisplayString(navItem.text), 11, _hoisted_5)]);
|
|
27
|
-
}), 128))])]), createElementVNode("div", _hoisted_6, [renderSlot(_ctx.$slots, "right-side", {}, () => [createCommentVNode(" Right-aligned links / calls-to-action ")])])]);
|
|
28
|
-
};
|
|
29
|
-
}
|
|
30
|
-
});
|
|
31
|
-
|
|
32
|
-
//#endregion
|
|
33
|
-
export { Header_vue_vue_type_script_setup_true_lang_default as default };
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
import RiveAnimation_vue_vue_type_script_setup_true_lang_default from "./RiveAnimation.vue_vue_type_script_setup_true_lang.js";
|
|
2
|
-
|
|
3
|
-
//#region src/vitepress/components/RiveAnimation.vue
|
|
4
|
-
var RiveAnimation_default = RiveAnimation_vue_vue_type_script_setup_true_lang_default;
|
|
5
|
-
|
|
6
|
-
//#endregion
|
|
7
|
-
export { RiveAnimation_default as default };
|
|
@@ -1,110 +0,0 @@
|
|
|
1
|
-
import { computed, createElementBlock, createElementVNode, defineComponent, normalizeClass, onMounted, onUnmounted, openBlock, ref } from "vue";
|
|
2
|
-
import * as rive from "@rive-app/canvas";
|
|
3
|
-
|
|
4
|
-
//#region src/vitepress/components/RiveAnimation.vue?vue&type=script&setup=true&lang.ts
|
|
5
|
-
const _hoisted_1 = ["width", "height"];
|
|
6
|
-
var RiveAnimation_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defineComponent({
|
|
7
|
-
__name: "RiveAnimation",
|
|
8
|
-
props: {
|
|
9
|
-
desktopSrc: {},
|
|
10
|
-
mobileSrc: {},
|
|
11
|
-
breakpoint: { default: 768 },
|
|
12
|
-
stateMachines: { default: "State Machine 1" },
|
|
13
|
-
canvasClass: { default: "w-full" },
|
|
14
|
-
desktopWidth: {},
|
|
15
|
-
desktopHeight: {},
|
|
16
|
-
mobileWidth: {},
|
|
17
|
-
mobileHeight: {}
|
|
18
|
-
},
|
|
19
|
-
setup(__props) {
|
|
20
|
-
const props = __props;
|
|
21
|
-
const canvasRef = ref(null);
|
|
22
|
-
const containerRef = ref(null);
|
|
23
|
-
let riveInstance = null;
|
|
24
|
-
let hasStarted = ref(false);
|
|
25
|
-
let observer = null;
|
|
26
|
-
const isMobile = ref(false);
|
|
27
|
-
const checkMobile = () => {
|
|
28
|
-
isMobile.value = window.innerWidth < props.breakpoint;
|
|
29
|
-
};
|
|
30
|
-
const getCurrentSrc = () => {
|
|
31
|
-
return isMobile.value && props.mobileSrc ? props.mobileSrc : props.desktopSrc;
|
|
32
|
-
};
|
|
33
|
-
const currentWidth = computed(() => {
|
|
34
|
-
return isMobile.value && props.mobileWidth ? props.mobileWidth : props.desktopWidth;
|
|
35
|
-
});
|
|
36
|
-
const currentHeight = computed(() => {
|
|
37
|
-
return isMobile.value && props.mobileHeight ? props.mobileHeight : props.desktopHeight;
|
|
38
|
-
});
|
|
39
|
-
const loadAnimation = () => {
|
|
40
|
-
if (!canvasRef.value || riveInstance) return;
|
|
41
|
-
const src = getCurrentSrc();
|
|
42
|
-
riveInstance = new rive.Rive({
|
|
43
|
-
src,
|
|
44
|
-
canvas: canvasRef.value,
|
|
45
|
-
autoplay: false,
|
|
46
|
-
stateMachines: props.stateMachines,
|
|
47
|
-
onLoad: () => {
|
|
48
|
-
riveInstance?.resizeDrawingSurfaceToCanvas();
|
|
49
|
-
}
|
|
50
|
-
});
|
|
51
|
-
};
|
|
52
|
-
const playAnimation = () => {
|
|
53
|
-
if (riveInstance) riveInstance.play();
|
|
54
|
-
};
|
|
55
|
-
const cleanupAnimation = () => {
|
|
56
|
-
if (riveInstance) {
|
|
57
|
-
riveInstance.cleanup();
|
|
58
|
-
riveInstance = null;
|
|
59
|
-
}
|
|
60
|
-
};
|
|
61
|
-
const handleResize = () => {
|
|
62
|
-
const wasMobile = isMobile.value;
|
|
63
|
-
checkMobile();
|
|
64
|
-
if (wasMobile !== isMobile.value) {
|
|
65
|
-
const wasPlaying = hasStarted.value;
|
|
66
|
-
cleanupAnimation();
|
|
67
|
-
loadAnimation();
|
|
68
|
-
if (wasPlaying) playAnimation();
|
|
69
|
-
}
|
|
70
|
-
};
|
|
71
|
-
onMounted(() => {
|
|
72
|
-
checkMobile();
|
|
73
|
-
loadAnimation();
|
|
74
|
-
observer = new IntersectionObserver((entries) => {
|
|
75
|
-
entries.forEach((entry) => {
|
|
76
|
-
if (entry.isIntersecting && !hasStarted.value) {
|
|
77
|
-
hasStarted.value = true;
|
|
78
|
-
playAnimation();
|
|
79
|
-
}
|
|
80
|
-
});
|
|
81
|
-
}, { threshold: .1 });
|
|
82
|
-
if (containerRef.value) observer.observe(containerRef.value);
|
|
83
|
-
window.addEventListener("resize", handleResize);
|
|
84
|
-
});
|
|
85
|
-
onUnmounted(() => {
|
|
86
|
-
cleanupAnimation();
|
|
87
|
-
if (observer && containerRef.value) {
|
|
88
|
-
observer.unobserve(containerRef.value);
|
|
89
|
-
observer.disconnect();
|
|
90
|
-
}
|
|
91
|
-
window.removeEventListener("resize", handleResize);
|
|
92
|
-
});
|
|
93
|
-
return (_ctx, _cache) => {
|
|
94
|
-
return openBlock(), createElementBlock("div", {
|
|
95
|
-
ref_key: "containerRef",
|
|
96
|
-
ref: containerRef,
|
|
97
|
-
class: "pointer-events-none touch-none select-none"
|
|
98
|
-
}, [createElementVNode("canvas", {
|
|
99
|
-
ref_key: "canvasRef",
|
|
100
|
-
ref: canvasRef,
|
|
101
|
-
width: currentWidth.value,
|
|
102
|
-
height: currentHeight.value,
|
|
103
|
-
class: normalizeClass(__props.canvasClass)
|
|
104
|
-
}, null, 10, _hoisted_1)], 512);
|
|
105
|
-
};
|
|
106
|
-
}
|
|
107
|
-
});
|
|
108
|
-
|
|
109
|
-
//#endregion
|
|
110
|
-
export { RiveAnimation_vue_vue_type_script_setup_true_lang_default as default };
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
import Terminal_vue_vue_type_script_setup_true_lang_default from "./Terminal.vue_vue_type_script_setup_true_lang.js";
|
|
2
|
-
|
|
3
|
-
//#region src/vitepress/components/Terminal.vue
|
|
4
|
-
var Terminal_default = Terminal_vue_vue_type_script_setup_true_lang_default;
|
|
5
|
-
|
|
6
|
-
//#endregion
|
|
7
|
-
export { Terminal_default as default };
|