feat: add mechnic-auto-model
This commit is contained in:
@@ -1,4 +1,5 @@
|
||||
from .auto import * # noqa
|
||||
from .mechanic_auto import * # noqa
|
||||
from .customer import * # noqa
|
||||
from .document import * # noqa
|
||||
from .documentcategory import * # noqa
|
||||
|
||||
@@ -69,6 +69,66 @@ class AutoevaluationhistoryModel(models.Model):
|
||||
]
|
||||
|
||||
|
||||
class MechanicAutoevaluationhistoryModel(models.Model):
|
||||
"""MechanicAutoEvaluation bo'yicha barcha harakatlar logi — faqat o'qiladi, signallar tomonidan yoziladi."""
|
||||
|
||||
mechanic_auto_evaluation = models.ForeignKey(
|
||||
"evaluation.MechanicAutoEvaluationModel",
|
||||
on_delete=models.CASCADE,
|
||||
related_name="history",
|
||||
verbose_name=_("mechanic auto evaluation"),
|
||||
)
|
||||
event_type = models.CharField(
|
||||
verbose_name=_("event type"),
|
||||
max_length=50,
|
||||
choices=EvaluationEventType.choices,
|
||||
)
|
||||
|
||||
actor_id = models.BigIntegerField(
|
||||
verbose_name=_("actor id"),
|
||||
null=True,
|
||||
blank=True,
|
||||
)
|
||||
actor_full_name = models.CharField(
|
||||
verbose_name=_("actor full name"),
|
||||
max_length=255,
|
||||
default="Tizim",
|
||||
)
|
||||
actor_role = models.CharField(
|
||||
verbose_name=_("actor role"),
|
||||
max_length=50,
|
||||
default="system",
|
||||
)
|
||||
|
||||
meta = models.JSONField(
|
||||
verbose_name=_("meta"),
|
||||
default=dict,
|
||||
blank=True,
|
||||
)
|
||||
|
||||
created_at = models.DateTimeField(
|
||||
verbose_name=_("created at"),
|
||||
auto_now_add=True,
|
||||
)
|
||||
|
||||
def __str__(self):
|
||||
return f"{self.get_event_type_display()} — MechanicAutoEval #{self.mechanic_auto_evaluation_id}"
|
||||
|
||||
@classmethod
|
||||
def _baker(cls):
|
||||
return baker.make(cls)
|
||||
|
||||
class Meta:
|
||||
db_table = "MechanicAutoEvaluationHistory"
|
||||
verbose_name = _("Mechanic Auto Evaluation History")
|
||||
verbose_name_plural = _("Mechanic Auto Evaluation Histories")
|
||||
ordering = ["created_at"]
|
||||
indexes = [
|
||||
models.Index(fields=["mechanic_auto_evaluation_id", "created_at"], name="mech_auto_hist_eval_date_idx"),
|
||||
models.Index(fields=["event_type"], name="mech_auto_hist_event_type_idx"),
|
||||
]
|
||||
|
||||
|
||||
class QuickevaluationhistoryModel(models.Model):
|
||||
"""QuickEvaluation bo'yicha barcha harakatlar logi — faqat o'qiladi, signallar tomonidan yoziladi."""
|
||||
|
||||
|
||||
250
core/apps/evaluation/models/mechanic_auto.py
Normal file
250
core/apps/evaluation/models/mechanic_auto.py
Normal file
@@ -0,0 +1,250 @@
|
||||
from django.db import models
|
||||
from django.utils.translation import gettext_lazy as _
|
||||
from django_core.models import AbstractBaseModel
|
||||
from model_bakery import baker
|
||||
|
||||
from core.apps.evaluation.choices.auto import (
|
||||
AutoCarType,
|
||||
AutoCarWheel,
|
||||
AutoEvaluationStatus,
|
||||
AutoObjectType,
|
||||
ObjectOwnerType,
|
||||
)
|
||||
from .valuation import ValuationModel
|
||||
from .vehicle import VehicleModel
|
||||
|
||||
|
||||
class MechanicAutoEvaluationModel(AbstractBaseModel):
|
||||
user = models.ForeignKey(
|
||||
"accounts.User",
|
||||
on_delete=models.SET_NULL,
|
||||
related_name="mechanic_auto_evaluations_user",
|
||||
null=True,
|
||||
blank=True,
|
||||
)
|
||||
evaluation_request = models.ForeignKey(
|
||||
"evaluation.EvaluationRequestModel",
|
||||
on_delete=models.SET_NULL,
|
||||
related_name="mechanic_auto_evaluations_request",
|
||||
null=True,
|
||||
blank=True,
|
||||
)
|
||||
valuation = models.OneToOneField(
|
||||
ValuationModel,
|
||||
on_delete=models.CASCADE,
|
||||
related_name="mechanic_auto_detail",
|
||||
null=True,
|
||||
blank=True,
|
||||
)
|
||||
vehicle = models.OneToOneField(
|
||||
VehicleModel,
|
||||
on_delete=models.CASCADE,
|
||||
related_name="mechanic_evaluation",
|
||||
null=True,
|
||||
blank=True,
|
||||
)
|
||||
appraisers = models.ManyToManyField(
|
||||
"accounts.User",
|
||||
verbose_name=_("appraisers"),
|
||||
related_name="mechanic_auto_evaluation_appraisers",
|
||||
blank=True,
|
||||
)
|
||||
|
||||
tex_passport_file = models.FileField(
|
||||
verbose_name=_("tech passport file"),
|
||||
upload_to="mechanic_evaluation/tech_passports/%Y/%m/",
|
||||
blank=True,
|
||||
null=True,
|
||||
)
|
||||
|
||||
# ── Step 1 — Umumiy ma'lumotlar ──────────────────────────────────
|
||||
registration_number = models.CharField(
|
||||
verbose_name=_("registration number"),
|
||||
max_length=50,
|
||||
blank=True,
|
||||
null=True,
|
||||
)
|
||||
contract_date = models.DateField(
|
||||
verbose_name=_("contract date"),
|
||||
blank=True,
|
||||
null=True,
|
||||
)
|
||||
object_inspection_date = models.DateField(
|
||||
verbose_name=_("object inspection date"),
|
||||
blank=True,
|
||||
null=True,
|
||||
)
|
||||
rate_date = models.DateField(
|
||||
verbose_name=_("rate date"),
|
||||
blank=True,
|
||||
null=True,
|
||||
)
|
||||
rate_report_date = models.DateField(
|
||||
verbose_name=_("rate report date"),
|
||||
blank=True,
|
||||
null=True,
|
||||
)
|
||||
object_type = models.CharField(
|
||||
verbose_name=_("object type"),
|
||||
max_length=50,
|
||||
choices=AutoObjectType.choices,
|
||||
blank=True,
|
||||
null=True,
|
||||
)
|
||||
|
||||
# ── Step 2 — Shaxs ma'lumotlari ─────────────────────────────────
|
||||
object_owner_type = models.IntegerField(
|
||||
verbose_name=_("object owner type"),
|
||||
choices=ObjectOwnerType.choices,
|
||||
blank=True,
|
||||
null=True,
|
||||
)
|
||||
object_owner_individual_person_f_name = models.CharField(
|
||||
verbose_name=_("owner first name"),
|
||||
max_length=100,
|
||||
blank=True,
|
||||
null=True,
|
||||
)
|
||||
object_owner_individual_person_l_name = models.CharField(
|
||||
verbose_name=_("owner last name"),
|
||||
max_length=100,
|
||||
blank=True,
|
||||
null=True,
|
||||
)
|
||||
object_owner_individual_person_p_name = models.CharField(
|
||||
verbose_name=_("owner patronymic"),
|
||||
max_length=100,
|
||||
blank=True,
|
||||
null=True,
|
||||
)
|
||||
object_owner_individual_person_passport_num = models.CharField(
|
||||
verbose_name=_("owner passport number"),
|
||||
max_length=20,
|
||||
blank=True,
|
||||
null=True,
|
||||
)
|
||||
object_owner_legal_entity = models.CharField(
|
||||
verbose_name=_("legal entity name"),
|
||||
max_length=255,
|
||||
blank=True,
|
||||
null=True,
|
||||
)
|
||||
object_owner_legal_inn = models.CharField(
|
||||
verbose_name=_("legal entity INN"),
|
||||
max_length=20,
|
||||
blank=True,
|
||||
null=True,
|
||||
)
|
||||
value_determined = models.ForeignKey(
|
||||
'evaluation.ReferenceitemModel',
|
||||
verbose_name=_("value determined"),
|
||||
blank=True,
|
||||
null=True,
|
||||
on_delete=models.SET_NULL,
|
||||
related_name='evaluation_mechanic_auto_value_determined'
|
||||
)
|
||||
rate_type = models.ForeignKey(
|
||||
'evaluation.ReferenceitemModel',
|
||||
verbose_name=_("rate type"),
|
||||
blank=True,
|
||||
null=True,
|
||||
on_delete=models.SET_NULL,
|
||||
related_name='evaluation_mechanic_auto_rate_type'
|
||||
)
|
||||
|
||||
# ── Step 4 — Avtomobil ma'lumotlari ─────────────────────────────
|
||||
tex_passport_serie_num = models.CharField(
|
||||
verbose_name=_("tech passport series and number"),
|
||||
max_length=20,
|
||||
blank=True,
|
||||
null=True,
|
||||
)
|
||||
tex_passport_gived_date = models.DateField(
|
||||
verbose_name=_("tech passport given date"),
|
||||
blank=True,
|
||||
null=True,
|
||||
)
|
||||
tex_passport_gived_location = models.CharField(
|
||||
verbose_name=_("tech passport given location"),
|
||||
max_length=255,
|
||||
blank=True,
|
||||
null=True,
|
||||
)
|
||||
car_type = models.IntegerField(
|
||||
verbose_name=_("car type"),
|
||||
choices=AutoCarType.choices,
|
||||
blank=True,
|
||||
null=True,
|
||||
)
|
||||
car_wheel = models.IntegerField(
|
||||
verbose_name=_("car wheel"),
|
||||
choices=AutoCarWheel.choices,
|
||||
blank=True,
|
||||
null=True,
|
||||
)
|
||||
car_brand = models.CharField(
|
||||
verbose_name=_("car brand"),
|
||||
max_length=100,
|
||||
blank=True,
|
||||
null=True,
|
||||
)
|
||||
car_model = models.CharField(
|
||||
verbose_name=_("car model"),
|
||||
max_length=100,
|
||||
blank=True,
|
||||
null=True,
|
||||
)
|
||||
car_number = models.CharField(
|
||||
verbose_name=_("car number"),
|
||||
max_length=20,
|
||||
blank=True,
|
||||
null=True,
|
||||
)
|
||||
manufacture_year = models.CharField(
|
||||
verbose_name=_("manufacture year"),
|
||||
max_length=10,
|
||||
blank=True,
|
||||
null=True,
|
||||
)
|
||||
car_dvigatel_number = models.CharField(
|
||||
verbose_name=_("engine number"),
|
||||
max_length=50,
|
||||
blank=True,
|
||||
null=True,
|
||||
)
|
||||
car_color = models.CharField(
|
||||
verbose_name=_("car color"),
|
||||
max_length=50,
|
||||
blank=True,
|
||||
null=True,
|
||||
)
|
||||
|
||||
# ── Natija ───────────────────────────────────────────────────────
|
||||
rating_goal = models.CharField(
|
||||
verbose_name=_("rating goal"),
|
||||
max_length=50,
|
||||
blank=True,
|
||||
null=True,
|
||||
)
|
||||
status = models.CharField(
|
||||
verbose_name=_("status"),
|
||||
max_length=50,
|
||||
choices=AutoEvaluationStatus.choices,
|
||||
default=AutoEvaluationStatus.CREATED,
|
||||
)
|
||||
is_archived = models.BooleanField(
|
||||
verbose_name=_("is archived"),
|
||||
default=False,
|
||||
)
|
||||
|
||||
def __str__(self):
|
||||
return f"Mechanic Auto Evaluation {self.registration_number or self.pk}"
|
||||
|
||||
@classmethod
|
||||
def _baker(cls):
|
||||
return baker.make(cls)
|
||||
|
||||
class Meta:
|
||||
db_table = "MechanicAutoEvaluation"
|
||||
verbose_name = _("Mechanic Auto Evaluation")
|
||||
verbose_name_plural = _("Mechanic Auto Evaluations")
|
||||
Reference in New Issue
Block a user