Tod

Build Status codecov Crates.io

A tiny todoist CLI program. Takes simple input and dumps it in your inbox or another project. Takes advantage of natural language processing to assign due dates, tags, etc.

Tod

Table of Contents

- Tod - Table of Contents - Installation - Crates.io (Linux, Mac, and Windows) - AUR (Arch-based Linux) - GitHub (Linux, Mac, and Windows) - Usage - Discovering the commands - Usage Examples - Shell script examples - Sort, schedule, prioritize, and process tasks - How item priority is determined - Disabling spinners - Why I made this - Related projects - Contributing

Will ask for your Todoist API token on the first run, and your data in JSON format in $XDG_CONFIG_HOME/tod.cfg. This defaults to:

Installation

Crates.io (Linux, Mac, and Windows)

Install Rust

```bash

Linux and MacOS

curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh ```

Install Tod

bash cargo install tod

AUR (Arch-based Linux)

```bash

Use yay or another AUR helper

yay tod-bin ```

GitHub (Linux, Mac, and Windows)

Install Rust

Clone the project

bash git clone git@github.com:alanvardy/tod.git cd tod ./test.sh # run the tests cargo build --release

You can then find the binary in /target/release/

Usage

Discovering the commands

```bash

tod -h

A tiny unofficial Todoist client

Usage: tod [OPTIONS] [COMMAND]

Commands: task
project
version
help Print this message or the help of the given subcommand(s)

Options: -o, --config Absolute path of configuration. Defaults to $XDGCONFIGHOME/tod.cfg -q, --quickadd ... Create a new task with natural language processing. -h, --help Print help -V, --version Print version ```

And also use it to dig into subcommands

```bash

tod task -h

Usage: tod task

Commands: create Create a new task list List all tasks in a project next Get the next task by priority complete Complete the last task fetched with the next command help Print this message or the help of the given subcommand(s)

Options: -h, --help Print help -V, --version Print version

```

Usage Examples

```bash

Quickly create a task

tod -q Buy more milk today

Create a new task (you will be prompted for content and project)

tod task create

Create a task in a project

tod task create --content "Write more rust" --project code

Import your projects

tod project import

Get the next task for a project

tod task next

Go through tasks with an interactive prompt, completing them in order of importance one at a time.

tod project process

Complete the last "next task" and get another

tod task complete && tod task next

Get your work schedule

tod tasks list --scheduled --project work

Get all tasks for work

tod tasks list --project work ```

Shell script examples

Sort, schedule, prioritize, and process tasks

bash echo "" && \ echo "=== EMPTYING INBOX ===" && \ tod project empty --project inbox && \ echo "" && \ echo "=== SCHEDULING DIGITAL ===" && \ tod project schedule --project digital && \ echo "" && \ echo "=== SCHEDULING PHYSICAL ===" && \ tod project schedule --project physical && \ echo "" && \ echo "=== PRIORITIZING DIGITAL ===" && \ tod project prioritize --project digital && \ echo "" && \ echo "=== PRIORITIZING PHYSICAL ===" && \ tod project prioritize --project physical echo "" && \ echo "=== PROCESSING DIGITAL ===" && \ tod project process --project digital && \ echo "" && \ echo "=== PROCESSING PHYSICAL ===" && \ tod project process --project physical;

Update Tod only if it is out of date

bash tod version check || cargo install tod --force

How item priority is determined

Items are ranked by points and the first is returned, the points are the sum of the following:

Disabling spinners

Find the line in your tod.cfg that reads "spinners": null and change the value to false.

Why I made this

I am a developer who uses Todoist to reduce stress and cognitive overhead, by delegating things that a machine does well to a machine. This CLI application scratches some very specific itches for me, and I hope that it may be of use to others as well!

Some points around my general strategy:

Related projects

Contributing

Contributions are welcome, just please open up an issue before putting too much work into a PR.