In this post, I will show you How to Download File in Laravel Livewire 3.
In this example, we will create a PhotoUpload Livewire component. This component will feature a form with a file input field and include image validation. The user can select an image, which will then be uploaded to the storage folder using the `WithFileUploads` trait. Additionally, we will also display list of images and user can download image as well. You Can Learn How To File Uploading Laravel Livewire 3
How to Download File in Laravel Livewire 3 Example
Step 1: Create PhotoUpload Component
Now here we will create a Livewire component using their command. So run the following command to create an add more component.
php artisan make:livewire PhotoUpload
Now they created files on both paths:
app/Livewire/PhotoUpload.php
resources/views/livewire/photo-upload.blade.php
Now, both files we will update as below for our contact us form.
app/Livewire/PhotoUpload.php
<?php
namespace App\Livewire;
use Livewire\Component;
use Livewire\WithFileUploads;
use App\Models\Image;
use Illuminate\Support\Facades\Storage;
class PhotoUpload extends Component
{
use WithFileUploads;
public $photo;
public function render()
{
return view('livewire.photo-upload', [
"images" => Image::all()
]);
}
public function submit(){
$this->validate([
"photo" => "required|image"
]);
$filepath = $this->photo->store("photos");
$image = Image::create([
"title" => "Test",
"filepath" => $filepath
]);
info($image)
}
public function download($path)
{
return Storage::download($path);
}
}
resources/views/livewire/photo-upload.blade.php
<div>
<form wire:submit="submit">
@if($photo)
Photo Preview:
<img src="{{ $photo->temporaryUrl() }}" width="400px"><br/>
@endif
<label>Image:</label>
<input type="file" name="photo" class="form-control" wire:model="photo">
@error("photo")
<p class="text-danger">{{ $message }}</p>
@enderror
<button class="btn btn-success">Submit</button>
</form>
<table class="table table-striped table-bordered mt-3">
<thead>
<tr>
<th>ID</th>
<th>Name</th>
<th>Download</th>
</tr>
</thead>
<tbody>
@foreach($products as $product)
<tr>
<td>{{ $product->id }}</td>
<td>{{ $product->title }}</td>
<td><button class="btn btn-info btn-sm" wire:click="download({{ $image->filepath }})">Download</button></td>
</tr>
@endforeach
</tbody>
</table>
</div>
Step 2: Use Livewire Component
now, we will user counter component in home page. so you need to update home.blade.php file as the following way:
resources/views/home.blade.php
@extends('layouts.app')
@section('content')
<div class="container">
<div class="row justify-content-center">
<div class="col-md-8">
<div class="card">
<div class="card-header">{{ __('Counter') }}</div>
<div class="card-body">
<livewire:photo-upload />
</div>
</div>
</div>
</div>
</div>
@endsection
Run Laravel:
All the required steps have been done, now you have to type the given below command and hit enter to run the Laravel app:
php artisan serve
Now, Go to your web browser, type the given URL and view the app output:
http://localhost:8000/
I hope it can help you…