Événements JavaScript intégrés

Après avoir créé une intégration (que ce soit publiquement, privée, avec l'authentification unique ou via l'API), vous pouvez interagir avec ces iFrames via JavaScript. Vous pouvez rendre votre page plus dynamique, en fonction de l'état de l'élément intégré, ou même modifier cet élément à partir de votre page Web.

Sachez que Looker ne contrôle pas l'ordre dans lequel les navigateurs envoient des événements aux applications Web. Par conséquent, l'ordre des événements n'est pas garanti dans les navigateurs ni sur les plates-formes. Veillez à écrire votre code JavaScript de façon appropriée afin de tenir compte du traitement des événements dans les différents navigateurs.

Vous pouvez utiliser JavaScript de deux manières pour le contenu intégré Looker:

  • À l'aide du kit de développement logiciel (SDK) intégré de Looker, décrit sur la page de documentation du SDK Embed
  • Utilisation d'événements JavaScript, comme décrit dans la section Accéder aux événements en JavaScript de cette page.

Préparation

Vous devez effectuer quelques actions avant d'interagir avec l'iFrame intégré:

Ajouter un ID à l'iFrame

L'une des actions que vous devrez effectuer ultérieurement consiste à vérifier que les informations avec lesquelles vous travaillez proviennent bien de l'iFrame de Looker. Pour vous faciliter la tâche, veillez à ajouter un ID à l'iFrame, si vous ne l'avez pas déjà fait. Dans l'exemple suivant, nous avons ajouté id="looker":

<iframe id="looker" src="https://instance_name.looker.com/embed/dashboards/1"></iframe>

Ajouter le domaine intégré à l'attribut iFrame src

Dans la propriété src de l'iFrame, ajoutez le domaine dans lequel l'iFrame est utilisé. Dans l'exemple suivant, nous avons ajouté ?embed_domain=https://mywebsite.com":

<iframe
  id="looker"
  src="https://instance_name.looker.com/embed/dashboards/1?embed_domain=https://mywebsite.com">
</iframe>

Si vous utilisez l'intégration de l'authentification unique, veillez à ajouter embed_domain à l'URL d'intégration.

N'incluez pas de barre oblique finale (/) dans embed_domain.

Ajouter le domaine intégré à la liste d'autorisation

Enfin, ajoutez le domaine sur lequel l'iFrame est utilisé à la liste d'autorisation sur la page Embed (intégration) du panneau Admin de Looker:

  1. Saisissez le domaine dans lequel l'iFrame est utilisé. Après l'avoir saisie, n'oubliez pas d'appuyer sur la touche Tabulation afin que le domaine apparaisse dans un champ. N'incluez pas de barre oblique finale (/) dans l'URL du domaine.
  2. Cliquez sur le bouton Mettre à jour.

Vous pouvez utiliser le caractère générique * dans la liste d'autorisation pour créer un modèle de domaine. Par exemple, https://*.mycompany.com autorise à la fois https://analytics.mycompany.com et https://data.mycompany.com.

Si vous utilisez l'intégration sans cookie avec Looker 23.8 ou une version ultérieure, vous pouvez spécifier le domaine d'intégration lors de l'acquisition de la session sans cookie. Il s'agit d'une alternative à l'ajout à la liste d'autorisation via le panneau Admin > Intégrer. Consultez les bonnes pratiques de sécurité si vous souhaitez bénéficier de cette fonctionnalité.

Récupérer des données depuis l'iFrame

Une fois la procédure de préparation terminée, vous pouvez accéder aux événements transmis entre l'iFrame Looker et votre domaine en écoutant les événements postMessage.

Assurez-vous que les événements proviennent bien de l'iFrame et du domaine Looker pour éviter les messages malveillants.

L'iFrame intégré peut créer plusieurs types d'événements, comme décrit dans la section Référence du type d'événement de cette page.

Accéder aux événements en JavaScript

Voici un exemple d'écoute de ces événements en JavaScript natif, puis de journalisation de ces événements dans la console:

window.addEventListener("message", function(event) {
  if (event.source === document.getElementById("looker").contentWindow) {
    if (event.origin === "https://instance_name.looker.com") {
      console.log(JSON.parse(event.data));
    }
  }
});

Voici un exemple de lecture de ces événements dans jQuery, puis journalisation de ces événements dans la console:

$(window).on("message", function(event) {
  if (event.originalEvent.source === $("#looker")[0].contentWindow) {
    if (event.origin === "https://instance_name.looker.com") {
      console.log(JSON.parse(event.data));
    }
  }
});

Tableau récapitulatif des types d'événements

Le tableau suivant récapitule les types d'événements. Cliquez sur un type d'événement pour afficher les détails correspondants.

Event Type Cause de l'événement
dashboard:loaded Dans les tableaux de bord où les tuiles ne sont pas définies pour s'exécuter automatiquement, un tableau de bord et ses éléments ont été chargés, mais les requêtes ne sont pas encore exécutées.
dashboard:run:start Un tableau de bord a commencé à se charger, et ses tuiles ont commencé à se charger et à interroger des données.
dashboard:run:complete L'exécution du tableau de bord est terminée, et le chargement de toutes les cartes et de leurs requêtes a pris fin.
dashboard:download Le téléchargement du tableau de bord au format PDF a commencé.
dashboard:edit:start ADDED 22.20 Un tableau de bord est passé en mode Édition. L'événement dashboard:save:complete se déclenche lorsque le tableau de bord est correctement enregistré.
dashboard:edit:cancel ADDED 22.20 Un tableau de bord en mode Édition a été quitté sans mode d'édition sans enregistrer.
dashboard:save:complete Un tableau de bord a été modifié et enregistré.
dashboard:delete:complete Un tableau de bord a été supprimé.
dashboard:tile:start Une carte a commencé à se charger ou à interroger des données.
dashboard:tile:complete Une carte a terminé l'exécution de la requête.
dashboard:tile:download Le téléchargement des données d'une carte a commencé.
dashboard:tile:explore Un utilisateur a cliqué sur l'option Explorer à partir de cet endroit dans une vignette du tableau de bord.
dashboard:tile:view Un utilisateur a cliqué sur l'option Afficher l'aspect d'origine dans une vignette du tableau de bord.
dashboard:filters:changed Les filtres d'un tableau de bord ont été appliqués ou modifiés.
look:ready Un aperçu a commencé à charger les données de la requête, que celle-ci soit exécutée ou non.
look:run:start Un aperçu a commencé à charger les données de la requête, qui a commencé à s'exécuter.
look:run:complete La requête a été exécutée.
look:save:complete Un style a été modifié et enregistré.
look:delete:complete Un aperçu a été placé dans le dossier Corbeille.
drillmenu:click Un utilisateur a cliqué sur un menu d'exploration dans un tableau de bord créé avec le paramètre LookML link.
drillmodal:download Un utilisateur a ouvert une boîte de dialogue d'analyse détaillée à partir d'une vignette du tableau de bord, puis a cliqué sur l'option Télécharger.
drillmodal:explore Un utilisateur a cliqué sur l'option Explorer à partir de cet emplacement dans une boîte de dialogue d'analyse détaillée.
explore:ready Une exploration a commencé à charger des données de requête, que la requête soit exécutée ou non.
explore:run:start Une exploration a commencé à charger des données de requête et la requête a commencé à s'exécuter.
explore:run:complete Une exploration a terminé l'exécution de la requête.
explore:state:changed L'URL d'une page "Explorer" a été modifiée à la suite des actions de l'utilisateur.
page:changed Un utilisateur a accédé à une nouvelle page dans le cadre iFrame.
page:properties:changed La hauteur d'un iFrame de tableau de bord a changé.
session:tokens Le client Looker requiert des jetons pour continuer.
session:status Envoie des informations sur l'état d'une session.
env:client:dialog Une boîte de dialogue (avec boîte de dialogue d'analyse détaillée) a peut-être été ouverte et partiellement invisible. Cet événement permet à l'application d'hébergement de faire défiler la boîte de dialogue.

À propos des types d'événements

L'iFrame intégré peut créer différents types d'événements:

dashboard:loaded

Sur les tableaux de bord où les tuiles ne sont pas définies pour s'exécuter automatiquement, cet événement est créé après le chargement d'un tableau de bord et de ses éléments, mais avant l'exécution des requêtes.


type: "dashboard:loaded",
status: "complete",
dashboard: {
  id: 1,
  title: "Business Pulse",
  canEdit: true,
  dashboard_filters: {
    "date": "Last 6 Years",
    "state": ""
  },
  absoluteUrl: "https://self-signed.looker.com:9999/embed/dashboards/1?embed_domain=https%3A%2F%2Fself-signed.looker.com%3A9999&date=Last+6+Years&state=",
  url: "/embed/dashboards/1?embed_domain=https%3A%2F%2Fself-signed.looker.com%3A9999&date=Last+6+Years&state=",
  options: {
    layouts: [
      {
        id: 1,
        dashboard_id: 1,
        type: "newspaper",
        active: true,
        column_width: null,
        width: null,
        deleted: false,
        dashboard_layout_components: [
          {
            id: 1,
            dashboard_layout_id: 1,
            dashboard_element_id: 1,
            row: 0,
            column: 0,
            width: 8,
            height: 4,
            deleted: false
          },
          {
            id: 2,
            dashboard_layout_id: 1,
            dashboard_element_id: 2,
            row: 0,
            column: 8,
            width: 8,
            height: 4,
            deleted: false
          }
        ]
      }
    ],
    elements: {
      1: {
        title: "Total Orders",
        title_hidden: false,
        vis_config: {
          type: "single_value",
          font_size: "medium",
          title: "Total Orders"
        }
      },
      2: {
        title: "Average Order Profit",
        title_hidden: false,
        vis_config: {
          type: "single_value",
          title: "Average Order Profit"
        }
      }
    }
  }
}
Attribut Format Description
status String Indique si le tableau de bord et ses éléments ont bien été chargés.
dashboard.id Nombre/Chaîne ID du tableau de bord.
dashboard.title String Titre, comme indiqué en haut du tableau de bord.
dashboard.canEdit Booléen ADDED 22.20 Lorsque true, l'utilisateur peut modifier le tableau de bord.
dashboard.dashboard_filters Objet Filtres appliqués au tableau de bord. Cet objet a le format suivant: {"Filter name 1": "value 1", "Filter name 2": "value 2", ...}
dashboard.absoluteUrl String URL complète du tableau de bord.
dashboard.url String URL du tableau de bord relatif (uniquement le chemin d'accès).
dashboard.options Objet Les propriétés et les valeurs de mise en page du tableau de bord, composant de mise en page du tableau de bord, et élément du tableau de bord. Toutes les propriétés renvoyées dans l'objet options peuvent recevoir des valeurs mises à jour à l'aide de l'événement dashboard:options:set.

dashboard:run:start

Cet événement est créé lorsqu'un tableau de bord commence à se charger, lorsque ses tuiles commencent à se charger et à interroger des données.

type: "dashboard:run:start",
dashboard: {
  id: 23,
  title: "My Dashboard",
  canEdit: true,
  url: "/embed/dashboards/...",
  absoluteUrl: "https://instance_name.looker.com/embed/dashboards/...",
  dashboard_filters: {
    "Date": "Last 28 days",
    "Total Orders": "Greater than 100"
  }
}
Attribut Format Description
dashboard.id Nombre/Chaîne ID du tableau de bord.
dashboard.title String Titre, comme indiqué en haut du tableau de bord.
dashboard.canEdit Booléen ADDED 22.20 Lorsque true, l'utilisateur peut modifier le tableau de bord.
dashboard.url String URL du tableau de bord relatif (uniquement le chemin d'accès).
dashboard.absoluteUrl String URL complète du tableau de bord.
dashboard.dashboard_filters Objet Filtres appliqués au tableau de bord. Cet objet a le format suivant: {"Filter name 1": "value 1", "Filter name 2": "value 2", ...}

dashboard:run:complete

Cet événement est créé lorsqu'un tableau de bord a terminé son exécution, et que le chargement et l'interrogation de toutes les tuiles sont terminés. Cet événement est créé, que toutes les tuiles se chargent ou non.

type: "dashboard:run:complete",
status: "complete",
dashboard: {
  id: 23,
  title: "My Dashboard",
  canEdit: true,
  url: "/embed/dashboards/...",
  absoluteUrl: "https://my.looker.com/embed/dashboards/...",
  dashboard_filters: {
    "Date": "Last 28 days",
    "Total Orders": "Greater than 100"
  }
  options: {
    layouts: [
      {
        id: 1,
        dashboard_id: 1,
        type: "newspaper",
        active: true,
        column_width: null,
        width: null,
        deleted: false,
        dashboard_layout_components: [
          {
            id: 1,
            dashboard_layout_id: 1,
            dashboard_element_id: 1,
            row: 0,
            column: 0,
            width: 8,
            height: 4,
            deleted: false
          },
          {
            id: 2,
            dashboard_layout_id: 1,
            dashboard_element_id: 2,
            row: 0,
            column: 8,
            width: 8,
            height: 4,
            deleted: false
          }
        ]
      }
    ],
    elements: {
      1: {
        title: "Total Orders",
        title_hidden: false,
        vis_config: {
          type: "single_value",
          font_size: "medium",
          title: "Total Orders"
        }
      },
      2: {
        title: "Average Order Profit",
        title_hidden: false,
        vis_config: {
          type: "single_value",
          title: "Average Order Profit"
        }
      }
    }
  }
}
Attribut Format Description
status String Indique si le tableau de bord et ses éléments ont bien été exécutés. Si le tableau de bord et ses éléments ont bien été exécutés, status renvoie "complete". Sinon, status renvoie "error". Si le tableau de bord en cours d'exécution a été arrêté, via l'interface utilisateur ou avec l'action dashboard:stop, status renvoie "stopped".
dashboard.id Nombre/Chaîne ID du tableau de bord.
dashboard.title String Titre, comme indiqué en haut du tableau de bord.
dashboard.canEdit Booléen ADDED 22.20 Lorsque true, l'utilisateur peut modifier le tableau de bord.
dashboard.url String URL du tableau de bord relatif (uniquement le chemin d'accès).
dashboard.absoluteUrl String URL complète du tableau de bord.
dashboard.dashboard_filters Objet Filtres appliqués au tableau de bord. Cet objet a le format suivant: {"Filter name 1": "value 1", "Filter name 2": "value 2", ...}
dashboard.options Objet Les propriétés et les valeurs de mise en page du tableau de bord, composant de mise en page du tableau de bord, et élément du tableau de bord. Vous pouvez mettre à jour toutes les propriétés renvoyées dans l'objet options à l'aide de l'action dashboard:options:set.
dashboard.tileStatuses Tableau d'objets Tableau d'objets fournissant des états de carte. Les propriétés de l'objet sont les suivantes:
  • tileId : numéro d'identifiant de la carte.
  • status : si la requête de carte a bien été exécutée, status renvoie "complete". Sinon, status renvoie "error".
  • errors : valeur renseignée lorsque la propriété status est "error". Tableau d'objets fournissant des détails sur l'erreur, y compris le texte du message d'erreur, une description plus détaillée de l'erreur et la requête SQL de la tuile qui a produit l'erreur.

dashboard:download

Cet événement est créé au début du téléchargement du tableau de bord au format PDF.

type: "dashboard:download",
dashboard: {
  id: 23,
  title: "My Dashboard",
  canEdit: true,
  url: "/embed/dashboards/...",
  absoluteUrl: "https://instance_name.looker.com/embed/dashboards/...",
  dashboard_filters: {
    "Date": "Last 28 days",
    "Total Orders": "Greater than 100"
  }
}
fileFormat: "pdf"
Attribut Format Description
dashboard.id Nombre/Chaîne ID du tableau de bord.
dashboard.title String Titre, comme indiqué en haut du tableau de bord.
dashboard.canEdit Booléen ADDED 22.20 Lorsque true, l'utilisateur peut modifier le tableau de bord.
dashboard.url String URL du tableau de bord relatif (uniquement le chemin d'accès).
dashboard.absoluteUrl String URL complète du tableau de bord.
dashboard.dashboard_filters Objet Filtres appliqués au tableau de bord. Cet objet a le format suivant: {"Filter name 1": "value 1", "Filter name 2": "value 2", ...}
fileFormat String Format du tableau de bord téléchargé (uniquement "pdf" pour le moment).

dashboard:edit:start

ADDED 22.20 Cet événement est créé lorsqu'un tableau de bord passe en mode Édition.

type: "dashboard:edit:start",
dashboard: {
  id: 23,
  title: "My Dashboard",
  canEdit: true,
  url: "/embed/dashboards/...",
  absoluteUrl: "https://instance_name.looker.com/embed/dashboards/...",
  dashboard_filters: {
    "Date": "Last 28 days",
    "Total Orders": "Greater than 100"
  }
}
Attribut Format Description
dashboard.id Nombre/Chaîne ID du tableau de bord.
dashboard.title String Titre, comme indiqué en haut du tableau de bord.
dashboard.canEdit Booléen ADDED 22.20 Lorsque true, l'utilisateur peut modifier le tableau de bord.
dashboard.url String URL du tableau de bord relatif (uniquement le chemin d'accès).
dashboard.absoluteUrl String URL complète du tableau de bord.
dashboard.dashboard_filters Objet Filtres appliqués au tableau de bord. Cet objet a le format suivant: {"Filter name 1": "value 1", "Filter name 2": "value 2", ...}

dashboard:edit:cancel

ADDED 22.20 Cet événement est créé lorsqu'un tableau de bord en mode Édition quitte le mode Édition sans enregistrer.

type: "dashboard:edit:cancel",
dashboard: {
  id: 23,
  title: "My Dashboard",
  canEdit: true,
  url: "/embed/dashboards/...",
  absoluteUrl: "https://instance_name.looker.com/embed/dashboards/...",
  dashboard_filters: {
    "Date": "Last 28 days",
    "Total Orders": "Greater than 100"
  }
}
Attribut Format Description
dashboard.id Nombre/Chaîne ID du tableau de bord.
dashboard.title String Titre, comme indiqué en haut du tableau de bord.
dashboard.canEdit Booléen ADDED 22.20 Lorsque true, l'utilisateur peut modifier le tableau de bord.
dashboard.url String URL du tableau de bord relatif (uniquement le chemin d'accès).
dashboard.absoluteUrl String URL complète du tableau de bord.
dashboard.dashboard_filters Objet Filtres appliqués au tableau de bord. Cet objet a le format suivant: {"Filter name 1": "value 1", "Filter name 2": "value 2", ...}

dashboard:save:complete

Cet événement est créé lorsqu'un tableau de bord est modifié, puis enregistré.

type: "dashboard:save:complete",
dashboard: {
  id: 23,
  title: "My Dashboard",
  canEdit: true,
  dashboard_filters: {
    "Date": "Last 28 days",
    "Total Orders": "Greater than 100"
  }
  absoluteUrl: "https://instance_name.looker.com/embed/dashboards/...",
  url: "/embed/dashboards/...",
  options: {
    layouts: [
      {
        id: 1,
        dashboard_id: 1,
        type: "newspaper",
        active: true,
        column_width: null,
        width: null,
        deleted: false,
        dashboard_layout_components: [
          {
            id: 1,
            dashboard_layout_id: 1,
            dashboard_element_id: 1,
            row: 0,
            column: 0,
            width: 8,
            height: 4,
            deleted: false
          },
          {
            id: 2,
            dashboard_layout_id: 1,
            dashboard_element_id: 2,
            row: 0,
            column: 8,
            width: 8,
            height: 4,
            deleted: false
          }
        ]
      }
    ],
    elements: {
      1: {
        title: "Total Orders",
        title_hidden: false,
        vis_config: {
          type: "single_value",
          font_size: "medium",
          title: "Total Orders"
        }
      },
      2: {
        title: "Average Order Profit",
        title_hidden: false,
        vis_config: {
          type: "single_value",
          title: "Average Order Profit"
        }
      }
    }
  }
}
Attribut Format Description
dashboard.id Nombre/Chaîne ID du tableau de bord.
dashboard.title String Titre, comme indiqué en haut du tableau de bord.
dashboard.canEdit Booléen ADDED 22.20 Lorsque true, l'utilisateur peut modifier le tableau de bord.
dashboard.dashboard_filters Objet Filtres appliqués au tableau de bord. Cet objet a le format suivant: {"Filter name 1": "value 1", "Filter name 2": "value 2", ...}
dashboard.absoluteUrl String URL complète du tableau de bord.
dashboard.url String URL du tableau de bord relatif (uniquement le chemin d'accès).
dashboard.options Objet Les propriétés et les valeurs de mise en page du tableau de bord, composant de mise en page du tableau de bord, et élément du tableau de bord. Toutes les propriétés renvoyées dans l'objet options peuvent recevoir des valeurs mises à jour à l'aide de l'événement dashboard:options:set.

dashboard:delete:complete

Cet événement est créé lorsqu'un tableau de bord est supprimé.

type: "dashboard:delete:complete",
dashboard: {
  id: 23,
  title: "My Dashboard",
  canEdit: true,
  dashboard_filters: {
    "Date": "Last 28 days",
    "Total Orders": "Greater than 100"
  }
  absoluteUrl: "https://instance_name.looker.com/embed/dashboards/...",
  url: "/embed/dashboards/...",
  options: {
    layouts: [
      {
        id: 1,
        dashboard_id: 1,
        type: "newspaper",
        active: true,
        column_width: null,
        width: null,
        deleted: false,
        dashboard_layout_components: [
          {
            id: 1,
            dashboard_layout_id: 1,
            dashboard_element_id: 1,
            row: 0,
            column: 0,
            width: 8,
            height: 4,
            deleted: false
          },
          {
            id: 2,
            dashboard_layout_id: 1,
            dashboard_element_id: 2,
            row: 0,
            column: 8,
            width: 8,
            height: 4,
            deleted: false
          }
        ]
      }
    ],
    elements: {
      1: {
        title: "Total Orders",
        title_hidden: false,
        vis_config: {
          type: "single_value",
          font_size: "medium",
          title: "Total Orders"
        }
      },
      2: {
        title: "Average Order Profit",
        title_hidden: false,
        vis_config: {
          type: "single_value",
          title: "Average Order Profit"
        }
      }
    }
  }
}
Attribut Format Description
dashboard.id Nombre/Chaîne ID du tableau de bord.
dashboard.title String Titre, comme indiqué en haut du tableau de bord.
dashboard.canEdit Booléen ADDED 22.20 Lorsque true, l'utilisateur peut modifier le tableau de bord.
dashboard.dashboard_filters Objet Filtres appliqués au tableau de bord. Cet objet a le format suivant: {"Filter name 1": "value 1", "Filter name 2": "value 2", ...}
dashboard.absoluteUrl String URL complète du tableau de bord.
dashboard.url String URL du tableau de bord relatif (uniquement le chemin d'accès).
dashboard.options Objet Les propriétés et les valeurs de mise en page du tableau de bord, composant de mise en page du tableau de bord, et élément du tableau de bord. Toutes les propriétés renvoyées dans l'objet options peuvent recevoir des valeurs mises à jour à l'aide de l'événement dashboard:options:set.

dashboard:tile:start

Cet événement est créé lorsqu'une carte commence à charger ou à interroger des données.

type: "dashboard:tile:start",
dashboard: {
  id: 23,
  title: "My Dashboard",
  canEdit: true,
  url: "/embed/dashboards/...",
  absoluteUrl: "https://instance_name.looker.com/embed/dashboards/...",
  dashboard_filters: {
    "Date": "Last 28 days",
    "Total Orders": "Greater than 100"
  }
}
tile: {
  id: 123,
  title: "Quarterly Sales",
  listen: {
    "Date": "order.date",
    "Total Orders": "order.count"
  }
}
Attribut Format Description
dashboard.id Nombre/Chaîne ID du tableau de bord auquel appartient la carte.
dashboard.title String Titre du tableau de bord, comme indiqué en haut du tableau de bord auquel la carte appartient.
dashboard.canEdit Booléen ADDED 22.20 Lorsque true, l'utilisateur peut modifier le tableau de bord.
dashboard.url String L'URL relative du tableau de bord (à savoir le chemin d'accès) auquel la carte appartient.
dashboard.absoluteUrl String URL complète du tableau de bord auquel appartient la carte.
dashboard.dashboard_filters Objet Filtres appliqués au tableau de bord auquel la carte appartient. Cet objet a le format suivant: {"Filter name 1": "value 1", "Filter name 2": "value 2", ...}
tile.id Integer Numéro de l'événement, et non de la tuile.
tile.title String Titre de la carte, comme indiqué en haut de celle-ci.
tile.listen Objet Le tableau de bord global filtre cette carte en écoute. Cet objet a le format suivant: {"Filter Label": "Filter Field", ...}

dashboard:tile:complete

Cet événement est créé lorsqu'une carte a fini d'exécuter la requête.

type: "dashboard:tile:complete",
dashboard: {
  id: 23,
  title: "My Dashboard",
  canEdit: true,
  url: "/embed/dashboards/...",
  absoluteUrl: "https://instance_name.looker.com/embed/dashboards/...",
  dashboard_filters: {
    "Date": "Last 28 days",
    "Total Orders": "Greater than 100"
  }
}
status: "complete",
truncated: false,
tile: {
  id: 123,
  title: "Quarterly Sales",
  listen: {
    "Date": "order.date",
    "Total Orders": "order.count"
  }
}
Attribut Format Description
dashboard.id Nombre/Chaîne ID du tableau de bord auquel appartient la carte.
dashboard.title String Titre du tableau de bord, comme indiqué en haut du tableau de bord auquel la carte appartient.
dashboard.canEdit Booléen ADDED 22.20 Lorsque true, l'utilisateur peut modifier le tableau de bord.
dashboard.url String L'URL relative du tableau de bord (à savoir le chemin d'accès) auquel la carte appartient.
dashboard.absoluteUrl String URL complète du tableau de bord auquel appartient la carte.
dashboard.dashboard_filters Objet Filtres appliqués au tableau de bord auquel la carte appartient. Cet objet a le format suivant: {"Filter name 1": "value 1", "Filter name 2": "value 2", ...}
status String Indique si la requête de tuile a abouti. Les valeurs possibles sont "complete" ou "error".
truncated Booléen Indique si les résultats de la requête de tuiles ont été tronqués en raison d'un nombre de lignes supérieur à la limite du nombre de lignes. Le nombre maximal de lignes peut être spécifié par l'utilisateur ou par défaut de 5 000.
tile.id Integer Numéro de l'événement, et non de la tuile.
tile.title String Titre de la carte, comme indiqué en haut de celle-ci.
tile.listen Objet Le tableau de bord global filtre cette carte en écoute. Cet objet a le format suivant: {"Filter Label": "Filter Field", ...}
tile.errors Tableau d'objets Valeur insérée lorsque la propriété status est "error". Tableau d'objets fournissant des détails sur l'erreur, y compris le texte du message d'erreur, une description plus détaillée de l'erreur et la requête SQL de la tuile qui a produit l'erreur.

dashboard:tile:download

Cet événement est créé lorsque le téléchargement des données d'une carte a commencé.

type: "dashboard:tile:download",
dashboard: {
  id: 23,
  title: "My Dashboard",
  canEdit: true,
  url: "/embed/dashboards/...",
  absoluteUrl: "https://instance_name.looker.com/embed/dashboards/...",
  dashboard_filters: {
    "Date": "Last 28 days",
    "Total Orders": "Greater than 100"
  }
}
tile: {
  id: 123,
  title: "Quarterly Sales"
  listen: {
    "Date": "order.date",
    "Total Orders": "order.count"
  }
}
fileFormat: "pdf"
Attribut Format Description
dashboard.id Nombre/Chaîne ID du tableau de bord auquel appartient la carte.
dashboard.title String Titre du tableau de bord, comme indiqué en haut du tableau de bord auquel la carte appartient.
dashboard.canEdit Booléen ADDED 22.20 Lorsque true, l'utilisateur peut modifier le tableau de bord.
dashboard.url String L'URL relative du tableau de bord (à savoir le chemin d'accès) auquel la carte appartient.
dashboard.absoluteUrl String URL complète du tableau de bord auquel appartient la carte.
dashboard.dashboard_filters Objet Filtres appliqués au tableau de bord auquel la carte appartient. Cet objet a le format suivant: {"Filter name 1": "value 1", "Filter name 2": "value 2", ...}
tile.id Integer Numéro de l'événement, et non de la tuile.
tile.title String Titre de la carte, comme indiqué en haut de celle-ci.
tile.listen Objet Le tableau de bord global filtre cette carte en écoute. Cet objet a le format suivant: {"Filter Label": "Filter Field", ...}
fileFormat String Format du bloc téléchargé (uniquement "pdf" pour le moment).

dashboard:tile:explore

Cet événement est créé lorsqu'un utilisateur clique sur l'option Explorer à partir de cet emplacement dans une vignette du tableau de bord.

type: "dashboard:tile:explore",
label: 'Explore From Here',
url: '/embed/explore/model/view...',
dashboard: {
  id: 23,
  title: "My Dashboard",
  canEdit: true,
  url: "/embed/dashboards/...",
  absoluteUrl: "https://instance_name.looker.com/embed/dashboards/...",
  dashboard_filters: {
    "Date": "Last 28 days",
    "Total Orders": "Greater than 100"
  }
}
tile: {
  id: 123,
  title: "Quarterly Sales",
  listen: {
    "Date": "order.date",
    "Total Orders": "order.count"
  }
}
Attribut Format Description
label String Libellé du bouton.
url String URL relative (uniquement le chemin) de l'exploration à afficher.
dashboard.id Nombre/Chaîne ID du tableau de bord auquel appartient la carte.
dashboard.title String Titre du tableau de bord, comme indiqué en haut du tableau de bord auquel la carte appartient.
dashboard.canEdit Booléen ADDED 22.20 Lorsque true, l'utilisateur peut modifier le tableau de bord.
dashboard.url String L'URL relative du tableau de bord (à savoir le chemin d'accès) auquel la carte appartient.
dashboard.absoluteUrl String URL complète du tableau de bord auquel appartient la carte.
dashboard.dashboard_filters Objet Filtres appliqués au tableau de bord auquel la carte appartient. Cet objet a le format suivant: {"Filter name 1": "value 1", "Filter name 2": "value 2", ...}
tile.id Integer Numéro de l'événement, et non de la tuile.
tile.title String Titre de la carte, comme indiqué en haut de celle-ci.
tile.listen Objet Le tableau de bord global filtre cette carte en écoute. Cet objet a le format suivant: {"Filter Label": "Filter Field", ...}

dashboard:tile:view

Cet événement est créé lorsqu'un utilisateur clique sur l'option Afficher l'aspect d'origine dans une vignette du tableau de bord.

type: "dashboard:tile:view",
label: 'View Original Look',
url: '/embed/look/...',
dashboard: {
  id: 23,
  title: "My Dashboard",
  canEdit: true,
  url: "/embed/dashboards/...",
  absoluteUrl: "https://instance_name.looker.com/embed/dashboards/...",
  dashboard_filters: {
    "Date": "Last 28 days",
    "Total Orders": "Greater than 100"
  }
}
tile: {
  id: 123,
  title: "Quarterly Sales",
  listen: {
    "Date": "order.date",
    "Total Orders": "order.count"
  }
}
Attribut Format Description
label String Libellé du bouton.
url String URL relative (uniquement le chemin d'accès) du style à afficher.
dashboard.id Nombre/Chaîne ID du tableau de bord auquel appartient la carte.
dashboard.title String Titre du tableau de bord, comme indiqué en haut du tableau de bord auquel la carte appartient.
dashboard.canEdit Booléen ADDED 22.20 Lorsque true, l'utilisateur peut modifier le tableau de bord.
dashboard.url String L'URL relative du tableau de bord (à savoir le chemin d'accès) auquel la carte appartient.
dashboard.absoluteUrl String URL complète du tableau de bord auquel appartient la carte.
dashboard.dashboard_filters Objet Filtres appliqués au tableau de bord auquel la carte appartient. Cet objet a le format suivant: {"Filter name 1": "value 1", "Filter name 2": "value 2", ...}
tile.id Integer Numéro de l'événement, et non de la tuile.
tile.title String Titre de la carte, comme indiqué en haut de celle-ci.
tile.listen Objet Le tableau de bord global filtre cette carte en écoute. Cet objet a le format suivant: {"Filter Label": "Filter Field", ...}

dashboard:filters:changed

Cet événement est créé lorsque des filtres de tableau de bord ont été appliqués ou modifiés.

type: "dashboard:filters:changed",
dashboard: {
  id: 23,
  title: "My Dashboard",
  canEdit: true,
  url: "/embed/dashboards/...",
  absoluteUrl: "https://instance_name.looker.com/embed/dashboards/...",
  dashboard_filters: {
    "Date": "Last 28 days",
    "Total Orders": "Greater than 100"
  }
  options: {
    layouts: [
      {
        id: 1,
        dashboard_id: 1,
        type: "newspaper",
        active: true,
        column_width: null,
        width: null,
        deleted: false,
        dashboard_layout_components: [
          {
            id: 1,
            dashboard_layout_id: 1,
            dashboard_element_id: 1,
            row: 0,
            column: 0,
            width: 8,
            height: 4,
            deleted: false
          },
          {
            id: 2,
            dashboard_layout_id: 1,
            dashboard_element_id: 2,
            row: 0,
            column: 8,
            width: 8,
            height: 4,
            deleted: false
          }
        ]
      }
    ],
    elements: {
      1: {
        title: "Total Orders",
        title_hidden: false,
        vis_config: {
          type: "single_value",
          font_size: "medium",
          title: "Total Orders"
        }
      },
      2: {
        title: "Average Order Profit",
        title_hidden: false,
        vis_config: {
          type: "single_value",
          title: "Average Order Profit"
        }
      }
    }
  }
}
Attribut Format Description
dashboard.id Nombre/Chaîne ID du tableau de bord.
dashboard.title String Titre, comme indiqué en haut du tableau de bord.
dashboard.canEdit Booléen ADDED 22.20 Lorsque true, l'utilisateur peut modifier le tableau de bord.
dashboard.url String URL du tableau de bord relatif (uniquement le chemin d'accès).
dashboard.absoluteUrl String URL complète du tableau de bord.
dashboard.dashboard_filters Objet Filtres appliqués au tableau de bord. Cet objet a le format suivant: {"Filter name 1": "value 1", "Filter name 2": "value 2", ...}
dashboard.options Objet Les propriétés et les valeurs de mise en page du tableau de bord, composant de mise en page du tableau de bord, et élément du tableau de bord. Toutes les propriétés renvoyées dans l'objet options peuvent recevoir des valeurs mises à jour à l'aide de l'événement dashboard:options:set.

look:ready

Cet événement est créé lorsqu'un look commence à charger des données de requête, que la requête soit exécutée ou non.

type: "look:ready",
look: {
  url: "/embed/looks/...",
  absoluteUrl: "https://instance_name.looker.com/embed/looks/...",
  }
}
Attribut Format Description
look.url String L'URL de l'aspect relatif (juste le chemin d'accès)
look.absoluteUrl String URL complète

look:run:start

Cet événement est créé lorsqu'un look commence à charger des données de requête et que la requête commence à s'exécuter.

type: "look:run:start",
look: {
  url: "/embed/looks/...",
  absoluteUrl: "https://instance_name.looker.com/embed/looks/...",
  }
}
Attribut Format Description
look.url String L'URL de l'aspect relatif (juste le chemin d'accès)
look.absoluteUrl String URL complète

look:run:complete

Cet événement est créé une fois qu'un look a terminé d'exécuter la requête.

type: look:run:complete
look: {
  url: "/embed/looks/...",
  absoluteUrl: "https://instance_name.looker.com/embed/looks/...",
  }
}
Attribut Format Description
look.url String L'URL de l'aspect relatif (juste le chemin d'accès)
look.absoluteUrl String URL complète

look:save:complete

Cet événement est créé lorsqu'un style est modifié et enregistré. Cet événement est créé lorsqu'un utilisateur effectue l'une des tâches suivantes:

Cet événement n'est pas créé si le style est enregistré via l'option de menu Enregistrer > Dans le tableau de bord existant ou Modifier les paramètres.

type: look:save:complete
look: {
  url: "/embed/looks/...",
  absoluteUrl: "https://instance_name.looker.com/embed/looks/...",
  spaceId: 123
  }
}
Attribut Format Description
look.url String L'URL de l'aspect relatif (juste le chemin d'accès)
look.absoluteUrl String URL complète
look.spaceID Integer ID du dossier où l'aperçu est stocké

look:delete:complete

Cet événement est créé lorsqu'un style est déplacé dans le dossier Corbeille.

type: look:delete:complete
look: {
  url: "/embed/looks/...",
  absoluteUrl: "https://instance_name.looker.com/embed/looks/...",
  }
}
Attribut Format Description
look.url String L'URL de l'aspect relatif (juste le chemin d'accès)
look.absoluteUrl String URL complète

drillmenu:click

Cet événement est créé lorsqu'un utilisateur clique sur un menu d'analyse détaillée dans un tableau de bord avec le paramètre LookML link. L'exemple LookML suivant crée un menu d'analyse détaillée dans lequel un utilisateur peut afficher les données filtrées selon la dimension state:


dimension: state {
  type: string
  sql: ${TABLE}.state ;;
  link: {
    label: "Filter by {{ state | encode_uri }}"
    url: "filter::q={{ state | encode_uri }}"
    icon_url: "https://google.com/favicon.ico"
  }
}

Lorsque le filtre state est défini sur Illinois, l'événement drillmenu:click renvoie le code suivant à l'hôte de l'iFrame:

type: "drillmenu:click",
label: "Filter by Illinois",
link_type: "url",
modal: false,
target: '_self',
url: "#filter::state=Illinois"
context: ' '
Attribut Format Description
label String Libellé du lien affiché dans le menu d'analyse détaillée
link_type String Type d'objet à l'emplacement de destination du lien
modal Booléen Indique si la boîte de dialogue d'analyse détaillée sera utilisée à la place de la navigation du navigateur
target String Est _self si la destination du lien remplace l'iFrame actuel, _blank si la destination du lien ouvre une nouvelle fenêtre.
url String URL de la destination du lien.
context String Attribut interne utilisé par certains types de visualisations

Si l'iFrame est bac à sable, les clics du menu d'analyse détaillée ne s'ouvrent pas dans une nouvelle fenêtre. Utilisez les valeurs suivantes dans le tag iFrame:

sandbox = "allow-same-origin allow-scripts"

drillmodal:download

Cet événement est créé lorsqu'un utilisateur ouvre une boîte de dialogue d'analyse détaillée depuis une tuile de tableau de bord, puis clique sur l'option Télécharger.

{
type: "drillmodal:download",
dashboard: {
  id: 23,
  title: "My Dashboard",
  url: "/embed/dashboards/…",
  absoluteUrl: "https://instance_name.looker.com/embed/dashboards/…",
  dashboard_filters: {
    "Date": "Last 28 days",
    "Total Orders": "Greater than 100"
  }
}
drillExploreUrl: "/embed...",
fileFormat: "pdf"
}
Attribut Format Description
dashboard.id Nombre/Chaîne ID du tableau de bord auquel appartient la carte.
dashboard.title String Titre du tableau de bord, comme indiqué en haut du tableau de bord auquel la carte appartient.
dashboard.url String L'URL relative du tableau de bord (à savoir le chemin d'accès) auquel la carte appartient.
dashboard.absoluteUrl String URL complète du tableau de bord auquel appartient la carte.
dashboard.dashboard_filters Objet Filtres appliqués au tableau de bord auquel la carte appartient. Cet objet a le format suivant: {"Filter name 1": "value 1", "Filter name 2": "value 2", ...}
drillExploreUrl String URL d'exploration relative (uniquement le chemin d'accès) à télécharger.
fileFormat String Format de fichier de téléchargement des données.

drillmodal:explore

Cet événement est créé lorsqu'un utilisateur clique sur l'option Explorer à partir de cet emplacement dans une boîte de dialogue d'analyse détaillée.

type: "drillmodal:explore",
label: "Explore From Here",
url: "/embed/explore/model/view..."
Attribut Format Description
label String Libellé du bouton tel qu'il apparaît dans le menu d'analyse détaillée
url String URL d'exploration relative (juste le chemin d'accès) à afficher

explore:ready

Cet événement est créé lorsqu'un exploration commence à charger des données de requête, que la requête s'exécute ou non.

type: "explore:ready",
explore: {
  url: "/embed/explore/...",
  absoluteUrl: "https://instance_name.looker.com/embed/explore/...",
  }
}
Attribut Format Description
explore.url String L'URL d'exploration relative (juste le chemin d'accès)
explore.absoluteUrl String URL d'exploration complète

explore:run:start

Cet événement est créé lorsqu'un exploration commence à charger des données et que la requête commence à s'exécuter.

type: "explore:run:start",
explore: {
  url: "/embed/explore/...",
  absoluteUrl: "https://instance_name.looker.com/embed/explore/...",
  }
}
Attribut Format Description
explore.url String L'URL d'exploration relative (juste le chemin d'accès)
explore.absoluteUrl String URL d'exploration complète

explore:run:complete

Cet événement est créé lorsqu'une exploration a terminé d'exécuter la requête.

type: "explore:run:complete",
explore: {
  url: "/embed/explore/...",
  absoluteUrl: "https://instance_name.looker.com/embed/explore/...",
  }
}
Attribut Format Description
explore.url String L'URL d'exploration relative (juste le chemin d'accès)
explore.absoluteUrl String URL d'exploration complète

explore:state:changed

Cet événement est créé lorsqu'une URL de page "Explorer" change en raison des actions de l'utilisateur.

type: "explore:state:changed",
explore: {
  url: "/embed/explore/...",
  absoluteUrl: "https://instance_name.looker.com/embed/explore/..."
}
Attribut Format Description
explore.url String L'URL d'exploration relative (juste le chemin d'accès)
explore.absoluteUrl String URL d'exploration complète

page:changed

Cet événement est créé lorsqu'un utilisateur accède à une nouvelle page dans le cadre iFrame.

type: "page:changed",
page: {
  type: "dashboard",
  url: "/embed/dashboards/...",
  absoluteUrl: "https://instance_name.looker.com/embed/dashboards/..."
}
Attribut Format Description
page.type String Type de page auquel l'utilisateur vient d'accéder, par exemple "dashboard", "look" ou "explore"
page.url String URL relative (juste le chemin d'accès) de la page à laquelle l'utilisateur vient d'accéder
page.absoluteUrl String URL complète de la page à laquelle l'utilisateur vient d'accéder

page:properties:changed

Cet événement est créé lorsque la hauteur d'un iFrame de tableau de bord change. Elle n'est pas disponible pour les looks ni les explorations, car ces éléments ajustent automatiquement leur hauteur à la taille de l'iFrame.

type: "page:properties:changed",
height: 1000
Attribut Format Description
height Integer Hauteur en pixels du cadre iFrame du tableau de bord.

session:tokens

Cet événement indique que le client Looker a besoin de jetons pour continuer. Cet événement est créé dès la création de l'iFrame, puis de manière régulière, pendant toute la durée de la session.

{
  "type": "session:tokens",
  "api_token": "eyJhbGciOiJIUzI1NiJ9.eyJpc3MiOiJodHRwczovL3NlbGYtc2lnbmVkLmxvb2tlci5jb206OTk5OSIsImV4cCI6MTY3MDYyNjMzMCwic3ViIjoiYVdrNWFGUzM4RnRwNzFFWXhuS3ZaMXdKRmV3ZjB2VzYtTV9zLWtCcHE1dXIiLCJ0b2tlbl90eXBlIjoiYXBpX3Rva2VuIiwicmFuZG9taXplciI6IkxjYnpOeDNTVjNOb3o3UVlqTVJjNmhlMkdodjh1a2UwWUhiZWNRMHVCYm1KIn0.CBv1__QGc_H7bKNe31SHMMQCsc5ya1xOiEv1UDWAyxM",
  "api_token_ttl": 463,
  "navigation_token": "eyJhbGciOiJIUzI1NiJ9.eyJpc3MiOiJodHRwczovL3NlbGYtc2lnbmVkLmxvb2tlci5jb206OTk5OSIsImV4cCI6MTY3MDYyNjMzMCwic3ViIjoiYVdrNWFGUzM4RnRwNzFFWXhuS3ZaMXdKRmV3ZjB2VzYtTV9zLWtCcHE1dXIiLCJ0b2tlbl90eXBlIjoibmF2aWdhdGlvbl90b2tlbiIsInJhbmRvbWl6ZXIiOiJHVVNlc00tdTRPRDlNdktodFJDU2pEcVFhUkJNeTh5dm42Q1FDUXhuLTNxMiJ9.sWo7LUEI5LeragVmeDamUR7u2myXpFJ0aqK_IIALUqI",
  "navigation_token_ttl": 463,
  "session_reference_token_ttl": 2924
}
Attribut Format Description
authentication_token String Jeton d'authentification. Inclus lors de la création de l'iFrame. Non inclus dans la réponse à une requête de génération de jetons ou si la session a expiré
authentication_token_ttl Nombre Durée de conservation du jeton d'authentification en secondes. Inclus lors de la création de l'iFrame. Non inclus dans la réponse à une requête de génération de jetons ou si la session a expiré
api_token String Jeton d'API. Non inclus si la session a expiré.
api_token_ttl Nombre Durée de conservation du jeton d'API en secondes. Non inclus si la session a expiré.
navigation_token String Jeton de navigation. Non inclus si la session a expiré.
navigation_token_ttl Nombre Durée de conservation du jeton de navigation en secondes. Non inclus si la session a expiré.
session_references_token_ttl Nombre Durée de vie de la session en secondes. La valeur est égale à 0 lorsque la session a expiré. Pour récupérer, l'application d'intégration doit acquérir une nouvelle session.

session:status

L'événement est généré lorsque l'application Looker intégrée gère les requêtes de jetons de session.

{
  "type": "session:status",
  "session_ttl": 0,
  "expired": true,
  "interrupted": false
}
Attribut Format Description
session_ttl Nombre Durée de vie de la session en secondes.
expired Booléen Si la valeur est true, cela signifie que la session a expiré.
interrupted Booléen Si la valeur est true, cela signifie qu'une requête de jetons de session n'a pas reçu de réponse. Cela peut indiquer qu'un serveur est temporairement indisponible.
recoverable Booléen N'est renseigné que lorsqu'il est interrompu : true. Indique si la session peut être récupérée ou non. Une valeur false signifie probablement qu'il y a un problème avec l'application d'intégration.

env:client:dialog

L'événement est généré lorsqu'une boîte de dialogue (avec boîte d'analyse détaillée, par exemple) a été partiellement masquée. Cet événement permet à l'application d'hébergement de faire défiler la boîte de dialogue à l'aide de l'action env:host:scroll.

{
  type: "env:client:dialog",
  dialogType: 'drilling',
  placement: 'cover',
  open: true
}
Attribut Format Description
type String env:client:dialog indique qu'une boîte de dialogue a été ouverte ou fermée. Actuellement, seule la boîte de dialogue d'analyse détaillée est compatible, mais d'autres boîtes de dialogue pourront être ajoutées ultérieurement. Il est possible que le haut de la boîte de dialogue d'analyse détaillée ne soit pas visible, car il couvre la fenêtre d'affichage iFrame. Cet événement permet à l'application hôte de faire défiler la boîte de dialogue en haut.
dialogType String Type de boîte de dialogue. Pour le moment, seul l'ouverture ou la fermeture de la boîte de dialogue "Forage" déclenche cet événement.
placement String Emplacement de la boîte de dialogue. Les boîtes de dialogue de type "drilling" utilisent toujours un placement de "cover".
open Booléen Indique si la boîte de dialogue est ouverte ou défilée.

Modifier l'iFrame

Après avoir préparé votre iFrame pour la récupération de données, vous pouvez le modifier en procédant comme suit:

  1. Écrivez votre requête au format JSON.
  2. Publiez la requête sur le contentWindow de l'iFrame.

Écrire votre requête au format JSON

Vous pouvez apporter plusieurs modifications à l'iFrame, que vous envoyez au format JSON. Les options disponibles sont décrites dans la section Documentation de référence sur les actions de cette page. N'oubliez pas d'utiliser JSON.stringify pour transformer votre action au format JSON, comme ceci:

var my_request = JSON.stringify(
  {
    type: "dashboard:run"
  }
);

Publier la requête sur la propriété contentWindow de l'iFrame

Enfin, publiez votre message sur le contentWindow de l'iFrame, comme ceci:

var my_iframe = document.getElementById("my_iframe_id");

my_iframe.contentWindow.postMessage(my_request, 'https://instance_name.looker.com');

Tableau récapitulatif des actions

Le tableau suivant récapitule les actions. Cliquez sur une action pour en afficher les détails.

Action Description de l'action
dashboard:load Charge un nouveau tableau de bord dans le cadre iFrame, en remplaçant un tableau de bord existant.
dashboard:run Exécute le tableau de bord dans l'iFrame.
dashboard:edit ADDED 22.20 Passe le tableau de bord en mode Édition.
dashboard:filters:update Met à jour un filtre de tableau de bord existant dans le cadre iFrame.
dashboard:options:set Écrit de nouvelles valeurs dans les propriétés de mise en page et d'élément du tableau de bord.
dashboard:schedule_modal:open Ouvre le programmeur, qui permet aux utilisateurs de diffuser du contenu Looker vers différentes destinations.
dashboard:stop Arrête un tableau de bord en cours d'exécution ou actualise les données.
look:run Exécute l'aspect dans l'iFrame.
look:filters:update Met à jour un filtre "Apparence" existant dans le cadre iFrame.
explore:run Exécute l'exploration dans l'iFrame.
explore:filters:update Met à jour ou supprime un filtre Explorer existant dans le cadre iFrame.
session:tokens:request Envoie des jetons en réponse à un événement session:tokens:request.
env:host:scroll Envoie des informations sur la position de défilement actuelle de l'iFrame de l'hôte à l'application Looker intégrée.

Référence des actions

Voici les actions que vous pouvez publier dans l'iFrame intégré:

dashboard:load

Utilisez cette action pour charger un nouveau tableau de bord dans le cadre iFrame, en remplacement d'un tableau de bord existant. Le nouveau tableau de bord commencera à exécuter des requêtes comme si une nouvelle page de tableau de bord avait été ouverte.

{
  type: "dashboard:load",
  id: "101",
  pushHistory: false
}
Attribut Format Description
type String L'utilisation du type dashboard:load indique que vous souhaitez charger un nouveau tableau de bord dans le cadre iFrame.
id String ID du tableau de bord à charger.
pushHistory Booléen Si la valeur est true, le tableau de bord chargé crée une entrée d'historique de navigateur, et l'utilisateur peut utiliser le bouton "Retour" du navigateur pour revenir au tableau de bord précédent. Si la valeur est false, le tableau de bord actuel est remplacé et la navigation dans le navigateur ne peut pas être utilisée pour y revenir.

dashboard:run

Utilisez cette action pour exécuter le tableau de bord dans le cadre iFrame. Cela revient à appuyer sur le bouton Exécuter ou Actualiser les données du tableau de bord.

{
  type: "dashboard:run"
}
Attribut Format Description
type String L'utilisation du type dashboard:run indique que vous souhaitez exécuter le tableau de bord.

dashboard:edit

ADDED 22.20 Cette action permet de faire passer un tableau de bord existant dans le cadre iFrame en mode Édition. Cela revient à sélectionner Modifier le tableau de bord dans le menu.

{
  type: "dashboard:edit"
}
Attribut Format Description
type String L'utilisation du type dashboard:edit indique que vous souhaitez passer le tableau de bord en mode Édition.

dashboard:filters:update

Utilisez cette action pour mettre à jour un filtre de tableau de bord existant dans le cadre iFrame. Cette méthode ne vous permet pas d'ajouter un filtre au tableau de bord.

{
  type: "dashboard:filters:update",
  filters: {
    "Sale date": "Last 28 days",
    "Sale amount": "Greater than 100"
  }
}
Attribut Format Description
type String L'utilisation du type dashboard:filters:update indique que vous souhaitez mettre à jour les filtres utilisés par le tableau de bord.
filters Objet Nouveaux filtres que vous souhaitez appliquer au tableau de bord. Cet objet a le format suivant: {"Filter name 1": "value 1", "Filter name 2": "value 2", ...}

dashboard:options:set

Cette action est disponible après l'événement dashboard:run:complete.

L'intégrateur crée le message et l'envoie à l'iFrame, mais le tableau de bord ne répond qu'après le dashboard:run:complete. L'action dashboard:options:set écrit de nouvelles valeurs dans les propriétés de mise en page et d'élément du tableau de bord. Seules les propriétés renvoyées dans l'attribut options de l'événement dashboard:run:complete peuvent être mises à jour à l'aide de dashboard:options:set. Toutes les propriétés qui n'avaient pas été précédemment renvoyées par l'attribut options de l'événement dashboard:run:complete sont ignorées.

{
  type: "dashboard:options:set",
  layouts: [
    {
      id: 1,
      dashboard_id: 1,
      type: "newspaper",
      active: true,
      column_width: null,
      width: null,
      deleted: false,
      dashboard_layout_components: [
        {
          id: 1,
          dashboard_layout_id: 1,
          dashboard_element_id: 1,
          row: 0,
          column: 0,
          width: 8,
          height: 4,
          deleted: false
        },
        {
          id: 2,
          dashboard_layout_id: 1,
          dashboard_element_id: 2,
          row: 0,
          column: 8,
          width: 8,
          height: 4,
          deleted: false
        }
      ]
    }
  ],
  elements: {
    1: {
      title: "Total Orders",
      title_hidden: false,
      vis_config: {
        type: "single_value",
        font_size: "medium",
        title: "Total Orders"
      }
    },
    2: {
      title: "Average Order Profit",
      title_hidden: false,
      vis_config: {
        type: "single_value",
        title: "Average Order Profit"
      }
    }
  }
}
Attribut Format Description
type String L'utilisation du type dashboard:options:set indique que vous souhaitez écrire de nouvelles valeurs dans les propriétés de mise en page et d'élément du tableau de bord.
layouts Objet Propriétés de mise en page du tableau de bord renvoyées par l'attribut options dans l'événement dashboard:run:complete. Elles seront au format suivant:

id: "string",
dashboard_id: "string",
type: "newspaper",
active: boolean,
column_width: number,
width: number
layouts.dashboard_layout_components Objet Un ou plusieurs objets de composants de mise en page de tableaux de bord renvoyés par l'attribut options dans l'événement dashboard:run:complete Le format sera le suivant:

id: "string",
dashboard_layout_id: "string",
dashboard_element_id: "string",
row: number,
column: number,
width: number,
height: number,
deleted: boolean,
elements Objet Un ou plusieurs objets d'élément de tableau de bord renvoyés par l'attribut options dans l'événement dashboard:run:complete Le format sera le suivant:

id: {
  title: "string"

dashboard:schedule_modal:open

Cette action permet d'ouvrir le planificateur, qui permet aux utilisateurs de diffuser du contenu Looker vers différentes destinations.

{
  type: "dashboard:schedule_modal:open"
}
Attribut Format Description
type String L'utilisation du type dashboard:schedule_modal:open indique que vous souhaitez ouvrir la boîte de dialogue Schedule (Programmer).

dashboard:stop

Cette action vous permet d'arrêter un tableau de bord en cours d'exécution ou d'actualiser les données. Cela revient à cliquer sur le bouton Annuler du tableau de bord. Un tableau de bord qui n'utilise plus dashboard:stop envoie un événement dashboard:run:complete avec status: défini sur "stopped".

{
  type: "dashboard:stop"
}
Attribut Format Description
type String L'utilisation du type dashboard:stop indique que vous souhaitez arrêter le tableau de bord en cours d'exécution.

look:run

Utilisez cette action pour exécuter la requête sur laquelle est basé l'aspect dans le cadre iFrame. Cette méthode est semblable à l'utilisation du bouton Exécuter sur le look, à ceci près que look:run interroge toujours la base de données directement et ne récupère pas les données du cache Looker.

{
  type: "look:run"
}
Attribut Format Description
type String L'utilisation du type look:run indique que vous souhaitez exécuter le style.

look:filters:update

Utilisez cette action pour mettre à jour un filtre de style existant dans le cadre iFrame. Vous ne pouvez pas ajouter de filtre à l'aspect à l'aide de cette méthode.

{
  type: "look:filters:update",
  filters: {
    "orders.created_at": "90 days",
    "products.department": "sweaters"
  }
}
Attribut Format Description
type String L'utilisation du type look:filters:update indique que vous souhaitez mettre à jour les filtres utilisés par le look.
filters Objet Nouveaux filtres que vous souhaitez appliquer au style. Cet objet a le format suivant: {"view_name.field_name_1": "value 1", "view_name.field_name_1": "value 2", ...}

explore:run

Utilisez cette action pour exécuter Explorer dans le cadre iFrame. Cela revient à appuyer sur le bouton Exécuter de l'exploration, sauf que explore:run interroge toujours la base de données directement et ne récupère pas les données du cache Looker.

{
  type: "explore:run"
}
Attribut Format Description
type String L'utilisation du type explore:run indique que vous souhaitez exécuter l'exploration.

explore:filters:update

Utilisez cette action pour mettre à jour ou supprimer un filtre Explorer existant dans l'iFrame. Si vous ajoutez un nouveau filtre faisant référence à un champ valide, il sera ajouté à Explorer.

{
  type: "explore:filters:update",
  filters: {
    "orders.created_at": "90 days",
    "orders.status": "complete"
  }
  deleteFilters:  ["products.department"]
}
Attribut Format Description
type String L'utilisation du type explore:filters:update indique que vous souhaitez mettre à jour les filtres utilisés par Explorer.
filters Objet Nouveaux filtres que vous souhaitez appliquer à l'exploration. Si filters inclut un filtre qui n'existe pas actuellement dans l'exploration, mais qui fait référence à un champ valide, ce filtre sera ajouté à l'exploration. Cet objet a le format suivant: {"view_name.field_name_1": "value 1", "view_name.field_name_1": "value 2", ...}
deleteFilters Tableau Filtres existants que vous souhaitez supprimer de l'exploration. Le tableau a le format suivant: ["view_name.field_name_1", "view_name.field_name_2", ...]

session:tokens:request

Utilisez cette action pour envoyer des jetons en réponse à une requête session:tokens:request.

{
  type: "session:tokens:request",
}
Attribut Format Description
type String L'utilisation du type session:tokens:request indique que vous souhaitez envoyer des jetons en réponse à un événement session:tokens:request.

env:host:scroll

Cette action permet d'envoyer à l'application Looker intégrée des informations sur la position actuelle du défilement de l'iFrame de l'hôte.

{
  type: "env:host:scroll",
  offsetTop: 10,
  offsetLeft: 10,
  scrollX: 5,
  scrollY: 5
}
Attribut Format Description
type String L'utilisation du type env:host:scroll indique que vous souhaitez envoyer des informations sur la position actuelle de défilement de l'iFrame de l'hôte à l'application Looker intégrée.
offsetTop Nombre Décalage vers le haut de l'iFrame.
offsetLeft Nombre Décalage à gauche de l'iFrame.
scrollX Nombre Position de défilementX de l'hôte de l'application.
scrollY Nombre Position de défilement de l'hôte de l'application.