EventoController.php 28 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730
  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. ->orderBy(["t.[[cantidadResultados]]" => SORT_DESC]);
  309. $data = [];
  310. /* foreach($query->each() as $resultado) {
  311. $data[] = [
  312. "id" => $resultado["dependenciaId"],
  313. "nombre" => $resultado["dependenciaNombre"],
  314. "participaciones" => $resultado["conteoNotNull"],
  315. "pendientes" => $resultado["totalDependencia"] - $resultado["conteoNotNull"]
  316. ];
  317. }
  318. return (new Respuesta())
  319. ->detalle($data); */
  320. $eventosAtendidos = 0;
  321. $eventosPendientes = 0;
  322. foreach($query2->each() as $resultado) {
  323. $eventosAtendidos += $resultado["cantidadResultados"];
  324. $eventosPendientes += $resultado["cantidadPendientes"];
  325. $usuariosDependencia = UsuarioDependencia::find()
  326. ->andWhere(['idDependencia' => $resultado["dependenciaId"]])
  327. ->count();
  328. $total = intval($resultado["cantidadResultados"]) + intval($resultado["cantidadPendientes"]);
  329. $porcentaje = 0;
  330. if ($total > 0) {
  331. $porcentaje = ($resultado["cantidadPendientes"] * 100) / $total;
  332. }
  333. $data[] = [
  334. "id" => $resultado["dependenciaId"],
  335. "nombre" => $resultado["dependenciaNombre"],
  336. "participaciones" => $resultado["cantidadResultados"],
  337. "pendientes" => $resultado["cantidadPendientes"],
  338. "porcentajeParticipacion" => $porcentaje,
  339. "cantidadUsuarios" => $usuariosDependencia
  340. ];
  341. }
  342. return (new Respuesta())
  343. ->detalle($data);
  344. }
  345. public function actionPorEvento() {
  346. $idEvento = trim($this->req->getBodyParam("tag", null));
  347. $fechaInicio = trim($this->req->getBodyParam("fechaInicio", ""));
  348. $fechaFinal = trim($this->req->getBodyParam("fechaFinal", ""));
  349. /* $queryUsuario = (new Query())
  350. ->select([
  351. "{{Evento}}.id as eventoId",
  352. // "{{Usuario}}.id",
  353. "{{Resultado}}.accion as accionRes",
  354. ])
  355. ->from("Evento")
  356. ->innerJoin("EventoGrupo", "{{EventoGrupo}}.[[idEvento]] = {{Evento}}.id")
  357. ->innerJoin("Grupo", "{{Grupo}}.id = {{EventoGrupo}}.[[idGrupo]]")
  358. ->innerJoin("UsuarioGrupo", "{{UsuarioGrupo}}.[[idGrupo]] = {{Grupo}}.id")
  359. // ->innerJoin("Usuario", "{{Usuario}}.[[id]] = {{UsuarioGrupo}}.[[idUsuario]]")
  360. ->leftJoin("Resultado", "{{Resultado}}.[[idEvento]] = {{Evento}}.id and {{Resultado}}.[[idUsuario]] = {{UsuarioGrupo}}.[[idUsuario]]")
  361. ->andWhere([
  362. "AND",
  363. [">=", "fechaInicio", $fechaInicio],
  364. ["<=", "fechaFinal", $fechaFinal],
  365. ])
  366. ->andWhere(["{{Evento}}.id" => $idEvento])
  367. ->orderBy(["eventoId" => SORT_ASC]); */
  368. $queryUsuario = (new Query())
  369. ->select([
  370. "{{Usuario}}.id as idUsuario",
  371. "{{Resultado}}.accion as accionRes",
  372. ])
  373. ->from("Evento")
  374. ->innerJoin("EventoGrupo", "{{EventoGrupo}}.[[idEvento]] = {{Evento}}.id")
  375. ->innerJoin("Grupo", "{{Grupo}}.id = {{EventoGrupo}}.[[idGrupo]]")
  376. ->innerJoin("UsuarioGrupo", "{{UsuarioGrupo}}.[[idGrupo]] = {{Grupo}}.id")
  377. ->innerJoin("Usuario", "{{Usuario}}.[[id]] = {{UsuarioGrupo}}.[[idUsuario]]")
  378. ->leftJoin("Resultado", "{{Resultado}}.[[idEvento]] = {{Evento}}.id and {{Resultado}}.[[idUsuario]] = {{Usuario}}.[[id]]")
  379. ->andWhere([
  380. "AND",
  381. [">=", "fechaInicio", $fechaInicio],
  382. ["<=", "fechaFinal", $fechaFinal],
  383. ])
  384. ->andWhere(["{{Evento}}.tag" => $idEvento])
  385. ->groupBy([
  386. "{{Usuario}}.id",
  387. "{{Resultado}}.accion",
  388. "{{Evento}}.tag"
  389. ])
  390. ->orderBy(["{{Evento}}.tag" => SORT_ASC]);
  391. $totalUsuario = 0;
  392. $participoUsuario = 0;
  393. $idUsuarios = [];
  394. foreach($queryUsuario->each() as $resultado) {
  395. $totalUsuario++;
  396. if ($resultado["accionRes"] !== null && !in_array($resultado["idUsuario"], $idUsuarios)) {
  397. $participoUsuario ++;
  398. $idUsuarios[] = $resultado["idUsuario"];
  399. } else if ($resultado["accionRes"] === null && in_array($resultado["idUsuario"], $idUsuarios)) {
  400. $totalUsuario--;
  401. }
  402. }
  403. $queryDependencia = (new Query())
  404. ->select([
  405. "{{Dependencia}}.id as dependenciaId",
  406. "{{Dependencia}}.nombre as dependenciaNombre",
  407. "COUNT({{Resultado}}.[[idUsuario]]) filter ( where {{Resultado}}.[[idUsuario]] is not null ) as conteoNotNull",
  408. "COUNT({{UsuarioGrupo}}.[[idUsuario]]) as totalDependencia"
  409. ])
  410. ->from("Evento")
  411. ->innerJoin("EventoGrupo", "{{EventoGrupo}}.[[idEvento]] = {{Evento}}.id")
  412. ->innerJoin("Grupo", "{{Grupo}}.id = {{EventoGrupo}}.[[idGrupo]]")
  413. ->innerJoin("UsuarioGrupo", "{{UsuarioGrupo}}.[[idGrupo]] = {{Grupo}}.id")
  414. ->innerJoin("UsuarioDependencia", "{{UsuarioDependencia}}.[[idUsuario]] = {{UsuarioGrupo}}.[[idUsuario]]")
  415. ->innerJoin("Dependencia", "{{Dependencia}}.id = {{UsuarioDependencia}}.[[idDependencia]]")
  416. ->leftJoin("Resultado", "{{Resultado}}.[[idEvento]] = {{Evento}}.id and {{Resultado}}.[[idUsuario]] = {{UsuarioDependencia}}.[[idUsuario]]")
  417. ->andWhere([
  418. "AND",
  419. [">=", "fechaInicio", $fechaInicio],
  420. ["<=", "fechaFinal", $fechaFinal],
  421. ])
  422. ->andWhere(["{{Evento}}.tag" => $idEvento])
  423. ->groupBy([
  424. "{{Evento}}.tag",
  425. "dependenciaId",
  426. "dependenciaNombre"
  427. ])
  428. ->orderBy(["dependenciaNombre" => SORT_ASC]);
  429. // $this->res->format = \yii\web\Response::FORMAT_RAW;
  430. // $sql = $queryDependencia->createCommand()->getRawSql();
  431. // return $sql;
  432. $dataDependencias = [];
  433. $totalParticipantesDependencias = 0;
  434. $totalPendientesDependencias = 0;
  435. foreach($queryDependencia->each() as $resultado) {
  436. $totalParticipantesDependencias += $resultado["conteoNotNull"];
  437. $totalPendientesDependencias += $resultado["totalDependencia"] - $resultado["conteoNotNull"];
  438. $dataDependencias[] = [
  439. "id" => $resultado["dependenciaId"],
  440. "nombre" => $resultado["dependenciaNombre"],
  441. "participaciones" => $resultado["conteoNotNull"],
  442. "pendientes" => $resultado["totalDependencia"] - $resultado["conteoNotNull"]
  443. ];
  444. }
  445. return (new Respuesta())
  446. ->detalle([
  447. "totalResultadosUsuarios" => $totalUsuario,
  448. "participoResultadosUsuarios" => $participoUsuario,
  449. "pendientesResultadosUsuarios" => ($totalUsuario - $participoUsuario),
  450. "datosDependencias" => $dataDependencias,
  451. "totalParticipantesDependencias" => $totalParticipantesDependencias,
  452. "totalPendientesDependencias" => $totalPendientesDependencias,
  453. "totalDependencias" => $totalPendientesDependencias + $totalPendientesDependencias
  454. ]);
  455. }
  456. public function actionTag() {
  457. $id = intval($this->req->get("id", ""));
  458. $q = trim($this->req->get("q", ""));
  459. // $query = $this->queryInicial;
  460. $query = (new Query())
  461. ->select([
  462. '{{Evento}}.tag',
  463. '{{Evento}}.nombre',
  464. '{{Evento}}.[[fechaInicio]]',
  465. '{{Evento}}.[[fechaFinal]]',
  466. 'case when count({{Resultado}}.accion) > 0 then true else false end as paticipo'
  467. ])
  468. ->from('Evento')
  469. ->innerJoin("EventoGrupo", "{{EventoGrupo}}.[[idEvento]] = {{Evento}}.id")
  470. ->innerJoin("Grupo", "{{Grupo}}.id = {{EventoGrupo}}.[[idGrupo]]")
  471. ->innerJoin("UsuarioGrupo", "{{UsuarioGrupo}}.[[idGrupo]] = {{Grupo}}.id")
  472. ->innerJoin("Usuario", "{{Usuario}}.[[id]] = {{UsuarioGrupo}}.[[idUsuario]]")
  473. ->leftJoin("Resultado", "{{Resultado}}.[[idEvento]] = {{Evento}}.id and {{Resultado}}.[[idUsuario]] = {{Usuario}}.id")
  474. ->andWhere(["{{Evento}}.eliminado" => null])
  475. ->andWhere("{{Evento}}.tag is not null")
  476. ->groupBy([
  477. '{{Evento}}.tag',
  478. '{{Evento}}.nombre',
  479. '{{Evento}}.[[fechaInicio]]',
  480. '{{Evento}}.[[fechaFinal]]',
  481. ]);
  482. /* if($id > 0) {
  483. $query->andWhere(["id" => $id]);
  484. } */
  485. if($q !== "") {
  486. # Ejemplo de buscador
  487. $query->andWhere([
  488. "OR",
  489. ["ilike", "{{Evento}}.nombre", $q],
  490. // ["ilike", "direccion", $q],
  491. ]);
  492. //
  493. }
  494. return new Respuesta($query, $this->limite, $this->pagina, $this->ordenar);
  495. }
  496. public function actionCondensado() {
  497. $tag = trim($this->req->getBodyParam("tag", null));
  498. $fechaInicio = trim($this->req->getBodyParam("fechaInicio", ""));
  499. $fechaFinal = trim($this->req->getBodyParam("fechaFinal", ""));
  500. try {
  501. $usuarios = (new Query())
  502. ->select([
  503. "{{Usuario}}.id as usuarioId",
  504. "{{Usuario}}.uid as uid",
  505. "{{Usuario}}.nombre as nombre",
  506. "case when {{Usuario}}.[[facebookVerificado]] = true then 1 else 0 end as [[tieneFb]]",
  507. "case when {{Usuario}}.[[twitterVerificado]] = true then 1 else 0 end as [[tieneTw]]",
  508. "case when {{Usuario}}.[[instagramVerificado]] = true then 1 else 0 end as [[tieneIg]]",
  509. "{{Usuario}}.facebook as facebook",
  510. "{{Usuario}}.instagram as instagram",
  511. "{{Usuario}}.twitter as twitter",
  512. "{{Usuario}}.verificado as verificado",
  513. "{{Dependencia}}.id as [[idDependencia]]",
  514. "{{Dependencia}}.nombre as dependencia",
  515. ])
  516. ->from("Usuario")
  517. ->innerJoin("UsuarioGrupo", "{{UsuarioGrupo}}.[[idUsuario]] = {{Usuario}}.id")
  518. ->innerJoin("UsuarioDependencia", "{{UsuarioDependencia}}.[[idUsuario]] = {{Usuario}}.id")
  519. ->innerJoin("Dependencia", "{{Dependencia}}.id = {{UsuarioDependencia}}.[[idDependencia]]")
  520. ->andWhere(["{{Usuario}}.eliminado" => null])
  521. ->andWhere(["{{UsuarioGrupo}}.[[idGrupo]]" => 1]) //Grupo ENLACES 2022
  522. ->andWhere(["!=", "{{UsuarioDependencia}}.[[idDependencia]]", 33]) //Diferente a dependencia Soporte
  523. ->orderBy(['dependencia' => SORT_ASC, 'nombre' => SORT_ASC])
  524. ->indexBy("usuarioId")
  525. ->all();
  526. $eventos = Evento::find()
  527. ->leftJoin("Resultado", "{{Resultado}}.[[idEvento]] = {{Evento}}.id")
  528. ->andWhere(["{{Evento}}.eliminado" => null])
  529. ->andWhere(["tag" => $tag])
  530. ->andWhere([
  531. "AND",
  532. [">=", "fechaInicio", $fechaInicio],
  533. ["<=", "fechaFinal", $fechaFinal],
  534. ]);
  535. $auxiliar = [];
  536. $auxiliarDependencias = [];
  537. foreach($eventos->each() as $e) {
  538. foreach($e->resultados as $resultado) {
  539. if (isset($usuarios[$resultado->idUsuario])) {
  540. $usuario = $usuarios[$resultado->idUsuario];
  541. if (!isset($auxiliar[$resultado->idUsuario])) {
  542. $auxiliar[$resultado->idUsuario] = [
  543. "id" => $usuario['usuarioId'],
  544. "uid" => $usuario['uid'],
  545. "nombre" => $usuario['nombre'],
  546. "idDependencia" => $usuario['idDependencia'],
  547. "dependencia" => $usuario['dependencia'],
  548. "tieneFb" => $usuario['tieneFb'],
  549. "facebook" => $usuario['facebook'],
  550. "tieneTw" => $usuario['tieneTw'],
  551. "twitter" => $usuario['twitter'],
  552. "tieneIg" => $usuario['tieneIg'],
  553. "instagram" => $usuario['instagram'],
  554. "verificado" => $usuario['verificado'],
  555. "participoFacebook" => 0,
  556. "participoTwitter" => 0,
  557. "participoInstagram" => 0,
  558. ];
  559. }
  560. if (!isset($auxiliarDependencias[$usuario['idDependencia']])) {
  561. $auxiliarDependencias[$usuario['idDependencia']] = [
  562. "id" => $usuario['idDependencia'],
  563. "nombre" => $usuario['dependencia'],
  564. "participaciones" => 0,
  565. "pendientes" => 0
  566. ];
  567. }
  568. if ($e->redSocial === 'Facebook') {
  569. $auxiliar[$resultado->idUsuario]["participoFacebook"] = 1;
  570. }
  571. if ($e->redSocial === 'Twitter') {
  572. $auxiliar[$resultado->idUsuario]["participoTwitter"] = 1;
  573. }
  574. if ($e->redSocial === 'Instagram') {
  575. $auxiliar[$resultado->idUsuario]["participoInstagram"] = 1;
  576. }
  577. }
  578. }
  579. foreach ($usuarios as $usr) {
  580. if (!isset($auxiliar[$usr["usuarioId"]])) {
  581. $auxiliar[$usr["usuarioId"]] = [
  582. "id" => $usr['usuarioId'],
  583. "uid" => $usr['uid'],
  584. "nombre" => $usr['nombre'],
  585. "idDependencia" => $usr['idDependencia'],
  586. "dependencia" => $usr['dependencia'],
  587. "tieneFb" => $usr['tieneFb'],
  588. "facebook" => $usr['facebook'],
  589. "tieneTw" => $usr['tieneTw'],
  590. "twitter" => $usr['twitter'],
  591. "tieneIg" => $usr['tieneIg'],
  592. "instagram" => $usr['instagram'],
  593. "verificado" => $usr['verificado'],
  594. "participoFacebook" => 0,
  595. "participoTwitter" => 0,
  596. "participoInstagram" => 0,
  597. ];
  598. }
  599. if (!isset($auxiliarDependencias[$usr['idDependencia']])) {
  600. $auxiliarDependencias[$usr['idDependencia']] = [
  601. "id" => $usr['idDependencia'],
  602. "nombre" => $usr['dependencia'],
  603. "participaciones" => 0,
  604. "pendientes" => 0
  605. ];
  606. }
  607. }
  608. }
  609. $segundoAuxiliar = [];
  610. $segundoAuxiliarDependencias = [];
  611. foreach($auxiliar as $aux) {
  612. if ($aux['tieneFb'] > 0) {
  613. if ($aux['participoFacebook'] > 0) {
  614. $auxiliarDependencias[$aux['idDependencia']]['participaciones'] += 1;
  615. } else {
  616. $auxiliarDependencias[$aux['idDependencia']]['pendientes'] += 1;
  617. }
  618. }
  619. if ($aux['tieneTw'] > 0) {
  620. if ($aux['participoTwitter'] > 0) {
  621. $auxiliarDependencias[$aux['idDependencia']]['participaciones'] += 1;
  622. } else {
  623. $auxiliarDependencias[$aux['idDependencia']]['pendientes'] += 1;
  624. }
  625. }
  626. if ($aux['tieneIg'] > 0) {
  627. if ($aux['participoInstagram'] > 0) {
  628. $auxiliarDependencias[$aux['idDependencia']]['participaciones'] += 1;
  629. } else {
  630. $auxiliarDependencias[$aux['idDependencia']]['pendientes'] += 1;
  631. }
  632. }
  633. $segundoAuxiliar[] = $aux;
  634. }
  635. $participaciones = 0;
  636. $pendientes = 0;
  637. foreach($auxiliarDependencias as $aux) {
  638. $participaciones += $aux['participaciones'];
  639. $pendientes += $aux['pendientes'];
  640. $segundoAuxiliarDependencias[] = $aux;
  641. }
  642. $total = $pendientes + $participaciones;
  643. $detalle = [
  644. "usuarios" => $segundoAuxiliar,
  645. "dependencias" => $segundoAuxiliarDependencias,
  646. "total" => $total,
  647. "participaciones" => $participaciones,
  648. "pendientes" => $pendientes
  649. ];
  650. return (new Respuesta())->detalle($detalle);
  651. } catch (\Exception $e) {
  652. return (new Respuesta())
  653. ->mensaje($e->getLine().'. '.$e->getMessage());
  654. }
  655. }
  656. }