承接 imsyuan/filament-image-caption-upload 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

imsyuan/filament-image-caption-upload

最新稳定版本:1.1.0

Composer 安装命令:

composer require imsyuan/filament-image-caption-upload

包简介

Filament v3 FileUpload component with per-image caption support

README 文档

README

Latest Version on Packagist GitHub Tests Action Status License

A Filament v3 form component that extends the built-in FileUpload to attach a per-image caption beneath each uploaded file — with no build step required.

Demo

Features

  • Drop-in replacement — extends Filament's native FileUpload, so every existing option (->image(), ->multiple(), ->reorderable(), ->disk(), ->directory(), ->maxFiles(), …) works unchanged
  • Zero build step — no npm, no Vite, no esbuild; pure Blade + Alpine.js inline
  • Reorder-safe — captions follow their image through drag-and-drop reordering
  • Duplicate-filename safe — maps FilePond internal IDs to Filament UUIDs directly, so ten files all named banner.jpg each keep their own caption
  • Race-condition safe — captions typed before an upload finishes are preserved and migrated to the final UUID automatically
  • Simple storage — saved as a plain [{image, caption}] JSON array in a single column; no extra tables or relationships needed

Requirements

  • PHP 8.2+
  • Laravel 10+
  • Filament 3.x

Installation

composer require imsyuan/filament-image-caption-upload

Laravel auto-discovers the service provider — no manual registration needed.

Usage

use Imsyuan\ImageCaptionUpload\Forms\Components\ImageCaptionUpload;

ImageCaptionUpload::make('photos')
    ->multiple()
    ->image()
    ->reorderable()
    ->captionPlaceholder('Enter a caption…'),

Cast the column as an array in your model:

// app/Models/Post.php
protected $casts = [
    'photos' => 'array',
];

Each field saves an array of {image, caption} pairs:

[
  { "image": "photos/living-room.jpg", "caption": "Living room view" },
  { "image": "photos/kitchen.jpg",     "caption": "Kitchen detail" }
]

Options

captionPlaceholder(string|Closure $placeholder)

Sets the placeholder text shown inside each caption input. Accepts a plain string or a closure. Defaults to 'Caption...'.

// Static
->captionPlaceholder('Add a description…')

// Dynamic
->captionPlaceholder(fn () => __('fields.caption_placeholder'))

All native FileUpload options

Because ImageCaptionUpload extends Filament's FileUpload directly, every built-in option is available:

ImageCaptionUpload::make('photos')
    ->multiple()
    ->image()
    ->maxFiles(10)
    ->reorderable()
    ->appendFiles()
    ->disk('s3')
    ->directory('photos')
    ->visibility('public')
    ->panelLayout('grid')
    ->imageResizeMode('cover')
    ->imageResizeTargetWidth('400')
    ->imageResizeTargetHeight('400'),

How it works

  1. Hydration[{image, caption}] from the database is split on load: file paths go into Filament's UUID-keyed state; captions are stored in a sibling Livewire key (_icap_<fieldname>).
  2. Alpine — A MutationObserver watches for FilePond item additions and injects a caption <input> beneath each file panel. Typing syncs directly to Livewire state via $wire.set().
  3. UUID mapping — FilePond's internal IDs are mapped to Filament UUIDs by reading the FilePond instance directly (pond.getFiles()), ensuring correctness regardless of stored filename or UUID-based disk naming.
  4. Dehydration — On save, {uuid: path} and {uuid: caption} are zipped back into [{image, caption}].

License

MIT — see LICENSE.

统计信息

  • 总下载量: 0
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 5
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: Blade

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-06-10

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固