"I have plenty things to do!"
Planty is an open-source task management app inspired by Todoist and GTD system.
This project is being actively developed and is not yet a fully working product.
Here is a quick demo (last updated: December 12, 2024):
planty_demo_1.mp4
Prerequisites: Docker (with compose plugin), uv
git clone https://github.com/m-danya/planty
cd planty
cp .env.sample .env
echo "\nPLANTY_AUTH_SECRET=$(openssl rand -base64 32)" >> .env
uv sync
source .venv/bin/activate
# Run Alembic migrations
# alembic upgrade head
# Alembic migrations are not being maintained yet due to a high pace of changes
# during initial development. To get db with sample data from tests, uncomment a
# line in `config.py` to avoid using in-memory db for tests and run this:
pytest; mv planty_test.db planty.db
# or just run this for automatic commenting, running tests and uncommenting:
sed -i '/Uncomment to /{n;s/# //}' planty/config.py; pytest planty/application; mv planty_test.db planty.db; sed -i '/Uncomment to /{n;s/^\(\s*\)/\1# /}' planty/config.py; echo Done. DB is ready!
# (backend is not dockerized yet)
# run "FastAPI" configuration in VS code or:
uvicorn planty.main:app --reload
To start the frontend, run the following commands:
cd frontend
npm i
npm run dev
Use nvm to manage nodejs versions:
nvm install --lts 20
nvm use --lts 20
By default, the SQLite engine is used for persistence, but you can easily switch
to PostgreSQL: change DB_TYPE
in .env
file to postgresql
and run
the system with docker compose compose.yaml --profile with-postgres up -d
.
pytest
mypy .
Measuring code coverage:
coverage run -m pytest
coverage report # or "coverage html"
(or just use Ruff extension for VS Code)
ruff check --extend-select I --fix
ruff format
- Start backend, save 127.0.0.1:8000/openapi.json to
frontend
directory (TODO: automate) - Run this:
cd frontend
npx swagger-typescript-api -p ./openapi.json -o ./api --axios