*/ protected $fillable = [ 'name', ]; /** * 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(['name' => $name]); } function pedidosConfirmados() { return $this->pedidos()->where('confirmed',true); } function totalARecaudar() : float { return $this->calcularTotalConfirmados(); } function totalNoBarriales() : float { return $this->calcularTotalConfirmados( fn($p) => $p->total($p->productosNoBarriales()) ); } function totalParaTransporte() : float { return $this->calcularTotalConfirmados( fn($p) => $p->total($p->productosConTransporte()) ); } function totalATransferir() : float { return $this->totalNoBarriales() + TransporteUtils::total($this->totalParaTransporte()); } private function calcularTotalConfirmados(Closure $closure = null) : float { if (!$closure) $closure = fn($p) => $p->totalChismosa(); return $this->pedidosConfirmados()->sum($closure); } /** * Los productos que pertenecen al barrio. */ public function productos(): HasMany { return $this->hasMany(Producto::class); } function exportarPedidoACsv() { if ($this->pedidosConfirmados()->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 $key => $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)]; 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 $key => $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)]; } } } private function cantidadPedida(Producto $producto) : int { return DB::table('pedido_producto') ->join('pedidos', 'pedido_producto.order_id', '=', 'pedidos.id') ->where('pedidos.barrio_id', $this->id) ->where('pedido_producto.producto_id', $producto->id) ->where('pedidos.confirmed', true) ->sum('pedido_producto.cantidad'); } }