Skip to content

louis-thevenet/vault-tasks

Repository files navigation

Vault-tasks

vault-tasks is a TUI Markdown task manager.

It will parse any Markdown file or vault and display the tasks it contains.

Demo using ./test-vault

test-vault
├── chocolate_lava_cake.md
├── daily_workout.md
├── diy_bookshelf.md
├── study_plan.md
└── test.md

Demo

Why

I made this tool because I wanted to integrate my task system directly inside my Second Brain.

Markdown tasks are very easy to integrate with knowledge and projects.

I also spend most of my writing time in the terminal (Helix) and do not rely on heavy external software.

Features

  • Task Parser (see Usage)
    • Subtasks
    • Fixed and relative dates
    • special today tag and regular tags
    • descriptions
    • priority
  • Navigate vault
  • Search through tasks (sort and filter)
  • Calendar view and timeline
  • Edit tasks or open in default editor
  • Time Management tab (Pomodoro & Flowtime)

Planned Features

  • new action in Explorer Tab to create a new child on selected entry

Installation

Cargo

cargo install vault-tasks

Nix

You can get it from nixpkgs 24.11 or directly from this repo's flake:

vault-tasks = {
  url = "github:louis-thevenet/vault-tasks";
  inputs.nixpkgs.follows = "nixpkgs";
};

And use the package in your configuration: inputs.vault-tasks.packages.${pkgs.system}.default

Build From Source

git clone https://github.com/louis-thevenet/vault-tasks.git
cd vault-tasks
cargo build --release

Usage

See vault-tasks --help for basic usage.

Writing tasks

<!-- An example task in your markdown file -->

- [ ] An example task #tag tomorrow p1
      A description
      of this task
  - [x] A subtask today @today
  - [/] Another subtask 10/23 @today
    Partly done
  - [-] This one is canceled
Token Meaning
- [ ] (- [x], ...) declares a task and sets its state
p1 (p10, ...) sets the priority
#tag is a tag, a task can have zero or more tags
@today (@tod, @t) is a special tag that will mark the task as part of today's tasks
23/10 (2024/23/10) sets the due date with a literal date
today (tdy) sets the due date to today
tomorrow (tmr) sets the due date to tomorrow
a day of the week (monday or mon, etc) sets the due date to the next occurence of that day
3d (3m, 3w, 3y, ...) means "in 3 days" and will set the due date accordingly
  • Task states are Done (x), To-Do ( ), Incomplete (/) and Canceled (-)

  • @today allows you mark a task for today while keeping a due date. It will show up with a ☀️ in vault-tasks.

  • Relative dates are always replaced by literal dates once vault-tasks is run. Thanks to this, vault-tasks does not store any data except its config file.

  • Other tokens will be part of the title of that task

  • Descriptions and subtasks are declared using indents (see configuration)

This is what you will see in the preview of this README.md in vault-tasks:

Default Key Map

Check the key map within the app with ?

General

Key Alternate Key Action
shift-h shift-← Previous tab
shift-l shift-→ Next tab
ctrl-k ctrl-↓ Scroll up
ctrl-j ctrl-↑ Scroll down
page_down Scroll one page down
page_up Scroll one page up
q ctrl-c Quit the application
? Open keybindings menu for the current tab

Explorer Tab

Navigation
Key Alternate Key Action
k , shift-tab Previous entry
j , tab Next entry
h , back_space Leave current entry
l ,enter Enter current entry
Commands
Key Action
s Focus search bar (enter or esc to unfocus)
o Open selection in default editor
e Quickly edit selection
r Reload vault
t Mark task To-Do
d Mark task Done
i Mark task Incomplete
c Mark task Canceled

Filter Tab

Commands
Key Action
enter Focus/Unfocus search bar
Shift-s Change sorting mode

Calendar Tab

Navigation
Key Alternate Key Action
h +1 day
l -1 day
j +7 days
k -7 days
Shift-j Shift-↓ +1 month
Shift-k Shift-↑ -1 month
n +1 year
Shift-n -1 year
Commands
Key Action
t Goto Today

Time Management Tab

Navigation
Key Alternate Key Action
k Previous setting
j Next setting
Commands
Key Action
space Next segment (skip current)
p Pause timer
e Edit selected setting
shift-tab Previous time management technique
tab Next time management technique

Modes

You can start already focused on a tab by using one of the CLI subcommands:

vault-tasks explorer # is the default
# Or
vault-tasks filter
vault-tasks time
vault-tasks calendar

You can also output the content of a vault in standard output using

vault-tasks stdout

Example output:

vault-tasks -v ./README.md stdout
./README.md
‾‾‾‾‾‾‾‾‾‾‾
        README.md
        ‾‾‾‾‾‾‾‾‾
                Vault-tasks
                ‾‾‾‾‾‾‾‾‾‾‾
                        Usage
                        ‾‾‾‾‾
                                Writing tasks
                                ‾‾‾‾‾‾‾‾‾‾‾‾‾
                                        ❌ An example task
                                        📅 2024-12-22 (tomorrow)❗1
                                        #tag
                                        A description
                                        of this task

                                                ✅ A subtask
                                                ☀️ 📅 2024-12-21 (today)


                                                ⏳ Another subtask
                                                ☀️ 📅 2024-10-23 (2 months ago)
                                                Partly done


                                                🚫 This one is canceled


Configuration

The config.toml contains the default configuration which can be generated using vault-tasks generate-config.

In $HOME/.config/vault-tasks/config.toml, you can override the default settings, keybindings and colorscheme.

In particular, you can set a default vault path.

Contributing

Feel free to submit issues or pull requests. Contributions are welcome!