AdminAreaController.php 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152
  1. <?php
  2. namespace App\Http\Controllers\Admin;
  3. use App\Http\Controllers\Controller;
  4. use App\Models\Dictionary\Area;
  5. use App\Models\Dictionary\District;
  6. use App\Services\Export\ExportAreasService;
  7. use App\Services\Import\ImportAreasService;
  8. use Illuminate\Http\RedirectResponse;
  9. use Illuminate\Http\Request;
  10. use Illuminate\Support\Facades\Storage;
  11. use Illuminate\View\View;
  12. class AdminAreaController extends Controller
  13. {
  14. protected string $id = 'admin_areas';
  15. protected array $header = [
  16. 'id' => 'ID',
  17. 'name' => 'Название',
  18. 'district_name' => 'Округ',
  19. 'actions' => '',
  20. ];
  21. protected array $searchFields = ['name'];
  22. public function index(Request $request): View
  23. {
  24. $allowedSortFields = ['id', 'name', 'district_name'];
  25. $sortBy = in_array($request->get('sortBy'), $allowedSortFields, true) ? $request->get('sortBy') : 'name';
  26. $orderBy = $request->get('order') === 'desc' ? 'desc' : 'asc';
  27. $query = Area::query()
  28. ->leftJoin('districts', 'areas.district_id', '=', 'districts.id')
  29. ->select('areas.*', 'districts.shortname as district_name');
  30. // Фильтр по округу
  31. if ($request->has('district_id') && $request->district_id) {
  32. $query->where('areas.district_id', $request->district_id);
  33. }
  34. if ($request->filled('s')) {
  35. $search = $request->get('s');
  36. $query->where(function ($q) use ($search) {
  37. $q->where('areas.name', 'like', '%' . $search . '%')
  38. ->orWhere('districts.shortname', 'like', '%' . $search . '%');
  39. });
  40. }
  41. if ($sortBy === 'district_name') {
  42. $query->orderBy('districts.shortname', $orderBy);
  43. } else {
  44. $query->orderBy('areas.' . $sortBy, $orderBy);
  45. }
  46. $areas = $query->get();
  47. $districts = District::orderBy('shortname')->pluck('shortname', 'id')->toArray();
  48. return view('admin.areas.index', [
  49. 'active' => 'admin_areas',
  50. 'id' => $this->id,
  51. 'header' => $this->header,
  52. 'sortBy' => $sortBy,
  53. 'orderBy' => $orderBy,
  54. 'searchFields' => ['name', 'district_name'],
  55. 'areas' => $areas,
  56. 'districts' => $districts,
  57. 'selectedDistrict' => $request->district_id,
  58. ]);
  59. }
  60. public function show(int $areaId): View
  61. {
  62. $area = Area::withTrashed()->findOrFail($areaId);
  63. $districts = District::orderBy('shortname')->pluck('name', 'id')->toArray();
  64. return view('admin.areas.edit', [
  65. 'active' => 'admin_areas',
  66. 'area' => $area,
  67. 'districts' => $districts,
  68. ]);
  69. }
  70. public function store(Request $request): RedirectResponse
  71. {
  72. $validated = $request->validate([
  73. 'id' => ['nullable', 'integer'],
  74. 'name' => ['required', 'string', 'max:255'],
  75. 'district_id' => ['required', 'integer', 'exists:districts,id'],
  76. ]);
  77. if (!empty($validated['id'])) {
  78. $area = Area::withTrashed()->findOrFail($validated['id']);
  79. $area->update([
  80. 'name' => $validated['name'],
  81. 'district_id' => $validated['district_id'],
  82. ]);
  83. } else {
  84. Area::create([
  85. 'name' => $validated['name'],
  86. 'district_id' => $validated['district_id'],
  87. ]);
  88. }
  89. return redirect()->route('admin.area.index')->with('success', 'Район сохранён');
  90. }
  91. public function destroy(Area $area): RedirectResponse
  92. {
  93. $area->delete();
  94. return redirect()->route('admin.area.index')->with('success', 'Район удалён');
  95. }
  96. public function undelete(int $areaId): RedirectResponse
  97. {
  98. $area = Area::withTrashed()->findOrFail($areaId);
  99. $area->restore();
  100. return redirect()->route('admin.area.index')->with('success', 'Район восстановлен');
  101. }
  102. public function export(Request $request): RedirectResponse
  103. {
  104. $service = new ExportAreasService();
  105. $link = $service->handle($request->user()->id);
  106. return redirect()->away($link);
  107. }
  108. public function import(Request $request): RedirectResponse
  109. {
  110. $request->validate([
  111. 'import_file' => ['required', 'file', 'mimes:xlsx,xls'],
  112. ]);
  113. $file = $request->file('import_file');
  114. $path = $file->store('import/areas', 'upload');
  115. $fullPath = Storage::disk('upload')->path($path);
  116. $service = new ImportAreasService($fullPath, $request->user()->id);
  117. $result = $service->handle();
  118. if ($result['success']) {
  119. return redirect()->route('admin.area.index')
  120. ->with('success', 'Импорт завершён успешно');
  121. }
  122. return redirect()->route('admin.area.index')
  123. ->with('error', 'Ошибка импорта: ' . ($result['error'] ?? 'неизвестная ошибка'));
  124. }
  125. }