やりたいこと
Experience Cloud上で組み込みサービスチャットを日本語英語で動作させたい
エクスペリエンスビルダーで日英各ページ作成済み、かつ必要なページに組み込みサービスチャット配置済み
日本語英語を使うEinsteinボットを作成して、各ダイアログのメッセージに日英メッセージを登録するところまではやってある
この後、URLのlanguageパラメータ(ページの言語切替に使われる標準パラメータ)に応じてチャット/ボットの日英切替を行いたい
この後やることの概要
- チャットボタンの日英文言はエクスペリエンスビルダーの組み込みサービスチャット設定で行う
- URLから取得した言語のチャットウィンドウへの言語設定はスニペットで行う
- URLから取得した言語はスニペットでチャットのトランスクリプトにセットし、Apexで取り出してチャットの会話言語にセットする
チャットのトランスクリプトオブジェクトにカスタム属性「言語」作成
- オブジェクトマネージャーでチャットのトランスクリプトオブジェクトに新規カスタム項目追加
- データ型:選択リスト
- 表示ラベル:言語
- 値:
- 各値を改行で区切って入力します:チェック
- ja
- en_US
- 各値を改行で区切って入力します:チェック
- 最初の値をデフォルト値とする:チェック
- 値セットで定義された値に選択リストを制限します:チェック
- 項目名:Language
- 値の入力を必須にする:チェック
スニペットファイル作成&アップロード
- 以下のファイルをローカルで作成、文字コードはUTF-8
SnapInCodeSnippetSettings.js
window._snapinsSnippetSettingsFile = (function () { // URLからlanguageパラメータの値を取得 const paramLanguage = (new URL(document.location)).searchParams.get('language'); // 言語を決定 const language = paramLanguage === 'en_US' ? 'en_US' : 'ja'; // 言語をチャットウィンドウに設定 embedded_svc.snippetSettingsFile.language = language; // 言語をチャットのトランスクリプトに設定 embedded_svc.snippetSettingsFile.extraPrechatFormDetails = [{ 'transcriptFields': ["Language__c"], 'value': language }]; })();
- Salesforceの設定の静的リソースで新規ボタンを押下して作成ファイルをアップロード
- 名前:SnapInCodeSnippetSettings
- ファイル:作成ファイル
- キャッシュコントロール:公開
Apexクラスを作成
- 設定のApexクラスで新規ボタンを押下してApexクラスを作成
EinsteinBotPrechatInfo.cls
public with sharing class EinsteinBotPrechatInfo { public class Input { @InvocableVariable(required=true) public ID routableID; } public class Output { @InvocableVariable(required=true) public String language; } @InvocableMethod(label='Get Einstein Bot Prechat Info') public static List<Output> getPrechatInfo(List<Input> inputs) { List<Output> outputs = new List<Output>(); for (Input input : inputs) { // 指定されたIDのチャットのトランスクリプトのレコードを取得 LiveChatTranscript liveChatTranscript = [ SELECT Language__c FROM LiveChatTranscript WHERE Id = :input.routableID LIMIT 1 ]; // 当該レコードの言語を出力 Output output = new Output(); output.language = liveChatTranscript.Language__c; outputs.add(output); } return outputs; } }
- 同様にテストクラス作成
EinsteinBotPrechatInfoTest.cls
@IsTest public with sharing class EinsteinBotPrechatInfoTest { @IsTest(SeeAllData=true) public static void testGetPrechatInfoJa() { testGetPrechatInfo('ja'); } @IsTest(SeeAllData=true) public static void testGetPrechatInfoEnUS() { testGetPrechatInfo('en_US'); } private static void testGetPrechatInfo(String language) { // チャット訪問者のレコードを作成 LiveChatVisitor liveChatVisitor = new LiveChatVisitor(); insert liveChatVisitor; // 言語と作成したチャット訪問者のIDを指定してチャットのトランスクリプトのレコードを作成 LiveChatTranscript liveChatTranscript = new LiveChatTranscript( Language__c = language, LiveChatVisitorId = liveChatVisitor.Id ); insert liveChatTranscript; // 作成したチャットのトランスクリプトのIDを指定してGetPrechatInfo()実行 EinsteinBotPrechatInfo.Input input = new EinsteinBotPrechatInfo.Input(); input.routableID = liveChatTranscript.Id; List<EinsteinBotPrechatInfo.Input> inputs = new List<EinsteinBotPrechatInfo.Input>(); inputs.add(input); List<EinsteinBotPrechatInfo.Output> outputs = EinsteinBotPrechatInfo.getPrechatInfo( inputs ); // 結果確認 System.assertEquals(outputs.size(), 1); System.assertEquals(outputs[0].language, language); } }
組み込みサービスチャットの設定
- エクスペリエンスビルダーで組み込みサービスチャット配置ページを開く
- ページに配置された組み込みサービスチャットをクリック
- 右側に組み込みサービスチャットの設定が開くので以下を設定
- 画面右上の言語をEnglishに切り替え、同様に組み込みサービスチャットの設定にボタン文言(英語)を設定
- サイトを公開する
Einsteinボットの設定
その他
ボット名
ボット対応時のチャットウィンドウタイトルに表示される
日英切り替えの方法分からず、日本人にもわかる平易な英語とすることとした
有人チャット時のカスタムエージェント名・自動挨拶
Einsteinボット内でエージェントに転送した(そして有人オペレータがチャット対応を開始した)場合の、カスタムエージェント名(ウィンドウタイトルや会話の発言者に使用される)・自動挨拶について
これらは、設定の機能設定>サービス>チャット>[チャット]ボタンと招待で、対象チャットボタンの編集にて変更できるが、日英切り替えの方法が見当たらない
いずれもデフォルトは空欄
空欄にするとカスタムエージェント名は対応オペレータの名前になる、自動挨拶は無しになる
そのため、カスタムエージェント名は平易な英語、自動挨拶は無し、とすることにした
表示ラベル
設定の機能設定>サービス>組み込みサービス>組み込みサービスリリースで、対象リリースに入り、チャットの設定の編集をクリックし、追加のブランド設定の編集をクリックし、表示ラベルタブを選ぶとより細かく表示ラベルを変更できる
参考:
https://help.salesforce.com/s/articleView?id=sf.snapins_chat_localization.htm&type=5
https://help.salesforce.com/s/articleView?id=sf.embedded_chat_custom_labels.htm&type=5
参考
https://qiita.com/shunkosa/items/a0f0470ccea9645c513f#%E3%82%B9%E3%83%8B%E3%83%9A%E3%83%83%E3%83%88%E3%81%AE%E3%82%AB%E3%82%B9%E3%82%BF%E3%83%9E%E3%82%A4%E3%82%BA
https://help.salesforce.com/s/articleView?id=sf.snapins_chat_parameters.htm&type=5