goodm4ven/blurred-image
最新稳定版本:v1.2.2
Composer 安装命令:
composer require goodm4ven/blurred-image
包简介
An elegant wrapper around Blurhash for the TALL stack
关键字:
README 文档
README
بسم الله الرحمن الرحيمblurred-image
An elegant wrapper around Blurhash for the TALL stack, so Laravel projects can show colorful blurred placeholders while the real image loads.
2025-12-14.19-16-48.mp4
How it works
- Generate a tiny blurred thumbnail for the image you want to render. You can do that via the Artisan command, the
BlurredImagefacade, or by registering a conversion through Spatie Media Library. - Pass both the final image URL (or the associated Media Library model+collection) and the thumbnail URL to the Blade component called
blurred-image. - The component:
- Renders an empty gray canvas immediately.
- Sends the thumbnail through Blurhash to animate a colorful, blurred version of the image.
- Replaces the blurhash with the real image once it has fully intersected the viewport or finished downloading, depending on your configuration.
Once configured, the component handles the placeholder animation for you so you can focus on content.
Installation
Install the package with Composer:
composer require goodm4ven/blurred-image
If you use Spatie's Laravel Media Library and want the model/collection scenario, install that package and add the HasBlurredImages trait to your model so addBlurredThumbnailConversion conversion method becomes available:
composer require spatie/laravel-medialibrary
use GoodMaven\BlurredImage\Concerns\HasBlurredImages; use Spatie\MediaLibrary\HasMedia; use Spatie\MediaLibrary\InteractsWithMedia; class User extends Model implements HasMedia { use InteractsWithMedia; use HasBlurredImages; public function registerMediaCollections(): void { $this ->addMediaCollection('profile-picture') ->singleFile() ->registerMediaConversions(function (Media $media) { $this->addBlurredThumbnailConversion(); }); } }
Publish the assets so the JavaScript helper, CSS, and placeholder images are copied to public/vendor/blurred-image.
php artisan vendor:publish --tag="blurred-image-assets"
Warning
Note that AlpineJS and its Intersect plugin are not bundled with these assets.
You may also publish additional resources to tailor the package to your project:-
Config file (to adjust defaults such as
conversion_nameand the component flags):php artisan vendor:publish --tag="blurred-image-config"- Check the current configurations for more settings.
-
Views (if you need to override the Blade template):
php artisan vendor:publish --tag="blurred-image-views"
Notes
- Static assets: Generate a
*-blur-thumbnail.*file next to your source image withphp artisan blurred-image:generate <imagePath>so the blurhash can render client-side. - Optimization:
is_generation_optimizedis enabled by default and runsblurred-image:optimizeon both the source image and the generated thumbnail whenever you call the generator command. - Media Library collections: Always sync
conversion_namewith the config by usingaddBlurredThumbnailConversionfrom theHasBlurredImagestrait. - Intersection/delay: Set
is_eager_loadedto preload the image or leave itfalseto wait for intersection; adjustis_display_enforcedif the final image should appear before an intersection callback.
Usage
-
Load both AlpineJS and its Intersect plugin before using the component.
-
Generate a blurred thumbnail before the first render:
php artisan blurred-image:generate storage/app/public/example.jpg # or, to only optimize an existing image manually php artisan blurred-image:optimize storage/app/public/example.jpguse GoodMaven\BlurredImage\Facades\BlurredImage; BlurredImage::generate(storage_path('app/public/example.jpg'));
Use cases overview
Use the blurred-image component in two primary ways:
- Static assets: Pass explicit image and thumbnail URLs for banners, seeded data, etc.
- Media Library: Provide a model and collection, letting the component read the conversion registered via
HasBlurredImages. UsemediaIndexto select from multiple media items.
Extra options to consider:
- Slot overlays: Place foreground content inside the component slot so your UI sits atop the blurhash and final image.
- Intersection tuning: Toggle
is_eager_loadedto preload the image, toggleis_display_enforcedto reveal the final image before intersection fires.
1. Render with explicit paths
<x-goodmaven::blurred-image :imagePath="asset('images/hero.jpg')" :thumbnailImagePath="asset('images/hero-blur-thumbnail.jpg')" :isDisplayEnforced="true" alt="Coastal trail" />
2. Render from the Media Library
Attach media to a model that uses HasBlurredImages and its conversion method:
$user = User::first(); $user ->addMedia($pathToImage) ->preservingOriginal() ->toMediaCollection('profile-picture');
<x-goodmaven::blurred-image :model="$user" :collection="'profile-picture'" :mediaIndex="0" />
Extra: Slot overlays and intersection tweaks
<x-goodmaven::blurred-image :image-path="asset('images/poster.jpg')" :thumbnail-image-path="asset('images/poster-blur-thumbnail.jpg')" :is-eager-loaded="false" :is-display-enforced="false" width-class="w-full" height-class="h-[520px]" > <div class="absolute inset-0 bg-linear-to-t from-black/60"></div> <div class="relative z-10 p-6 text-white"> <p class="text-lg font-semibold">Deferred reveal</p> <p class="text-sm text-white/70">Blurhash shows immediately; the full image waits for an intersection.</p> </div> </x-goodmaven::blurred-image>
Configuration for flags such as is_eager_loaded, is_display_enforced, and the conversion_name lives in the configuration file.
Edge Case
Important
If the parent element, that contains the component, doesn’t have an explicit height, like being absolute or whatever, you MUST explicitely set the heightClass yourself; like providing aspect-[4/3] or h-48 classes. And ensure a proper width too. You can check the props defaults at the top of blurred-image.blade.php file.
Development
This package was initiated based on my Laravel package template that is built on top of Spatie's. Make sure to read the docs for both.
Tasks
- // TODO Improve tests or rework them to avoid CI failing sometimes after tracing the cause
- // TODO Rework the demo Livewire component setup to load more images into the page, from both DB and fake-urls, and visualize the benifit
Support
Support ongoing package maintenance as well as the development of other projects through sponsorship or one-time donations if you prefer.
Credits
- Inspired by Blurhash.
- TALL Stack Community
- TailwindCSS
- AlpineJS
- Laravel
- Laravel Media Library
- Spatie Team
- ChatGPT & Codex
- GoodM4ven
- All Contributors
والحمد لله رب العالمين
统计信息
- 总下载量: 24
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 1
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2025-12-23