EventoController.php 28 KB

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