Klint is a modern 2D canvas library for React, inspired by p5.js and Processing. It makes creative coding in React intuitive and powerful, perfect for generative art, data visualization, interactive graphics, and creative web experiences.
- ๐ฏ React-first: Built specifically for React with hooks and component patterns
- ๐จ Creative coding: p5.js-like API with modern JavaScript/TypeScript
- ๐ Performance: Direct canvas access with minimal overhead
- ๐ ๏ธ Developer friendly: Full TypeScript support and great tooling
- ๐ง Extensible: Plugin system and easy customization
npm install @shopify/klintimport { useKlint, Klint } from '@shopify/klint';
function MySketch() {
const { context } = useKlint();
const draw = (K) => {
K.background('#000');
K.fillColor('#ff6b6b');
K.circle(K.width/2, K.height/2, 50);
};
return <Klint context={context} draw={draw} />;
}Want to experiment with Klint interactively? Create a live editor environment:
npx @shopify/klint klint-create-editor my-klint-project
cd my-klint-project
npm install
npm run devThis creates a Monaco-based editor with live preview - perfect for learning and prototyping!
- Getting Started Guide - Learn the basics
- API Reference - Complete function reference
- Examples - See Klint in action
- Lifecycle - Understand how Klint works with React
function AnimatedCircle() {
const { context } = useKlint();
const draw = (K) => {
K.background('rgba(0, 0, 0, 0.1)');
K.fillColor('#4ecdc4');
const x = K.width/2 + Math.cos(K.frame * 0.02) * 100;
const y = K.height/2 + Math.sin(K.frame * 0.02) * 100;
K.circle(x, y, 20);
};
return <Klint context={context} draw={draw} />;
}function InteractiveDrawing() {
const { context, KlintMouse } = useKlint();
const { mouse } = KlintMouse();
const draw = (K) => {
if (mouse.pressed) {
K.fillColor('red');
K.circle(mouse.x, mouse.y, 10);
}
};
return <Klint context={context} draw={draw} />;
}For contributors who want to work on Klint itself:
git clone https://github.com/Shopify/klint.git
cd klint
npm install
npm run buildSee CONTRIBUTING.md for development guidelines.
MIT
Ready to create? Start with npx @shopify/klint klint-create-editor my-project ๐จ