aldeebhasan / lottie-laravel
This package will allow you to manage and preview lottiefiles in your laravel project
Installs: 6 562
Dependents: 0
Suggesters: 0
Security: 0
Stars: 7
Watchers: 2
Forks: 1
Open Issues: 2
Requires
- php: >=7.4
- ext-json: *
Requires (Dev)
- phpunit/phpunit: ^9.3
This package is auto-updated.
Last update: 2024-12-27 17:37:10 UTC
README
A php package allow you to load lottie files to your blade directly or after making some updates.
Installation
Install using composer:
composer require aldeebhasan/lottie-laravel:1.1.0
A new cache capabilities added to the package, you can enable it by using the following keys to your env file:
LOTTIE_CACHE=false
LOTTIE_CACHE_PERIOD=60
you can publish the config file using the following command:
php artisan vendor:publish --provider="Aldeebhasan\LottieLaravel\LottieLaravelServiceProvider" --tag="config"
Basic Usage
Lottie file component
You can use the lottie file component directly within your blade as following
<x-lottie class="class-1 class-2" style="color:red; background-color:blue;" path="path to lottie file (.json)" animType="animation type (ex: svg)" loop="true|false" autoplay="true|false" :data="array of the lottie file content" > </x-lottie>
All the attributes are optional. Anyway, either
path
or animationData
should be specified in order to
display the lottie.
Lottie files manager
The package also provide a manager to manage the lottie files and make updates over them(like changing the colors)
You can load the lottie file from remote url or pass the file content directly. Check the following
use \Aldeebhasan\LottieLaravel\Facades\Lottie; //from remote $content = Lottie::loadUrl("https://example.json"); //from local array $content = Lottie::loadData([ "v" => "4.8.0", "meta" => [ "g" => "LottieFiles AE 3.0.2", "a" => "", "k" => "", "d" => "", "tc" => "" ], .... ]);
After loading the lottie file to the manager you can change the colors using one of the following
$content = Lottie::loadUrl("https://example.json") ->replaceColor("#000","#0f0f0f") // color with color ->replaceColor(["#000","#00f"],"#fff") // color list with color ->replaceColor(["#000","#00f"],["#fff","#ff0"]); // color list with color list
The function replaceColor
also accept rgb
and rgba
color encoding:
$content = Lottie::loadUrl("https://example.json") ->replaceColor("rgb(0,0,0)",'rgba(255,255,0)'); // color with color
To retrieve the updated lottie data you can use our export
function:
$content = Lottie::loadUrl("https://example.json") ->replaceColor("rgb(0,0,0)",'rgba(255,255,0)') ->export();
Finally, thanks for the lottie-web package author, without their lottie player, we were not able to complete this work.
You can directly get an instance from the lottie manager using our helper function lottie()
$content = lottie()->loadUrl("https://example.json");
Direct Rendering
now you can render the desired lottie file directly in your blade files. Only you need to provide the lottie file data or path, and you will get your view back.
//From URL {!! lottie()->loadUrl('https://assets8.lottiefiles.com/packages/lf20_tuzu65Bu6N.json')->render() !!} //From Data $data = lottie()->loadUrl('https://assets8.lottiefiles.com/packages/lf20_tuzu65Bu6N.json')->export(); {!! lottie()->loadData($data)->render() !!}
Examples
- Loading lottie file directly in the blade:
<x-lottie class="w-50" style="background-color:gray" path="https://assets8.lottiefiles.com/packages/lf20_PmGV4skHBv.json"/>
- Loading lottie file using the manager and pass it to the lottie component:
@php($data = lottie() ->loadUrl('https://assets8.lottiefiles.com/packages/lf20_PmGV4skHBv.json') ->export()) <x-lottie loop="true" :data='$data' /> @php($data2 = lottie() ->loadUrl('https://assets8.lottiefiles.com/packages/lf20_PmGV4skHBv.json') ->replaceColor(["#70D0EF","#B7B7B7","#FF5900"],["#F64848","#FFA900","#003BFF"]) ->export()) <x-lottie loop="true" :data='$data2' />
License
Laravel Lottie Library package is licensed under The MIT License (MIT).
Security contact information
To report a security vulnerability, contact directly to the developer contact email Here.