Files
sam-manage/app/Http/Controllers/HR/EmployeeController.php
김보곤 5f81e5f356 feat: [hr] 사원관리 영업팀 제외 및 강제 제외 기능 추가
- 영업팀 포함 부서 사원 기본 제외 (외부직원)
- json_extra.is_excluded 플래그로 강제 제외/복원 토글
- 필터에 '제외 사원 표시' 체크박스 추가
- 제외 사원 시각적 구분 (주황 배경, 제외 뱃지)
2026-03-05 15:16:15 +09:00

102 lines
2.8 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
{
public function __construct(
private EmployeeService $employeeService
) {}
/**
* 사원 목록 페이지
*/
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();
return view('hr.employees.show', [
'employee' => $employee,
'files' => $files,
]);
}
/**
* 사원 수정 폼
*/
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();
return view('hr.employees.edit', [
'employee' => $employee,
'departments' => $departments,
'ranks' => $ranks,
'titles' => $titles,
'banks' => config('banks', []),
'files' => $files,
]);
}
}