Files
sam-manage/app/Http/Controllers/Api/Admin/DepartmentController.php
hskwon d4534f0d3f feat(mng): 사용자 역할/부서 매핑 및 부서관리 복구/영구삭제 기능 추가
사용자 관리:
- 사용자 등록/수정 시 테넌트별 역할/부서 선택 기능 추가
- Department, UserRole, DepartmentUser 모델 추가
- User 모델에 역할/부서 관계 및 헬퍼 메서드 추가
- syncRoles/syncDepartments 메서드 (forceDelete로 유니크 키 충돌 방지)
- 체크박스 UI로 다중 선택 지원

부서 관리:
- Soft Delete 필터 (정상만/전체/삭제된 항목만)
- 복구(restore) 및 영구삭제(forceDelete) 기능 추가
- Department 모델에 SoftDeletes 트레이트 추가
- 삭제된 항목 빨간 배경 + "삭제됨" 배지 표시
2025-11-26 20:28:07 +09:00

212 lines
6.1 KiB
PHP

<?php
namespace App\Http\Controllers\Api\Admin;
use App\Http\Controllers\Controller;
use App\Http\Requests\StoreDepartmentRequest;
use App\Http\Requests\UpdateDepartmentRequest;
use App\Services\DepartmentService;
use Illuminate\Http\JsonResponse;
use Illuminate\Http\Request;
class DepartmentController extends Controller
{
public function __construct(
private readonly DepartmentService $departmentService
) {}
/**
* 부서 목록 조회
*/
public function index(Request $request): JsonResponse
{
$departments = $this->departmentService->getDepartments(
$request->all(),
$request->integer('per_page', 10)
);
// HTMX 요청 시 HTML 반환
if ($request->header('HX-Request')) {
$html = view('departments.partials.table', compact('departments'))->render();
return response()->json([
'html' => $html,
]);
}
// 일반 요청 시 JSON 반환
return response()->json([
'success' => true,
'data' => $departments->items(),
'meta' => [
'current_page' => $departments->currentPage(),
'last_page' => $departments->lastPage(),
'per_page' => $departments->perPage(),
'total' => $departments->total(),
],
]);
}
/**
* 부서 생성
*/
public function store(StoreDepartmentRequest $request): JsonResponse
{
$department = $this->departmentService->createDepartment($request->validated());
// HTMX 요청 시 성공 메시지와 리다이렉트 헤더 반환
if ($request->header('HX-Request')) {
return response()->json([
'success' => true,
'message' => '부서가 생성되었습니다.',
'redirect' => route('departments.index'),
]);
}
return response()->json([
'success' => true,
'message' => '부서가 생성되었습니다.',
'data' => $department,
], 201);
}
/**
* 특정 부서 조회
*/
public function show(Request $request, int $id): JsonResponse
{
$department = $this->departmentService->getDepartmentById($id);
if (! $department) {
return response()->json([
'success' => false,
'message' => '부서를 찾을 수 없습니다.',
], 404);
}
// HTMX 요청 시 HTML 반환
if ($request->header('HX-Request')) {
return response()->json([
'html' => view('departments.partials.detail', compact('department'))->render(),
]);
}
return response()->json([
'success' => true,
'data' => $department,
]);
}
/**
* 부서 수정
*/
public function update(UpdateDepartmentRequest $request, int $id): JsonResponse
{
$result = $this->departmentService->updateDepartment($id, $request->validated());
if (! $result) {
return response()->json([
'success' => false,
'message' => '부서 수정에 실패했습니다.',
], 400);
}
// HTMX 요청 시 성공 메시지와 리다이렉트 헤더 반환
if ($request->header('HX-Request')) {
return response()->json([
'success' => true,
'message' => '부서가 수정되었습니다.',
'redirect' => route('departments.index'),
]);
}
return response()->json([
'success' => true,
'message' => '부서가 수정되었습니다.',
]);
}
/**
* 부서 삭제 (Soft Delete)
*/
public function destroy(Request $request, int $id): JsonResponse
{
$result = $this->departmentService->deleteDepartment($id);
if (! $result) {
return response()->json([
'success' => false,
'message' => '부서 삭제에 실패했습니다. (하위 부서가 존재할 수 있습니다)',
], 400);
}
// HTMX 요청 시 테이블 행 제거 트리거
if ($request->header('HX-Request')) {
return response()->json([
'success' => true,
'message' => '부서가 삭제되었습니다.',
'action' => 'remove',
]);
}
return response()->json([
'success' => true,
'message' => '부서가 삭제되었습니다.',
]);
}
/**
* 부서 복원
*/
public function restore(Request $request, int $id): JsonResponse
{
$result = $this->departmentService->restoreDepartment($id);
if (! $result) {
return response()->json([
'success' => false,
'message' => '부서 복원에 실패했습니다.',
], 400);
}
if ($request->header('HX-Request')) {
return response()->json([
'success' => true,
'message' => '부서가 복원되었습니다.',
]);
}
return response()->json([
'success' => true,
'message' => '부서가 복원되었습니다.',
]);
}
/**
* 부서 영구 삭제
*/
public function forceDelete(Request $request, int $id): JsonResponse
{
$result = $this->departmentService->forceDeleteDepartment($id);
if (! $result) {
return response()->json([
'success' => false,
'message' => '부서 영구 삭제에 실패했습니다. (하위 부서가 존재할 수 있습니다)',
], 400);
}
if ($request->header('HX-Request')) {
return response()->json([
'success' => true,
'message' => '부서가 영구 삭제되었습니다.',
]);
}
return response()->json([
'success' => true,
'message' => '부서가 영구 삭제되었습니다.',
]);
}
}