API de la barre d'outils Dev
L’API de la barre d’outils Dev d’Astro vous permet de créer des Intégrations Astro qui ajoutent des applications à la barre d’outils Astro Dev. Cela vous permet d’ajouter de nouvelles fonctionnalités et des intégrations avec des services tiers.
Configuration de l’intégration des applications dans la barre d’outils
Titre de la section Configuration de l’intégration des applications dans la barre d’outilsLes intégrations peuvent ajouter des applications à la barre d’outils de développement dans le hook astro:config:setup
.
addDevToolbarApp()
Titre de la section addDevToolbarApp()Une fonction disponible pour le hook astro:config:setup
qui ajoute les applications de la barre d’outils de développement. Elle prend un objet avec les propriétés suivantes pour définir l’application de la barre d’outils : id
, name
, icon
, et entrypoint
.
Un identifiant unique pour l’application. Il sera utilisé pour identifier l’application de manière unique dans les hooks et les événements.
Le nom de l’application. Il sera affiché aux utilisateurs chaque fois que l’application devra être référencée à l’aide d’un nom lisible par l’humain.
L’icône utilisée pour afficher l’application dans la barre d’outils. Il peut s’agir d’une icône de la liste des icônes, ou d’une chaîne de caractères contenant le balisage SVG de l’icône.
entrypoint
Titre de la section entrypointChemin d’accès au fichier qui exporte l’application de la barre d’outils de développement.
Ajouté à la version :
astro@5.0.0
La fonction accepte également une URL
comme point d’entrée (entrypoint
) :
Structure d’une application pour la barre d’outils de développement
Titre de la section Structure d’une application pour la barre d’outils de développementUne application de barre d’outils de développement est un fichier .js
ou .ts
qui exporte par défaut un objet en utilisant la fonction defineToolbarApp()
disponible dans le module astro/toolbar
.
defineToolbarApp()
Titre de la section defineToolbarApp()
Ajouté à la version :
astro@4.7.0
Une fonction qui définit la logique de votre application de barre d’outils lorsqu’elle est chargée et désactivée.
Cette fonction prend un objet avec une fonction init()
qui sera appelée lorsque l’application de la barre d’outils sera chargée. Elle peut également prendre une fonction beforeTogglingOff()
qui s’exécutera lorsque l’application de la barre d’outils sera cliquée pour désactiver son statut actif.
Signature : init(canvas: ShadowRoot, app: ToolbarAppEventTarget, server: ToolbarServerHelpers) => void
Bien que cela ne soit pas obligatoire, la plupart des applications utiliseront cette fonction pour définir le comportement de base de l’application. Cette fonction ne sera appelée qu’une seule fois lors du chargement de l’application, soit lorsque le navigateur est inactif, soit lorsque l’utilisateur clique sur l’application dans l’interface utilisateur, selon ce qui se produit en premier.
La fonction reçoit trois arguments pour définir la logique de votre application : canvas
(pour afficher les éléments à l’écran), app
(pour envoyer et recevoir des événements côté client depuis la barre d’outils de développement), et server
(pour communiquer avec le serveur).
Un ShadowRoot standard que l’application peut utiliser pour afficher son interface utilisateur. Les éléments peuvent être créés et ajoutés au ShadowRoot à l’aide des API DOM standard.
Chaque application reçoit son propre ShadowRoot dédié pour afficher son interface utilisateur. De plus, l’élément parent est positionné en utilisant position : absolute;
afin que l’interface utilisateur de l’application n’affecte pas la mise en page d’une page Astro.
Ajouté à la version :
astro@4.7.0
Une interface EventTarget
standard avec quelques aides pour les événements côté client supplémentaires qui peuvent être utilisés pour envoyer et recevoir des événements depuis la barre d’outils Dev.
Ajouté à la version :
astro@4.7.0
Un objet qui peut être utilisé pour communiquer avec le serveur.
beforeTogglingOff()
Titre de la section beforeTogglingOff()Signature : beforeTogglingOff(canvas: ShadowRoot): boolean | void
astro@4.7.0
Cette fonction facultative est appelée lorsque l’utilisateur clique sur l’icône de l’application dans l’interface utilisateur pour la désactiver. Cette fonction peut être utilisée, par exemple, pour effectuer des opérations de nettoyage ou pour demander à l’utilisateur une confirmation avant de désactiver l’application.
Si une valeur fausse est renvoyée, la désactivation sera annulée et l’application restera activée.
Le ShadowRoot de l’application, peut être utilisé pour afficher toute interface utilisateur nécessaire avant la fermeture. Identique à l’argument canvas
de la fonction init
.
Événements côté client
Titre de la section Événements côté clientEn plus des méthodes standards d’une EventTarget
(addEventListener
, dispatchEvent
, removeEventListener
, etc.), l’objet app
possède aussi les méthodes suivantes :
onToggled()
Titre de la section onToggled()Signature : onToggled(callback: (options: {state: boolean})) => void
astro@4.7.0
Enregistre un rappel à appeler lorsque l’utilisateur clique sur l’icône de l’application dans l’interface utilisateur pour activer ou désactiver l’application.
onToolbarPlacementUpdated()
Titre de la section onToolbarPlacementUpdated()Signature : onToolbarPlacementUpdated(callback: (options: {placement: 'bottom-left' | 'bottom-center' | 'bottom-right'})) => void
astro@4.7.0
Cet événement est déclenché lorsque l’utilisateur modifie l’emplacement de la barre d’outils de développement. Il peut, par exemple, être utilisé pour repositionner l’interface utilisateur de l’application lorsque la barre d’outils est déplacée.
toggleState()
Titre de la section toggleState()Signature : toggleState(options: {state: boolean}) => void
astro@4.7.0
Modifie l’état de l’application. Cela peut être utilisé pour activer ou désactiver l’application de manière programmatique, par exemple, lorsque l’utilisateur clique sur un bouton dans l’interface utilisateur de l’application.
toggleNotification()
Titre de la section toggleNotification()Signature : toggleNotification(options: {state?: boolean, level?: 'error' | 'warning' | 'info'}) => void
astro@4.7.0
Permet d’afficher une notification sur l’icône de l’application. Elle peut être utilisée pour informer l’utilisateur que l’application requiert son attention ou pour supprimer la notification en cours.
state: boolean
Titre de la section state: booleanIndique si l’application a une notification pour l’utilisateur. Lorsque true
, l’icône de l’application sera mise en évidence. Inversement, lorsque false
, la mise en évidence sera supprimée. Si cette propriété n’est pas spécifiée, true
sera pris en compte.
level: 'error' | 'warning' | 'info'
Titre de la section level: 'error' | 'warning' | 'info'Indique le niveau de la notification. Il sera utilisé pour déterminer la couleur et la forme (cercle rose foncé, triangle doré ou carré bleu) de la surbrillance sur l’icône de l’application. Si cette propriété n’est pas spécifiée, 'error'
sera pris en compte.
Communication client-serveur
Titre de la section Communication client-serveurEn utilisant les méthodes de communication client-serveur de Vite, les applications de la barre d’outils Dev et le serveur peuvent communiquer entre eux. Afin de faciliter l’envoi et la réception de messages personnalisés, des méthodes d’aide sont fournies pour être utilisées à la fois dans votre application de barre d’outils (sur le client) et dans votre intégration (sur le serveur).
Sur le client
Titre de la section Sur le clientDans votre application, utilisez l’objet server
sur le hook init()
pour envoyer et recevoir des messages vers et depuis le serveur.
Signature : send<T>(event: stringify, data: T) => void
astro@4.7.0
Envoie des données au serveur à partir de la logique définie dans l’application de la barre d’outils.
Lors de l’envoi de messages du client au serveur, il est conseillé de préfixer le nom de l’événement avec l’identifiant de l’application ou d’autres espaces de noms afin d’éviter les conflits avec d’autres applications ou d’autres intégrations qui pourraient être à l’écoute de messages.
Signature : on<T>(event: string, callback: (data: T) => void) => void
astro@4.7.0
Enregistre un rappel à appeler lorsque le serveur envoie un message avec l’événement spécifié.
Sur le serveur
Titre de la section Sur le serveurDans une intégration, telle que l’intégration qui ajoute votre application de barre d’outils, utilisez le hook astro:server:setup
pour accéder à l’objet toolbar
afin d’envoyer et de recevoir des messages vers et à partir de vos applications.
Signature : send<T>(event: string, data: T) => void
astro@4.7.0
Envoie des données au client.
Signature : on<T>(event: string, callback: (data: T) => void) => void
astro@4.7.0
Enregistre un callback qui sera appelé lorsque le client enverra un message avec l’événement spécifié.
onInitialized()
Titre de la section onInitialized()Signature : onInitialized(appId: string, callback: () => void) => void
astro@4.7.0
Enregistre un callback qui sera appelé lors de l’initialisation de l’application.
L’événement intégré connection
de Vite se déclenche avant que les applications de la barre d’outils Dev ne soient initialisées et ne peut donc pas être utilisé directement par les applications. Utilisez la méthode onInitialized
pour vous assurer que l’application est complètement initialisée avant de lui envoyer des messages.
onAppToggled()
Titre de la section onAppToggled()Signature : onAppToggled(appId: string, callback: (options: {state: boolean}) => void) => void
astro@4.7.0
Enregistre une fonction de rappel à appeler lorsque l’utilisateur clique sur l’icône de l’application dans l’interface utilisateur pour activer ou désactiver l’application.
Bibliothèque de composants
Titre de la section Bibliothèque de composantsLa barre d’outils Dev comprend un ensemble de composants web qui peuvent être utilisés pour créer des applications avec une apparence et une convivialité cohérentes.
astro-dev-toolbar-window
Titre de la section astro-dev-toolbar-windowAffiche une fenêtre.
Le slot du composant sera utilisé comme contenu de la fenêtre.
Lors de la construction d’une fenêtre à l’aide de JavaScript, le contenu des slots doit être placé à l’intérieur du DOM allégé du composant.
astro-dev-toolbar-button
Titre de la section astro-dev-toolbar-buttonAffiche un bouton.
L’emplacement du composant sera utilisé comme contenu du bouton.
La taille du bouton (small
, medium
, large
).
button-style
Titre de la section button-styleLe style du bouton (ghost
, outline
, purple
, gray
, red
, green
, yellow
, blue
). En utilisant ghost
, le bouton lui-même est invisible et seul le contenu du bouton est affiché.
En JavaScript, définissez cette propriété en utilisant la propriété buttonStyle
pour éviter tout conflit avec la propriété native style
.
button-border-radius
Titre de la section button-border-radius
Ajouté à la version :
astro@4.8.0
Le rayon de la bordure du bouton (normal
, rounded
). Si vous utilisez rounded
, le bouton aura des coins arrondis et un rembourrage uniforme sur tous les côtés.
En JavaScript, définissez cette propriété à l’aide de la propriété buttonBorderRadius
.
astro-dev-toolbar-badge
Titre de la section astro-dev-toolbar-badgeAffiche un badge.
L’emplacement du composant sera utilisé comme contenu du badge.
La taille du badge (small
, large
).
badge-style
Titre de la section badge-styleLe style (couleur) du badge (purple
, gray
, red
, green
, yellow
, blue
).
En JavaScript, définissez cette propriété en utilisant la propriété badgeStyle
pour éviter tout conflit avec la propriété native style
.
astro-dev-toolbar-card
Titre de la section astro-dev-toolbar-cardMontre une carte. Spécifiez un attribut link
facultatif pour que la carte agisse comme un élément <a>
.
Lors de la création d’une carte à l’aide de JavaScript, une propriété clickAction
peut être spécifiée pour que la carte se comporte comme un élément <button>
.
L’emplacement du composant sera utilisé comme contenu de la carte.
card-style
Titre de la section card-styleLe style de la carte (purple
, gray
, red
, green
, yellow
, blue
). La couleur n’est appliquée au bord de la carte qu’au survol.
En JavaScript, définissez cette propriété à l’aide de cardStyle
.
astro-dev-toolbar-toggle
Titre de la section astro-dev-toolbar-toggleAffiche un élément à bascule, agissant comme une case à cocher. Cet élément est une simple enveloppe autour de l’élément natif <input type="checkbox">
. L’élément checkbox est accessible à l’aide de la propriété input
.
astro-dev-toolbar-radio-checkbox
Titre de la section astro-dev-toolbar-radio-checkbox
Ajouté à la version :
astro@4.8.0
Affiche une case à cocher de type radio. Similaire au composant astro-dev-toolbar-toggle
, cet élément est une simple enveloppe autour d’un élément natif <input type="radio">
. L’élément radio est accessible à l’aide de la propriété input
.
toggle-style
Titre de la section toggle-styleLe style du menu déroulant (purple
, gray
, red
, green
, yellow
, blue
).
En JavaScript, définissez cette propriété à l’aide de la propriété toggleStyle
.
astro-dev-toolbar-highlight
Titre de la section astro-dev-toolbar-highlightPeut être utilisé pour mettre en évidence un élément sur la page. Dans la plupart des cas, vous devrez positionner et redimensionner cet élément en utilisant les propriétés CSS top
, left
, width
et height
pour qu’il corresponde à l’élément que vous souhaitez mettre en évidence.
Le style de la mise en évidence (purple
, gray
, red
, green
, yellow
, blue
).
Une icône à afficher dans le coin supérieur droit de la surbrillance.
astro-dev-toolbar-tooltip
Titre de la section astro-dev-toolbar-tooltipAffiche une infobulle avec différentes sections. Ce composant est réglé sur display : none;
par défaut et peut être rendu visible en utilisant l’attribut data-show="true"
.
Les sections sont définies à l’aide de la propriété sections
. Cette propriété est un tableau d’objets ayant la forme suivante :
Ce composant est souvent combiné avec le composant astro-dev-toolbar-highlight
pour afficher une infobulle au survol d’un élément mis en évidence :
astro-dev-toolbar-icon
Titre de la section astro-dev-toolbar-iconAffiche une icône. Une icône de la liste des icônes peut être spécifiée en utilisant l’attribut icon
, ou le balisage SVG d’une icône peut être passé en tant que slot.
Les icônes suivantes sont actuellement disponibles et peuvent être utilisées dans tout composant acceptant une icône :
astro:logo
warning
arrow-down
bug
file-search
check-circle
gear
lightbulb
checkmark
dots-three
copy
Toutes les icônes ci-dessus utilisent fill="currentColor"
par défaut et héritent de la couleur de l’élément parent.