Innei b42bfbc520 feat: implement tenant suspension handling and deletion functionality
- Added a new tenant suspension page and related components to inform users when their tenant is suspended due to policy violations.
- Implemented deletion functionality for tenants in the SuperAdminTenantManager, allowing super admins to permanently delete tenant accounts.
- Updated localization files to include new strings for tenant suspension and deletion prompts.
- Enhanced the DataManagementService to handle tenant deletion with metadata checks.

Signed-off-by: Innei <tukon479@gmail.com>
2025-12-05 15:28:21 +08:00
2025-09-11 18:42:47 +08:00
2025-11-12 17:56:22 +08:00
2025-10-26 18:37:56 +08:00
2025-12-05 00:35:32 +08:00
2025-11-25 16:41:21 +08:00
2025-06-05 13:27:09 +08:00
2025-06-05 13:27:09 +08:00

Afilmory

Afilmory

Afilmory (/əˈfɪlməri/, "uh-FIL-muh-ree") is a term created for personal photography websites, blending Auto Focus (AF), aperture (light control), film (vintage medium), and memory (captured moments).

A modern photo gallery website built with React + TypeScript, supporting automatic photo synchronization from multiple storage sources (S3, GitHub), featuring high-performance WebGL rendering, masonry layout, EXIF information display, thumbnail generation, and more.

🚀 Get Started in Seconds

👉 Use the Official SaaS - No setup required!

The easiest way to create your photo gallery is through our hosted service at afilmory.art. Sign up, connect your storage, and your gallery is live in minutes—no deployment, no servers, no maintenance.

Why Use the Official SaaS?

  • Zero setup - No configuration, no deployment, no infrastructure management
  • Live CMS - Edit photos, titles, and metadata in real-time without rebuilding
  • Custom domains - Bind your own domain with DNS verification
  • Automatic updates - Always running the latest version with new features
  • Managed infrastructure - We handle scaling, backups, and maintenance

Get Started Now →


Live Photo Galleries

🌟 Features

Core Functionality

  • 🖼️ High-Performance WebGL Image Renderer - Custom WebGL component with smooth zoom and pan operations
  • 📱 Responsive Masonry Layout - Powered by Masonic, adapts to different screen sizes
  • 🎨 Modern UI Design - Built with Tailwind CSS and Radix UI component library
  • Incremental Sync - Smart change detection, processes only new or modified photos
  • 🌐 i18n - Multi-language support
  • 🔗 OpenGraph - OpenGraph metadata for social media sharing

Image Processing

  • 🔄 HEIC/HEIF Format Support - Automatic conversion of Apple device HEIC format
  • 📷 TIFF Format Support - Automatic conversion of TIFF format
  • 🖼️ Smart Thumbnail Generation - Multi-size thumbnails for optimized loading performance
  • 📊 EXIF Information Display - Complete shooting parameters including camera model, focal length, aperture, etc.
  • 🌈 Blurhash Placeholders - Elegant image loading experience
  • 📱 Live Photo Support - Detection and display of iPhone Live Photos
  • ☀️ HDR Image Support - Display HDR images

Advanced Features

  • 🎛️ Fujifilm Recipe - Read and display Fujifilm camera film simulation settings
  • 🔍 Fullscreen Viewer - Image viewer with gesture support
  • 🏷️ File System Tags - Auto-generated tags based on file system
  • Concurrent Processing - Multi-process/multi-thread concurrent processing support
  • 🗂️ Multi-Storage Support - S3, GitHub, and other storage backends
  • 📷 Share Image - Share image to social media or embed iframe to your website
  • 🗺️ Interactive Map Explorer - Geographic visualization of photos with GPS coordinates from EXIF data using MapLibre

🏗️ Technical Architecture

Frontend Tech Stack

  • React 19 - Latest React version with Compiler
  • TypeScript - Complete type safety
  • Vite - Modern build tool
  • Tailwind CSS - Atomic CSS framework
  • Radix UI - Accessible component library
  • Jotai - State management
  • TanStack Query - Data fetching and caching
  • React Router 7 - Routing management
  • i18next - Internationalization

Build System

  • Node.js - Server-side runtime
  • Sharp - High-performance image processing
  • AWS SDK - S3 storage operations
  • Worker Threads/Cluster - Concurrent processing
  • EXIF-Reader - EXIF data extraction

Storage Architecture

Designed with adapter pattern, supporting multiple storage backends:

  • S3-Compatible Storage - AWS S3, MinIO, Alibaba Cloud OSS, etc.
  • GitHub Storage - Using GitHub repository as image storage
  • Eagle Storage - Using Eagle app library as image storage
  • Local File System - Local storage for development and testing

🛠️ Self-Host (Advanced)

If you prefer to host Afilmory yourself, you can deploy it on your own infrastructure. This requires more technical knowledge and ongoing maintenance.

💡 Tip: For most users, we recommend using the official SaaS instead. Self-hosting is best suited for developers who need full control over their deployment or have specific infrastructure requirements.

Docker deployment guide ships prebuilt images with minimal setup.

Option B: Manual install

  1. Copy config.example.json to config.json and fill in your site name, description, and social links.
  2. Prepare access to your photo storage (S3/B2/GitHub/local). The builder will read photos and generate thumbnails plus photos-manifest.json.
  3. Run the builder to generate assets, then start the site.

Looking for developer commands, environment variables, and builder config details? See DEVELOPMENT.md.

For detailed self-hosting instructions, see the Documentation.

🔧 Advanced Usage

Custom Storage Provider

Implement the StorageProvider interface to support new storage backends:

import { StorageProvider } from './src/core/storage/interfaces'

class MyStorageProvider implements StorageProvider {
  async getFile(key: string): Promise<Buffer | null> {
    // Implement file retrieval logic
  }

  async listImages(): Promise<StorageObject[]> {
    // Implement image list retrieval logic
  }

  // ... other methods
}

Custom Image Processing

Add custom processors in the src/core/image/ directory:

export async function customImageProcessor(buffer: Buffer) {
  // Custom image processing logic
  return processedBuffer
}

📄 License

Attribution Network License (ANL) v1.0 © 2025 Afilmory Team. See LICENSE for more details.

📚 Documentation


If this project helps you, please give it a Star for support!

Description
No description provided
Readme Multiple Licenses 120 MiB
Languages
TypeScript 95.6%
MDX 2.1%
JavaScript 1%
CSS 0.7%
HTML 0.5%