この記事は 株式会社SUPER STUDIO Advent Calendar 2024 18日目の記事です。
みなさん、Notion は使っていますか?
使っていますね。良かったです。
Notion でタスク管理してますか?
してますね。良かったです。
今日は、Notion でのタスク管理でちょっと役立つオートメーションをいくつかご紹介します。
Notion でタスク管理していなくても、今日からタスク管理できるように、前提設定なども含めて説明していきます。
最初に
まず、このオートメーションを設定するにあたって、データベースの設定をします。
前提条件を揃えないと、うまくオートメーションを組めなくなってしまうので。
一つずつ見ていきましょう。
タスクデータベースを用意する
まずはデータベースを用意します。
詳しい作り方は、公式のヘルプをご覧ください。
作り方はお好きな方法で大丈夫です。
タスク用データベースとして設定する
そうしましたら、右上の「⋯」(三点リーダー)から「カスタマイズ」を選択します。
データベースの機能を追加できるので、ここで「サブアイテム」と「タスク」をオンにします。
タスクをオンにしたとき、「担当者」「ステータス」「期限」に該当するプロパティを選択しろと言われます。
既存のデータベースをタスクデータベースに変換する場合は、該当するプロパティを選択してください。
新規で作る場合、もしくは該当するプロパティが存在しない場合は、新規作成を選択した状態で「タスクデータベースに変換」を押します。
今回は新規で作るので、すべてのプロパティを新規作成の状態で作ります。
これ以外にもカスタマイズ機能があり、簡単に追加することができるので、試してみてください。
プロジェクトデータベースを用意する
プロジェクトを管理しない場合は、この部分は飛ばしてください。
データベースの作り方は先程と同じなので割愛します。
プロジェクトにタスクを紐づけるためにリレーションを設定します。
右上の「⋯」(三点リーダー)から今度は「プロパティ」を選択します。
「双方向リレーション」を有効にして、【リレーションを追加する】を押します。
これでプロジェクトとタスクの紐づけができるようになりました。
ついでに、プロジェクト側にも「ステータス」のプロパティを作成しておいてください。
オートメーションを設定する
タスク、プロジェクトにそれぞれ設定していきます。
今回は下記の4つを紹介します。
- 親タスクが完了になったら、すべてのサブタスクも完了にする
- すべてのサブタスクが完了になったら、親タスクも完了にする
- プロジェクトが完了になったら、プロジェクトに紐づくすべてのタスクも完了にする
- プロジェクトに紐づくすべてのタスクが完了になったら、プロジェクトも完了にする
4つと言いながら、設定の内容はだいたい2種類です。
親タスクが完了になったら、すべてのサブタスクも完了にする
トリガーを設定する
まず、一番上の「誰々のオートメーション」となっている部分をクリックしてわかりやすい名前をつけておきましょう。
今回は、親タスクが完了になったときサブタスクも完了にしたいので「完了」のみを選択しておきます。
トリガーはこれだけです。
アクションを追加する
続いては実際に動作する部分を作っていきます。
サブタスクを取得する変数を作成する
まず、変数を定義します。
【新規アクション】から「変数を定義」を選択します。
変数を定義することで、様々な条件に合わせたページを自動的に対象にすることができます。
「変数1∨」となっているところをクリックすると、名前を変えることができるのでわかりやすいように「サブタスク」とつけておきましょう。
プロパティ欄から「トリガーページ」を選択した後「サブタスク」を選択します。
「トリガーページ」を選択した後、「.(ピリオド)」を入力すると「サブアイテム」が選択できるようになると思います。
(余談)一部のステータスは完了にしたくない場合
「進行中」グループにある「変えないで」は言わずもがな変えてほしくないステータスでしょう。
また、「完了」グループにある「アーカイブ」は、アーカイブしたのにステータスを「完了」にされてしまうと、タスクチケットを見返すときにノイズになってしまう可能性があります。
これらのステータスは除外したい場合、下記のように変数を設定します。
やっていることとしては、まず「トリガーページ」.「サブアイテム」で親タスクに紐づくタブタスクを取得します。
そのあと.filter()
を使って、条件に合うサブタスクのみを取得するようにします。
除外したいステータスが一つの場合はfilter(current.ステータス != "除外するステータス)
だけで大丈夫です。
除外したいステータスが複数ある場合はfilter((current.ステータス != "除外するステータス1").and(current.ステータス != "除外するステータス2").and(以下略...
のように.and()
で繋いでいきます。
複数ある場合の注意点としては、必ず1つ目の除外したいステータスは「()」で括ってください。
そうじゃないと、判定されません。
// Good
トリガーページ.サブアイテム.filter((current.ステータス != "除外するステータス1").and(current.ステータス != "除外するステータス2")
// Bad
トリガーページ.サブアイテム.filter(current.ステータス != "除外するステータス1".and(current.ステータス != "除外するステータス2")
すべてのサブタスクのステータスを変更する処理を作成する
続いて、実際にステータスを編集する部分を作ります。
【アクションを追加】から「ページを編集」を選択します。
【データベースを選択】をクリックして、先ほど作った変数の「サブタスク」を選択します。
【プロパティを編集∨】から「ステータス」を選択し、「完了」を選択します。
すべて設定できたら【保存】を押します
完成です!
実際に動作させてみる
親タスクにいくつかのサブタスクを作り、親タスクのステータスを「完了」に変えてみましょう。
少し待つと勝手にサブタスクのステータスも「完了」に変わると思います!
もしうまく動作しない場合は、もう一度設定を見直してみてください。
初回は動作に少し時間がかかる可能性もありますので、10〜20秒待っても変わらない場合は設定を見てみてください。
すべてのサブタスクが完了になったら、親タスクも完了にする
一個前でやったものと同じ動作になるものは、基本的に画像などを省略していきます。
タスクデータベースのオートメーション作成画面を開きます。
開き方はさっきと同じなので割愛します。
トリガーを設定する
トリガーもトリガーを設定すると一緒です。
割愛します。
アクションを追加する
先ほどと同じようにまず、変数を定義します。
【新規アクション】から「変数を定義」を選択し、入力欄の右側「Σ」の「関数として編集」をクリックして関数の編集画面に入ります。
オートメーション名も変えておきましょう。
親タスクを取得する変数を作成する
変数名は「親タスク」とでもしておきましょう。
変数の内容は下記です。
「トリガーページ」を選択した後に「.(ピリオド)」を入力して、「親アイテム」を選択後、再度「.」を入力して「first()」を使います。
サブタスクのステータスがすべて完了しているかを判定する変数を作成する
ここから少し高度な変数になります。
今作った「親タスク」変数を利用して、「サブタスクがすべて完了している」という以下条件で値が入る変数を定義します。
a. サブタスクがすべて完了していたらTrue
b. サブタスクのうち完了していないものがあったらFalse
【アクションを追加】から「変数を定義」を選択し、入力欄の右側「Σ」の「関数として編集」をクリックして関数の編集画面に入ります。
変数の内容は下記です。
「親タスク」の「サブアイテム」があるかどうかを判断します。
「サブアイテム」がある場合はすべての「サブアイテム」の「ステータス」が「完了」かどうかを判断してTrue
orFalse
を返します。
「親タスク」に「サブアイテム」がそもそもない場合は、False
を返します。
if関数ではなく、三項演算子を使う場合は、下記のようにも記述できます。
処理内容に違いはなく、記述の好みなのでどちらでも大丈夫です。
親タスクのステータスを変更する処理を作成する
ここまで来たらあと一歩です。
今作った「サブタスクがすべて完了している」変数を使い、今のステータスを保持するか完了にするかを設定します。
【新規アクション】から「ページを編集」を選択し、【データベースを選択】で「親タスク」を選択します。
【プロパティを編集】で「ステータス」を選択します。
ここで、既存のステータスではなく【カスタム数式】を選択します。
先程作った「サブタスクがすべて完了している」を使って、下記のようなif文を作ります。
「サブタスクがすべて完了している」がTrue
だったとき、ステータスを「完了」にします。
「サブタスクがすべて完了している」がFalse
だったとき、ステータスを今のままにします。
実際に動作させてみる
親タスクにいくつかのサブタスクを作り、すべてのサブタスクのステータスを「完了」に変えてみましょう。
少し待つと勝手に親タスクのステータスも「完了」に変わると思います!
プロジェクトが完了になったら、プロジェクトに紐づくすべてのタスクも完了にする
今度はプロジェクト側に作っていきます。
プロジェクトデータベースのオートメーション編集画面を開きます。
オートメーション名も変えておきましょう。
トリガーを設定する
ここはトリガーを設定すると一緒ですので、割愛します。
アクションを設定する
プロジェクトのタスクを取得する変数を作成する
いつも通り変数を設定していきます。
【新規アクション】から「変数を定義」を選択し、入力欄の右側「Σ」の「関数として編集」をクリックして関数の編集画面に入ります。
変数名は「プロジェクトのタスク」とでもしておきましょう。
下記のように変数を設定します。
これでプロジェクトのタスクが取得できるようになりました。
プロジェクトに紐づくすべてのタスクのステータスを変更する処理を作成する
続いて、実際にプロジェクトのタスクをすべて「完了」にする部分を作っていきます。
【新規アクション】から「ページを編集」を選択し、【データベースを選択】で「プロジェクトのタスク」を選択します。
【プロパティを編集】で「ステータス」を選択します。
「ステータス」で「完了」を選択します。
すべて設定できたら【保存】を押します。
完成です!
実際に動作させてみる
いくつかのプロジェクトを作り、それに紐づくタスクもいくつか作っておきます。
プロジェクトのテンプレートで、タスクのリンクドビューを作っておくとわかりやすいかと思います。
プロジェクトを完了にすると、紐づくタスクがすべて「完了」になるかと思います!
プロジェクトに紐づくすべてのタスクが完了になったら、プロジェクトも完了にする
ついに最後です。
今回はすべてのサブタスクが完了になったら、親タスクも完了にすると似たオートメーションです。
というか、一部以外ほぼ一緒です。
タスクデータベースのオートメーション作成画面を開きます。
いつも通りオートメーション名も変更しておきましょう。
トリガーを設定する
トリガーはトリガーを設定すると一緒です。
アクションを追加する
親プロジェクトを取得する変数を作成する
いつも通り、変数を定義します。
【新規アクション】から「変数を定義」を選択し、入力欄の右側「Σ」の「関数として編集」をクリックして関数の編集画面に入ります。
変数名は「プロジェクト」とでもしておきましょう。
もう慣れてきましたね。
変数の内容は下記です。
「トリガーページ」を選択した後に「.(ピリオド)」を入力して、「このタスクのプロジェクト」を選択後、再度「.」を入力して「first()」を使います。
プロジェクトに紐づくタスクのステータスがすべて完了しているかを判定する変数を作成する
今作った「プロジェクト」変数を利用して、「紐づくタスクがすべて完了している」という以下条件で値が入る変数を定義します。
a. タスクがすべて完了していたらTrue
b. タスクのうち完了していないものがあったらFalse
【アクションを追加】から「変数を定義」を選択し、入力欄の右側「Σ」の「関数として編集」をクリックして関数の編集画面に入ります。
変数の内容は下記です。
「プロジェクト」に「このプロジェクトのタスク」があるかどうかを判断します。
「このプロジェクトのタスク」がある場合はすべての「このプロジェクトのタスク」の「ステータス」が「完了」かどうかを判断してTrue
orFalse
を返します。
「プロジェクト」に「このプロジェクトのタスク」がない場合は、False
を返します。
親プロジェクトのステータスを変更する処理を作成する
今作った「紐づくタスクがすべて完了している」変数を使い、今のステータスを保持するか完了にするかを設定します。
【新規アクション】から「ページを編集」を選択し、【データベースを選択】で「プロジェクト」を選択します。
【プロパティを編集】で「ステータス」を選択します。
既存のステータスではなく【カスタム数式】を選択します。
先程作った「紐づくタスクがすべて完了している」を使って、下記のようなif文を作ります。
「紐づくタスクがすべて完了している」がTrue
だったとき、ステータスを「完了」にします。
「紐づくタスクがすべて完了している」がFalse
だったとき、ステータスを今のままにします。
実際に動作させてみる
プロジェクトを作り、それに紐づくタスクもいくつか作っておきます。
プロジェクトのテンプレートで、タスクのリンクドビューを作っておくとわかりやすいかと思います。
プロジェクトに紐づくタスクをすべてを完了にすると、プロジェクト「完了」になるかと思います!
最後に
めちゃめちゃ長くなってしまいましたが、最後までお読みいただきありがとうございました。
Notion はアップデートが頻繁にあって、いろいろな機能が沢山追加されて楽しいですね。
みなさんも Notion で良きタスク管理ライフを送ってください。