project_process.go 2.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. package dao
  2. import "server/global"
  3. type ProjectProcess struct {
  4. global.GVA_MODEL
  5. ProjectProcessName string `json:"projectProcessName" form:"projectProcessName" gorm:"comment:项目审批名称"`
  6. ProjectId int `json:"projectId" form:"projectId" gorm:"comment:项目id"`
  7. Project Project `json:"project" form:"project" gorm:"foreignKey:ProjectId;references:id;"`
  8. Applicant int `json:"applicant" form:"applicant" gorm:"comment:申请人"`
  9. User SysUser `json:"user" form:"user" gorm:"foreignKey:Applicant;references:id;"`
  10. CurrentNodeOrder int `json:"currentNodeOrder" form:"currentNodeOrder" gorm:"comment:当前审批节点id"`
  11. Node Node `json:"node" form:"node" gorm:"foreignKey:CurrentNodeOrder;references:id;"`
  12. ProcessApprovalId int `json:"processApprovalId" form:"processApprovalId" gorm:"comment:当前审批流程id"`
  13. Process Process `json:"process" form:"process" gorm:"foreignKey:ProcessApprovalId;references:id"`
  14. ProjectType string `json:"projectType" form:"projectType" gorm:"comment:项目类型"`
  15. Descriptions []Description `json:"descriptions" form:"descriptions" gorm:"foreignKey:ProjectProcessId;"`
  16. }
  17. func (ProjectProcess) TableName() string {
  18. return "project_process"
  19. }
  20. func QueryProjectApplicantList(limit, offset, applicant int) (projectProcesses []ProjectProcess, total int64, err error) {
  21. // 创建db
  22. db := global.GVA_DB.Model(&ProjectProcess{})
  23. // 如果有条件搜索 下方会自动创建搜索语句
  24. if applicant != 0 {
  25. db = db.Where("applicant = ?", applicant)
  26. }
  27. err = db.Count(&total).Error
  28. if err != nil {
  29. return
  30. }
  31. err = db.Order("id desc").Limit(limit).Offset(offset).Preload("Project").Preload("User").Preload("Node").Preload("Process").Preload("Descriptions").Find(&projectProcesses).Error
  32. return projectProcesses, total, err
  33. }
  34. func QueryProjectProcessList(limit, offset, applicant int) (projectProcesses []ProjectProcess, total int64, err error) {
  35. // 创建db
  36. db := global.GVA_DB.Model(&ProjectProcess{}).Joins("JOIN node ON project_process.current_node_order = node.id").Where("node.approver_id = ?", applicant)
  37. // 如果有条件搜索 下方会自动创建搜索语句
  38. err = db.Count(&total).Error
  39. if err != nil {
  40. return
  41. }
  42. err = db.Order("id desc").Limit(limit).Offset(offset).Preload("Project").Preload("User").Preload("Node").Preload("Process").Preload("Descriptions").Find(&projectProcesses).Error
  43. return projectProcesses, total, err
  44. }
  45. func (pp ProjectProcess) CreateProjectProcess() error {
  46. return global.GVA_DB.Create(&pp).Error
  47. }
  48. func (pp ProjectProcess) UpdateProjectProcess() error {
  49. return global.GVA_DB.Where("id = ?", pp.ID).Updates(&pp).Error
  50. }
  51. func (pp ProjectProcess) DeleteProjectProcess() error {
  52. return global.GVA_DB.Unscoped().Delete(&pp).Error
  53. }