Zenity: A Guide to Creating GTK+ Dialogs in Linux Command Line

Zenity is a tool that allows you to create graphical dialog boxes in Linux using the command line. It uses GTK+, a toolkit for creating graphical user interfaces (GUIs), making it easy to add visual elements to your scripts.

Zenity can be extremely useful for shell scripting, as it provides a simple way to interact with users through dialogs such as information boxes, file selectors, progress bars, and more.

In this article, we will dive deep into how Zenity works, the types of dialog boxes it can create, and how to use it effectively in your shell scripts.

Why Use Zenity?

When writing shell scripts, user interaction is usually done via text input/output in the terminal. However, there are scenarios where you may want to provide a more user-friendly experience, especially when the script is intended for people who might not be comfortable with terminal commands.

Zenity helps solve this problem by allowing you to create graphical dialog boxes that are easy to understand and use.

Installing Zenity in Linux

Most modern Linux distributions come with Zenity pre-installed and you can check if Zenity is available on your system by typing the following command in your terminal:

zenity --version

4.0.1

If Zenity is installed, this command will display the version number. If it is not installed, you can install it using your package manager.

sudo apt install zenity         [On Debian, Ubuntu and Mint]
sudo yum install zenity         [On RHEL/CentOS/Fedora and Rocky/AlmaLinux]
sudo emerge -a sys-apps/zenity  [On Gentoo Linux]
sudo apk add zenity             [On Alpine Linux]
sudo pacman -S zenity           [On Arch Linux]
sudo zypper install zenity      [On OpenSUSE]    
sudo pkg install zenity         [On FreeBSD]

Basic Usage of Zenity in Linux

Zenity is very simple to use, as it operates by invoking different types of dialog boxes from the command line using various options. Each option corresponds to a specific type of dialog box.

Example 1: Displaying an Information Dialog

One of the simplest uses of Zenity is to show an information dialog.

zenity --info --text="This is an information dialog"
Zenity Show Information Dialog
Zenity Show Information Dialog

Example 2: Displaying a Warning Dialog

You can also show a warning dialog using the following command:

zenity --warning --text="This is a warning message"
Zenity Show Warning Dialog
Zenity Show Warning Dialog

Example 3: Displaying Question Dialog

A question dialog can be used to ask the user a yes/no question. The result is returned as an exit code.

if zenity --question --text="Do you want to continue?"; then
    echo "User selected Yes"
else
    echo "User selected No"
fi
Zenity Show Question Dialog
Zenity Show Question Dialog

Example 4: Displaying File Selection Dialog

Zenity can also be used to open a file selection dialog, allowing users to pick a file from their system:

FILE=$(zenity --file-selection --title="Choose a file")
echo "You selected: $FILE"
Zenity Show File Selection-Dialog
Zenity Show File Selection-Dialog

Example 5: Displaying Text Entry Dialog

You can create a dialog box that prompts the user to enter some text, which can be useful for getting user input.

USER_INPUT=$(zenity --entry --title="Input required" --text="Enter your name:")
echo "You entered: $USER_INPUT"
Zenity Show Text Entry Dialog
Zenity Show Text Entry Dialog

Example 6: Displaying Password Dialog

If you want to ask the user for a password, you can use the password dialog, but the input will be hidden from view:

PASSWORD=$(zenity --password --title="Enter your password")
echo "Password entered: $PASSWORD"
Zenity Show Password Dialog
Zenity Show Password Dialog

Example 7: Displaying Progress Bar Dialog

Zenity can display a progress bar, which is useful when you want to indicate that a task is in progress.

(
for i in {1..100}; do
    echo $i
    sleep 0.1
done
) | zenity --progress --title="Task in progress" --text="Please wait..." --percentage=0
Zenity Show Progress Bar Dialog
Zenity Show Progress Bar Dialog

Example 8: Displaying Error Dialog

You can show an error dialog when something goes wrong in your script:

zenity --error --text="An error occurred!"
Zenity Show Error Dialog
Zenity Show Error Dialog

Example 9: Displaying List Dialog

Zenity can display a list of options for the user to choose from:

zenity --list --title="Choose an option" --column="Options" "Option 1" "Option 2" "Option 3"
Zenity Show List Dialog
Zenity Show List Dialog

Using Zenity in Shell Scripts

Zenity can be seamlessly integrated into shell scripts to create a more user-friendly experience.

Here is a complete example of a simple script that uses various Zenity dialogs.

#!/bin/bash

# Welcome message
zenity --info --text="Welcome to the user setup script"

# Ask for user's name
USER_NAME=$(zenity --entry --title="User Information" --text="Please enter your name:")

# Ask for confirmation
if zenity --question --text="Is your name $USER_NAME?"; then
    zenity --info --text="Thank you, $USER_NAME"
else
    zenity --error --text="Name mismatch. Exiting script."
    exit 1
fi

# File selection
FILE=$(zenity --file-selection --title="Select a file to process")
zenity --info --text="You selected: $FILE"

# Display progress
(
for i in {1..100}; do
    echo $i
    sleep 0.1
done
) | zenity --progress --title="Processing file" --text="Please wait while we process the file..." --percentage=0

zenity --info --text="Process complete!"

This script starts by welcoming the user, then asking for their name, confirming the name, asking them to select a file, and showing a progress bar while the file is processed. It demonstrates how Zenity can be used to add a graphical interface to a script that would otherwise be text-based.

Using Zenity in Shell Scripts
Using Zenity in Shell Scripts

Error Handling in Zenity

Zenity returns different exit codes based on user actions. Understanding these codes helps to handle errors or user cancellations properly in your scripts.

  • Exit code 0: The user clicked “OK” or select an option.
  • Exit code 1: The user clicked “Cancel” or closed the dialog.
  • Exit code -1: Some error occurred.

You can use these exit codes to handle different user responses:

if zenity --question --text="Do you want to proceed?"; then
    echo "Proceeding..."
else
    echo "Action canceled by the user."
    exit 1
fi
Conclusion

Zenity is an incredibly useful tool for creating graphical dialog boxes in shell scripts. Whether you’re building simple file selectors, interactive question dialogs, or progress bars, Zenity can enhance your scripts by providing a user-friendly interface.

By using Zenity, you can make your command-line applications and shell scripts more accessible to non-technical users.

Hey TecMint readers,

Exciting news! Every month, our top blog commenters will have the chance to win fantastic rewards, like free Linux eBooks such as RHCE, RHCSA, LFCS, Learn Linux, and Awk, each worth $20!

Learn more about the contest and stand a chance to win by sharing your thoughts below!

Ravi Saive
I am an experienced GNU/Linux expert and a full-stack software developer with over a decade in the field of Linux and Open Source technologies

Each tutorial at TecMint is created by a team of experienced Linux system administrators so that it meets our high-quality standards.

Join the TecMint Weekly Newsletter (More Than 156,129 Linux Enthusiasts Have Subscribed)
Was this article helpful? Please add a comment or buy me a coffee to show your appreciation.

11 Comments

Leave a Reply
  1. I am still fairly new to the Linux world. I’m using Ubuntu 16.10 and Gnome. I REALLY appreciate useful and informative articles such as this one both here at Tecmint and other, similar sites around the ‘net.

    Look, I don’t like to be a nodge, and I’m not really a grammar Nazi, but there are some significant problems with the grammar in this piece. I’m also acutely aware that we did not all grow up with English as our native tongue, but don’t all of you at Tecmint think someone should proofread your article before you post them?

    Alternatively, there are some very good to excellent grammar checking tools now available, many of which are free. I’m just sayin’ this because what you all write is great and I don’t want anyone thinking less of your works because of poor grammar or spelling, ‘K?

    Reply
    • Grammarly reports an “advanced issue” in your text (“Alternatively, … spelling”). Why don’t you put your money where your mouth is?

      Reply
  2. Nice blog.

    Can you suggest me the source code for “zenity –about”?

    or can you suggest how to make something like “Zenity –about” dialog box?

    Reply
  3. Hi
    I am trying to develop zenity form and password in redhat linux 6.2 but these two option is not availible in current supported zenity version 2.2.

    I have done 2 day search to run zenity password and form but fail.

    Can some one help how I can run zenity password and form in redhat liniux server.

    Thanks in advance

    Reply
  4. hey! I happen to find this blog today (apr 08, 2014) because of Tarunika’s rsync article (https://www.tecmint.com/rsync-local-remote-file-synchronization-commands/). So, i continued browsing through your site and found this article.

    Just a few months back I wrote and published a simple show clock (date, time) shell script that uses Zenity. Please find it here: http://thatmaheshrs.wordpress.com/2014/02/09/show-date-and-time-in-xubuntu-as-well-as-other-linux-distros/

    Please post your constructive comments, if any, onto my blog.

    Reply

Got Something to Say? Join the Discussion...

Thank you for taking the time to share your thoughts with us. We appreciate your decision to leave a comment and value your contribution to the discussion. It's important to note that we moderate all comments in accordance with our comment policy to ensure a respectful and constructive conversation.

Rest assured that your email address will remain private and will not be published or shared with anyone. We prioritize the privacy and security of our users.