fix: 프로젝트 전체 TypeScript 타입에러 408개 수정 (tsc --noEmit 0 errors)

- 공통 템플릿 타입 수정 (IntegratedDetailTemplate, UniversalListPage)
- 페이지(app/[locale]) 타입 호환성 수정 (80개)
- 재고/자재 모듈 타입 수정 (StockStatus, ReceivingManagement)
- 생산 모듈 타입 수정 (WorkOrders, WorkerScreen, WorkResults)
- 주문/출고 모듈 타입 수정 (ShipmentManagement, Orders)
- 견적/단가 모듈 타입 수정 (Quotes, Pricing)
- 건설 모듈 타입 수정 (49개, 17개 하위 모듈)
- HR 모듈 타입 수정 (CardManagement, VacationManagement 등)
- 설정 모듈 타입 수정 (PermissionManagement, AccountManagement 등)
- 게시판 모듈 타입 수정 (BoardManagement, BoardList 등)
- 회계 모듈 타입 수정 (VendorManagement, BadDebtCollection 등)
- 기타 모듈 타입 수정 (CEODashboard, clients, vehicle 등)
- 유틸/훅/API 타입 수정 (hooks, contexts, lib)

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
This commit is contained in:
유병철
2026-01-30 10:07:58 +09:00
parent 8a5cbde5ef
commit a1f4c82cec
154 changed files with 832 additions and 536 deletions

View File

@@ -417,10 +417,11 @@ export function BoardForm({ mode, initialData }: BoardFormProps) {
config={config}
mode={mode}
isLoading={isBoardsLoading}
isSubmitting={isSubmitting}
onBack={handleCancel}
onCancel={handleCancel}
onSubmit={handleSubmit}
onSubmit={async (_data: Record<string, unknown>) => {
await handleSubmit();
return { success: true };
}}
renderForm={renderFormContent}
/>
);

View File

@@ -261,7 +261,7 @@ export function BoardList() {
<TableRow
key={item.id}
className="hover:bg-muted/50 cursor-pointer"
onClick={onRowClick}
onClick={() => onRowClick?.()}
>
<TableCell className="text-center" onClick={(e) => e.stopPropagation()}>
<Checkbox checked={isSelected} onCheckedChange={onToggle} />
@@ -337,7 +337,7 @@ export function BoardList() {
}
isSelected={isSelected}
onToggleSelection={onToggle}
onCardClick={onRowClick}
onCardClick={onRowClick ? () => onRowClick() : undefined}
infoGrid={
<div className="grid grid-cols-2 gap-3">
<InfoField label="작성자" value={item.authorName} />

View File

@@ -143,7 +143,7 @@ const createBoardManagementConfig = (router: ReturnType<typeof useRouter>): Univ
<TableRow
key={item.id}
className="hover:bg-muted/50 cursor-pointer"
onClick={onRowClick}
onClick={() => onRowClick?.()}
>
<TableCell className="text-center" onClick={(e) => e.stopPropagation()}>
<Checkbox checked={isSelected} onCheckedChange={onToggle} />
@@ -163,10 +163,10 @@ const createBoardManagementConfig = (router: ReturnType<typeof useRouter>): Univ
<TableCell className="text-right" onClick={(e) => e.stopPropagation()}>
{isSelected && (
<div className="flex items-center justify-end gap-1">
<Button variant="ghost" size="sm" onClick={onEdit} title="수정">
<Button variant="ghost" size="sm" onClick={() => onEdit?.()} title="수정">
<Edit className="w-4 h-4" />
</Button>
<Button variant="ghost" size="sm" onClick={onDelete} title="삭제">
<Button variant="ghost" size="sm" onClick={() => onDelete?.()} title="삭제">
<Trash2 className="w-4 h-4 text-red-500" />
</Button>
</div>
@@ -201,7 +201,7 @@ const createBoardManagementConfig = (router: ReturnType<typeof useRouter>): Univ
}
isSelected={isSelected}
onToggleSelection={onToggle}
onCardClick={onRowClick}
onCardClick={onRowClick ? () => onRowClick() : undefined}
infoGrid={
<div className="grid grid-cols-2 gap-x-4 gap-y-3">
<InfoField label="대상" value={getTargetDisplay(item)} />
@@ -218,7 +218,7 @@ const createBoardManagementConfig = (router: ReturnType<typeof useRouter>): Univ
className="flex-1 min-w-[100px] h-11"
onClick={(e) => {
e.stopPropagation();
onEdit();
onEdit?.();
}}
>
<Edit className="h-4 w-4 mr-2" />
@@ -230,7 +230,7 @@ const createBoardManagementConfig = (router: ReturnType<typeof useRouter>): Univ
className="flex-1 min-w-[100px] h-11 border-red-200 text-red-600 hover:border-red-300 bg-transparent"
onClick={(e) => {
e.stopPropagation();
onDelete();
onDelete?.();
}}
>
<Trash2 className="h-4 w-4 mr-2" />