project.go 7.8 KB

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