Skip to content

A photo album organizer written in Python/Django.

License

Notifications You must be signed in to change notification settings

wojciechpolak/webxiangpianbu

Repository files navigation

WebXiangpianbu

WebXiangpianbu is a photo album organizer written in Python/Django. It can work as a dynamic web application photo gallery or as a static site generator.

Features

  • Free, self-hosted web application
  • No database required
  • Highly customizable (albums, templates, styles)
  • Mobile friendly
  • EXIF and Geotagging extracting
  • Map feature (Leaflet, Mapbox)
  • Language localization

Installation

Install all necessary dependencies using uv.

$ uv sync

Next steps:

  1. Copy webxiang/settings_sample.py to webxiang/settings.py and modify it to your needs.
  2. Optionally, run uv run manage.py compilemessages (if you have gettext installed).
  3. uv run manage.py collectstatic

Web Application Deployment

See https://docs.djangoproject.com/en/dev/howto/deployment/ for usual Django applications deployment.

Docker Deployment

./scripts/build-docker.sh
# [adjust files in the `run` folder]
docker-compose up

Tools

generate.py -- generate albums from photo files.

tools/generate.py --album-dir=albums/ ~/photos/vacation/ ~/webxiang/static/data/vacation
tools/generate.py --help
# next, adjust the generated vacation.yaml

convert.py -- convert albums between different file formats (YAML, JSON).

tools/convert.py 'albums/*.yaml' tmp/

Static Site Generator

tools/generate.py ~/photos/vacation/ ~/tmp/vacation
tools/staticgen.py --quick=~/tmp/vacation --copy
tools/staticgen.py --help

Sample Galleries

About

A photo album organizer written in Python/Django.

Topics

Resources

License

Stars

Watchers

Forks

Packages