WIP
This commit is contained in:
@@ -2,6 +2,15 @@
|
||||
|
||||
namespace App\Livewire\Drawer\Album;
|
||||
|
||||
use App\Models\BatchMutation;
|
||||
use App\Services\MediaImporter;
|
||||
use App\Models\Album;
|
||||
use Illuminate\Contracts\View\Factory;
|
||||
use Illuminate\Contracts\View\View;
|
||||
use Illuminate\Support\Facades\Bus;
|
||||
use Livewire\Attributes\Locked;
|
||||
use Livewire\Attributes\On;
|
||||
use Livewire\Attributes\Validate;
|
||||
use Livewire\Component;
|
||||
use Livewire\Features\SupportFileUploads\WithFileUploads;
|
||||
|
||||
@@ -9,9 +18,37 @@ class AddImage extends Component
|
||||
{
|
||||
use WithFileUploads;
|
||||
|
||||
#[Locked]
|
||||
public Album $album;
|
||||
|
||||
#[Locked]
|
||||
public bool $processing = false;
|
||||
|
||||
#[Validate(['media.*' => 'image|max:8192'])] // max:8MB
|
||||
public $media = [];
|
||||
|
||||
public function render()
|
||||
public function save(MediaImporter $importer) : void {
|
||||
$this->validate();
|
||||
|
||||
$jobs = array_map(fn($file) => $importer->import($file, $this->album), $this->media);
|
||||
$batch = Bus::batch($jobs)
|
||||
->name('Media import in ' . $this->album->name)
|
||||
->allowFailures()
|
||||
->dispatch();
|
||||
|
||||
BatchMutation::create([
|
||||
'album_id' => $this->album->id,
|
||||
'batch_id' => $batch->id,
|
||||
]);
|
||||
|
||||
$this->redirect(route('album.show', $this->album), navigate: true);
|
||||
}
|
||||
|
||||
public function mount(Album $album) : void {
|
||||
$this->album = $album;
|
||||
}
|
||||
|
||||
public function render() : View|Factory
|
||||
{
|
||||
return view('livewire.drawer.album.add-image');
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user