project.go 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207
  1. package admin
  2. import (
  3. "fmt"
  4. "github.com/shopspring/decimal"
  5. "server/dao"
  6. "server/model/common/request"
  7. "time"
  8. )
  9. type ProjectService struct{}
  10. func (ps *ProjectService) QueryProjectList(info request.SearchProject) (list interface{}, total int64, err error) {
  11. limit := info.PageInfo.PageSize
  12. offset := info.PageInfo.PageSize * (info.PageInfo.Page - 1)
  13. project, total, err := dao.QueryProjectList(limit, offset, info.State, info.Name, info.Time)
  14. for i, p := range project {
  15. collection, err := dao.QueryCollection(p.Code)
  16. if err != nil {
  17. return nil, total, err
  18. }
  19. project[i].Collection = collection
  20. }
  21. return project, total, err
  22. }
  23. func (ps *ProjectService) QueryProjectByCode(code string) (project dao.Project, err error) {
  24. project, err = dao.QueryProjectByCode(code)
  25. if err != nil {
  26. return
  27. }
  28. files, err := dao.QueryFilesByCode(code)
  29. if err != nil {
  30. return
  31. }
  32. project.Files = files
  33. return project, err
  34. }
  35. func (ps *ProjectService) QueryFileList(info request.SearchProjectFileList) (list interface{}, total int64, err error) {
  36. limit := info.PageInfo.PageSize
  37. offset := info.PageInfo.PageSize * (info.PageInfo.Page - 1)
  38. files, total, err := dao.QueryFileList(limit, offset, info.Genre, info.Code, info.Name)
  39. return files, total, err
  40. }
  41. func (ps *ProjectService) QueryFilesByNameOrGenre(info request.SearchProjectFileList) ([]dao.ProjectFile, error) {
  42. return dao.QueryFilesByNameOrGenre(info.Genre, info.Code, info.Name)
  43. }
  44. func (ps *ProjectService) QueryAllProject() ([]dao.Project, error) {
  45. return dao.QueryAllProject()
  46. }
  47. func (ps *ProjectService) QueryProjectsInfo() (sum decimal.Decimal, totalProject, completeProject, unCompleteProject int, err error) {
  48. projects, err := dao.QueryAllProject()
  49. if err != nil {
  50. return
  51. }
  52. for _, project := range projects {
  53. totalProject++
  54. if project.State == 3 {
  55. completeProject++
  56. }
  57. sum = sum.Add(project.Price)
  58. }
  59. fmt.Printf("%y", sum)
  60. unCompleteProject = totalProject - completeProject
  61. return
  62. }
  63. func (ps *ProjectService) QueryProjectState() ([]dao.ProjectState, error) {
  64. return dao.QueryProjectState()
  65. }
  66. func (ps *ProjectService) QueryWorkingHours(code string) ([]dao.ProjectWorkingHours, error) {
  67. return dao.QueryWorkingHours(code)
  68. }
  69. func (ps *ProjectService) QueryWorkingHoursList(info request.SearchWorkingHours) (list interface{}, total int64, err error) {
  70. limit := info.PageInfo.PageSize
  71. offset := info.PageInfo.PageSize * (info.PageInfo.Page - 1)
  72. return dao.QueryWorkingHoursList(limit, offset, info.People, info.Code, info.Time, info.YearTime)
  73. }
  74. func (ps *ProjectService) QueryWorkingHoursSum(info request.SearchWorkingHours) (list interface{}, total int64, err error) {
  75. limit := info.PageInfo.PageSize
  76. offset := info.PageInfo.PageSize * (info.PageInfo.Page - 1)
  77. return dao.QueryWorkingHoursSum(limit, offset, info.People, info.Code, info.Time, info.YearTime)
  78. }
  79. func (ps *ProjectService) QueryCollections(code string) ([]dao.Collection, error) {
  80. return dao.QueryCollection(code)
  81. }
  82. func (ps *ProjectService) QueryCollectionList(info request.SearchProjectList) (list interface{}, total int64, err error) {
  83. limit := info.PageInfo.PageSize
  84. offset := info.PageInfo.PageSize * (info.PageInfo.Page - 1)
  85. return dao.QueryCollectionList(limit, offset, info.Code, info.Time)
  86. }
  87. func (ps *ProjectService) QueryReimbursementList(info request.SearchProjectList) (list interface{}, total int64, err error) {
  88. limit := info.PageInfo.PageSize
  89. offset := info.PageInfo.PageSize * (info.PageInfo.Page - 1)
  90. reimbursements, total, err := dao.QueryReimbursementList(limit, offset, info.Code, info.Name, info.Time)
  91. if err != nil {
  92. return nil, 0, err
  93. }
  94. for i, reimbursement := range reimbursements {
  95. details, err := dao.QueryFeeDetails(int(reimbursement.ID))
  96. if err != nil {
  97. return nil, 0, err
  98. }
  99. reimbursements[i].FeeDetails = details
  100. }
  101. return
  102. }
  103. func (ps *ProjectService) QueryReimbursement(code string) ([]dao.Reimbursement, error) {
  104. reimbursements, err := dao.QueryReimbursement(code)
  105. if err != nil {
  106. return nil, err
  107. }
  108. for i, reimbursement := range reimbursements {
  109. details, err := dao.QueryFeeDetails(int(reimbursement.ID))
  110. if err != nil {
  111. return nil, err
  112. }
  113. reimbursements[i].FeeDetails = details
  114. }
  115. return reimbursements, err
  116. }
  117. func (ps *ProjectService) CreateProject(project dao.Project) error {
  118. return project.CreateProject()
  119. }
  120. func (ps *ProjectService) CreateProjectFile(projectFile dao.ProjectFile) error {
  121. return projectFile.CreateFile()
  122. }
  123. func (ps *ProjectService) CreateProjectState(projectState dao.ProjectState) error {
  124. return projectState.CreateProjectState()
  125. }
  126. func (ps *ProjectService) CreateOrUpdateWorkingHours(workingHours dao.ProjectWorkingHours) error {
  127. return workingHours.CreateWorkingHours()
  128. }
  129. func (ps *ProjectService) CreateCollection(collection dao.Collection) error {
  130. return collection.CreateCollection()
  131. }
  132. func (ps *ProjectService) CreateReimbursement(reimbursement dao.Reimbursement) error {
  133. return reimbursement.CreateReimbursement()
  134. }
  135. func (ps *ProjectService) UpdateProject(project dao.Project) error {
  136. if project.State == 3 {
  137. project.CollectionTime = time.Now().Format("2006-01-02 15:04:05")
  138. } else if project.State == 4 || project.State == 5 {
  139. project.EndTime = time.Now().Format("2006-01-02 15:04:05")
  140. }
  141. return project.UpdateProject()
  142. }
  143. func (ps *ProjectService) UpdateProjectState(projectState dao.ProjectState) error {
  144. return projectState.UpdateProjectState()
  145. }
  146. func (ps *ProjectService) UpdateWorkingHours(workingHours dao.ProjectWorkingHours) error {
  147. return workingHours.UpdateWorkingHours()
  148. }
  149. func (ps *ProjectService) UpdateCollection(collection dao.Collection) error {
  150. return collection.UpdateCollection()
  151. }
  152. func (ps *ProjectService) UpdateReimbursement(reimbursement dao.Reimbursement) error {
  153. return reimbursement.UpdateReimbursement()
  154. }
  155. func (ps *ProjectService) DeleteProject(code string) error {
  156. return dao.DeleteProject(code)
  157. }
  158. func (ps *ProjectService) DeleteProjectFile(id uint) error {
  159. return dao.DeleteFile(id)
  160. }
  161. func (ps *ProjectService) DeleteProjectState(projectState dao.ProjectState) error {
  162. return projectState.DeleteProjectState()
  163. }
  164. func (ps *ProjectService) DeleteWorkingHours(workingHours dao.ProjectWorkingHours) error {
  165. return workingHours.DeleteWorkingHours()
  166. }
  167. func (ps *ProjectService) DeleteCollection(collection dao.Collection) error {
  168. return collection.DeleteCollection()
  169. }
  170. func (ps *ProjectService) DeleteReimbursement(reimbursement dao.Reimbursement) error {
  171. return reimbursement.DeleteReimbursement()
  172. }