2024-06-28 21:42:21 +02:00
2024-06-28 14:25:27 +02:00
2024-06-28 11:38:13 +02:00
2024-06-28 14:27:13 +02:00
2024-06-26 13:47:07 +02:00
2024-06-28 11:38:13 +02:00
2024-06-28 11:38:13 +02:00
2024-06-28 21:42:21 +02:00
2024-06-26 13:47:07 +02:00
2024-06-28 14:25:27 +02:00

generate_html.py

generate_html.py is a Python script designed to generate static HTML files for hosting images on a web server. It traverses a specified root directory, creates thumbnail previews for images, and generates corresponding HTML files to display the images and subfolders in a user-friendly format.

Features

  • Generate HTML Files: The script creates HTML files for each folder in the specified root directory.
  • Thumbnail Creation: It generates thumbnail previews for supported image formats.
  • Folder Navigation: The HTML files include navigation links to subfolders.
  • Responsive Design: The generated HTML uses responsive design techniques to ensure the gallery looks good on different screen sizes.
  • Non-Interactive Mode: It can run in a non-interactive mode suitable for automated workflows.
  • License Information: Optionally include license information in the HTML files.
  • Custom Author and Title: Allows specifying a custom author and title for the HTML files.
  • CSS Theme Support: Allows specifying a custom CSS theme file for the HTML files.

Requirements

  • Python 3.x
  • numpy library
  • tqdm library
  • Jinja2 library
  • ImageMagick

Installation

Install the required libraries using pip:

pip install numpy tqdm Jinja2

Usage

The script supports several command-line options to customize its behavior. Below is the list of available options:

./generate_html.py [-h] [-p ROOT] [-w WEBROOT] [-i ICON] [-r] [-n] [--fancyfolders] [-l LICENSE] [-a AUTHOR] [-t TITLE] [--theme THEME]

Options

  • -h, --help: Show the help message and exit.
  • -p ROOT, --root ROOT: Specify the root folder where the images are stored. Default is /data/pictures/.
  • -w WEBROOT, --webroot WEBROOT: Specify the web root URL where the images will be accessible. Default is https://pictures.example.com/.
  • -i ICON, --foldericon ICON: Specify the URL for the folder icon. Default is https://www.svgrepo.com/show/400249/folder.svg.
  • -r, --regenerate: Regenerate thumbnails even if they already exist.
  • -n, --non-interactive: Disable interactive mode, which is useful for automated workflows.
  • --fancyfolders: Use fancy folders instead of the default Apache directory listing.
  • -l LICENSE, --license LICENSE: Specify a license for the content. Options are cc-zero, cc-by, cc-by-sa, cc-by-nd, cc-by-nc, cc-by-nc-sa, and cc-by-nc-nd.
  • -a AUTHOR, --author AUTHOR: Specify the author of the content.
  • -t TITLE, --title TITLE: Specify the title for the root directory HTML file.
  • --theme THEME: Specify the path to a custom CSS theme file. Default is themes/default.css.

Example

To generate HTML files and thumbnails for a directory /data/pictures and host them on https://pictures.example.com, run:

./generate_html.py -p /data/pictures -w https://pictures.example.com

To regenerate thumbnails and run in non-interactive mode:

./generate_html.py -p /data/pictures -w https://pictures.example.com -r -n

To include a license, author, and custom title:

./generate_html.py -p /data/pictures -w https://pictures.example.com -l cc-by -a "John Doe" -t "My Photo Gallery"

To specify a custom CSS theme:

./generate_html.py -p /data/pictures -w https://pictures.example.com --theme custom_theme.css

Notes

  • The root and webroot paths must point to the same folder, one on the filesystem and one on the webserver. Use absolute paths.
  • Ensure that ImageMagick is installed and accessible in your system for thumbnail generation.
  • The script generates the preview thumbnails in a .thumbnails subdirectory within the root folder.

License

This project is licensed under the AGPL-3.0 License. See the LICENSE file for details.

Description
No description provided
Readme AGPL-3.0 416 MiB
Languages
JavaScript 53.3%
Python 31.2%
CSS 10.6%
Jinja 4.8%