Skip to content

Latest commit

 

History

History
219 lines (148 loc) · 7.3 KB

README.md

File metadata and controls

219 lines (148 loc) · 7.3 KB

Git Things Done (GitTD)

Every few years I hunt around for a habit-tracker that meets my needs.

And for maybe a week: my needs are met.

It’s not long however before I want to track tasks, add journal entries; add tags, images and notes; I want to set deadlines; make API calls and synchronize with other tools on the web. The apps are never flexible enough; so I give up.

This year it occurred to me that I could build what I needed using GitHub Issues, GitHub Actions, GitHub Pages and GitHub Flat Data. Git Things Done is a programmable, flexible, hackable and extensible “Getting Things Done” system. Try it out and make it yours.

Screenshot

🚨 WARNING! 🚨

This is new software and definitely not mature! Error handling is bad! You may have to help fix things!

How It Works

Every morning the porter creates a new ticket for the day from a template you control. We suggest this template contains habits you aim to complete each day but that’s up to you.

Tick off the habits (or strike-them-out† if you couldn’t do them) and once they are all checked off the ticket is closed by our automation.

† Surround text in ~ to strike-out

Habit tracking is the just the first part of GitTD, the rest is up to you.

Getting Things Done

The beauty of Git Things Done is the ecosystem. Anyone can create actions so you can customize it to exactly what you need.

Fundamentally GitTD is based on the principle of pulling forward previous data as copies. You always have a fresh copy, thus you have history and edits are both non-destructive and progressive.

We provide the following:

Browse our Awesome List for GitTD

Search for more GitTD actions on the GitHub Actions Marketplace

As a work in progress we also have:

Getting Started

  1. Do Not Fork
    Unfortunately, GitHub do not allow you to make a private fork of a public repository1.
    Instead use gh:
gh repo create gtd --private --template git-things-done/template
  1. Edit the templates
  2. Wait for tomorrow‡

‡ If you can’t wait, manually dispatch the porter.

Detritus

Suggestions and tips for using GitTD effectively

Suggested Usage

  • Every morning ensure you’ve closed out yesterday
  • Tick habits and tasks off during the day
  • Try it out for a week
  • Start adding “Sticky Comments
  • Start editing the workflows to suit your usage
  • Add an occasional:
    • Journal (How are you feeling?)
    • Audit (How’s life going? What needs changing?)
  • Publish any new stuff you make and buoy up the ecosystem
Preventing your GitTD from falling behind updates

Staying Updated

We are unlikely to bump our major versions so you should automatically be up-to-date, but just in case consider setting up Dependabot.

Changes to our template workflows are more likely and easier to miss. Subscribe to this repo’s release updates to get pings.

Want a URL that goes straight to today’s entry? We got you covered.

Bookmarkable URL

NOTE this only works for private forks if you have GitHub Pro 😒. Apparently it can work with a PAT, if so, please advise. Either way we could use a general solution, so please ideate on the discussion board.

We generate a HTML redirect to the latest ticket every day and make it the GitHub Pages for your GitTD repo. It has the form: https://YOU.github.io/REPO/

eg. https://mxcl.github.io/gtd/

Bookmark it and you can quickly and easily get to today’s entry.

Considerations for iOS

It is complicated to bookmark a URL that is just a redirect on iOS. Additionally, if you succeed (there are tricks) the bookmark will always open Safari before opening the GitHub app. Thus we recommend using an iOS Shortcut that opens the URL as it solves both issues (iOS asks if you want to let the shortcut open GitHub a few times but stops after about 3).

You can use this Shortcuts.app shortcut that we already prepared for you.

image

Contributing

  1. Create a GitHub Action
  2. The porter provides GTD_TODAY (today’s ticket number) and GTD_YESTERDAY
  3. Ensure your repo is public
  4. Tag the repo with GitTD and github-actions
  5. Publish to the GitHub Actions Marketplace and tag it GitTD
  6. Consider a PR on our Awesome List

† For other variables you might need, check out the sources for our actions.

Branding

Consistent GitTD branding assists user recognition:

# `action.yml`

name: “Foo” for Git Things Done
branding:
  icon: check-square
  color: green
#

We suggest setting your primary category in the GitHub Actions Marketplace to Utilities, but this is optional—choose whatever you feel is appropriate.

Here’s a Marketplace example.

Please note, to be added to our Awesome List your branding must be match the above guidelines.

Work in Your Fork

It can be fiddly to develop GitHub Actions, so we suggest starting in your own fork and making the action locally:

- uses: ./my-gtd-action
  ## ^^ will run $REPO_ROOT/my-gtd-action/action.yml

When it works move the code to its own public repo and publicize it.

More Like This?

Want to make things like this with people who make things like this?

Join Bootstrap Club.

Footnotes

  1. If you work at GitHub could you perhaps consider allowing private forks for templates. This is presumably useful in general and not just for us. Thanks muchly bae 💜.