product_service.go 8.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243
  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. product := entity.Product{
  80. ProductType: productCreateParam.ProductType,
  81. KuaishouProductId: productCreateParam.ProductId,
  82. ProductName: productCreateParam.ProductName,
  83. ProductCategory: productCreateParam.ProductCategory,
  84. ProductPrice: productCreateParam.ProductPrice,
  85. ProductDetail: productCreateParam.ProductDetail,
  86. EnterpriseID: productCreateParam.EnterpriseId,
  87. SubAccountID: productCreateParam.SubAccountId,
  88. ExclusiveCommission: productCreateParam.ExclusiveCommission,
  89. CommissionPrice: productCreateParam.CommissionPrice,
  90. PublicCommission: productCreateParam.PublicCommission,
  91. ProductUrl: productCreateParam.ProductUrl,
  92. }
  93. productID, err := dao.ProductDAO{}.CreateProduct(product)
  94. if err != nil {
  95. return 0, err
  96. }
  97. if productCreateParam.ProductPhotos != nil {
  98. productPhotos := []entity.ProductPhoto{}
  99. for _, photo := range productCreateParam.ProductPhotos {
  100. productPhoto := entity.ProductPhoto{
  101. PhotoUrl: photo.PhotoUrl,
  102. PhotoUid: photo.PhotoUid,
  103. Symbol: photo.Symbol,
  104. ProductID: productID,
  105. CreatedAt: time.Now(),
  106. }
  107. productPhotos = append(productPhotos, productPhoto)
  108. }
  109. err = dao.ProductPhotoDAO{}.CreateProductPhoto(productPhotos)
  110. if err != nil {
  111. return 0, err
  112. }
  113. }
  114. return productID, nil
  115. }
  116. // 商品详情
  117. func (s ProductService) GetProductDetail(param *vo.ProductSearchParam) (*vo.ReProductInfo, error) {
  118. var reProductInfo *vo.ReProductInfo
  119. product, err := dao.ProductDAO{}.GetProductByID(param.ProductId)
  120. if err != nil {
  121. return nil, err
  122. }
  123. photoMain, _ := dao.ProductPhotoDAO{}.GetMainPhotoByProductID(param.ProductId)
  124. photosAll, _ := dao.ProductPhotoDAO{}.GetProductPhotoByProductID(param.ProductId)
  125. var photoRotates []vo.Photo
  126. var photoDetails []vo.Photo
  127. for _, photosOne := range photosAll {
  128. if photosOne.Symbol == 2 || photosOne.Symbol == 3 {
  129. photo := vo.Photo{
  130. PhotoUrl: photosOne.PhotoUrl,
  131. Symbol: photosOne.Symbol,
  132. }
  133. photoRotates = append(photoRotates, photo)
  134. } else if photosOne.Symbol == 4 || photosOne.Symbol == 5 {
  135. photo := vo.Photo{
  136. PhotoUrl: photosOne.PhotoUrl,
  137. Symbol: photosOne.Symbol,
  138. }
  139. photoDetails = append(photoDetails, photo)
  140. }
  141. }
  142. reProductInfo = &vo.ReProductInfo{
  143. ProductID: product.ProductID,
  144. ProductName: product.ProductName,
  145. ProductCategory: product.ProductCategory,
  146. ProductPrice: product.ProductPrice,
  147. ExclusiveCommission: product.ExclusiveCommission,
  148. CommissionPrice: product.CommissionPrice,
  149. ProductDetail: product.ProductDetail,
  150. ProductUrl: product.ProductUrl,
  151. PhotoMain: photoMain,
  152. PhotoRotates: photoRotates,
  153. PhotoDetails: photoDetails,
  154. CreatedAt: product.CreatedAt.Format("2006-01-02 15:04:05"),
  155. }
  156. return reProductInfo, nil
  157. }
  158. // 更新商品
  159. func (p ProductService) UpdateProduct(param *vo.ProductUpdateParam) (int64, error) {
  160. newProduct := entity.Product{
  161. ProductID: param.ProductId,
  162. ProductName: param.ProductName,
  163. ProductCategory: param.ProductCategory,
  164. ProductPrice: param.ProductPrice,
  165. ExclusiveCommission: param.ExclusiveCommission,
  166. CommissionPrice: param.CommissionPrice,
  167. ProductDetail: param.ProductDetail,
  168. ProductUrl: param.ProductUrl,
  169. UpdatedAt: time.Now(),
  170. }
  171. productId, err := dao.ProductDAO{}.UpdateProduct(newProduct)
  172. if err != nil {
  173. return 0, err
  174. }
  175. if param.ProductPhotos != nil {
  176. productPhotos := []entity.ProductPhoto{}
  177. for _, photo := range param.ProductPhotos {
  178. productPhoto := entity.ProductPhoto{
  179. PhotoUrl: photo.PhotoUrl,
  180. PhotoUid: photo.PhotoUid,
  181. Symbol: photo.Symbol,
  182. StoreID: productId,
  183. ProductPhotoType: 1,
  184. CreatedAt: time.Now(),
  185. }
  186. productPhotos = append(productPhotos, productPhoto)
  187. }
  188. err = dao.ProductPhotoDAO{}.CreateProductPhoto(productPhotos)
  189. if err != nil {
  190. return 0, err
  191. }
  192. }
  193. return productId, nil
  194. }
  195. // 删除商品
  196. func (p ProductService) DeleteProduct(param *vo.ProductUpdateParam) (int64, error) {
  197. err := dao.ProductDAO{}.DeleteProduct(param.ProductId)
  198. if err != nil {
  199. return 0, err
  200. }
  201. return param.ProductId, nil
  202. }
  203. // 商品列表-角标
  204. func (t ProductService) CountProduct(param *vo.GetAllProductParam) map[string]int64 {
  205. res := make(map[string]int64)
  206. var commonProduct int64
  207. var kuaishouProduct int64
  208. if param.ProductTitle != "" {
  209. 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)
  210. 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)
  211. } else {
  212. 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)
  213. 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)
  214. }
  215. res["commonProduct"] = commonProduct
  216. res["kuaishouProduct"] = kuaishouProduct
  217. return res
  218. }
  219. // 获取商品类目
  220. func (p ProductService) GetProductCategorys() ([]string, error) {
  221. var categorys []string
  222. productCategorys, err := dao.ProductDAO{}.GetProductCategorys()
  223. if err != nil {
  224. return nil, err
  225. }
  226. for _, productCategory := range productCategorys {
  227. categorys = append(categorys, productCategory.ProductCategory)
  228. }
  229. return categorys, nil
  230. }