project.go 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436
  1. package service
  2. import (
  3. "context"
  4. "fmt"
  5. "strconv"
  6. "strings"
  7. "youngee_b_api/db"
  8. "youngee_b_api/model/common_model"
  9. "youngee_b_api/model/gorm_model"
  10. "youngee_b_api/model/http_model"
  11. "youngee_b_api/pack"
  12. "youngee_b_api/util"
  13. "github.com/gin-gonic/gin"
  14. "github.com/issue9/conv"
  15. "github.com/sirupsen/logrus"
  16. )
  17. var Project *project
  18. type project struct {
  19. }
  20. func (*project) Create(ctx context.Context, newProject http_model.CreateProjectRequest, enterpriseID int64) (*http_model.CreateProjectData, error) {
  21. // build gorm_model.ProjectInfo
  22. // 查询关联商品信息
  23. product, err := db.GetProductByID(ctx, newProject.ProductID)
  24. if err != nil {
  25. return nil, err
  26. }
  27. AutoTaskID, err := db.GetLastAutoTaskID()
  28. if err != nil {
  29. return nil, err
  30. }
  31. AutoDefaultID, err := db.GetLastAutoDefaultID()
  32. if err != nil {
  33. return nil, err
  34. }
  35. // 按照品牌名-商品名对项目进行命名
  36. projectName := product.BrandName + "-" + product.ProductName
  37. //feeForm := fmt.Sprintf("[")
  38. feeFrom := []string{}
  39. for _, strategy := range newProject.RecruitStrategys {
  40. //if strategy.StrategyID
  41. feeFrom = append(feeFrom, strconv.FormatInt(strategy.FeeForm, 10))
  42. //feeForm += string(strategy.StrategyID)
  43. }
  44. feeFroms := strings.Join(feeFrom, ",")
  45. projectInfo := gorm_model.ProjectInfo{}
  46. if newProject.ProjectType == int64(1) {
  47. projectInfo = gorm_model.ProjectInfo{
  48. ProjectName: projectName,
  49. ProjectStatus: 1,
  50. ProjectType: newProject.ProjectType,
  51. TalentType: newProject.TalentType,
  52. ProjectPlatform: newProject.ProjectPlatform,
  53. ProjectForm: newProject.ProjectForm,
  54. RecruitDdl: &newProject.RecruitDdl,
  55. ProjectDetail: newProject.ProjectDetail,
  56. ContentType: newProject.ContentType,
  57. EnterpriseID: enterpriseID,
  58. ProductID: newProject.ProductID,
  59. FeeForm: feeFroms,
  60. AutoTaskID: conv.MustInt64(AutoTaskID),
  61. AutoDefaultID: conv.MustInt64(AutoDefaultID),
  62. }
  63. } else {
  64. projectInfo = gorm_model.ProjectInfo{
  65. ProjectName: projectName,
  66. ProjectStatus: 1,
  67. ProjectType: newProject.ProjectType,
  68. TalentType: "[]",
  69. ProjectPlatform: newProject.ProjectPlatform,
  70. ProjectForm: newProject.ProjectForm,
  71. ProjectDetail: newProject.ProjectDetail,
  72. ContentType: newProject.ContentType,
  73. EnterpriseID: enterpriseID,
  74. ProductID: newProject.ProductID,
  75. FeeForm: feeFroms,
  76. AutoTaskID: conv.MustInt64(AutoTaskID),
  77. AutoDefaultID: conv.MustInt64(AutoDefaultID),
  78. }
  79. }
  80. // db create ProjectInfo
  81. projectID, err := db.CreateProject(ctx, projectInfo)
  82. if err != nil {
  83. return nil, err
  84. }
  85. if newProject.ProjectPhotos != nil {
  86. // build []gorm_model.ProjectPhoto
  87. projectPhotos := []gorm_model.ProjectPhoto{}
  88. for _, photo := range newProject.ProjectPhotos {
  89. projectPhoto := gorm_model.ProjectPhoto{
  90. PhotoUrl: photo.PhotoUrl,
  91. PhotoUid: photo.PhotoUid,
  92. ProjectID: *projectID,
  93. }
  94. projectPhotos = append(projectPhotos, projectPhoto)
  95. }
  96. // db create ProjectPhoto
  97. err = db.CreateProjectPhoto(ctx, projectPhotos)
  98. if err != nil {
  99. return nil, err
  100. }
  101. }
  102. // build
  103. if newProject.ProjectType == int64(1) {
  104. recruitStrategys := []gorm_model.RecruitStrategy{}
  105. for _, strategy := range newProject.RecruitStrategys {
  106. recruitStrategy := gorm_model.RecruitStrategy{
  107. FeeForm: strategy.FeeForm,
  108. StrategyID: strategy.StrategyID,
  109. FollowersLow: strategy.FollowersLow,
  110. FollowersUp: strategy.FollowersUp,
  111. RecruitNumber: strategy.RecruitNumber,
  112. Offer: strategy.Offer,
  113. ProjectID: *projectID,
  114. }
  115. recruitStrategys = append(recruitStrategys, recruitStrategy)
  116. }
  117. err = db.CreateRecruitStrategy(ctx, recruitStrategys)
  118. if err != nil {
  119. return nil, err
  120. }
  121. }
  122. res := &http_model.CreateProjectData{
  123. ProjectID: *projectID,
  124. }
  125. fmt.Printf("%+v", res)
  126. return res, nil
  127. }
  128. func (*project) Update(ctx context.Context, newProject http_model.UpdateProjectRequest, enterpriseID int64) (*http_model.UpdateProjectData, error) {
  129. fmt.Println("newproject:", newProject)
  130. project := gorm_model.ProjectInfo{
  131. ProjectID: conv.MustInt64(newProject.ProjectID),
  132. RecruitDdl: &newProject.RecruitDdl,
  133. TalentType: newProject.TalentType,
  134. ContentType: conv.MustInt64(newProject.ContentType),
  135. ProjectDetail: newProject.ProjectDetail,
  136. ProjectForm: conv.MustInt64(newProject.ProjectForm),
  137. EnterpriseID: enterpriseID,
  138. ProjectStatus: conv.MustInt64(newProject.ProjectStatus),
  139. }
  140. projectID, err := db.UpdateProject(ctx, project)
  141. if err != nil {
  142. return nil, err
  143. }
  144. // 删除该项目之前的所有图片
  145. err = db.DeleteProjectPhotoByProjecttID(ctx, *projectID)
  146. if err != nil {
  147. return nil, err
  148. }
  149. fmt.Printf("照片:\t %+v", newProject.ProjectPhotos)
  150. if newProject.ProjectPhotos != nil {
  151. // 新增图片
  152. projectPhotos := []gorm_model.ProjectPhoto{}
  153. for _, photo := range newProject.ProjectPhotos {
  154. projectPhoto := gorm_model.ProjectPhoto{
  155. ProjectID: project.ProjectID,
  156. PhotoUrl: photo.PhotoUrl,
  157. PhotoUid: photo.PhotoUid,
  158. }
  159. projectPhotos = append(projectPhotos, projectPhoto)
  160. }
  161. err = db.CreateProjectPhoto(ctx, projectPhotos)
  162. if err != nil {
  163. return nil, err
  164. }
  165. }
  166. // 删除该项目之前的所有策略
  167. err = db.DeleteRecruitStrategyByProjectID(ctx, *projectID)
  168. if err != nil {
  169. return nil, err
  170. }
  171. //fmt.Printf("策略:\t %+v", newProject.RecruitStrategys)
  172. if newProject.RecruitStrategys != nil {
  173. // 新增策略
  174. RecruitStrategys := []gorm_model.RecruitStrategy{}
  175. for _, Strategy := range newProject.RecruitStrategys {
  176. RecruitStrategy := gorm_model.RecruitStrategy{
  177. FeeForm: conv.MustInt64(Strategy.FeeForm),
  178. StrategyID: conv.MustInt64(Strategy.StrategyID),
  179. FollowersLow: conv.MustInt64(Strategy.FollowersLow),
  180. FollowersUp: conv.MustInt64(Strategy.FollowersUp),
  181. RecruitNumber: conv.MustInt64(Strategy.RecruitNumber),
  182. Offer: conv.MustInt64(Strategy.Offer),
  183. ProjectID: project.ProjectID,
  184. }
  185. fmt.Printf("Offer:\t %+v", Strategy.Offer)
  186. RecruitStrategys = append(RecruitStrategys, RecruitStrategy)
  187. }
  188. err = db.CreateRecruitStrategy(ctx, RecruitStrategys)
  189. if err != nil {
  190. return nil, err
  191. }
  192. }
  193. res := &http_model.UpdateProjectData{
  194. ProjectID: *projectID,
  195. }
  196. return res, nil
  197. }
  198. func (*project) Delete(ctx context.Context, projectID int64) (*http_model.DeleteProjectData, error) {
  199. // 删除该项目之前的所有图片
  200. err := db.DeleteProjectPhotoByProjecttID(ctx, projectID)
  201. if err != nil {
  202. return nil, err
  203. }
  204. // 删除该项目之前的所有策略
  205. err = db.DeleteRecruitStrategyByProjectID(ctx, projectID)
  206. if err != nil {
  207. return nil, err
  208. }
  209. //删除项目
  210. NewProjectID, err1 := db.DeleteProject(ctx, projectID)
  211. if err1 != nil {
  212. return nil, err1
  213. }
  214. res := &http_model.DeleteProjectData{
  215. ProjectID: *NewProjectID,
  216. }
  217. return res, nil
  218. }
  219. func (*project) GetFullProjectList(ctx context.Context, enterpriseID int64, pageSize, pageNum int32, condition *common_model.ProjectCondition) (*http_model.FullProjectListData, error) {
  220. fullProjects, total, err := db.GetFullProjectList(ctx, enterpriseID, pageSize, pageNum, condition)
  221. if err != nil {
  222. logrus.WithContext(ctx).Errorf("[project service] call GetFullProjectList error,err:%+v", err)
  223. return nil, err
  224. }
  225. fullProjectListData := new(http_model.FullProjectListData)
  226. fullProjectListData.FullProjectPreview = pack.MGormFullProjectToHttpFullProjectPreview(fullProjects)
  227. fullProjectListData.Total = conv.MustString(total)
  228. return fullProjectListData, nil
  229. }
  230. func (*project) GetProjectDraftList(ctx context.Context, enterpriseID int64, pageSize, pageNum int32, condition *common_model.ProjectCondition) (*http_model.ProjectDraftListData, error) {
  231. ProjectDrafts, total, err := db.GetProjectDraftList(ctx, enterpriseID, pageSize, pageNum, condition)
  232. if err != nil {
  233. logrus.WithContext(ctx).Errorf("[project service] call GetProjectDraftList error,err:%+v", err)
  234. return nil, err
  235. }
  236. ProjectDraftListData := new(http_model.ProjectDraftListData)
  237. ProjectDraftListData.ProjectDraftPreview = pack.MGormProjectDraftToHttpProjectDraftPreview(ProjectDrafts)
  238. ProjectDraftListData.Total = conv.MustString(total)
  239. return ProjectDraftListData, nil
  240. }
  241. func (*project) GetProjectTaskList(ctx context.Context, projectID string, pageSize, pageNum int64, conditions *common_model.TaskConditions) (*http_model.ProjectTaskListData, error) {
  242. projectTasks, total, err := db.GetProjectTaskList(ctx, projectID, pageSize, pageNum, conditions)
  243. if err != nil {
  244. logrus.WithContext(ctx).Errorf("[project service] call GetProjectTaskList error,err:%+v", err)
  245. return nil, err
  246. }
  247. projectTaskListData := new(http_model.ProjectTaskListData)
  248. projectTaskListData.ProjectTaskPreview = pack.MGormProjectTaskToHttpProjectTaskPreview(projectTasks)
  249. projectTaskListData.Total = conv.MustString(total)
  250. return projectTaskListData, nil
  251. }
  252. func (*project) GetPorjectDetail(ctx context.Context, projectID int64) (*http_model.ShowProjectData, error) {
  253. project, err := db.GetProjectDetail(ctx, projectID)
  254. if err != nil {
  255. logrus.WithContext(ctx).Errorf("[project service] call GetPorjectDetail error,err:%+v", err)
  256. return nil, err
  257. }
  258. enterprise, err := db.GetEnterpriseByEnterpriseID(ctx, project.EnterpriseID)
  259. // fmt.Println("%+v", enterprise.UserID)
  260. if err != nil {
  261. logrus.WithContext(ctx).Errorf("[project service] call GetEnterpriseByEnterpriseID error,err:%+v", err)
  262. return nil, err
  263. }
  264. user, err := db.GetUserByID(ctx, enterprise.UserID)
  265. if err != nil {
  266. logrus.WithContext(ctx).Errorf("[project service] call GetUserByID error,err:%+v", err)
  267. return nil, err
  268. }
  269. // fmt.Println("%+v", user.Phone)
  270. //var RecruitStrategys []http_model.ShowRecruitStrategy
  271. ProjectDetail := http_model.ShowProjectData{
  272. ProjectID: conv.MustString(project.ProjectID),
  273. ProjectName: conv.MustString(project.ProjectName),
  274. ProjectStatus: conv.MustString(project.ProjectStatus),
  275. ProjectType: conv.MustString(project.ProjectType),
  276. ProjectPlatform: conv.MustString(project.ProjectPlatform),
  277. ProjectForm: conv.MustString(project.ProjectForm),
  278. TalentType: conv.MustString(project.TalentType),
  279. RecruitDdl: util.GetTimePoionter(project.RecruitDdl),
  280. ContentType: conv.MustString(project.ContentType),
  281. ProjectDetail: conv.MustString(project.ProjectDetail),
  282. ProductID: conv.MustString(project.ProductID),
  283. EnterpriseID: conv.MustString(project.EnterpriseID),
  284. Balance: conv.MustString(enterprise.Balance),
  285. FailReason: conv.MustString(project.FailReason),
  286. CreateAt: util.GetTimePoionter(project.CreatedAt),
  287. UpdateAt: util.GetTimePoionter(project.UpdatedAt),
  288. Phone: user.Phone,
  289. FinishAt: util.GetTimePoionter(project.FinishAt),
  290. PassAt: util.GetTimePoionter(project.PassAt),
  291. PayAt: util.GetTimePoionter(project.PayAt),
  292. }
  293. Strategys, err := db.GetRecruitStrategys(ctx, projectID)
  294. fmt.Println("招募策略:", Strategys)
  295. if err != nil {
  296. logrus.WithContext(ctx).Error()
  297. return nil, err
  298. }
  299. for _, strategy := range Strategys {
  300. RecruitStrategy := http_model.ShowRecruitStrategy{
  301. RecruitStrategyID: conv.MustString(strategy.RecruitStrategyID),
  302. FeeForm: conv.MustString(strategy.FeeForm),
  303. StrategyID: conv.MustString(strategy.StrategyID),
  304. FollowersLow: conv.MustString(strategy.FollowersLow),
  305. FollowersUp: conv.MustString(strategy.FollowersUp),
  306. RecruitNumber: conv.MustString(strategy.RecruitNumber),
  307. Offer: conv.MustString(strategy.Offer),
  308. ServiceCharge: strategy.ServiceCharge,
  309. SelectedNumber: strategy.SelectedNumber,
  310. WaitingNumber: strategy.WaitingNumber,
  311. DeliveredNumber: strategy.DeliveredNumber,
  312. SignedNumber: strategy.SignedNumber,
  313. }
  314. ProjectDetail.RecruitStrategys = append(ProjectDetail.RecruitStrategys, RecruitStrategy)
  315. }
  316. Photos, err := db.GetProjectPhoto(ctx, projectID)
  317. if err != nil {
  318. logrus.WithContext(ctx).Error()
  319. return nil, err
  320. }
  321. for _, Photo := range Photos {
  322. ProjectPhoto := http_model.ShowProjectPhoto{
  323. PhotoUrl: Photo.PhotoUrl,
  324. PhotoUid: Photo.PhotoUid,
  325. }
  326. ProjectDetail.ProjectPhotos = append(ProjectDetail.ProjectPhotos, ProjectPhoto)
  327. }
  328. return &ProjectDetail, nil
  329. }
  330. func (*project) GetTaskLogisticsList(ctx context.Context, projectID string, pageSize, pageNum int64, conditions *common_model.TalentConditions) (*http_model.TaskLogisticsListData, error) {
  331. TaskLogisticss, total, err := db.GetTaskLogisticsList(ctx, projectID, pageSize, pageNum, conditions)
  332. if err != nil {
  333. logrus.WithContext(ctx).Errorf("[project service] call GetTaskLogisticsList error,err:%+v", err)
  334. return nil, err
  335. }
  336. TaskLogisticsListData := new(http_model.TaskLogisticsListData)
  337. TaskLogisticsListData.TaskLogisticsPreview = pack.MGormTaskLogisticsInfoListToHttpTaskLogisticsPreviewList(TaskLogisticss)
  338. TaskLogisticsListData.Total = conv.MustString(total)
  339. return TaskLogisticsListData, nil
  340. }
  341. func (*project) ChangeTaskStatus(ctx *gin.Context, data http_model.ProjectChangeTaskStatusRequest) interface{} {
  342. RecruitStrategyIDs, err := db.ChangeTaskStatus(ctx, data.TaskIds, data.TaskStatus)
  343. if err != nil {
  344. logrus.WithContext(ctx).Errorf("[project service] call ChangeTaskStatus error,err:%+v", err)
  345. return err
  346. }
  347. if data.TaskStatus == "2" {
  348. err = db.CalculateSelectedNumberByRecruitStrategyID(ctx, RecruitStrategyIDs, 1)
  349. if err != nil {
  350. logrus.WithContext(ctx).Errorf("[project service] call ChangeTaskStatus error,err:%+v", err)
  351. return err
  352. }
  353. } else {
  354. err = db.CalculateSelectedNumberByRecruitStrategyID(ctx, RecruitStrategyIDs, -1)
  355. if err != nil {
  356. logrus.WithContext(ctx).Errorf("[project service] call ChangeTaskStatus error,err:%+v", err)
  357. return err
  358. }
  359. }
  360. return nil
  361. }
  362. func (p *project) GetTaskScriptList(ctx *gin.Context, projectID string, pageSize, pageNum int64, conditions *common_model.TalentConditions) (*http_model.TaskScriptListData, error) {
  363. TaskScripts, total, err := db.GetTaskScriptList(ctx, projectID, pageSize, pageNum, conditions)
  364. if err != nil {
  365. logrus.WithContext(ctx).Errorf("[project service] call GetTaskScriptList error,err:%+v", err)
  366. return nil, err
  367. }
  368. TaskScriptListData := new(http_model.TaskScriptListData)
  369. TaskScriptListData.TaskScriptPreview = pack.MGormTaskScriptInfoListToHttpTaskScriptPreviewList(TaskScripts)
  370. TaskScriptListData.Total = conv.MustString(total)
  371. return TaskScriptListData, nil
  372. }
  373. func (p *project) GetTaskSketchList(ctx *gin.Context, projectID string, pageSize, pageNum int64, conditions *common_model.TalentConditions) (*http_model.TaskSketchListData, error) {
  374. TaskSketchs, total, err := db.GetTaskSketchList(ctx, projectID, pageSize, pageNum, conditions)
  375. if err != nil {
  376. logrus.WithContext(ctx).Errorf("[project service] call GetTaskSketchList error,err:%+v", err)
  377. return nil, err
  378. }
  379. TaskSketchListData := new(http_model.TaskSketchListData)
  380. TaskSketchListData.TaskSketchPreview = pack.MGormTaskSketchInfoListToHttpTaskSketchPreviewList(TaskSketchs)
  381. TaskSketchListData.Total = conv.MustString(total)
  382. return TaskSketchListData, nil
  383. }
  384. func (p *project) GetTaskLinkList(ctx *gin.Context, projectID string, pageSize, pageNum int64, conditions *common_model.TalentConditions) (*http_model.TaskLinkListData, error) {
  385. TaskLinks, total, err := db.GetTaskLinkList(ctx, projectID, pageSize, pageNum, conditions)
  386. if err != nil {
  387. logrus.WithContext(ctx).Errorf("[project service] call GetTaskLinkList error,err:%+v", err)
  388. return nil, err
  389. }
  390. TaskLinkListData := new(http_model.TaskLinkListData)
  391. TaskLinkListData.TaskLinkPreview = pack.MGormTaskLinkInfoListToHttpTaskLinkPreviewList(TaskLinks)
  392. TaskLinkListData.Total = conv.MustString(total)
  393. return TaskLinkListData, nil
  394. }
  395. func (p *project) GetTaskDataList(ctx *gin.Context, projectID string, pageSize, pageNum int64, conditions *common_model.TalentConditions) (*http_model.TaskDataListData, error) {
  396. TaskDatas, total, err := db.GetTaskDataList(ctx, projectID, pageSize, pageNum, conditions)
  397. if err != nil {
  398. logrus.WithContext(ctx).Errorf("[project service] call GetTaskDataList error,err:%+v", err)
  399. return nil, err
  400. }
  401. TaskDataListData := new(http_model.TaskDataListData)
  402. TaskDataListData.TaskDataPreview = pack.MGormTaskDataInfoListToHttpTaskDataPreviewList(TaskDatas)
  403. TaskDataListData.Total = conv.MustString(total)
  404. return TaskDataListData, nil
  405. }
  406. func (p *project) GetTaskFinishList(ctx *gin.Context, projectID string, pageSize, pageNum int64, conditions *common_model.TalentConditions) (*http_model.TaskFinishListData, error) {
  407. TaskFinishs, total, err := db.GetTaskFinishList(ctx, pageSize, pageNum, conditions)
  408. if err != nil {
  409. logrus.WithContext(ctx).Errorf("[project service] call GetTaskFinishList error,err:%+v", err)
  410. return nil, err
  411. }
  412. TaskFinishListData := new(http_model.TaskFinishListData)
  413. TaskFinishListData.TaskFinishPreview = pack.MGormTaskFinishInfoListToHttpTaskFinishPreviewList(TaskFinishs)
  414. TaskFinishListData.Total = conv.MustString(total)
  415. return TaskFinishListData, nil
  416. }