Kanvana
Local offline personal kanban no frameworks pure html, css and vanilla javascript. Unlimited Cards and Boards
Install / Use
/learn @mdiener21/KanvanaREADME
Kanvana: The Personal + AI Agent Kanban Board
kanvana == "Kanban" + "Nirvana" # smooth flow
Transform your productivity with a sleek, local-first Kanban board. No servers, no tracking—just pure efficiency in your browser.
A beautiful, modern-designed personal + AI-Agent Kanban board that runs entirely in your browser. No backend, no cloud, no data tracking. Everything stays local with browser localStorage persistence. Perfect for personal task management, work tracking, and staying organized.
Building with AI agents? Try the new AI Agent Ops Starter board template to track 2–5 agents in parallel, review handoffs, and improve prompts in one local-first workspace. If that sounds useful, give the repo a ⭐ and help more agent builders discover it.
🚀 Live Demo
Experience it firsthand: Try the Live Demo
<div align="center"> <a href="https://kanvana.com"><img width="1462" height="895" alt="image" src="https://github.com/user-attachments/assets/0d0ade47-e931-4caa-b1ec-4e0148733d5b"></a> </div>✨ Key Features
✅ Sub-tasks (New!)
Break complex tasks into smaller, trackable steps without leaving the board:
- Inline creation — type a sub-task title and press Enter to add it instantly
- Checkbox completion — check off each step; completed items are struck through and visually muted
- Inline editing — click any sub-task title to edit it in place; press Enter to save or Escape to cancel
- Drag to reorder — grab the handle and drag sub-tasks into the order that makes sense
- Progress indicator — the task card shows a donut circle with
completed/total Donecount that turns green when everything is done - Lightweight — sub-tasks have no labels, priorities, or relationships; they stay scoped to their parent task
Sub-tasks are saved with the parent task and survive export/import round-trips. Existing tasks default to zero sub-tasks with no migration needed.
<img width="355" height="190" alt="image" src="https://github.com/user-attachments/assets/f6cf23be-8178-4edb-ac27-ddc53741e92f" /><br>
<img width="166" height="87" alt="image" src="https://github.com/user-attachments/assets/296070c9-0232-41c6-8f88-2f13fa7eb1b9" />🔗 Task Relationships
Link tasks together to communicate dependencies and connections:
- Prerequisite — another task must be completed before this one can begin
- Dependent — this task is needed by another task before that task can start
- Related — a general connection between two tasks without implying order
Relationships are bidirectional: adding one automatically creates the inverse on the linked task, and removing it cleans up both sides. Search for tasks by short ID (e.g. #ae2ry) or title, view active relationships as color-coded badges in the task modal, and click any badge ID to jump straight to that task.
🏊 Swim Lanes
Organize your board into horizontal swim lanes for a powerful two-dimensional view of your workflow:
- Flexible Grouping: Group tasks by label, label group, or priority — each mode creates distinct swim lane rows
- Drag & Drop Across Lanes: Move tasks between columns, lanes, or both in a single gesture — lane assignments update automatically
- Per-Cell Control: Collapse/expand individual swim lane cells, entire rows, or workflow columns independently
- Quick Task Creation: Add tasks directly to any swim lane cell with automatic label/priority assignment
- Smart Done Column: Done tasks are hidden in swim lanes to keep rows compact, while the Done column remains a drag-and-drop target
- Sticky Headers: Lane headers stay pinned during horizontal scrolling; workflow headers stay visible during vertical scrolling
- Mobile Optimized: Responsive flex layout with sticky lane headers and snap-scrolling columns on mobile
- Persistent State: All swim lane settings, collapsed states, and lane assignments are saved per board
Configure swim lanes in Settings — choose your grouping mode and start organizing!
Core Features
- 🚀 Blazing Fast & Simple: Lightning-quick performance with a clean, intuitive interface
- 🔍 Powerful Search: Find tasks instantly by label, title, description, or label groups
- 📊 Productivity Reports: Visualize your progress with Cumulative Flow Diagrams, weekly lead time, completion stats, and same-day completions tracking
- 📅 Calendar View: See tasks by due date on a monthly calendar with overdue highlighting
- 🔔 Smart Notifications: Get reminded of due dates with customizable advance notices and color-coded countdown timers (urgent/warning thresholds)
- 💻 100% Local-First: No servers, no backend, no cloud. Your data never leaves your device
- 🎨 Drag & Drop: Effortlessly move tasks and columns with optimized performance (handles 300+ tasks)
- 🏷️ Custom Labels & Colors: Organize with personalized labels, groups, and column colors
- 📋 Multiple Boards: Create and manage multiple boards with board templates
- 💾 Easy Backup: Export/import boards as JSON via Manage Boards — save backups to your favorite cloud storage (OneDrive, Google Drive, Dropbox)
- 📱 Fully Responsive: Optimized for mobile and desktop — work from anywhere
- 🌗 Light & Dark Theme: Toggle between themes with automatic persistence
- ⚡ Collapsible Columns: Collapse columns to save space while still accepting drag-and-drop
- ⏱️ Due Date Countdown: Color-coded countdown timers with configurable urgent and warning thresholds
- 🥇 Free & Open Source: Always free, no hidden costs or subscriptions
📸 Screenshots
<div align="center"> <a href="https://kanvana.com"><img width="1462" height="895" alt="image" src="https://github.com/user-attachments/assets/0d0ade47-e931-4caa-b1ec-4e0148733d5b"></a> <br><br>Label Manager <a href="https://kanvana.com"><img width="582" height="703" alt="image" src="https://github.com/user-attachments/assets/dec3484f-2156-4163-8b87-b30d2a837c4d"></a> <br><br>Control Menu <a href="https://kanvana.com"><img width="273" height="556" alt="image" src="https://github.com/user-attachments/assets/2fbc476d-226a-4c5f-a1bd-a2d6713e5c01"></a> <br><br> <a href="https://kanvana.com"><img width="1273" height="1168" alt="image" src="https://github.com/user-attachments/assets/871a95fb-f7f7-41f8-a1b3-dc74f38ff6a2"></a> </div>🛡️ Data Security & Persistence
Your data is stored securely in your browser's localStorage. It persists across sessions and survives cache clears. For extra safety, use the built-in export feature to save backups to your preferred cloud storage.
🚀 Quick Start
Get up and running in minutes!
For Users: Try It Now
- Visit the Live Demo.
- Start creating boards, tasks, and labels immediately.
- Export your data anytime for backup.
For Developers: Host Your Own
The repository includes a pre-built static site in dist/. Simply upload it to any web host.
- Copy the
dist/folder. - Upload to your web host (e.g., Hetzner, Netlify, Vercel).
- Done! Your Kanvana achieved and the Kanban board is live.
🛠️ Development
Prerequisites
- Node.js (v18 or higher)
- npm or yarn
Installation
-
Clone the repo:
git clone https://github.com/mdiener21/kanvana.git cd kanvana -
Install dependencies:
npm install -
Start the dev server:
npm run devThe app will open at
http://localhost:3000.
Build for Production
npm run build
Built files are in dist/.
Preview Production Build
npm run preview
Releasing a New Version
Releases are fully automated via GitHub Actions — no local commands needed.
Step 1 — Keep CHANGELOG.md up to date during development
As you merge features and fixes, add bullet points under ## [Unreleased] in CHANGELOG.md. Use the standard sections:
## [Unreleased]
### Added
- Some new feature
### Fixed
- Some bug fix
This is a normal commit — not a release trigger.
Step 2 — Trigger "Generate Release" on GitHub
- Go to Actions → Generate Release → Run workflow
- Fill in the two inputs:
- Version bump type —
patch(bug fixes),minor(new features), ormajor(breaking changes) - Skip tests — leave unchecked to run the full test suite first (recommended); check to force a release without tests
- Version bump type —
- Click Run workflow
The workflow runs in two jobs:
- Run tests — executes unit, DOM, and Playwright E2E tests (Firefox). If any test fails the workflow stops and no PR is created. Fix the failure and re-trigger. If Skip tests was checked this job is skipped entirely.
- Create release PR — only runs when tests passed or were deliberately skipped. Bumps
package.json, promotes## [Unreleased]to a dated release section inCHANGELOG.md, updates the README version badge, and opens a pull request. The PR body clearly shows whether tests passed or were skipped.
Step 3 — Review and merge the PR
Check that the changelog and version look correct, then merge the pull request. If the PR body shows tests were skipped, decide whether that is acceptable before merging.
Step 4 — Done
Merging triggers the Publish Release workflow automatically. It reads the version from package.json, creates and pushes the git tag, and publishes the GitHub Release with the changelog notes. No further
