- 마이그레이션 생성: quotes, quote_items, quote_revisions 테이블 - Model 생성: Quote, QuoteItem, QuoteRevision - BelongsToTenant, SoftDeletes 트레이트 적용 - 상태 관리 메서드 및 스코프 구현 - 개발 계획서 작성 및 진행 상황 문서화
76 lines
1.6 KiB
PHP
76 lines
1.6 KiB
PHP
<?php
|
||
|
||
namespace App\Models\Quote;
|
||
|
||
use App\Traits\BelongsToTenant;
|
||
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
||
use Illuminate\Database\Eloquent\Model;
|
||
use Illuminate\Database\Eloquent\Relations\BelongsTo;
|
||
|
||
class QuoteItem extends Model
|
||
{
|
||
use BelongsToTenant, HasFactory;
|
||
|
||
protected $fillable = [
|
||
'quote_id',
|
||
'tenant_id',
|
||
// 품목 정보
|
||
'item_id',
|
||
'item_code',
|
||
'item_name',
|
||
'specification',
|
||
'unit',
|
||
// 수량/금액
|
||
'base_quantity',
|
||
'calculated_quantity',
|
||
'unit_price',
|
||
'total_price',
|
||
// 수식 정보
|
||
'formula',
|
||
'formula_result',
|
||
'formula_source',
|
||
'formula_category',
|
||
'data_source',
|
||
// 기타
|
||
'delivery_date',
|
||
'note',
|
||
'sort_order',
|
||
];
|
||
|
||
protected $casts = [
|
||
'base_quantity' => 'decimal:4',
|
||
'calculated_quantity' => 'decimal:4',
|
||
'unit_price' => 'decimal:2',
|
||
'total_price' => 'decimal:2',
|
||
'delivery_date' => 'date',
|
||
'created_at' => 'datetime',
|
||
'updated_at' => 'datetime',
|
||
];
|
||
|
||
/**
|
||
* 견적 마스터
|
||
*/
|
||
public function quote(): BelongsTo
|
||
{
|
||
return $this->belongsTo(Quote::class);
|
||
}
|
||
|
||
/**
|
||
* 금액 계산 (수량 × 단가)
|
||
*/
|
||
public function calculateTotalPrice(): float
|
||
{
|
||
return round($this->calculated_quantity * $this->unit_price, 2);
|
||
}
|
||
|
||
/**
|
||
* 금액 업데이트 후 저장
|
||
*/
|
||
public function updateTotalPrice(): self
|
||
{
|
||
$this->total_price = $this->calculateTotalPrice();
|
||
|
||
return $this;
|
||
}
|
||
}
|