Get expert guidance in a few days with a Laravel code review

Livewire Filepond

spatie/livewire-filepond image

Livewire Filepond stats

Downloads
449
Stars
107
Open Issues
3
Forks
4

View on GitHub →

Upload files using Filepond in Livewire components

Upload files using Filepond in Livewire components

Filepond is a powerful JavaScript library to upload files.

This repository contains a Livewire component that allow you to use Filepond easily in your projects.

Here's an example of how you can use it in your views:

<x-filepond::upload wire:model="file" />

Here's how it looks like in action in mailcoach.app (a product we built at Spatie):

Support us

We invest a lot of resources into creating best in class open source packages. You can support us by buying one of our paid products.

We highly appreciate you sending us a postcard from your hometown, mentioning which of our package(s) you are using. You'll find our address on our contact page. We publish all received postcards on our virtual postcard wall.

Installation

You can install the package via composer:

composer require spatie/livewire-filepond

Optionally, you can publish the views using

php artisan vendor:publish --tag="livewire-filepond-views"

Usage

First, add the scripts to your layout or view where you want to use Filepond:

@filepondScripts

Next, add the WithFilePond trait to your component:

use Livewire\Component;
use Spatie\LivewireFilepond\WithFilePond;
 
class MyLivewireComponent extends Component
{
use WithFilePond;
 
public $file;
}

Finally, add the component to your view:

<x-filepond::upload wire:model="file" />

Customizing the component

Optionally, you can use these component properties to customize the component:

  • multiple: Allow multiple files to be uploaded. Default: false.
  • required: Make the file input required. Default: false.
  • disabled: Disable the file input. Default: false.
  • placeholder: Placeholder text for the file input. Default: Drag & Drop your files or <span class="filepond--label-action"> Browse </span>.

Additionally, you can also pass any property that the Filepond component accepts. Make sure to use kebab case the property. For example, to set the maximum number of files to 5, you can do this:

<x-filepond::upload wire:model="file" max-files="5" />

Publishing assets

Livewire Filepond automatically loads the scripts through an endpoint. If you want to serve the assets directly, you can publish them:

php artisan vendor:publish --tag=livewire-filepond-assets --force

To keep the assets up to that at all times, you can add the command above to your Composer's post-update-cmd scripts.

Testing

composer test

Changelog

Please see CHANGELOG for more information on what has changed recently.

Contributing

Please see CONTRIBUTING for details.

Security Vulnerabilities

Please review our security policy on how to report security vulnerabilities.

Credits

License

The MIT License (MIT). Please see License File for more information.

spatie photo

We create open source, digital products and courses for the developer community

Cube

Laravel Newsletter

Join 40k+ other developers and never miss out on new tips, tutorials, and more.


Spatie Livewire Filepond Related Articles

Upload Files Using Filepond in Livewire Components image

Upload Files Using Filepond in Livewire Components

Read article
Honeybadger logo

Honeybadger

Simple developer-focused application monitoring for Laravel. Error tracking, log management, uptime monitoring, status pages, and more!

Honeybadger
LoadForge logo

LoadForge

Scalable load testing for web apps & APIs. Simulate real-world traffic and identify breaking points and performance limits with powerful, scalable load tests designed for Laravel.

LoadForge
PhpStorm logo

PhpStorm

The go-to PHP IDE with extensive out-of-the-box support for Laravel and its ecosystem.

PhpStorm
The Certification of Competence for Laravel logo

The Certification of Competence for Laravel

A community-driven, proctored assessment across 4 levels designed to validate real-world Laravel knowledge, from Junior to mastery-level Artisan. Official Vue.js, Official Nuxt, Angular, React, JS certifications also available.

The Certification of Competence for Laravel
Celebian logo

Celebian

Celebian is a social media marketing agency specializing in helping their clients go viral on TikTok. Whether you're looking to reach a bigger audience or gain more Tiktok followers, likes, and views, they've got you covered.

Celebian
CodeKudu logo

CodeKudu

Stand-ups, Retrospectives, and 360° Feedback for the entire team. 50% off with code LARAVELNEWS.

CodeKudu