Your IP : 216.73.217.77


Current Path : /home/users/unlimited/www/whatsapp-crm/app/Imports/
Upload File :
Current File : /home/users/unlimited/www/whatsapp-crm/app/Imports/ContactGroupsImport.php

<?php

namespace App\Imports;

use App\Models\ContactGroup;
use Illuminate\Support\Facades\Validator;
use Maatwebsite\Excel\Concerns\ToModel;
use Maatwebsite\Excel\Concerns\WithHeadingRow;
use Illuminate\Support\Facades\Log;

class ContactGroupsImport implements ToModel, WithHeadingRow
{
    protected $successfulImports = 0;
    protected $totalImports = 0;
    protected $failedImportsDueToFormat = 0;
    protected $failedImportsDueToDuplicates = 0;

    /**
    * @param array $row
    *
    * @return \Illuminate\Database\Eloquent\Model|null
    */
    public function model(array $row)
    {
        try {
            $this->totalImports++;

            $validator = Validator::make($row, [
                'group_name' => [
                    'required',
                    function ($attribute, $value, $fail) use ($row) {
                        if (ContactGroup::where('organization_id', session()->get('current_organization'))->where('name', $row['group_name'])->whereNull('deleted_at')->exists()) {
                            $this->failedImportsDueToDuplicates++;
                            $fail('The '.$attribute.' already exists.');
                        }
                    }
                ]
            ]);

            if ($validator->fails()) {
                //Log::error($validator->errors()->all());
                return null;
            }
            
            $contactGroup = new ContactGroup([
                'organization_id'  => session()->get('current_organization'),
                'name'  => $row['group_name'],
                'created_by'  => auth()->user()->id,
            ]);

            if($contactGroup){
                $this->successfulImports++;
                return $contactGroup;
            }
        } catch (\Exception $e) {
            /*Log::error('Error importing contact: ' . $e->getMessage(), [
                'row' => $row,
                'exception' => $e,
            ]);*/

            $this->failedImportsDueToFormat++;
            
            return null;
        }
    }

    public function getFailedImportsDueToDuplicatesCount()
    {
        return $this->failedImportsDueToDuplicates;
    }

    public function getFailedImportsDueToFormat()
    {
        return $this->failedImportsDueToFormat;
    }

    public function getSuccessfulImports()
    {
        return $this->successfulImports;
    }

    public function getTotalImportsCount()
    {
        return $this->totalImports;
    }
}