Différences
Ci-dessous, les différences entre deux révisions de la page.
Les deux révisions précédentesRévision précédenteProchaine révision | Révision précédente | ||
yad_yet_another_dialog [Le 15/07/2018, 14:36] – [Exemples] LukePerp | yad_yet_another_dialog [Le 23/02/2021, 09:03] (Version actuelle) – [États de sorties] christophe c | ||
---|---|---|---|
Ligne 1: | Ligne 1: | ||
+ | {{tag> | ||
+ | |||
+ | ---- | ||
+ | |||
+ | ====== YAD ====== | ||
+ | |||
+ | // | ||
+ | |||
+ | **Yad** (« Yet Another Dialog », « encore une boîte de dialogue ») est un outil pour créer des boîtes de dialogue graphiques à partir de scripts shell. | ||
+ | |||
+ | **Yad** est un fork de [[: | ||
+ | Ses avantages par rapport à Zenity sont l' | ||
+ | |||
+ | ===== Auteurs ===== | ||
+ | Yad a été écrit par Victor Ananjevsky. | ||
+ | |||
+ | L' | ||
+ | ===== Pré-requis ===== | ||
+ | |||
+ | * Disposer des [[: | ||
+ | * Disposer d'une connexion à Internet configurée et activée. | ||
+ | * Avoir activé l' | ||
+ | |||
+ | ===== Installation ===== | ||
+ | ==== Version des dépôts ==== | ||
+ | Pour installer ce logiciel, il suffit d' | ||
+ | |||
+ | ==== Avec un ppa ==== | ||
+ | Pour installer une version récente de YAD, vous pouvez installer YAD avec le PPA de webupd8, en une ligne : | ||
+ | < | ||
+ | |||
+ | ==== Par compilation ==== | ||
+ | < Pour les utilisateurs avancés > | ||
+ | **Yad** évolue très vite, il peut être utile de compiler la dernière version. | ||
+ | |||
+ | Pour satisfaire les dépendances, | ||
+ | |||
+ | Vous devrez peut-être installer gcc, libwebkitgtk-dev | ||
+ | |||
+ | Pour avoir la dernière version, télécharger l' | ||
+ | Décompressez-la ou vous voulez. | ||
+ | Ouvrez un terminal | ||
+ | < | ||
+ | cd / | ||
+ | ./configure | ||
+ | make | ||
+ | sudo make install | ||
+ | </ | ||
+ | < | ||
+ | L' | ||
+ | Il vous faut également activer le widget --html. | ||
+ | Procèder comme suit pour les installer. | ||
+ | </ | ||
+ | < | ||
+ | cd / | ||
+ | ./configure --enable-icon-browser --enable-html | ||
+ | make | ||
+ | sudo make install | ||
+ | </ | ||
+ | |||
+ | ===== Utilisation ===== | ||
+ | ==== Types de fenêtres ==== | ||
+ | Yad permet d' | ||
+ | |||
+ | ^ Type de fenêtre | ||
+ | | Sélection | ||
+ | | Sélection | ||
+ | | Sélection | ||
+ | | Sélection | ||
+ | | Selection | ||
+ | | Entrée | ||
+ | | Entrée |'' | ||
+ | | Entrée |'' | ||
+ | | Affichage | | Affiche une boîte de dialogue (Peut être utilisé pour des informations ou des erreurs.).| | ||
+ | | Affichage | ||
+ | | Affichage | ||
+ | | Affichage | ||
+ | | Affichage | ||
+ | | Affichage | ||
+ | | Affichage | ||
+ | | Affichage | ||
+ | | Affichage | ||
+ | | Multiples | ||
+ | | Multiples | ||
+ | | Multiple |'' | ||
+ | |||
+ | |||
+ | [[http:// | ||
+ | |||
+ | ==== Types de champs de la fenêtre form (formulaire) ==== | ||
+ | Les formulaires permettent de décliner les différentes options de yad dans la même fenêtre. | ||
+ | Les types de champs de formulaire sont saisis sous la forme | ||
+ | --field=" | ||
+ | Les types de champs sont les suivants : H, RO, NUM, CHK, CB, CBE, CE, FL, SFL, DIR, CDIR, FN, MFL, MDIR, DT, SCL, CLR, BTN, FBTN, LBL, TXT. || | ||
+ | ^Type de champ^ Utilisation^ | ||
+ | | |Les entrées de formulaire non typées sont traitées comme des entrées texte simple (Type CE).| | ||
+ | |BTN |Champ bouton libre. L’étiquette du bouton est un texte saisi selon la convent d’écriture suivante : Etiquette[!Icone[!Infobulle]]. Le séparateur est le caractère !. (point d’exclamation). L’étiquette est un texte ou un identifiant gtk. Icône est un fichier icône (identifiant ou nom de fichier). L’infobulle est un paramètre optionnel correspondant à une fenêtre surgissante d’aide qui apparaît au survol du bouton. Il est possible d’affecter une commande au bouton. Dans ce cas, le symbole spécial%N d’une commande est remplacé par la valeur du champ N. Si la commande débute par le caractère @ (arobase), la sortie de la commande sera parsée et les lignes qui débutent par des nombres et des colonnes seront traitées comme les valeurs de nouveaux champs.| | ||
+ | |CB |Boîte déroulante. Les valeurs possibles sont saisies sous la forme VAL1!VAL2 !… Le séparateur est identique au séparateur des champs numériques. La valeur précédée du caractère ∧ correspond à la valeur par défaut.| | ||
+ | |CBE |Boîte déroulante éditable. Valeurs initiales saisies selon les mêmes règles que pour la boîte déroulante standard. D' | ||
+ | |CDIR |Bouton de sélection ou de création de répertoire.| | ||
+ | |CE |Texte libre. Correspond au type de champ par défaut.| | ||
+ | |CHK |Case à cocher. La valeur initiale est une constante insensible à la casse (TRUE ou FALSE)| | ||
+ | |CLR |Boîte de sélection de couleur. La valeur par défaut de la couleur peut être saisie au format hexadécimal (#FF0000 par exemple). La boîte de dialogue est moins sophistiquée que le champ yad –color qui affiche une roue des couleurs et des champs de saisie numérique.| | ||
+ | |DIR |Bouton de sélection de répertoire dans l’arborescence. Ne permet pas la saisie d’un nom de répertoire qui ne figure pas dans l’arborescence (voir option CDIR).| | ||
+ | |DT |Champ date.| | ||
+ | |FBTN |Identique au champ BTN, le bouton étant en relief.| | ||
+ | |FL |Bouton de sélection de fichier dans l’arborescence. Ne permet pas la saisie d’un nom de fichier qui ne figure pas dans l’arborescence (voir option SFL).| | ||
+ | |FN |Boîte de sélection de police de caractère. Les polices de caractère sont saisies sous la forme Famille Style Taille (exemple : Sans Bold 13). La boîte de dialogue est moins sophistiquée que le champ yad –font.| | ||
+ | |H |Champ caché. Tous les caractères saisis apparaissent sous la forme d’un caractère invisible (souvent un point). Permet la saisie discrète d’un mot de passe.| | ||
+ | |LBL |Étiquette. Si le nom du champ est vide, un séparateur linéaire horizontal apparaîtra dans le formulaire.| | ||
+ | |MDIR |Bouton de sélection de plusieurs répertoires dans l’arborescence. Les noms de répertoires apparaîtront séparés par des virgules. Ne permet pas la saisie d’un nom de répertoires qui ne figure pas dans l’arborescence.| | ||
+ | |MFL |Bouton de sélection de plusieurs fichiers dans l’arborescence. Les noms de fichiers apparaîtront séparés par des virgules. Ne permet pas la saisie d’un nom de fichier qui ne figure pas dans l’arborescence.| | ||
+ | |NUM |Valeur numérique. Formatage possible : Valeur[!Echelle[!Pas[!Précision]]]. L’échelle des valeurs se présente sous la forme Min..Max. La précision concerne les décimales.| | ||
+ | |RO |Champ en mode lecture seule.| | ||
+ | |SCL |Échelle (réglette). Valeur comprise entre 0 et 100.| | ||
+ | |SFL |Bouton de sélection ou de création de fichier.| | ||
+ | |TXT |Entrée texte multiligne. Occupe l’ensemble de la surface du formulaire.| | ||
+ | ===== Exemples ===== | ||
+ | Avant de vous lancer dans la lecture, notez que vous trouverez de nombreux exemples, simples et complexes avec ces liens : | ||
+ | * [[http:// | ||
+ | * [[https:// | ||
+ | ====--calendar==== | ||
+ | Dans cet exemple le calendrier s' | ||
+ | |||
+ | --title=" | ||
+ | |||
+ | --window-icon=" | ||
+ | < | ||
+ | jour=$(date +%d) | ||
+ | mois=$(date +%m) | ||
+ | annee=$(date +%Y) | ||
+ | yad --calendar --day=" | ||
+ | </ | ||
+ | |||
+ | ====--dnd==== | ||
+ | < | ||
+ | #!/bin/bash | ||
+ | yad --dnd \ | ||
+ | --title=" | ||
+ | --window-icon=" | ||
+ | --width=" | ||
+ | --center --on-top \ | ||
+ | --undecorated \ | ||
+ | --text="< | ||
+ | --text-align=" | ||
+ | </ | ||
+ | ====--entry==== | ||
+ | Une boîte de recherche sur les pages en français de Google | ||
+ | < | ||
+ | #!/bin/bash | ||
+ | recherche=$(yad --entry --title=' | ||
+ | recherche=$(echo " | ||
+ | xdg-open https:// | ||
+ | </ | ||
+ | ====--form==== | ||
+ | C'est ici que Yad devient intéressant car il permet de cumuler plusieurs types de boîtes dans une seule fenêtre. | ||
+ | |||
+ | Deux exemples récapitulatifs : | ||
+ | < | ||
+ | retour=$(yad --form --field=" | ||
+ | echo " | ||
+ | </ | ||
+ | {{:: | ||
+ | |||
+ | et (un seul formulaire avec toutes les options risque de dépasser les dimensions de votre écran) : | ||
+ | < | ||
+ | retour=$(yad --form | ||
+ | echo " | ||
+ | </ | ||
+ | {{:: | ||
+ | |||
+ | <note tip>Voir [[https:// | ||
+ | |||
+ | Si l'on reprend l' | ||
+ | < | ||
+ | #!/bin/bash | ||
+ | search=$(yad --title=' | ||
+ | --form \ | ||
+ | --field=" | ||
+ | --field=" | ||
+ | rech=$(echo $search | awk 'BEGIN {FS=" | ||
+ | moteur=$(echo $search | awk 'BEGIN {FS=" | ||
+ | if [ " | ||
+ | then | ||
+ | rech=$(echo " | ||
+ | xdg-open https:// | ||
+ | elif [ " | ||
+ | then | ||
+ | rech=$(echo " | ||
+ | xdg-open https:// | ||
+ | fi | ||
+ | </ | ||
+ | ====--notification==== | ||
+ | Affiche une icône dans la zone de notification du panel (le systray). | ||
+ | |||
+ | Un exemple concret tout simple, qui affiche une icône et quitte lorsqu' | ||
+ | < | ||
+ | |||
+ | On peux changer l’icône avec le paramètre **--image** | ||
+ | < | ||
+ | < | ||
+ | |||
+ | Exemple avec un script faisant les mises à jour et affichant avec une icône dans la zone de notification pour le signaler : | ||
+ | < | ||
+ | MSG=" | ||
+ | notify-send " | ||
+ | faireMaJ () { (sudo apt update ; sudo apt full-upgrade) > /dev/null; quit ; } | ||
+ | faireMaJ | yad --notification --no-middle --text=" | ||
+ | exit 0</ | ||
+ | {{:: | ||
+ | |||
+ | La liste des noms d’icônes standard sont là : [[https:// | ||
+ | |||
+ | Quelques exemples du site officiel : [[https:// | ||
+ | |||
+ | Reprenons l' | ||
+ | < | ||
+ | #!/bin/bash | ||
+ | ##### | ||
+ | function _commande () | ||
+ | { | ||
+ | commande=$(ps -ef | grep "yad --title=Recherche web --text=Tapez votre recherche" | ||
+ | if [ -n " | ||
+ | then | ||
+ | kill -9 " | ||
+ | else | ||
+ | _recherche | ||
+ | fi | ||
+ | } | ||
+ | export -f _commande | ||
+ | ##### | ||
+ | function _recherche () | ||
+ | { | ||
+ | search=$(yad --title=' | ||
+ | --form \ | ||
+ | --field=" | ||
+ | --field=" | ||
+ | rech=$(echo $search | awk 'BEGIN {FS=" | ||
+ | moteur=$(echo $search | awk 'BEGIN {FS=" | ||
+ | if [ " | ||
+ | then | ||
+ | rech=$(echo " | ||
+ | xdg-open https:// | ||
+ | elif [ " | ||
+ | then | ||
+ | rech=$(echo " | ||
+ | xdg-open https:// | ||
+ | fi | ||
+ | } | ||
+ | export -f _recherche | ||
+ | ##### | ||
+ | yad --notification --no-middle --title=" | ||
+ | </ | ||
+ | ====--notebook==== | ||
+ | Une boite à onglets. | ||
+ | < | ||
+ | #!/bin/bash | ||
+ | #####ID --KEY Création aléatoire de l' | ||
+ | id=$(echo $[($RANDOM % ($[10000 - 32000] + 1)) + 10000] ) | ||
+ | ########## | ||
+ | #####Avec une colonne####### | ||
+ | yad --plug=" | ||
+ | --field=" | ||
+ | --field=": | ||
+ | --field=" | ||
+ | &> /tmp/data1 & | ||
+ | ########## | ||
+ | #####Avec 3 colonnes######## | ||
+ | yad --plug=" | ||
+ | --field="< | ||
+ | --field=" | ||
+ | --field=" | ||
+ | --field=" | ||
+ | --field=" | ||
+ | --field=" | ||
+ | &> /tmp/data2 & | ||
+ | yad --notebook --width=" | ||
+ | --tab=" | ||
+ | --button=" | ||
+ | --button=" | ||
+ | fermernotebook=$? | ||
+ | if [ $fermernotebook -eq 252 ] | ||
+ | then | ||
+ | exit | ||
+ | elif [ $fermernotebook -eq 1 ] | ||
+ | then | ||
+ | exit | ||
+ | fi | ||
+ | </ | ||
+ | |||
+ | ====--list==== | ||
+ | Des cases à cocher. | ||
+ | Choisir un item dans une liste : | ||
+ | < | ||
+ | #!/bin/bash | ||
+ | # Affichage du contenu du fichier sélectionné | ||
+ | function usage { | ||
+ | echo " | ||
+ | echo "Un unique fichier sélectionné" | ||
+ | echo " | ||
+ | } | ||
+ | if [[ " | ||
+ | usage | ||
+ | else | ||
+ | retour=$(yad --title=" | ||
+ | cat $(echo " | ||
+ | fi | ||
+ | exit 0; | ||
+ | </ | ||
+ | {{ : | ||
+ | Et pour pourvoir sélectionner plusieurs lignes à la fois : | ||
+ | < | ||
+ | retour=$(yad --title=" | ||
+ | lesFichiers=$(echo " | ||
+ | for i in $lesFichiers; | ||
+ | cat " | ||
+ | done | ||
+ | </ | ||
+ | {{ : | ||
+ | <note tip>Bien qu' | ||
+ | ===== Pango Markup Language - mettre en forme un texte ===== | ||
+ | Le langage de Markup Pango est un langage de mise en forme très simple qui est supporté par Yad. Il permet de mettre en forme le texte via des balises < | ||
+ | |||
+ | Quelques balises inspirées du html existent aussi (sans balise < | ||
+ | |||
+ | La liste des balises autorisées se trouvent ici : [[https:// | ||
+ | |||
+ | Exemples : | ||
+ | |||
+ | **font_desc** : '' | ||
+ | |||
+ | **font_desc** : '' | ||
+ | |||
+ | **souligné** : '' | ||
+ | |||
+ | |||
+ | ===== Trucs et astuces ===== | ||
+ | ==== États de sorties==== | ||
+ | Voilà le code (testable) renvoyé par **yad** quand on appuie sur certains boutons pour quitter une boite de dialogue : | ||
+ | |||
+ | **0** : L' | ||
+ | |||
+ | **1** : L' | ||
+ | |||
+ | **70** : La boîte de dialogue a été fermée parce que le délai d' | ||
+ | |||
+ | **252** : La boîte de dialogue a été fermée en appuyant sur la touche Echap ou en cliquant sur le bouton de fermeture de la barre du titre de la boîte de dialogue | ||
+ | |||
+ | |||
+ | Les codes de sortie pour les boutons créés par l' | ||
+ | === Test sur les boutons=== | ||
+ | < | ||
+ | #!/bin/bash | ||
+ | |||
+ | yad --title=" | ||
+ | echo " | ||
+ | |||
+ | yad --title=" | ||
+ | echo " | ||
+ | |||
+ | yad --title=" | ||
+ | echo " | ||
+ | |||
+ | yad --title=" | ||
+ | echo " | ||
+ | |||
+ | yad --title=" | ||
+ | echo " | ||
+ | </ | ||
+ | Comme vous le constatez la fenêtre se ferme mais le script continu. | ||
+ | |||
+ | Personnellement lorsque je clique sur le bouton de fermeture, le bouton Annuler ou la touche Echap je veux arrêter le script. | ||
+ | |||
+ | Pour ce faire nous allons utiliser la [[: | ||
+ | |||
+ | Je me sers de [[: | ||
+ | < | ||
+ | #!/bin/bash | ||
+ | |||
+ | yad --title=" | ||
+ | case $? in | ||
+ | 1) | ||
+ | exit;; | ||
+ | 70) | ||
+ | exit;; | ||
+ | 252) | ||
+ | exit;; | ||
+ | esac | ||
+ | |||
+ | yad --title=" | ||
+ | echo " | ||
+ | </ | ||
+ | |||
+ | ====Les boutons.==== | ||
+ | ===Comportements=== | ||
+ | Il y a deux types de comportements: | ||
+ | |||
+ | Si la sortie est numérique, la fenêtre se ferme. | ||
+ | |||
+ | Si la sortie est non numérique, la fenêtre reste ouverte. | ||
+ | < | ||
+ | yad --width=" | ||
+ | yad --width=" | ||
+ | </ | ||
+ | ===Décorations=== | ||
+ | Pour personnaliser les boutons vous pouvez: | ||
+ | |||
+ | Utiliser ceux prédéfinis gtk-stock (ex: gtk-close ou gtk-ok). | ||
+ | |||
+ | Définir vos propres options sous la forme LABEL[!ICON[!TOOLTIP]] où LABEL est le texte du bouton, ICON est l' | ||
+ | < | ||
+ | yad --width=" | ||
+ | yad --width=" | ||
+ | </ | ||
+ | L’icône peut être définie par son chemin complet ou par une icône système (Dans mon exemple " | ||
+ | |||
+ | ===Fermer la fenêtre et lancer une action=== | ||
+ | Il est possible d' | ||
+ | < | ||
+ | yad --form --field " | ||
+ | </ | ||
+ | Dans cet exemple simple, l' | ||
+ | < | ||
+ | function bonjour () { echo " | ||
+ | export -f bonjour | ||
+ | yad --form --field " | ||
+ | </ | ||
+ | Dans cet autre exemple, on crée une fonction toute simple qui affiche le nom de l' | ||
+ | |||
+ | Ce numéro pid (process identification digit) peut être utilisé pour fermer la fenêtre yad si le bouton appelle un script. En effet, comme indiqué ci-dessus, si la sortie du bouton n'est pas numérique, l' | ||
+ | < | ||
+ | function ferme_yad () { bonjour ; PidYad=$(pgrep yad); kill -s SIGUSR1 " | ||
+ | export -f ferme_yad | ||
+ | yad --form --field " | ||
+ | </ | ||
+ | ====Récupérer les sorties dans les boîtes multiples.==== | ||
+ | Dans les boîtes multiples la sortie standard sera de type champ1|champ2|champ3| où " | ||
+ | Pour récupérer les champs il est donc pratique d' | ||
+ | < | ||
+ | #Envoi de la sortie dans une variable. | ||
+ | champs=$(yad --title=" | ||
+ | --form \ | ||
+ | --field=" | ||
+ | --field=" | ||
+ | --field=" | ||
+ | echo " | ||
+ | # | ||
+ | champ1=$(echo $champs | awk 'BEGIN {FS=" | ||
+ | champ2=$(echo $champs | awk 'BEGIN {FS=" | ||
+ | champ3=$(echo $champs | awk 'BEGIN {FS=" | ||
+ | #Affichage des champs. | ||
+ | echo " | ||
+ | echo " | ||
+ | echo " | ||
+ | </ | ||
+ | Une autre méthode consiste à éclater l' | ||
+ | < | ||
+ | usr@pc:~$ ANC_IFS=" | ||
+ | usr@pc:~$ echo " | ||
+ | usr@pc:~$ echo " | ||
+ | usr@pc:~$ echo " | ||
+ | </ | ||
+ | Explications : | ||
+ | * ANC_IFS=" | ||
+ | * IFS=' | ||
+ | * read -ra LesParametres <<< | ||
+ | * IFS=" | ||
+ | * Pour accéder à la valeur de chaque champ, il suffit d' | ||
+ | ==== Gestion d' | ||
+ | L' | ||
+ | < | ||
+ | usr@pc: | ||
+ | </ | ||
+ | Ce message est bien connu et ne correspond pas à une erreur grave. Pour s'en débarrasser, | ||
+ | < | ||
+ | usr@pc: | ||
+ | </ | ||
+ | |||
+ | ===== Désinstallation ===== | ||
+ | |||
+ | Pour supprimer cette application, | ||
+ | |||
+ | ===== Voir aussi ===== | ||
+ | |||
+ | * **(en)** [[http:// | ||
+ | * **(en)** [[http:// | ||
+ | * **(en)** [[https:// | ||
+ | * **(en)** [[https:// | ||
+ | * **(en)** [[http:// | ||
+ | * **(en)** [[http:// | ||
+ | * **(en)** [[https:// | ||
+ | |||
+ | ---- | ||
+ | // | ||
+ | |||
+ | //Basé sur [[http:// | ||
+ | |||
+ | |||
+ | |||
+ | |||
+ | |||
+ | |||
+ | |||
+ | |||
+ | |||