- 사원 상세/수정 페이지에 연봉정보 입력 섹션 추가 - 특수 권한 사용자만 열람/수정 가능한 접근 제어 적용 - 연봉 변경 시 자동 이력 기록 - 일반 API 응답에서 연봉 데이터 노출 방지 (toArray 오버라이드)
117 lines
3.3 KiB
PHP
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,
|
|
]);
|
|
}
|
|
}
|