seal.go 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. package seal
  2. import (
  3. "fmt"
  4. "hongze/hongze_mobile_admin/utils"
  5. "rdluck_tools/orm"
  6. "time"
  7. )
  8. //用印
  9. type Seal struct {
  10. SealId int `orm:"column(seal_id);pk"`
  11. Code string `description:"用印编号,长度32位"`
  12. UserId int `description:"申请人id"`
  13. UserName string `description:"申请人名称"`
  14. Use string `description:"用印用途,枚举值:'销售合同', '渠道合同', '付款通知函', '招投标', '战略合作协议';默认:销售合同"`
  15. CompanyName string `description:"客户名称,甲方名称,长度32位"`
  16. UseCompanyName string `description:"实际使用方客户名称,长度32位"`
  17. CreditCode string `description:"社会统一信用代码,长度64位"`
  18. ServiceType string `description:"业务类型,枚举值:'新签合同','续约合同','补充协议';默认:新签合同"`
  19. SealType string `description:"加盖印章类型,枚举值:'合同章', '公章', '法人章';默认:合同章"`
  20. Status string `description:"合同状态,枚举值:'待提交','待审批','已撤回','已审批','已驳回','已作废'"`
  21. Remark string `description:"补充内容,长度255位"`
  22. ApprovalRemark string `description:"审核备注"`
  23. FileUrl string `description:"文件附件地址"`
  24. FileNum int `description:"文件附件份数"`
  25. ContractId int `description:"系统合同id"`
  26. IsDelete int `description:"是否已经删除,0:未删除,1:已删除",json:"-"`
  27. ModifyTime time.Time `description:"最近一次修改时间"`
  28. CreateTime time.Time `description:"添加时间"`
  29. }
  30. //根据合同id获取合同信息
  31. func GetSealInfoById(sealId int) (sealInfo *Seal, err error) {
  32. o := orm.NewOrm()
  33. sql := `select * from seal where seal_id = ? `
  34. err = o.Raw(sql, sealId).QueryRow(&sealInfo)
  35. return
  36. }
  37. //用印添加
  38. func AddSeal(sealInfo *Seal) (err error) {
  39. o := orm.NewOrm()
  40. //用印数据入库
  41. sealId, err := o.Insert(sealInfo)
  42. if err != nil {
  43. return
  44. }
  45. sealInfo.SealId = int(sealId)
  46. return
  47. }
  48. //更新用印信息
  49. func (seal *Seal) Update(cols []string) (err error) {
  50. o := orm.NewOrm()
  51. _, err = o.Update(seal, cols...)
  52. return
  53. }
  54. //删除用印
  55. func DeleteSeal(sealInfo *Seal) (err error) {
  56. sealInfo.IsDelete = 1
  57. sealInfo.ModifyTime = time.Now()
  58. err = sealInfo.Update([]string{"IsDelete", "ModifyTime"})
  59. return
  60. }
  61. //作废用印
  62. func Invalid(sealInfo *Seal) (err error) {
  63. sealInfo.Status = "已作废"
  64. sealInfo.ModifyTime = time.Now()
  65. //修改用印数据入库
  66. err = sealInfo.Update([]string{"Status", "ModifyTime"})
  67. return
  68. }
  69. //生成合同编号
  70. func GetSealCode() (code string, err error) {
  71. var num int
  72. o := orm.NewOrm()
  73. today := utils.GetToday(utils.FormatDate)
  74. sql := `SELECT COUNT(1) AS num FROM seal where create_time>=?`
  75. err = o.Raw(sql, today).QueryRow(&num)
  76. if err != nil {
  77. return
  78. }
  79. code = "HZ" + time.Now().Format("20060102") + fmt.Sprintf("%03d", num)
  80. return
  81. }
  82. type CompanyNameList struct {
  83. CompanyName string `description:"客户名称,甲方名称,长度32位"`
  84. }
  85. //获取客户名称列表数据
  86. func GetCompanyNameList(name string) (list []*CompanyNameList, err error) {
  87. o := orm.NewOrm()
  88. sql := `select * from seal where company_name like '%` + name + `%' group by company_name order by modify_time desc `
  89. _, err = o.Raw(sql).QueryRows(&list)
  90. return
  91. }