Files
sam-docs/features/card-vehicle/corporate-cards.md
김보곤 a23e2560ac docs:카드/차량관리 개발문서 추가 (5개 메뉴)
- 법인카드관리: 카드 CRUD, 결제일 휴일조정, 사용금액 집계, 선불결제
- 카드사용내역: 바로빌 SOAP 연동, 분개, 거래숨김, 금액수정
- 차량목록: 법인/렌트/리스 차량 등록, 주행거리 자동계산
- 차량일지: 운행기록, 용도별 통계, 출발↔도착 교환
- 정비이력: 카테고리별 비용 관리, 주행거리 자동갱신

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-02-11 16:31:25 +09:00

223 lines
7.8 KiB
Markdown

# 법인카드관리
## 개요
법인카드관리는 회사의 법인카드(신용/체크)를 등록하고 관리하는 기능입니다.
카드 CRUD, 결제일 휴일 조정, 바로빌 기반 사용금액 집계, 선불결제 관리 등을 지원합니다.
- **라우트**: `GET /finance/corporate-cards`
- **라우트 이름**: `finance.corporate-cards`
- **UI 기술**: React 18 + Babel (브라우저 트랜스파일링)
## 파일 구조
```
mng/
├── app/Http/Controllers/Finance/
│ └── CorporateCardController.php # 메인 컨트롤러 (7개 메서드)
├── app/Models/Finance/
│ ├── CorporateCard.php # 법인카드 모델
│ └── CorporateCardPrepayment.php # 선불결제 모델
├── app/Models/Barobill/
│ ├── CardTransaction.php # 바로빌 카드거래 모델
│ └── CardTransactionHide.php # 거래 숨김 모델
├── app/Models/System/
│ └── Holiday.php # 휴일 모델
└── resources/views/finance/
└── corporate-cards.blade.php # React 기반 단일 페이지
api/
└── database/migrations/
├── 2026_01_30_180000_create_corporate_cards_table.php
└── 2026_02_11_100000_create_corporate_card_prepayments_table.php
```
## 라우트
```php
// routes/web.php (finance prefix 그룹 내)
Route::get('/corporate-cards', fn() => ...)->name('corporate-cards');
// API 라우트 (corporate-cards prefix)
GET /list index() 카드 목록 조회
GET /summary summary() 요약 데이터 (결제일, 사용금액 )
POST /prepayment updatePrepayment() 선불결제 수정
POST /store store() 카드 등록
PUT /{id} update() 카드 수정
POST /{id}/deactivate deactivate() 카드 비활성화
DELETE /{id} destroy() 카드 영구삭제
```
## 컨트롤러
### CorporateCardController
| 메서드 | HTTP | 설명 |
|--------|------|------|
| `index()` | GET | 카드 목록 JSON 반환 |
| `store()` | POST | 카드 등록 |
| `update()` | PUT | 카드 수정 |
| `deactivate()` | POST | 비활성화 (status → inactive) |
| `destroy()` | DELETE | 영구삭제 (forceDelete) |
| `summary()` | GET | **요약 데이터** (결제일, 사용금액, 선불결제) |
| `updatePrepayment()` | POST | 선불결제 금액 수정 (upsert) |
### summary() 응답 구조
```json
{
"success": true,
"data": {
"paymentDate": "2026-02-19",
"paymentDay": 15,
"originalDate": "2026-02-15",
"isAdjusted": true,
"billingPeriod": { "start": "2026-01-01", "end": "2026-02-19" },
"billingUsage": 3500000,
"cardUsages": { "9438830936384247": 1200000, "1234567890123456": 2300000 },
"prepaidAmount": 500000,
"prepaidMemo": "2월 선결제"
}
}
```
## 핵심 로직
### 휴일 조정 결제일 계산 (getAdjustedPaymentDate)
```
당월 payment_day (예: 15일)
Carbon 날짜 생성
holidays 테이블에서 해당 기간 휴일 조회
토/일/공휴일이면 다음 날로 반복 이동
영업일 결제일 반환 (예: 15일→토→17일(월))
```
### 사용금액 계산 (calculateBillingUsage)
```
청구기간: 전월 1일 ~ 당월 결제일(휴일조정)
corporate_cards에서 활성 카드번호 수집
카드번호 정규화 (하이픈 제거)
barobill_card_transactions 조회 (use_date 범위)
숨긴 거래 제외 (barobill_card_transaction_hides)
approval_type별 합산:
- '1' (승인): + approval_amount
- '2' (취소): - approval_amount
총 사용금액 반환
```
### 잔여 한도 계산
```
잔여 한도 = 총 한도 - 사용금액 + 선불결제
```
## 모델
### CorporateCard
**테이블**: `corporate_cards`
| 필드 | 타입 | 설명 |
|------|------|------|
| `tenant_id` | bigint | 테넌트 ID |
| `card_name` | string(100) | 카드명 (예: "업무용 법인카드") |
| `card_company` | string(50) | 카드사 (삼성, 현대 등) |
| `card_number` | string(30) | 카드번호 (하이픈 포함) |
| `card_type` | enum | credit / debit |
| `payment_day` | tinyint | 결제일 (기본: 15) |
| `credit_limit` | decimal(15,2) | 사용한도 |
| `current_usage` | decimal(15,2) | 현재 사용액 |
| `card_holder_name` | string(100) | 이용자명 (법인 명의) |
| `actual_user` | string(100) | 실사용자 |
| `expiry_date` | string(10) | 유효기간 (YY/MM) |
| `cvc` | string(10) | CVC |
| `status` | enum | active / inactive |
| `memo` | text | 메모 |
#### 주요 Scope
```php
->active() // status = 'active'
->forTenant($id) // tenant_id 필터
```
### CorporateCardPrepayment
**테이블**: `corporate_card_prepayments`
| 필드 | 타입 | 설명 |
|------|------|------|
| `tenant_id` | bigint | 테넌트 ID |
| `year_month` | string(7) | "2026-02" 형식 |
| `amount` | decimal(15,0) | 선불결제 금액 |
| `memo` | string(200) | 메모 |
- Unique: `[tenant_id, year_month]`
- `getOrCreate(tenantId, yearMonth)`: 조회 또는 기본값(0) 생성
## 뷰 구성 (React)
### corporate-cards.blade.php
```
┌─ 페이지 헤더 ──────────────────────
│ 제목: "법인카드 등록/조회"
│ 버튼: "카드 등록" (보라색)
├─ 요약 카드 (2열 / lg:6열) ─────────
│ ┌──────┐ ┌──────┐ ┌──────┐ ┌──────┐ ┌──────┐ ┌──────┐
│ │등록카드│ │총 한도│ │매월 │ │사용 │ │선불 │ │잔여 │
│ │ │ │ │ │결제일 │ │금액 │ │결제 │ │한도 │
│ │3장 │ │50백만│ │2/19 │ │35백만│ │5백만 │ │20백만│
│ │활성2 │ │신용 │ │(수) │ │1/1~ │ │[수정]│ │한도- │
│ │ │ │기준 │ │15→조정│ │2/19 │ │ │ │사용+ │
│ │ │ │ │ │ │ │기준 │ │ │ │선결제│
│ └──────┘ └──────┘ └──────┘ └──────┘ └──────┘ └──────┘
├─ 검색 및 필터 ─────────────────────
│ 검색창 | 전체 | 활성 | 비활성
├─ 카드 목록 테이블 ─────────────────
│ 카드명(카드사) | 카드번호 | 실사용자 | 사용현황(진행바) | 상태
│ └─ 신용: 사용률 % + 프로그레스 바
│ └─ 체크: 사용금액 표시
├─ 등록/수정 모달 ───────────────────
│ 카드명, 카드사, 카드종류, 카드번호, 이용자명
│ 유효기간, CVC, 상태, 실사용자
│ 결제일(신용만), 사용한도(신용만), 메모
│ [비활성화] [영구삭제] [취소] [등록/저장]
└─ 선불결제 수정 모달 ───────────────
금액 입력 (3자리 콤마), 메모 (선택)
[취소] [저장]
```
### React 주요 기능
| 기능 | 설명 |
|------|------|
| 요약 카드 6개 | 등록카드, 총한도, 매월결제일, 사용금액, 선불결제, 잔여한도 |
| 카드별 사용률 | billingUsage 기준 프로그레스 바 표시 |
| 선불결제 인라인 수정 | 수정 버튼 → 모달 → 금액/메모 입력 → 즉시 반영 |
| 상태 필터 | 전체 / 활성 / 비활성 |
| 카드 검색 | 카드명, 카드사, 이용자명, 실사용자 검색 |
## HTMX 호환성
- React 기반 페이지이므로 **HX-Redirect 필요**
- `@push('scripts')` 블록에 React/Babel 스크립트 포함
- HTMX 네비게이션 시 전체 페이지 리로드 필수