project.go 26 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658
  1. package service
  2. import (
  3. "context"
  4. "encoding/json"
  5. "fmt"
  6. "math/rand"
  7. "strconv"
  8. "strings"
  9. "time"
  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. "youngee_m_api/util"
  16. "github.com/caixw/lib.go/conv"
  17. "github.com/gin-gonic/gin"
  18. "github.com/sirupsen/logrus"
  19. )
  20. var Project *project
  21. type project struct {
  22. }
  23. func (*project) GetFullProjectList(ctx context.Context, pageSize, pageNum int32, condition *common_model.ProjectCondition, projectType string) (*http_model.FullProjectListData, error) {
  24. fullProjects, total, err := db.GetFullProjectList(ctx, pageSize, pageNum, condition, projectType)
  25. if err != nil {
  26. logrus.WithContext(ctx).Errorf("[project service] call GetFullProjectList error,err:%+v", err)
  27. return nil, err
  28. }
  29. fullProjectListData := new(http_model.FullProjectListData)
  30. fullProjectListData.FullProjectPreview = pack.MGormFullProjectToHttpFullProjectPreview(fullProjects)
  31. fullProjectListData.Total = conv.MustString(total, "")
  32. return fullProjectListData, nil
  33. }
  34. func (*project) GetProjectDetail(ctx context.Context, projectID string) (*http_model.ShowProjectData, error) {
  35. project, err := db.GetProjectDetail(ctx, projectID)
  36. if err != nil {
  37. logrus.WithContext(ctx).Errorf("[project service] call GetPorjectDetail error,err:%+v", err)
  38. return nil, err
  39. }
  40. enterprise, err := db.GetEnterpriseByEnterpriseID(ctx, project.EnterpriseID)
  41. if err != nil {
  42. logrus.WithContext(ctx).Errorf("[project service] call GetEnterpriseByEnterpriseID error,err:%+v", err)
  43. return nil, err
  44. }
  45. user, err := db.GetUserByID(ctx, enterprise.UserID)
  46. if err != nil {
  47. logrus.WithContext(ctx).Errorf("[project service] call GetUserByID error,err:%+v", err)
  48. return nil, err
  49. }
  50. ProjectDetail := http_model.ShowProjectData{
  51. ProjectID: conv.MustString(project.ProjectID, ""),
  52. ProjectName: conv.MustString(project.ProjectName, ""),
  53. ProjectStatus: conv.MustString(project.ProjectStatus, ""),
  54. ProjectType: conv.MustString(project.ProjectType, ""),
  55. ProjectPlatform: conv.MustString(project.ProjectPlatform, ""),
  56. ProjectForm: conv.MustString(project.ProjectForm, ""),
  57. TalentType: conv.MustString(project.TalentType, ""),
  58. RecruitDdl: util.GetTimePointer(project.RecruitDdl),
  59. ContentType: conv.MustString(project.ContentType, ""),
  60. ProjectDetail: conv.MustString(project.ProjectDetail, ""),
  61. ProductID: conv.MustString(project.ProductID, ""),
  62. EnterpriseID: conv.MustString(project.EnterpriseID, ""),
  63. Balance: conv.MustString(enterprise.Balance, ""),
  64. AvailableBalance: conv.MustString(enterprise.AvailableBalance, ""),
  65. EstimatedCost: conv.MustString(project.EstimatedCost, ""),
  66. FailReason: conv.MustString(project.FailReason, ""),
  67. CreateAt: util.GetTimePointer(project.CreatedAt),
  68. UpdateAt: util.GetTimePointer(project.UpdatedAt),
  69. Phone: user.Phone,
  70. FinishAt: util.GetTimePointer(project.FinishAt),
  71. PassAt: util.GetTimePointer(project.PassAt),
  72. PayAt: util.GetTimePointer(project.PayAt),
  73. ProductInfo: conv.MustString(project.ProductSnap, ""),
  74. ProductPhotoInfo: conv.MustString(project.ProductPhotoSnap, ""),
  75. AutoFailAt: util.GetTimePointer(project.AutoFailAt),
  76. SubmitAt: util.GetTimePointer(project.SubmitAt),
  77. }
  78. Strategys, err := db.GetRecruitStrategys(ctx, projectID)
  79. if err != nil {
  80. logrus.WithContext(ctx).Error()
  81. return nil, err
  82. }
  83. for _, strategy := range Strategys {
  84. RecruitStrategy := http_model.ShowRecruitStrategy{
  85. RecruitStrategyID: conv.MustString(strategy.RecruitStrategyID, ""),
  86. FeeForm: conv.MustString(strategy.FeeForm, ""),
  87. StrategyID: conv.MustString(strategy.StrategyID, ""),
  88. FollowersLow: conv.MustString(strategy.FollowersLow, ""),
  89. FollowersUp: conv.MustString(strategy.FollowersUp, ""),
  90. RecruitNumber: conv.MustString(strategy.RecruitNumber, ""),
  91. Offer: conv.MustString(strategy.Offer, ""),
  92. ServiceCharge: conv.MustString(strategy.ServiceCharge, ""),
  93. SelectedNumber: strategy.SelectedNumber,
  94. WaitingNumber: strategy.WaitingNumber,
  95. DeliveredNumber: strategy.DeliveredNumber,
  96. SignedNumber: strategy.SignedNumber,
  97. }
  98. ProjectDetail.RecruitStrategys = append(ProjectDetail.RecruitStrategys, RecruitStrategy)
  99. }
  100. Photos, err := db.GetProjectPhoto(ctx, projectID)
  101. if err != nil {
  102. logrus.WithContext(ctx).Error()
  103. return nil, err
  104. }
  105. for _, Photo := range Photos {
  106. ProjectPhoto := http_model.ShowProjectPhoto{
  107. PhotoUrl: Photo.PhotoUrl,
  108. PhotoUid: Photo.PhotoUid,
  109. }
  110. ProjectDetail.ProjectPhotos = append(ProjectDetail.ProjectPhotos, ProjectPhoto)
  111. }
  112. return &ProjectDetail, nil
  113. }
  114. func (*project) ApproveProject(ctx *gin.Context, data http_model.ApproveProjectRequest) (error, string) {
  115. //fmt.Println("data.IsApprove:", data.IsApprove)
  116. err, message := db.ApproveProject(ctx, data.ProjectId, data.IsApprove)
  117. if err != nil {
  118. logrus.WithContext(ctx).Errorf("[project service] call ChangeTaskStatus error,err:%+v", err)
  119. return err, ""
  120. }
  121. return nil, message
  122. }
  123. func (*project) GetAllProject(ctx context.Context, pageSize, pageNum int32) (*http_model.GetAllProjectData, error) {
  124. allProjectPreviews, total, err := db.GetAllProject(ctx, pageSize, pageNum)
  125. if err != nil {
  126. logrus.WithContext(ctx).Errorf("[project service] call GetAllProject error,err:%+v", err)
  127. return nil, err
  128. }
  129. allProjects := new(http_model.GetAllProjectData)
  130. allProjects.AllProjectPreview = pack.MGormAllProjectToHttpAllProjectPreview(allProjectPreviews)
  131. allProjects.Total = conv.MustString(total, "")
  132. return allProjects, nil
  133. }
  134. func (*project) GetProjectTaskList(ctx context.Context, projectID string, pageSize, pageNum int64, conditions *common_model.TaskConditions) (*http_model.ProjectTaskListData, error) {
  135. projectTasks, total, err := db.GetProjectTaskList(ctx, projectID, pageSize, pageNum, conditions)
  136. if err != nil {
  137. logrus.WithContext(ctx).Errorf("[project service] call GetProjectTaskList error,err:%+v", err)
  138. return nil, err
  139. }
  140. projectTaskListData := new(http_model.ProjectTaskListData)
  141. projectTaskListData.ProjectTaskPreview = pack.MGormProjectTaskToHttpProjectTaskPreview(projectTasks)
  142. projectTaskListData.Total = conv.MustString(total, "")
  143. return projectTaskListData, nil
  144. }
  145. func (*project) Create(ctx context.Context, newProject http_model.CreateProjectRequest, enterpriseID string) (*http_model.CreateProjectData, error) {
  146. fmt.Printf("newProject:%+v\n", newProject)
  147. fmt.Println("newProject.RecruitDdl:", newProject.RecruitDdl)
  148. RecruitDdl := time.Time{} //赋零值
  149. if newProject.RecruitDdl != "" {
  150. RecruitDdl, _ = time.ParseInLocation("2006-01-02 15:04:05", newProject.RecruitDdl, time.Local)
  151. }
  152. // 查询关联商品信息
  153. product, err := db.GetProductByID(ctx, newProject.ProductID)
  154. if err != nil {
  155. return nil, err
  156. }
  157. fmt.Println("product:", product)
  158. productPhotos, err := db.GetProductPhotoByProductID(ctx, newProject.ProductID)
  159. productInfoToJson, _ := json.Marshal(product)
  160. productPhotosToJson, _ := json.Marshal(productPhotos)
  161. // 按照品牌名-商品名对项目进行命名
  162. AutoTaskID, err := db.GetLastAutoTaskID()
  163. if err != nil {
  164. return nil, err
  165. }
  166. AutoDefaultID, err := db.GetLastAutoDefaultID()
  167. if err != nil {
  168. return nil, err
  169. }
  170. projectName := product.BrandName + "-" + product.ProductName
  171. var feeFrom []string
  172. for _, strategy := range newProject.RecruitStrategys {
  173. feeFrom = append(feeFrom, strconv.FormatInt(strategy.FeeForm, 10))
  174. }
  175. var ECost float64 = 0
  176. if newProject.ProjectType == int64(1) {
  177. for _, strategy := range newProject.RecruitStrategys {
  178. // 计算预估成本
  179. var tmpCost float64 = 0
  180. if strategy.FeeForm == 1 {
  181. tmpCost = strategy.ServiceCharge * float64(strategy.RecruitNumber)
  182. } else if strategy.FeeForm == 2 {
  183. tmpCost = strategy.Offer * float64(strategy.RecruitNumber)
  184. }
  185. ECost += tmpCost
  186. }
  187. }
  188. feeForms := strings.Join(feeFrom, ",")
  189. projectInfo := gorm_model.ProjectInfo{}
  190. rand.Seed(time.Now().UnixNano())
  191. td := conv.MustString(time.Now().Day(), "")
  192. for {
  193. if len(td) == 3 {
  194. break
  195. }
  196. td = "0" + td
  197. }
  198. fmt.Printf("RecruitDdl:%+v\n", RecruitDdl)
  199. if newProject.ProjectType == int64(1) {
  200. if newProject.RecruitDdl == "" {
  201. projectInfo = gorm_model.ProjectInfo{
  202. ProjectID: conv.MustString(time.Now().Year(), "")[2:] + td + conv.MustString(rand.Intn(100000-10000)+10000, ""),
  203. ProjectName: projectName,
  204. ProjectStatus: 1,
  205. ProjectType: newProject.ProjectType,
  206. TalentType: newProject.TalentType,
  207. ProjectPlatform: newProject.ProjectPlatform,
  208. ProjectForm: newProject.ProjectForm,
  209. ProjectDetail: newProject.ProjectDetail,
  210. ContentType: newProject.ContentType,
  211. EnterpriseID: enterpriseID,
  212. ProductID: newProject.ProductID,
  213. FeeForm: feeForms,
  214. AutoTaskID: conv.MustInt64(AutoTaskID, 0),
  215. AutoDefaultID: conv.MustInt64(AutoDefaultID, 0),
  216. EstimatedCost: ECost,
  217. IsRead: 0,
  218. ProductSnap: string(productInfoToJson),
  219. ProductPhotoSnap: string(productPhotosToJson),
  220. }
  221. } else {
  222. projectInfo = gorm_model.ProjectInfo{
  223. ProjectID: conv.MustString(time.Now().Year(), "")[2:] + td + conv.MustString(rand.Intn(100000-10000)+10000, ""),
  224. ProjectName: projectName,
  225. ProjectStatus: 1,
  226. ProjectType: newProject.ProjectType,
  227. TalentType: newProject.TalentType,
  228. ProjectPlatform: newProject.ProjectPlatform,
  229. ProjectForm: newProject.ProjectForm,
  230. RecruitDdl: &RecruitDdl,
  231. ProjectDetail: newProject.ProjectDetail,
  232. ContentType: newProject.ContentType,
  233. EnterpriseID: enterpriseID,
  234. ProductID: newProject.ProductID,
  235. FeeForm: feeForms,
  236. AutoTaskID: conv.MustInt64(AutoTaskID, 0),
  237. AutoDefaultID: conv.MustInt64(AutoDefaultID, 0),
  238. EstimatedCost: ECost,
  239. IsRead: 0,
  240. ProductSnap: string(productInfoToJson),
  241. ProductPhotoSnap: string(productPhotosToJson),
  242. }
  243. }
  244. } else {
  245. projectInfo = gorm_model.ProjectInfo{
  246. ProjectID: conv.MustString(time.Now().Year(), "")[2:] + td + conv.MustString(rand.Intn(100000-10000)+10000, ""),
  247. ProjectName: projectName,
  248. ProjectStatus: 1,
  249. ProjectType: newProject.ProjectType,
  250. TalentType: "[]",
  251. ProjectPlatform: newProject.ProjectPlatform,
  252. ProjectForm: newProject.ProjectForm,
  253. ProjectDetail: newProject.ProjectDetail,
  254. ContentType: newProject.ContentType,
  255. EnterpriseID: enterpriseID,
  256. ProductID: newProject.ProductID,
  257. FeeForm: feeForms,
  258. AutoTaskID: conv.MustInt64(AutoTaskID, 0),
  259. AutoDefaultID: conv.MustInt64(AutoDefaultID, 0),
  260. EstimatedCost: ECost,
  261. ProductSnap: string(productInfoToJson),
  262. ProductPhotoSnap: string(productPhotosToJson),
  263. }
  264. }
  265. // db create ProjectInfo
  266. projectID, err := db.CreateProject(ctx, projectInfo)
  267. if err != nil {
  268. return nil, err
  269. }
  270. if len(newProject.ProjectPhotos) != 0 {
  271. var projectPhotos []gorm_model.ProjectPhoto
  272. for _, photo := range newProject.ProjectPhotos {
  273. projectPhoto := gorm_model.ProjectPhoto{
  274. PhotoUrl: photo.PhotoUrl,
  275. PhotoUid: photo.PhotoUid,
  276. ProjectID: projectID,
  277. }
  278. projectPhotos = append(projectPhotos, projectPhoto)
  279. }
  280. // db create ProjectPhoto
  281. err = db.CreateProjectPhoto(ctx, projectPhotos)
  282. if err != nil {
  283. return nil, err
  284. }
  285. }
  286. // build
  287. if newProject.ProjectType == int64(1) && newProject.RecruitStrategys != nil {
  288. var recruitStrategys []gorm_model.RecruitStrategy
  289. for _, strategy := range newProject.RecruitStrategys {
  290. // 查询对应定价策略
  291. pricingStrategy, err := db.GetPricingStrategy(ctx, strategy.FollowersLow, strategy.FollowersUp, strategy.FeeForm, newProject.ProjectPlatform)
  292. if err != nil {
  293. return nil, err
  294. }
  295. // 根据定价策略计算达人所见报价
  296. if strategy.FeeForm == 2 {
  297. strategy.TOffer = strategy.Offer * (1 - conv.MustFloat64(pricingStrategy.ServiceRate, 0)/1000)
  298. }
  299. recruitStrategy := gorm_model.RecruitStrategy{
  300. FeeForm: strategy.FeeForm,
  301. StrategyID: strategy.StrategyID,
  302. FollowersLow: strategy.FollowersLow,
  303. FollowersUp: strategy.FollowersUp,
  304. RecruitNumber: strategy.RecruitNumber,
  305. ServiceCharge: strategy.ServiceCharge,
  306. Offer: strategy.Offer,
  307. TOffer: strategy.TOffer,
  308. ProjectID: projectID,
  309. }
  310. recruitStrategys = append(recruitStrategys, recruitStrategy)
  311. }
  312. err = db.CreateRecruitStrategy(ctx, recruitStrategys)
  313. if err != nil {
  314. return nil, err
  315. }
  316. }
  317. res := &http_model.CreateProjectData{
  318. ProjectID: projectID,
  319. }
  320. return res, nil
  321. }
  322. func (*project) Update(ctx context.Context, newProject http_model.UpdateProjectRequest, enterpriseID string) (*http_model.UpdateProjectData, error) {
  323. //RecruitDdl, _ := time.ParseInLocation("2006-01-02 15:04:05", newProject.RecruitDdl, time.Local)
  324. RecruitDdl := time.Time{} //赋零值
  325. if newProject.RecruitDdl != "" {
  326. RecruitDdl, _ = time.ParseInLocation("2006-01-02 15:04:05", newProject.RecruitDdl, time.Local)
  327. }
  328. oldProject, err3 := db.GetProjectDetail(ctx, newProject.ProjectID)
  329. if err3 != nil {
  330. return nil, err3
  331. }
  332. var feeFrom []string
  333. for _, strategy := range newProject.RecruitStrategys {
  334. feeFrom = append(feeFrom, strconv.FormatInt(strategy.FeeForm, 10))
  335. }
  336. var ECost float64 = 0
  337. if newProject.ProjectType == int64(1) {
  338. for _, strategy := range newProject.RecruitStrategys {
  339. // 计算预估成本
  340. var tmpCost float64 = 0
  341. if strategy.FeeForm == 1 {
  342. tmpCost = strategy.ServiceCharge * float64(strategy.RecruitNumber)
  343. } else if strategy.FeeForm == 2 {
  344. tmpCost = strategy.Offer * float64(strategy.RecruitNumber)
  345. }
  346. ECost += tmpCost
  347. }
  348. }
  349. feeForms := strings.Join(feeFrom, ",")
  350. t := time.Now()
  351. project := gorm_model.ProjectInfo{}
  352. if newProject.RecruitDdl == "" {
  353. project = gorm_model.ProjectInfo{
  354. ProjectType: newProject.ProjectType,
  355. ProjectID: newProject.ProjectID,
  356. TalentType: newProject.TalentType,
  357. ContentType: conv.MustInt64(newProject.ContentType, 0),
  358. ProjectDetail: newProject.ProjectDetail,
  359. ProjectForm: conv.MustInt64(newProject.ProjectForm, 0),
  360. EnterpriseID: enterpriseID,
  361. ProjectStatus: newProject.ProjectStatus,
  362. FeeForm: feeForms,
  363. EstimatedCost: ECost,
  364. SubmitAt: &t,
  365. }
  366. } else {
  367. project = gorm_model.ProjectInfo{
  368. ProjectType: newProject.ProjectType,
  369. ProjectID: newProject.ProjectID,
  370. RecruitDdl: &RecruitDdl,
  371. TalentType: newProject.TalentType,
  372. ContentType: conv.MustInt64(newProject.ContentType, 0),
  373. ProjectDetail: newProject.ProjectDetail,
  374. ProjectForm: conv.MustInt64(newProject.ProjectForm, 0),
  375. EnterpriseID: enterpriseID,
  376. ProjectStatus: newProject.ProjectStatus,
  377. FeeForm: feeForms,
  378. EstimatedCost: ECost,
  379. SubmitAt: &t,
  380. }
  381. }
  382. projectID, err := db.UpdateProject(ctx, project)
  383. if err != nil {
  384. return nil, err
  385. }
  386. // 删除该项目之前的所有图片
  387. err = db.DeleteProjectPhotoByProjectID(ctx, *projectID)
  388. if err != nil {
  389. return nil, err
  390. }
  391. fmt.Printf("照片:\t %+v\n", newProject.ProjectPhotos)
  392. if len(newProject.ProjectPhotos) != 0 {
  393. // 新增图片
  394. var projectPhotos []gorm_model.ProjectPhoto
  395. for _, photo := range newProject.ProjectPhotos {
  396. projectPhoto := gorm_model.ProjectPhoto{
  397. ProjectID: project.ProjectID,
  398. PhotoUrl: photo.PhotoUrl,
  399. PhotoUid: photo.PhotoUid,
  400. }
  401. projectPhotos = append(projectPhotos, projectPhoto)
  402. }
  403. err = db.CreateProjectPhoto(ctx, projectPhotos)
  404. if err != nil {
  405. return nil, err
  406. }
  407. }
  408. // 删除该项目之前的所有策略
  409. err = db.DeleteRecruitStrategyByProjectID(ctx, *projectID)
  410. if err != nil {
  411. return nil, err
  412. }
  413. fmt.Printf("招募策略:%+v \n", newProject.RecruitStrategys)
  414. if newProject.RecruitStrategys != nil && newProject.ProjectType == 1 {
  415. // 新增策略
  416. var RecruitStrategys []gorm_model.RecruitStrategy
  417. for _, Strategy := range newProject.RecruitStrategys {
  418. // 查询对应定价策略
  419. pricingStrategy, err := db.GetPricingStrategy(ctx, Strategy.FollowersLow, Strategy.FollowersUp, Strategy.FeeForm, oldProject.ProjectPlatform)
  420. if err != nil {
  421. return nil, err
  422. }
  423. // 根据定价策略计算达人所见报价
  424. if Strategy.FeeForm == 2 {
  425. Strategy.TOffer = Strategy.Offer * (1 - conv.MustFloat64(pricingStrategy.ServiceRate, 0)/1000)
  426. }
  427. RecruitStrategy := gorm_model.RecruitStrategy{
  428. FeeForm: conv.MustInt64(Strategy.FeeForm, 0),
  429. StrategyID: conv.MustInt64(Strategy.StrategyID, 0),
  430. FollowersLow: conv.MustInt64(Strategy.FollowersLow, 0),
  431. FollowersUp: conv.MustInt64(Strategy.FollowersUp, 0),
  432. RecruitNumber: conv.MustInt64(Strategy.RecruitNumber, 0),
  433. Offer: conv.MustFloat64(Strategy.Offer, 0),
  434. TOffer: conv.MustFloat64(Strategy.TOffer, 0),
  435. ProjectID: project.ProjectID,
  436. }
  437. fmt.Printf("Offer:\t %+v", Strategy.Offer)
  438. RecruitStrategys = append(RecruitStrategys, RecruitStrategy)
  439. }
  440. err = db.CreateRecruitStrategy(ctx, RecruitStrategys)
  441. if err != nil {
  442. return nil, err
  443. }
  444. }
  445. res := &http_model.UpdateProjectData{
  446. ProjectID: *projectID,
  447. }
  448. return res, nil
  449. }
  450. func (*project) GetPorjectDetail(ctx context.Context, projectID string) (*http_model.ShowProjectData, error) {
  451. project, err := db.GetProjectDetail(ctx, projectID)
  452. if err != nil {
  453. logrus.WithContext(ctx).Errorf("[project service] call GetPorjectDetail error,err:%+v", err)
  454. return nil, err
  455. }
  456. enterprise, err := db.GetEnterpriseByEnterpriseID(ctx, project.EnterpriseID)
  457. // fmt.Println("%+v", enterprise.UserID)
  458. if err != nil {
  459. logrus.WithContext(ctx).Errorf("[project service] call GetEnterpriseByEnterpriseID error,err:%+v", err)
  460. return nil, err
  461. }
  462. user, err := db.GetUserByID(ctx, enterprise.UserID)
  463. if err != nil {
  464. logrus.WithContext(ctx).Errorf("[project service] call GetUserByID error,err:%+v", err)
  465. return nil, err
  466. }
  467. ProjectDetail := http_model.ShowProjectData{
  468. ProjectID: project.ProjectID,
  469. ProjectName: conv.MustString(project.ProjectName, ""),
  470. ProjectStatus: conv.MustString(project.ProjectStatus, ""),
  471. ProjectType: conv.MustString(project.ProjectType, ""),
  472. ProjectPlatform: conv.MustString(project.ProjectPlatform, ""),
  473. ProjectForm: conv.MustString(project.ProjectForm, ""),
  474. TalentType: conv.MustString(project.TalentType, ""),
  475. RecruitDdl: util.GetTimePointer(project.RecruitDdl),
  476. ContentType: conv.MustString(project.ContentType, ""),
  477. ProjectDetail: conv.MustString(project.ProjectDetail, ""),
  478. ProductID: conv.MustString(project.ProductID, ""),
  479. EnterpriseID: conv.MustString(project.EnterpriseID, ""),
  480. Balance: conv.MustString(enterprise.Balance, ""),
  481. FailReason: conv.MustString(project.FailReason, ""),
  482. CreateAt: util.GetTimePointer(project.CreatedAt),
  483. UpdateAt: util.GetTimePointer(project.UpdatedAt),
  484. Phone: user.Phone,
  485. FinishAt: util.GetTimePointer(project.FinishAt),
  486. PassAt: util.GetTimePointer(project.PassAt),
  487. PayAt: util.GetTimePointer(project.PayAt),
  488. }
  489. Strategys, err := db.GetRecruitStrategys(ctx, projectID)
  490. fmt.Println("招募策略:", Strategys)
  491. if err != nil {
  492. logrus.WithContext(ctx).Error()
  493. return nil, err
  494. }
  495. for _, strategy := range Strategys {
  496. RecruitStrategy := http_model.ShowRecruitStrategy{
  497. RecruitStrategyID: conv.MustString(strategy.RecruitStrategyID, ""),
  498. FeeForm: conv.MustString(strategy.FeeForm, ""),
  499. StrategyID: conv.MustString(strategy.StrategyID, ""),
  500. FollowersLow: conv.MustString(strategy.FollowersLow, ""),
  501. FollowersUp: conv.MustString(strategy.FollowersUp, ""),
  502. RecruitNumber: conv.MustString(strategy.RecruitNumber, ""),
  503. Offer: conv.MustString(strategy.Offer, ""),
  504. ServiceCharge: conv.MustString(strategy.ServiceCharge, ""),
  505. SelectedNumber: strategy.SelectedNumber,
  506. WaitingNumber: strategy.WaitingNumber,
  507. DeliveredNumber: strategy.DeliveredNumber,
  508. SignedNumber: strategy.SignedNumber,
  509. }
  510. ProjectDetail.RecruitStrategys = append(ProjectDetail.RecruitStrategys, RecruitStrategy)
  511. }
  512. Photos, err := db.GetProjectPhoto(ctx, projectID)
  513. if err != nil {
  514. logrus.WithContext(ctx).Error()
  515. return nil, err
  516. }
  517. for _, Photo := range Photos {
  518. ProjectPhoto := http_model.ShowProjectPhoto{
  519. PhotoUrl: Photo.PhotoUrl,
  520. PhotoUid: Photo.PhotoUid,
  521. }
  522. ProjectDetail.ProjectPhotos = append(ProjectDetail.ProjectPhotos, ProjectPhoto)
  523. }
  524. return &ProjectDetail, nil
  525. }
  526. func (*project) GetTaskLogisticsList(ctx context.Context, projectID string, pageSize, pageNum int64, conditions *common_model.TalentConditions) (*http_model.TaskLogisticsListData, error) {
  527. TaskLogisticss, total, err := db.GetTaskLogisticsList(ctx, projectID, pageSize, pageNum, conditions)
  528. if err != nil {
  529. logrus.WithContext(ctx).Errorf("[project service] call GetTaskLogisticsList error,err:%+v", err)
  530. return nil, err
  531. }
  532. TaskLogisticsListData := new(http_model.TaskLogisticsListData)
  533. TaskLogisticsListData.TaskLogisticsPreview = pack.MGormTaskLogisticsInfoListToHttpTaskLogisticsPreviewList(TaskLogisticss)
  534. TaskLogisticsListData.Total = conv.MustString(total, "")
  535. return TaskLogisticsListData, nil
  536. }
  537. func (*project) ChangeTaskStatus(ctx *gin.Context, data http_model.ProjectChangeTaskStatusRequest) interface{} {
  538. RecruitStrategyIDs, err := db.ChangeTaskStatus(ctx, data.TaskIds, data.TaskStatus)
  539. if err != nil {
  540. logrus.WithContext(ctx).Errorf("[project service] call ChangeTaskStatus error,err:%+v", err)
  541. return err
  542. }
  543. if data.TaskStatus == "2" {
  544. err = db.CalculateSelectedNumberByRecruitStrategyID(ctx, RecruitStrategyIDs, 1)
  545. if err != nil {
  546. logrus.WithContext(ctx).Errorf("[project service] call ChangeTaskStatus error,err:%+v", err)
  547. return err
  548. }
  549. } else {
  550. err = db.CalculateSelectedNumberByRecruitStrategyID(ctx, RecruitStrategyIDs, -1)
  551. if err != nil {
  552. logrus.WithContext(ctx).Errorf("[project service] call ChangeTaskStatus error,err:%+v", err)
  553. return err
  554. }
  555. }
  556. return nil
  557. }
  558. func (*project) ChangeSpecialTaskStatus(ctx *gin.Context, data http_model.ProjectChangeTaskStatusRequest) interface{} {
  559. err := db.ChangeSpecialTaskStatus(ctx, data.TaskIds, data.TaskStatus, data.TaskStage)
  560. if err != nil {
  561. logrus.WithContext(ctx).Errorf("[project service] call ChangeSpecialTaskStatus error,err:%+v", err)
  562. return err
  563. }
  564. for _, taskId := range data.TaskIds {
  565. err = db.CreateMessageByTaskId(ctx, 7, 2, taskId)
  566. if err != nil {
  567. logrus.WithContext(ctx).Errorf("[project service] call CreateMessageByTaskId error,err:%+v", err)
  568. return err
  569. }
  570. }
  571. return nil
  572. }
  573. func (p *project) GetTaskScriptList(ctx *gin.Context, projectID string, pageSize, pageNum int64, conditions *common_model.TalentConditions) (*http_model.TaskScriptListData, error) {
  574. TaskScripts, total, err := db.GetTaskScriptList(ctx, projectID, pageSize, pageNum, conditions)
  575. if err != nil {
  576. logrus.WithContext(ctx).Errorf("[project service] call GetTaskScriptList error,err:%+v", err)
  577. return nil, err
  578. }
  579. TaskScriptListData := new(http_model.TaskScriptListData)
  580. TaskScriptListData.TaskScriptPreview = pack.MGormTaskScriptInfoListToHttpTaskScriptPreviewList(TaskScripts)
  581. TaskScriptListData.Total = conv.MustString(total, "")
  582. return TaskScriptListData, nil
  583. }
  584. func (p *project) GetTaskSketchList(ctx *gin.Context, projectID string, pageSize, pageNum int64, conditions *common_model.TalentConditions) (*http_model.TaskSketchListData, error) {
  585. TaskSketchs, total, err := db.GetTaskSketchList(ctx, projectID, pageSize, pageNum, conditions)
  586. if err != nil {
  587. logrus.WithContext(ctx).Errorf("[project service] call GetTaskSketchList error,err:%+v", err)
  588. return nil, err
  589. }
  590. TaskSketchListData := new(http_model.TaskSketchListData)
  591. TaskSketchListData.TaskSketchPreview = pack.MGormTaskSketchInfoListToHttpTaskSketchPreviewList(TaskSketchs)
  592. TaskSketchListData.Total = conv.MustString(total, "")
  593. return TaskSketchListData, nil
  594. }
  595. func (p *project) GetTaskLinkList(ctx *gin.Context, projectID string, pageSize, pageNum int64, conditions *common_model.TalentConditions) (*http_model.TaskLinkListData, error) {
  596. TaskLinks, total, err := db.GetTaskLinkList(ctx, projectID, pageSize, pageNum, conditions)
  597. if err != nil {
  598. logrus.WithContext(ctx).Errorf("[project service] call GetTaskLinkList error,err:%+v", err)
  599. return nil, err
  600. }
  601. TaskLinkListData := new(http_model.TaskLinkListData)
  602. TaskLinkListData.TaskLinkPreview = pack.MGormTaskLinkInfoListToHttpTaskLinkPreviewList(TaskLinks)
  603. TaskLinkListData.Total = conv.MustString(total, "")
  604. return TaskLinkListData, nil
  605. }
  606. func (p *project) GetTaskDataList(ctx *gin.Context, projectID string, pageSize, pageNum int64, conditions *common_model.TalentConditions) (*http_model.TaskDataListData, error) {
  607. TaskDatas, total, err := db.GetTaskDataList(ctx, projectID, pageSize, pageNum, conditions)
  608. if err != nil {
  609. logrus.WithContext(ctx).Errorf("[project service] call GetTaskDataList error,err:%+v", err)
  610. return nil, err
  611. }
  612. TaskDataListData := new(http_model.TaskDataListData)
  613. TaskDataListData.TaskDataPreview = pack.MGormTaskDataInfoListToHttpTaskDataPreviewList(TaskDatas)
  614. TaskDataListData.Total = conv.MustString(total, "")
  615. return TaskDataListData, nil
  616. }
  617. func (p *project) GetTaskFinishList(ctx *gin.Context, projectID string, pageSize, pageNum int64, conditions *common_model.TalentConditions) (*http_model.TaskFinishListData, error) {
  618. TaskFinishs, total, err := db.GetTaskFinishList(ctx, pageSize, pageNum, conditions)
  619. if err != nil {
  620. logrus.WithContext(ctx).Errorf("[project service] call GetTaskFinishList error,err:%+v", err)
  621. return nil, err
  622. }
  623. TaskFinishListData := new(http_model.TaskFinishListData)
  624. TaskFinishListData.TaskFinishPreview = pack.MGormTaskFinishInfoListToHttpTaskFinishPreviewList(TaskFinishs)
  625. TaskFinishListData.Total = conv.MustString(total, "")
  626. return TaskFinishListData, nil
  627. }
  628. func (p *project) GetServiceCharge(ctx *gin.Context, data http_model.GetServiceChargeRequest) (*http_model.ServiceChargeData, error) {
  629. pricingStrategy, err := db.GetPricingStrategy(ctx, data.FollowersLow, data.FollowersUp, data.FeeForm, data.Platform)
  630. if err != nil {
  631. return nil, err
  632. }
  633. serviceFee := http_model.ServiceChargeData{
  634. ServiceCharge: pricingStrategy.ServiceCharge,
  635. }
  636. return &serviceFee, nil
  637. }