digitonic / photonic-filament
The Photonic Field is a custom input component designed specifically for ingesting pictures and returning an appropriate CDN link for them
Installs: 98
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 0
Open Issues: 0
pkg:composer/digitonic/photonic-filament
Requires
- php: ^8.2|^8.3|^8.4|^8.5
- ext-fileinfo: *
- filament/filament: ^4.0|^5.0
- saloonphp/saloon: ^3.0
- spatie/laravel-package-tools: ^1.92
Requires (Dev)
- larastan/larastan: ^3.7
- laravel/framework: ^11.0|^12.0
- laravel/pint: ^1.21
- orchestra/testbench: ^9.0|^10.0
- pestphp/pest: ^4.0|^3.8
- pestphp/pest-plugin-arch: ^3.1
- pestphp/pest-plugin-laravel: ^3.0
- phpstan/extension-installer: ^1.4
This package is auto-updated.
Last update: 2026-02-11 12:27:41 UTC
README
A Filament 4 form component package for Laravel 12 that uploads image assets to a third‑party Photonic API, stores metadata in your database, and renders CDN image URLs. It does not persist the uploaded file locally.
We intend this package to be used with the Photonic Server API.
Features
- Optionally records each upload to a dedicated
photonictable. - Includes form component:
PhotonicImageField– composite helper (upload + preview + delete + meta info).
- Blade component
<x-photonic-filament::image>for rendering CDN URLs. - Helpers:
photonic_asset($filename, $assetUuid, $preset = 'original')URL builder.get_photonic_table_name()resolves the media table from config.
Installation
composer require digitonic/photonic-filament
1. Run the installer
php artisan photonic-filament:install
The installer will prompt you for the required Photonic values and will update both your .env and .env.example.
2. Publish and run migrations
php artisan vendor:publish --tag=photonic-filament-migrations php artisan migrate
This creates the photonic table in your database to store image metadata.
Optional: Publish config and views
If you want to customize the config or views:
php artisan vendor:publish --tag=photonic-filament-config php artisan vendor:publish --tag=photonic-filament-views
Configuration
All options live in config/photonic-filament.php and can be set via environment variables:
| Key | Env var | Default | Description |
|---|---|---|---|
| endpoint | PHOTONIC_ENDPOINT | https://photonic.test/api/v1 | Base API URL used by the Saloon connector. |
| cdn_endpoint | PHOTONIC_CDN_ENDPOINT | https://minio.herd.test/photonic | Base CDN URL for image rendering. |
| site_uuid | PHOTONIC_SITE_UUID | (null) | Site identifier sent with each upload. |
| api_key | PHOTONIC_API_KEY | (null) | Bearer API token. |
| file_field | PHOTONIC_FILE_FIELD | file | Multipart field name for the uploaded file. |
| response_key | PHOTONIC_RESPONSE_KEY | original_filename | JSON key inside data used to pull the stored filename. |
| media_model | (class) | Digitonic\Photonic\Filament\Models\Media::class |
Eloquent model used to persist uploads. |
Trait: UsesPhotonic
use Digitonic\Photonic\Filament\Concerns\UsesPhotonic; class Article extends Model { use UsesPhotonic; }
$article->photonicMedia(morphOne)$article->addPhotonicMedia($filename, $presetsArray)$article->removePhotonicMedia($mediaId)
Components
PhotonicImageField
use Digitonic\Photonic\Filament\Forms\Components\PhotonicImageField; PhotonicImageField::make();
Blade component
<x-photonic-filament::image :media="photonic_media_by_id($model->meta['background_image'])" />
Helper functions
photonic_asset(string $filename, string $assetUuid, string $preset = 'original'): ?string;photonic_asset_by_id(int $mediaId, string $preset = 'original', int $cacheTtl = 3600): ?string;photonic_media_by_id(int $mediaId, int $cacheTtl = 3600): ?Media;forget_photonic_cache(int $mediaId): void;get_photonic_table_name(): string;
License
Copyright 2026, Digitonic
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License