seal.go 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  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. ContractId int `description:"系统合同id"`
  25. IsDelete int `description:"是否已经删除,0:未删除,1:已删除",json:"-"`
  26. ModifyTime time.Time `description:"最近一次修改时间"`
  27. CreateTime time.Time `description:"添加时间"`
  28. }
  29. //根据合同id获取合同信息
  30. func GetSealInfoById(sealId int) (sealInfo *Seal, err error) {
  31. o := orm.NewOrm()
  32. sql := `select * from seal where seal_id = ? `
  33. err = o.Raw(sql, sealId).QueryRow(&sealInfo)
  34. return
  35. }
  36. //用印添加
  37. func AddSeal(sealInfo *Seal) (err error) {
  38. o := orm.NewOrm()
  39. //用印数据入库
  40. sealId, err := o.Insert(sealInfo)
  41. if err != nil {
  42. return
  43. }
  44. sealInfo.SealId = int(sealId)
  45. return
  46. }
  47. //更新用印信息
  48. func (seal *Seal) Update(cols []string) (err error) {
  49. o := orm.NewOrm()
  50. _, err = o.Update(seal, cols...)
  51. return
  52. }
  53. //删除用印
  54. func DeleteSeal(sealInfo *Seal) (err error) {
  55. sealInfo.IsDelete = 1
  56. sealInfo.ModifyTime = time.Now()
  57. err = sealInfo.Update([]string{"IsDelete", "ModifyTime"})
  58. return
  59. }
  60. //作废用印
  61. func InvalidSeal(sealInfo *Seal) (err error) {
  62. sealInfo.Status = "已作废"
  63. sealInfo.ModifyTime = time.Now()
  64. //修改用印数据入库
  65. err = sealInfo.Update([]string{"IsDelete", "ModifyTime"})
  66. return
  67. }
  68. //生成合同编号
  69. func GetSealCode() (code string, err error) {
  70. var num int
  71. o := orm.NewOrm()
  72. today := utils.GetToday(utils.FormatDate)
  73. sql := `SELECT COUNT(1) AS num FROM seal where create_time>=?`
  74. err = o.Raw(sql, today).QueryRow(&num)
  75. if err != nil {
  76. return
  77. }
  78. code = "HZ" + time.Now().Format("20060102") + fmt.Sprintf("%03d", num)
  79. return
  80. }
  81. type CompanyNameList struct {
  82. CompanyName string `description:"客户名称,甲方名称,长度32位"`
  83. }
  84. //获取客户名称列表数据
  85. func GetCompanyNameList(name string) (list []*CompanyNameList, err error) {
  86. o := orm.NewOrm()
  87. sql := `select * from seal where company_name like '%` + name + `%' group by company_name order by modify_time desc `
  88. _, err = o.Raw(sql).QueryRows(&list)
  89. return
  90. }