SubtemaSolicitudController.php 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. <?php
  2. namespace v1\controllers;
  3. use common\data\Respuesta;
  4. use common\rest\AuthController;
  5. use yii\db\Expression;
  6. class SubtemaSolicitudController extends AuthController {
  7. public $modelClass = "v1\models\SubtemaSolicitud";
  8. public function actionIndex() {
  9. $id = trim($this->req->get("id", ""));
  10. $idTema = trim($this->req->get("idTema", ""));
  11. $buscar = trim($this->req->get("q", ""));
  12. $notIn = trim($this->req->get("notIn", ""));
  13. $query = $this->queryInicial;
  14. if ($id !== '') {
  15. $query->andWhere(["id" => $id]);
  16. }
  17. if ($idTema !== '') {
  18. $query->andWhere(["idTema" => $idTema]);
  19. }
  20. if (!empty($notIn)) {
  21. $explode = explode(",", $notIn);
  22. $query->andWhere(["NOT IN", "id", $explode]);
  23. }
  24. if ($buscar) {
  25. $query->andWhere([
  26. "OR",
  27. "f_unaccent([[nombre]]) ilike f_unaccent(:q)",
  28. ])->addParams([':q' => "%{$buscar}%"]);
  29. }
  30. // Devolver una respuesta con los resultados de la consulta
  31. return new Respuesta($query, $this->limite, $this->pagina, $this->ordenar);
  32. }
  33. // Acción para guardar un calendario
  34. public function actionGuardar() {
  35. $id = trim($this->req->getBodyParam("id", ""));
  36. $modelo = null;
  37. if (!empty($id)) {
  38. $modelo = $this->modelClass::findOne($id);
  39. }
  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 Solicitud");
  52. }
  53. $modelo->refresh();
  54. return (new Respuesta($modelo))
  55. ->mensaje("Registro de Solicitud guardado con éxito.");
  56. }
  57. public function actionEliminar() {
  58. $id = trim($this->req->getBodyParam("id", ""));
  59. $modelo = null;
  60. if ($id !== "") {
  61. $modelo = $this->modelClass::findOne(["id" => $id]);
  62. }
  63. if ($modelo === null) {
  64. return (new Respuesta())
  65. ->esError()
  66. ->mensaje("Registro de Solicitud no encontrado");
  67. }
  68. $modelo->eliminado = new Expression('now()');
  69. if (!$modelo->save()) {
  70. return (new Respuesta($modelo))
  71. ->mensaje("No se pudo eliminar el registro de Solicitud");
  72. }
  73. return (new Respuesta())
  74. ->mensaje("Registro de Solicitud eliminado");
  75. }
  76. }