イベント情報のページからカレンダーに予定を登録する「everything-ics」を作った

イベント開催や本の発売に関するWebニュースを見ているとき、気になった内容の開催日や発売日をカレンダーに登録したいことがあります。
このとき、カレンダーアプリを開いてイベント情報を入力して登録することは面倒なので、その作業を簡便化できるWebアプリケーション「everything-ics」を作りました。
ソースコードはGitHubに公開しています。

everything to ics. Contribute to chick-p/everything-ics development by creating an account on GitHub.
GitHub

「everything-ics」の使い方

「everything-ics」は、iOSのショートカットでの利用を想定しています。
ショートカット使って、イベント情報をカレンダーに登録する流れは、次のとおりです。

  1. イベント情報などのWebページで、共有メニューを開く
  2. 「everything-ics」ショートカットを選択する
  3. 必要に応じて、画面でイベント情報を修正する
  4. icsファイルからカレンダーを登録する

アニメーション:「everything-ics」を使ってWebページからイベントを登録している

「everything-ics」では、次の情報をカレンダーに登録できます。

  • イベント名
  • 開催日付(開始日のみ)
  • 元となったWebページのURL

デプロイ方法

「everthing-ics」を使用するには、ソースコードをCloudflare Workersにデプロイする必要があります。

$ git clone https://github.com/chick-p/everything-ics.git
$ cd everything-ics

# 依存パッケージをインストール
$ npm install

# 事前にCloudflare Workersへのloginが必要
# ログイン済みの場合は次のコマンドをスキップする
$ npx wrangler login

# デプロイ
$ npm run deploy

デプロイが終わると、Cloudflare WorkersのURLが発行されます。
発行されたURLにアクセスすると、ショートカットアプリのセットアップ方法を確認できます。
スクリーンショット:セットアップ方法が枠線で強調されている

ショートカットの登録方法

ショートカットの登録時にCloudflare WorkersのURLを貼り付けするだけで、共有シートから「everything-ics」を利用できるショートカットも用意しました。
ダウンロードURLは、Cloudflare WorkersのURLにアクセスすると確認できます。
ちなみに、ショートカットの構成は、次のようになっています。
スクリーンショット:ショートカットアプリの画面

技術的なこと

構成図

「everything-ics」の構成はシンプルです。
Cloudflare Worker上に立てたWebアプリケーションに対し、クライントがGETリクエストで、目的のイベントページのURLを送ります。
「everything-ics」は、目的のページのURLにリクエストを送りHTMLを取得します。
HTMLの内容からイベント名や開催日付を取得してicsファイルを生成し、クライアントに返します。

図:構成を説明している

技術スタック

  • Hono
  • Cloudflare Workers
  • Jest
  • Tailwind CSS

行っていることはただのHTTPリクエストと文字列処理という軽い処理なので、サーバレスなCloudflare Workersを使うことにしました。
WebアプリケーションはHonoを使って実装しています。
Honoを選んだ理由は、触ってみたかったというのが一番大きいですが、Cloudflare Workers上で動くアプリケーションをかんたんに作成でき、Webアプリケーションでよくある処理をまとめたヘルパー関数も充実していたからです。

なお、テストを書いたときにいくつかハマったこととその解決策は、別の記事に書きました。

Hono on Cloudflare WorkersのWebアプリでテストを書くときにハマったこと

日付の処理

日付の処理は、単純な正規表現で行っています。
次の書式の日付に対応しています。使っていくなかで、ほかにも必要な書式があれば増やす予定です。

  • 年月日
  • 月日
  • yyyy/MM/dd