models.py 7.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226
  1. #!/usr/bin/env python
  2. # -*- coding: utf-8 -*-
  3. from django.db import models
  4. from django.contrib.auth.models import User
  5. from datetime import date, timedelta
  6. from django.utils import dateformat
  7. from django.contrib.auth.signals import user_logged_in, user_logged_out, user_login_failed
  8. from django.db.models.signals import post_save, post_delete
  9. from django.contrib.admin.models import LogEntry, ADDITION, CHANGE, DELETION
  10. from django.contrib.contenttypes.models import ContentType
  11. from django.dispatch import receiver
  12. from gadjo.requestprovider.signals import get_request
  13. #Изделия
  14. class Product(models.Model):
  15. name = models.CharField(max_length=150)
  16. prod_period = models.IntegerField()#трудоемкость, дней
  17. def __unicode__(self):
  18. return self.name
  19. #График работы
  20. class Schedule(models.Model):
  21. date = models.DateField()
  22. designer = models.ForeignKey(User)
  23. def __unicode__(self):
  24. return ' '.join((self.designer.first_name, self.designer.last_name))
  25. #Таблица посещаемости
  26. class Attendance(models.Model):
  27. date = models.DateField()
  28. calls = models.IntegerField()
  29. visits = models.IntegerField()
  30. @property
  31. def date_dd_mm_yy(self):
  32. return self.date.strftime("%d/%m/%Y")
  33. @property
  34. def date_as_tuple(self):
  35. return tuple(self.date_dd_mm_yy().split("/"))
  36. @property
  37. def order_count(self):
  38. return Order.objects.filter(date=self.date).count()
  39. @property
  40. def orders_price(self):
  41. orders = Order.objects.filter(date=self.date)
  42. day_price = sum(o.price for o in orders)
  43. return day_price
  44. #Статьи затрат
  45. class CostItem(models.Model):
  46. name = models.CharField(max_length=150)
  47. default_item = models.BooleanField(default=False)
  48. def __unicode__(self):
  49. return self.name
  50. #Заказы
  51. class Order(models.Model):
  52. date = models.DateField() #дата
  53. product = models.ForeignKey(Product) #id изделия
  54. price = models.DecimalField(max_digits=12, decimal_places=2) #стоимость
  55. address = models.CharField(max_length=150) #адрес
  56. designer = models.ForeignKey(User, related_name='+') #id дизайнера
  57. deadline = models.DateField() #срок сдачи
  58. delivery = models.BooleanField(default=False) #доставка
  59. lifting = models.BooleanField(default=False) #подъем
  60. paid = models.DecimalField(max_digits=12, decimal_places=2) #оплачено
  61. approved = models.DateTimeField(null=True, blank = True) #согласовано
  62. executor = models.ForeignKey(User, null = True, blank = True, related_name='+') #id исполнителя
  63. is_done = models.BooleanField(default=False) #сдан
  64. calls = models.TextField(null=True, blank = True) #обзвон
  65. contact = models.CharField(max_length=150, null=True, blank = True) #контактное лицо
  66. phone_num = models.CharField(max_length=150,null=True, blank = True) #контактный телефон
  67. cancelled = models.BooleanField(default=False) #отменен
  68. cost_items = models.ManyToManyField(CostItem, through='OrderCosts', related_name='+', null=True, blank=True) #статьи затрат
  69. def __unicode__(self):
  70. return ', '.join((dateformat.format(self.date, 'd E Y'), self.product.name, self.address))
  71. @property
  72. def date_dmy(self):
  73. return self.date.strftime("%d/%m/%Y")
  74. @property
  75. def deadline_dmy(self):
  76. return self.deadline.strftime("%d/%m/%Y")
  77. @property
  78. def approved_date(self):
  79. return self.approved.strftime("%d/%m/%Y %H:%M")
  80. @property
  81. def sketch(self):
  82. return len(Sketch.objects.filter(order = self))
  83. @property
  84. def ostatok(self):
  85. return self.price-self.paid
  86. @property
  87. def calls_color(self):
  88. need_color=False
  89. if self.approved!=None:
  90. need_color = (date.today()-self.approved.date()>= timedelta(days = 10))
  91. need_color = need_color and (self.calls == '')
  92. return need_color
  93. def save(self, *args, **kwargs):
  94. super(Order, self).save(*args, **kwargs)
  95. cost_items = CostItem.objects.filter(default_item = True)
  96. for ci in cost_items:
  97. new_order_cost = OrderCosts(order = self, cost_item = ci, value = 0, formula = '')
  98. new_order_cost.save()
  99. #Эскизы
  100. class Sketch(models.Model):
  101. def get_sketch_path(self, file_name):
  102. template = 'sketches/%s'
  103. return template % '' if self.order == None else '%s/%s' % ((template % self.order.id), file_name)
  104. sketch_file = models.FileField(upload_to = get_sketch_path) #путь к файу
  105. order = models.ForeignKey(Order) #id заказа
  106. def __unicode__(self):
  107. return self.sketch_file.name
  108. #Действия
  109. class Action(models.Model):
  110. name = models.CharField(max_length=150) #наименование действия
  111. def __unicode__(self):
  112. return self.name
  113. #Производственный план
  114. class ProdPlan(models.Model):
  115. start_date = models.DateField() #дата начала
  116. end_date = models.DateField() #дата окончания
  117. order = models.ForeignKey(Order) #id заказа
  118. executor = models.ForeignKey(User) #id исполнителя
  119. action = models.ForeignKey(Action) #id действия
  120. def __unicode__(self):
  121. return ', '.join((str(self.start_date), self.order.product.name, self.action.name, self.executor.first_name))
  122. #Протокол доступа
  123. class AccessProtocol(models.Model):
  124. time = models.DateTimeField() #время
  125. user = models.ForeignKey(User) #id пользователя
  126. event = models.CharField(max_length=150) #действие
  127. #План заказов
  128. class OrderPlan(models.Model):
  129. date = models.DateField()
  130. plan = models.DecimalField(max_digits=12, decimal_places=2)
  131. def __unicode__(self):
  132. return self.date.strftime('%B %Y')
  133. # Затраты по заказам
  134. class OrderCosts(models.Model):
  135. order = models.ForeignKey(Order, related_name='+')
  136. cost_item = models.ForeignKey(CostItem, related_name='+')
  137. value = models.DecimalField(max_digits=12, decimal_places=2, null=True, blank = True)
  138. formula = models.CharField(max_length=150, null=True, blank = True)
  139. def __unicode__(self):
  140. return ', '.join((self.order.product.name, self.cost_item.name))
  141. ############################################################################################
  142. # Signal handlers
  143. ############################################################################################
  144. def auth_log(message, user = None):
  145. if user == None:
  146. user = User.objects.get(pk = 1)
  147. entry = LogEntry(user = user, object_repr = message, action_flag = 4)
  148. entry.save()
  149. on_login = lambda **kwargs: auth_log(u'Вход в систему', kwargs['user'])
  150. on_logout = lambda **kwargs: auth_log(u'Выход из системы', kwargs['user'])
  151. on_login_error = lambda **kwargs: auth_log(u'Ошибка входа пользователя %s' % kwargs['credentials']['username'])
  152. user_logged_in.connect(on_login)
  153. user_logged_out.connect(on_logout)
  154. user_login_failed.connect(on_login_error)
  155. def construct_log_entry(**kwargs):
  156. instance = kwargs['instance']
  157. content_type = ContentType.objects.get_for_model(instance)
  158. user = User.objects.get(username = get_request().META['USER'])
  159. log_entry = {}
  160. log_entry['user'] = user
  161. log_entry['object_repr'] = str(instance)
  162. log_entry['content_type'] = content_type
  163. log_entry['object_id'] = instance.id
  164. return log_entry
  165. @receiver(post_save)
  166. def after_save(*args, **kwargs):
  167. instance = kwargs['instance']
  168. if isinstance(instance, LogEntry): return
  169. log_entry = construct_log_entry(**kwargs)
  170. created = kwargs['created']
  171. log_entry['action_flag'] = ADDITION if created else CHANGE
  172. entry = LogEntry(**log_entry)
  173. entry.save()
  174. @receiver(post_delete)
  175. def after_delete(*args, **kwargs):
  176. log_entry = construct_log_entry(**kwargs)
  177. log_entry['action_flag'] = DELETION
  178. entry = LogEntry(**log_entry)
  179. entry.save()
  180. @receiver(post_delete, sender=Sketch)
  181. def sketch_delete(sender, instance, **kwargs):
  182. instance.sketch_file.delete(False)