0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

フロー内で作成したレコードのIdを使って子レコードも紐づけてコピーする

Posted at

結論

画面フローだけで「親子レコードの複製」を実現する最短手順は、

  1. 割当 で元レコードを丸ごとコピー & Id を Null 化
  2. レコードの作成要素 の“レコード変数から”で 作成
  3. 返ってきた CloneContact.Id を子レコードの 上司Id に流し込む
    これにより、新フィールドが追加されてもフロー改修ゼロが実現。子レコードはループ+レコードコレクション変数で一括作成すれば OK。
    コードも拡張パッケージも不要で、組織フィールドが増えても自動追従するため、保守コストを最小化できる。

背景

「どの取引先責任者をコピーしますか?」と聞かれ、1人の取引先責任者Aを選択。
「取引先責任者Aには取引先責任者a1、a2、a3が紐づいています。併せてコピーしますか?」
と聞かれ、「はい」を選ぶと、コピー開始。A’及びA’に紐づいたa1’a2’a3’というレコードが作成。

という画面フローを実現したいというご相談がありました。
恐らく通常はコードを書いている優秀な方なのかと思いますが、フロー内で作成したレコードのIdを取得することに困っていたようです。
この手順は確かに分かりづらいので、良い記事があれば教えて差し上げたいと探してみましたが、なかなか見当たりません。
何故だろうか?と考えたところ、確かに私もメンバーに対して説明するときには口頭だと伝わらないので毎回webMTGしていたことに気が付きました。
そこでパッケージを用意し、ご自身で触っていただくのがよいかと考えてこの記事とパッケージを作成しました。
↓未管理パッケージURL
https://login.salesforce.com/packaging/installPackage.apexp?p0=04tWU0000008COz

構築内容

image.png
image.png
image.png
image.png
image.png

フロー全景

image.png

事前準備

使用するオブジェクトと項目

  • 取引先
    • Id
  • 取引先責任者
    • Id
    • 氏名
    • 上司Id
    • 説明

標準項目だけにしています。
また、項目が増えてもキーにする項目が変わらなければメンテナンス不要にすることを目指しています。

フローで最初に作成しておく変数

  • レコード単一変数
    • recordId
      • レコード型(Account)
    • var_CloneContact
      • レコード型(Contact)
    • var_CloneChildContact
      • レコード型(Contact)
  • レコードコレクション変数
    • vars_CloneChildContacts
      • レコード型(Contact)

フロー内容解説

  1. get_OriginContats

    1. image.png
    2. 取引先のレコードページのIdから現在存在する取引先責任者を取得しています。
  2. sc01

    1. image.png
    2. この画面でコピーする取引先責任者を選択します
  3. set_CloneContact

    1. image.png
    2. ここが一番重要です。レコード変数var_CloneContactに画面で選択したレコードの情報を割り当てます。この際にレコード変数の各項目選択に進みたくなるUIではありますが、これを無視して別の領域をクリックしてください。※次の画像まで変数を設定したら別領域をクリック。これにより画面で選択したコピー元レコードの値すべてが変数に割当たります。
    3. image.png
    4. image.png
    5. 次の行で変数の取引先責任者Idを空にします。また、今回はテスト用のため、説明項目にはクローンであると明記させています。実際の構築では適宜修正してください。image.png
  4. create_CloneContact

    1. 変数を基にレコードを作成します。image.png
  5. sc02

    1. レコード作成後の変数内容を確認する画面です。ここでレコード変数にIdが入っていれば、レコードが作成され、レコードIdが変数に割り当てられたことが確認できます。構築でのわかりやすさの為に作っていますが、実運用では不要だと思います。image.png
  6. get_OriginChildContacts

    1. コピー元となった取引先責任者の子レコードを取得します。今回のシナリオでは部下も含めてコピーする、と仮定し、上司項目の値がコピー元のレコードIdと一致することにしました。image.png
  7. sc03

    1. 取得した部下の取引先責任者一覧の取引先責任者達を画面に表示します。この画面も実際の運用では不要ですが処理状況の確認の為に入れています。image.png
  8. loop_originChildContacts

    1. 取得した部下の取引先責任者一覧でループを開始します。image.png
  9. set_CloneChildContact

    1. 先と同様にレコード変数の項目までは進まずに、変数に対して現在ループ中の取引先責任者情報を割り当てます。
    2. 変わる部分は上司Idの部分です。ここではcreate_CloneContactで作成する際に使用した変数の値を用います。image.png
  10. add_CloneChildContacts

    1. レコード変数をレコードコレクション変数に追加します。image.png
  11. create_CloneChildContacts

    1. レコードコレクション変数の内容で作成します。image.png
  12. sc04

    1. 作成確認画面です。ここも実運用では不要ですので、動作確認が出来た後は削除いただいて構いません。image.png

別案

極力作らないことを正しいと考えています。
優秀なAppExchangeがあるので通常はこちらを推奨します。
https://appexchange.salesforce.com/appxListingDetail?listingId=a0N3A00000G12chUAB

まとめ

  1. 割当要素 の項目指定無しでの「=」演算子は“全フィールドコピー”を意味する。ここで Id = Null を忘れない。
  2. レコードの作成要素 で「レコード変数からすべての値を取得」を選ぶと、ReadOnly フィールドを自動除外して Insert。
  3. レコードの作成 後は同じレコード変数に 新しい Id が返る。この Id を子レコードの外部参照に流用できる。
  4. 子レコードは Loop → 1 件ずつ 割当 → コレクションに追加 → 一括 レコードさくせ が最もシンプル。
  5. フィールド追加やレイアウト変更があっても、フロー側はメンテ不要。大規模オブジェクトでも安全に運用できる。

※あくまで構築のヒントの為のサンプルです。自己責任でお願いします。

0
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?