Files
sam-manage/app/Http/Controllers/HR/EmployeeController.php
김보곤 eab39e0b29 feat: [hr] 사원관리 연봉정보 탭 생성
- 사원 상세/수정 페이지에 연봉정보 입력 섹션 추가
- 특수 권한 사용자만 열람/수정 가능한 접근 제어 적용
- 연봉 변경 시 자동 이력 기록
- 일반 API 응답에서 연봉 데이터 노출 방지 (toArray 오버라이드)
2026-03-11 16:27:49 +09:00

117 lines
3.3 KiB
PHP

<?php
namespace App\Http\Controllers\HR;
use App\Http\Controllers\Controller;
use App\Models\Boards\File;
use App\Services\HR\EmployeeService;
use Illuminate\Contracts\View\View;
class EmployeeController extends Controller
{
private const ALLOWED_SALARY_USERS = ['이의찬', '전진선', '김보곤'];
public function __construct(
private EmployeeService $employeeService
) {}
private function canViewSalary(): bool
{
return in_array(auth()->user()->name, self::ALLOWED_SALARY_USERS);
}
/**
* 사원 목록 페이지
*/
public function index(): View
{
$showExcluded = request()->boolean('show_excluded');
$stats = $this->employeeService->getStats($showExcluded);
$departments = $this->employeeService->getDepartments();
return view('hr.employees.index', [
'stats' => $stats,
'departments' => $departments,
]);
}
/**
* 사원 등록 폼
*/
public function create(): View
{
$departments = $this->employeeService->getDepartments();
$ranks = $this->employeeService->getPositions('rank');
$titles = $this->employeeService->getPositions('title');
return view('hr.employees.create', [
'departments' => $departments,
'ranks' => $ranks,
'titles' => $titles,
'banks' => config('banks', []),
]);
}
/**
* 사원 상세 페이지
*/
public function show(int $id): View
{
$employee = $this->employeeService->getEmployeeById($id);
if (! $employee) {
abort(404, '사원 정보를 찾을 수 없습니다.');
}
$files = File::where('document_type', 'employee_profile')
->where('document_id', $employee->id)
->where('tenant_id', session('selected_tenant_id'))
->orderBy('created_at', 'desc')
->get();
$canViewSalary = $this->canViewSalary();
return view('hr.employees.show', [
'employee' => $employee,
'files' => $files,
'canViewSalary' => $canViewSalary,
'salaryInfo' => $canViewSalary ? $employee->getSalaryInfo() : null,
]);
}
/**
* 사원 수정 폼
*/
public function edit(int $id): View
{
$employee = $this->employeeService->getEmployeeById($id);
if (! $employee) {
abort(404, '사원 정보를 찾을 수 없습니다.');
}
$departments = $this->employeeService->getDepartments();
$ranks = $this->employeeService->getPositions('rank');
$titles = $this->employeeService->getPositions('title');
$files = File::where('document_type', 'employee_profile')
->where('document_id', $employee->id)
->where('tenant_id', session('selected_tenant_id'))
->orderBy('created_at', 'desc')
->get();
$canViewSalary = $this->canViewSalary();
return view('hr.employees.edit', [
'employee' => $employee,
'departments' => $departments,
'ranks' => $ranks,
'titles' => $titles,
'banks' => config('banks', []),
'files' => $files,
'canViewSalary' => $canViewSalary,
'salaryInfo' => $canViewSalary ? $employee->getSalaryInfo() : null,
]);
}
}