HEX
Server: Apache/2.4.41 (Ubuntu)
System: Linux ip-172-31-42-149 5.15.0-1084-aws #91~20.04.1-Ubuntu SMP Fri May 2 07:00:04 UTC 2025 aarch64
User: ubuntu (1000)
PHP: 7.4.33
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: /var/www/vhost/disk-apps/demo.sports-crowd.com/app/Http/Controllers/Exports/ReportClientsNever.php
<?php

namespace App\Http\Controllers\Exports;

use DB;
use App\User;
use Maatwebsite\Excel\Concerns\FromCollection;
use Maatwebsite\Excel\Concerns\WithEvents;
use Maatwebsite\Excel\Concerns\WithHeadings;

class ReportClientsNever implements FromCollection, WithHeadings, WithEvents
{

    // set the headings
    public function headings(): array
    {
        return [
            'Email', 'Nombres', 'Teléfono', 'Fecha registro', 'Abonado'
        ];
    }

    // freeze the first row with headings
    public function registerEvents(): array
    {
        return [];
    }

    public function collection()
    {
        $users = User::select(
            'users.id',
            'users.first_name',
            'users.last_name',
            'users.email',
            'users.active',
            'users.phone',
            'users.created_at',
            DB::raw('if(users.is_subscriber > 0, "SI", "NO") AS abonado')
        )
            ->whereNotIn('users.id', function ($query) {
                $query->select('client_id')->from('orders');
            })
            ->where('users.rol_id', 4)
            ->whereNull('users.deleted_at')
            ->orderBy('users.id', 'DESC')
            ->get();

        $data = [];
        foreach ($users as $user) {
            $data[] = array(
                $user->email, $user->first_name . ' ' . $user->last_name, $user->phone, $user->created_at, $user->abonado,
            );
        }
        return collect($data);
    }
}