Dialogflow CX Messenger

Cette intégration fournit une boîte de dialogue de chat personnalisable pour votre agent, qui peut être intégrée à votre site Web.

Capture d'écran de Dialogflow CX Messenger

Configuration

Cette intégration peut autoriser l'accès aux requêtes d'agent des utilisateurs finaux authentifiés ou non authentifiés.

Configuration non authentifiée

Pour configurer un accès non authentifié à votre agent Dialogflow CX Messenger :

  1. Accédez à la console Dialogflow CX.
  2. Choisissez votre projet Google Cloud.
  3. Sélectionnez votre agent.
  4. Sélectionnez l'onglet Gérer.
  5. Cliquez sur Integrations (Intégrations) dans le menu de la barre latérale gauche.
  6. Cliquez sur Connecter pour Dialogflow CX Messenger.
  7. Une boîte de dialogue de configuration s'ouvre.
  8. Si l'intégration a déjà été configurée pour cet agent, vous verrez un code HTML intégrable. Que vous souhaitiez ou non authentifier l'utilisateur, cliquez sur le bouton Disable… (Désactiver…) en bas de la boîte de dialogue pour pouvoir reconfigurer les paramètres à l'étape suivante.
  9. Sélectionnez un environnement.
  10. Sélectionnez API non authentifiée.
  11. Sélectionnez un style.
  12. Vous pouvez éventuellement limiter l'accès au domaine.
  13. Cliquez sur Enable the unauthenticated API (Activer l'API non authentifiée).
  14. La boîte de dialogue affiche le code HTML intégrable sur votre site Web. Copiez ce code.
  15. Cliquez sur OK.

Configuration authentifiée

Pour configurer un accès authentifié à votre agent Dialogflow CX Messenger :

  1. Accédez à la console Dialogflow CX.
  2. Choisissez votre projet Google Cloud.
  3. Sélectionnez votre agent.
  4. Sélectionnez l'onglet Gérer.
  5. Cliquez sur Integrations (Intégrations) dans le menu de la barre latérale gauche.
  6. Cliquez sur Connecter pour Dialogflow CX Messenger.
  7. Une boîte de dialogue de configuration s'ouvre.
  8. Si l'intégration a déjà été configurée pour cet agent, vous verrez un code HTML intégrable. Que vous souhaitiez ou non authentifier l'utilisateur, cliquez sur le bouton Disable… (Désactiver…) en bas de la boîte de dialogue pour pouvoir reconfigurer les paramètres à l'étape suivante.
  9. Sélectionnez un environnement.
  10. Sélectionnez API autorisée.
  11. Sélectionnez un style.
  12. Vous pouvez éventuellement limiter l'accès au domaine.
  13. Cliquez sur Enable the authorized API (Activer l'API autorisée).
  14. La boîte de dialogue affiche le code HTML intégrable sur votre site Web. Copiez ce code.
  15. Cliquez sur OK.
  16. Configurez le client OAuth :
    1. Créez un écran de consentement OAuth pour votre organisation. Ajoutez https://www.googleapis.com/auth/cloud-platform comme portée requise.
    2. Créez un ID client OAuth 2.0. Sous Origines JavaScript autorisées, spécifiez les origines HTTP autorisées à héberger et à interroger votre agent. Par exemple, https://your-company.com.
    3. Autorisez les utilisateurs finaux à interroger votre agent. Ajoutez chacun de vos utilisateurs finaux ou un groupe en tant que compte principal avec les rôles Client de l'API Dialogflow et Consommateur Service Usage.

Intégrer

Collez le code d'intégration que vous avez copié ci-dessus dans une page Web de votre site Web. Les éléments HTML <script> et <df-messenger> doivent se trouver dans l'élément <body> de votre page.

Si vous utilisez une intégration authentifiée, définissez l'attribut oauth-client-id pour <df-messenger> sur votre ID client OAuth. Si vous souhaitez utiliser les identités des utilisateurs finaux pour l'authentification des outils, définissez l'attribut access-token-name avec le nom de votre choix. Utilisez ensuite le jeton du porteur avec la valeur $session.params.ACCESS_TOKEN_NAME pour l'authentification de l'outil.

Mettez à jour les autres attributs qui doivent l'être.

Pour autoriser les mises en page responsives, ajoutez également les éléments suivants à votre élément <head> :

<meta name="viewport" content="width=device-width, initial-scale=1">

Personnalisation

Vous pouvez appliquer de nombreuses personnalisations HTML et personnalisations CSS pour modifier l'apparence et le comportement de la boîte de dialogue de chat.

JavaScript

De nombreux événements JavaScript et fonctions JavaScript vous permettent d'interagir avec la boîte de dialogue de chat.

Exemple

L'exemple suivant montre la personnalisation HTML, la personnalisation CSS et la gestion des événements JavaScript :

<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <meta http-equiv="Cache-Control" content="no-cache, no-store, must-revalidate" />
  <meta http-equiv="Pragma" content="no-cache" />
  <meta http-equiv="Expires" content="0" />
  <title>My chat</title>
  <style>
    df-messenger {
      /*
       * Customize as required. df-messenger will fill the
       * space that is provided.
      */
      position: absolute;
      right: 0;
      top: 0;
      bottom: 0;
      width: 320px;
    }
  </style>
  <script src="https://www.gstatic.com/dialogflow-console/fast/df-messenger/prod/v1/df-messenger.js"></script>
</head>
<body>
<df-messenger
    location="global" <!-- TODO: update agent location as needed -->
    project-id="my-project-id" <!-- TODO: update project ID -->
    agent-id="my-agent-id" <!-- TODO: update agent ID -->
    language-code="en" <!-- TODO: update agent language as needed -->
>
  <df-messenger-chat
      chat-title="Agent Name" <!-- TODO: update dialog title as needed -->
  ></df-messenger-chat>
</df-messenger>

<script>
  // An example of handling events: Navigate to the first suggested URL.
  document.addEventListener('df-url-suggested', (event) => {
    if (Array.isArray(event.detail.suggestedUrls) &&
      event.detail.suggestedUrls.length) {
      window.location.href = event.detail.suggestedUrls[0];
  }
});
</script>
</body>
</html>

Fulfillment

Vous pouvez utiliser de nombreux types de réponses d'exécution pour les réponses de l'agent.

Commentaires sur les réponses

Si l'évaluation des réponses est activée, la boîte de dialogue de chat ajoute par défaut des boutons J'aime  et Je n'aime pas  à l'interface utilisateur. Au cours de la conversation, un utilisateur final peut cliquer sur ces boutons pour donner son avis sur les réponses de l'agent. Si l'utilisateur sélectionne "Je n'aime pas", il peut éventuellement expliquer pourquoi.

Composant de commentaires personnalisés

Pour spécifier un élément de commentaires personnalisé, un nouvel élément personnalisé doit être défini sur le site Web. Pour envoyer les commentaires, l'élément doit émettre un événement df-custom-submit-feedback-clicked. Le champ detail contenu doit être une chaîne.

class CustomFeedbackElement extends HTMLElement {
  constructor() {
    super();
    // It is not strictly required but recommended to contain the custom
    // element in a shadow root.
    this.renderRoot = this.attachShadow({mode: 'open'});
  }

  // Web component Lifecycle method.
  connectedCallback() {
    const wrapper = document.createElement('div');

    // Build the component as required.
    const button = document.createElement('button');
    button.innerText = 'Submit';
    button.addEventListener('click', () => {
      this._onSubmitClick();
    });
    wrapper.appendChild(button);

    this.renderRoot.appendChild(wrapper);
  }

  // Called when Submit button is clicked.
  _onSubmitClick() {
    const event = new CustomEvent("df-custom-submit-feedback-clicked", {
      // `detail` may be any string,
      // this will be sent to the backend to be stored.
      detail: JSON.stringify({
        "usefulness": 2,
        "accuracy": 3,
      }),
      // Required to propagate up the DOM tree
      // https://developer.mozilla.org/en-US/docs/Web/API/Event/bubbles
      bubbles: true,
      // Required to propagate across ShadowDOM
      // https://developer.mozilla.org/en-US/docs/Web/API/Event/composed
      composed: true,
   });
   this.dispatchEvent(event);
  }
}

(function() {
  // Registers the element. This name must be "df-external-custom-feedback".
  customElements.define('df-external-custom-feedback', CustomFeedbackElement);
})();

Débogage

Pour tester votre agent avec Dialogflow CX Messenger en local :

  • Intégrez l'élément Dialogflow CX Messenger dans une page, comme décrit ci-dessus.
  • Démarrez un serveur HTTP local pour cette page avec un port spécifique.
  • Accédez à cette page à l'adresse http://localhost:port_number.