https://github.com/d-e-s-o/notnow
  
  
    A terminal based task and TODO management software. 
    https://github.com/d-e-s-o/notnow
  
rust terminal-based todoapp todolist
        Last synced: 7 months ago 
        JSON representation
    
A terminal based task and TODO management software.
- Host: GitHub
- URL: https://github.com/d-e-s-o/notnow
- Owner: d-e-s-o
- License: gpl-3.0
- Created: 2018-06-06T05:58:54.000Z (over 7 years ago)
- Default Branch: main
- Last Pushed: 2024-05-07T13:15:39.000Z (over 1 year ago)
- Last Synced: 2024-05-21T19:27:09.032Z (over 1 year ago)
- Topics: rust, terminal-based, todoapp, todolist
- Language: Rust
- Homepage:
- Size: 1.46 MB
- Stars: 29
- Watchers: 3
- Forks: 5
- Open Issues: 1
- 
            Metadata Files:
            - Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
 
Awesome Lists containing this project
README
          [](https://github.com/d-e-s-o/notnow/actions/workflows/test.yml)
[](https://codecov.io/gh/d-e-s-o/notnow)
[](https://crates.io/crates/notnow)
[](https://blog.rust-lang.org/2022/12/15/Rust-1.66.0.html)
notnow
======
- [Changelog](CHANGELOG.md)
**notnow** is a terminal based task/TODO management program.
Two of its overarching goals are to allow for tag based filtering of
tasks, along with fully user-definable tags and views, and to support
server based synchronization of iCalendar-style TODO items as per [RFC
5545][rfc-5545] using the CalDAV protocol as specified by [RFC
4791][rfc-4791].
Status
------
**notnow** is being used actively on a day-to-day basis, without any
known issues. Most of the desired functionality exists, but not
everything is hooked up to the UI yet:
- tag based filtering is implemented and fully functionally, but not all
  aspects of it are available through the UI
- the program stores tasks as iCalendar TODO items
  - it loosely follows the [Vdir storage format][vdir-format], enabling
    task synchronization between different systems via [vdirsyncer][]
  - "native" CalDAV support without a Python dependency is considered,
    but there exist no immediate plans to get there
Configuration
-------------
The program stores its configuration below `$XDG_CONFIG_HOME/notnow/`
(which most commonly defaults to `~/.config/notnow/`). Configuration is
two-fold:
- `notnow.json` is a JSON file storing basic program state such as
  colors and views ("tabs") to display
  - when not present, defaults are being used
  - this file will be auto-created with the default contents once the
    user saves data from within the program (see below)
- `tasks/` is a folder comprised of files for individual tasks
  - the file `00000000-0000-0000-0000-000000000000` is special and
    contains task meta data such as tag information
  - the program takes care of creating said files as tasks are added
*Note*: If you were a user of **notnow** in version `0.2.*` and want to
carry managed tasks and configuration over to version `0.3`, the script
at [var/config-conversion-v02-to-v03.sh](var/config-conversion-v02-to-v03.sh)
may be of help.
### vdirsyncer
If you would like to synchronize tasks with your CalDAV enabled calendar
and/or share one set of tasks between different systems running
**notnow**, [vdirsyncer][] is the recommended way to go about that.
Here is a configuration template that specifies relevant settings, along
with some opinionated ones (typically stored at
`$XDG_CONFIG_HOME/vdirsyncer/config`):
```ini
[general]
status_path = "~//vdirsyncer-state/status/"
[pair todos]
a = "todos_remote"
b = "todos_local"
collections = ["from a", "from b"]
conflict_resolution = ["command", "nvim", "-d"]
[storage todos_remote]
type = "caldav"
item_types = ["VTODO"]
url = "https://"
username = ""
password.fetch = ["command", "sh", "-c", "pass  | head -n1"]
read_only = false
[storage todos_local]
type = "filesystem"
path = "~//vdirsyncer-state/todos/"
fileext = ""
encoding = "utf-8"
```
Please refer to its [documentation][vdirsyncer-config] for additional
details.
With the configuration in place, once you `vsyncdir discover`, create a
symbolic link below `~//vdirsyncer-state/todos/` replacing
the automatically created subfolder with a reference to
`$XDG_CONFIG_HOME/notnow/tasks/`. Next, synchronize tasks using
`vsyncdir sync`.
Please note that task synchronization should happen before or after
running **notnow**, to prevent collisions with changes happening
concurrently from the program.
Usage
-----
Being terminal based, **notnow** is controlled through its UI as opposed
to command line parameters. The program aims to mirror Vi style bindings
where that is possible. The key bindings are as follows:
| Key(s) | Function                                 |
|--------|------------------------------------------|
| a      | Add a new task                           |
| e      | Edit selected task's summary             |
| t      | Edit selected task's tags                |
| d      | Delete selected task                     |
| y      | Copy the selected task                   |
| p      | Paste a previously copied task           |
| j      | Move task selection down                 |
| k      | Move task selection up                   |
| J      | Move selected task down                  |
| K      | Move selected task up                    |
| g      | Select first task on the current tab     |
| G      | Select last task on the current tab      |
| Space  | Toggle completion state of selected task |
| h      | Select tab to the left                   |
| l      | Select tab to the right                  |
| H      | Move tab to the left                     |
| L      | Move tab to the right                    |
| 1-9    | Select tab #x                            |
| 0      | Select last tab                          |
| `      | Select previous tab                      |
| /      | Start task search forward                |
| ?      | Start task search backward               |
| n      | Continue task search forward             |
| N      | Continue task search backward            |
| *      | Start forward search for currently       |
|        | selected task on other views             |
| Return | Accept text input / Edit task details    |
| Esc    | Cancel text input                        |
| w      | Save tasks to file                       |
| q      | Quit program                             |
In addition, when inputting text (e.g., when **a**dding or **e**diting a
task), the backspace, delete, home, end, and left and right cursor keys
have functions similar to those they carry most commonly.
The program has support for [`libreadline`][libreadline] style task
input, when built with the `readline` feature flag enabled. That is,
when entering actual text (as opposed to just pressing a key to, say,
selecting a different task), `libreadline` bindings will be honored.
Example
-------
If you are just interested in trying out the program with some
programmatically created tasks, you can use the existing example:
```sh
$ cargo run --example=with-test-data --features=test
```
Note that if saved, tasks will be stored in a temporary directory and
not overwrite user-specific configuration mentioned above.
[rfc-4791]: https://tools.ietf.org/html/rfc4791
[rfc-5545]: https://www.rfc-editor.org/rfc/rfc5545
[vdir-format]: http://vdirsyncer.pimutils.org/en/stable/vdir.html
[vdirsyncer]: https://github.com/pimutils/vdirsyncer
[vdirsyncer-config]: http://vdirsyncer.pimutils.org/en/stable/index.html
[libreadline]: https://tiswww.case.edu/php/chet/readline/readline.html