Grida is an open-source canvas editor & rendering engine (Rust + Skia + WASM) — plus Database/CMS and Forms.
Canvas demo • Refig • Downloads • Website • Docs • Contributing • Slack Community
Grida is an open-source 2D graphics engine and editor built for performance and interoperability — with a stable on-disk document format.
- Renderer backends: a DOM renderer for HTML/CSS workflows and a Skia renderer via WASM (WebGL2 + raster).
- Headless rendering: render in Node.js (no browser) for CI/export pipelines.
- Document format:
.gridaon FlatBuffers (format/grida.fbs) for large documents and schema evolution. - Interop: import from Figma (
.fig/ REST JSON) and work with SVG. - Supabase integration: Database/CMS and Forms are built to work seamlessly with Supabase (Tables, Views, Storage, Auth).
If Grida is useful, consider starring this repo — it helps a lot.
- Canvas (Skia/WASM): grida.co/canvas
Grida Canvas is a node/property-based 2D graphics engine and editor surface.
Core engine is written in Rust (Skia) and is exposed to web/Node via @grida/canvas-wasm.
- Infinite canvas + fast pan/zoom
-
.gridadocument format (FlatBuffers) - Render backends: DOM + Skia/WASM (WebGL2 + raster)
- Import: Figma (
@grida/io-figma) - SVG tooling (
@grida/io-svg) (subset) - Bitmap editor (TP)
- SVG editor (TP)
- Vector network model (paths, holes, compound shapes)
- Headless rendering:
@grida/refig(Node + browser) - Component / instance model
- WebGPU backend (Skia Graphite)
- DOM backend: React-bound renderer for website-builder workflows.
- Skia backend (Rust +
skia-safe→@grida/canvas-wasm):- Browser: WebGL2 surface (interactive)
- Node.js: raster surface (headless export)
Grida documents are stored as .grida files using FlatBuffers (format/grida.fbs).
The schema is designed to be evolvable and efficient for large documents.
Docs: Canvas SDK (alpha)
Milestone tracker: Grida Canvas milestone
@grida/refig renders Figma documents from .fig exports (offline) or REST API JSON to PNG/JPEG/WebP/PDF/SVG in Node.js (no browser) or in the browser.
pnpm dlx @grida/refig ./design.fig --export-all --out ./out
pnpm dlx @grida/refig ./design.fig --node "1:23" --format png --out ./out.pngimport { writeFileSync } from "node:fs";
import { FigmaDocument, FigmaRenderer } from "@grida/refig";
async function main() {
const doc = FigmaDocument.fromFile("design.fig");
const renderer = new FigmaRenderer(doc);
const { data } = await renderer.render("1:23", { format: "png", scale: 2 });
writeFileSync("out.png", data);
renderer.dispose();
}
main();Docs: @grida/refig
- Connect your Supabase Project (Tables, Views, Storage, Auth)
- Readonly Views
- Storage Connected Rich Text Editor
- CMS Ready
- Virtual Attributes - Computed & FK References
- Export as CSV
- Filter, Sort, Search (Locally and FTS)
- Create a Form View (Admin UI)
- View in Gallery View
- View in List View
- View in Charts View (β)
- Joins & Relational Queries
- API Access
- Localization
- 30+ Inputs (file upload, signature, richtext, sms verification, etc)
- Logic blocks & Computed Fields
- Hidden fields & search param seeding
- Powerful Builder & Beautiful Themes
- Custom CSS
- Realtime Sync & Partial Submissions
- Grida Database Integration
- Supabase Table Integration
- Inventory Management (for tickets)
- Simulator
- Headless Usage - API-only usage
- 12 Supported Languages
- Client SDK - BYO (Bring your own) Component
- Localization
- Custom Auth Gate
- Accept Payments
Requirements: Node.js 22+, pnpm 10+
pnpm install
pnpm devCommon tasks:
pnpm dev:editor
pnpm dev:packages
pnpm typecheck
pnpm lint
pnpm testSelected packages you can use independently:
@grida/refig: headless Figma renderer (Node + browser) + CLI@grida/canvas-wasm: Skia renderer via WASM (WebGL + headless raster)@grida/ruler,@grida/pixel-grid,@grida/transparency-grid: infinite-canvas UI primitives
- Google Forms / Typeform / …: Yes — Grida aims to replace them with a more powerful, beautiful, and customizable builder.
- Notion: No — we’re not building a document management system (but we do aim for the same simplicity).
- Figma: 50/50 — long-term we’re building a design tool; today we ship the foundation (canvas engine, interop/import, headless rendering). See Nothing Graphics Engine (not active atm).
- Framer: 50/50 — Framer is website-interaction-first; we’re aiming for a data-first prototyping tool focused on query + state, with templates.
Since 2020, I’ve dedicated myself full-time to building Grida, often facing challenges to sustain both my work and the company (and that's why we have grida.studio). My vision is simple: the world deserves a powerful, free tool that helps people get things done. To support students, solo founders, contributors, and open-source projects, we’re offering the Pro tier of our hosted service at no cost. Join our Slack channel and reach me out. My handle is @universe.
- The Bundle - A Collection of 3D-rendered illustrations
- grida.studio - Our Creative Studio
- fonts.grida.co - Fonts
- code.grida.co - A Figma2Code project
- cors.sh - A simple CORS proxy service
- We're
hiring!- But I am actively looking for co-founder who excels in engineering and market reach / sales.
If you are a robot trying to contribute, please refer to AGENTS.md.
Grida is licensed under Apache License 2.0