En este capítulo finalizamos el sistema CRUD con la actualización de registros, para ello crearemos una nueva acción-vista llamada Update desde la cual podremos editar el alumno seleccionado a través de su id, para la selección del registro utilizaremos el método findOne($id) que buscará el registro a través de la clave primaria dada en el argumento, para la actualización utilizaremos el método update() que pasado por una sentencia if, nos regresará un valor boolean: true si la actualización se ha podido llevar a cabo correctamente y false para todo lo contrario.
findOne(): http://www.yiiframework.com/doc-2.0/yii-db-baseactiverecord.html#findOne()-detail
update(): http://www.yiiframework.com/doc-2.0/yii-db-activerecord.html#update()-detail
El código que interviene en el capítulo lo podéis ver a continuación:
Modificación en la acción view.php para agregar la ruta en el link de editar
<?php use yii\helpers\Url; use yii\helpers\Html; use yii\widgets\ActiveForm; use yii\data\Pagination; use yii\widgets\LinkPager; ?> <a href="<?= Url::toRoute("site/create") ?>">Crear un nuevo alumno</a> <?php $f = ActiveForm::begin([ "method" => "get", "action" => Url::toRoute("site/view"), "enableClientValidation" => true, ]); ?> <div class="form-group"> <?= $f->field($form, "q")->input("search") ?> </div> <?= Html::submitButton("Buscar", ["class" => "btn btn-primary"]) ?> <?php $f->end() ?> <h3><?= $search ?></h3> <h3>Lista de alumnos</h3> <table class="table table-bordered"> <tr> <th>Id Alumno</th> <th>Nombre</th> <th>Apellidos</th> <th>Clase</th> <th>Nota Final</th> <th></th> <th></th> </tr> <?php foreach($model as $row): ?> <tr> <td><?= $row->id_alumno ?></td> <td><?= $row->nombre ?></td> <td><?= $row->apellidos ?></td> <td><?= $row->clase ?></td> <td><?= $row->nota_final ?></td> <td><a href="<?= Url::toRoute(["site/update", "id_alumno" => $row->id_alumno]) ?>">Editar</a></td> <td> <a href="#" data-toggle="modal" data-target="#id_alumno_<?= $row->id_alumno ?>">Eliminar</a> <div class="modal fade" role="dialog" aria-hidden="true" id="id_alumno_<?= $row->id_alumno ?>"> <div class="modal-dialog"> <div class="modal-content"> <div class="modal-header"> <button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">×</span></button> <h4 class="modal-title">Eliminar alumno</h4> </div> <div class="modal-body"> <p>¿Realmente deseas eliminar al alumno con id <?= $row->id_alumno ?>?</p> </div> <div class="modal-footer"> <?= Html::beginForm(Url::toRoute("site/delete"), "POST") ?> <input type="hidden" name="id_alumno" value="<?= $row->id_alumno ?>"> <button type="button" class="btn btn-default" data-dismiss="modal">Cerrar</button> <button type="submit" class="btn btn-primary">Eliminar</button> <?= Html::endForm() ?> </div> </div><!-- /.modal-content --> </div><!-- /.modal-dialog --> </div><!-- /.modal --> </td> </tr> <?php endforeach ?> </table> <?= LinkPager::widget([ "pagination" => $pages, ]);
Código de la vista update.php
<?php use yii\helpers\Html; use yii\widgets\ActiveForm; use yii\helpers\Url; ?> <a href="<?= Url::toRoute("site/view") ?>">Ir a la lista de alumnos</a> <h1>Editar alumno con id <?= Html::encode($_GET["id_alumno"]) ?></h1> <h3><?= $msg ?></h3> <?php $form = ActiveForm::begin([ "method" => "post", 'enableClientValidation' => true, ]); ?> <?= $form->field($model, "id_alumno")->input("hidden")->label(false) ?> <div class="form-group"> <?= $form->field($model, "nombre")->input("text") ?> </div> <div class="form-group"> <?= $form->field($model, "apellidos")->input("text") ?> </div> <div class="form-group"> <?= $form->field($model, "clase")->input("text") ?> </div> <div class="form-group"> <?= $form->field($model, "nota_final")->input("text") ?> </div> <?= Html::submitButton("Actualizar", ["class" => "btn btn-primary"]) ?> <?php $form->end() ?>
Código de SiteController.php donde se encuentra la acción Update
<?php namespace app\controllers; use Yii; use yii\filters\AccessControl; use yii\web\Controller; use yii\filters\VerbFilter; use app\models\LoginForm; use app\models\ContactForm; use app\models\ValidarFormulario; use app\models\ValidarFormularioAjax; use yii\widgets\ActiveForm; use yii\web\Response; use app\models\FormAlumnos; use app\models\Alumnos; use app\models\FormSearch; use yii\helpers\Html; use yii\data\Pagination; use yii\helpers\Url; class SiteController extends Controller { public function actionUpdate() { $model = new FormAlumnos; $msg = null; if($model->load(Yii::$app->request->post())) { if($model->validate()) { $table = Alumnos::findOne($model->id_alumno); if($table) { $table->nombre = $model->nombre; $table->apellidos = $model->apellidos; $table->clase = $model->clase; $table->nota_final = $model->nota_final; if ($table->update()) { $msg = "El Alumno ha sido actualizado correctamente"; } else { $msg = "El Alumno no ha podido ser actualizado"; } } else { $msg = "El alumno seleccionado no ha sido encontrado"; } } else { $model->getErrors(); } } if (Yii::$app->request->get("id_alumno")) { $id_alumno = Html::encode($_GET["id_alumno"]); if ((int) $id_alumno) { $table = Alumnos::findOne($id_alumno); if($table) { $model->id_alumno = $table->id_alumno; $model->nombre = $table->nombre; $model->apellidos = $table->apellidos; $model->clase = $table->clase; $model->nota_final = $table->nota_final; } else { return $this->redirect(["site/view"]); } } else { return $this->redirect(["site/view"]); } } else { return $this->redirect(["site/view"]); } return $this->render("update", ["model" => $model, "msg" => $msg]); } public function actionDelete() { if(Yii::$app->request->post()) { $id_alumno = Html::encode($_POST["id_alumno"]); if((int) $id_alumno) { if(Alumnos::deleteAll("id_alumno=:id_alumno", [":id_alumno" => $id_alumno])) { echo "Alumno con id $id_alumno eliminado con éxito, redireccionando ..."; echo "<meta http-equiv='refresh' content='3; ".Url::toRoute("site/view")."'>"; } else { echo "Ha ocurrido un error al eliminar el alumno, redireccionando ..."; echo "<meta http-equiv='refresh' content='3; ".Url::toRoute("site/view")."'>"; } } else { echo "Ha ocurrido un error al eliminar el alumno, redireccionando ..."; echo "<meta http-equiv='refresh' content='3; ".Url::toRoute("site/view")."'>"; } } else { return $this->redirect(["site/view"]); } } public function actionView() { $form = new FormSearch; $search = null; if($form->load(Yii::$app->request->get())) { if ($form->validate()) { $search = Html::encode($form->q); $table = Alumnos::find() ->where(["like", "id_alumno", $search]) ->orWhere(["like", "nombre", $search]) ->orWhere(["like", "apellidos", $search]); $count = clone $table; $pages = new Pagination([ "pageSize" => 1, "totalCount" => $count->count() ]); $model = $table ->offset($pages->offset) ->limit($pages->limit) ->all(); } else { $form->getErrors(); } } else { $table = Alumnos::find(); $count = clone $table; $pages = new Pagination([ "pageSize" => 1, "totalCount" => $count->count(), ]); $model = $table ->offset($pages->offset) ->limit($pages->limit) ->all(); } return $this->render("view", ["model" => $model, "form" => $form, "search" => $search, "pages" => $pages]); } public function actionCreate() { $model = new FormAlumnos; $msg = null; if($model->load(Yii::$app->request->post())) { if($model->validate()) { $table = new Alumnos; $table->nombre = $model->nombre; $table->apellidos = $model->apellidos; $table->clase = $model->clase; $table->nota_final = $model->nota_final; if ($table->insert()) { $msg = "Enhorabuena registro guardado correctamente"; $model->nombre = null; $model->apellidos = null; $model->clase = null; $model->nota_final = null; } else { $msg = "Ha ocurrido un error al insertar el registro"; } } else { $model->getErrors(); } } return $this->render("create", ['model' => $model, 'msg' => $msg]); } public function actionSaluda($get = "Tutorial Yii") { $mensaje = "Hola Mundo"; $numeros = [0, 1, 2, 3, 4, 5]; return $this->render("saluda", [ "saluda" => $mensaje, "numeros" => $numeros, "get" => $get, ]); } public function actionFormulario($mensaje = null) { return $this->render("formulario", ["mensaje" => $mensaje]); } public function actionRequest() { $mensaje = null; if (isset($_REQUEST["nombre"])) { $mensaje = "Bien, has enviando tu nombre correctamente: " . $_REQUEST["nombre"]; } $this->redirect(["site/formulario", "mensaje" => $mensaje]); } public function actionValidarformulario() { $model = new ValidarFormulario; if ($model->load(Yii::$app->request->post())) { if($model->validate()) { //Por ejemplo, consultar en una base de datos } else { $model->getErrors(); } } return $this->render("validarformulario", ["model" => $model]); } public function actionValidarformularioajax() { $model = new ValidarFormularioAjax; $msg = null; if ($model->load(Yii::$app->request->post()) && Yii::$app->request->isAjax) { Yii::$app->response->format = Response::FORMAT_JSON; return ActiveForm::validate($model); } if ($model->load(Yii::$app->request->post())) { if ($model->validate()) { //Por ejemplo hacer una consulta a una base de datos $msg = "Enhorabuena formulario enviado correctamente"; $model->nombre = null; $model->email = null; } else { $model->getErrors(); } } return $this->render("validarformularioajax", ['model' => $model, 'msg' => $msg]); } public function behaviors() { return [ 'access' => [ 'class' => AccessControl::className(), 'only' => ['logout'], 'rules' => [ [ 'actions' => ['logout'], 'allow' => true, 'roles' => ['@'], ], ], ], 'verbs' => [ 'class' => VerbFilter::className(), 'actions' => [ 'logout' => ['post'], ], ], ]; } public function actions() { return [ 'error' => [ 'class' => 'yii\web\ErrorAction', ], 'captcha' => [ 'class' => 'yii\captcha\CaptchaAction', 'fixedVerifyCode' => YII_ENV_TEST ? 'testme' : null, ], ]; } public function actionIndex() { return $this->render('index'); } public function actionLogin() { if (!\Yii::$app->user->isGuest) { return $this->goHome(); } $model = new LoginForm(); if ($model->load(Yii::$app->request->post()) && $model->login()) { return $this->goBack(); } else { return $this->render('login', [ 'model' => $model, ]); } } public function actionLogout() { Yii::$app->user->logout(); return $this->goHome(); } public function actionContact() { $model = new ContactForm(); if ($model->load(Yii::$app->request->post()) && $model->contact(Yii::$app->params['adminEmail'])) { Yii::$app->session->setFlash('contactFormSubmitted'); return $this->refresh(); } else { return $this->render('contact', [ 'model' => $model, ]); } } public function actionAbout() { return $this->render('about'); } }
Ver el vídeo tutorial de Yii Framework 2 en Youtube
No hay comentarios:
Publicar un comentario