こんにちは。ファンリピートの鳴海です。
今回はBubbleでリストの検索結果をパラメータで引き継ぐ方法について解説いたします。
bubbleとは?
data:image/s3,"s3://crabby-images/6eef1/6eef13f68c83fc51cb59c31ce8821eb6c605d265" alt=""
URL:https://bubble.io/blog/content/images/2020/09/Logo-with-clearspace.png
コードを書かずにアプリを作れる
一般的なWebサービスやWebアプリの開発では、プログラミングコードを書くといったイメージがありますが、ノーコードツールBubbleでは名前の通り、ノーコードで開発できるサービスとなっています。
また、クラウドプラットフォームというサイト上でアプリケーションを構築できるので、インターネットがあればいつでもどこでもアクセスができるため、チームで連携してアプリを作れます。
bubbleについての詳細は「ノーコードツール「Bubble」って?特徴・料金・使い方を解説」という記事でも解説しておりますので、気になる方は一度ご覧になってみてください。
Option setsとは?
リストを簡易的に表示や使い回しができる機能です。
保存したいデータに対して、事前に把握している情報(例えば性別、チーム名、曜日)を毎回リストで表示するといったことがプログラミングの世界ではあると思います。
BubbleですとOption setsという機能で、事前にリストを作成するだけで表示させたいページやエレメントに使い回しができます。
詳しくはこちらの記事をご覧ください。
パラメータの渡し方
Bubbleでは、ページ遷移時にWorkflowでパラメータを指定して渡す処理があります。
そもそもパラメータとは?
値を与えるという意味で、引数ともいいます。
普段URLを見た時にkey=?やid=?というのを見かけると思うのですが、別ページや詳細ページに遷移する時に、画面で操作した値(例えば検索にかけた値)をURLで値を引き継ぎができます。
そして遷移した際にデータを表示するという便利なものがWEBの仕組みとしてあります。
Bubbleでパラメータの渡し方
主にページ遷移時にパラメータを渡すという設定があります。
WorkflowのGo to page…や、
data:image/s3,"s3://crabby-images/9262f/9262f020c1c260952a49dd4ecb3d372d9f2457b9" alt=""
linkエレメントの下部にそれぞれSend parametersというのがあります。
data:image/s3,"s3://crabby-images/92390/92390910a411d9889cb8ca4890e6ab54b472f4c0" alt=""
そちらが主にページ遷移時にパラメータを送る際の設定となります。
渡し方としては、Send more parameters to the pageを押して、それぞれ引き渡したい値をkeyに設定します。
data:image/s3,"s3://crabby-images/bfbd8/bfbd87e3a7bdc8112a04d95a7f5314fc2da00046" alt=""
そしてページ遷移し、URLの箇所をみると赤色で囲まれている通りに、わざわざデータベースに保存せずに値を渡せます。
※%2C%20という文字があるのですが、こちらは文字を区切る際の「,」がURL上の文字列化しただけなので心配ございません。
data:image/s3,"s3://crabby-images/1cd16/1cd1643a47ef62736929427e339a3d419ea48ad1" alt=""
パラメータから値を取得して、表示する
Bubbleでは、Get data from page URLというのからparameterの値を取得できます。
パラメータから値を取得する
先ほどURLで渡した値を取得するには、Get data from page URLを選択します。
data:image/s3,"s3://crabby-images/7928c/7928ca4d23b9a65474b644eda4b0cc3a129230ff" alt=""
パラメータ値を表示する
Parameter nameで、取得したいパラメータ名を入力します。
data:image/s3,"s3://crabby-images/b6c7b/b6c7b59f72fabd2a255eed32e90267feeb9333d2" alt=""
そうするとページ遷移時に、todoに入っていた値がページ遷移しても表示されます。
data:image/s3,"s3://crabby-images/4bf83/4bf83342098abd90115590f51fde4d59ee70bd20" alt=""
リストの値をパラメータで引き継ぐ
上記の方法を応用して、簡易的なアプリを制作してみようと思います。
動作確認
下記のような感じで、「曜日(リスト値)」と「todo」という値を引き継いだまま、ページ遷移しても情報を表示させて、ブラウザバックしても引き継がせるようにします。
実装する
Dataを用意する。
Data typesはDayを作成し、unique id、Day、todoを追加しました。
unique idはnumber型で、使い方としてはデータをそれぞれ連番でつけておき、詳細画面で連番からデータを簡易的に表示するためです。
toodはtext型で、DayはField typeをOption setで作成したものを指定しました。
data:image/s3,"s3://crabby-images/7ba64/7ba64f437cb94ab4b4681d82bb777f47a7ac553c" alt=""
Option setsの設定は、Days of weekという名前でそれぞれ曜日を追加しました。
data:image/s3,"s3://crabby-images/f9ee0/f9ee0824ae4cce9523788c26694e760d664593e5" alt=""
メインページのDesign
ページを作成して、Groupエレメントを配置後、inputエレメント、Buttonエレメントを2つ配置します。
data:image/s3,"s3://crabby-images/8de86/8de862a882694fb88178e711edd078000e75c854" alt=""
Repeating groupを配置して、列内にTextエレメント、Layoutの設定で縦上限を外すためにrowsを外します。
data:image/s3,"s3://crabby-images/ab61f/ab61f3e3650603d3756763c60162bbc448f66534" alt=""
Input 曜日にフォーカスした際に表示させたいので、Group fucusを配置して、Input 曜日を選びます。
data:image/s3,"s3://crabby-images/7ba4c/7ba4c7636279feef22a0669819c60aef0e9731c6" alt=""
Repeating groupを配置して、それぞれ小さいですがエレメントを入れ込みます。コツとして、左のelement treeを操作しながら、各エレメントのサイズを直接調整することです。
data:image/s3,"s3://crabby-images/d8946/d89466feed908109eb0f50a24877edb78f95bce6" alt=""
サブページのDesign
後ほどページ遷移する際に必要なので、予め作成しておきます。
ページを作成して、Groupエレメントを配置して、Textエレメントを3つ入れます。
data:image/s3,"s3://crabby-images/47682/47682a30f88a9b5d07f754e2b37cf7a7f2cf3d93" alt=""
Unique idからデータを表示する
Groupエレメントを設定します。
①Type of contentはDay
②Data sourceはDo search forを選択し、TypeはDayを選択します。
data:image/s3,"s3://crabby-images/04d00/04d007ed6a912414f9a8ea6d7010d704cea1ae7f" alt=""
Add a new Constraintでunique id を指定して
data:image/s3,"s3://crabby-images/6cbb0/6cbb0003eab9c37f297196da64c9490b05c2c813" alt=""
Get data from pageからunique_idを取得するために設定します。
data:image/s3,"s3://crabby-images/edb2f/edb2f3b5abaca4c4d1fbeddbf1217be4783b25b9" alt=""
この場合だと取得する際に文字列となっているので、number型に変換します。
data:image/s3,"s3://crabby-images/698db/698db20822dfc9176e24ee5c23587008d43c520c" alt=""
unique idで検索して取得したリストは1つだけなので、first itemと指定します。
data:image/s3,"s3://crabby-images/cbf06/cbf0655142ddc759603b171d65cf639bd6a46134" alt=""
配置したTextエレメントに、値を表示します。
①Parent group’s Day’s todoにします。
②Parent group’s Day’s Day’s displayにします。
③Parent group’s Day’s Creation Date
data:image/s3,"s3://crabby-images/3deb6/3deb6363dad4d45af14e86e2c3ae86021d6994fd" alt=""
リストの表示設定
検索処理を反映させるために、Repeating group設定を先にします。
Type of contentはDay、Data sourceはDo search forからTypeをDayにします。
data:image/s3,"s3://crabby-images/8df60/8df608a8efe30a95f4c69c2960724d6aaf3a8d30" alt=""
Textエレメントには、サブページと同じような形で設定します。
data:image/s3,"s3://crabby-images/b5b1f/b5b1f1a337244c27a804098197e96584631ed5a2" alt=""
checkbox型のリスト作成
次に曜日選択を設定します。
Group focus内のRepeating Groupを開きます。
data:image/s3,"s3://crabby-images/19f60/19f6043612f66d234e10784c1334350a4846b79f" alt=""
Type of contentはDays of weekで、Data sourceはAll Days of weak、option setsで設定したリストを選択します。
data:image/s3,"s3://crabby-images/5c053/5c053719e6bb1303952b3d0505782b44b7cc7858" alt=""
Repeating group内のGroupにもType of contentの設定をし、Data sourceはそれぞれ曜日を表示するようにします。
data:image/s3,"s3://crabby-images/9bed7/9bed77e2eafd83428dd25033794d6a403ed142d1" alt=""
Text エレメントの設定もします。
data:image/s3,"s3://crabby-images/d6f56/d6f5659087e7c474932e7ec878148b53dbf7f8ce" alt=""
Input曜日を指定したときに、Group Focusを出現させたいので、Group化して、Workflowを開きます。
data:image/s3,"s3://crabby-images/439fe/439fe45841139f0584031e7316328fb7f073e9ff" alt=""
show elementで、Focusエレメントを指定します。
data:image/s3,"s3://crabby-images/268e4/268e4cfa5c7208af24ea875a9a34391c4049a01c" alt=""
曜日をCheckboxで選択した分だけでリストを作成するための設定をしたいので、Repeating Groupのinspectorを開き、custom statesを設定します。
data:image/s3,"s3://crabby-images/ad4cb/ad4cb8354bf40286cddce74d00d5fa27ee99419b" alt=""
下記の内容で作成します。
data:image/s3,"s3://crabby-images/0bab2/0bab2430e14b1e3a05c27ec7ceed30702a1f0337" alt=""
次にcheckboxがチェック状態になったら、リストに追加する処理を作りたいと思います。
Workflowを開いて、値が変更された時の処理を指定します。
data:image/s3,"s3://crabby-images/f1a76/f1a765b082644932d568fe2af36b18b69f73623b" alt=""
ElementはCheckboxを指定して、Only whenにはcheckがされた時の処理を入れます。
data:image/s3,"s3://crabby-images/e741d/e741d4b6de07a0982d5b152efc8454827f5ea153" alt=""
step1では、set stateを選択し、
data:image/s3,"s3://crabby-images/72a21/72a2160a4ec805813ba9efa1566a64f90a3444f9" alt=""
①Elementは曜日を表示しているRepeating groupを指定し、
②Custom stateはselected_daysを指定し、
③Valueには、selected_daysをplus itemでcheckboxにした曜日を入れるようにします。
data:image/s3,"s3://crabby-images/5aa88/5aa88d13b633a20548595ea0c367aab4b690c3f4" alt=""
次にcheckboxが外された時に、選択されていた曜日リストから減らしたいので、WFをコピーして、貼り付けます。
data:image/s3,"s3://crabby-images/eab29/eab29d794ec7d5910f307fd029cac532a34f98f3" alt=""
もう一つの処理には、Checkが外された時と指定して、
data:image/s3,"s3://crabby-images/d68d8/d68d8b82ff6d1de4c3525504789da7367845c007" alt=""
Step1のValueで、plus itemからminus itemにします。
data:image/s3,"s3://crabby-images/651d8/651d885daf3d4361ef22e188627dc33bd99fd26b" alt=""
検索処理
検索ボタンを押した時に、処理を走らせます。
data:image/s3,"s3://crabby-images/fa532/fa532010b725d1020863b984987f4269ca4faed6" alt=""
ElementはRepeating groupを指定して、Data sourceでは、do search forを選択します。尚、TypeはDayにします。
data:image/s3,"s3://crabby-images/87e50/87e502dade5761d0e7f42d57f1d655c56c645e83" alt=""
Input todoで入力した内容、選択した曜日を指定するに2つ設定して、Ignore empty constarainsを忘れずにCheckすることで、どちらかが空白でも検索が走るようになります。
data:image/s3,"s3://crabby-images/6436e/6436e71d07f92e1d036de5fb8804a186d5c96be9" alt=""
parameterを渡す
次に検索した際に、parameterを持たせるようにします。
NavigationからGo to page…を選択して、今回は遷移しないのでメインページを選択します。
data:image/s3,"s3://crabby-images/8d310/8d3107f87e03d69a6acbcbfe07941273e16fc889" alt=""
それぞれ2つ追加します。
data:image/s3,"s3://crabby-images/7d7a7/7d7a7a7651bd9829278b734e87904514df4a23fc" alt=""
ページ読み込み時の処理
これで検索した際に、URLのパラメータに値を保持できるので、ページを更新しても値が消えないようにできました。
ですがエレメント上では初期値が設定されていないため、消えています。なのでページを読み込んだ時の処理を設定します。
data:image/s3,"s3://crabby-images/d215b/d215b460bac8a43b6a263281185681992b083d93" alt=""
ValueにはOption setsで作成した曜日リストに含まれている曜日をParameterで取得した値をテキストで取得し、曜日リストのテキストで絞り込むを行います。
data:image/s3,"s3://crabby-images/e6af6/e6af6b0e70ad5e393ad17bd7d160cb88b6a0db9e" alt=""
data:image/s3,"s3://crabby-images/1b480/1b4802e06f139c0e1ea37911c3d953c7e4bae194" alt=""
Input Todoには、初期値でURLにTodoに値が入っていたら、そちらを表示するように、Conditional設定します。
data:image/s3,"s3://crabby-images/12a8d/12a8db04524451524013bfa4a3d5d0a4c6e0532a" alt=""
ページ読み込み時のStep2では、自動で検索できるようにしたいので、pluginsからtoolboxをインストールします。
data:image/s3,"s3://crabby-images/8bcb3/8bcb3b931249f1774be836feb14ed8215c0b8dd2" alt=""
検索ボタンにIDを付与したいので、SettingからIDを使えるように設定します。
data:image/s3,"s3://crabby-images/324f0/324f0f6717d59ba2059c6a298eb714688545980f" alt=""
Workflowに戻り、Run javascriptで下記のコードを貼り付けます。
document.getElementById(“search”).click();
data:image/s3,"s3://crabby-images/54e7e/54e7eb00f48cf2b73c6c2cfb3fd1238c89091e0a" alt=""
リセット処理
リセットボタンを押した時の処理設定します。
data:image/s3,"s3://crabby-images/68287/682876a004487bda32118c4f71cc58aa75c11448" alt=""
WFでは、Parameterの値を空に設定します。
data:image/s3,"s3://crabby-images/de0ae/de0aec7b3be934e5669682a716e0f25d17cabb15" alt=""
Input todoのConditionalでは、下記のように指定します。
data:image/s3,"s3://crabby-images/92eb2/92eb27a896c49c0d773b3b4ad66fa264597063c5" alt=""
最後にTextエレメントを押した時に、サブページに遷移するようにします。
data:image/s3,"s3://crabby-images/0214d/0214d1e15528481a270c718398905039d88a455e" alt=""
NavigationからGo to page…を選択して、ページ遷移時にparameterを送るようにします。
data:image/s3,"s3://crabby-images/d0b9c/d0b9c4b8c110b5e93e69f35ae925b3cc97550c58" alt=""
3つのパラメータ設定をしたら、終わりです。
data:image/s3,"s3://crabby-images/ec584/ec58401f2f757e265c1fe620395bfd694ce1717d" alt=""
まとめ
今回はBubbleでparameterの使い方を主に、リストでの渡し方について解説致しました。
プログラミングの世界ではサーバー言語でparameterを指定したりなど様々あると思うのですが、ノーコードですとただ値をkeyで指定するだけなので設定が簡単になりますね。
以上、今回は リストの検索結果をパラメータで引き継ぐ方法についてでした。