Skip to content

oschrenk/plan.swift

Repository files navigation

README

A macOS terminal tool to fetch calendar events from Calendar.app

Features

  • return JSON by default
  • for emoji lovers: separate leading emojis from event title, giving you the emoji, short and full title
  • ignore events based on tags e.g. tag:example within the event notes
  • return start and end time in relative and absolute terms
  • return an ical URL that can be used to open $URL to show the particular event in Calendar.app
  • parse Google meet URLs from notes
  • print out calendar entries with a templating engine

Examples

JSON

Example output in JSON

plan next

[
  {
    "id": "9675DF46-4040-4762-A70B-6CD65DC01C36:CC525CBD-F5A3-4EBB-970E-7A0EC2D2370D",
    "calendar": {
      "id": "C5AE5024-78BD-4965-BB0D-0E43E1024368",
      "color": "#E195DA",
      "label": "Some calendar",
      "type": "caldav",
      "source": ""
    },
    "title": {
      "full": "🏆 Release plan",
      "description": "Release plan",
      "icon": "🏆"
    },
    "schedule": {
      "start": {
        "at": "2024-09-02T18:00:00+02:00",
        "in": 30
      },
      "end": {
        "at": "2024-09-02T19:00:00+02:00",
        "in": 90
      }
    },
    "services": [
      { "ical": "ical://ekevent/9675DF46-4040-4762-A70B-6CD65DC01C36?method=show&options=more" }
    ],
    "tags": [ "timeblock" ]
 }
]

markdown

plan today --template-path path/to/template.md

With template.md:

{% for e in events %}- {{ e.schedule.start.at|format:"HH:mm"}} - {{ e.schedule.end.at|format:"HH:mm"}}{{ e.title.full }} [ ]({{e.services["ical"]}}) #{{ e.calendar.label|lowercase }}
{% endfor %}

You get

- 12:15 - 12:45 🥗 Lunch [ ](ical://ekevent/CC23ADF2-9303-42C4-A854-BE12F2081E16?method=show&options=more) #private
- 13:00 - 14:00 🕐 Meeting [ ](ical://ekevent/59856934-5D89-45A2-9C11-0E3877F1B082?method=show&options=more) #work

For more details, consult Docs/Templating.

Usage

Commands

Example commands (use plan --help for full usage)

  • plan calendars List available calendars
  • plan next Returns the current or next event within the next hour
  • plan today Returns all events for today

Use cases

plan can help with your "productivity" setup. It plays very well with Sketchybar and Obsidian. But with the default output being JSON, and the templating engine, you can easily make plan fit your individual needs.

Sketchybar

You can use it with Sketchybar to show the next event.

Obsidian

You can use it with Obsidian to inject today's schedule into your notes. For more details, consult Docs/Obsidian and Docs/Templating.

Templating

For more details, consult Docs/Templating.

Installation

Via GitHub

  • installs to $HOME/.local/bin/plan (make sure it's in $PATH)
git clone [email protected]:oschrenk/plan.swift.git
cd plan.swift
task install

Via Homebrew

brew tap oschrenk/made [email protected]:oschrenk/homebrew-made
brew install oschrenk/made/plan