Skip to content

Stack tecnologico

Tecnologie principali

LivelloTecnologiaPerché
RenderingSkia CanvasKit WASMStesso motore di Figma — prestazioni provate, accelerato GPU, pixel-perfetto
Framework UIVue 3 + VueUseAPI di composizione reattiva, eccellente supporto TypeScript
ComponentiReka UIPrimitivi UI headless e accessibili (tree, slider, ecc.)
StileTailwind CSS 4Utility-first, iterazione rapida, tema scuro
LayoutYoga WASMMotore CSS flexbox di Meta, collaudato in React Native
Formato fileKiwi binario + ZstdFormato proprio di Figma — compatto, parsing veloce, compatibile .fig
CollaborazioneTrystero + YjsP2P WebRTC via segnalazione MQTT, sync CRDT, persistenza y-indexeddb
ColoreculoriConversioni spazio colore (HSV, RGB, hex)
IA/MCPMCP SDK + Hono90+ strumenti per il coding IA, trasporti stdio + HTTP
JSX TransformSucrase201 KB JSX → JS, sincrono, compatibile browser
Eventinanoevents108 byte, emettitore eventi tipizzato per mutazioni SceneGraph
JSX TransformSucrase201 KB JSX → JS, sincrono, compatibile browser
Eventinanoevents108 byte, emettitore eventi tipizzato per mutazioni SceneGraph
DesktopTauri v2~5 MB app nativa (vs ~100 MB di Electron), backend Rust
BuildVite 7HMR veloce, moduli ES nativi
TestPlaywright + bun:testRegressione visiva (E2E) + test unitari veloci
LintingoxlintBasato su Rust, ordini di grandezza più veloce di ESLint
FormattazioneoxfmtFormattatore basato su Rust
Verifica tipitypescript-go (tsgo)Implementazione nativa in Go del type checker TypeScript

Dipendenze principali

json
{
  "canvaskit-wasm": "^0.40.0",
  "vue": "^3.5.29",
  "yoga-layout": "npm:@open-pencil/yoga-layout@3.3.0-grid.2",
  "nanoevents": "^9.1.0",
  "sucrase": "^3.35.1",
  "reka-ui": "^2.8.2",
  "tailwindcss": "^4.2.1",
  "culori": "^4.0.2",
  "fzstd": "^0.1.1",
  "fflate": "^0.8.2",
  "trystero": "^0.20.0",
  "yjs": "^13.6.24",
  "y-indexeddb": "^9.0.12"
}

Perché non...

Perché non il rendering SVG?

SVG è lento per documenti complessi. Ogni nodo è un elemento DOM — 10.000 nodi significano 10.000 elementi DOM con overhead di layout, disegno e composizione. CanvasKit disegna tutto su una singola superficie GPU.

Perché non Electron (come Figma desktop)?

Tauri v2 usa il webview di sistema (~5 MB) invece di incorporare Chromium (~100 MB). Il backend Rust fornisce prestazioni native per I/O file e integrazione di sistema.

Perché non React?

Il progetto è migrato da React a Vue 3 nelle fasi iniziali. Il sistema di reattività di Vue e i composables VueUse si sono rivelati più ergonomici.

Perché non un motore di layout personalizzato?

Yoga è mantenuto da Meta, collaudato su miliardi di dispositivi React Native e implementa la specifica CSS flexbox.

Tecnologie pianificate

TecnologiaScopoFase
CSS Grid in YogaAuto layout basato su griglia✅ Incluso tramite fork Yoga (@open-pencil/yoga-layout)

Released under the MIT License.