From aec635c26ab1bb5bfb8b0ac0d7adda6ef17c2d75 Mon Sep 17 00:00:00 2001 From: Adam Malczewski Date: Wed, 1 Apr 2026 03:36:49 +0900 Subject: init --- .gitignore | 6 + bin/certs | 12 ++ index.html | 4 +- public/favicon.svg | 1 - public/icons.svg | 24 ---- src/App.svelte | 106 +++--------------- src/app.css | 298 +------------------------------------------------ src/assets/hero.png | Bin 44919 -> 0 bytes src/assets/svelte.svg | 1 - src/assets/vite.svg | 1 - src/lib/Counter.svelte | 10 -- src/lib/api.ts | 11 ++ vite.config.ts | 36 +++++- 13 files changed, 86 insertions(+), 424 deletions(-) create mode 100755 bin/certs delete mode 100644 public/favicon.svg delete mode 100644 public/icons.svg delete mode 100644 src/assets/hero.png delete mode 100644 src/assets/svelte.svg delete mode 100644 src/assets/vite.svg delete mode 100644 src/lib/Counter.svelte create mode 100644 src/lib/api.ts diff --git a/.gitignore b/.gitignore index a547bf3..aa0a3ae 100644 --- a/.gitignore +++ b/.gitignore @@ -22,3 +22,9 @@ dist-ssr *.njsproj *.sln *.sw? + +# Environment files +.env* + +# TLS certificates +tmp/tls/ diff --git a/bin/certs b/bin/certs new file mode 100755 index 0000000..1b00dd6 --- /dev/null +++ b/bin/certs @@ -0,0 +1,12 @@ +#!/usr/bin/env bash +set -euo pipefail + +CERT_DIR="$(dirname "$0")/../tmp/tls" +mkdir -p "$CERT_DIR" + +echo "Extracting TLS certificates from gopass..." +gopass show tailscale/arch-razer/crt > "$CERT_DIR/cert.pem" +gopass show tailscale/arch-razer/key > "$CERT_DIR/key.pem" +chmod 600 "$CERT_DIR/key.pem" + +echo "Certificates written to $CERT_DIR" diff --git a/index.html b/index.html index 376345f..6e0c3db 100644 --- a/index.html +++ b/index.html @@ -1,10 +1,10 @@ - + - dispatch-web + Dispatch
diff --git a/public/favicon.svg b/public/favicon.svg deleted file mode 100644 index 6893eb1..0000000 --- a/public/favicon.svg +++ /dev/null @@ -1 +0,0 @@ - \ No newline at end of file diff --git a/public/icons.svg b/public/icons.svg deleted file mode 100644 index e952219..0000000 --- a/public/icons.svg +++ /dev/null @@ -1,24 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - diff --git a/src/App.svelte b/src/App.svelte index dafc575..de37b26 100644 --- a/src/App.svelte +++ b/src/App.svelte @@ -1,89 +1,19 @@ - +
+ + -
-
- - Svelte logo - Vite logo -
-
-

Get started

-

Edit src/App.svelte and save to test HMR

-
- -
- -
- -
-
- -

Documentation

-

Your questions, answered

- -
-
- -

Connect with us

-

Join the Vite community

- -
-
- -
-
+ +
+
+

Welcome to Dispatch

+

AI orchestration platform is online.

+
+
+
diff --git a/src/app.css b/src/app.css index 527d4fb..e036bb6 100644 --- a/src/app.css +++ b/src/app.css @@ -1,296 +1,2 @@ -:root { - --text: #6b6375; - --text-h: #08060d; - --bg: #fff; - --border: #e5e4e7; - --code-bg: #f4f3ec; - --accent: #aa3bff; - --accent-bg: rgba(170, 59, 255, 0.1); - --accent-border: rgba(170, 59, 255, 0.5); - --social-bg: rgba(244, 243, 236, 0.5); - --shadow: - rgba(0, 0, 0, 0.1) 0 10px 15px -3px, rgba(0, 0, 0, 0.05) 0 4px 6px -2px; - - --sans: system-ui, 'Segoe UI', Roboto, sans-serif; - --heading: system-ui, 'Segoe UI', Roboto, sans-serif; - --mono: ui-monospace, Consolas, monospace; - - font: 18px/145% var(--sans); - letter-spacing: 0.18px; - color-scheme: light dark; - color: var(--text); - background: var(--bg); - font-synthesis: none; - text-rendering: optimizeLegibility; - -webkit-font-smoothing: antialiased; - -moz-osx-font-smoothing: grayscale; - - @media (max-width: 1024px) { - font-size: 16px; - } -} - -@media (prefers-color-scheme: dark) { - :root { - --text: #9ca3af; - --text-h: #f3f4f6; - --bg: #16171d; - --border: #2e303a; - --code-bg: #1f2028; - --accent: #c084fc; - --accent-bg: rgba(192, 132, 252, 0.15); - --accent-border: rgba(192, 132, 252, 0.5); - --social-bg: rgba(47, 48, 58, 0.5); - --shadow: - rgba(0, 0, 0, 0.4) 0 10px 15px -3px, rgba(0, 0, 0, 0.25) 0 4px 6px -2px; - } - - #social .button-icon { - filter: invert(1) brightness(2); - } -} - -body { - margin: 0; -} - -h1, -h2 { - font-family: var(--heading); - font-weight: 500; - color: var(--text-h); -} - -h1 { - font-size: 56px; - letter-spacing: -1.68px; - margin: 32px 0; - @media (max-width: 1024px) { - font-size: 36px; - margin: 20px 0; - } -} -h2 { - font-size: 24px; - line-height: 118%; - letter-spacing: -0.24px; - margin: 0 0 8px; - @media (max-width: 1024px) { - font-size: 20px; - } -} -p { - margin: 0; -} - -code, -.counter { - font-family: var(--mono); - display: inline-flex; - border-radius: 4px; - color: var(--text-h); -} - -code { - font-size: 15px; - line-height: 135%; - padding: 4px 8px; - background: var(--code-bg); -} - -.counter { - font-size: 16px; - padding: 5px 10px; - border-radius: 5px; - color: var(--accent); - background: var(--accent-bg); - border: 2px solid transparent; - transition: border-color 0.3s; - margin-bottom: 24px; - - &:hover { - border-color: var(--accent-border); - } - &:focus-visible { - outline: 2px solid var(--accent); - outline-offset: 2px; - } -} - -.hero { - position: relative; - - .base, - .framework, - .vite { - inset-inline: 0; - margin: 0 auto; - } - - .base { - width: 170px; - position: relative; - z-index: 0; - } - - .framework, - .vite { - position: absolute; - } - - .framework { - z-index: 1; - top: 34px; - height: 28px; - transform: perspective(2000px) rotateZ(300deg) rotateX(44deg) rotateY(39deg) - scale(1.4); - } - - .vite { - z-index: 0; - top: 107px; - height: 26px; - width: auto; - transform: perspective(2000px) rotateZ(300deg) rotateX(40deg) rotateY(39deg) - scale(0.8); - } -} - -#app { - width: 1126px; - max-width: 100%; - margin: 0 auto; - text-align: center; - border-inline: 1px solid var(--border); - min-height: 100svh; - display: flex; - flex-direction: column; - box-sizing: border-box; -} - -#center { - display: flex; - flex-direction: column; - gap: 25px; - place-content: center; - place-items: center; - flex-grow: 1; - - @media (max-width: 1024px) { - padding: 32px 20px 24px; - gap: 18px; - } -} - -#next-steps { - display: flex; - border-top: 1px solid var(--border); - text-align: left; - - & > div { - flex: 1 1 0; - padding: 32px; - @media (max-width: 1024px) { - padding: 24px 20px; - } - } - - .icon { - margin-bottom: 16px; - width: 22px; - height: 22px; - } - - @media (max-width: 1024px) { - flex-direction: column; - text-align: center; - } -} - -#docs { - border-right: 1px solid var(--border); - - @media (max-width: 1024px) { - border-right: none; - border-bottom: 1px solid var(--border); - } -} - -#next-steps ul { - list-style: none; - padding: 0; - display: flex; - gap: 8px; - margin: 32px 0 0; - - .logo { - height: 18px; - } - - a { - color: var(--text-h); - font-size: 16px; - border-radius: 6px; - background: var(--social-bg); - display: flex; - padding: 6px 12px; - align-items: center; - gap: 8px; - text-decoration: none; - transition: box-shadow 0.3s; - - &:hover { - box-shadow: var(--shadow); - } - .button-icon { - height: 18px; - width: 18px; - } - } - - @media (max-width: 1024px) { - margin-top: 20px; - flex-wrap: wrap; - justify-content: center; - - li { - flex: 1 1 calc(50% - 8px); - } - - a { - width: 100%; - justify-content: center; - box-sizing: border-box; - } - } -} - -#spacer { - height: 88px; - border-top: 1px solid var(--border); - @media (max-width: 1024px) { - height: 48px; - } -} - -.ticks { - position: relative; - width: 100%; - - &::before, - &::after { - content: ''; - position: absolute; - top: -4.5px; - border: 5px solid transparent; - } - - &::before { - left: 0; - border-left-color: var(--border); - } - &::after { - right: 0; - border-right-color: var(--border); - } -} +@import 'tailwindcss'; +@plugin 'daisyui'; diff --git a/src/assets/hero.png b/src/assets/hero.png deleted file mode 100644 index cc51a3d..0000000 Binary files a/src/assets/hero.png and /dev/null differ diff --git a/src/assets/svelte.svg b/src/assets/svelte.svg deleted file mode 100644 index c5e0848..0000000 --- a/src/assets/svelte.svg +++ /dev/null @@ -1 +0,0 @@ - \ No newline at end of file diff --git a/src/assets/vite.svg b/src/assets/vite.svg deleted file mode 100644 index 5101b67..0000000 --- a/src/assets/vite.svg +++ /dev/null @@ -1 +0,0 @@ -Vite diff --git a/src/lib/Counter.svelte b/src/lib/Counter.svelte deleted file mode 100644 index 4395790..0000000 --- a/src/lib/Counter.svelte +++ /dev/null @@ -1,10 +0,0 @@ - - - diff --git a/src/lib/api.ts b/src/lib/api.ts new file mode 100644 index 0000000..649c683 --- /dev/null +++ b/src/lib/api.ts @@ -0,0 +1,11 @@ +import ky from 'ky' + +const apiUrl = import.meta.env.VITE_API_URL || '' + +export const api = ky.create({ + prefixUrl: apiUrl, + credentials: 'include', + headers: { + 'Content-Type': 'application/json', + }, +}) diff --git a/vite.config.ts b/vite.config.ts index d32eba1..80a4102 100644 --- a/vite.config.ts +++ b/vite.config.ts @@ -1,7 +1,41 @@ import { defineConfig } from 'vite' import { svelte } from '@sveltejs/vite-plugin-svelte' +import tailwindcss from '@tailwindcss/vite' +import fs from 'fs' + +const port = parseInt(process.env.VITE_PORT || '5188') +const apiPort = process.env.VITE_API_PORT || '3100' +const host = process.env.VITE_HOST || 'arch-razer.chimera-dinosaur.ts.net' + +const certPath = 'tmp/tls/cert.pem' +const keyPath = 'tmp/tls/key.pem' +const hasCerts = fs.existsSync(certPath) && fs.existsSync(keyPath) // https://vite.dev/config/ export default defineConfig({ - plugins: [svelte()], + plugins: [tailwindcss(), svelte()], + server: { + port, + host: '0.0.0.0', + ...(hasCerts + ? { + https: { + cert: fs.readFileSync(certPath), + key: fs.readFileSync(keyPath), + }, + } + : {}), + proxy: { + '/api': { + target: `https://${host}:${apiPort}`, + changeOrigin: true, + secure: false, + }, + '/cable': { + target: `wss://${host}:${apiPort}`, + ws: true, + secure: false, + }, + }, + }, }) -- cgit v1.2.3