local_life_task_info_dao.go 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170
  1. package dao
  2. import (
  3. "youngee_b_api/app/entity"
  4. "youngee_b_api/app/vo"
  5. )
  6. type LocalLifeTaskInfoDao struct{}
  7. // 获取指定违约类型的本地生活子任务数量
  8. func (d LocalLifeTaskInfoDao) CountByDefaultType(localId string, defaultType int64) int64 {
  9. var total int64
  10. Db.Model(&entity.LocalLifeTaskInfo{}).Where("local_id = ? AND cur_default_type = ?", localId, defaultType).Count(&total)
  11. return total
  12. }
  13. // 获取指定任务阶段的本地生活子任务数量
  14. func (d LocalLifeTaskInfoDao) CountByTaskStage(localId string, taskStage int64) int64 {
  15. var total int64
  16. Db.Model(&entity.LocalLifeTaskInfo{}).Where("local_id = ? AND task_stage = ?", localId, taskStage).Count(&total)
  17. return total
  18. }
  19. // 获取指定任务阶段的本地生活子任务
  20. func (d LocalLifeTaskInfoDao) GetListByTaskStage(localId string, taskStage int64, time string, page int, pageSize int) ([]*entity.LocalLifeTaskInfo, int64, error) {
  21. var taskInfos []*entity.LocalLifeTaskInfo
  22. var total int64
  23. query := Db.Debug().Model(&entity.LocalLifeTaskInfo{}).Where("local_id = ? AND task_stage = ?", localId, taskStage)
  24. // 计算偏移量
  25. offset := (page - 1) * pageSize
  26. var err error
  27. if taskStage == 4 { // 待预约探店
  28. query.Count(&total)
  29. err = query.Order("select_date asc").Offset(offset).Limit(pageSize).Find(&taskInfos).Error
  30. } else if taskStage == 5 { // 待确认探店
  31. if time != "" {
  32. query = query.Where("DATE(reserve_time) = ?", time)
  33. }
  34. query.Count(&total)
  35. err = query.Order("reserve_time desc").Offset(offset).Limit(pageSize).Find(&taskInfos).Error
  36. }
  37. if err != nil {
  38. return nil, 0, err
  39. }
  40. return taskInfos, total, nil
  41. }
  42. // 获取指定探店状态的本地生活子任务
  43. func (d LocalLifeTaskInfoDao) GetListByBookStatus(localId string, bookStatus int64, time string, page int, pageSize int) ([]*entity.LocalLifeTaskInfo, int64, error) {
  44. var taskInfos []*entity.LocalLifeTaskInfo
  45. var total int64
  46. query := Db.Model(&entity.LocalLifeTaskInfo{}).Where("local_id = ? AND book_status = ?", localId, bookStatus)
  47. // 计算偏移量
  48. offset := (page - 1) * pageSize
  49. var err error
  50. if bookStatus == 5 { // 待探店
  51. if time != "" {
  52. query = query.Where("DATE(explore_time) = ?", time)
  53. }
  54. query.Count(&total)
  55. err = query.Order("explore_time desc").Offset(offset).Limit(pageSize).Find(&taskInfos).Error
  56. } else if bookStatus == 6 { // 已探店
  57. if time != "" {
  58. query = query.Where("DATE(finish_explore_time) = ?", time)
  59. }
  60. query.Count(&total)
  61. err = query.Order("finish_explore_time desc").Offset(offset).Limit(pageSize).Find(&taskInfos).Error
  62. }
  63. if err != nil {
  64. return nil, 0, err
  65. }
  66. return taskInfos, total, nil
  67. }
  68. // 获取未传初稿的本地生活子任务数据
  69. func (d LocalLifeTaskInfoDao) GetListBySketchDefault(param *vo.DefaultSearchParam) ([]entity.LocalLifeTaskInfo, int64, error) {
  70. localTaskInfos := []entity.LocalLifeTaskInfo{}
  71. var total int64
  72. query := Db.Model(&entity.LocalLifeTaskInfo{}).Where("local_id = ? AND cur_default_type = ?", param.TaskId, 4)
  73. query.Count(&total)
  74. query = query.Select("task_id, talent_id, settle_amount, draft_fee, sketch_missing_time, open_id")
  75. offset := (param.Page - 1) * param.PageSize
  76. if err := query.Order("sketch_missing_time desc").Offset(offset).Limit(param.PageSize).Find(&localTaskInfos).Error; err != nil {
  77. return nil, 0, err
  78. }
  79. return localTaskInfos, total, nil
  80. }
  81. // 获取未发作品的本地生活子任务数据
  82. func (d LocalLifeTaskInfoDao) GetListByLinkDefault(param *vo.DefaultSearchParam) ([]entity.LocalLifeTaskInfo, int64, error) {
  83. localTaskInfos := []entity.LocalLifeTaskInfo{}
  84. var total int64
  85. query := Db.Model(&entity.LocalLifeTaskInfo{}).Where("local_id = ? AND cur_default_type = ?", param.TaskId, 6)
  86. query.Count(&total)
  87. query = query.Select("task_id, talent_id, settle_amount, draft_fee, link_missing_time, open_id")
  88. offset := (param.Page - 1) * param.PageSize
  89. if err := query.Order("link_missing_time desc").Offset(offset).Limit(param.PageSize).Find(&localTaskInfos).Error; err != nil {
  90. return nil, 0, err
  91. }
  92. return localTaskInfos, total, nil
  93. }
  94. // 获取未传数据的本地生活子任务数据
  95. func (d LocalLifeTaskInfoDao) GetListByDataDefault(param *vo.DefaultSearchParam) ([]entity.LocalLifeTaskInfo, int64, error) {
  96. localTaskInfos := []entity.LocalLifeTaskInfo{}
  97. var total int64
  98. query := Db.Model(&entity.LocalLifeTaskInfo{}).Where("local_id = ? AND cur_default_type = ?", param.TaskId, 8)
  99. query.Count(&total)
  100. query = query.Select("task_id, talent_id, settle_amount, draft_fee, data_missing_time, open_id")
  101. offset := (param.Page - 1) * param.PageSize
  102. if err := query.Order("data_missing_time desc").Offset(offset).Limit(param.PageSize).Find(&localTaskInfos).Error; err != nil {
  103. return nil, 0, err
  104. }
  105. return localTaskInfos, total, nil
  106. }
  107. // 获取终止合作的本地生活子任务数据
  108. func (d LocalLifeTaskInfoDao) GetListByTerminateDefault(param *vo.DefaultSearchParam) ([]entity.LocalLifeTaskInfo, int64, error) {
  109. localTaskInfos := []entity.LocalLifeTaskInfo{}
  110. var total int64
  111. query := Db.Debug().Model(&entity.LocalLifeTaskInfo{}).Where("local_id = ? AND task_stage = ?", param.TaskId, 17)
  112. query.Count(&total)
  113. query = query.Select("task_id, talent_id, settle_amount, draft_fee, terminate_time, terminate_reason, terminate_operator_type, terminate_operator, open_id")
  114. offset := (param.Page - 1) * param.PageSize
  115. if err := query.Order("terminate_time desc").Offset(offset).Limit(param.PageSize).Find(&localTaskInfos).Error; err != nil {
  116. return nil, 0, err
  117. }
  118. return localTaskInfos, total, nil
  119. }
  120. // 获取已解约的本地生活子任务数据
  121. func (d LocalLifeTaskInfoDao) GetListByCancelDefault(param *vo.DefaultSearchParam) ([]entity.LocalLifeTaskInfo, int64, error) {
  122. localTaskInfos := []entity.LocalLifeTaskInfo{}
  123. var total int64
  124. query := Db.Debug().Model(&entity.LocalLifeTaskInfo{}).Where("local_id = ? AND task_stage = ?", param.TaskId, 16)
  125. query.Count(&total)
  126. query = query.Select("task_id, talent_id, settle_amount, draft_fee, cancel_time, cancel_reason, cancel_operator_type, cancel_operator, open_id")
  127. offset := (param.Page - 1) * param.PageSize
  128. if err := query.Order("cancel_time desc").Offset(offset).Limit(param.PageSize).Find(&localTaskInfos).Error; err != nil {
  129. return nil, 0, err
  130. }
  131. return localTaskInfos, total, nil
  132. }
  133. // 更新字段
  134. func (d LocalLifeTaskInfoDao) UpdateField(taskId string, updateData map[string]interface{}) error {
  135. err := Db.Model(&entity.LocalLifeTaskInfo{}).Where("task_id = ?", taskId).Updates(updateData).Error
  136. if err != nil {
  137. return err
  138. }
  139. return nil
  140. }
  141. // 批量更新字段
  142. func (d LocalLifeTaskInfoDao) UpdateFieldBatch(taskIds []string, updateData map[string]interface{}) error {
  143. err := Db.Model(&entity.LocalLifeTaskInfo{}).Where("task_id IN ?", taskIds).Updates(updateData).Error
  144. if err != nil {
  145. return err
  146. }
  147. return nil
  148. }
  149. // 批量更新字段
  150. func (d LocalLifeTaskInfoDao) UpdateLocalStatus(taskIds []string, localLifeTaskInfo entity.LocalLifeTaskInfo) error {
  151. err := Db.Debug().Model(&entity.LocalLifeTaskInfo{}).Where("task_id IN ?", taskIds).Updates(localLifeTaskInfo).Error
  152. if err != nil {
  153. return err
  154. }
  155. return nil
  156. }