TareasController.php 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505
  1. <?php
  2. namespace App\Http\Controllers\Api;
  3. use App\Http\Controllers\Controller;
  4. use App\Services\PeriodoService;
  5. use Illuminate\Http\Request;
  6. use Illuminate\Support\Facades\DB;
  7. use Illuminate\Support\Facades\Storage;
  8. use Illuminate\Support\Facades\Validator;
  9. class TareasController extends Controller
  10. {
  11. protected $nombrePeriodoActivo;
  12. public function __construct(PeriodoService $periodoService)
  13. {
  14. try {
  15. $this->nombrePeriodoActivo = $periodoService->obtenerPeriodoActivoNombre();
  16. } catch (\Exception $e) {
  17. $this->nombrePeriodoActivo = null;
  18. }
  19. }
  20. public function getAllTareas()
  21. {
  22. try {
  23. $tareas = DB::table('tareas_usuarios_colegioabc as tu')
  24. ->join('tareas as t', 'tu.idTarea', '=', 't.idTarea')
  25. ->join('materias as m', 't.idMateriaTarea', '=', 'm.idMateria')
  26. ->join('tareas_tipos as tt', 't.idTipoTarea', '=', 'tt.idTareasTipos')
  27. ->join('usuarios as u', 't.idUsuario', '=', 'u.idUsuario')
  28. ->select(
  29. 'u.primerNombre',
  30. 'u.segundoNombre',
  31. 'u.apellidoPaterno',
  32. 'u.apellidoMaterno',
  33. 'u.alias',
  34. 'm.nombreMateria as materia',
  35. 'tt.nombreTareasTipos as tipo_tarea',
  36. 't.*', // todos los campos de tareas
  37. 'tu.idUsuario as usuario_asignado', // opcional, por si quieres saber a qué usuario está asignada
  38. 'tu.completa'
  39. )
  40. ->orderBy('t.fechaPublicacion', 'desc')
  41. ->get();
  42. return response()->json($tareas);
  43. } catch (\Exception $e) {
  44. return response()->json([
  45. 'mensaje' => 'Error al obtener las tareas: ' . $e->getMessage()
  46. ], 500);
  47. }
  48. }
  49. public function getTareasPorFechaEntrega($fecha, $idUsuario)
  50. {
  51. try {
  52. $tareas = DB::table('tareas as t')
  53. ->join('materias as m', 't.idMateriaTarea', '=', 'm.idMateria')
  54. ->join('tareas_tipos as tt', 't.idTipoTarea', '=', 'tt.idTareasTipos')
  55. ->join('tareas_usuarios_colegioabc as tu', 't.idTarea', '=', 'tu.idTarea')
  56. ->where('tu.idUsuario', $idUsuario)
  57. ->whereDate('t.fechaEntrega', '=', $fecha)
  58. ->select(
  59. 'm.nombreMateria as materia',
  60. 'tt.nombreTareasTipos as tipo_tarea',
  61. 't.*'
  62. )
  63. ->orderBy('t.fechaEntrega', 'asc')
  64. ->get();
  65. return response()->json($tareas);
  66. } catch (\Exception $e) {
  67. return response()->json(['mensaje' => 'Error al obtener las tareas por fecha de entrega: ' . $e->getMessage()], 500);
  68. }
  69. }
  70. public function getAllTareasPorFechaEntrega($fecha)
  71. {
  72. try {
  73. $tareas = DB::table('tareas as t')
  74. ->join('materias as m', 't.idMateriaTarea', '=', 'm.idMateria')
  75. ->join('tareas_tipos as tt', 't.idTipoTarea', '=', 'tt.idTareasTipos')
  76. ->join('tareas_usuarios_colegioabc as tu', 't.idTarea', '=', 'tu.idTarea')
  77. ->whereDate('t.fechaEntrega', '=', $fecha)
  78. ->select(
  79. 'm.nombreMateria as materia',
  80. 'tt.nombreTareasTipos as tipo_tarea',
  81. 't.*'
  82. )
  83. ->orderBy('t.fechaEntrega', 'asc')
  84. ->get();
  85. return response()->json($tareas);
  86. } catch (\Exception $e) {
  87. return response()->json(['mensaje' => 'Error al obtener las tareas por fecha de entrega: ' . $e->getMessage()], 500);
  88. }
  89. }
  90. public function getAllTareasPorFechaAsignacion($fecha)
  91. {
  92. try {
  93. $tareas = DB::table('tareas as t')
  94. ->join('materias as m', 't.idMateriaTarea', '=', 'm.idMateria')
  95. ->join('tareas_tipos as tt', 't.idTipoTarea', '=', 'tt.idTareasTipos')
  96. ->join('tareas_usuarios_colegioabc as tu', 't.idTarea', '=', 'tu.idTarea')
  97. ->whereDate('t.fechaPublicacion', '=', $fecha)
  98. ->select(
  99. 'm.nombreMateria as materia',
  100. 'tt.nombreTareasTipos as tipo_tarea',
  101. 't.*'
  102. )
  103. ->orderBy('t.fechaPublicacion', 'asc')
  104. ->get();
  105. return response()->json($tareas);
  106. } catch (\Exception $e) {
  107. return response()->json(['mensaje' => 'Error al obtener las tareas por fecha de asignación: ' . $e->getMessage()], 500);
  108. }
  109. }
  110. public function getTareasPorFechaAsignacion($fecha, $idUsuario)
  111. {
  112. try {
  113. $tareas = DB::table('tareas as t')
  114. ->join('materias as m', 't.idMateriaTarea', '=', 'm.idMateria')
  115. ->join('tareas_tipos as tt', 't.idTipoTarea', '=', 'tt.idTareasTipos')
  116. ->join('tareas_usuarios_colegioabc as tu', 't.idTarea', '=', 'tu.idTarea')
  117. ->where('tu.idUsuario', $idUsuario)
  118. ->whereDate('t.fechaPublicacion', '=', $fecha)
  119. ->select(
  120. 'm.nombreMateria as materia',
  121. 'tt.nombreTareasTipos as tipo_tarea',
  122. 't.*'
  123. )
  124. ->orderBy('t.fechaPublicacion', 'asc')
  125. ->get();
  126. return response()->json($tareas);
  127. } catch (\Exception $e) {
  128. return response()->json(['mensaje' => 'Error al obtener las tareas por fecha de asignación: ' . $e->getMessage()], 500);
  129. }
  130. }
  131. public function getMateriasUsuarioUltimos30Dias($idUsuario)
  132. {
  133. try {
  134. $materias = DB::table('tareas as t')
  135. ->join('materias as m', 't.idMateriaTarea', '=', 'm.idMateria')
  136. ->join('tareas_usuarios_colegioabc as tu', 't.idTarea', '=', 'tu.idTarea')
  137. ->where('tu.idUsuario', $idUsuario)
  138. ->where('t.fechaPublicacion', '>=', now()->subDays(30))
  139. ->select(
  140. 'm.idMateria',
  141. 'm.nombreMateria'
  142. )
  143. ->distinct()
  144. ->orderBy('m.nombreMateria', 'asc')
  145. ->get();
  146. return response()->json($materias);
  147. } catch (\Exception $e) {
  148. return response()->json([
  149. 'mensaje' => 'Error al obtener las materias: ' . $e->getMessage()
  150. ], 500);
  151. }
  152. }
  153. public function getTareasPorMateria($idMateria)
  154. {
  155. try {
  156. $tareas = DB::table('tareas as t')
  157. ->join('materias as m', 't.idMateriaTarea', '=', 'm.idMateria')
  158. ->join('tareas_tipos as tt', 't.idTipoTarea', '=', 'tt.idTareasTipos')
  159. ->where('t.idMateriaTarea', $idMateria)
  160. ->select(
  161. 'm.nombreMateria as materia',
  162. 'tt.nombreTareasTipos as tipo_tarea',
  163. 't.*'
  164. )
  165. ->orderBy('t.fechaPublicacion', 'desc')
  166. ->get();
  167. return response()->json($tareas);
  168. } catch (\Exception $e) {
  169. return response()->json(['mensaje' => 'Error al obtener las tareas por materia: ' . $e->getMessage()], 500);
  170. }
  171. }
  172. public function crear(Request $request)
  173. {
  174. $carpetaBase = config('custom.s3_carpeta_base');
  175. $periodoService = new PeriodoService();
  176. $carpetaPeriodo = $periodoService->obtenerPeriodoActivoNombre();
  177. $rutaBucket = 'tareas/';
  178. try {
  179. // Procesar adjuntoTarea (por si mandas archivos en base64 como en circulares)
  180. $adjuntos = [];
  181. if ($request->has('bases64')) {
  182. foreach ($request->bases64 as $file) {
  183. $fileInfo = explode(';', $file['base64'])[0];
  184. $fileExtension = explode('/', $fileInfo)[1];
  185. switch ($fileExtension) {
  186. case 'vnd.openxmlformats-officedocument.wordprocessingml.document':
  187. $fileExtension = 'docx';
  188. break;
  189. case 'vnd.openxmlformats-officedocument.spreadsheetml.sheet':
  190. $fileExtension = 'xlsx';
  191. break;
  192. case 'vnd.openxmlformats-officedocument.presentationml.presentation':
  193. $fileExtension = 'pptx';
  194. break;
  195. }
  196. $fileData = substr($file['base64'], strpos($file['base64'], ',') + 1);
  197. $fileData = str_replace(' ', '+', $fileData);
  198. $contenidoArchivo = base64_decode($fileData);
  199. $fileName = $file['id'] . '-' . $file['nombre'] . '.' . $fileExtension;
  200. $pathS3 = $carpetaBase . '/' . $carpetaPeriodo . '/' . $rutaBucket . $fileName;
  201. // Subir al s3
  202. Storage::disk('s3')->put($pathS3, $contenidoArchivo, 'public');
  203. $adjuntos[] = [
  204. 'id' => $file['id'],
  205. 'nombre' => $file['nombre'],
  206. 'ruta' => Storage::disk('s3')->url($pathS3)
  207. ];
  208. }
  209. }
  210. // Insertar tarea en la base de datos
  211. DB::table('tareas')->insert([
  212. 'idEscuela' => 'COlEGIOABC',
  213. 'idMateriaTarea' => $request->idMateriaTarea,
  214. 'idTipoTarea' => $request->idTipoTarea,
  215. 'tituloTarea' => $request->tituloTarea,
  216. 'descripcionTarea' => $request->descripcionTarea,
  217. 'vinculoTarea' => $request->vinculoTarea,
  218. 'adjuntoTarea' => json_encode($adjuntos),
  219. 'fechaPublicacion' => $request->fechaPublicacion,
  220. 'fechaEntrega' => $request->fechaEntrega,
  221. 'estado' => 'Completa',
  222. // estos por default en 'No' si no vienen en la request
  223. 'entregaDigital' => $request->entregaDigital ?? 'No',
  224. 'calificacion' => $request->calificacion ?? 'No',
  225. 'retroalimentacion' => $request->retroalimentacion ?? 'No',
  226. 'descargarTareas' => $request->descargarTareas ?? 'No',
  227. 'idUsuario' => $request->idUsuario,
  228. ]);
  229. return response()->json([
  230. 'mensaje' => 'Tarea creada exitosamente',
  231. 'idTarea' => DB::getPdo()->lastInsertId()
  232. ], 201);
  233. } catch (\Exception $e) {
  234. return response()->json(['mensaje' => 'Error al crear la tarea: ' . $e->getMessage()], 500);
  235. }
  236. }
  237. public function actualizar(Request $request, $idTarea)
  238. {
  239. $carpetaBase = config('custom.s3_carpeta_base');
  240. $periodoService = new PeriodoService();
  241. $carpetaPeriodo = $periodoService->obtenerPeriodoActivoNombre();
  242. $rutaBucket = 'tareas/';
  243. try {
  244. // Recuperar tarea existente
  245. $tareaExistente = DB::table('tareas')->where('idTarea', $idTarea)->first();
  246. if (!$tareaExistente) {
  247. return response()->json(['mensaje' => 'Tarea no encontrada'], 404);
  248. }
  249. // Adjuntos (si vienen)
  250. $adjuntos = json_decode($tareaExistente->adjuntoTarea ?? '[]', true);
  251. if ($request->has('bases64')) {
  252. foreach ($request->bases64 as $file) {
  253. $fileInfo = explode(';', $file['base64'])[0];
  254. $fileExtension = explode('/', $fileInfo)[1];
  255. switch ($fileExtension) {
  256. case 'vnd.openxmlformats-officedocument.wordprocessingml.document':
  257. $fileExtension = 'docx';
  258. break;
  259. case 'vnd.openxmlformats-officedocument.spreadsheetml.sheet':
  260. $fileExtension = 'xlsx';
  261. break;
  262. case 'vnd.openxmlformats-officedocument.presentationml.presentation':
  263. $fileExtension = 'pptx';
  264. break;
  265. }
  266. $fileData = substr($file['base64'], strpos($file['base64'], ',') + 1);
  267. $fileData = str_replace(' ', '+', $fileData);
  268. $contenidoArchivo = base64_decode($fileData);
  269. $fileName = $file['id'] . '-' . $file['nombre'] . '.' . $fileExtension;
  270. $pathS3 = $carpetaBase . '/' . $carpetaPeriodo . '/' . $rutaBucket . $fileName;
  271. Storage::disk('s3')->put($pathS3, $contenidoArchivo, 'public');
  272. $adjuntos[] = [
  273. 'id' => $file['id'],
  274. 'nombre' => $file['nombre'],
  275. 'ruta' => Storage::disk('s3')->url($pathS3)
  276. ];
  277. }
  278. }
  279. // Actualizar tarea en DB
  280. DB::table('tareas')
  281. ->where('idTarea', $idTarea)
  282. ->update([
  283. 'idMateriaTarea' => $request->idMateriaTarea ?? $tareaExistente->idMateriaTarea,
  284. 'idTipoTarea' => $request->idTipoTarea ?? $tareaExistente->idTipoTarea,
  285. 'tituloTarea' => $request->tituloTarea ?? $tareaExistente->tituloTarea,
  286. 'descripcionTarea' => $request->descripcionTarea ?? $tareaExistente->descripcionTarea,
  287. 'vinculoTarea' => $request->vinculoTarea ?? $tareaExistente->vinculoTarea,
  288. 'adjuntoTarea' => json_encode($adjuntos),
  289. 'fechaPublicacion' => $request->fechaPublicacion ?? $tareaExistente->fechaPublicacion,
  290. 'fechaEntrega' => $request->fechaEntrega ?? $tareaExistente->fechaEntrega,
  291. 'entregaDigital' => $request->entregaDigital ?? $tareaExistente->entregaDigital,
  292. 'calificacion' => $request->calificacion ?? $tareaExistente->calificacion,
  293. 'retroalimentacion' => $request->retroalimentacion ?? $tareaExistente->retroalimentacion,
  294. 'descargarTareas' => $request->descargarTareas ?? $tareaExistente->descargarTareas,
  295. 'estado' => $request->estado ?? $tareaExistente->estado,
  296. 'idUsuario' => $request->idUsuario ?? $tareaExistente->idUsuario,
  297. ]);
  298. return response()->json([
  299. 'mensaje' => 'Tarea actualizada exitosamente',
  300. 'idTarea' => $idTarea
  301. ], 200);
  302. } catch (\Exception $e) {
  303. return response()->json(['mensaje' => 'Error al actualizar la tarea: ' . $e->getMessage()], 500);
  304. }
  305. }
  306. public function obtenerAlumnosPorMateria($idMateria)
  307. {
  308. // Primero obtenemos el grado o grupo relacionado con la materia
  309. $materia = DB::table('vista_materias_grados_grupos')
  310. ->where('idMateria', $idMateria)
  311. ->first();
  312. if (!$materia) {
  313. return collect(); // Si no existe la materia
  314. }
  315. $idRelacionado = $materia->idGradoGrupoRelacionado;
  316. // --- Caso 1: Coincide con el grado del usuario ---
  317. $alumnosPorGrado = DB::table('usuarios')
  318. ->where('grado', $idRelacionado)
  319. ->where('tipoUsuario', 'AL') // solo alumnos
  320. ->where('estatus', 'Activo')
  321. ->get();
  322. // --- Caso 2: Coincide con un grupo ---
  323. $alumnosPorGrupo = DB::table('usuarios')
  324. ->join('grupos', 'usuarios.idUsuario', '=', 'grupos.idUsuario')
  325. ->where('grupos.idGrupo', $idRelacionado)
  326. ->where('usuarios.tipoUsuario', 'AL')
  327. ->where('usuarios.estatus', 'Activo')
  328. ->select('usuarios.*')
  329. ->get();
  330. // Unimos los resultados
  331. return $alumnosPorGrado->merge($alumnosPorGrupo);
  332. }
  333. public function asignarTareaUsuario(Request $request)
  334. {
  335. // Insertar con Query Builder
  336. DB::table('tareas_usuarios_colegioabc')->insert([
  337. 'idTarea' => $request->idTarea,
  338. 'idUsuario' => $request->idUsuario,
  339. ]);
  340. return response()->json([
  341. 'success' => true,
  342. 'message' => 'Tarea asignada al usuario correctamente',
  343. ], 201);
  344. }
  345. public function getTareasPorUsuario($idUsuario)
  346. {
  347. try {
  348. $tareas = DB::table('tareas_usuarios_colegioabc as tu')
  349. ->join('tareas as t', 'tu.idTarea', '=', 't.idTarea')
  350. ->join('materias as m', 't.idMateriaTarea', '=', 'm.idMateria')
  351. ->join('tareas_tipos as tt', 't.idTipoTarea', '=', 'tt.idTareasTipos')
  352. ->where('tu.idUsuario', $idUsuario)
  353. ->select(
  354. 'm.nombreMateria as materia',
  355. 'tt.nombreTareasTipos as tipo_tarea',
  356. 't.*', // todos los campos de tareas
  357. 'tu.idUsuario as usuario_asignado', // opcional, por si quieres saber a qué usuario está asignada
  358. 'tu.completa'
  359. )
  360. ->orderBy('t.fechaPublicacion', 'desc')
  361. ->get();
  362. return response()->json($tareas);
  363. } catch (\Exception $e) {
  364. return response()->json([
  365. 'mensaje' => 'Error al obtener las tareas: ' . $e->getMessage()
  366. ], 500);
  367. }
  368. }
  369. // Función para completar una tarea por idUsuario y idTarea
  370. public function completarTarea(Request $request)
  371. {
  372. try {
  373. $tarea = DB::table('tareas_usuarios_colegioabc')
  374. ->where('idTarea', $request->idTarea)
  375. ->where('idUsuario', $request->idUsuario)
  376. ->first();
  377. if ($tarea) {
  378. // Si ya existe, alternamos el valor de "completa"
  379. $nuevoEstado = $tarea->completa ? 0 : 1;
  380. DB::table('tareas_usuarios_colegioabc')
  381. ->where('idTarea', $request->idTarea)
  382. ->where('idUsuario', $request->idUsuario)
  383. ->update(['completa' => $nuevoEstado]);
  384. $mensaje = $nuevoEstado ? 'Tarea completada' : 'Tarea desmarcada como incompleta';
  385. } else {
  386. // Si no existe el registro, la creamos como completada
  387. DB::table('tareas_usuarios_colegioabc')->insert([
  388. 'idTarea' => $request->idTarea,
  389. 'idUsuario' => $request->idUsuario,
  390. 'completa' => 1
  391. ]);
  392. $mensaje = 'Tarea completada por primera vez';
  393. }
  394. return response()->json(['mensaje' => $mensaje], 200);
  395. } catch (\Exception $e) {
  396. return response()->json(['mensaje' => 'Error al cambiar el estado de la tarea: ' . $e->getMessage()], 500);
  397. }
  398. }
  399. public function habilitar($id)
  400. {
  401. try {
  402. //code...
  403. DB::table('tareas')
  404. ->updateOrInsert(
  405. ['idTarea' => $id],
  406. ['estado' => 'Completa']
  407. );
  408. return response()->json(['mensaje' => 'Tarea habilitada exitosamente'], 201);
  409. } catch (\Exception $e) {
  410. //throw $th;
  411. return response()->json(['mensaje' => 'Error al habilitar la tarea: ' . $e->getMessage()], 500);
  412. }
  413. }
  414. public function eliminar($id)
  415. {
  416. try {
  417. //code...
  418. DB::table('tareas')
  419. ->updateOrInsert(
  420. ['idTarea' => $id],
  421. ['estado' => 'Eliminada']
  422. );
  423. return response()->json(['mensaje' => 'Tarea eliminada exitosamente'], 201);
  424. } catch (\Exception $e) {
  425. //throw $th;
  426. return response()->json(['mensaje' => 'Error al eliminar la tarea: ' . $e->getMessage()], 500);
  427. }
  428. }
  429. }