クライアントスクリプト:OnLoadスクリプトのためのワンタイム自動更新でレコード詳細ページを更新する方法

クライアントスクリプト:OnLoadスクリプトのためのワンタイム自動更新でレコード詳細ページを更新する方法

お知らせ:当社は、お客様により充実したサポート情報を迅速に提供するため、本ページのコンテンツは機械翻訳を用いて日本語に翻訳しています。正確かつ最新のサポート情報をご覧いただくには、本内容の英語版を参照してください。

Requirement 概要

Zoho CRM ユーザーが、Client Scriptを利用して詳細ページ上のデータを更新しています。しかし、従来の方法では、詳細ページで項目やサブフォームを更新する際に課題が生じることがよくあります。たとえば、営業担当者がリードデータを詳細ページで更新すると、Client Scriptが発動し、関連項目(例:ステータス、担当者、カスタムスコア項目など)を修正します。ただし、更新後の値はすぐに詳細ページに反映されません。 これにより混乱や意思決定の遅れが発生することがあります。

現在の課題

詳細ページでのデータ更新 - 現時点では、Client Script 機能で setValues() Client メソッドを利用した詳細表示ページでの項目更新には対応していません。同様に、サブフォームを更新する insetRows() Client メソッドにも対応していません。

現在、上記の Client メソッドは作成・編集・複製ページなど他のページで対応しています。詳細表示ページでは、ユーザーがクライアントスクリプト内で Web API メソッド(CRM API など)を利用できます。

データ詳細ページでの更新反映の仕組み- 現在、詳細表示ページで行った更新内容は即時に反映されません。変更を表示するにはページを更新する必要があります。この課題を解決するために、navigateTo() Client メソッドをスクリプト内で利用し、現在のデータ詳細ページへ自動遷移させることができます。

OnLoad スクリプトによる自動更新ループの稀なシナリオ- ユーザーが OnLoad ページイベントに基づいて詳細ページに Client Script を設定し、変更を自動的に反映させたい場合があります。しかし、この場合、ページの自動更新ループが発生することがあります。

権限 & 利用可能範囲

Info
-> 管理 Extensibility権限を持つユーザーは、Client Script の設定および管理が可能です。
-> 管理 テスト環境権限を持つユーザーは、テスト環境の管理が可能です。
  1. Client Script の様々な場所でのデプロイ

例えば

-> ページの On_Load/On_Save/On_Edit、項目の On_Type/On_Change、サブフォーム処理、Blueprint 処理、リスト表示処理 など。
-> コマンド/ショートカットキー(CRM 内のどこからでも、いつでもスクリプトをトリガー可能)。
-> カスタムボタン (最近の強化)

Notes詳細については以下のヘルプ 参照をご覧ください。対象: Client Script 処理 詳細.
  1. Client Script の作成手順:

Client Script の追加方法は2通りあります:

1. 設定ページから追加する場合:

Zoho CRM の設定 (⚙️) >> Developer Hub >> Client Script >> 新規 Script へ進みます。



-> スクリプトに適した名前説明を入力します
-> カテゴリー 詳細-
  1. 要件に応じて カテゴリーを選択します。タブ - 処理でトリガーされます || Commands- Command Palletやショートカットキーでトリガーされます。
  2. スクリプトを追加したいタブを選択します。例:Lead、連絡先など。
  3. 特定のページにスクリプトを適用するためのPageを選択します。例:作成、編集、複製する、詳細、Listなど。
  4. Layoutを選択します。例:スタンダードまたはカスタムレイアウト。

-> Event 詳細-
処理の種類を選択します - 項目 Event または Page Event または Subform Event
  1.       項目 Event-> 項目とEventを選択します(例:名 項目のonChange)。
  2.       Page Event-> PageとEventを選択します(例:作成 PageのonLoad)。
  3.       Subform Event-> SubformとEventを選択します(例:onCellChange)。




2. 詳細/List/作成/編集/複製するページを利用したデータ操作

-> Zoho CRMで目的のタブを選択し、そのタブ内の任意のデータでList、作成、詳細、編集、複製するページのいずれかを開きます。として、作成 Lead ページを参照してください。
-> ページ(作成/編集/複製する など)の場合は、ページ最右端にある Client Script をクリックし、スクリプトを追加してください。
-> カテゴリー 詳細はシステムによって自動入力されます。クライアントスクリプトのその他の詳細(名前、説明、Event 詳細など)を入力してください。その後、「次へ」をクリックし、Client Script IDEのコードエディターにスクリプトを追加します。最後に、「保存」と「閉じる」をクリックします。

詳細ページからClient Scriptを追加する方法:



リスト/作成/編集/複製ページなどからClient Scriptを追加する方法:


使用する-case

A銀行のローン担当者が、Zoho CRM内の詳細表示ページでLeadデータを開きます。選択されたLoan種類に基づいて、システムはLoanステータス項目を「In確認する」に自動入力します。これらすべての処理は、手動で保存やページの更新を行う必要なく完了します。

設定

次に、Leadタブ詳細ページに対してOnLoad of PageトリガーでClient Scriptを作成します。例として、データ詳細ページが読み込まれるたびに、クライアントスクリプトが実行され、データを更新する操作を行います。


Loan種類とLoanステータスの2つのピッキングリスト項目を追加します。また、詳細ページで自動更新のループを防ぐために、カスタムチェックボックス項目(例:名前 - ForDetailPage_stop_automatic_reload)を追加します。



Notes
メモ: 現在、Client Scriptを通じて詳細ページに加えた更新はすぐには反映されません。変更内容をデータに適用するには、ユーザーがページを更新する必要があります。

上記の制限により、同じClient Scriptを使用してデータ詳細ページを自動的に更新するようにします。ユーザーがデータ詳細ページを開くたびに、スクリプトがデータを更新し、自動的に更新を行います。ただし、再読み込みは1回だけで停止させる必要があります。そのため、もう1つのチェックボックス項目を使って更新を停止します。
Info
ユーザーにカスタム項目を表示したくない場合は、項目詳細を編集し、すべての権限で非表示(表示しない)に設定できます。

コード

  1. var 種類 = ZDK.Page.getField('Loan_Type').getValue(); //Loan 種類 項目の値を取得
  2. log(種類);

  3.  //現在のデータを取得
  4. var recDetail = ZDK.Apps.CRM.見込み客.fetchById($Page.record_id);

  5. //確認中:種類項目が「Personal Loan」と等しいかどうか確認。該当する場合は、Loan ステータス項目を「In 確認する」に更新
  6. if (種類 == 'Personal Loan') {

  7.     //データ内の国およびチェックボックス項目を更新
  8. recDetail.Loan_Status = 'In 確認する';
  9. recDetail.ForDetailPage_stop_automatic_reload = 真;
  10. var recUpdate = recDetail.__update();
  11. // log('recUpdate', recUpdate);
  12.     
  13.  //チェックボックス項目を取得
  14. var stopField = ZDK.Page.getField('ForDetailPage_stop_automatic_reload');
  15. var stopFieldVal = stopField.getValue();
  16. log('項目値 - ' + stopFieldVal);

  17. //チェックボックス項目が無効の場合のみ、入力を行います。有効であれば、スキップします。
  18. if (stopFieldVal == 無効) {

  19.   //詳細ページを自動的に更新します。次の1時間後に更新されます。.
  20. log('entered');
  21. ZDK.Client.navigateTo('record_detail', { タブ: '見込み客', record_id: $Page.record_id });
  22. }
  23. }

動作デモ - スクリーンキャスト




TIPS(ヒント)

-> スクリプト内で 正しい API名を両方 タブ & 項目で使用するようにしてください。

-> スクリプト作成時には、各変数に logs() または console.log()を追加して出力を確認し、スムーズな動作を確保することを推奨します。例えば、出力を 'Messages'タブ(Client Script IDE 内)で各 logs() の出力として表示できます。consoleのログを表示するには、次の手順で確認できます - ブラウザページ上で右クリック >> 検証 >> Console

-> 期待した機能が動作しない場合は、各出力やループを確認しながらスクリプトを検証し、さらに各 ZDK Client/CRM APIメソッドの構文をサンプルヘルプドキュメントでクロス認証してください。

-> スクリプト内に同じ内容の記述(例:同じ小さな関数)が繰り返しある場合 Static Resourcesを使用することができます。

Info各ZDK クライアント/CRM API メソッドのサンプルスクリプト- ヘルプ 参照

Alert
円滑な導入のため、設定をテスト環境で構成・検証してから本番環境へ展開することを推奨します。



ご不明な点がございましたら、どうぞご遠慮なくパートナー-サポート@zohocorp.comまでご連絡ください。

Notes
また、ヨーロッパおよびイギリスのパートナーの皆様はパートナー-サポート@eu.zohocorp.comまでご連絡いただきますようお願いいたします。


    Zoho CRM 管理者向けトレーニング

    「導入したばかりで基本操作や設定に不安がある」、「短期間で集中的に運用開始できる状態にしたい」、「運用を開始しているが再度学び直したい」 といった課題を抱えられているユーザーさまに向けた少人数制のオンライントレーニングです。

    日々の営業活動を効率的に管理し、導入効果を高めるための方法を学びましょう。

    Zoho CRM Training



              Zoho Campaigns Resources

                Zoho WorkDrive Resources




                  • Desk Community Learning Series


                  • Digest


                  • Functions


                  • Meetups


                  • Kbase


                  • Resources


                  • Glossary


                  • Desk Marketplace


                  • MVP Corner


                  • Word of the Day


                  • Ask the Experts









                                  • Related Articles

                                  • クライアントスクリプト:Zoho CRMで重要データを削除する前の確認プロンプト

                                    お知らせ:当社は、お客様により充実したサポート情報を迅速に提供するため、本ページのコンテンツは機械翻訳を用いて日本語に翻訳しています。正確かつ最新のサポート情報をご覧いただくには、本内容の英語版を参照してください。 Requirement 概要 Zoho CRM ユーザーは、機密性が高く重要な項目のデータを消去する前に、ダブル確認を行うための確認注意を求めています。 使用例 銀行が、Zoho ...
                                  • クライアントスクリプト:Zoho CRMにおけるリード変換前のデータ検証を効果的に処理する方法

                                    お知らせ:当社は、お客様により充実したサポート情報を迅速に提供するため、本ページのコンテンツは機械翻訳を用いて日本語に翻訳しています。正確かつ最新のサポート情報をご覧いただくには、本内容の英語版を参照してください。 Requirement 概要 Zoho CRM ...
                                  • Zoho CRMサブフォームでクライアントスクリプトを使用して商品リスト価格を自動入力する方法

                                    お知らせ:当社は、お客様により充実したサポート情報を迅速に提供するため、本ページのコンテンツは機械翻訳を用いて日本語に翻訳しています。正確かつ最新のサポート情報をご覧いただくには、本内容の英語版を参照してください。 Requirement 概要 顧客は、同じタブに保存されている選択済み価格Book(Lookup項目)に基づき、カスタムタブ(例:Pre-注文)のサブフォーム内の商品リスト価格を自動的に更新・表示したいと考えています。この処理は、サブフォームで商品を選択した際に実行されます。 権限 ...
                                  • クライアントスクリプト:Zoho CRMのブループリント遷移中にサブフォームのバリデーションを強制する

                                    お知らせ:当社は、お客様により充実したサポート情報を迅速に提供するため、本ページのコンテンツは機械翻訳を用いて日本語に翻訳しています。正確かつ最新のサポート情報をご覧いただくには、本内容の英語版を参照してください。 Requirement 概要 Zoho CRM では、商談データがBlueprintに含まれている場合、ユーザーはサブフォームに追加されたエントリーを認証し、Blueprintの遷移で完了済みにする前に確認する必要があります。 権限 & 利用可能範囲 -> 管理 ...
                                  • クライアントスクリプトを使用してZoho CRMでフライアウトモードのカスタムウィジェットを起動および同期する

                                    お知らせ:当社は、お客様により充実したサポート情報を迅速に提供するため、本ページのコンテンツは機械翻訳を用いて日本語に翻訳しています。正確かつ最新のサポート情報をご覧いただくには、本内容の英語版を参照してください。 概要: この記事では、Zoho CRMでClient Scriptを使用してフライアウトとしてカスタムウィジェットを起動し、CRM項目からウィジェットへデータを渡し、ウィジェットのレスポンスに基づいて同じ項目を更新する方法について説明します。 Requirement 概要: ...

                                  Resources

                                  Videos

                                  Watch comprehensive videos on features and other important topics that will help you master Zoho CRM.



                                  eBooks

                                  Download free eBooks and access a range of topics to get deeper insight on successfully using Zoho CRM.



                                  Webinars

                                  Sign up for our webinars and learn the Zoho CRM basics, from customization to sales force automation and more.



                                  CRM Tips

                                  Make the most of Zoho CRM with these useful tips.