orders.py 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
  1. from .template import Template
  2. class Orders(models.Model):
  3. """
  4. Orders - таблица с заказами
  5. """
  6. id = models.IntegerField(
  7. primary_key=True
  8. )
  9. # ID METASERVICE
  10. id_metaservice = models.PositiveIntegerField(
  11. null=True,
  12. help_text="уникальный идентификатор мета-сервиса, необходимый для синхронизации данных. Если при синхронизации возникает конфликт (несовместимость) с другим сервисом, предлагается или форсировать изменения везде (если возможно), либо is_global выставляется как false."
  13. )
  14. # DATA
  15. status = models.CharField(
  16. max_length=150,
  17. help_text="текущий статус заказа из возможных на платформе"
  18. )
  19. title = models.CharField(
  20. max_length=150,
  21. help_text="заголовок заказа",
  22. default='Заголовок'
  23. )
  24. note = models.CharField(
  25. max_length=150,
  26. help_text="задание к заказу",
  27. default='Записи'
  28. )
  29. time_created = models.DateTimeField(
  30. auto_now_add=True,
  31. help_text="время создания заказа"
  32. )
  33. time_placed = models.DateTimeField(
  34. help_text="время размещения заказа"
  35. )
  36. time_start = models.DateTimeField(
  37. null=True,
  38. help_text="время начала оказания услуги"
  39. )
  40. time_start_real = models.DateTimeField(
  41. null=True,
  42. help_text=""
  43. )
  44. time_start_predicted = models.DateTimeField(
  45. null=True,
  46. help_text=""
  47. )
  48. time_finish_real = models.DateTimeField(
  49. null=True,
  50. help_text="фактическое время окончания (точное установленное время)"
  51. )
  52. time_finish_predicted = models.DateTimeField(
  53. help_text="предварительное/расчетное время до окончания оказания услуги"
  54. )
  55. real_price = models.FloatField(
  56. help_text="цена с учетом тарифа поставщика услуг по факту оказания услуги"
  57. )
  58. predicted_price = models.FloatField(
  59. help_text="расчетная цена с учетом тарифа поставщика услуг"
  60. )
  61. # NOTE: Возможно в будующем можнос сделать символом
  62. asap = models.BooleanField(
  63. default=False,
  64. help_text="Срочный ли заказ"
  65. )
  66. # OTHER
  67. is_global = models.CharField(
  68. max_length=1,
  69. default="f",
  70. help_text="доступна ли информация по заказу для хранения в глобальном сервисе/нужна синхронизация данных. Если is_global = false, то и is_visible для заказа и вглубь по цепочке для всех исполнителей и ресурсов - тоже false."
  71. )
  72. is_visible = models.CharField(
  73. max_length=1,
  74. default="f",
  75. help_text="доступна ли информация по заказу (время, место) для планирования иных цепочек. Если нет, то все действующие исполнители и ресурсы считаются занятыми на неопределенное время, пока не завершится заказ. Если да - то ресурсы могут использоваться для построения цепочек после планируемого времени завершения, с учетом места."
  76. )
  77. # FK
  78. ticket = models.ForeignKey(
  79. Ticket,
  80. null=True,
  81. on_delete=models.DO_NOTHING
  82. )
  83. service = models.ForeignKey(
  84. Service,
  85. null=True,
  86. on_delete=models.DO_NOTHING,
  87. help_text="спецификатор услуги провайдера, нужен для установления цены (id_service - уникальный идентификатор шаблона услуги, необходим для установления цены и исполнителей."
  88. )
  89. service_type = models.ForeignKey(
  90. ServiceType,
  91. null=True,
  92. on_delete=models.DO_NOTHING,
  93. help_text="тип заказа по классификатору услу"
  94. )
  95. client = models.ForeignKey(
  96. Client,
  97. null=True,
  98. on_delete=models.DO_NOTHING,
  99. help_text="клиент/аккаунт, который оплачивает все оказанные услуги"
  100. )
  101. provider = models.ForeignKey(
  102. Provider,
  103. null=True,
  104. on_delete=models.DO_NOTHING,
  105. help_text="уникальный идентификатор поставщика услуги/аккаунта, который оказывает услугу. Если несколько провайдеров собираются мета-сервисом в цепочку, где на уровне связи с клиентом нельзя установить одно ответственное лицо, то указывается вспомогательный мета-провайдер сервиса, и это означает, что мета-сервис несет ответственность перед пользователем за сборку услуги воедино."
  106. )
  107. receiver = models.ForeignKey(
  108. get_user_model(),
  109. null=True,
  110. related_name="user_id",
  111. on_delete=models.DO_NOTHING,
  112. help_text="пользователь/аккаунт, который принимает оказываемые услуги"
  113. )
  114. company = models.ForeignKey(
  115. Company,
  116. on_delete=models.DO_NOTHING,
  117. null=True,
  118. help_text="Идентификатор компании, к которой относится документ, если таковая есть (может не быть)"
  119. )
  120. class Meta:
  121. db_table = "orders"
  122. verbose_name = "Заказ"
  123. verbose_name_plural = "Заказы"