project.go 8.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211
  1. package dao
  2. import (
  3. "github.com/shopspring/decimal"
  4. "gorm.io/gorm"
  5. "server/dao/system"
  6. "server/global"
  7. )
  8. type Project struct {
  9. global.GVA_MODEL
  10. Code string `json:"code" form:"code" gorm:"comment:项目编号"`
  11. Name string `json:"name" form:"name" gorm:"comment:项目名称"`
  12. Address string `json:"address" form:"address" gorm:"comment:项目地址"`
  13. FirstPrincipal string `json:"firstPrincipal" form:"firstPrincipal" gorm:"comment:甲方负责人"`
  14. FirstPhone string `json:"firstPhone" form:"firstPhone" gorm:"comment:甲方电话"`
  15. ProjectPrice float64 `json:"projectPrice" form:"projectPrice" gorm:"type:decimal(10,2);comment:合同金额"`
  16. SecondPrincipal int `json:"secondPrincipal" form:"secondPrincipal" gorm:"comment:乙方负责人"`
  17. Principal system.SysUser `json:"principal" form:"principal" gorm:"foreignKey:SecondPrincipal;references:id;"`
  18. SecondPrincipalName string `json:"secondPrincipalName" form:"secondPrincipalName" gorm:"comment:乙方姓名"`
  19. SignTime string `json:"signTime" form:"signTime" gorm:"comment:合同签订日期"`
  20. IntoConstructionTime string `json:"intoConstructionTime" form:"intoConstructionTime" gorm:"comment:进场施工时间"`
  21. CompletedTime string `json:"completedTime" form:"completedTime" gorm:"comment:竣工时间"`
  22. SupervisorUint string `json:"supervisorUint" form:"supervisorUint" gorm:"comment:监理单位"`
  23. SupervisorName string `json:"supervisorName" form:"supervisorName" gorm:"comment:监理姓名"`
  24. SupervisorPhone string `json:"supervisorPhone" form:"supervisorPhone" gorm:"comment:监理电话"`
  25. Illustrate string `json:"illustrate" form:"illustrate" gorm:"comment:说明;type:varchar(200)"`
  26. State int `json:"state" form:"state" gorm:"comment:状态"`
  27. ProjectState ProjectState `json:"projectState" form:"projectState" gorm:"foreignKey:State;references:id;"`
  28. CollectionTime string `json:"collectionTime" form:"collectionTime" gorm:"comment:收款时间"`
  29. EndTime string `json:"endTime" form:"endTime" gorm:"comment:结束时间"`
  30. Files []ProjectFile `json:"files" form:"files" gorm:"-"`
  31. WorkingHours []ProjectWorkingHours `json:"workingHours" form:"workingHours" gorm:"-"`
  32. WorkingHoursTotal int64 `json:"workingHoursTotal" form:"workingHoursTotal" gorm:"-"`
  33. Collection []Collection `json:"collection" form:"collection" gorm:"-"`
  34. CollectionTotal int64 `json:"collectionTotal" form:"collectionTotal" gorm:"-"`
  35. Reimbursement []Reimbursement `json:"reimbursement" form:"reimbursement" gorm:"-"`
  36. ReimbursementTotal int64 `json:"reimbursementTotal" form:"reimbursementTotal" gorm:"-"`
  37. ProjectFee []ProjectFee `json:"projectFee" form:"project" gorm:"-"`
  38. ProjectFeeTotal int64 `json:"projectFeeTotal" form:"projectFeeTotal" gorm:"-"`
  39. IsApprove bool `json:"isApprove" form:"isApprove" gorm:"comment:是否审批;default:0"`
  40. }
  41. func (Project) TableName() string {
  42. return "project"
  43. }
  44. // TODO:项目查询
  45. // QueryProjectList 查询项目列表
  46. func QueryProjectList(limit, offset, state int, name, time string) (project []Project, total int64, err error) {
  47. // 创建db
  48. db := global.GVA_DB.Model(&Project{}).Where("is_approve = ?", true)
  49. // 如果有条件搜索 下方会自动创建搜索语句
  50. if state != 0 {
  51. db = db.Where("state = ?", state)
  52. }
  53. if name != "" {
  54. db = db.Where("name LIKE ?", "%"+name+"%")
  55. }
  56. if time != "" {
  57. db = db.Where("DATE_FORMAT(created_at, '%Y-%m') = ?", time)
  58. }
  59. err = db.Count(&total).Error
  60. if err != nil {
  61. return
  62. }
  63. err = db.Order("id desc").Limit(limit).Offset(offset).Preload("Principal").Preload("ProjectState").Find(&project).Error
  64. for i, p := range project {
  65. project[i].SecondPrincipalName = p.Principal.NickName
  66. }
  67. return project, total, err
  68. }
  69. // QueryProjectByCode 查询单个项目 按编号
  70. func QueryProjectByCode(code string) (project Project, err error) {
  71. err = global.GVA_DB.Model(&Project{}).Where("code = ?", code).Preload("Principal").Preload("ProjectState").First(&project).Error
  72. project.SecondPrincipalName = project.Principal.NickName
  73. return
  74. }
  75. func QueryProjectById(id int) (project Project, err error) {
  76. err = global.GVA_DB.Model(&Project{}).Where("id =?", id).Preload("Principal").Preload("ProjectState").First(&project).Error
  77. project.SecondPrincipalName = project.Principal.NickName
  78. return
  79. }
  80. // QueryAllProject 查询所以项目
  81. func QueryAllProject() (projects []Project, err error) {
  82. err = global.GVA_DB.Model(&Project{}).Find(&projects).Error
  83. return projects, err
  84. }
  85. // TODO:项目新增
  86. // CreateProject 新增项目
  87. func (p Project) CreateProject() error {
  88. return global.GVA_DB.Transaction(func(tx *gorm.DB) error {
  89. var process Process
  90. txErr := global.GVA_DB.Model(&Process{}).Where("process_type = ? AND is_use = 1", "立项").Find(&process).Error
  91. if txErr != nil {
  92. return txErr
  93. }
  94. var processNodes []ProcessNodes
  95. txErr = global.GVA_DB.Model(&ProcessNodes{}).Where("process_id = ?", process.ID).Find(&processNodes).Error
  96. if txErr != nil {
  97. return txErr
  98. }
  99. var nodes []Node
  100. for _, node := range processNodes {
  101. var node1 Node
  102. txErr := global.GVA_DB.Model(&Node{}).Where("id = ?", node.NodeId).Preload("Approver").Find(&node1).Error
  103. if txErr != nil {
  104. return txErr
  105. }
  106. node1.Order = node.NodeOrder
  107. nodes = append(nodes, node1)
  108. }
  109. process.Nodes = nodes
  110. if process.ID == 0 {
  111. p.IsApprove = true
  112. }
  113. txErr = tx.Model(&Project{}).Create(&p).Error
  114. if txErr != nil {
  115. return txErr
  116. }
  117. for _, file := range p.Files {
  118. var isFile ProjectFile
  119. tx.Model(&ProjectFile{}).Where("project_code = ? AND name = ? AND genre = ?", file.ProjectCode, file.Name, file.Genre).First(&isFile)
  120. if isFile.ID != 0 {
  121. txErr := tx.Model(&ProjectFile{}).Where("id = ?", isFile.ID).Updates(&file).Error
  122. if txErr != nil {
  123. return txErr
  124. }
  125. } else {
  126. txErr := tx.Model(&ProjectFile{}).Create(&file).Error
  127. if txErr != nil {
  128. return txErr
  129. }
  130. }
  131. }
  132. // 查询是否有使用的流程
  133. if process.ID != 0 {
  134. projectProcess := ProjectProcess{
  135. ProjectProcessName: p.Name + "审批",
  136. Applicant: p.SecondPrincipal,
  137. ProjectId: int(p.ID),
  138. CurrentNodeOrder: int(process.Nodes[0].ID),
  139. ProcessApprovalId: int(process.ID),
  140. ProjectType: "立项",
  141. }
  142. txErr := projectProcess.CreateProjectProcess()
  143. if txErr != nil {
  144. return txErr
  145. }
  146. }
  147. return txErr
  148. })
  149. }
  150. type ProjectSum struct {
  151. TotalProjectAmount float64
  152. TotalCollectionAmount float64
  153. Receivables float64
  154. }
  155. // QueryProjectSum 查询项目总
  156. func QueryProjectSum(code string) (projectSum ProjectSum, err error) {
  157. err = global.GVA_DB.Transaction(func(tx *gorm.DB) error {
  158. projectDB := tx.Model(&Project{}).Select("SUM(project_price) AS total_project_amount")
  159. collectionDB := tx.Model(&Collection{}).Select("SUM(collection_price) AS total_collection_amount")
  160. if code != "" {
  161. projectDB = projectDB.Where("code =?", code)
  162. collectionDB = collectionDB.Where("project_code =?", code)
  163. }
  164. txErr := projectDB.First(&projectSum).Error
  165. if txErr != nil {
  166. return txErr
  167. }
  168. txErr = collectionDB.First(&projectSum).Error
  169. if txErr != nil {
  170. return txErr
  171. }
  172. return txErr
  173. })
  174. // 使用decimal 防止精度不准
  175. exponent := decimal.NewFromFloatWithExponent(projectSum.TotalProjectAmount-projectSum.TotalCollectionAmount, -2)
  176. projectSum.Receivables = exponent.InexactFloat64()
  177. return
  178. }
  179. // TODO:项目修改
  180. // UpdateProject 修改项目
  181. func (p Project) UpdateProject() error {
  182. return global.GVA_DB.Model(&p).Where("id = ?", p.ID).Updates(p).Error
  183. }
  184. // TODO:项目删除
  185. // DeleteProject 删除项目
  186. func DeleteProject(code string) error {
  187. return global.GVA_DB.Unscoped().Where("code = ?", code).Delete(&Project{}).Error
  188. }