project.go 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163
  1. package admin
  2. import (
  3. "fmt"
  4. "github.com/shopspring/decimal"
  5. "server/dao"
  6. "server/model/common/request"
  7. )
  8. type ProjectService struct{}
  9. func (ps *ProjectService) QueryProjectList(info request.SearchProject) (list interface{}, total int64, err error) {
  10. limit := info.PageInfo.PageSize
  11. offset := info.PageInfo.PageSize * (info.PageInfo.Page - 1)
  12. project, total, err := dao.QueryProjectList(limit, offset, info.State, info.Name, info.Time)
  13. return project, total, err
  14. }
  15. func (ps *ProjectService) QueryProjectByCode(code string) (project dao.Project, err error) {
  16. project, err = dao.QueryProjectByCode(code)
  17. if err != nil {
  18. return
  19. }
  20. files, err := dao.QueryFilesByCode(code)
  21. if err != nil {
  22. return
  23. }
  24. project.Files = files
  25. return project, err
  26. }
  27. func (ps *ProjectService) QueryFileList(info request.SearchProjectFileList) (list interface{}, total int64, err error) {
  28. limit := info.PageInfo.PageSize
  29. offset := info.PageInfo.PageSize * (info.PageInfo.Page - 1)
  30. files, total, err := dao.QueryFileList(limit, offset, info.Genre, info.Code, info.Name)
  31. return files, total, err
  32. }
  33. func (ps *ProjectService) QueryFilesByNameOrGenre(info request.SearchProjectFileList) ([]dao.ProjectFile, error) {
  34. return dao.QueryFilesByNameOrGenre(info.Genre, info.Code, info.Name)
  35. }
  36. func (ps *ProjectService) QueryAllProject() ([]dao.Project, error) {
  37. return dao.QueryAllProject()
  38. }
  39. func (ps *ProjectService) QueryProjectsInfo() (sum decimal.Decimal, totalProject, completeProject, unCompleteProject int, err error) {
  40. projects, err := dao.QueryAllProject()
  41. if err != nil {
  42. return
  43. }
  44. for _, project := range projects {
  45. totalProject++
  46. if project.State == 3 {
  47. completeProject++
  48. }
  49. sum = sum.Add(project.Price)
  50. }
  51. fmt.Printf("%y", sum)
  52. unCompleteProject = totalProject - completeProject
  53. return
  54. }
  55. func (ps *ProjectService) QueryWorkingHours(code string) ([]dao.ProjectWorkingHours, error) {
  56. return dao.QueryWorkingHours(code)
  57. }
  58. func (ps *ProjectService) QueryCollections(code string) ([]dao.Collection, error) {
  59. return dao.QueryCollection(code)
  60. }
  61. func (ps *ProjectService) QueryReimbursementList(info request.SearchProjectList) (list interface{}, total int64, err error) {
  62. limit := info.PageInfo.PageSize
  63. offset := info.PageInfo.PageSize * (info.PageInfo.Page - 1)
  64. return dao.QueryReimbursementList(limit, offset, info.Code, info.Name)
  65. }
  66. func (ps *ProjectService) QueryReimbursement(code string) ([]dao.Reimbursement, error) {
  67. reimbursements, err := dao.QueryReimbursement(code)
  68. if err != nil {
  69. return nil, err
  70. }
  71. for i, reimbursement := range reimbursements {
  72. details, err := dao.QueryFeeDetails(int(reimbursement.ID))
  73. if err != nil {
  74. return nil, err
  75. }
  76. reimbursements[i].FeeDetails = details
  77. }
  78. return reimbursements, err
  79. }
  80. func (ps *ProjectService) CreateProject(project dao.Project) error {
  81. return project.CreateProject()
  82. }
  83. func (ps *ProjectService) CreateProjectFile(projectFile dao.ProjectFile) error {
  84. return projectFile.CreateFile()
  85. }
  86. func (ps *ProjectService) CreateOrUpdateWorkingHours(workingHours dao.ProjectWorkingHours) error {
  87. // 查询是否已有工时
  88. hours, err := dao.QueryWorkingHoursByCode(workingHours.ProjectCode, workingHours.People)
  89. if err != nil { // 创建时没有id 判断是创建还是修改
  90. // 新增工时+已有工时
  91. zongHours := hours.Days + workingHours.Days
  92. workingHours.Days = zongHours
  93. err = workingHours.UpdateWorkingHours()
  94. return err
  95. } else {
  96. err := workingHours.CreateWorkingHours()
  97. if err != nil {
  98. return err
  99. }
  100. return err
  101. }
  102. }
  103. func (ps *ProjectService) CreateCollection(collection dao.Collection) error {
  104. return collection.CreateCollection()
  105. }
  106. func (ps *ProjectService) CreateReimbursement(reimbursement dao.Reimbursement) error {
  107. return reimbursement.CreateReimbursement()
  108. }
  109. func (ps *ProjectService) UpdateProject(project dao.Project) error {
  110. return project.UpdateProject()
  111. }
  112. func (ps *ProjectService) UpdateWorkingHours(workingHours dao.ProjectWorkingHours) error {
  113. return workingHours.UpdateWorkingHours()
  114. }
  115. func (ps *ProjectService) UpdateCollection(collection dao.Collection) error {
  116. return collection.UpdateCollection()
  117. }
  118. func (ps *ProjectService) UpdateReimbursement(reimbursement dao.Reimbursement) error {
  119. return reimbursement.UpdateReimbursement()
  120. }
  121. func (ps *ProjectService) DeleteProject(code string) error {
  122. return dao.DeleteProject(code)
  123. }
  124. func (ps *ProjectService) DeleteProjectFile(id uint) error {
  125. return dao.DeleteFile(id)
  126. }
  127. func (ps *ProjectService) DeleteWorkingHours(workingHours dao.ProjectWorkingHours) error {
  128. return workingHours.DeleteWorkingHours()
  129. }
  130. func (ps *ProjectService) DeleteCollection(collection dao.Collection) error {
  131. return collection.DeleteCollection()
  132. }
  133. func (ps *ProjectService) DeleteReimbursement(reimbursement dao.Reimbursement) error {
  134. return reimbursement.DeleteReimbursement()
  135. }