MotivosInconformidadController.php 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. <?php
  2. namespace v1\controllers;
  3. use common\data\Respuesta;
  4. use common\rest\AuthController;
  5. use yii\db\Expression;
  6. class MotivosInconformidadController extends AuthController {
  7. // Establece la clase del modelo a utilizar
  8. public $modelClass = "v1\models\MotivosInconformidad";
  9. // Acción para obtener una lista de MotivosInconformidad
  10. public function actionIndex() {
  11. $id = trim($this->req->get("id", ""));
  12. $buscar = trim($this->req->get("buscar", ""));
  13. $notIn = trim($this->req->get("notIn", ""));
  14. $query = $this->queryInicial;
  15. if (!empty($id)) {
  16. $query->andWhere(["id" => $id]);
  17. }
  18. if (!empty($notIn)) {
  19. $explode = explode(",", $notIn);
  20. $query->andWhere(["NOT IN", "id", $explode]);
  21. }
  22. if ($buscar) {
  23. $query->andWhere([
  24. "OR",
  25. "f_unaccent([[nombre]]) ilike f_unaccent(:q)",
  26. ])->addParams([':q' => "%{$buscar}%"]);
  27. }
  28. // Devolver una respuesta con los resultados de la consulta
  29. return new Respuesta($query, $this->limite, $this->pagina, $this->ordenar);
  30. }
  31. // Acción para guardar un calendario
  32. public function actionGuardar() {
  33. $id = trim($this->req->getBodyParam("id", ""));
  34. $modelo = null;
  35. if (!empty($id)) {
  36. $modelo = $this->modelClass::findOne($id);
  37. }
  38. $tran = \Yii::$app->getDb()->beginTransaction();
  39. try {
  40. if ($modelo === null) {
  41. $modelo = new $this->modelClass();
  42. $modelo->creado = new Expression('now()');
  43. $modelo->uuid();
  44. } else {
  45. $modelo->modificado = new Expression('now()');
  46. }
  47. $modelo->load($this->req->getBodyParams(), '');
  48. // Guardar el modelo en la base de datos
  49. if (!$modelo->save()) {
  50. return (new Respuesta($modelo))
  51. ->mensaje("Hubo un problema al guardar el registro de inconformidad");
  52. }
  53. $tran->commit();
  54. $modelo->refresh();
  55. return (new Respuesta($modelo))
  56. ->mensaje("Registro de inconformidad guardado con éxito.");
  57. } catch (\Exception $e) {
  58. $tran->rollBack();
  59. return (new Respuesta())
  60. ->esError($e)
  61. ->mensaje("Hubo un error en el servidor");
  62. }
  63. }
  64. // Acción para eliminar un calendario
  65. public function actionEliminar() {
  66. $id = trim($this->req->getBodyParam("id", ""));
  67. $modelo = null;
  68. if ($id !== "") {
  69. $modelo = $this->modelClass::findOne(["id" => $id]);
  70. }
  71. if ($modelo === null) {
  72. return (new Respuesta())
  73. ->esError()
  74. ->mensaje("Registro de inconformidad no encontrado");
  75. }
  76. $modelo->eliminado = new Expression('now()');
  77. if (!$modelo->save()) {
  78. return (new Respuesta($modelo))
  79. ->mensaje("No se pudo eliminar el registro de inconformidad");
  80. }
  81. return (new Respuesta())
  82. ->mensaje("Registro de inconformidad eliminado");
  83. }
  84. }