Esphome based Immich digital photo frame https://jtenniswood.github.io/espframe/
  • C 72.3%
  • Python 14.3%
  • C++ 12.4%
  • JavaScript 0.9%
  • CMake 0.1%
Find a file
2026-06-10 09:46:21 +01:00
.agents/skills Make release readiness compile-aware 2026-06-08 10:08:21 +01:00
.github/workflows Fix OTA release firmware build variant 2026-06-10 09:15:10 +01:00
builds Remove JC1060P470 support 2026-06-07 09:10:11 +01:00
common/addon Add Immich tag photo source 2026-06-09 12:32:06 +01:00
components Add Immich tag photo source 2026-06-09 12:32:06 +01:00
devices/guition-esp32-p4-jc8012p4a1 Add Immich tag photo source 2026-06-09 12:32:06 +01:00
docs Add Immich tag photo source 2026-06-09 12:32:06 +01:00
product Add Immich tag photo source 2026-06-09 12:32:06 +01:00
scripts Fix OTA release firmware build variant 2026-06-10 09:15:10 +01:00
tests Fix smoke test timeout result handling 2026-06-10 09:46:21 +01:00
.gitignore Add local ESPHome flashing setup 2026-06-07 11:58:28 +01:00
LICENSE Add non-commercial license 2026-05-13 14:28:11 +01:00
NOTICE Add non-commercial license 2026-05-13 14:28:11 +01:00
package-lock.json Add non-commercial license 2026-05-13 14:28:11 +01:00
package.json Make release readiness compile-aware 2026-06-08 10:08:21 +01:00
README.md Add Immich tag photo source 2026-06-09 12:32:06 +01:00
renovate.json Fix release build integrity and pin ESPHome Docker image 2026-04-15 11:58:48 +01:00

Espframe for Immich

Turn a supported Guition ESP32-P4 touchscreen into a private digital photo frame for your Immich photo library.

Espframe is for people who want their photos out in the room, not hidden on a phone, and do not want to run another server, cloud account, or subscription just to make that happen. Flash the frame from a browser, connect it to WiFi, point it at Immich, and it starts showing your photos.

Espframe displaying Immich photos on a Guition ESP32-P4 touchscreen

What Espframe Lets You Do

  • Make a real photo frame from your Immich library
    Show photos from the Immich server you already run, without needing a tablet, Raspberry Pi, Home Assistant, or a separate slideshow service.

  • Keep your photos private
    The frame connects directly to your Immich server over your own network. There is no Espframe cloud service and no extra account to trust with your pictures.

  • Choose what appears on the frame
    Show your whole library, favorites, specific albums, specific people, specific tags, "on this day" memories, or photos from a chosen date range.

  • Make portrait photos look better on a wide screen
    Espframe can pair portrait photos from the same day side-by-side, so the display feels more like a composed frame and less like a single narrow image with empty space.

  • Tune the screen for your room
    Adjust brightness, warm up a panel that looks too blue, use a softer night tone after sunset, and schedule the display to turn off overnight.

  • Control it from the frame or a browser
    Use simple touch gestures to wake, sleep, or advance to the next photo. Open the built-in web page on your phone or computer to change photo sources, timing, brightness, Immich settings, and display options.

  • Use Home Assistant if you want to, but it is not required
    Espframe works by itself. If you already use Home Assistant, it can also appear there as an ESPHome device for dashboard controls, automations, and updates.

Who This Is For

Espframe is a good fit if:

  • You already use, or plan to use, Immich for your photo library.
  • You want a dedicated photo frame instead of leaving a tablet permanently awake.
  • You prefer local, self-hosted tools over cloud photo-frame services.
  • You are comfortable following a step-by-step browser installer and copying an Immich API key.

It is not a general-purpose tablet app. It is firmware for specific ESP32-P4 touchscreen hardware.

Hardware

Currently documented hardware:

Item Link
10" Guition ESP32-P4 panel (JC8012P4A1) AliExpress
10" printable stand MakerWorld

Getting Started

The easiest way to install Espframe is with the web installer. You do not need to install developer tools or build firmware yourself.

Open the Web Installer

You will need:

  • A supported Guition ESP32-P4 touchscreen
  • A USB-C data cable, not a charge-only cable
  • Chrome or Edge on a desktop computer
  • Your Immich server address
  • An Immich API key

The full setup guide is here:

jtenniswood.github.io/espframe

Everyday Controls

Once installed, the frame has two main control surfaces:

  • On the touchscreen: tap to wake, double-tap to advance to the next photo, and press-and-hold to sleep.
  • In the web settings page: change the photo source, slideshow speed, date filters, brightness, screen tone, rotation, WiFi, Immich connection, and firmware update options.

Development

Most people do not need this section. It is here for contributors or anyone who wants to build the docs or firmware locally.

# Docs site (live reload)
npm ci
npm run docs:dev

# Compile firmware locally
docker run --rm -v "${PWD}:/config" ghcr.io/esphome/esphome:2026.5.3 compile /config/builds/guition-esp32-p4-jc8012p4a1.factory.yaml

In-Development Firmware Features

In-progress firmware experiences are built into normal firmware, but must stay off unless the hidden developer setting is enabled. Open the device web UI with ?developer=experimental, for example http://<device-ip>/?developer=experimental, then use the Developer panel to turn them on for that device.

Firmware code should check id(developer_features_enabled).state before running anything experimental. The switch defaults off and persists only when deliberately enabled.

License

Espframe's project-owned code and documentation are source-available under the PolyForm Noncommercial License 1.0.0. You can use, change, and share it for non-commercial purposes. Commercial use needs separate permission from the project owner.

This is not an OSI-approved open source license because formal open source licenses must allow commercial use. Third-party components keep their own licenses.

Support This Project

If you find this project useful, consider buying me a coffee to support ongoing development.

Buy Me A Coffee