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/qas.sports-crowd.com/app/Http/Controllers/Exports/ReportInventory.php
<?php

namespace App\Http\Controllers\Exports;

use App\Product;
use Maatwebsite\Excel\Concerns\FromCollection;
use Maatwebsite\Excel\Concerns\WithEvents;
use Maatwebsite\Excel\Concerns\WithHeadings;

class ReportInventory implements FromCollection, WithHeadings, WithEvents
{
    protected $storeType;

    public function __construct($storeType)
    {
        $this->storeType = $storeType;
    }

    // set the headings
    public function headings(): array
    {
        return [
            'Nombre', 'PLU', 'Unidades totales', 'Sucursal', 'SKU', 'Atributo', 'Valor', 'Unidades disponibles', 'Unidades en despacho'
        ];
    }

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

    public function collection()
    {
        $products = Product::select('id', 'name', 'plu', 'available_units', 'sucursal_id')
            ->with('sucursal', 'productAttributes')
            ->where('store_type', $this->storeType)
            ->get();
        $data = [];
        foreach ($products as $product) {
            $sucursal_name = "";
            if ($product->sucursal) {
                $sucursal_name = $product->sucursal->name;
            }
            if ($product->productAttributes && count($product->productAttributes)) {
                foreach ($product->productAttributes as $attribute) {
                    $data[] = array(
                        $product->name,
                        $product->plu,
                        $product->available_units,
                        $sucursal_name,
                        $attribute->sku,
                        $attribute->attribute->display_name,
                        $attribute->value,
                        $attribute->available_units,
                        $attribute->dispatched_units,
                    );
                }
            } else {
                $data[] = array(
                    $product->name, $product->plu, $product->available_units, $sucursal_name
                );
            }
        }
        return collect($data);
    }
}