Joshuto supports some terminal graphics protocols for showing thumbnails out of the box. See ratatui-image for which terminals are supported.
This works without further configuration if the preview script returns with 0
for a file.
The textual preview returned by the preview script will be shown right beneath the thumbnail image.
This allows to use both, an image preview and a textual preview which is often used to show meta-data for non-text files.
This thumbnail feature is enabled by default and uses an auto-detection for the image-protocol to use.
To disable the inbuilt thumbnail feature or to override the detected protocol, the preview_protocol
option can
be used in the joshuto.toml
file. Accepted values are auto
(default),
disabled
, or any of the implemented protocols
in lowercase, for example:
[preview]
preview_protocol = "halfblocks"
...
By default, Joshuto uses thumbnails and the freedesktop.org specified thumbnail cache for the image previews.
This increases performance, because images are scaled down only once and then kept in a cache, which can also be used by different programs. This feature also allows to provide thumbnails for file formats other than image files. Internally, Joshuto uses allmytoes to provide the thumbnails. Check the documentation for “providers” there to see which other file types are supported and which local dependencies must be available to have them created when needed.
To disable the XDG-thumbnails and the provision of thumbs for non-image file types,
set the respective property in joshuto.toml
to false
:
[preview]
use_xdg_thumbs = false
The image-preview feature will still work, but will only show previews for image-files and it will have to load the full-size images and then scale them down every time they are shown.
The freedesktop.org thumbnail specification defines four different thumbnail sizes: normal, large, x-large, and xx-large with maximum edge lengths of 128 px, 256 px, 512 px, and 1024 px respectively.
By default, Joshuto uses “x-large” thumbnails. This can be changed by the respective property in joshuto.toml
, e.g.:
[preview]
# Allowed values are 'normal', 'large', 'xlarge', and 'xxlarge'
xdg_thumb_size = "xxlarge"
The thumbnails provided directly by Joshuto might not be satisfying for all users. Some terminals might not be supported at all, or only support a less satisfying image representation, like “halfblocks”.
As a solution for these cases, Joshuto offers two text-preview-related hooks which allow to implement an image preview with external scripts and some other “terminal image” solutions. Most probably, you will use Überzug++ for this job. This allows, for example, to have proper preview-images in Alacritty, which otherwise only support “halfblocks” with Joshuto's inbuilt image-preview.
Essentially, you have to create two scripts and “hook” them into Joshuto. Joshuto will call them every time a new image-preview shall be shown or when any preview-image shall be cleared.
The hooks can be configured in the joshuto.toml
file.
[preview]
...
preview_shown_hook_script = "~/.config/joshuto/preview_shown_hook"
preview_removed_hook_script = "~/.config/joshuto/preview_removed_hook"
Be aware that as soon as these scripts are configured, the inbuilt image-preview feature is disabled automatically.
The preview_shown_hook_script
is called each time a file-preview (in the 3rd
pane) is focused.
The preview_removed_hook_script
will be called each time the file preview
panel completely disappears in Joshuto.
That is the case if the user selects a file for which no file preview is shown
(either due to missing output of the preview script or due to file size),
if the preview is not cached already and the preview pane is temporarily removed,
or if the selection jumps from a file to a directory.
The “shown” script gets the path of the file being previewed as first argument and then the x and y coordinate and the width a height of the preview area as second to fifth parameters.
The “removed” script does not get any arguments.
❗ Important: Text preview area is what triggers the hook scripts ❗
The “preview” hooks are triggered by the text preview. The “shown hook” will be invoked when the text preview area is shown. Ergo, a text preview must be activated for files for which one wants to have an image preview. If you don't want to do fancy stuff like combining a textual preview with image previews, just return with exit code
0
from the preview-script without any output for those files for which an image preview shall be shown. That will trigger Joshuto to show an empty text-preview area which can then be used as a canvas for the image preview.
For some of the 3rd party tools, it's necessary to run them as a separate process, in parallel to Joshuto.
The famous example is “Überzug” and its successor “Überzug++”. To be able to use such a solution, one needs to have a “wrapper-script” which must be started instead of Joshuto. The wrapper-script will then start both, first the program for showing images in the terminal and then Joshuto.
See
- Überzug (only for X11; unmaintained but may live on in some fork)
- Überzug++ (for X11, some Wayland compositors, and some specific terminal emulators)
- Combining text preview and image preview
- To use XDG-thumbnails or thumbnails for non-image file types, you
can use the program
allmytoes
inside your shown-hook script to get the thumb-image for a file. This is basically the “shell-program” version of what Joshuto also uses internally for the inbuilt XDG-thumbnail feature.