結論
条件が「他のアクションの実行が完了した時」以外の場合、やることはすべて「なにもしない」にする!
というマイルールをご紹介します。
私の経歴
kintone歴は1年半ほどです!もともとはプログラム開発をしていましたが、最近はカスタマインしか触っていません!
アドベントカレンダーへの参加は今回が初めてです。よろしくお願いします。
目次
- カスタマインを使っているときの私の悩み
- カスタマインらしさとは
- お悩みその1の解決策:アクショングラフで条件分岐を見やすくする
- お悩みその2の解決策:アクションの構造はそのままで、画面上にて処理状況を確認する
- お悩みその3の解決策:「なにもしない」を入れておけば、アクションの追加が簡単に
- まとめ
カスタマインを使っているときの私の悩み
- カスタマイズが長く複雑になり、次の日に見てもわからず絶望する
- 処理がどこまで進んでいるのか、意図通りに動いているのかがわかりにくい
- アクションとアクションの間に、後からアクションを追加しづらい
カスタマインらしさとは
カスタマインらしいカスタマイズとは、シンプルなアクションで、カスタマイズの画面を見ただけで何をやっているのか分かるくらいのカスタマイズです。
そのほうがメンテナンスもしやすいし、良いですよね。まさに「Keep it simple, stupid.」という考え方です。
ただし、やろうと思えばどこまでも作り込めてしまうのがカスタマインの良さでもあり、悩ましいところです。
途中から楽しくなりすぎて、結果的に複雑怪奇なものが出来上がってしまう…というのは、半分冗談で半分本当です。
そこで、「なにもしない」を使うことで、このような悩みを解決していきます。
お悩みその1の解決策:アクショングラフで条件分岐を見やすくする
例えば、このようなアプリがあるとします。
ドロップダウンの値が『計算する』の場合にボタンを押すと、数値Aと数値Bの足し算結果を計算結果フィールドに書き込みたいとします。(自動計算でやれっていうのはなしで)
ボタンを押すとドロップダウンの値を確認し、フィールドに値をセットするという流れが1つのアクションで完結しています。
これは、カスタマインらしさが全面に出たシンプルな作りです。
ただし、このようにマイルールに沿って「なにもしない」をカスタマイズに組み込むと、条件分岐が増えてカスタマイズ画面は複雑化しますが、、
今回のポイントは、「条件分岐をアクショングラフで見やすくする」ということです。
カスタマイズ画面のシンプルさを犠牲にしてでも、「アクショングラフの流れが見やすいこと」に全振りしてます。
処理が複雑になればなるほど、カスタマイズを理解するうえで頼りになるのは結局アクショングラフなんです。(個人の感想)
いやいや、条件分岐を見やすくするだけなら、「なにもしない」を使う必要ないやろ!っていう突込みがありそうですが、それはお悩み2、3を踏まえてのことです。
お悩みその2の解決策:アクションの構造はそのままで、画面上にて処理状況を確認する
見出しの日本語が下手すぎて消えたくなるのですが、、、
カスタマインの処理がどこまで進んでいるか、皆さんはどのように確認していますか?
ブラウザのデベロッパーツールを使いこなせる方は良いのですが、私は以下のような方法をよく使っています:
- 「情報ダイアログを表示する」でメッセージを表示して確認
- 「レコードの一覧をポップアップで表示する」で取得したレコードが想定通りか確認
マイルール適用後のカスタマイズでは、「なにもしない」を一時的に「情報ダイアログを表示する」に置き換えることで、アクションを崩さずに確認用メッセージを出せます。
例えば、先ほどの条件分岐部分、アクション14の「なにもしない」を
すると、条件が「計算する」に該当したタイミングで画面上にメッセージが出力され、処理が意図通り進んでいることやフィールドの値が正しく取得できていることを確認できます。
確認が終われば、再度「なにもしない」に戻せば良いだけ、という点もポイントです!
単純な例ではあまりメリットを感じないかもしれませんが、条件分岐が複雑に絡む場合、現在の処理状況や扱っている値を確認できると、不具合の切り分けが容易になり、とても便利です!
お悩みその3の解決策:「なにもしない」を入れておけば、アクションの追加が簡単に
例えば、「なにもしない」を使っていないカスタマイズでボタンを押した際にメッセージを表示したい場合を考えます。
メッセージを入れる前の状態。
通常の手順では、次のような作業が必要になります:
- アクション2を複製
- アクション2を「情報ダイアログを表示する」に変更
- 複製したアクション15の条件を「他のアクションの実行が完了した時」に変更
- アクション15の条件パラメータを2に変更
- アクション15の「フィールド値が特定の値ならば」という条件を削除
- アクション3の条件パラメータを15に変更
このように作業が簡略化されます:
- アクション5と13の間に「情報ダイアログを表示する」を挿入
- 挿入したアクション16の条件を「他のアクションの実行が完了した時」に変更
- アクション16の条件パラメータを5に変更
- 後続のアクション13、14の条件パラメータを16に変更
手順が減り、追加したアクション以外の修正は条件のパラメータだけで済みます。
これにより、処理を後から追加しやすくなるので、条件分岐など大枠の構造を先に作り、枝葉部分を後から埋めるという作り方が可能になります。
まとめ
これらの悩みを「なにもしない」を活用して解決する方法をご紹介しましたが、いかがでしたでしょうか?
ある程度複雑なカスタマイズになりそうな場合は、ぜひ試してみてください。
ただし、そもそもカスタマインらしくない複雑なアクションを組まないのが一番です。
ちなみに、例外もあります。それが、テーブルの行を特定して処理を行う場合です。
テーブルの行を特定するような条件と組み合わせることで、特定の行だけフィールドの値をセットするなどのことができるのですが、この場合はやることと行を特定する条件を組み合わせることになります!
(参考:サポートページリンク)
余談
カスタマイズを画像で書き出すと、情報ダイアログのメッセージは空欄になるんですね!
以上です!