project.go 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285
  1. package service
  2. import (
  3. "context"
  4. "fmt"
  5. "github.com/caixw/lib.go/conv"
  6. "github.com/gin-gonic/gin"
  7. "github.com/sirupsen/logrus"
  8. "strconv"
  9. "strings"
  10. "youngee_m_api/db"
  11. "youngee_m_api/model/common_model"
  12. "youngee_m_api/model/gorm_model"
  13. "youngee_m_api/model/http_model"
  14. "youngee_m_api/pack"
  15. )
  16. var Project *project
  17. type project struct {
  18. }
  19. func (*project) GetFullProjectList(ctx context.Context, pageSize, pageNum int32, condition *common_model.ProjectCondition) (*http_model.FullProjectListData, error) {
  20. fullProjects, total, err := db.GetFullProjectList(ctx, pageSize, pageNum, condition)
  21. if err != nil {
  22. logrus.WithContext(ctx).Errorf("[project service] call GetFullProjectList error,err:%+v", err)
  23. return nil, err
  24. }
  25. fullProjectListData := new(http_model.FullProjectListData)
  26. fullProjectListData.FullProjectPreview = pack.MGormFullProjectToHttpFullProjectPreview(fullProjects)
  27. fullProjectListData.Total = conv.MustString(total, "")
  28. return fullProjectListData, nil
  29. }
  30. func (*project) GetProjectDetail(ctx context.Context, projectID int64) (*http_model.ShowProjectData, error) {
  31. project, err := db.GetProjectDetail(ctx, projectID)
  32. if err != nil {
  33. logrus.WithContext(ctx).Errorf("[project service] call GetPorjectDetail error,err:%+v", err)
  34. return nil, err
  35. }
  36. enterprise, err1 := db.GetEnterpriseByEnterpriseID(ctx, project.EnterpriseID)
  37. fmt.Println("%+v", enterprise.UserID)
  38. if err1 != nil {
  39. logrus.WithContext(ctx).Errorf("[project service] call GetEnterpriseByEnterpriseID error,err:%+v", err1)
  40. return nil, err1
  41. }
  42. user, err2 := db.GetUserByID(ctx, enterprise.UserID)
  43. if err2 != nil {
  44. logrus.WithContext(ctx).Errorf("[project service] call GetUserByID error,err:%+v", err2)
  45. return nil, err2
  46. }
  47. fmt.Println("%+v", user.Phone)
  48. //var RecruitStrategys []http_model.ShowRecruitStrategy
  49. ProjectDetail := http_model.ShowProjectData{
  50. ProjectID: conv.MustString(project.ProjectID, ""),
  51. ProjectName: conv.MustString(project.ProjectName, ""),
  52. ProjectStatus: conv.MustString(project.ProjectStatus, ""),
  53. ProjectType: conv.MustString(project.ProjectType, ""),
  54. ProjectPlatform: conv.MustString(project.ProjectPlatform, ""),
  55. ProjectForm: conv.MustString(project.ProjectForm, ""),
  56. TalentType: conv.MustString(project.TalentType, ""),
  57. RecruitDdl: project.RecruitDdl,
  58. ContentType: conv.MustString(project.ContentType, ""),
  59. ProjectDetail: conv.MustString(project.ProjectDetail, ""),
  60. ProductID: conv.MustString(project.ProductID, ""),
  61. EnterpriseID: conv.MustString(project.EnterpriseID, ""),
  62. Balance: conv.MustString(enterprise.Balance, ""),
  63. CreateAt: project.CreatedAt,
  64. UpdateAt: project.UpdatedAt,
  65. Phone: user.Phone,
  66. }
  67. Strategys, err3 := db.GetRecruitStrategys(ctx, projectID)
  68. if err3 != nil {
  69. logrus.WithContext(ctx).Error()
  70. return nil, err3
  71. }
  72. for _, strategy := range Strategys {
  73. RecruitStrategy := http_model.ShowRecruitStrategy{
  74. FeeForm: conv.MustString(strategy.FeeForm, ""),
  75. StrategyID: conv.MustString(strategy.StrategyID, ""),
  76. FollowersLow: conv.MustString(strategy.FollowersLow, ""),
  77. FollowersUp: conv.MustString(strategy.FollowersUp, ""),
  78. RecruitNumber: conv.MustString(strategy.RecruitNumber, ""),
  79. Offer: conv.MustString(strategy.Offer, ""),
  80. }
  81. ProjectDetail.RecruitStrategys = append(ProjectDetail.RecruitStrategys, RecruitStrategy)
  82. }
  83. Photos, err4 := db.GetProjectPhoto(ctx, projectID)
  84. if err4 != nil {
  85. logrus.WithContext(ctx).Error()
  86. return nil, err4
  87. }
  88. for _, Photo := range Photos {
  89. ProjectPhoto := http_model.ShowProjectPhoto{
  90. PhotoUrl: Photo.PhotoUrl,
  91. PhotoUid: Photo.PhotoUid,
  92. }
  93. ProjectDetail.ProjectPhotos = append(ProjectDetail.ProjectPhotos, ProjectPhoto)
  94. }
  95. return &ProjectDetail, nil
  96. }
  97. func (*project) Update(ctx context.Context, newProject http_model.UpdateProjectRequest, enterpriseID string) (*http_model.UpdateProjectData, error) {
  98. fmt.Println("newproject:", newProject)
  99. project := gorm_model.ProjectInfo{
  100. ProjectID: conv.MustInt64(newProject.ProjectID, 0),
  101. RecruitDdl: newProject.RecruitDdl,
  102. TalentType: newProject.TalentType,
  103. ContentType: conv.MustInt64(newProject.ContentType, 0),
  104. ProjectDetail: newProject.ProjectDetail,
  105. ProjectForm: conv.MustInt64(newProject.ProjectForm, 0),
  106. EnterpriseID: conv.MustInt64(enterpriseID, 0),
  107. ProjectStatus: 4,
  108. }
  109. projectID, err := db.UpdateProject(ctx, project)
  110. if err != nil {
  111. return nil, err
  112. }
  113. // 删除该项目之前的所有图片
  114. err = db.DeleteProjectPhotoByProjecttID(ctx, *projectID)
  115. if err != nil {
  116. return nil, err
  117. }
  118. fmt.Printf("照片:\t %+v", newProject.ProjectPhotos)
  119. if newProject.ProjectPhotos != nil {
  120. // 新增图片
  121. projectPhotos := []gorm_model.ProjectPhoto{}
  122. for _, photo := range newProject.ProjectPhotos {
  123. projectPhoto := gorm_model.ProjectPhoto{
  124. ProjectID: project.ProjectID,
  125. PhotoUrl: photo.PhotoUrl,
  126. PhotoUid: photo.PhotoUid,
  127. }
  128. projectPhotos = append(projectPhotos, projectPhoto)
  129. }
  130. err = db.CreateProjectPhoto(ctx, projectPhotos)
  131. if err != nil {
  132. return nil, err
  133. }
  134. }
  135. // 删除该项目之前的所有策略
  136. err = db.DeleteRecruitStrategyByProjectID(ctx, *projectID)
  137. if err != nil {
  138. return nil, err
  139. }
  140. fmt.Printf("策略:\t %+v", newProject.RecruitStrategys)
  141. if newProject.RecruitStrategys != nil {
  142. // 新增策略
  143. RecruitStrategys := []gorm_model.RecruitStrategy{}
  144. for _, Strategy := range newProject.RecruitStrategys {
  145. RecruitStrategy := gorm_model.RecruitStrategy{
  146. FeeForm: conv.MustInt64(Strategy.FeeForm, 0),
  147. StrategyID: conv.MustInt64(Strategy.StrategyID, 0),
  148. FollowersLow: conv.MustInt64(Strategy.FollowersLow, 0),
  149. FollowersUp: conv.MustInt64(Strategy.FollowersUp, 0),
  150. RecruitNumber: conv.MustInt64(Strategy.RecruitNumber, 0),
  151. Offer: conv.MustInt64(Strategy.Offer, 0),
  152. ProjectID: project.ProjectID,
  153. }
  154. fmt.Printf("Offer:\t %+v", Strategy.Offer)
  155. RecruitStrategys = append(RecruitStrategys, RecruitStrategy)
  156. }
  157. err = db.CreateRecruitStrategy(ctx, RecruitStrategys)
  158. if err != nil {
  159. return nil, err
  160. }
  161. }
  162. res := &http_model.UpdateProjectData{
  163. ProjectID: *projectID,
  164. }
  165. return res, nil
  166. }
  167. func (*project) ApproveProject(ctx *gin.Context, data http_model.ApproveProjectRequest) (error, string) {
  168. fmt.Println("data.IsApprove:", data.IsApprove)
  169. err, message := db.ApproveProject(ctx, data.ProjectId, data.IsApprove)
  170. if err != nil {
  171. logrus.WithContext(ctx).Errorf("[project service] call ChangeTaskStatus error,err:%+v", err)
  172. return err, ""
  173. }
  174. return nil, message
  175. }
  176. func (*project) GetAllProject(ctx context.Context, pageSize, pageNum int32) (*http_model.GetAllProjectData, error) {
  177. allProjectPreviews, total, err := db.GetAllProject(ctx, pageSize, pageNum)
  178. if err != nil {
  179. logrus.WithContext(ctx).Errorf("[project service] call GetAllProject error,err:%+v", err)
  180. return nil, err
  181. }
  182. allProjects := new(http_model.GetAllProjectData)
  183. allProjects.AllProjectPreview = pack.MGormAllProjectToHttpAllProjectPreview(allProjectPreviews)
  184. allProjects.Total = conv.MustString(total, "")
  185. return allProjects, nil
  186. }
  187. func (*project) GetProjectTaskList(ctx context.Context, projectID string, pageSize, pageNum int64, conditions *common_model.TaskConditions) (*http_model.ProjectTaskListData, error) {
  188. projectTasks, total, err := db.GetProjectTaskList(ctx, projectID, pageSize, pageNum, conditions)
  189. if err != nil {
  190. logrus.WithContext(ctx).Errorf("[project service] call GetProjectTaskList error,err:%+v", err)
  191. return nil, err
  192. }
  193. projectTaskListData := new(http_model.ProjectTaskListData)
  194. projectTaskListData.ProjectTaskPreview = pack.MGormProjectTaskToHttpProjectTaskPreview(projectTasks)
  195. projectTaskListData.Total = conv.MustString(total, "")
  196. return projectTaskListData, nil
  197. }
  198. func (*project) Create(ctx context.Context, newProject http_model.CreateProjectRequest, enterpriseID int64) (*http_model.CreateProjectData, error) {
  199. // build gorm_model.ProjectInfo
  200. // 查询关联商品信息
  201. product, err := db.GetProductByID(ctx, newProject.ProductID)
  202. if err != nil {
  203. return nil, err
  204. }
  205. // 按照品牌名-商品名对项目进行命名
  206. projectName := product.BrandName + "-" + product.ProductName
  207. //feeForm := fmt.Sprintf("[")
  208. feeFrom := []string{}
  209. for _, strategy := range newProject.RecruitStrategys {
  210. //if strategy.StrategyID
  211. feeFrom = append(feeFrom, strconv.FormatInt(strategy.FeeForm, 10))
  212. //feeForm += string(strategy.StrategyID)
  213. }
  214. feeFroms := strings.Join(feeFrom, ",")
  215. projectInfo := gorm_model.ProjectInfo{
  216. ProjectName: projectName,
  217. ProjectStatus: 1,
  218. ProjectType: newProject.ProjectType,
  219. TalentType: newProject.TalentType,
  220. ProjectPlatform: newProject.ProjectPlatform,
  221. ProjectForm: newProject.ProjectForm,
  222. RecruitDdl: newProject.RecruitDdl,
  223. ProjectDetail: newProject.ProjectDetail,
  224. ContentType: newProject.ContentType,
  225. EnterpriseID: enterpriseID,
  226. ProductID: newProject.ProductID,
  227. FeeForm: feeFroms,
  228. }
  229. // db create ProjectInfo
  230. projectID, err := db.CreateProject(ctx, projectInfo)
  231. if err != nil {
  232. return nil, err
  233. }
  234. if newProject.ProjectPhotos != nil {
  235. // build []gorm_model.ProjectPhoto
  236. projectPhotos := []gorm_model.ProjectPhoto{}
  237. for _, photo := range newProject.ProjectPhotos {
  238. projectPhoto := gorm_model.ProjectPhoto{
  239. PhotoUrl: photo.PhotoUrl,
  240. PhotoUid: photo.PhotoUid,
  241. ProjectID: *projectID,
  242. }
  243. projectPhotos = append(projectPhotos, projectPhoto)
  244. }
  245. // db create ProjectPhoto
  246. err = db.CreateProjectPhoto(ctx, projectPhotos)
  247. if err != nil {
  248. return nil, err
  249. }
  250. }
  251. // build
  252. recruitStrategys := []gorm_model.RecruitStrategy{}
  253. for _, strategy := range newProject.RecruitStrategys {
  254. recruitStrategy := gorm_model.RecruitStrategy{
  255. FeeForm: strategy.FeeForm,
  256. StrategyID: strategy.StrategyID,
  257. FollowersLow: strategy.FollowersLow,
  258. FollowersUp: strategy.FollowersUp,
  259. RecruitNumber: strategy.RecruitNumber,
  260. Offer: strategy.Offer,
  261. ProjectID: *projectID,
  262. }
  263. recruitStrategys = append(recruitStrategys, recruitStrategy)
  264. }
  265. err = db.CreateRecruitStrategy(ctx, recruitStrategys)
  266. if err != nil {
  267. return nil, err
  268. }
  269. res := &http_model.CreateProjectData{
  270. ProjectID: *projectID,
  271. }
  272. fmt.Printf("%+v", res)
  273. return res, nil
  274. }