orders.py 3.6 KB

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