Lightweight, typed React hooks and utilities for building interactive snake games with VIM-inspired controls.
Part of the VIMazing project - GitHub.
- Features
- Installation
- Quick Start
- Core Hooks
- Utilities
- Example App
- Build & Release
- License
- Acknowledgements
- Drop-in hooks for snake game mechanics, scoring, and key logging.
- Typed API with generated declaration files for editor IntelliSense.
- VIM-style controls (
h,j,k,lfor direction changes). - Composable architecture – bring your own rendering and platform-specific bindings.
- Tree-shakeable exports to keep bundles lean.
Using npm:
npm install @vimazing/vim-snakeOr with bun:
bun add @vimazing/vim-snakeimport { useEffect } from "react";
import { useGame } from "@vimazing/vim-snake";
import "@vimazing/vim-snake/game.css";
export function SnakeGame() {
const { containerRef, gameStatus, startGame } = useGame(30, 20);
useEffect(() => {
startGame();
}, [startGame]);
return (
<section className="mx-auto w-fit space-y-4">
<h1 className="text-2xl font-bold">VIMazing Snake</h1>
<div ref={containerRef} className="relative" />
{gameStatus === "game-won" && <p>🎉 You won!</p>}
</section>
);
}Note: You must manually import the CSS file. The package exports styles but does not auto-import them, giving you control over when and how styles are loaded.
Default controls:
| Key | Action |
|---|---|
i |
Start game |
h / j / k / l |
Change direction |
q |
Quit game |
Esc |
Cancel / pause |
| Hook | Description |
|---|---|
useGame(cols, rows, platformHook?) |
One-stop hook that wires board rendering, snake state, food spawning, scoring, and keyboard bindings. Returns refs, status helpers, and managers you can compose with your UI. |
useScore() |
Tracks timers, level progression, and final score calculation. |
Each hook is exported individually, so you can cherry-pick only what you need:
import { useScore } from "@vimazing/vim-snake/useScore";Besides the hooks, the library exports:
types– shared TypeScript types such asGameStatus,Direction, andPosition.
import { GameStatus } from "@vimazing/vim-snake";A demo application lives under example/ and consumes the package directly.
cd example
bun install
bun run devDuring local development the Vite config aliases @vimazing/vim-snake to the source folder so you can iterate without rebuilding. When publishing, run the build first (see below) so editors consume the generated declarations in dist/.
Build the distributable bundle and type declarations:
bun run buildThis writes JavaScript, type definitions, and styles to dist/. The prepublishOnly hook reuses the same command to guarantee fresh artifacts before publishing.
MIT © André Padez
Classic Snake game reimagined for the VIMazing platform with Vim-style controls.