開発速度を上げ、反感を買う ローコード開発の光と影に以下のような記述がありました。
米アイオワ州ジョンストンを拠点とする農業科学企業DuPont Pioneerでは、同社の社内モバイルアプリの約90%をシチズンデベロッパーが開発している。
ここでいうシチズンデベロッパーとは、
技術者だけでなく、IT部門以外に所属する開発経験がほとんどないような人々
ということなので、IT部門以外でIT技術者でない人、また開発経験がほとんど無い人々なのでIT部門でも自分で開発しない人は含まれるのではないでしょうか。
この開発をOutSystemsでやっているということなので、実際に開発経験がほとんど無い人がOutSystemsでモバイルアプリケーション開発をすると、どんな感じになるのか考えてみました。
以下、全くOutSystemsを知らない人がわかることを目的として書いていきます。わからないことがあったら、是非コメント等で教えてください。
前提条件
環境は以下の通り。
Service Studio:11.0.204.114(Beta)
Platform(Personal Environment):11.0.118.0
また、OutSystemsの環境のセットアップ、必要な部品のインストール、モバイルアプリケーションビルドのための設定は専門家によって行われているとします。
開発する人の想定スキルは、Officeやブラウザは問題なく使える、本を見ながらコピー・アンド・ペーストでいいから数行程度のVBAくらい書ける、程度。
作成するアプリケーション
上の記事の最後あたりに、ネットワークが通じない場所で検査するために、オフラインでフォームに情報を入力する例が出てきます。これに合わせて、以下の条件で作っていきます。
- 利用者は、作成者が所属する部門のごく限られた人数
- 検査対象の名前(Text型、Name)、検査日(Date型、SurveyDate)、検査完了(Boolean型、IsSurveyFinished)、検査結果(Integer型、SurveyResult)を入力するフォーム1画面を持つ
- 作りを簡単にするため、入力したデータを確認する画面はなし
- フォームにはオフラインで入力する。入力結果はモバイル端末内のLocalDBに持つ
入力すると端末内のデータベースに蓄積されます。
アプリケーションとモジュールを作成
モバイルアプリケーションはモジュールという単位として作成します。
このモジュールはアプリケーションに格納します。
よってまずはアプリケーションを作成します。
Service StudioでNew Application、Mobile Appと選択して、NEXTボタンをクリック。
次の画面でどのテンプレートで作るか選択肢がでてきます。ここではスマートフォンで動作することを考えて、Phoneを選択して、NEXTボタンをクリック。
名前を入力してCREATE APPボタンをクリック(説明は入力した方がいいですね。色合いやアイコンはごく少人数で使うことを想定してそのままにします)。
モジュール名はアプリケーション名のままにして、Module TypeはMobileであることを確認してから、CREATE MODULEボタンをクリック。
Entityを用意
OutSystemsではDBのテーブルに相当する要素をEntityと呼びます。
今回は、ごく限られた人数が身内だけで利用することを想定しているので、モバイルのモジュール中にEntityを定義していきます。
まずはサーバ側Entity、後でWebアプリケーションで閲覧するのに使うEntityを定義します。
Dataタブを開き、Entities>Databaseを右クリックしてAdd Entity。
作成されたEntityの名前を「Survey」に変更し、Surveyを右クリックしてAdd Entity Attributeで属性を追加していきます。「作成するアプリケーション」に書いた4つと、検査担当者(Text型、SurveyUserName)を追加しました。
後で別のモジュール(閲覧用Webアプリケーション)から参照するため、PublicプロパティをYesにしておきます。
LocalDBにも同じEntityを定義します。
今回は、すでにサーバ側にEntityがあるので、ここからコピーして作成です。
Dataタブを開き、Entities>Local Storageを右クリック。Add Entity from Databaseを選択。
EntityはSurveyを選択し、Attributeはサーバ同期時に追加する予定のSurveyUserName以外を選択してADDボタンをクリック。。
不要なデータはデータ容量、同期時の通信容量を食うので必要最小限をLocalDB荷物ことが推奨されています。
LocalDBに作成されたEntity(Localのプレフィックスがつきます)。
このEntityは実行時にユーザの端末内のsqlite DBにテーブルとして保持されます。
スクリーン作成
OutSystemsには、Screen Templateと言う仕組みがあります。
画面作成時に、画面のテンプレートとして利用できるもので、これをベースに画面を作成すると、サンプルデータを使って組み上がった状態になります。
利用できるScreen Templateがある場合は、サンプルデータを実際に使用するデータに紐付け直して微調整することですぐに完成度の高い画面が作れます。
どんな感じのテンプレートがあるかはここで確認できます。
https://www.outsystems.com/outsystems-ui/screens/mobile
また、つい最近このScreen Templateを自作する機能がリリースされたので、企業の要件に合わせたテンプレートを事前に作成しておくことで、Low-Codeの生産性を享受できる範囲が拡大できるかもしれません。
とは言え、今回は単純な入力フォームを作るので、あえてScreen Templateを使いません。
InterfaceタブのUI Flows>MainFlowを右クリックして、Add Screenを選択し、テンプレートはEmptyとしてCREATE SCREENボタンをクリック。
ドラッグ&ドロップで入力フォームを作成
フォームを作成したいので、できあがった画面にForm Widgetをドラッグ&ドロップします(下の画像の左の赤枠内のウィジェット)。
そして画面上にドロップしたForm ウィジェットの上に、作成しておいたLocalDB>LocalSurvey(Dataタブ)をドラッグ&ドロップ(右の赤枠の位置でドロップしてください)。
この時点で、
- パラメータとして、LocalSurveyのId(レコードを特定する値)を受取る(入力変数:LocalSurveyId)
- パラメータでLocalDBを検索する(Entity:GetLocalSurveyById)
- 検索した1レコードを表示する
- パラメータが渡されなかった場合は、値は空で表示する
という画面ができています。
入力したデータをローカルのデータに格納する処理を書きましょう。
Saveボタンをクリックしたら入力内容を変数に格納してLocalSurveyに1データ追加(既存データの場合は更新。今回のUIでは想定しませんが)する処理を書きます。
できあがったフォームのSaveボタンを選択してください(画像左の赤枠)。
すると画面右下にSaveボタンの設定が表示されるので、その中のOn Click(ボタンクリックしたときの動作を紐付ける設定です)の右側にある下向き三角形(▼)をクリック。
その中で、(New Client Action)を選択します。これで保存処理の枠ができます。
Client Actionというのは、端末内で動作するひとかたまりの処理を定義するものです。
実行時にJavaScriptに変換されて動作します。
入力内容を更新し、次の登録のために、画面を再び空にする処理です。
画面内のアイコンは対応するものを、画面左側からドラッグ&ドロップしてください。
上から順に説明します。
- Form1.Valid?:この部分は作成時に自動的に配置されるので作成不要です。入力内容が正しいかを判定(型があっているか、必須入力を満たしているかなど)
- CreateOrUpdateLocalSurvey:LocalSurvey Entityに1レコード登録。ただし、パラメータで受け取ったIdがある場合、対応するレコードに対する更新となります
- LocalSurveyId:パラメータ(LocalSurveyId)をNullIdentifier()に設定
- Refresh……:Entityを再取得する。3でNullIdentifierを設定するため、空のレコードが返ってきます
これだけでもう入力フォームができあがりです。
Chromeが入っていれば、動作確認が可能です。
1-Click Publish(画面上部の緑のアイコン)をクリックしてサーバに変更を反映し、アイコンが青に変わったらもう1回クリックするとPC上のブラウザでプレビューできます。
入力したデータを確認するUIを作っていませんが、ブラウザプレビュー中には、Chromeの機能で確認できます。
F12キーを押してデベロッパー ツールを起動し、Applicationタブ>Storage>Web SQLの下にEntityを見るためのUIがあります。
UI Patternからウィジェットを追加
作成したフォームの内、検査結果はInteger型(整数)であるにもかかわらず、直接入力のテキストボックスになっています。
これをもう少し項目が整数であることがわかりやすい部品に置き換えてみます。
UI部品を探すときは、まずはService Studio左側に表示されるウィジェットを見ますが、その次はUIフレームワークです。
OutSystems 11ではOutSystems UIです。
https://www.outsystems.com/outsystems-ui/patterns/mobile
ページを見渡して、要件を満たすUIを探してみます。
RangeSliderと言う部品がありました。数値をスライダーを使って入力できます。
https://www.outsystems.com/outsystems-ui/patterns/mobile/RangeSlider
まずは、参照を確認しましょう。
Service Studio上でCtrl+QでManage Dependenciesダイアログを開き、OutSystemsUIMobileのInteraction>RangeSliderのチェックを確認します。
もしチェックがなかったらチェックしてOKボタンをクリック。
整数型のSurveyResult変数を紐付けてあったInputを削除し、代わりにRangeSliderをドラッグ&ドロップして配置します。
RangeSliderはInterfaceタブのUI Flows>OutSystemsUIMobile>Interactionsにあります。
UIフレームワークの使い方は上記ページのHow to Useにあります。
Bind your variable to the InitialValue input and use the OnChange event to add your logic to handle value changes.
残念ながら英語です。
- 変数をInitialValueプロパティに紐付ける
- OnChangeイベントハンドラを作成して、紐付けた値を変化させる
ですね。
OnChangeイベントハンドラはドロップしたウィジェットのEvents>Handlerプロパティの(New Client Action)で作ります。
こんな感じになります。
- スライダーは0-10の範囲で変化する。
- 紐付ける変数は元々あったInputの時と同じくEntityの整数型の属性。
- OnChangeのハンドラは以下の通り(入力変数Value:Changeイベント発生時のスライダー上のつまみの位置の値、をフォームの変数に設定している)
所感
あまりにも長くなりすぎたので、証跡の画像を端末のカメラで撮影する部分と、入力結果をOutSystemsサーバに吸い上げ、Web画面で一覧する部分は後日別の記事に譲ることにしました。
長い手順に見えるかもしれませんが、手順書用意するか、一度慣れてしまえば簡単に何度でもできるようになるのではないでしょうか。
ただ、残念ながら、UIフレームワークの説明が薄すぎ、英語のみはきついですね。
OutSystemsの専門家チームがいたら、そのチームがウィジェットの使い方を調べてマニュアル化したらいいかもしれませんね。
もし使い方がわからないウィジェットがOutSystems UIのパターンにあったらコメントで質問ください。
70ほどもあるので即答はできないと思いますが、なるべく調べて回答してみます。