models.py 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205
  1. # coding=utf-8
  2. from django.db import models
  3. from django.conf import settings
  4. from utils.exceptions import CustomError
  5. from apps.log.models import BizLog
  6. from django.contrib.auth import get_user_model
  7. User = get_user_model()
  8. from apps.upload.models import Upload
  9. from apps import order
  10. class Product(models.Model):
  11. create_user = models.ForeignKey(settings.AUTH_USER_MODEL, related_name='package_create_user', verbose_name=u"添加人",
  12. on_delete=models.PROTECT, editable=False)
  13. create_time = models.DateTimeField(verbose_name=u'添加时间', auto_now_add=True, editable=False)
  14. month = models.IntegerField(verbose_name=u'贷款期限')
  15. name = models.CharField(verbose_name=u'产品名称', max_length=200)
  16. enable = models.BooleanField(verbose_name=u'是否在用', default=True,)
  17. main_image = models.ForeignKey(Upload, verbose_name=u'主图', on_delete=models.SET_NULL, null=True,
  18. related_name='main_image')
  19. notes = models.CharField(verbose_name=u'备注', max_length=200, null=True,)
  20. class Meta:
  21. db_table = "product"
  22. verbose_name = u"贷款产品"
  23. ordering = ('-id',)
  24. default_permissions = ()
  25. permissions = [
  26. ]
  27. class ProductImages(models.Model):
  28. name = models.CharField(verbose_name=u'名称', max_length=200)
  29. product = models.ForeignKey(Product, verbose_name=u'产品', on_delete=models.PROTECT, related_name='product_images')
  30. image = models.ForeignKey(Upload, verbose_name=u'图片', on_delete=models.PROTECT)
  31. class Meta:
  32. db_table = "product_images"
  33. verbose_name = u"产品图片"
  34. ordering = ('id',)
  35. default_permissions = ()
  36. @staticmethod
  37. def getById(id):
  38. try:
  39. id = int(id)
  40. except:
  41. raise CustomError(u'无效的ID')
  42. instance = ProductImages.objects.filter(pk=id).first()
  43. if not instance:
  44. raise CustomError(u'未找到相应的产品图片')
  45. return instance
  46. class Order(models.Model):
  47. category = models.PositiveSmallIntegerField(choices=order.CATEGORY_CHOICES, verbose_name=u"订单类型", default=order.ZERO)
  48. status = models.PositiveSmallIntegerField(choices=order.STATUS_CHOICES, verbose_name=u"订单状态", default=order.ZERO, editable=False)
  49. seller = models.ForeignKey(settings.AUTH_USER_MODEL, related_name='order_seller', verbose_name=u"业务人员",
  50. on_delete=models.PROTECT)
  51. create_user = models.ForeignKey(settings.AUTH_USER_MODEL, related_name='order_create_user', verbose_name=u"添加人",
  52. on_delete=models.PROTECT, editable=False)
  53. create_time = models.DateTimeField(verbose_name=u'添加时间', auto_now_add=True, editable=False)
  54. cancel_reason = models.CharField(max_length=100, verbose_name=u"未通过原因", null=True, editable=False)
  55. vmodel = models.CharField(max_length=100, verbose_name=u"车型", null=True)
  56. invioce = models.CharField(max_length=10, verbose_name=u"车辆发票金额", null=True)
  57. ptax = models.CharField(max_length=10, verbose_name=u"购置税", null=True)
  58. insurance = models.CharField(max_length=10, verbose_name=u"保险", null=True)
  59. boutique = models.CharField(max_length=10, verbose_name=u"精品", null=True)
  60. wextension = models.CharField(max_length=10, verbose_name=u"延保", null=True)
  61. upkeep = models.CharField(max_length=10, verbose_name=u"保养", null=True)
  62. dpratio = models.CharField(max_length=10, verbose_name=u"首付比例", null=True)
  63. lamount = models.CharField(max_length=10, verbose_name=u"申请贷款金额", null=True)
  64. laompany = models.ForeignKey(Product, verbose_name=u'贷款产品', on_delete=models.PROTECT)
  65. name = models.CharField(max_length=10, verbose_name=u"姓名")
  66. sex = models.PositiveSmallIntegerField(choices=order.GENDER_CHOICES, verbose_name=u"性别", default=order.ZERO)
  67. bdate = models.DateField(verbose_name=u"出生日期", null=True)
  68. rpr = models.PositiveSmallIntegerField(choices=order.HUKOU_CHOICES, verbose_name=u"户口", default=order.ZERO)
  69. nationality = models.PositiveSmallIntegerField(choices=order.NATIONALITY_CHOICES, verbose_name=u"国籍/地区", default=order.ZERO)
  70. ntype = models.PositiveSmallIntegerField(choices=order.ITYPE_CHOICES, verbose_name=u"身份证件类型", default=order.ZERO)
  71. inumber = models.CharField(max_length=18, verbose_name=u"身份证件号码", null=True)
  72. dincome = models.CharField(max_length=10, verbose_name=u"税后收入", null=True)
  73. mstatus = models.PositiveSmallIntegerField(choices=order.HUNYIN_CHOICES, verbose_name=u"婚姻状况", default=order.ZERO)
  74. elevel = models.PositiveSmallIntegerField(choices=order.JIAOYU_CHOICES, verbose_name=u"教育程度", default=order.ZERO)
  75. naddress = models.CharField(max_length=100, verbose_name=u"现居住地址", null=True)
  76. hptype = models.PositiveSmallIntegerField(choices=order.FAGNCHAN_CHOICES, verbose_name=u"现居住房产类型", default=order.ZERO)
  77. maddress = models.PositiveSmallIntegerField(choices=order.YOUJI_CHOICES, verbose_name=u"邮寄地址", default=order.ZERO)
  78. email = models.CharField(max_length=100, verbose_name=u"电子邮箱", null=True)
  79. wx = models.CharField(max_length=100, verbose_name=u"微信号", null=True)
  80. phone = models.CharField(max_length=15, verbose_name=u"住宅固定电话", null=True)
  81. tel = models.CharField(max_length=11, verbose_name=u"手机号")
  82. wname = models.CharField(max_length=100, verbose_name=u"现工作单位名称", null=True)
  83. wphone = models.CharField(max_length=15, verbose_name=u"单位电话", null=True)
  84. waddress = models.CharField(max_length=100, verbose_name=u"现工作单位地址", null=True)
  85. itype = models.PositiveSmallIntegerField(choices=order.HANGYE_CHOICES, verbose_name=u"行业类型", default=order.ZERO)
  86. otype = models.PositiveSmallIntegerField(choices=order.ZHIYE_CHOICES, verbose_name=u"职业类型", default=order.ZERO)
  87. position = models.CharField(max_length=20, verbose_name=u"职位", null=True)
  88. wbst = models.SmallIntegerField(verbose_name=u"是否挂靠", default=0)
  89. bstname = models.CharField(max_length=100, verbose_name=u"挂靠公司名称", null=True)
  90. bstcode = models.CharField(max_length=100, verbose_name=u"挂靠公司组织机构代码", null=True)
  91. bsttel = models.CharField(max_length=100, verbose_name=u"挂靠公司电话", null=True)
  92. bstaddress = models.CharField(max_length=100, verbose_name=u"挂靠公司地址", null=True)
  93. cname = models.CharField(max_length=10, verbose_name=u"联系人1名称", null=True)
  94. ctel = models.CharField(max_length=11, verbose_name=u"联系人1手机号", null=True)
  95. relation = models.PositiveSmallIntegerField(choices=order.GUANXI_CHOICES, verbose_name=u"与借款人关系", default=order.ZERO)
  96. caddress = models.CharField(max_length=100, verbose_name=u"现居住地址", null=True)
  97. ctname = models.CharField(max_length=10, verbose_name=u"联系人2姓名", null=True)
  98. cttel = models.CharField(max_length=11, verbose_name=u"联系人2手机号", null=True)
  99. thesame = models.SmallIntegerField(verbose_name=u"是否有共同借款人", default=0)
  100. tsname = models.CharField(max_length=10, verbose_name=u"共借人姓名", null=True)
  101. tsbdate = models.DateField(verbose_name=u"出生日期", null=True)
  102. tsitype = models.PositiveSmallIntegerField(choices=order.ITYPE_CHOICES, verbose_name=u"身份证件类型", default=order.ZERO)
  103. tsinumber = models.CharField(max_length=18, verbose_name=u"身份证件号码", null=True)
  104. tstel = models.CharField(max_length=11, verbose_name=u"手机号", null=True)
  105. tsrelation = models.PositiveSmallIntegerField(choices=order.GUANXI_CHOICES, verbose_name=u"与借款人关系",
  106. default=order.ZERO)
  107. tsnaddress = models.CharField(max_length=100, verbose_name=u"现居住地址", null=True)
  108. tsmaddress = models.PositiveSmallIntegerField(choices=order.YOUJI_CHOICES, verbose_name=u"邮寄地址", default=order.ZERO)
  109. tsemail = models.CharField(max_length=50, verbose_name=u"电子邮箱", null=True)
  110. tswx = models.CharField(max_length=20, verbose_name=u"微信号", null=True)
  111. tswname = models.CharField(max_length=100, verbose_name=u"现工作单位名称", null=True)
  112. tswphone = models.CharField(max_length=15, verbose_name=u"单位电话", null=True)
  113. tswaddress = models.CharField(max_length=100, verbose_name=u"现工作单位地址", null=True)
  114. tsmincome = models.CharField(max_length=10, verbose_name=u"税后月收入", null=True)
  115. class Meta:
  116. db_table = "order"
  117. verbose_name = u"订单管理"
  118. ordering = ('-id',)
  119. default_permissions = ()
  120. permissions = [
  121. ]
  122. @staticmethod
  123. def get_instance_by_id(id):
  124. try:
  125. id = int(id)
  126. except:
  127. raise CustomError('无效的订单ID')
  128. instance = Order.objects.filter(pk=id).first()
  129. if not instance:
  130. raise CustomError('未找到对应的订单')
  131. return instance
  132. class OrderImages(models.Model):
  133. ONE = 1
  134. TOW = 2
  135. THREE = 3
  136. FOUR = 4
  137. FIVE = 5
  138. SIX = 6
  139. TYPE_CHOICE = (
  140. (ONE, '身份证', ),
  141. (TOW, '驾驶证', ),
  142. (THREE, '收入类',),
  143. (FOUR, '流水类',),
  144. (FIVE, '营业执照', ),
  145. (SIX, '挂靠协议', ),
  146. )
  147. type = models.PositiveSmallIntegerField(choices=TYPE_CHOICE, default=ONE)
  148. order = models.ForeignKey(Order, verbose_name=u'产品', on_delete=models.PROTECT, related_name='order_images')
  149. image = models.ForeignKey(Upload, verbose_name=u'图片', on_delete=models.SET_NULL, null=True,)
  150. enable = models.BooleanField(verbose_name=u'是否在用', default=True, )
  151. class Meta:
  152. db_table = "order_images"
  153. verbose_name = u"订单图片"
  154. ordering = ('id',)
  155. default_permissions = ()
  156. @staticmethod
  157. def getById(id):
  158. try:
  159. id = int(id)
  160. except:
  161. raise CustomError(u'无效的ID')
  162. instance = OrderImages.objects.filter(pk=id).first()
  163. if not instance:
  164. raise CustomError(u'未找到相应的图片')
  165. return instance
  166. class OrderDetailEdit(models.Model):
  167. ZERO = 0
  168. ONE = 1
  169. TYPE_CHOICE = (
  170. (ZERO, '资料'),
  171. (ONE, '图片'),
  172. )
  173. type = models.PositiveSmallIntegerField(choices=TYPE_CHOICE, default=ZERO)
  174. order = models.ForeignKey(Order, verbose_name=u'产品', on_delete=models.PROTECT, related_name='order_detail_edit')
  175. value = models.CharField(max_length=20, verbose_name=u'订单明细对象值') # 文字资料存自动名称,图片存OrderImages type值
  176. edit_time = models.DateTimeField(verbose_name=u'修改时间', null=True)
  177. reason = models.CharField(max_length=200, verbose_name=u'修改原因', null=True)
  178. class Meta:
  179. db_table = "order_detail_edit"
  180. verbose_name = u"订单明细修改"
  181. ordering = ('id',)
  182. default_permissions = ()