- 테넌트 선택을 각 페이지에서 헤더로 통합 이동 - 페이지 제목 이모지 제거 및 상단 여백(mt-6) 축소 - 역할 권한 관리 페이지 레이아웃을 다른 페이지와 통일 - 메뉴명 스타일 개선 (depth 들여쓰기, └ 기호 적용) - 상위 메뉴 컬럼 제거로 테이블 간소화 - RolePermissionService에 depth 계산 로직 추가 - pagination.js를 body 끝으로 이동하여 로딩 오류 해결 - 역할 선택 UI를 셀렉트박스에서 버튼 형태로 변경 - 역할 버튼 hover 효과 개선 (선택된 버튼 가독성 향상) 변경된 파일: - resources/views/partials/header.blade.php: 테넌트 선택 UI 추가 - resources/views/dashboard|menus|users|departments|permissions|roles/index.blade.php: tenant-selector 제거, 여백 축소 - resources/views/layouts/app.blade.php: pagination.js 위치 변경 - app/Services/RolePermissionService.php: depth 계산 로직 추가 - resources/views/role-permissions/: 역할 권한 관리 페이지 개선 - routes/web.php, routes/api.php: 역할 권한 관리 라우트 추가
113 lines
3.3 KiB
PHP
113 lines
3.3 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers\Api\Admin;
|
|
|
|
use App\Http\Controllers\Controller;
|
|
use App\Services\RolePermissionService;
|
|
use Illuminate\Http\Request;
|
|
|
|
class RolePermissionController extends Controller
|
|
{
|
|
protected RolePermissionService $rolePermissionService;
|
|
|
|
public function __construct(RolePermissionService $rolePermissionService)
|
|
{
|
|
$this->rolePermissionService = $rolePermissionService;
|
|
}
|
|
|
|
/**
|
|
* 권한 매트릭스 조회 (역할 변경 시 호출)
|
|
*/
|
|
public function getMatrix(Request $request)
|
|
{
|
|
$roleId = $request->input('role_id');
|
|
$tenantId = session('selected_tenant_id');
|
|
|
|
if (! $roleId) {
|
|
return view('role-permissions.partials.empty-state');
|
|
}
|
|
|
|
// 메뉴 트리 조회
|
|
$menus = $this->rolePermissionService->getMenuTree($tenantId);
|
|
|
|
// 권한 매트릭스 조회
|
|
$permissions = $this->rolePermissionService->getRolePermissionMatrix($roleId, $tenantId);
|
|
|
|
return view('role-permissions.partials.permission-matrix', [
|
|
'menus' => $menus,
|
|
'permissions' => $permissions,
|
|
'roleId' => $roleId,
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* 권한 토글
|
|
*/
|
|
public function toggle(Request $request)
|
|
{
|
|
$roleId = $request->input('role_id');
|
|
$menuId = $request->input('menu_id');
|
|
$permissionType = $request->input('permission_type');
|
|
$tenantId = session('selected_tenant_id');
|
|
|
|
$newValue = $this->rolePermissionService->togglePermission(
|
|
$roleId,
|
|
$menuId,
|
|
$permissionType,
|
|
$tenantId
|
|
);
|
|
|
|
// 전체 매트릭스 다시 로드
|
|
$menus = $this->rolePermissionService->getMenuTree($tenantId);
|
|
$permissions = $this->rolePermissionService->getRolePermissionMatrix($roleId, $tenantId);
|
|
|
|
return view('role-permissions.partials.permission-matrix', [
|
|
'menus' => $menus,
|
|
'permissions' => $permissions,
|
|
'roleId' => $roleId,
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* 전체 허용
|
|
*/
|
|
public function allowAll(Request $request)
|
|
{
|
|
$roleId = $request->input('role_id');
|
|
$tenantId = session('selected_tenant_id');
|
|
|
|
$this->rolePermissionService->allowAllPermissions($roleId, $tenantId);
|
|
|
|
// 전체 매트릭스 다시 로드
|
|
$menus = $this->rolePermissionService->getMenuTree($tenantId);
|
|
$permissions = $this->rolePermissionService->getRolePermissionMatrix($roleId, $tenantId);
|
|
|
|
return view('role-permissions.partials.permission-matrix', [
|
|
'menus' => $menus,
|
|
'permissions' => $permissions,
|
|
'roleId' => $roleId,
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* 전체 거부
|
|
*/
|
|
public function denyAll(Request $request)
|
|
{
|
|
$roleId = $request->input('role_id');
|
|
$tenantId = session('selected_tenant_id');
|
|
|
|
$this->rolePermissionService->denyAllPermissions($roleId, $tenantId);
|
|
|
|
// 전체 매트릭스 다시 로드
|
|
$menus = $this->rolePermissionService->getMenuTree($tenantId);
|
|
$permissions = $this->rolePermissionService->getRolePermissionMatrix($roleId, $tenantId);
|
|
|
|
return view('role-permissions.partials.permission-matrix', [
|
|
'menus' => $menus,
|
|
'permissions' => $permissions,
|
|
'roleId' => $roleId,
|
|
]);
|
|
}
|
|
}
|