project_task_info_dao.go 4.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  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) GetListBySketchDefault(param *vo.DefaultSearchParam) ([]entity.ProjectTaskInfo, int64, error) {
  21. projectTaskInfos := []entity.ProjectTaskInfo{}
  22. var total int64
  23. query := Db.Model(&entity.ProjectTaskInfo{}).Where("project_id = ? AND cur_default_type = ?", param.TaskId, 4)
  24. query.Count(&total)
  25. query = query.Select("talent_id, settle_amount, draft_fee, sketch_missing_time")
  26. offset := (param.Page - 1) * param.PageSize
  27. if err := query.Order("sketch_missing_time desc").Offset(offset).Limit(param.PageSize).Find(&projectTaskInfos).Error; err != nil {
  28. return nil, 0, err
  29. }
  30. return projectTaskInfos, total, nil
  31. }
  32. // 获取未发作品的种草子任务数据
  33. func (d ProjectTaskInfoDao) GetListByLinkDefault(param *vo.DefaultSearchParam) ([]entity.ProjectTaskInfo, int64, error) {
  34. projectTaskInfos := []entity.ProjectTaskInfo{}
  35. var total int64
  36. query := Db.Model(&entity.ProjectTaskInfo{}).Where("project_id = ? AND cur_default_type = ?", param.TaskId, 6)
  37. query.Count(&total)
  38. query = query.Select("talent_id, settle_amount, draft_fee, link_missing_time")
  39. offset := (param.Page - 1) * param.PageSize
  40. if err := query.Order("link_missing_time desc").Offset(offset).Limit(param.PageSize).Find(&projectTaskInfos).Error; err != nil {
  41. return nil, 0, err
  42. }
  43. return projectTaskInfos, total, nil
  44. }
  45. // 获取未传数据的种草子任务数据
  46. func (d ProjectTaskInfoDao) GetListByDataDefault(param *vo.DefaultSearchParam) ([]entity.ProjectTaskInfo, int64, error) {
  47. projectTaskInfos := []entity.ProjectTaskInfo{}
  48. var total int64
  49. query := Db.Model(&entity.ProjectTaskInfo{}).Where("project_id = ? AND cur_default_type = ?", param.TaskId, 8)
  50. query.Count(&total)
  51. query = query.Select("talent_id, settle_amount, draft_fee, data_missing_time")
  52. offset := (param.Page - 1) * param.PageSize
  53. if err := query.Order("data_missing_time desc").Offset(offset).Limit(param.PageSize).Find(&projectTaskInfos).Error; err != nil {
  54. return nil, 0, err
  55. }
  56. return projectTaskInfos, total, nil
  57. }
  58. // 获取终止合作的种草子任务数据
  59. func (d ProjectTaskInfoDao) GetListByTerminateDefault(param *vo.DefaultSearchParam) ([]entity.ProjectTaskInfo, int64, error) {
  60. projectTaskInfos := []entity.ProjectTaskInfo{}
  61. var total int64
  62. query := Db.Model(&entity.ProjectTaskInfo{}).Where("project_id = ? AND task_stage = ?", param.TaskId, 17)
  63. query.Count(&total)
  64. query = query.Select("talent_id, settle_amount, draft_fee, terminate_time, terminate_reason, terminate_operator_type, terminate_operator")
  65. offset := (param.Page - 1) * param.PageSize
  66. if err := query.Order("terminate_time desc").Offset(offset).Limit(param.PageSize).Find(&projectTaskInfos).Error; err != nil {
  67. return nil, 0, err
  68. }
  69. return projectTaskInfos, total, nil
  70. }
  71. // 获取已解约类型的种草子任务数据
  72. func (d ProjectTaskInfoDao) GetListByCancelDefault(param *vo.DefaultSearchParam) ([]entity.ProjectTaskInfo, int64, error) {
  73. projectTaskInfos := []entity.ProjectTaskInfo{}
  74. var total int64
  75. query := Db.Model(&entity.ProjectTaskInfo{}).Where("project_id = ? AND task_stage = ?", param.TaskId, 16)
  76. query.Count(&total)
  77. query = query.Select("talent_id, settle_amount, draft_fee, cancel_time, cancel_reason, cancel_operator_type, cancel_operator")
  78. offset := (param.Page - 1) * param.PageSize
  79. if err := query.Order("cancel_time desc").Offset(offset).Limit(param.PageSize).Find(&projectTaskInfos).Error; err != nil {
  80. return nil, 0, err
  81. }
  82. return projectTaskInfos, total, nil
  83. }