Skip to content

Stack tecnológico

Tecnologías principales

CapaTecnologíaPor qué
RenderizadoSkia CanvasKit WASMMismo motor que Figma — rendimiento probado, acelerado por GPU, píxel-perfecto
Framework UIVue 3 + VueUseAPI de composición reactiva, excelente soporte TypeScript
ComponentesReka UIPrimitivas UI headless y accesibles (tree, slider, etc.)
EstiladoTailwind CSS 4Utility-first, iteración rápida, tema oscuro
LayoutYoga WASMMotor CSS flexbox de Meta, probado en React Native
Formato de archivoKiwi binario + ZstdFormato propio de Figma — compacto, parseo rápido, compatible con .fig
ColaboraciónTrystero + YjsP2P WebRTC vía señalización MQTT, sync CRDT, persistencia y-indexeddb
ColorculoriConversiones de espacio de color (HSV, RGB, hex)
IA/MCPMCP SDK + Hono90+ herramientas para codificación IA, transportes stdio + HTTP
JSX TransformSucrase201 KB JSX → JS, síncrono, compatible con navegador
Eventosnanoevents108 bytes, emisor de eventos tipado para mutaciones de SceneGraph
JSX TransformSucrase201 KB JSX → JS, síncrono, compatible con navegador
Eventosnanoevents108 bytes, emisor de eventos tipado para mutaciones de SceneGraph
DesktopTauri v2~5 MB app nativa (vs ~100 MB de Electron), backend Rust
BuildVite 7HMR rápido, módulos ES nativos
TestingPlaywright + bun:testRegresión visual (E2E) + tests unitarios rápidos
LintingoxlintBasado en Rust, órdenes de magnitud más rápido que ESLint
FormateooxfmtFormateador basado en Rust
Verificación de tipostypescript-go (tsgo)Implementación nativa en Go del verificador de tipos TypeScript

Dependencias principales

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"
}

¿Por qué no...

¿Por qué no renderizado SVG?

SVG es lento para documentos complejos. Cada nodo es un elemento DOM — 10.000 nodos significan 10.000 elementos DOM con overhead de layout, pintado y composición. CanvasKit dibuja todo en una única superficie GPU.

¿Por qué no Electron (como Figma desktop)?

Tauri v2 usa el webview del sistema (~5 MB) en lugar de empaquetar Chromium (~100 MB). El backend Rust proporciona rendimiento nativo para E/S de archivos e integración con el sistema.

¿Por qué no React?

El proyecto migró de React a Vue 3 tempranamente. El sistema de reactividad de Vue y los composables de VueUse resultaron más ergonómicos.

¿Por qué no un motor de layout propio?

Yoga es mantenido por Meta, probado en miles de millones de dispositivos React Native e implementa la especificación CSS flexbox.

Tecnologías planificadas

TecnologíaPropósitoFase
CSS Grid en YogaAuto layout basado en grid✅ Incluido vía fork de Yoga (@open-pencil/yoga-layout)

Released under the MIT License.