#はじめに
「UNOFFICAL SF」というサイトをお存じでしょうか。
海外有志による非公式のSalesforceコンテンツが公開されているサイトです。
こちらのサイトにはフローで使えるAuraコンポーネントや
LightningWebコンポーネントがパッケージングされて多数公開されています。
しかも無料!
トップページに掲載されている通りあくまで非公式なので、
トラブルが起きた際のリスクは背負わなければなりませんが、
無料でフローの機能を拡張できるのはかなり大きいです。
さらに非管理パッケージなので、コーディングに自信があれば
カスタマイズ可能なのも魅力的。
今回は公開されているパッケージが数多ある中でいくつか触ってみたうち、
個人的に最もおススメだと感じた、
**「Signature Capture」**というパッケージと、
このパッケージを使ったアレンジ例を紹介したいと思います。
UNOFFICAL SFへはこちら:https://unoffialsf.com/
#「Signature Capture」というパッケージを試してみた
##どんなパッケージ?
パッケージを導入し、フローを作成するだけで署名機能がすぐ使えます!
画面はこんな感じ↓
タイトルを入力して保存するとその署名画像をレコードに紐づけることが可能です。
しかも、タッチ操作にも対応しています。
#使い方
##1 導入手順
- トップページの「EXTEND FLOW」から「Screen Components」をクリックします。
![q1.png](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.ap-northeast-1.amazonaws.com%2F0%2F218192%2Fd5449972-fd38-2d43-619c-80a47c8b1399.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=67f75c9dd48d748f406222bbde07c576)
2.「Signature Capture」をクリックします。
するとSalesforce環境へパッケージをインストールする画面が開きますので、
インストールの方法を選択してインストールを実行してください。
「インストール完了!」と表示されればフロー内で使用できるようになります。
#2 署名画面フロー作成手順
-
フロー設定画面まで移動したら「新規フロー」ボタンをクリックします。
-
画面フローを選択して「作成」ボタンをクリックします。
![q4.png](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.ap-northeast-1.amazonaws.com%2F0%2F218192%2F1fb4cd7e-2977-5ff1-b949-36b7a41f13ec.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=890b1ad3e02ce6e98a6079b421cde15c)
-
画面左部の画面コンポーネント一覧から
カスタム「SignatureCaptureCMP」をクリックします。 -
画面右側で「SignatureCaptureCMP」の設定を行います。
![q6.png](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.ap-northeast-1.amazonaws.com%2F0%2F218192%2F70e38471-97ad-6b4d-cda1-9aee3331e015.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=3ceb2275f54444d9797954b611f3b209)
-
次にヘッダー部をクリックし、その画面の表示ラベルとAPI参照名を設定して「完了」ボタンをクリックします。
-
開始アイコンの〇から矢印が伸びるようになるので「画面」へドラッグ&ドロップします。
-
画面右上の「保存」ボタンをクリックします。
フロー自体の表示ラベル名とAPI参照名を入力した後、
さらに「保存」ボタンをクリックします。 -
警告がでますが、確認した限り動作に支障はありませんでしたので、
無視して「有効」ボタンをクリックします。
![q9.png](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.ap-northeast-1.amazonaws.com%2F0%2F218192%2F83d111ed-710f-2e2d-3f36-107686c10a1c.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=f709ff5c8ed948d6c4e643fa653d5b44)
#3 試してみる
-
レコード詳細画面に表示させるにはこのフローを呼び出す
アクションを作成し、レイアウトに配置します。
※今回は取引先で試してみます。ファイルに添付されるのであらかじめ
「メモ&添付ファイル」関連リストを出しておきましょう。 -
署名を記入してみます。
「Save as...」 にはファイルのタイトルを設定できます。
![q12.png](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.ap-northeast-1.amazonaws.com%2F0%2F218192%2Fa2a38a7e-033b-5268-367b-dc1e483ebaeb.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=57ddff3adaa6b606e41d401392355d88)
- 「Update and Save」ボタンをクリックします。
「Upload Successful!」と表示されたら成功です。「完了」ボタンをクリックして画面に戻ってみましょう。
![q13.png](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.ap-northeast-1.amazonaws.com%2F0%2F218192%2F58f11a38-2f39-dbf9-da9c-eadeed969473.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=0012d6ce251c73cdca030aab30016b3e)
- 「メモ&添付ファイル」関連リストに先ほど入力した署名画像が.png形式で保存されています。
![q14.png](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.ap-northeast-1.amazonaws.com%2F0%2F218192%2F515c74d5-da39-86ae-31c8-bee0bd34ad39.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=a5103d03ab0d60fe9def5bad33ab1a40)
- 背景が透過されているので見づらいですが、確かに先ほど入力した内容が保存されています。
![q15.png](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.ap-northeast-1.amazonaws.com%2F0%2F218192%2F03b6cee8-d535-936a-efca-dae4133daf7a.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=8ea701e86cdbad6aad5f7d601dfb42bf)
#4 アレンジしてみた
先ほどのフローをアレンジして、この署名画像をレコード詳細画面に直接表示させてみました。
こんな感じ↓
-
カスタム項目を2つ作成します。
① ファイルのIDを保存する用のテキスト項目を作成します。
② 画像を表示させる用の数式項目を作成します。
IMAGE関数を使って画像を表示させましょう。
関数の第1引数は以下とします。
"/sfc/servlet.shepherd/version/download/" + Signature__c
第2引数には署名画像がまだない場合に備えて
**"署名はありません"**とします。
第3、第4引数には表示されるサイズを設定できます。
③ 作成したら、数式項目だけレイアウトに配置します。 -
先ほどのフローを改修します。
① **「画面」をクリックし、画面内「SignatureCaptureCMP」を
クリックします。
② 画面右側、「SignatureCaptureCMP」の設定でスクロールダウンします。
すると"選択した変数に出力値を保存"**というセクションがあるので
「ContentDocument Id」入力欄をクリックし、「+新規リソース」を
選択します。
③テキスト型の変数を作成します。
API参照名はお好きな名称を設定してください。
また、この変数はフロー外部で使用しないので"フロー外部の可用性"に
チェックせず完了します。
④ContentDocument Idに変数がセットされたら
「完了」ボタンをクリックします。
★このContentDocument Idに設定した変数に署名画像のIDが出力されます。
※設定参考イメージ
![mudai.png](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.ap-northeast-1.amazonaws.com%2F0%2F218192%2F317e12ae-02aa-de7f-9485-3bd68e10524c.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=c8aff09b1ce45f055b950a5534b8a1b5)
⑤「レコードを取得」を右画面にドラッグ&ドロップします。
表示ラベルとAPI参照名を設定し、
オブジェクトや絞込条件は以下のキャプチャのようにします。
さらに、レコードデータの保存方法を
「項目を選択して後はSalesforceに任せる」を選択します。
変数に保存するコンテンツバージョン項目は「ID」となっていることを
確認したら「完了」ボタンをクリックします。
⑥レコードを更新をドラッグ&ドロップします。
表示ラベルとAPI参照名を設定し、
「レコードを識別する条件を指定し、項目を個別に設定」を選択します。
残りは以下のキャプチャのように設定し、「完了」ボタンをクリックします。
⑦画面→レコードを取得→レコードを更新と矢印が伸びるよう
ドラッグ&ドロップします。
⑧最後に「別名で保存」ボタンをクリック ⇒
「保存」ボタンをクリックして完成です。
忘れずに「有効化」しましょう。
##5 動作確認
①改修直後なので、まだ署名画像は表示されていません。
②署名を書き、保存します。
※保存したあと「次へ」ボタンを押すことが必要です。
##あとがき
いかがだったでしょうか。
通常、署名画面の開発にはそこそこ手間がかかりますが、
このパッケージを使えば簡単に署名画面を利用することが可能です。
また、冒頭でも述べたように、非管理パッケージとして公開されています。
このパッケージはAuraコンポーネントで構成されていますので、
中身を編集することで署名記入欄のサイズやボタンの名称も変更可能です。
他にも有用なパッケージがたくさんあるので、いろいろ試してみたいと思います。