/** * Actualiza a 0's el monto de cada artículo cotizado en la tabla articulos */ public function unsetMontoArticulo() { foreach ($this->articulos as $articulo) { $articulo_x_modificar = Articulo::find($articulo->id); $articulo_x_modificar->monto = 0; $articulo_x_modificar->save(); } }
/** * Show the form for editing the specified resource. * * @param int $req_id * @param int $articulo_id * @return Response */ public function edit($req_id, $articulo_id) { $articulo = Articulo::find($articulo_id); //Verifica que el artículo corresponda a la requisición if ($articulo->req_id == $req_id) { $solicita = User::find($articulo->req->solicita); $data['solicita'] = $solicita; $unidades = Unidad::all(); foreach ($unidades as $unidad) { $arr_unidades[$unidad->tipo][$unidad->unidad] = $unidad->unidad; } $data['articulo'] = $articulo; $data['req'] = $articulo->req; $data['unidades'] = $arr_unidades; return view('reqs.formArticulo')->with($data); } else { return redirect()->action('RequisicionController@show', array($req_id))->with(['alert-class' => 'alert-warning', 'message' => 'El artículo no corresponde a la requisición']); } }
/** * Actualiza cuadro comparativo * * @param int $id * @return Response */ public function update($id, MatrizCuadroRequest $request) { /** * @todo Validar que no se seleccione una cotización de un artículo con costo == 0 */ $cuadro = Cuadro::find($id); $arr_articulos_id = Articulo::whereReqId($cuadro->req_id)->lists('id')->all(); $arr_cotizaciones_id = Cotizacion::whereReqId($cuadro->req_id)->lists('id')->all(); foreach ($arr_articulos_id as $articulo_id) { $articulo = Articulo::find($articulo_id); $sel_value = $request->input('sel_' . $articulo_id); $no_cotizado = $request->input('no_cotizado_' . $articulo_id); if (empty($no_cotizado)) { $no_cotizado = 0; } foreach ($arr_cotizaciones_id as $cotizacion_id) { $costo_nuevo = $request->input('costo_' . $articulo_id . '_' . $cotizacion_id); if (isset($costo_nuevo)) { $sel_value == $cotizacion_id && $costo_nuevo > 0 && empty($no_cotizado) ? $sel = 1 : ($sel = 0); //Verifica existencia de pivote if ($articulo->cotizaciones()->get()->contains($cotizacion_id)) { $costo_actual = $articulo->cotizaciones()->whereCotizacionId($cotizacion_id)->first()->pivot->costo; $sel_actual = $articulo->cotizaciones()->whereCotizacionId($cotizacion_id)->first()->pivot->sel; if ($costo_actual != $costo_nuevo || $sel_actual != $sel) { $articulo->cotizaciones()->updateExistingPivot($cotizacion_id, ['costo' => round($costo_nuevo, 2), 'sel' => $sel]); } } else { //Crea un nuevo registro en pivote articulo_cotizacion $articulo->cotizaciones()->attach([$cotizacion_id => ['costo' => round($costo_nuevo, 2), 'sel' => $sel]]); } } } //Actualizar impuesto en articulos $articulo->impuesto = $request->input('impuesto_' . $articulo_id); $articulo->no_cotizado = $no_cotizado; $articulo->save(); } //Actualiza información de vigencia y garantía @cotizaciones foreach ($arr_cotizaciones_id as $cotizacion_id) { $cotizacion = Cotizacion::find($cotizacion_id); $cotizacion->vigencia = $request->input('vigencia_' . $cotizacion_id); $cotizacion->garantia = $request->input('garantia_' . $cotizacion_id); $cotizacion->imprimir = true; $cotizacion->save(); } //Actualizar Tipo de Cambio en @reqs $tipo_cambio = $request->input('tipo_cambio'); $moneda = $request->input('moneda'); $req = Req::find($cuadro->req_id); if ($req->tipo_cambio != $tipo_cambio || $req->moneda != $moneda) { $req->tipo_cambio = $tipo_cambio; $req->moneda = $moneda; $req->save(); } return redirect()->action('MatrizCuadroController@show', array($cuadro->req_id)); }
private function actualizar_articulo($id, $oc_id) { $articulo = Articulo::find($id); $articulo->oc_id = $oc_id; $articulo->save(); }