Beautiful and powerful yet simple local image viewer on your PC or mobile.
No installment required!
- Serve the local photos.
bunx gallery-server --folder /path/to/photos --no-footer
or:
pnpx gallery-server --folder /path/to/photos
npx gallery-server --folder /path/to/photos
For more usage:
bunx gallery-server -h
- Open http://localhost:xxxx/ in your favorite browser or share with your friends http://a.b.c.d:xxxx?token=${token}.
Photos from pixabay API of Yosemite.
- 📱 Photos in your PC can be viewed in your mobile phone's browser! So your can download photos on your PC to mobile phone.
- 🔐 Security on privacy to prevent eavesdropping. API or images without token are forbidden, but you can still share with your friends by sending him the token.
- 🎭 Light and dark theme.
- 🎞️ Videos also supported!
- 🖼️ More than one galleries can be served at the same time.
- 📚 A lot of gallery features. Check it at react-images.
- It is both a server and a client application, as well as a command-line application!
- Tech stack:
- pnpm v9, Node.js v22 (builtin
--watch
🎉), - ESLint v9, Biome v2 (for formatting instead of Prettier), Bun v1.2 (for test),
- Vite v7,
- TypeScript v5, Koa v2.
- pnpm v9, Node.js v22 (builtin
-
Q: Why
403 forbidden
?{ "code": 403, "message": "Forbidden. `token` required. Please redirect to https://github.com/legend80s/gallery-server#faq for more information." }
- A: You see this message because you are not the gallery owner. Ask the owner for the token and append it to the resource URL.
-
Photos in node_modules will be ignored for performance.
- install
pnpm i
- start api server
pnpm dev:server --folder='/path/to/photos'
# pnpm ds --folder='/path/to/photos'
- start webpack devServer
pnpm dev:client
# pnpm dc
Notice: Install all the dependencies into ./package.json
's devDependencies not ./client/package.json
. The package.json in client
exits only for scripts
。
For example if you want change to another gallery (react-bnb-gallery):
# enter project root not ./client/
cd project_root
pnpm install --save-dev react-bnb-gallery
# start webpack devServer
pnpm dev:client
# start api server
pnpm dev:server -- --folder=/path/to/photos
pnpm version patch / minor / major
pnpm test
👤 legend80s
- Github: @legend80s
Contributions, issues and feature requests are welcome!
Feel free to check issues page.
- [x] Any port. use unoccupied port.
- [ ] Build with remote client to support a wide range of client gallery.
- [x] Use network IP. mimic create-react-app.
- [x] Show help Information on cli
-v
-h
. - [x] Viewable on mobile.
- [x] Adapt to mobile.
- [ ] Image lazy load.
- [x] Security on privacy. only url with token is shareable.
- [x] Port customizable.
- [x] Token customizable.
- [x] Serve multiple folders in one cmd.
- [x] Token can be optional when viewed on owner's browser.
- [ ] Electron App.
- [x] npm to pnpm.
- [x] Node.js v16 to v22 (LTS 2025-7-10).
- [ ]
Koa v2 to v3.No migration because nothing big changed. - [x]
React v16 → React v19. No migration to React.js v19 because react-images and react-photo-gallery are not v19 supported and not maintained. - [x] Webpack v4 → Vite v7: Performance gain build
26s
→5s
. - [ ] Show thumbnail for first render performance.
- [ ] Next.js.
- [ ] TRPC - share backend request typings with client.
- [ ] FastAPI python.
- [ ] Save UI state (theme) to server using sqlite.
Give a ⭐️ if this project helped you!
This README was generated with ❤️ by readme-md-generator