Your IP : 216.73.217.77


Current Path : /home/users/unlimited/www/dabbawali.sizzlingcafe.co.in/app/Imports/
Upload File :
Current File : /home/users/unlimited/www/dabbawali.sizzlingcafe.co.in/app/Imports/ItemCategoryImport.php

<?php

namespace App\Imports;

use App\Libraries\EnumAppLibrary;
use App\Models\ItemCategory;
use Illuminate\Support\Str;
use Illuminate\Validation\Rule;
use Maatwebsite\Excel\Concerns\ToModel;
use Maatwebsite\Excel\Concerns\Importable;
use Maatwebsite\Excel\Concerns\SkipsFailures;
use Maatwebsite\Excel\Concerns\SkipsEmptyRows;
use Maatwebsite\Excel\Concerns\SkipsOnFailure;
use Maatwebsite\Excel\Concerns\WithHeadingRow;
use Maatwebsite\Excel\Concerns\WithValidation;


class ItemCategoryImport implements ToModel, WithHeadingRow, WithValidation, SkipsOnFailure, SkipsEmptyRows
{
    use Importable, SkipsFailures;

    public function model(array $row)
    {
            return new ItemCategory([
                'name' => $this->sanitizeInput($row['name'] ?? ''),
                'slug' => Str::slug($this->sanitizeInput($row['name'])),
                'status' => EnumAppLibrary::itemStatus($row['status']),
                'description' => $this->sanitizeInput($row['description'] ?? ''),
            ]);
    }

    public function rules(): array
    {
        return [
            'name'        => [
                'required',
                'string',
                'max:190',
                Rule::unique("item_categories", "name")
            ],
            'description' => ['nullable', 'string', 'max:900'],
            'status'      => ['nullable', 'string'],
        ];
    }

    private function sanitizeInput($value): array|bool|string
    {
        return mb_convert_encoding(trim($value), 'UTF-8', 'UTF-8');
    }

}