EventoController.php 28 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718
  1. <?php
  2. namespace v1\controllers;
  3. use common\data\Respuesta;
  4. use common\rest\AuthController;
  5. use v1\models\Evento;
  6. use v1\models\Usuario;
  7. use v1\models\UsuarioDependencia;
  8. use yii\db\Expression;
  9. use yii\db\Query;
  10. class EventoController extends AuthController {
  11. public $modelClass = "v1\models\Evento";
  12. public $modelName = "Evento";
  13. public function actionIndex() {
  14. $id = intval($this->req->get("id", ""));
  15. $q = trim($this->req->get("q", ""));
  16. $query = $this->queryInicial;
  17. if($id > 0) {
  18. $query->andWhere(["id" => $id]);
  19. }
  20. if($q !== "") {
  21. # Ejemplo de buscador
  22. $query->andWhere([
  23. "OR",
  24. ["ilike", "nombre", $q],
  25. // ["ilike", "direccion", $q],
  26. ]);
  27. //
  28. }
  29. return new Respuesta($query, $this->limite, $this->pagina, $this->ordenar);
  30. }
  31. public function actionGuardar() {
  32. $id = intval($this->req->getBodyParam("id", null));
  33. $modelo = null;
  34. if($id > 0) {
  35. $modelo = $this->modelClass::findOne($id);
  36. }
  37. if($modelo === null) {
  38. $modelo = new $this->modelClass();
  39. $modelo->creado = new Expression('now()');
  40. $modelo->idUsuarioCreador = $this->usuario->id;
  41. } else {
  42. $modelo->modificado = new Expression('now()');
  43. }
  44. $modelo->load($this->req->getBodyParams(), '');
  45. if (!$modelo->save()) {
  46. return (new Respuesta($modelo))
  47. ->mensaje("Hubo un problema al guardar el {$this->modelName}");
  48. }
  49. $modelo->refresh();
  50. return (new Respuesta($modelo))
  51. ->mensaje("{$this->modelName} guardado correctamente");
  52. }
  53. public function actionEliminar() {
  54. $id = intval($this->req->getBodyParam("id", null));
  55. $modelo = null;
  56. if($id > 0) {
  57. $modelo = $this->modelClass::findOne(["id" => $id]);
  58. }
  59. if($modelo === null) {
  60. return (new Respuesta())
  61. ->esError()
  62. ->mensaje("{$this->modelName} no encontrado");
  63. }
  64. $modelo->eliminado = null;
  65. if(!$modelo->save()) {
  66. return (new Respuesta($modelo))
  67. ->mensaje("No se pudo eliminar el {$this->modelName}");
  68. }
  69. return (new Respuesta())
  70. ->mensaje("{$this->modelName} eliminado");
  71. }
  72. public function actionResultadosIndividuales() {
  73. $idUsuario = intval($this->req->getBodyParam("idUsuario", null));
  74. $fechaInicio = trim($this->req->getBodyParam("fechaInicio", ""));
  75. $fechaFinal = trim($this->req->getBodyParam("fechaFinal", ""));
  76. $query = (new Query())
  77. ->select([
  78. "{{Evento}}.id as eventoId",
  79. "{{Resultado}}.accion as accionRes",
  80. "{{Evento}}.redSocial as redSocial",
  81. "{{Usuario}}.[[facebookVerificado]] as facebookVerificado",
  82. "{{Usuario}}.[[twitterVerificado]] as twitterVerificado",
  83. "{{Usuario}}.[[instagramVerificado]] as instagramVerificado",
  84. ])
  85. ->from("Evento")
  86. ->innerJoin("EventoGrupo", "{{EventoGrupo}}.[[idEvento]] = {{Evento}}.id")
  87. ->innerJoin("Grupo", "{{Grupo}}.id = {{EventoGrupo}}.[[idGrupo]]")
  88. ->innerJoin("UsuarioGrupo", "{{UsuarioGrupo}}.[[idGrupo]] = {{Grupo}}.id")
  89. ->innerJoin("Usuario", "{{UsuarioGrupo}}.[[idUsuario]] = {{Usuario}}.id")
  90. ->leftJoin("Resultado", "{{Resultado}}.[[idEvento]] = {{Evento}}.id and {{Resultado}}.[[idUsuario]] = {{UsuarioGrupo}}.[[idUsuario]]")
  91. ->orderBy(["eventoId" => SORT_ASC]);
  92. /* $query = (new Query())
  93. ->select([
  94. "{{Usuario}}.nombre as nombre",
  95. "{{Usuario}}.facebook as facebook",
  96. "{{Usuario}}.facebookVerificado as facebookVerificado",
  97. "{{Usuario}}.twitter as twitter",
  98. "{{Usuario}}.twitterVerificado as twitterVerificado",
  99. "{{Usuario}}.instagram as instagram",
  100. "{{Usuario}}.instagramVerificado as instagramVerificado",
  101. "{{Usuario}}.id as uId",
  102. // "{{Evento}}.id as eventoId",
  103. // "{{Evento}}.redSocial",
  104. "count({{Evento}}.id) as cantidadEventos",
  105. "count({{Evento}}.[[redSocial]]) filter (where {{Evento}}.[[redSocial]] = Facebook) as eventosFacebook",
  106. "count({{Evento}}.[[redSocial]]) filter (where {{Evento}}.[[redSocial]] = Twitter) as eventosTwitter",
  107. "count({{Evento}}.[[redSocial]]) filter (where {{Evento}}.[[redSocial]] = Instagram) as eventosInstagram",
  108. "count({{Resultado}}.accion) as cantidadResultados",
  109. "(count({{Evento}}.id) - count({{Resultado}}.accion)) as cantidadPendientes",
  110. ])
  111. ->from("Evento")
  112. ->innerJoin("EventoGrupo", "{{EventoGrupo}}.[[idEvento]] = {{Evento}}.id")
  113. ->innerJoin("Grupo", "{{Grupo}}.id = {{EventoGrupo}}.[[idGrupo]]")
  114. ->innerJoin("UsuarioGrupo", "{{UsuarioGrupo}}.[[idGrupo]] = {{Grupo}}.id")
  115. ->innerJoin("Usuario", "{{Usuario}}.id = {{UsuarioGrupo}}.[[idUsuario]]")
  116. ->leftJoin("Resultado", "{{Resultado}}.[[idEvento]] = {{Evento}}.id and {{Resultado}}.[[idUsuario]] = {{Usuario}}.id")
  117. ->groupBy(["{{Usuario}}.nombre", "facebook", "facebookVerificado", "twitter", "twitterVerificado", "instagram", "instagramVerificado", "uId"]); */
  118. // ->orderBy(["eventoId" => SORT_ASC]);
  119. if ($idUsuario > 0) {
  120. $query->andWhere(["{{UsuarioGrupo}}.[[idUsuario]]" => $idUsuario]);
  121. }
  122. if ($fechaInicio != "" && $fechaFinal != ""){
  123. $query->andWhere([
  124. "AND",
  125. [">=", "fechaInicio", $fechaInicio],
  126. ["<=", "fechaFinal", $fechaFinal],
  127. ]);
  128. }
  129. $total = 0;
  130. $participo = 0;
  131. foreach($query->each() as $resultado) {
  132. $total++;
  133. if ($resultado["redSocial"] === "Facebook" && !isset($resultado["facebookVerificado"])){
  134. $total--;
  135. } else if ($resultado["redSocial"] === "Twitter" && !isset($resultado["twitterVerificado"])){
  136. $total--;
  137. } else if ($resultado["redSocial"] === "Instagram" && !isset($resultado["instagramVerificado"])){
  138. $total--;
  139. }
  140. if ($resultado["accionRes"] !== null) {
  141. $participo ++;
  142. }
  143. };
  144. return (new Respuesta())
  145. ->detalle([
  146. "total" => $total,
  147. "participo" => $participo,
  148. "pendientes" => ($total - $participo)
  149. ]);
  150. // return new Respuesta($query);
  151. }
  152. public function actionResultadosDependencia() {
  153. $idDependencia = intval($this->req->getBodyParam("idDependencia", null));
  154. $fechaInicio = trim($this->req->getBodyParam("fechaInicio", ""));
  155. $fechaFinal = trim($this->req->getBodyParam("fechaFinal", ""));
  156. $query = (new Query())
  157. ->select([
  158. "{{Usuario}}.nombre as nombre",
  159. "{{UsuarioDependencia}}.[[idDependencia]]",
  160. "{{Usuario}}.facebook as facebook",
  161. "{{Usuario}}.facebookVerificado as facebookVerificado",
  162. "{{Usuario}}.twitter as twitter",
  163. "{{Usuario}}.twitterVerificado as twitterVerificado",
  164. "{{Usuario}}.instagram as instagram",
  165. "{{Usuario}}.instagramVerificado as instagramVerificado",
  166. "{{Usuario}}.id as uId",
  167. "count({{Evento}}.id) as cantidadEventos",
  168. "count({{Evento}}.[[redSocial]]) filter (where {{Evento}}.[[redSocial]] = 'Facebook' and {{Usuario}}.[[facebookVerificado]]) as eventosFacebook",
  169. "count({{Evento}}.[[redSocial]]) filter (where {{Evento}}.[[redSocial]] = 'Twitter' and {{Usuario}}.[[twitterVerificado]]) as eventosTwitter",
  170. "count({{Evento}}.[[redSocial]]) filter (where {{Evento}}.[[redSocial]] = 'Instagram' and {{Usuario}}.[[instagramVerificado]]) as eventosInstagram",
  171. "count({{Resultado}}.accion) as cantidadResultados",
  172. "(count({{Evento}}.id) - count({{Resultado}}.accion)) as cantidadPendientes",
  173. ])
  174. ->from("Evento")
  175. ->innerJoin("EventoGrupo", "{{EventoGrupo}}.[[idEvento]] = {{Evento}}.id")
  176. ->innerJoin("Grupo", "{{Grupo}}.id = {{EventoGrupo}}.[[idGrupo]]")
  177. ->innerJoin("UsuarioGrupo", "{{UsuarioGrupo}}.[[idGrupo]] = {{Grupo}}.id")
  178. ->innerJoin("Usuario", "{{Usuario}}.[[id]] = {{UsuarioGrupo}}.[[idUsuario]]")
  179. ->innerJoin("UsuarioDependencia", "{{UsuarioDependencia}}.[[idUsuario]] = {{Usuario}}.id")
  180. ->leftJoin("Resultado", "{{Resultado}}.[[idEvento]] = {{Evento}}.id and {{Resultado}}.[[idUsuario]] = {{Usuario}}.id")
  181. ->andWhere(['{{Usuario}}.eliminado' => null])
  182. ->groupBy([
  183. "{{Usuario}}.nombre",
  184. "{{UsuarioDependencia}}.[[idDependencia]]",
  185. "facebook",
  186. "[[facebookVerificado]]",
  187. "twitter",
  188. "[[twitterVerificado]]",
  189. "instagram",
  190. "[[instagramVerificado]]",
  191. "uId"
  192. ]);
  193. if ($idDependencia > 0) {
  194. $query->andWhere(["{{UsuarioDependencia}}.[[idDependencia]]" => $idDependencia]);
  195. }
  196. if ($fechaInicio != "" && $fechaFinal != ""){
  197. $query->andWhere([
  198. "AND",
  199. [">=", "fechaInicio", $fechaInicio],
  200. ["<=", "fechaFinal", $fechaFinal],
  201. ]);
  202. }
  203. $query2 = (new Query())
  204. ->select([
  205. "*",
  206. "([[eventosFacebook]] + [[eventosTwitter]] + [[eventosInstagram]]) as [[cantidadEventos]]",
  207. "([[eventosFacebook]] + [[eventosTwitter]] + [[eventosInstagram]]) - [[cantidadResultados]] as [[cantidadPendientes]]"
  208. ])
  209. ->from(["t" => $query]);
  210. // return new Respuesta($query2);
  211. $info = [];
  212. $totalEventos = 0;
  213. $eventosAtendidos = 0;
  214. $eventosPendientes = 0;
  215. foreach($query2->each() as $resultado) {
  216. $info[] = $resultado;
  217. $totalEventos += $resultado["cantidadEventos"];
  218. $eventosAtendidos += $resultado["cantidadResultados"];
  219. $eventosPendientes += $resultado["cantidadPendientes"];
  220. }
  221. return (new Respuesta())->detalle([
  222. "total" => $totalEventos,
  223. "participo" => $eventosAtendidos,
  224. "pendientes" => $eventosPendientes,
  225. "usuarios" => $info
  226. ]);
  227. /* $total = 0;
  228. $participo = 0;
  229. foreach($query->each() as $resultado) {
  230. $total++;
  231. if ($resultado["accionRes"] !== null) {
  232. $participo ++;
  233. }
  234. }
  235. return (new Respuesta())
  236. ->detalle([
  237. "total" => $total,
  238. "participo" => $participo,
  239. "pendientes" => ($total - $participo)
  240. ]); */
  241. }
  242. public function actionComparativaDependencia() {
  243. $fechaInicio = trim($this->req->getBodyParam("fechaInicio", ""));
  244. $fechaFinal = trim($this->req->getBodyParam("fechaFinal", ""));
  245. /* $query = (new Query())
  246. ->select([
  247. "{{Dependencia}}.id as dependenciaId",
  248. "{{Dependencia}}.nombre as dependenciaNombre",
  249. "COUNT({{Resultado}}.[[idUsuario]]) filter ( where {{Resultado}}.[[idUsuario]] is not null ) as conteoNotNull",
  250. "COUNT({{UsuarioGrupo}}.[[idUsuario]]) as totalDependencia"
  251. ])
  252. ->from("Evento")
  253. ->innerJoin("EventoGrupo", "{{EventoGrupo}}.[[idEvento]] = {{Evento}}.id")
  254. ->innerJoin("Grupo", "{{Grupo}}.id = {{EventoGrupo}}.[[idGrupo]]")
  255. ->innerJoin("UsuarioGrupo", "{{UsuarioGrupo}}.[[idGrupo]] = {{Grupo}}.id")
  256. ->innerJoin("UsuarioDependencia", "{{UsuarioDependencia}}.[[idUsuario]] = {{UsuarioGrupo}}.[[idUsuario]]")
  257. ->innerJoin("Dependencia", "{{Dependencia}}.id = {{UsuarioDependencia}}.[[idDependencia]]")
  258. ->leftJoin("Resultado", "{{Resultado}}.[[idEvento]] = {{Evento}}.id and {{Resultado}}.[[idUsuario]] = {{UsuarioDependencia}}.[[idUsuario]]")
  259. ->andWhere([
  260. "AND",
  261. [">=", "fechaInicio", $fechaInicio],
  262. ["<=", "fechaFinal", $fechaFinal],
  263. ])
  264. ->groupBy([
  265. "dependenciaId",
  266. "dependenciaNombre"
  267. ])
  268. ->orderBy(["dependenciaNombre" => SORT_ASC]); */
  269. $query = (new Query())
  270. ->select([
  271. "{{Dependencia}}.id as dependenciaId",
  272. "{{Dependencia}}.nombre as dependenciaNombre",
  273. "count({{Evento}}.id) as cantidadEventos",
  274. "count({{Evento}}.[[redSocial]]) filter (where {{Evento}}.[[redSocial]] = 'Facebook' and {{Usuario}}.[[facebookVerificado]]) as eventosFacebook",
  275. "count({{Evento}}.[[redSocial]]) filter (where {{Evento}}.[[redSocial]] = 'Twitter' and {{Usuario}}.[[twitterVerificado]]) as eventosTwitter",
  276. "count({{Evento}}.[[redSocial]]) filter (where {{Evento}}.[[redSocial]] = 'Instagram' and {{Usuario}}.[[instagramVerificado]]) as eventosInstagram",
  277. "count({{Resultado}}.accion) as cantidadResultados",
  278. "(count({{Evento}}.id) - count({{Resultado}}.accion)) as cantidadPendientes",
  279. ])
  280. ->from("Evento")
  281. ->innerJoin("EventoGrupo", "{{EventoGrupo}}.[[idEvento]] = {{Evento}}.id")
  282. ->innerJoin("Grupo", "{{Grupo}}.id = {{EventoGrupo}}.[[idGrupo]]")
  283. ->innerJoin("UsuarioGrupo", "{{UsuarioGrupo}}.[[idGrupo]] = {{Grupo}}.id")
  284. ->innerJoin("Usuario", "{{Usuario}}.id = {{UsuarioGrupo}}.[[idUsuario]]")
  285. ->innerJoin("UsuarioDependencia", "{{UsuarioDependencia}}.[[idUsuario]] = {{Usuario}}.[[id]]")
  286. ->innerJoin("Dependencia", "{{Dependencia}}.id = {{UsuarioDependencia}}.[[idDependencia]]")
  287. ->leftJoin("Resultado", "{{Resultado}}.[[idEvento]] = {{Evento}}.id and {{Resultado}}.[[idUsuario]] = {{Usuario}}.id")
  288. ->andWhere([
  289. "AND",
  290. [">=", "fechaInicio", $fechaInicio],
  291. ["<=", "fechaFinal", $fechaFinal],
  292. ])
  293. ->groupBy([
  294. "dependenciaId",
  295. "dependenciaNombre",
  296. ])
  297. ->orderBy(["dependenciaNombre" => SORT_ASC]);
  298. $query2 = (new Query())
  299. ->select([
  300. "*",
  301. "([[eventosFacebook]] + [[eventosTwitter]] + [[eventosInstagram]]) as [[cantidadEventos]]",
  302. "([[eventosFacebook]] + [[eventosTwitter]] + [[eventosInstagram]]) - [[cantidadResultados]] as [[cantidadPendientes]]"
  303. ])
  304. ->from(["t" => $query]);
  305. $data = [];
  306. /* foreach($query->each() as $resultado) {
  307. $data[] = [
  308. "id" => $resultado["dependenciaId"],
  309. "nombre" => $resultado["dependenciaNombre"],
  310. "participaciones" => $resultado["conteoNotNull"],
  311. "pendientes" => $resultado["totalDependencia"] - $resultado["conteoNotNull"]
  312. ];
  313. }
  314. return (new Respuesta())
  315. ->detalle($data); */
  316. $eventosAtendidos = 0;
  317. $eventosPendientes = 0;
  318. foreach($query2->each() as $resultado) {
  319. $eventosAtendidos += $resultado["cantidadResultados"];
  320. $eventosPendientes += $resultado["cantidadPendientes"];
  321. $usuariosDependencia = UsuarioDependencia::find()
  322. ->andWhere(['idDependencia' => $resultado["dependenciaId"]])
  323. ->count();
  324. $data[] = [
  325. "id" => $resultado["dependenciaId"],
  326. "nombre" => $resultado["dependenciaNombre"],
  327. "participaciones" => $resultado["cantidadResultados"],
  328. "pendientes" => $resultado["cantidadPendientes"],
  329. "cantidadUsuarios" => $usuariosDependencia
  330. ];
  331. }
  332. return (new Respuesta())
  333. ->detalle($data);
  334. }
  335. public function actionPorEvento() {
  336. $idEvento = trim($this->req->getBodyParam("tag", null));
  337. $fechaInicio = trim($this->req->getBodyParam("fechaInicio", ""));
  338. $fechaFinal = trim($this->req->getBodyParam("fechaFinal", ""));
  339. /* $queryUsuario = (new Query())
  340. ->select([
  341. "{{Evento}}.id as eventoId",
  342. // "{{Usuario}}.id",
  343. "{{Resultado}}.accion as accionRes",
  344. ])
  345. ->from("Evento")
  346. ->innerJoin("EventoGrupo", "{{EventoGrupo}}.[[idEvento]] = {{Evento}}.id")
  347. ->innerJoin("Grupo", "{{Grupo}}.id = {{EventoGrupo}}.[[idGrupo]]")
  348. ->innerJoin("UsuarioGrupo", "{{UsuarioGrupo}}.[[idGrupo]] = {{Grupo}}.id")
  349. // ->innerJoin("Usuario", "{{Usuario}}.[[id]] = {{UsuarioGrupo}}.[[idUsuario]]")
  350. ->leftJoin("Resultado", "{{Resultado}}.[[idEvento]] = {{Evento}}.id and {{Resultado}}.[[idUsuario]] = {{UsuarioGrupo}}.[[idUsuario]]")
  351. ->andWhere([
  352. "AND",
  353. [">=", "fechaInicio", $fechaInicio],
  354. ["<=", "fechaFinal", $fechaFinal],
  355. ])
  356. ->andWhere(["{{Evento}}.id" => $idEvento])
  357. ->orderBy(["eventoId" => SORT_ASC]); */
  358. $queryUsuario = (new Query())
  359. ->select([
  360. "{{Usuario}}.id as idUsuario",
  361. "{{Resultado}}.accion as accionRes",
  362. ])
  363. ->from("Evento")
  364. ->innerJoin("EventoGrupo", "{{EventoGrupo}}.[[idEvento]] = {{Evento}}.id")
  365. ->innerJoin("Grupo", "{{Grupo}}.id = {{EventoGrupo}}.[[idGrupo]]")
  366. ->innerJoin("UsuarioGrupo", "{{UsuarioGrupo}}.[[idGrupo]] = {{Grupo}}.id")
  367. ->innerJoin("Usuario", "{{Usuario}}.[[id]] = {{UsuarioGrupo}}.[[idUsuario]]")
  368. ->leftJoin("Resultado", "{{Resultado}}.[[idEvento]] = {{Evento}}.id and {{Resultado}}.[[idUsuario]] = {{Usuario}}.[[id]]")
  369. ->andWhere([
  370. "AND",
  371. [">=", "fechaInicio", $fechaInicio],
  372. ["<=", "fechaFinal", $fechaFinal],
  373. ])
  374. ->andWhere(["{{Evento}}.tag" => $idEvento])
  375. ->groupBy([
  376. "{{Usuario}}.id",
  377. "{{Resultado}}.accion",
  378. "{{Evento}}.tag"
  379. ])
  380. ->orderBy(["{{Evento}}.tag" => SORT_ASC]);
  381. $totalUsuario = 0;
  382. $participoUsuario = 0;
  383. $idUsuarios = [];
  384. foreach($queryUsuario->each() as $resultado) {
  385. $totalUsuario++;
  386. if ($resultado["accionRes"] !== null && !in_array($resultado["idUsuario"], $idUsuarios)) {
  387. $participoUsuario ++;
  388. $idUsuarios[] = $resultado["idUsuario"];
  389. } else if ($resultado["accionRes"] === null && in_array($resultado["idUsuario"], $idUsuarios)) {
  390. $totalUsuario--;
  391. }
  392. }
  393. $queryDependencia = (new Query())
  394. ->select([
  395. "{{Dependencia}}.id as dependenciaId",
  396. "{{Dependencia}}.nombre as dependenciaNombre",
  397. "COUNT({{Resultado}}.[[idUsuario]]) filter ( where {{Resultado}}.[[idUsuario]] is not null ) as conteoNotNull",
  398. "COUNT({{UsuarioGrupo}}.[[idUsuario]]) as totalDependencia"
  399. ])
  400. ->from("Evento")
  401. ->innerJoin("EventoGrupo", "{{EventoGrupo}}.[[idEvento]] = {{Evento}}.id")
  402. ->innerJoin("Grupo", "{{Grupo}}.id = {{EventoGrupo}}.[[idGrupo]]")
  403. ->innerJoin("UsuarioGrupo", "{{UsuarioGrupo}}.[[idGrupo]] = {{Grupo}}.id")
  404. ->innerJoin("UsuarioDependencia", "{{UsuarioDependencia}}.[[idUsuario]] = {{UsuarioGrupo}}.[[idUsuario]]")
  405. ->innerJoin("Dependencia", "{{Dependencia}}.id = {{UsuarioDependencia}}.[[idDependencia]]")
  406. ->leftJoin("Resultado", "{{Resultado}}.[[idEvento]] = {{Evento}}.id and {{Resultado}}.[[idUsuario]] = {{UsuarioDependencia}}.[[idUsuario]]")
  407. ->andWhere([
  408. "AND",
  409. [">=", "fechaInicio", $fechaInicio],
  410. ["<=", "fechaFinal", $fechaFinal],
  411. ])
  412. ->andWhere(["{{Evento}}.tag" => $idEvento])
  413. ->groupBy([
  414. "{{Evento}}.tag",
  415. "dependenciaId",
  416. "dependenciaNombre"
  417. ])
  418. ->orderBy(["dependenciaNombre" => SORT_ASC]);
  419. // $this->res->format = \yii\web\Response::FORMAT_RAW;
  420. // $sql = $queryDependencia->createCommand()->getRawSql();
  421. // return $sql;
  422. $dataDependencias = [];
  423. $totalParticipantesDependencias = 0;
  424. $totalPendientesDependencias = 0;
  425. foreach($queryDependencia->each() as $resultado) {
  426. $totalParticipantesDependencias += $resultado["conteoNotNull"];
  427. $totalPendientesDependencias += $resultado["totalDependencia"] - $resultado["conteoNotNull"];
  428. $dataDependencias[] = [
  429. "id" => $resultado["dependenciaId"],
  430. "nombre" => $resultado["dependenciaNombre"],
  431. "participaciones" => $resultado["conteoNotNull"],
  432. "pendientes" => $resultado["totalDependencia"] - $resultado["conteoNotNull"]
  433. ];
  434. }
  435. return (new Respuesta())
  436. ->detalle([
  437. "totalResultadosUsuarios" => $totalUsuario,
  438. "participoResultadosUsuarios" => $participoUsuario,
  439. "pendientesResultadosUsuarios" => ($totalUsuario - $participoUsuario),
  440. "datosDependencias" => $dataDependencias,
  441. "totalParticipantesDependencias" => $totalParticipantesDependencias,
  442. "totalPendientesDependencias" => $totalPendientesDependencias,
  443. "totalDependencias" => $totalPendientesDependencias + $totalPendientesDependencias
  444. ]);
  445. }
  446. public function actionTag() {
  447. $id = intval($this->req->get("id", ""));
  448. $q = trim($this->req->get("q", ""));
  449. // $query = $this->queryInicial;
  450. $query = (new Query())
  451. ->select([
  452. '{{Evento}}.tag',
  453. '{{Evento}}.nombre',
  454. '{{Evento}}.[[fechaInicio]]',
  455. '{{Evento}}.[[fechaFinal]]',
  456. 'case when count({{Resultado}}.accion) > 0 then true else false end as paticipo'
  457. ])
  458. ->from('Evento')
  459. ->innerJoin("EventoGrupo", "{{EventoGrupo}}.[[idEvento]] = {{Evento}}.id")
  460. ->innerJoin("Grupo", "{{Grupo}}.id = {{EventoGrupo}}.[[idGrupo]]")
  461. ->innerJoin("UsuarioGrupo", "{{UsuarioGrupo}}.[[idGrupo]] = {{Grupo}}.id")
  462. ->innerJoin("Usuario", "{{Usuario}}.[[id]] = {{UsuarioGrupo}}.[[idUsuario]]")
  463. ->leftJoin("Resultado", "{{Resultado}}.[[idEvento]] = {{Evento}}.id and {{Resultado}}.[[idUsuario]] = {{Usuario}}.id")
  464. ->andWhere(["{{Evento}}.eliminado" => null])
  465. ->andWhere("{{Evento}}.tag is not null")
  466. ->groupBy([
  467. '{{Evento}}.tag',
  468. '{{Evento}}.nombre',
  469. '{{Evento}}.[[fechaInicio]]',
  470. '{{Evento}}.[[fechaFinal]]',
  471. ]);
  472. /* if($id > 0) {
  473. $query->andWhere(["id" => $id]);
  474. } */
  475. if($q !== "") {
  476. # Ejemplo de buscador
  477. $query->andWhere([
  478. "OR",
  479. ["ilike", "{{Evento}}.nombre", $q],
  480. // ["ilike", "direccion", $q],
  481. ]);
  482. //
  483. }
  484. return new Respuesta($query, $this->limite, $this->pagina, $this->ordenar);
  485. }
  486. public function actionCondensado() {
  487. $tag = trim($this->req->getBodyParam("tag", null));
  488. $fechaInicio = trim($this->req->getBodyParam("fechaInicio", ""));
  489. $fechaFinal = trim($this->req->getBodyParam("fechaFinal", ""));
  490. try {
  491. $usuarios = (new Query())
  492. ->select([
  493. "{{Usuario}}.id as usuarioId",
  494. "{{Usuario}}.uid as uid",
  495. "{{Usuario}}.nombre as nombre",
  496. "case when {{Usuario}}.[[facebookVerificado]] = true then 1 else 0 end as [[tieneFb]]",
  497. "case when {{Usuario}}.[[twitterVerificado]] = true then 1 else 0 end as [[tieneTw]]",
  498. "case when {{Usuario}}.[[instagramVerificado]] = true then 1 else 0 end as [[tieneIg]]",
  499. "{{Usuario}}.facebook as facebook",
  500. "{{Usuario}}.instagram as instagram",
  501. "{{Usuario}}.twitter as twitter",
  502. "{{Usuario}}.verificado as verificado",
  503. "{{Dependencia}}.id as [[idDependencia]]",
  504. "{{Dependencia}}.nombre as dependencia",
  505. ])
  506. ->from("Usuario")
  507. ->innerJoin("UsuarioGrupo", "{{UsuarioGrupo}}.[[idUsuario]] = {{Usuario}}.id")
  508. ->innerJoin("UsuarioDependencia", "{{UsuarioDependencia}}.[[idUsuario]] = {{Usuario}}.id")
  509. ->innerJoin("Dependencia", "{{Dependencia}}.id = {{UsuarioDependencia}}.[[idDependencia]]")
  510. ->andWhere(["{{Usuario}}.eliminado" => null])
  511. ->andWhere(["{{UsuarioGrupo}}.[[idGrupo]]" => 1]) //Grupo ENLACES 2022
  512. ->andWhere(["!=", "{{UsuarioDependencia}}.[[idDependencia]]", 33]) //Diferente a dependencia Soporte
  513. ->orderBy(['dependencia' => SORT_ASC, 'nombre' => SORT_ASC])
  514. ->indexBy("usuarioId")
  515. ->all();
  516. $eventos = Evento::find()
  517. ->leftJoin("Resultado", "{{Resultado}}.[[idEvento]] = {{Evento}}.id")
  518. ->andWhere(["{{Evento}}.eliminado" => null])
  519. ->andWhere(["tag" => $tag])
  520. ->andWhere([
  521. "AND",
  522. [">=", "fechaInicio", $fechaInicio],
  523. ["<=", "fechaFinal", $fechaFinal],
  524. ]);
  525. $auxiliar = [];
  526. $auxiliarDependencias = [];
  527. foreach($eventos->each() as $e) {
  528. foreach($e->resultados as $resultado) {
  529. if (isset($usuarios[$resultado->idUsuario])) {
  530. $usuario = $usuarios[$resultado->idUsuario];
  531. if (!isset($auxiliar[$resultado->idUsuario])) {
  532. $auxiliar[$resultado->idUsuario] = [
  533. "id" => $usuario['usuarioId'],
  534. "uid" => $usuario['uid'],
  535. "nombre" => $usuario['nombre'],
  536. "idDependencia" => $usuario['idDependencia'],
  537. "dependencia" => $usuario['dependencia'],
  538. "tieneFb" => $usuario['tieneFb'],
  539. "facebook" => $usuario['facebook'],
  540. "tieneTw" => $usuario['tieneTw'],
  541. "twitter" => $usuario['twitter'],
  542. "tieneIg" => $usuario['tieneIg'],
  543. "instagram" => $usuario['instagram'],
  544. "verificado" => $usuario['verificado'],
  545. "participoFacebook" => 0,
  546. "participoTwitter" => 0,
  547. "participoInstagram" => 0,
  548. ];
  549. }
  550. if (!isset($auxiliarDependencias[$usuario['idDependencia']])) {
  551. $auxiliarDependencias[$usuario['idDependencia']] = [
  552. "id" => $usuario['idDependencia'],
  553. "nombre" => $usuario['dependencia'],
  554. "participaciones" => 0,
  555. "pendientes" => 0
  556. ];
  557. }
  558. if ($e->redSocial === 'Facebook') {
  559. $auxiliar[$resultado->idUsuario]["participoFacebook"] = 1;
  560. }
  561. if ($e->redSocial === 'Twitter') {
  562. $auxiliar[$resultado->idUsuario]["participoTwitter"] = 1;
  563. }
  564. if ($e->redSocial === 'Instagram') {
  565. $auxiliar[$resultado->idUsuario]["participoInstagram"] = 1;
  566. }
  567. }
  568. }
  569. foreach ($usuarios as $usr) {
  570. if (!isset($auxiliar[$usr["usuarioId"]])) {
  571. $auxiliar[$usr["usuarioId"]] = [
  572. "id" => $usr['usuarioId'],
  573. "uid" => $usr['uid'],
  574. "nombre" => $usr['nombre'],
  575. "idDependencia" => $usr['idDependencia'],
  576. "dependencia" => $usr['dependencia'],
  577. "tieneFb" => $usr['tieneFb'],
  578. "facebook" => $usr['facebook'],
  579. "tieneTw" => $usr['tieneTw'],
  580. "twitter" => $usr['twitter'],
  581. "tieneIg" => $usr['tieneIg'],
  582. "instagram" => $usr['instagram'],
  583. "verificado" => $usr['verificado'],
  584. "participoFacebook" => 0,
  585. "participoTwitter" => 0,
  586. "participoInstagram" => 0,
  587. ];
  588. }
  589. if (!isset($auxiliarDependencias[$usr['idDependencia']])) {
  590. $auxiliarDependencias[$usr['idDependencia']] = [
  591. "id" => $usr['idDependencia'],
  592. "nombre" => $usr['dependencia'],
  593. "participaciones" => 0,
  594. "pendientes" => 0
  595. ];
  596. }
  597. }
  598. }
  599. $segundoAuxiliar = [];
  600. $segundoAuxiliarDependencias = [];
  601. foreach($auxiliar as $aux) {
  602. if ($aux['tieneFb'] > 0) {
  603. if ($aux['participoFacebook'] > 0) {
  604. $auxiliarDependencias[$aux['idDependencia']]['participaciones'] += 1;
  605. } else {
  606. $auxiliarDependencias[$aux['idDependencia']]['pendientes'] += 1;
  607. }
  608. }
  609. if ($aux['tieneTw'] > 0) {
  610. if ($aux['participoTwitter'] > 0) {
  611. $auxiliarDependencias[$aux['idDependencia']]['participaciones'] += 1;
  612. } else {
  613. $auxiliarDependencias[$aux['idDependencia']]['pendientes'] += 1;
  614. }
  615. }
  616. if ($aux['tieneIg'] > 0) {
  617. if ($aux['participoInstagram'] > 0) {
  618. $auxiliarDependencias[$aux['idDependencia']]['participaciones'] += 1;
  619. } else {
  620. $auxiliarDependencias[$aux['idDependencia']]['pendientes'] += 1;
  621. }
  622. }
  623. $segundoAuxiliar[] = $aux;
  624. }
  625. $participaciones = 0;
  626. $pendientes = 0;
  627. foreach($auxiliarDependencias as $aux) {
  628. $participaciones += $aux['participaciones'];
  629. $pendientes += $aux['pendientes'];
  630. $segundoAuxiliarDependencias[] = $aux;
  631. }
  632. $total = $pendientes + $participaciones;
  633. $detalle = [
  634. "usuarios" => $segundoAuxiliar,
  635. "dependencias" => $segundoAuxiliarDependencias,
  636. "total" => $total,
  637. "participaciones" => $participaciones,
  638. "pendientes" => $pendientes
  639. ];
  640. return (new Respuesta())->detalle($detalle);
  641. } catch (\Exception $e) {
  642. return (new Respuesta())
  643. ->mensaje($e->getLine().'. '.$e->getMessage());
  644. }
  645. }
  646. }