company.py 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123
  1. from django.contrib.auth import get_user_model
  2. from django.db import models
  3. from tickets.models import Ticket
  4. from dbsynce.docs.database.company import Company as HelpTexts
  5. class Company(models.Model):
  6. """
  7. Company - это таблица с партнерами сервисов. Партнер сервиса -
  8. юридическое лицо или ИП, которое непосредственно организует работу с
  9. исполнителями и отвечает перед клиентами и перед сервисом за качество
  10. оказанных услуг. Юридически это лица, фактически оказывающие услуги
  11. по договору.
  12. """
  13. # ID METASERVICE
  14. # FIXME: id_metaservice должно принимать текущий идентификатор метасервиса, на котором происходит создание записи
  15. id_metaservice = models.PositiveIntegerField(
  16. default=1,
  17. help_text=HelpTexts.id_metaservice
  18. )
  19. # DATA
  20. requirements = models.CharField(
  21. "Ограничения",
  22. max_length=150,
  23. default="DS01y04y05y06y07yMPUCS13MPUB",
  24. help_text=HelpTexts.requirements
  25. )
  26. status = models.CharField(
  27. "Статус",
  28. max_length=150,
  29. default="deactivated",
  30. help_text=HelpTexts.status
  31. )
  32. legal_name = models.CharField(
  33. "Название организации",
  34. max_length=150,
  35. help_text=HelpTexts.legal_name
  36. )
  37. address = models.CharField(
  38. "Юридический адрес",
  39. max_length=150,
  40. help_text=HelpTexts.address
  41. )
  42. inn = models.CharField(
  43. "ИНН компании",
  44. max_length=12,
  45. unique=True,
  46. help_text=HelpTexts.inn
  47. )
  48. kpp = models.CharField(
  49. "КПП компании",
  50. max_length=9,
  51. help_text=HelpTexts.kpp
  52. )
  53. ogrn = models.CharField(
  54. "ОГРН компании",
  55. max_length=15,
  56. help_text=HelpTexts.ogrn
  57. )
  58. bank_name = models.CharField(
  59. "Название банка",
  60. max_length=150,
  61. help_text=HelpTexts.bank_name
  62. )
  63. bik = models.CharField(
  64. "БИК компании",
  65. max_length=11,
  66. help_text=HelpTexts.bik
  67. )
  68. rs = models.CharField(
  69. "Расчетный счет",
  70. max_length=20,
  71. help_text=HelpTexts.rs
  72. )
  73. ks = models.CharField(
  74. "Корреспондентский счет",
  75. max_length=20,
  76. help_text=HelpTexts.ks
  77. )
  78. tax_method = models.IntegerField(
  79. help_text=HelpTexts.tax_method
  80. )
  81. # OTHER
  82. is_global = models.CharField(
  83. max_length=1,
  84. default="f",
  85. help_text="Доступно ли для хранения в глобальном сервисе / Нужна синхронизация данных"
  86. )
  87. is_visible = models.CharField(
  88. max_length=1,
  89. default="f",
  90. help_text="Доступно ли для планирования в цепочке с другими услугами в глобальном сервисе"
  91. )
  92. # FK
  93. repr = models.ForeignKey(
  94. get_user_model(),
  95. blank=True,
  96. verbose_name="Представитель организации",
  97. on_delete=models.DO_NOTHING,
  98. help_text="Уникальный идентификатор представителя компании"
  99. )
  100. ticket_status = models.ForeignKey(
  101. Ticket,
  102. on_delete=models.SET_NULL,
  103. blank=True,
  104. null=True,
  105. help_text="ID заявки, привязанной к текущей записи",
  106. verbose_name="Связанный тикет"
  107. )
  108. def deactivate(self):
  109. self.status = "deactivated"
  110. self.save()
  111. class Meta:
  112. db_table = "company"
  113. verbose_name = "Компания"
  114. verbose_name_plural = "Компании"