product_service.go 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252
  1. package service
  2. import (
  3. "errors"
  4. "time"
  5. "youngee_b_api/app/dao"
  6. "youngee_b_api/app/entity"
  7. "youngee_b_api/app/vo"
  8. )
  9. type ProductService struct{}
  10. func (p ProductService) GetTaskProductsByUserId(param vo.GetAllProductParam) (vo.ResultVO, error) {
  11. if param.Page == 0 {
  12. param.Page = 1
  13. }
  14. if param.PageSize == 0 {
  15. param.PageSize = 10
  16. }
  17. var result vo.ResultVO
  18. var products []entity.Product
  19. var err error
  20. var total int64
  21. //if param.SubAccountId == 0 {
  22. // enterpriseId := param.EnterpriseId
  23. // if enterpriseId == "" {
  24. // return result, errors.New("enterpriseId is empty")
  25. // }
  26. // products, total, err = (&dao.ProductDAO{}).GetProductsByEnterpriseID(enterpriseId, param.Page, param.PageSize)
  27. //} else {
  28. // products, total, err = (&dao.ProductDAO{}).GetProductsBySubAccountId(param.SubAccountId, param.Page, param.PageSize)
  29. //}
  30. enterpriseId := param.EnterpriseId
  31. if enterpriseId == "" {
  32. return result, errors.New("enterpriseId is empty")
  33. }
  34. products, total, err = (&dao.ProductDAO{}).GetProductsByEnterpriseIDAndTypeTitle(enterpriseId, param.ProductType, param.ProductTitle, param.Page, param.PageSize)
  35. if err != nil {
  36. // 数据库查询error
  37. return result, err
  38. }
  39. var reProducts []vo.ReProductPreview
  40. for _, product := range products {
  41. var createrName string
  42. photoUrl, e := dao.ProductPhotoDAO{}.GetMainPhotoByProductID(product.ProductID)
  43. if e != nil {
  44. photoUrl = ""
  45. }
  46. if product.SubAccountID == 0 {
  47. enterprise, err := dao.EnterpriseDao{}.GetEnterprise(product.EnterpriseID)
  48. if err == nil && enterprise != nil {
  49. createrName = enterprise.BusinessName
  50. }
  51. } else {
  52. subAccount, err := dao.SubAccountDao{}.GetSubAccount(product.SubAccountID)
  53. if err == nil && subAccount != nil {
  54. createrName = subAccount.SubAccountName
  55. }
  56. }
  57. reProduct := vo.ReProductPreview{
  58. ProductID: product.ProductID,
  59. ProductName: product.ProductName,
  60. ProductType: product.ProductType,
  61. ProductCategory: product.ProductCategory,
  62. ProductPrice: product.ProductPrice,
  63. ProductDetail: product.ProductDetail,
  64. CreatedAt: product.CreatedAt.Format("2006-01-02 15:04:05"),
  65. PhotoUrl: photoUrl,
  66. CreateName: createrName,
  67. }
  68. reProducts = append(reProducts, reProduct)
  69. }
  70. result = vo.ResultVO{
  71. Page: param.Page,
  72. PageSize: param.PageSize,
  73. Total: total,
  74. Data: reProducts,
  75. }
  76. return result, nil
  77. }
  78. func (p ProductService) CreateProduct(productCreateParam *vo.ProductCreateParam) (int64, error) {
  79. if len(productCreateParam.ProductPhotos) == 0 {
  80. return 0, errors.New("商品主图不能为空!")
  81. }
  82. if productCreateParam.ProductType == 1 {
  83. count := dao.ProductDAO{}.CheckKuaishouProduct(productCreateParam.EnterpriseId, productCreateParam.ProductId)
  84. if count > 0 {
  85. return 0, errors.New("该快手商品已存在!")
  86. }
  87. }
  88. product := entity.Product{
  89. ProductType: productCreateParam.ProductType,
  90. KuaishouProductId: productCreateParam.ProductId,
  91. ProductName: productCreateParam.ProductName,
  92. ProductCategory: productCreateParam.ProductCategory,
  93. ProductPrice: productCreateParam.ProductPrice,
  94. ProductDetail: productCreateParam.ProductDetail,
  95. EnterpriseID: productCreateParam.EnterpriseId,
  96. SubAccountID: productCreateParam.SubAccountId,
  97. ExclusiveCommission: productCreateParam.ExclusiveCommission,
  98. CommissionPrice: productCreateParam.CommissionPrice,
  99. PublicCommission: productCreateParam.PublicCommission,
  100. ProductUrl: productCreateParam.ProductUrl,
  101. }
  102. productID, err := dao.ProductDAO{}.CreateProduct(product)
  103. if err != nil {
  104. return 0, err
  105. }
  106. if productCreateParam.ProductPhotos != nil {
  107. productPhotos := []entity.ProductPhoto{}
  108. for _, photo := range productCreateParam.ProductPhotos {
  109. productPhoto := entity.ProductPhoto{
  110. PhotoUrl: photo.PhotoUrl,
  111. PhotoUid: photo.PhotoUid,
  112. Symbol: photo.Symbol,
  113. ProductID: productID,
  114. CreatedAt: time.Now(),
  115. }
  116. productPhotos = append(productPhotos, productPhoto)
  117. }
  118. err = dao.ProductPhotoDAO{}.CreateProductPhoto(productPhotos)
  119. if err != nil {
  120. return 0, err
  121. }
  122. }
  123. return productID, nil
  124. }
  125. // 商品详情
  126. func (s ProductService) GetProductDetail(param *vo.ProductSearchParam) (*vo.ReProductInfo, error) {
  127. var reProductInfo *vo.ReProductInfo
  128. product, err := dao.ProductDAO{}.GetProductByID(param.ProductId)
  129. if err != nil {
  130. return nil, err
  131. }
  132. photoMain, _ := dao.ProductPhotoDAO{}.GetMainPhotoByProductID(param.ProductId)
  133. photosAll, _ := dao.ProductPhotoDAO{}.GetProductPhotoByProductID(param.ProductId)
  134. var photoRotates []vo.Photo
  135. var photoDetails []vo.Photo
  136. for _, photosOne := range photosAll {
  137. if photosOne.Symbol == 2 || photosOne.Symbol == 3 {
  138. photo := vo.Photo{
  139. PhotoUrl: photosOne.PhotoUrl,
  140. Symbol: photosOne.Symbol,
  141. }
  142. photoRotates = append(photoRotates, photo)
  143. } else if photosOne.Symbol == 4 || photosOne.Symbol == 5 {
  144. photo := vo.Photo{
  145. PhotoUrl: photosOne.PhotoUrl,
  146. Symbol: photosOne.Symbol,
  147. }
  148. photoDetails = append(photoDetails, photo)
  149. }
  150. }
  151. reProductInfo = &vo.ReProductInfo{
  152. ProductID: product.ProductID,
  153. ProductName: product.ProductName,
  154. ProductCategory: product.ProductCategory,
  155. ProductPrice: product.ProductPrice,
  156. ExclusiveCommission: product.ExclusiveCommission,
  157. CommissionPrice: product.CommissionPrice,
  158. ProductDetail: product.ProductDetail,
  159. ProductUrl: product.ProductUrl,
  160. PhotoMain: photoMain,
  161. PhotoRotates: photoRotates,
  162. PhotoDetails: photoDetails,
  163. CreatedAt: product.CreatedAt.Format("2006-01-02 15:04:05"),
  164. }
  165. return reProductInfo, nil
  166. }
  167. // 更新商品
  168. func (p ProductService) UpdateProduct(param *vo.ProductUpdateParam) (int64, error) {
  169. newProduct := entity.Product{
  170. ProductID: param.ProductId,
  171. ProductName: param.ProductName,
  172. ProductCategory: param.ProductCategory,
  173. ProductPrice: param.ProductPrice,
  174. ExclusiveCommission: param.ExclusiveCommission,
  175. CommissionPrice: param.CommissionPrice,
  176. ProductDetail: param.ProductDetail,
  177. ProductUrl: param.ProductUrl,
  178. UpdatedAt: time.Now(),
  179. }
  180. productId, err := dao.ProductDAO{}.UpdateProduct(newProduct)
  181. if err != nil {
  182. return 0, err
  183. }
  184. if param.ProductPhotos != nil {
  185. productPhotos := []entity.ProductPhoto{}
  186. for _, photo := range param.ProductPhotos {
  187. productPhoto := entity.ProductPhoto{
  188. PhotoUrl: photo.PhotoUrl,
  189. PhotoUid: photo.PhotoUid,
  190. Symbol: photo.Symbol,
  191. StoreID: productId,
  192. ProductPhotoType: 1,
  193. CreatedAt: time.Now(),
  194. }
  195. productPhotos = append(productPhotos, productPhoto)
  196. }
  197. err = dao.ProductPhotoDAO{}.CreateProductPhoto(productPhotos)
  198. if err != nil {
  199. return 0, err
  200. }
  201. }
  202. return productId, nil
  203. }
  204. // 删除商品
  205. func (p ProductService) DeleteProduct(param *vo.ProductUpdateParam) (int64, error) {
  206. err := dao.ProductDAO{}.DeleteProduct(param.ProductId)
  207. if err != nil {
  208. return 0, err
  209. }
  210. return param.ProductId, nil
  211. }
  212. // 商品列表-角标
  213. func (t ProductService) CountProduct(param *vo.GetAllProductParam) map[string]int64 {
  214. res := make(map[string]int64)
  215. var commonProduct int64
  216. var kuaishouProduct int64
  217. if param.ProductTitle != "" {
  218. dao.Db.Model(&entity.Product{}).Where("enterprise_id = ? sub_account_id = ? and product_type = ? AND is_deleted = 0 and product_name LIKE ?", param.EnterpriseId, param.SubAccountId, 0, "%"+param.ProductTitle+"%").Count(&commonProduct)
  219. dao.Db.Model(&entity.Product{}).Where("enterprise_id = ? sub_account_id = ? and product_type = ? AND is_deleted = 0 and product_name LIKE ?", param.EnterpriseId, param.SubAccountId, 1, "%"+param.ProductTitle+"%").Count(&kuaishouProduct)
  220. } else {
  221. dao.Db.Model(&entity.Product{}).Where("enterprise_id = ? sub_account_id = ? and product_type = ? AND is_deleted = 0", param.EnterpriseId, param.SubAccountId, 0).Count(&commonProduct)
  222. dao.Db.Model(&entity.Product{}).Where("enterprise_id = ? sub_account_id = ? and product_type = ? AND is_deleted = 0", param.EnterpriseId, param.SubAccountId, 1).Count(&kuaishouProduct)
  223. }
  224. res["commonProduct"] = commonProduct
  225. res["kuaishouProduct"] = kuaishouProduct
  226. return res
  227. }
  228. // 获取商品类目
  229. func (p ProductService) GetProductCategorys() ([]string, error) {
  230. var categorys []string
  231. productCategorys, err := dao.ProductDAO{}.GetProductCategorys()
  232. if err != nil {
  233. return nil, err
  234. }
  235. for _, productCategory := range productCategorys {
  236. categorys = append(categorys, productCategory.ProductCategory)
  237. }
  238. return categorys, nil
  239. }