Skip to content

Shopify/Klint

Folders and files

NameName
Last commit message
Last commit date

Latest commit

ย 

History

294 Commits
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 

๐ŸŽจ Klint

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.

โœจ Features

  • ๐ŸŽฏ 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

๐Ÿš€ Quick Start

Install Klint

npm install @shopify/klint

Basic Usage

import { 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} />;
}

๐ŸŽฎ Try the Editor

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 dev

This creates a Monaco-based editor with live preview - perfect for learning and prototyping!

๐Ÿ“š Documentation

๐ŸŒŸ Examples

Animated Circle

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} />;
}

Interactive Drawing

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} />;
}

๐Ÿ› ๏ธ Development

For contributors who want to work on Klint itself:

git clone https://github.com/Shopify/klint.git
cd klint
npm install
npm run build

See CONTRIBUTING.md for development guidelines.

๐Ÿ“„ License

MIT


Ready to create? Start with npx @shopify/klint klint-create-editor my-project ๐ŸŽจ

About

Base repository for the Klint component

Resources

Code of conduct

Contributing

Security policy

Stars

Watchers

Forks

Packages

No packages published

Contributors 5