project_task_info_dao.go 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132
  1. package dao
  2. import (
  3. "youngee_b_api/app/entity"
  4. "youngee_b_api/app/vo"
  5. )
  6. type ProjectTaskInfoDao struct{}
  7. // 获取指定违约类型的种草子任务数量
  8. func (d ProjectTaskInfoDao) CountByDefaultType(projectId string, defaultType int64) int64 {
  9. var total int64
  10. Db.Model(&entity.ProjectTaskInfo{}).Where("project_id = ? AND cur_default_type = ?", projectId, defaultType).Count(&total)
  11. return total
  12. }
  13. // 获取指定任务阶段的种草子任务数量
  14. func (d ProjectTaskInfoDao) CountByTaskStage(projectId string, taskStage int64) int64 {
  15. var total int64
  16. Db.Model(&entity.ProjectTaskInfo{}).Where("project_id = ? AND task_stage = ?", projectId, taskStage).Count(&total)
  17. return total
  18. }
  19. // 获取指定任务阶段的种草子任务
  20. func (d ProjectTaskInfoDao) GetListByTaskStage(projectId string, taskStage int64, time *string, page int, pageSize int) ([]*entity.ProjectTaskInfo, int64, error) {
  21. var taskInfos []*entity.ProjectTaskInfo
  22. var total int64
  23. query := Db.Model(&entity.ProjectTaskInfo{}).Where("project_id = ? AND task_stage = ?", projectId, taskStage)
  24. query.Count(&total)
  25. // 计算偏移量
  26. offset := (page - 1) * pageSize
  27. var err error
  28. if taskStage == 4 {
  29. err = query.Order("create_date desc").Offset(offset).Limit(pageSize).Find(&taskInfos).Error
  30. } else if taskStage == 5 {
  31. err = query.Where("delivery_date >= ?", *time).Order("delivery_date desc").Offset(offset).Limit(pageSize).Find(&taskInfos).Error
  32. } else if taskStage == 6 {
  33. err = query.Order("signed_time desc").Offset(offset).Limit(pageSize).Find(&taskInfos).Error
  34. }
  35. if err != nil {
  36. return nil, 0, err
  37. }
  38. return taskInfos, total, nil
  39. }
  40. // 获取未传初稿的种草子任务数据
  41. func (d ProjectTaskInfoDao) GetListBySketchDefault(param *vo.DefaultSearchParam) ([]entity.ProjectTaskInfo, int64, error) {
  42. projectTaskInfos := []entity.ProjectTaskInfo{}
  43. var total int64
  44. query := Db.Model(&entity.ProjectTaskInfo{}).Where("project_id = ? AND cur_default_type = ?", param.TaskId, 4)
  45. query.Count(&total)
  46. query = query.Select("task_id, talent_id, settle_amount, draft_fee, sketch_missing_time")
  47. offset := (param.Page - 1) * param.PageSize
  48. if err := query.Order("sketch_missing_time desc").Offset(offset).Limit(param.PageSize).Find(&projectTaskInfos).Error; err != nil {
  49. return nil, 0, err
  50. }
  51. return projectTaskInfos, total, nil
  52. }
  53. // 获取未发作品的种草子任务数据
  54. func (d ProjectTaskInfoDao) GetListByLinkDefault(param *vo.DefaultSearchParam) ([]entity.ProjectTaskInfo, int64, error) {
  55. projectTaskInfos := []entity.ProjectTaskInfo{}
  56. var total int64
  57. query := Db.Model(&entity.ProjectTaskInfo{}).Where("project_id = ? AND cur_default_type = ?", param.TaskId, 6)
  58. query.Count(&total)
  59. query = query.Select("task_id, talent_id, settle_amount, draft_fee, link_missing_time")
  60. offset := (param.Page - 1) * param.PageSize
  61. if err := query.Order("link_missing_time desc").Offset(offset).Limit(param.PageSize).Find(&projectTaskInfos).Error; err != nil {
  62. return nil, 0, err
  63. }
  64. return projectTaskInfos, total, nil
  65. }
  66. // 获取未传数据的种草子任务数据
  67. func (d ProjectTaskInfoDao) GetListByDataDefault(param *vo.DefaultSearchParam) ([]entity.ProjectTaskInfo, int64, error) {
  68. projectTaskInfos := []entity.ProjectTaskInfo{}
  69. var total int64
  70. query := Db.Model(&entity.ProjectTaskInfo{}).Where("project_id = ? AND cur_default_type = ?", param.TaskId, 8)
  71. query.Count(&total)
  72. query = query.Select("task_id, talent_id, settle_amount, draft_fee, data_missing_time")
  73. offset := (param.Page - 1) * param.PageSize
  74. if err := query.Order("data_missing_time desc").Offset(offset).Limit(param.PageSize).Find(&projectTaskInfos).Error; err != nil {
  75. return nil, 0, err
  76. }
  77. return projectTaskInfos, total, nil
  78. }
  79. // 获取终止合作的种草子任务数据
  80. func (d ProjectTaskInfoDao) GetListByTerminateDefault(param *vo.DefaultSearchParam) ([]entity.ProjectTaskInfo, int64, error) {
  81. projectTaskInfos := []entity.ProjectTaskInfo{}
  82. var total int64
  83. query := Db.Debug().Model(&entity.ProjectTaskInfo{}).Where("project_id = ? AND task_stage = ?", param.TaskId, 17)
  84. query.Count(&total)
  85. query = query.Select("task_id, talent_id, settle_amount, draft_fee, terminate_time, terminate_reason, terminate_operator_type, terminate_operator")
  86. offset := (param.Page - 1) * param.PageSize
  87. if err := query.Order("terminate_time desc").Offset(offset).Limit(param.PageSize).Find(&projectTaskInfos).Error; err != nil {
  88. return nil, 0, err
  89. }
  90. return projectTaskInfos, total, nil
  91. }
  92. // 获取已解约的种草子任务数据
  93. func (d ProjectTaskInfoDao) GetListByCancelDefault(param *vo.DefaultSearchParam) ([]entity.ProjectTaskInfo, int64, error) {
  94. projectTaskInfos := []entity.ProjectTaskInfo{}
  95. var total int64
  96. query := Db.Debug().Model(&entity.ProjectTaskInfo{}).Where("project_id = ? AND task_stage = ?", param.TaskId, 16)
  97. query.Count(&total)
  98. query = query.Select("task_id, talent_id, settle_amount, draft_fee, cancel_time, cancel_reason, cancel_operator_type, cancel_operator")
  99. offset := (param.Page - 1) * param.PageSize
  100. if err := query.Order("cancel_time desc").Offset(offset).Limit(param.PageSize).Find(&projectTaskInfos).Error; err != nil {
  101. return nil, 0, err
  102. }
  103. return projectTaskInfos, total, nil
  104. }
  105. // 更新字段
  106. func (d ProjectTaskInfoDao) UpdateField(taskId string, updateData map[string]interface{}) error {
  107. err := Db.Model(&entity.ProjectTaskInfo{}).Where("task_id = ?", taskId).Updates(updateData).Error
  108. if err != nil {
  109. return err
  110. }
  111. return nil
  112. }
  113. // 批量更新字段
  114. func (d ProjectTaskInfoDao) UpdateFieldBatch(taskIds []string, updateData map[string]interface{}) error {
  115. err := Db.Model(&entity.ProjectTaskInfo{}).Where("task_id IN ?", taskIds).Updates(updateData).Error
  116. if err != nil {
  117. return err
  118. }
  119. return nil
  120. }