ReportController.php 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Exports\ContatosAssociadosExport;
  4. use App\Exports\ExclusoesMesExport;
  5. use App\Exports\NovoAssociadosExport;
  6. use App\Services\ReportService;
  7. use Illuminate\Http\JsonResponse;
  8. use Illuminate\Http\Request;
  9. use Maatwebsite\Excel\Facades\Excel;
  10. use Symfony\Component\HttpFoundation\BinaryFileResponse;
  11. class ReportController extends Controller
  12. {
  13. public function __construct(protected ReportService $service) {}
  14. public function getCounters(): JsonResponse
  15. {
  16. return $this->successResponse(payload: $this->service->getCounters());
  17. }
  18. public function getNovoAssociadosPaginated(Request $request): JsonResponse
  19. {
  20. $filters = $request->only(['search']);
  21. $perPage = min((int) $request->get('per_page', 10), 100);
  22. $paginator = $this->service->getNovoAssociadosPaginated($filters, $perPage);
  23. return $this->successResponse(payload: [
  24. 'data' => array_map(
  25. fn($u) => [
  26. 'id' => $u->id,
  27. 'name' => $u->name,
  28. 'cpf' => $u->cpf,
  29. 'created_at' => $u->created_at?->format('d/m/Y'),
  30. ],
  31. $paginator->items()
  32. ),
  33. 'total' => $paginator->total(),
  34. 'from' => $paginator->firstItem() ?? 0,
  35. 'to' => $paginator->lastItem() ?? 0,
  36. ]);
  37. }
  38. public function getContatosAssociadosPaginated(Request $request): JsonResponse
  39. {
  40. $filters = $request->only(['search']);
  41. $perPage = min((int) $request->get('per_page', 10), 100);
  42. $paginator = $this->service->getContatosAssociadosPaginated($filters, $perPage);
  43. return $this->successResponse(payload: [
  44. 'data' => array_map(
  45. fn($u) => [
  46. 'id' => $u->id,
  47. 'name' => $u->name,
  48. 'phone' => $u->phone,
  49. 'email' => $u->email,
  50. ],
  51. $paginator->items()
  52. ),
  53. 'total' => $paginator->total(),
  54. 'from' => $paginator->firstItem() ?? 0,
  55. 'to' => $paginator->lastItem() ?? 0,
  56. ]);
  57. }
  58. public function getExclusoesMesPaginated(Request $request): JsonResponse
  59. {
  60. $filters = $request->only(['search']);
  61. $perPage = min((int) $request->get('per_page', 10), 100);
  62. $paginator = $this->service->getExclusoesMesPaginated($filters, $perPage);
  63. return $this->successResponse(payload: [
  64. 'data' => array_map(
  65. fn($u) => [
  66. 'id' => $u->id,
  67. 'name' => $u->name,
  68. 'cpf' => $u->cpf,
  69. 'excluded_at' => $u->excluded_at?->format('d/m/Y'),
  70. ],
  71. $paginator->items()
  72. ),
  73. 'total' => $paginator->total(),
  74. 'from' => $paginator->firstItem() ?? 0,
  75. 'to' => $paginator->lastItem() ?? 0,
  76. ]);
  77. }
  78. public function exportNovoAssociados(Request $request): BinaryFileResponse
  79. {
  80. $filename = 'novos_associados_' . now()->format('d-m-Y') . '.xlsx';
  81. return Excel::download(new NovoAssociadosExport($request->get('search')), $filename);
  82. }
  83. public function exportContatosAssociados(Request $request): BinaryFileResponse
  84. {
  85. $filename = 'contatos_associados_' . now()->format('d-m-Y') . '.xlsx';
  86. return Excel::download(new ContatosAssociadosExport($request->get('search')), $filename);
  87. }
  88. public function exportExclusoesMes(Request $request): BinaryFileResponse
  89. {
  90. $filename = 'exclusoes_mes_' . now()->format('d-m-Y') . '.xlsx';
  91. return Excel::download(new ExclusoesMesExport($request->get('search')), $filename);
  92. }
  93. }