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: 7

Dependents: 0

Suggesters: 0

Security: 0

Stars: 0

Watchers: 0

Forks: 0

Open Issues: 0

pkg:composer/digitonic/photonic-filament

1.0.2 2026-01-20 12:47 UTC

This package is auto-updated.

Last update: 2026-01-20 12:48:29 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 photonic table.
  • 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
php artisan photonic-filament:install

The installer will prompt you for the required Photonic values and will update both your .env and .env.example.

Optional: publish assets

If you want to customize the config / views, you can still publish them:

php artisan vendor:publish --tag=photonic-filament-config
php artisan vendor:publish --tag=photonic-filament-migrations
php artisan vendor:publish --tag=photonic-filament-views

This creates config/photonic-filament.php, publishes the migration for the photonic table, and the Blade view component.

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