inmanturbo / volt-csv-import-field-mapper
Component to allow user to map fields for csv imports
Installs: 412
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 1
Forks: 0
Open Issues: 0
Language:Blade
Requires
- livewire/volt: ^1.6
- spatie/simple-excel: ^3.6
README
Component to allow user to map fields for csv imports
Tailwind Purge
'./vendor/inmanturbo/volt-csv-import-field-mapper/resources/views/**/*.blade.php',
Usage
use Illuminate\Support\Facades\Storage; use Spatie\SimpleExcel\SimpleExcelReader; use Inmanturbo\ImportFieldMapper\ImportFieldMapper; use App\Models\Contact; use function Livewire\Volt\{on, state}; state([ 'importMap' => [ 'display_name' => 'Display Name', 'email' => 'Email', ], 'uploadDialog' => false, ]); on([ 'import-field-mapper-updated-uploaded-file' => fn($uploadedCsvPath) => $this->uploadedCsvPath = Storage::path( config('import-field-mapper.path') . DIRECTORY_SEPARATOR . $uploadedCsvPath ), 'import-field-mapper-updated-mapped-import-fields' => fn($mappedImportFields) => $this->mappedImportFields = $mappedImportFields, ]); $importCsv = function () { $path = Storage::path(config('import-field-mapper.path'). '/' . $this->uploadedCsvFile); $reader = SimpleExcelReader::create($path); $reader->getRows()->each(function ($row) { $row = ImportFieldMapper::row($row)->toArray(); $action = new class($row, $this->importMap, $this->mappedImportFields) { use \Inmanturbo\ImportFieldMapper\HandlesMappedEloquentAttributes; protected modelClass() { return \App\Models\Contact::class; } } $action->handle(); }); $this->uploadedCsvFile = null; $this->uploadDialog = false; $this->banner($reader->getRows()->count() . ' Contacts imported successfully'); }; <div> <x-button wire:click="$set('uploadDialog', true)" type="file" class="justify-center w-full space-x-1 sm:w-40"> {{_('Upload Csv')}} </x-button> <x-dialog-modal wire:model="uploadDialog" maxWidth="full"> <x-slot name="title"> {{ __('Import Contacts from CSV file') }} </x-slot> <x-slot name="content"> @livewire('import-field-mapper', ['importFieldMap' => $this->importMap,]) </x-slot> <x-slot name="footer"> <x-secondary-button wire:click="$set('uploadDialog', false)" wire:loading.attr="disabled"> {{ __('Cancel') }} </x-secondary-button> <x-button class="ml-3" wire:click="importCsv" wire:loading.attr="disabled"> <div wire:loading> <svg class="w-4 mr-2 animate-spin" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 28 28" fill="none" stroke-width="3"><circle cx="14" cy="14" r="12" stroke="currentColor" class="opacity-25"></circle><path d="M26 14c0-6.627-5.373-12-12-12" stroke-linecap="round" stroke="currentColor" class="opacity-75"></path></svg> </div> {{ __('Save') }} </x-button> </x-slot> </x-dialog-modal> </div>