commandline kanban #notetaking #todomanager #scriptable for teams AND personal CSV kanban for minimalist productivity hackers.
WHY? online issuetrackers are great for teams, but how to manage (personal) todo's on a crossrepo-, macro-, or micro-level? This is a very simple powerful tool to do that AND measure productivity. Just store the CSV-file(s) inside repos, clouddrives and local filesystems. #teamfriendly #symlinktheplanet #nestedkanbans
$ curl -LO "https://raw.githubusercontent.com/coderofsalvation/kanban.bash/master/kanban"
$ chmod 755 kanban
$ ./kanban init
$ ./kanban add TODO PERSONAL "buy rose for girlfriend foo bar"
$ ./kanban show
NOTE: columns are configurable, and board resizes according to terminal width
$ ./kanban
Usage:
kanban init # initialize kanban in current directory
kanban add # add item interactive (adviced)
kanban show [status] .... # show ascii kanban board [with status]
kanban <id> # edit or update item
kanban <id> <status> # update status of todo id (uses $EDITOR as preferred editor)
kanban <status> ..... # list only todo items with this status(es)
kanban list # list all todos (heavy)
kanban tags # list all submitted tags
kanban add <status> <tag> <description> # add item (use quoted strings for args)
kanban stats status [tag]
kanban stats tag
kanban stats history
kanban csv # edit raw csv
NOTE #1: statuses can be managed in ~/.kanban/.kanban.conf
NOTE #2: the database csv can be found in ~/.kanban/.kanban.csv
Examples:
kanban add TODO projectX "do foo"
kanban TODO DOING HOLD
kanban stats status projectX
kanban stats tag projectX
watch NOCOLOR=1 kanban show
# notekeeping by entering a filename as description:
echo hello > note.txt && kanban add DOING note.txt
# store in github repo
git clone https://../foo.git && cd foo.git && kanban init && git add .kanban
Environment:
X=120 kanban .... # set max line-width to 120
NOCOLOR=1 kanban .... # disable colors
PLAIN=1 kanban ... # plaintext, disable utf8 chars
$ ./kanban show
.------. .------. .-------.
| TODO |_______ | HOLD |_______ | DOING |_______
| | |
| 1 foobar | 3 ipsum
| 2 lorem
$ ./kanban 2 DOING
TODO -> DOING
NOTE: make sure you have your favorite editor set in ~/.bashrc (
export EDITOR=vim
e.g.)
$ ./kanban 2 # this executes ${EDITOR}
$ ./kanban TODO DOING | grep projectfoo
Nice to get project-specific kanban overviews.
adding a filename as a description, will trigger kanban to launch
$EDITOR
:
$ echo -e "hello\nworld" > my_idea.txt
$ kanban add TODO note my_idea.txt
$ kanban list
id status tag description
- - - - -
4 TODO note my_idea.txt
$ k 4
TIP: use symlinks to share notes across boards (
cd myproject && ln -s ~/.kanban/timelog.txt timelog.txt
e.g.)
NOTE: from here we use the k-alias, see the 'Attention Unix ninjas' on how to use it
$ k TODO
id status tag description history
- - - - -
185 TODO bly fooo bar flop BTBDHDHDHT
199 TODO bly meeting about techdesign BT
245 TODO lb checkout testsuite BT
246 TODO nus add field to db BT
242 TODO nus fix db lag BT
as you can see in the history, todo 185 is quite problematic. It went from Backlog->Todo->Backlog->Doing->Hold->... and so on. Obviously the person who assigned this todo should rethink it, and chop it up into seperate todos.
$ k TODO 2015-08
id status tag description history
- - - - -
246 TODO nus add field to db BT
242 TODO nus fix db lag BT
Here you can see all todo's which were 'touched' in august 2015
see ~/.kanban/.kanban.conf
(gets created automatically)
You can define the kanban statuses, and limit the maximum amount of todos per status.
See .kanban/kanban.conf
in case you initialized a board in your current dir (using kanban init
)
Safest way to keep the CSV sane:
$ ./kanban add
enter description:
> do laundry
enter one of statuses: BACKLOG TODO IN_PROGRESS HOLD DONE
> TODO
enter one of tags: projectA, projectB
> projectA
$
As mentioned earlier, the status/categorynames can be changed in .kanban/.kanban.conf
.
No widescreen? Show a tag-less, simplified kanban board by hiding some categories:
XSMALL=119 # show simplified kanban for terminalwidth < 119 chars
SMALLSCREEN=('DOING' 'TODO' 'HOLD') # define simplified kanban board statuses
Besides regular tickets, infinite nested kanbans are supported too, as well as adding a kanban as a ticket.
$ kanban init
$ mkdir v3
$ mkdir v3/v4
$ cd v3 && kanban init && kanban add a foo && cd -
$ cd v3/v4 && kanban init && kanban add b bar && cd -
$ kanban add TODO dev foobar
$ cd ..
$ kanban show
.____.
| TODO |_____
|
| 1 #dev foobar
kanbans:
├─ v3
├─ v3/v4
$ kanban v3 # shows v3 kanban
.____.
| TODO |_____
|
| 1 #a foo
Now lets add the v3/v4
kanban as a ticket:
$ kanban add TODO foo v3/v4
$ kanban show
.____.
| TODO |_____
|
| 1 #dev foobar
| 2 #foo v3/v4
kanbans:
├─ v3
├─ v3/v4
$ kanban 2 # shows v3/v4 kanban
.____.
| TODO |_____
|
| 1 #b bar
$ cd ~ # go to homedir (where your dotfiles live)
$ kanban init # creates ~/.kanban
$ cd projects/foo
$ kanban init
$ mv .kanban ~/.kanban/foo
$ ln -s ~/.kanban/foo .kanban # link dotfiles-folder to here
$ cd ~
$ git add .kanban && git commit -m "dotfiles: updated kanbans"
$ cd projects/bar
$ kanban init
$ git add .kanban && git commit -m "added kanban to project repo"
kanban items are SCRIPTABLE using your favorite language. This allows dynamic statuses, tags & descriptions in the CSV-file:
"$(~/.kanban/bot status_day TODO '1 4')","script","database backup","T","2021-10-04@15:36"
this will call the following (executable) shellscript (~/.kanban/bot
)
#!/bin/bash
status_day(){
[[ "$2" =~ $(date +%u) ]] && printf $1 || printf BACKLOG
}
"$@"
Profit!
The database backup
item will have status TODO on mondays & fridays, otherwise BACKLOG
TIP: use curl to generate dynamic descriptions, for example:
"$(curl https://api.github.com/repos/coderofsalvation/kanban.bash/issues | grep total_count | sed 's/[^0-9]//g') open issues"
Just wrap a word with stars (*iamblinking*
e.g.) in your csv to catch more attention.
type 'k' instead of './kanban'
$ cp kanban ~/bin
$ echo 'export PATH=$PATH:~/bin' >> ~/.bashrc
$ echo 'alias k=kanban' >> ~/.bashrc
$ source ~/.bashrc
(now all terminals will recognize 'k' as a command)
Cleanup your kanban board with some bash-fu:
$ for i in {19,36,49}; do kanban $i BACKLOG; done
DONE -> BACKLOG
DONE -> BACKLOG
DONE -> BACKLOG
mass-renames:
$ sed -i 's/FOO/BAR/g' ~/.kanban.csv
Open a terminal on an extra monitor/screen/tmux:
$ NOCOLOR=1 watch kanban show
Run ninja-commands like: 'k 23 DONE' and withness the update:
$ k 34 DONE
TODO -> DONE
$ k add TODO NINJW workout" "$(date --date='tomorrow' +'%Y-%m-%d') deadline"
Put the following in ~/.bashrc
to display boards whenever you enter a directory with a kanban:
cd(){
builtin cd ${1:+"$@"} && [[ -d ./.kanban ]] && kanban show
}
With the power of grep you can get overviews:
$ k stats status
DONE 155 ▆▆▆▆▆▆▆▆▆▆▆▆▆▆▆▆▆▆▆▆
BACKLOG 73 ▆▆▆▆▆▆▆▆▆▆
HOLD 9 ▆▆
TODO 5 ▆
DOING 5 ▆
$ k status 2015-08
DONE 155 ▆▆▆▆▆▆▆▆▆▆▆▆▆▆▆▆▆▆▆▆
BACKLOG 73 ▆▆▆▆▆▆▆▆▆▆
HOLD 9 ▆▆
TODO 5 ▆
DOING 5 ▆
$ k stats status DONE 2015-08
projectfoo 62 ▆▆▆▆▆▆▆▆▆▆▆▆▆▆▆▆▆▆▆▆
opensource 43 ▆▆▆▆▆▆▆▆▆▆▆▆▆▆
projectX 3 ▆
admin 2 ▆
$ k stats status projectfoo
DONE 56 ▆▆▆▆▆▆▆▆
BACKLOG 33 ▆▆▆▆▆
HOLD 6 ▆
TODO 2 ▆
DOING 1 ▆
Lets see what the slacking / project ratio is :)
$ k stats tag 2015-08
slacking 76 ▆▆▆▆▆▆▆▆
projecfoo 36 ▆▆▆▆
What are are typical tasktransitions:
$ k stats history
T 129 ▆▆▆▆▆▆▆▆▆▆▆▆▆▆▆▆▆▆▆▆
BTDHDHD 16 ▆▆▆
T 129 ▆▆▆▆▆▆▆▆▆▆▆▆▆▆▆▆▆▆▆▆
BD 16 ▆▆▆ ```
View which projects were put on hold at least 2 times in 2014:
```bash
$ k stats history HDHD 2014
project30 6 ▆▆▆▆▆▆▆▆▆▆▆▆▆▆▆▆▆▆▆▆
project40 4 ▆▆▆▆▆▆▆▆▆▆▆▆▆▆
project20 4 ▆▆▆▆▆▆▆▆▆▆▆▆▆▆
project10 3 ▆▆▆▆▆▆▆▆▆▆
Create the following index.html
:
<!DOCTYPE html>
<pre id="log"></pre>
<script>
// helper function: log message to screen
function log(msg) { document.getElementById('log').textContent += msg + '\n'; }
// setup websocket with callbacks
var ws = new WebSocket('ws://localhost:8080/');
ws.onopen = function() { console.log('CONNECT'); };
ws.onclose = function() { console.log('DISCONNECT'); };
ws.onmessage = function(event) { log(event.data); };
</script>
And then serve it to the web:
$ sudo apt-get install websocketd
$ X=120 NOCOLOR=1 PLAIN=1 websocketd -passenv 'X,NOCOLOR,PLAIN' -port 8080 -staticdir . ./kanban show
Mon, 04 Oct 2021 18:23:08 +0200 | INFO | server | | Serving using application : ./kanban show
Mon, 04 Oct 2021 18:23:08 +0200 | INFO | server | | Serving static content from : .
Mon, 04 Oct 2021 18:23:08 +0200 | INFO | server | | Starting WebSocket server : ws://localhost:8080/
Now surf to http://localhost:8080 and PROFIT!
Somehow source kanban.completion
in your ~/.bashrc
or just copy it to /etc/bash_completion.d
For developers, there's no such thing as the ultimate todo-utility
KANBAN.bash brings the lean and mean kanban board to the console. It uses csv as database backend, a very popular tabular format. The commandline usage is very minimal so few keystrokes can do magic.
tests oneliners:
cd test; for test in test-*; do ./$test &>/dev/null; done && echo OK || echo ERROR
cd test; for test in test-*; do bash -x $test; done && echo OK || echo ERROR