Utiliser la mise en forme avancée

Vous pouvez utiliser des expressions Arcade pour la mise en forme avancée des éléments de liste, d’indicateur et de table afin de personnaliser le mode de rendu des points de données. Un point de données peut représenter une entité ou des résumés statistiques, selon la façon dont l’élément est configuré. Lorsque des entités sont utilisées, un point de données unique représente une entité unique. Lorsqu’une statistique est utilisée, chaque point de données représente le résultat de cette statistique. L’élément de liste rend les points de données de votre entité sous la forme d’éléments de ligne, chaque ligne représentant un point de données. L’élément d’indicateur rend un point de données à la fois. L’élément tabulaire rend les points de données d’entités sous la forme de lignes, et permet de contrôler le contenu et de mettre en forme chaque cellule de la ligne.

Contrairement aux expressions attributaires (utilisées dans les fenêtres contextuelles, les styles et les étiquettes d’une couche), une expression unique est créée pour chaque élément. L’expression est exécutée pour chaque point de données et renvoie pour cet élément des propriétés définies par le système et définies par l’utilisateur. Les propriétés définies par le système sont les paramètres que vous configureriez normalement dans un élément (par exemple, la couleur du texte et de l’arrière-plan). Les propriétés définies par l’utilisateur sont définies par l’utilisateur dans l’expression et peuvent être référencées pendant la configuration de l’élément.

Remarque :

Les expressions attributaires créées sur les cartes Web ne sont pas transférées pour être utilisées dans les éléments de tableau de bord.

Le tableau suivant récapitule les données de votre couche qui seront transmises à l’expression :

Nom de variableTypeDescription

$datapoint

Entité ou dictionnaire

S’applique à l’indicateur, à la table et à la liste.

$reference

Dictionnaire

S’applique à l’indicateur.

Remarque :
Gardez les points suivants à l’esprit lorsque vous rédigez des expressions Arcade :
  • Incluez une virgule après chaque propriété dans un dictionnaire, sauf pour la dernière propriété.
  • Les noms attributaires ne doivent pas contenir d’espaces ni de caractères spéciaux.

Mettre en forme des listes

Pour l’élément de liste, vous pouvez utiliser des expressions Arcade en activant l’option Advanced formatting (Mise en forme avancée). Une fois que vous avez choisi d’utiliser la mise en forme avancée, les entrées de couleur ne sont plus disponibles, ni les autres propriétés définies par le système.

L’expression, qui est exécutée pour chaque élément de ligne, est utilisée pour définir la manière dont chaque ligne de votre liste est rendue. De plus, une expression peut être utilisée pour créer des attributs pouvant être référencés dans le modèle d’élément de ligne.

Les attributs de point de données peuvent être référencés à l’aide de la variable globale $datapoint dans l’éditeur Arcade. Le tableau suivant fournit la liste des propriétés pouvant être retournées depuis l’expression sous la forme d’un dictionnaire :

PropriétéType de valeurDescription

textColor

Chaîne

Couleur de texte de base de l’élément de ligne

backgroundColor

Chaîne

Couleur d’arrière-plan de l’élément de ligne

separatorColor

Chaîne

Couleur de bordure inférieure de l’élément de ligne

selectionTextColor

Chaîne

Couleur utilisée pour le texte de l’élément de ligne lorsque l’élément est sélectionné

selectionColor

Chaîne

Couleur de texte de base utilisée lorsque l’élément est sélectionné

attributs

Dictionnaire

Dictionnaire de paires attribut-valeur

yourAttributeName

Chaîne, Nombre, Date, Booléen

Attribut pouvant être référencé dans le modèle de ligne d’élément à l’aide de la syntaxe {expression/votreNomAttributaire}

Remarque :

Les fonctions de géométrie ne sont pas prises en charge.

Par exemple, si vous souhaitez que la couleur d’arrière-plan de votre liste devienne rouge lorsque la valeur dépasse un certain seuil, vous pouvez créer une variable semblable à ce qui suit :

var color = IIF($datapoint.fieldName>[threshold], '#F3DED7','')

Dans cette variable, fieldName est le champ de vos valeurs et [threshold] la valeur à laquelle vous souhaitez que la couleur d’arrière-plan change. La variable peut être utilisée comme une valeur de propriété, comme dans l’exemple suivant :

backgroundColor: color,

Utiliser cette variable dans la propriété de couleur d’arrière-plan donne une expression semblable à la suivante, dans laquelle la couleur d’arrière-plan de l’élément de liste devient rouge lorsque la valeur de vitesse dépasse 40 :

var color = IIF($datapoint.Speed > 40, '#F3DED7', '');

return {
	backgroundColor: color
}

Activer la mise en forme avancée dans une liste

Pour activer la mise en forme avancée dans un élément de liste, procédez comme suit :

  1. Dans la fenêtre de configuration de la liste, cliquez sur l’onglet List (Liste).
  2. Dans la section Advanced formatting (Mise en forme avancée), cliquez sur Enable (Activer).
    Remarque :
    Une fois la mise en forme avancée activée, les paramètres définis par le système comme les couleurs en entrée ne sont plus disponibles. Ces configurations sont établies dans votre expression. Si vous avez entré des valeurs avant d’activer la mise en forme avancée, ces valeurs sont automatiquement ajoutées à votre expression.
  3. Créez votre expression de mise en forme dans l’éditeur.
    Conseil :
    Si vous avez besoin d’aide avec des fonctions Arcade, cliquez sur le bouton Information en regard de la fonction pour afficher des détails supplémentaires.
  4. Si vous souhaitez que votre expression s’exécute à un intervalle spécifié (par exemple, si elle utilise la fonction Now()), activez le bouton radio Refresh script (Actualiser le script) et définissez un intervalle d’actualisation.
  5. Saisissez les nouveaux attributs dans le champ Line item template (Modèle d’élément de ligne) en utilisant la syntaxe {expression/votreNomAttributaire}.

Mettre en forme des indicateurs

Pour l’élément d’indicateur, vous pouvez utiliser des expressions Arcade en activant l’option Advanced formatting (Mise en forme avancée). Une fois que vous avez choisi d’activer la mise en forme avancée, les propriétés définies par le système (par exemple, les options de couleur et la mise en forme de valeur) ne sont plus disponibles et la mise en forme conditionnelle est désactivée. L’expression est utilisée pour définir ces propriétés de rendu et cette logique conditionnelle. En outre, une expression peut transmettre des attributs définis par l’utilisateur à référencer dans les champs Title (Titre) et Description de l’onglet General (Général).

Lorsque vous incluez une valeur de référence dans votre indicateur, seul un type de référence basé sur une statistique est disponible dans l’onglet Data (Données) une fois la mise en forme avancée activée. Si vous avez précédemment défini un type de référence de valeur fixe, celui-ci est automatiquement ajouté à l’expression, avec les facteurs de conversion, le texte et la mise en forme de couleur. La mise en forme de valeur effectuée avant l’activation de la mise en forme avancée est supprimée et doit être définie dans l’expression à l’aide de modèles de valeur.

Remarque :

La valeur précédente n’est pas prise en charge dans Arcade. Si vous avez défini un type de référence de valeur précédent avant d’activer la mise en forme avancée, celui-ci sera converti dans la valeur actuelle.

Les attributs de point de données peuvent être référencés à l’aide de la variable globale $datapoint dans l’éditeur Arcade. Selon que le type de valeur est Entité ou Statistique, $datapoint est de type entité ou dictionnaire, respectivement. Si une statistique de référence a été configurée dans l’onglet Data (Données), la variable globale $reference sera également disponible dans l’éditeur.

Le tableau suivant fournit la liste des propriétés pouvant être retournées depuis l’expression sous la forme d’un dictionnaire :

PropriétéType de valeurDescription

textColor

Chaîne

Couleur de texte de base de l’élément d’indicateur

backgroundColor

Chaîne

Couleur d’arrière-plan de l’élément d’indicateur

topText

Chaîne

S’affiche en tant que texte supérieur

topTextColor

Chaîne

Couleur du texte supérieur

topTextOutlineColor

Chaîne

Couleur de contour du texte supérieur

topTextMaxSize

Chaîne

Taille de texte supérieur maximale (xx-petite | x-petite | petite | moyenne | grande | x-grande | xx-grande)

middleText

Chaîne

S’affiche en tant que texte central

middleTextColor

Chaîne

Couleur du texte central

middleTextOutlineColor

Chaîne

Couleur de contour du texte central

middleTextMaxSize

Chaîne

Taille de texte central maximale (xx-petite | x-petite | petite | moyenne | grande | x-grande | xx-grande)

bottomText

Chaîne

S’affiche en tant que texte inférieur

bottomTextColor

Chaîne

Couleur du texte inférieur

bottomTextOutlineColor

Chaîne

Couleur de contour du texte inférieur

bottomTextMaxSize

Chaîne

Taille de texte inférieur maximale (xx-petite | x-petite | petite | moyenne | grande | x-grande | xx-grande)

iconName

Chaîne

Nom de l’icône définie pour l’indicateur

Remarque :

Les noms d’icône sont définis hors de l’expression.

iconAlign

Chaîne

Placement de l’icône adjacent au texte central (gauche | droit)

iconColor

Chaîne

Couleur de remplissage de l’icône

iconOutlineColor

Chaîne

Couleur de contour de l’icône

noValue

Booléen

Drapeau indiquant d’afficher un texte sans valeur au lieu de l’indicateur (vrai | faux)

attributs

Dictionnaire

Dictionnaire de paires attribut-valeur

yourAttributeName

Chaîne, Nombre, Date, Booléen

Attribut pouvant être référencé dans les champs Title (Titre) et Description à l’aide de la syntaxe {expression/votreNomAttributaire}

Par exemple, si vous possédez un indicateur affichant une valeur dans une unité de mesure mais souhaitez également afficher la même valeur dans une autre unité en dessous, vous pouvez créer une variable pour convertir vos valeurs existantes. Avec un indicateur affichant les températures moyennes en degrés Celsius, vous pouvez créer une variable Fahrenheit à utiliser dans votre expression pour afficher également vos valeurs en Fahrenheit.

var fahrenheit = Floor(($datapoint.avg_Temperature/5*9)+32)

Vous pouvez ensuite inclure la variable en tant que valeur de propriété, par exemple comme suit :

bottomText: fahrenheit,

Utiliser cette variable dans la propriété de texte inférieur donne une expression semblable à la suivante, où la température moyenne (en degrés Celsius) est affichée dans le texte central de l’indicateur et la valeur Fahrenheit affichée dans le texte inférieur :

var farenheit = Floor(($datapoint.avg_Temperature/5*9)+32)

return {
	topText: 'Average Temperature',
	middleText: Floor($datapoint.avg_Temperature),
	bottomText: farenheit,
}

Utiliser la mise en forme avancée dans un indicateur

Pour activer la mise en forme avancée dans un élément d’indicateur, procédez comme suit :

  1. Dans la fenêtre de configuration de l’indicateur, cliquez sur l’onglet Indicator (Indicateur).
  2. Dans la section Advanced formatting (Mise en forme avancée), cliquez sur Enable (Activer).
    Remarque :
    Une fois la mise en forme avancée activée, les paramètres définis par le système comme les couleurs en entrée ne sont plus disponibles. Ces configurations sont établies dans votre expression. Si vous avez entré des valeurs avant d’activer la mise en forme avancée, ces valeurs sont automatiquement ajoutées à votre expression.
  3. Créez votre expression de mise en forme dans l’éditeur.
    Conseil :
    Si vous avez besoin d’aide avec des fonctions Arcade, cliquez sur le bouton Information en regard de la fonction pour afficher des détails supplémentaires.
  4. Si vous souhaitez que votre expression s’exécute à un intervalle spécifié (par exemple, si elle utilise la fonction Now()), activez le bouton radio Refresh script (Actualiser le script) et définissez un intervalle d’actualisation.
  5. Vous pouvez également faire référence aux nouveaux attributs dans les champs Title (Titre) et Description en utilisant la syntaxe {expression/votreNomAttributaire}.

Mettre en forme des tables

Pour l’élément tabulaire, vous pouvez utiliser une expression Arcade en activant l’option Advanced formatting (Mise en forme avancée). Une fois que vous avez opté pour la mise en forme avancée, les entrées de couleur, les options d’alignement de texte et d’autres propriétés définies par le système ne sont plus disponibles et sont définies dans l’expression.

L’expression, qui est exécutée pour chaque ligne de la table, est utilisée pour définir le contenu et la mise en forme de chaque cellule dans la colonne. Les attributs de point de données peuvent être référencés à l’aide de la variable globale $datapoint dans l’éditeur Arcade.

Le dictionnaire cells doit comporter une propriété pour chaque champ défini sur l’onglet Data (Données) de la configuration de la table. Par exemple, dans une table de valeurs regroupées qui comporte un champ de catégorie pour Zone, et un champ de valeur pour Transaction Amounts (Montants de transaction), le dictionnaire cells contient deux propriétés : zone et sum_transaction_amounts.

Le tableau suivant fournit la liste des propriétés pouvant être retournées depuis l’expression sous la forme d’un dictionnaire :

PropriétéType de valeurDescription

cellules

Dictionnaire

Dictionnaire des noms de colonne basés sur les champs définis sur l’onglet Data (Données)

displayText

Chaîne

Texte affiché dans la cellule

Remarque :

La propriété displayText est obligatoire.

hoverText

Chaîne

Texte qui apparaît lors du survol des valeurs.

Remarque :

Le texte de survol doit être activé au préalable dans l’onglet Table.

textColor

Chaîne

Couleur du texte de la cellule

backgroundColor

Chaîne

Couleur d’arrière-plan de la cellule

textAlign

Chaîne

Alignement (gauche | centre | droite)

iconName

Chaîne

Nom de l’icône définie pour la table

Remarque :

Les noms d’icône sont définis hors de l’expression.

iconAlign

Chaîne

Placement de l’icône adjacent au texte de la cellule (gauche | droite)

iconColor

Chaîne

Couleur de remplissage de l’icône

iconOutlineColor

Chaîne

Couleur de contour de l’icône

Vous pouvez également utiliser une mise en forme avancée pour créer une mise en forme conditionnelle de votre table. Par exemple, si une de vos tables affiche des requêtes de réparation récentes, vous pouvez appliquer une mise en forme conditionnelle pour distinguer le statut des requêtes. Vous pouvez créer une variable qui change la couleur de la cellule en fonction du statut à l’aide d’une variable similaire à l’exemple suivant :

var statusColor = When($datapoint.status== 'new', 'yellow', $datapoint.status== 'closed', 'lightgray', 'white')

Vous pouvez ensuite affecter la variable à la propriété backgroundColor pour faire en sorte que les cellules soient mises en surbrillance dans le cas de nouveaux incidents et que cette mise en évidence soit annulée pour les incidents clos.

var statusColor = When(
	$datapoint.status == 'new', 'yellow',
	$datapoint.status == 'closed', lightgray', 'white')

return {
	cells:{
		requests:{
			displayText: <span>${$datapoint.requests}</span>, 
			backgroundColor: statusColor,
			}
		}
	}
Remarque :

Les expressions ne sont pas appliquées à la ligne de résumé d’une table.

Activer la mise en forme avancée dans une table

Pour activer la mise en forme avancée dans un élément tabulaire, procédez comme suit :

  1. Dans la fenêtre de configuration de la table, cliquez sur l’onglet Values (Valeurs).
  2. Dans la section Advanced formatting (Mise en forme avancée), cliquez sur Enable (Activer).
    Remarque :
    Une fois la mise en forme avancée activée, les paramètres définis par le système comme les couleurs en entrée ne sont plus disponibles. Ces configurations sont établies dans votre expression. Si vous avez entré des valeurs avant d’activer la mise en forme avancée, ces valeurs sont automatiquement ajoutées à votre expression.
  3. Créez votre expression de mise en forme dans l’éditeur.
    Conseil :
    Si vous avez besoin d’aide avec des fonctions Arcade, cliquez sur le bouton Information en regard de la fonction pour afficher des détails supplémentaires.
  4. Si vous souhaitez que votre expression s’exécute à un intervalle spécifié (par exemple, si elle utilise la fonction Now()), activez le bouton radio Refresh script (Actualiser le script) et définissez un intervalle d’actualisation.

Définir les noms d’icône

Les éléments d’indicateur et tabulaires vous permettent d’inclure des icônes au format SVG dans la configuration de votre élément. Lorsque vous utilisez la mise en forme avancée, des icônes sont ajoutées dans votre expression Arcade.

Pour ajouter une icône à votre expression Arcade, procédez comme suit :

  1. Dans la section Icons (Icônes), sous l’éditeur Arcade, cliquez sur Add (Ajouter).
  2. Sélectionnez une icône ou créez une icône personnalisée.
  3. Saisissez un nom pour l’icône.
  4. Dans votre expression Arcade, indiquez le nom de votre icône comme valeur renvoyée par la propriété iconName.

Valeurs de couleur

Lorsque vous incluez des valeurs de couleur dans une expression, ces valeurs doivent être renvoyées en tant que chaînes (entourées de guillemets). Les valeurs de couleur non définies ou non valides utiliseront automatiquement les valeurs par défaut. Les types de valeur de couleur acceptés incluent les valeurs hexadécimales, RGB, RGBA, HSL et HSLA. Voici quelques exemples avec les syntaxes prises en charge :

  • Hexadécimal
    • #090
    • #009900
    • #090a
    • #009900aa
  • RGB et RGBA
    • rgb(34, 12, 64)
    • rgba(34, 12, 64, 0.6)
  • HSL et HSLA
    • hsl(50, 33%, 25%)
    • hsla(50, 33%, 25%, 0.75)