マシンピラティスに夢中な私
はじめまして。商業ディベロッパーに新卒で入社して6年目のOLです!
私は、今年の4月から週2~3回の頻度で、仕事終わりにグループレッスンのマシンピラティスに通い始めました。(回数無制限のプランです!)
この趣味を満喫するために、初めてLINE Bot作りに挑戦したので、紆余曲折をご覧いただければと思います。
マシンピラティスとは
マシンピラティスとは、専用のマシンを使ったピラティスのことです。
参考:マシンピラティスとは?(私が通っているスタジオのHPではないです!)
私が3ヶ月間通ってみた結果、こんなところにハマってしまいました。
- 体が伸びてスッキリする
- ちょうどいい筋肉痛になる
- 汗だくにならずに済む(レッスンの内容によりますが)
マシンピラティスを始めてからは仕事中も姿勢を意識するようになり、以前よりはなんとなく健康的になった気がします。
最近は私と同じようにマシンピラティスに興味を持つ方が多いようで、レッスンに行く度に体験の方が入会手続きをしている様子を見かけます。
大人気だからこそ、レッスンの予約が取りづらい!
私が通っているスタジオはインストラクターを囲む形で約30台のマシンがあり、受講生1人につき1台を使用することになっています。
そのため、各レッスンにおいて受講生による予約の争奪戦が勃発しています。
そんな中、より多くの受講生がレッスンを受けられるように、下記の通り予約に関するルールが設けられています。
-
3件のレッスンしか予約ができない
⇒レッスンが終わった瞬間(予約済のレッスンが2件になった瞬間)に、次のレッスンを予約する人が多い。 -
キャンセル期限は、レッスン開始時刻の1時間前まで
⇒1時間前までにキャンセルしなかった場合は出席するものと見なされ、出席できなかった場合は無断欠席扱いになる。 - 月に2回無断欠席をすると、翌月の予約可能件数が3件から1件に減少する
・・・この一番下のルールが、私にとって恐怖なのです
決して安くはない月額料金を払っていることもあり、週2~3回は通いたいので、1件ずつしか予約できなくなってしまったら予約争いに太刀打ちできません。
つまり、無断欠席をしないために予約したレッスンの存在を失念してはいけないのは当然のこと、突然の残業や会食が発生した場合には、抜かりなく予約をキャンセルする必要があります。
各種期限をリマインドしてくれるLINE Botを作ってみた
そこで、こんなLINE Botを作ってみました!
翌日にレッスンがある旨を、前日の夜にリマインド
⇒レッスンを失念しないため
当日のレッスンのキャンセル期限を、キャンセル期限の1時間前にリマインド
⇒急用が入った時にキャンセルを失念しないため
次の予約をする旨を、レッスンの終了時間にリマインド
⇒レッスンが終わってすぐに次の予約をすることを失念しないため
マイページ(ジムの会員ページ)にログインできるリンクを、リッチメニューに設定
⇒予約やキャンセルの画面に到達しやすくするため
動いているところ⇓
使用ツール
Makeの全体像
1.Google スプレッドシートの作成と連携
まずはじめに、リマインドしたい内容やリマインドしたい時間などの情報が入ったGoogle スプレッドシートを作成し、Make内のモジュールに連携しました。
①レッスン日などを記入したGoogle スプレッドシートを作成
実際は3件ずつしか予約ができないのですが、1ヶ月分の予約したい日時を事前に考え、「予約ができたもの」として作成しました。
- A~C列:該当のレッスン日時
- D列:前日リマインドをしたい日時
- E~F列:キャンセル期限リマインドをしたい日時とキャンセル期限
- G~J列:次回予約リマインドをしたい日時と次回予約日時
このとき、D・E・G列のリマインド時間は「YYYY/MM/DD HH:mm」の形式で記入しました。
②「Google Sheets(Search Rows)」モジュールに連携
- Googleのアカウントと連携して「Spreadsheet」の部分で該当のファイルを選択
- 「Sheet Name」の部分で該当のシートを選択
2.リマインドの設定
次に、3つのリマインドの設定をしました。
操作方法は3つとも同じなので、ここでは「前日リマインド」の設定時の紹介をします。
①「LINE(Send a Push Message)」モジュールの設定
「LINE(Send a Push Message)」モジュールで、リマインドを送りたい宛先の設定と、送りたいメッセージの記入をしました。
②「Set up a filter」の設定
「前日リマインド時間」が「今の時刻」と一致したら送信するように設定しました。
-
「Condition」の上部の枠をクリック
-
をクリック
-
「Condition」の下部の枠をクリック
-
をクリック
-
「formatDate」をクリック
-
「;」前に「now」をクリック
-
「;」後にベタ打ちで「YYYY/MM/DD HH:mm」と入力
参考にさせていただいたサイト:Make(integromat)で、昨日を指定する
これで、3つのリマインドの設定が完了しました。
問題点:Run onceしないとリマインドが届かない(未解決)
設定が完了し、Googleスプレッドシートで直近の時間に変更して(下記画像の黄色部分)、Run onceをクリックしたところ、欲しい情報がきちんと手に入りました!
しかし、SCHEDULINGをONにした上で、Run onceをせずにその時間まで待っていてもリマインドが届きません。
よく考えると、Makeの設定時に触っていなかった部分がありました。
「Google Sheets(Search Rows)」モジュールの左下にある時計マークです。
デフォルトでは「At regular intervals」になっていました。
クリックしてみると、沢山の選択肢があります。
自動的に届くようにする方法を考えた結果、消去法で「On demand」か「At regular intervals」の2択で迷ったので、Makeのホームページで調べてみました。
参考:https://www.make.com/en/help/scenarios/scheduling-a-scenario
どうやら「On demand」はRun Onceをしないと実行しないようです。
となると「At regular intervals」でしょうか。
調べてみると、「デフォルトではシナリオは15分ごとに実行されますが、このパネル内で実行スケジュールと間隔をカスタマイズできます。」とあります。
ということは間隔を1分ごとにすれば、自動的にリマインドが届くのでは?とひらめいたのですが・・・
Makeのホームページで調べたところ、1分間隔に設定できるのは有料プランの特権のようで、無料プランの私は試すことができませんでした。
参考:https://www.make.com/en/pricing
果たして有料プランになれば、自動的にリマインドが届くのか?
はたまた違う方法があるのか?
また色々調べてみようと思います。
おまけ:リッチメニューの作成
せっかくなら予約やキャンセルができるマイページ(ジムの会員ページ)のリンクを常に表示させようと思い、リッチメニューを作成しました。
詳しい説明は省きますが、LINE Official Account Manager>ホーム>トークルーム管理>リッチメニューで画像を作ったりリンクを設定したりして、完成いたしました!
まとめ
このLINE Botを作ったことで無断欠席を予防でき、予約枠が1件に減ることなく、沢山ピラティスに通うことができそうです!
しかし現状のままでは自動的には稼働しないので、いろいろ勉強して改善し、実働させたいと思います。
はじめてのLINE Botづくりは分からないことばかりでとても大変でしたが、未知の世界にぐっと近付けた気がして素直に嬉しかったです。
これからもデジタルを実用的に使えるように頑張って参りますので、あたたかく見守っていただけますと幸いです!