You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

240 lines
7.9 KiB

5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
  1. <?php
  2. namespace App\Service\v3\Implementations;
  3. use App\Commons\Log;
  4. use App\Constants\v3\ErrorCode;
  5. use App\Constants\v3\LogLabel;
  6. use App\Exception\ErrorCodeException;
  7. use App\Service\v3\Interfaces\GoodsInventoryServiceInterface;
  8. use App\Service\v3\Interfaces\GoodsServiceInterface;
  9. use App\Model\v3\Goods;
  10. use App\Model\v3\GoodsBanner;
  11. use Hyperf\Redis\Redis;
  12. use Hyperf\Utils\ApplicationContext;
  13. use Hyperf\Di\Annotation\Inject;
  14. class GoodsService implements GoodsServiceInterface
  15. {
  16. /**
  17. * @Inject
  18. * @var Log
  19. */
  20. protected $log;
  21. /**
  22. * @Inject
  23. * @var GoodsInventoryServiceInterface
  24. */
  25. protected $goodsInventoryService;
  26. public function do($goodsId)
  27. {
  28. }
  29. public function check(Goods $goods,$num = 1)
  30. {
  31. if (empty($goods)) {
  32. return ErrorCode::GOODS_NOT_EXISTS;
  33. }
  34. // 商户歇业
  35. if(is_null($goods->store) || $goods->store->is_open == 0 || $goods->store->is_rest == 1){
  36. return ErrorCode::STORE_REST;
  37. }
  38. // 商品下架或已删除
  39. if($goods->on_sale == 0 || !is_null($goods->deleted_at)){
  40. return ErrorCode::GOODS_ON_SALE_NO;
  41. }
  42. // 商品库存不足
  43. // 获取冻结的库存
  44. // $inventoryFrozen = $this->goodsInventoryService->getSold(1, $goods->id);
  45. $inventoryFrozen = 0;
  46. if($goods->is_infinite != 1 && $goods->inventory < ($num+$inventoryFrozen)){
  47. return ErrorCode::GOODS_INVENTORY_ERROR;
  48. }
  49. // 是否超过限购数量
  50. if ($goods->restrict_num != 0 && $goods->restrict_num < $num) {
  51. return ErrorCode::GOODS_RESTRICT_LIMIT;
  52. }
  53. return true;
  54. }
  55. public function undo()
  56. {
  57. // TODO: Implement undo() method.
  58. }
  59. public function getBanner($goodsId)
  60. {
  61. $banner = GoodsBanner::query()->where('goods_id',$goodsId)->orderByDesc('type')->get();
  62. return $banner;
  63. }
  64. public function detail($goodsId)
  65. {
  66. $res = Goods::query()->with(['store' => function($query){
  67. $query->withoutGlobalScope('normal');
  68. }])->where('id',$goodsId)->first();
  69. return $res;
  70. }
  71. public function getByType($storeId,$typeId)
  72. {
  73. return Goods::query()->withoutGlobalScope('normal')->where(['store_id' => $storeId,'category_id' => $typeId])->orderByDesc('on_sale')->orderByDesc('created_at')->get()->toArray();
  74. }
  75. public function create($params)
  76. {
  77. $data =
  78. [
  79. 'market_id' => $params['market_id'],
  80. 'store_id' => $params['store_id'],
  81. 'name' => $params['name'],
  82. 'category_id' => $params['category_id'],
  83. 'goods_category_id' => $params['goods_category_id'],
  84. 'goods_unit' => $params['goods_unit'],
  85. 'price' => $params['price'],
  86. 'original_price' => $params['original_price'],
  87. 'inventory' => $params['inventory'],
  88. 'restrict_num' => $params['restrict_num'],
  89. 'start_num' => $params['start_num'],
  90. 'spec' => $params['spec'],
  91. 'tags' => $params['tags'],
  92. 'remark' => $params['remark'],
  93. 'on_sale' => $params['on_sale'],
  94. 'is_infinite' => $params['is_infinite'],
  95. 'cover_img' => $params['cover_img']
  96. ];
  97. $this->log->event(LogLabel::CREATE_GOODS_LOG, ['logData' => json_encode(
  98. [
  99. 'id' => $params['id'],
  100. 'market_id' => $params['market_id'],
  101. 'store_id' => $params['store_id'],
  102. 'name' => $params['name'],
  103. 'category_id' => $params['category_id'],
  104. 'goods_category_id' => $params['goods_category_id'],
  105. 'goods_unit' => $params['goods_unit'],
  106. 'price' => $params['price'],
  107. 'original_price' => $params['original_price'],
  108. 'inventory' => $params['inventory'],
  109. 'restrict_num' => $params['restrict_num'],
  110. 'start_num' => $params['start_num'],
  111. 'spec' => $params['spec'],
  112. 'tags' => $params['tags'],
  113. 'remark' => $params['remark'],
  114. 'on_sale' => $params['on_sale'],
  115. 'is_infinite' => $params['is_infinite'],
  116. 'user_id' => $params['user_id'],
  117. 'cover_img' => $params['cover_img']
  118. ]
  119. )]);
  120. return Goods::create($data);
  121. }
  122. public function update($params)
  123. {
  124. $goods = Goods::query()->withoutGlobalScope('normal')
  125. ->where(
  126. [
  127. 'id' => $params['id'],
  128. 'market_id' => $params['market_id'],
  129. 'store_id' => $params['store_id']
  130. ]
  131. )
  132. ->update(
  133. [
  134. 'name' => $params['name'],
  135. 'category_id' => $params['category_id'],
  136. 'goods_category_id' => $params['goods_category_id'],
  137. 'goods_unit' => $params['goods_unit'],
  138. 'price' => $params['price'],
  139. 'original_price' => $params['original_price'],
  140. 'inventory' => $params['inventory'],
  141. 'restrict_num' => $params['restrict_num'],
  142. 'start_num' => $params['start_num'],
  143. 'spec' => $params['spec'],
  144. 'tags' => $params['tags'],
  145. 'remark' => $params['remark'],
  146. 'on_sale' => $params['on_sale'],
  147. 'is_infinite' => $params['is_infinite'],
  148. 'cover_img' => $params['cover_img']
  149. ]);
  150. $this->log->event(LogLabel::UPDATE_GOODS_LOG, ['logData' => json_encode(
  151. [
  152. 'id' => $params['id'],
  153. 'market_id' => $params['market_id'],
  154. 'store_id' => $params['store_id'],
  155. 'name' => $params['name'],
  156. 'category_id' => $params['category_id'],
  157. 'goods_category_id' => $params['goods_category_id'],
  158. 'goods_unit' => $params['goods_unit'],
  159. 'price' => $params['price'],
  160. 'original_price' => $params['original_price'],
  161. 'inventory' => $params['inventory'],
  162. 'restrict_num' => $params['restrict_num'],
  163. 'start_num' => $params['start_num'],
  164. 'spec' => $params['spec'],
  165. 'tags' => $params['tags'],
  166. 'remark' => $params['remark'],
  167. 'on_sale' => $params['on_sale'],
  168. 'is_infinite' => $params['is_infinite'],
  169. 'user_id' => $params['user_id'],
  170. 'cover_img' => $params['cover_img']
  171. ]
  172. )]);
  173. return $goods;
  174. }
  175. public function info($goodsId)
  176. {
  177. $res = Goods::query()->withoutGlobalScope('normal')->where('id',$goodsId)->with('banner')->first();
  178. return $res;
  179. }
  180. public function getTags()
  181. {
  182. return [
  183. '新品',
  184. '热销',
  185. '新鲜'
  186. ];
  187. }
  188. public function updateOnSale($goodsId)
  189. {
  190. $goods = Goods::query()->withoutGlobalScope('normal')->find($goodsId);
  191. $onSale = $goods->on_sale + 1;
  192. $goods->on_sale = $onSale % 2;
  193. return $goods->save();
  194. }
  195. public function bannerDelete($bannerId)
  196. {
  197. return GoodsBanner::query()->where('id',$bannerId)->delete();
  198. }
  199. public function bannerCreate($goodsId,$path,$type = 1)
  200. {
  201. $data = [
  202. 'goods_id' => $goodsId,
  203. 'path' => $path,
  204. 'type' => $type
  205. ];
  206. return GoodsBanner::create($data);
  207. }
  208. public function bannerUpdate($bannerId,$goodsId,$path,$type = 1)
  209. {
  210. return GoodsBanner::query()->where([
  211. 'id' => $bannerId,
  212. 'goods_id' => $goodsId
  213. ])
  214. ->update([
  215. 'path' => $path,
  216. 'type' => $type
  217. ]);
  218. }
  219. }