Kimi chinh sua
This commit is contained in:
@@ -15,11 +15,17 @@ class Contract extends Model
|
||||
|
||||
protected $casts = [
|
||||
'metadata' => 'array',
|
||||
'discount_details' => 'array',
|
||||
'total_value' => 'decimal:2',
|
||||
'land_value' => 'decimal:2',
|
||||
'foundation_value' => 'decimal:2',
|
||||
'total_value_with_foundation' => 'decimal:2',
|
||||
'paid_amount' => 'decimal:2',
|
||||
'remaining_amount' => 'decimal:2',
|
||||
'excess_amount' => 'decimal:2',
|
||||
'signing_date' => 'date',
|
||||
'sale_date' => 'date',
|
||||
'hql_confirmation_date' => 'date',
|
||||
];
|
||||
|
||||
public function product()
|
||||
@@ -45,18 +51,15 @@ class Contract extends Model
|
||||
return $this->hasOne(PaymentSchedule::class);
|
||||
}
|
||||
|
||||
/**
|
||||
* Lấy trực tiếp các đợt thanh toán của hợp đồng này
|
||||
*/
|
||||
public function scheduleItems(): HasManyThrough
|
||||
{
|
||||
return $this->hasManyThrough(
|
||||
PaymentScheduleItem::class,
|
||||
PaymentSchedule::class,
|
||||
'contract_id', // Khóa ngoại trên bảng PaymentSchedule
|
||||
'schedule_id', // Khóa ngoại trên bảng PaymentScheduleItem
|
||||
'id', // Khóa chính trên bảng Contract
|
||||
'id' // Khóa chính trên bảng PaymentSchedule
|
||||
'contract_id',
|
||||
'schedule_id',
|
||||
'id',
|
||||
'id'
|
||||
);
|
||||
}
|
||||
|
||||
@@ -72,17 +75,22 @@ class Contract extends Model
|
||||
|
||||
protected static function booted()
|
||||
{
|
||||
static::creating(function ($contract) {
|
||||
// Tự động lấy giá trị từ sản phẩm nếu chưa có
|
||||
if (empty($contract->total_value) && !empty($contract->product_id)) {
|
||||
static::saving(function ($contract) {
|
||||
// Bảo vệ tính toán tài chính: total_value luôn bằng land_value + foundation_value
|
||||
$landValue = (float) ($contract->land_value ?? 0);
|
||||
$foundationValue = (float) ($contract->foundation_value ?? 0);
|
||||
|
||||
if ($landValue > 0 || $foundationValue > 0) {
|
||||
$contract->total_value = $landValue + $foundationValue;
|
||||
} elseif ($contract->exists === false && empty($contract->total_value) && !empty($contract->product_id)) {
|
||||
// Fallback khi tạo mới và chưa có giá trị tài chính chi tiết
|
||||
$product = Product::find($contract->product_id);
|
||||
if ($product) {
|
||||
$contract->total_value = $product->total_price;
|
||||
}
|
||||
}
|
||||
|
||||
// Tính toán số tiền còn lại
|
||||
$contract->remaining_amount = ($contract->total_value ?? 0) - ($contract->paid_amount ?? 0);
|
||||
$contract->remaining_amount = (float) ($contract->total_value ?? 0) - (float) ($contract->paid_amount ?? 0);
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user