111 lines
		
	
	
	
		
			3.6 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			111 lines
		
	
	
	
		
			3.6 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| namespace App\Models;
 | |
| 
 | |
| use Illuminate\Database\Eloquent\Relations\HasMany;
 | |
| use Illuminate\Database\Eloquent\Relations\BelongsTo;
 | |
| use Illuminate\Database\Eloquent\Model;
 | |
| use League\Csv\CannotInsertRecord;
 | |
| use League\Csv\Writer;
 | |
| 
 | |
| class Barrio extends Model
 | |
| {
 | |
|     /**
 | |
|      * The attributes that are mass assignable.
 | |
|      *
 | |
|      * @var array<int, string>
 | |
|      */
 | |
|     protected $fillable = [
 | |
|         'nombre',
 | |
|     ];
 | |
| 
 | |
|     /**
 | |
|      * La región a la que pertenece el barrio.
 | |
|      */
 | |
|     public function region(): BelongsTo
 | |
|     {
 | |
|         return $this->belongsTo(Region::class);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Los pedidos que pertenecen al barrio.
 | |
|      */
 | |
|     public function pedidos(): HasMany
 | |
|     {
 | |
|         return $this->hasMany(Pedido::class);
 | |
|     }
 | |
| 
 | |
|     function crearPedido(string $nombre) : Pedido {
 | |
|         return $this->pedidos()->create(['nombre' => $name]);
 | |
|     }
 | |
| 
 | |
|     function totalARecaudar() : float {
 | |
|         return $this->calcularTotalPagados();
 | |
|     }
 | |
| 
 | |
|     private function calcularTotalPagados(Closure $closure = null) : float {
 | |
|         if (!$closure)
 | |
|             $closure = fn($p) => $p->totalChismosa();
 | |
|         return $this->pedidosPagados()->sum($closure);
 | |
|     }
 | |
| 
 | |
|     function totalATransferir() : float {
 | |
|         return $this->calcularTotalPagados($p->totalATransferir());
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Los productos que pertenecen al barrio.
 | |
|      */
 | |
|     public function productos(): HasMany
 | |
|     {
 | |
|         return $this->hasMany(Producto::class);
 | |
|     }
 | |
| 
 | |
|     function exportarPedidoACsv() {
 | |
|         if ($this->pedidosPagados()->exists()) {
 | |
|             $columnaProductos = $this->armarColumnasPedido();
 | |
| 
 | |
|             try {
 | |
|                 $writer = Writer::createFromPath(resource_path('csv/exports/'.$this->nombre.'.csv'), 'w');
 | |
|                 $writer->insertAll($columnaProductos);
 | |
|             } catch (CannotInsertRecord $e) {
 | |
|                 var_export($e->getRecords());
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     private function armarColumnasPedido() : array {
 | |
|         $columnaProductos = [];
 | |
|         $filasVaciasAgregadas = false;
 | |
| 
 | |
|         foreach (Categoria::orderBy('id')->get() as $keyC => $categoria) {
 | |
|             $columnaProductos[] = ['name' => $categoria->name, 'cantidad' => null];
 | |
| 
 | |
|             if ($categoria->name == 'TRANSPORTE, BONOS Y FINANCIAMIENTO SORORO')
 | |
|                 $columnaProductos[] = ['name' => 'Bono de Transporte', 'cantidad' => TransporteUtils::cantidad($this->totalParaTransporte)];
 | |
|             else if ($categoria->name == 'PRODUCTOS DE GESTIÓN MENSTRUAL')
 | |
|                 $columnaProductos[] = ['name' => '¿Cuántas copas quieren y pueden comprar en el grupo?', 'cantidad' => null];
 | |
| 
 | |
|             foreach ($categoria->productos()->orderBy('id')->get() as $keyP => $producto) {
 | |
|                 if ($producto->price == 0 && !$filasVaciasAgregadas) {
 | |
|                     $columnaProductos[] = ['name' => '¿Cuántas copas quieren adquirir a través del financiamiento sororo?', 'cantidad' => null];
 | |
|                     $filasVaciasAgregadas = true;
 | |
|                 }
 | |
|                 $columnaProductos[] = ['name' => $producto->name, 'cantidad' => $this->cantidadPedida($producto->id)];
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     private function cantidadPedida($productoId) {
 | |
|         $pedidos = $this->pedidos()
 | |
|                         ->whereHas('productos', 
 | |
|                             function ($query) use ($productoId) {
 | |
|                                 $query->where('producto_id', $productoId);})
 | |
|                         ->get();
 | |
| 
 | |
|         return $pedidos->sum(function ($pedido) use ($productoId) {
 | |
|                                 return $pedido->productos
 | |
|                                               ->find($productoId)
 | |
|                                               ->pivot->cantidad ?? 0;});
 | |
|     }
 | |
| }
 |