HEX
Server: Apache/2.4.58 (Ubuntu)
System: Linux Bradford-Sitios 6.14.0-1017-azure #17~24.04.1-Ubuntu SMP Mon Dec 1 20:10:50 UTC 2025 x86_64
User: www-data (33)
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/dtw.bradford/app/Models/InventoryPurchaseOrders.php
<?php

namespace App\Models;

use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;

class InventoryPurchaseOrders extends Model
{
    use HasFactory;

    protected $table = 'inventory_purchase_orders_view';

    public $timestamps = false;

    protected $fillable = [
        'id',
        'type_request',
        'responsible',
        'provider_social_reason',
        'provider_rut',
        'observation',
        'quantity',
        'subtotal',
        'tax',
        'total',
        'tax_type',
        'status_purchase_order',
        'status_integration',
        'odoo_document_id',
        'odoo_service_name',
        'odoo_account_analytic',
        'accounting_account',
        'date_purchase_order',
        'creation_date',
        'branch',
        'purchase_order_details' // JSON con los detalles de productos o servicios
    ];

    // Método para obtener detalles de líneas de la orden de compra
    protected function details()
    {
        return collect(json_decode($this->purchase_order_details, true))->map(function ($line) {
            return [
                'detail_id' => $line['detail_id'],
                'product_id' => $line['product_id'],
                'service' => $line['service'],
                'quantity' => $line['quantity'],
                'price' => $line['price'],
                'subtotal' => $line['subtotal'],
                'bar_code' => $line['bar_code'],
                'product' => $line['product'],
                'product_odoo_id' => $line['product_odoo_id'],
                'presentation' => $line['presentation'],
            ];
        });
    }

    // Sobrescribir el método toArray
    public function toArray()
    {
        $array = parent::toArray();
        $array['purchase_order_details'] = $this->details();
        return $array;
    }
}