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.

54 lines
1.3 KiB

6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
  1. <?php
  2. namespace App\Service\v3\Implementations;
  3. use App\Constants\v3\ErrorCode;
  4. use App\Service\v3\Interfaces\GoodsServiceInterface;
  5. use Hyperf\DbConnection\Db;
  6. use App\Model\v3\Goods;
  7. use App\Model\v3\GoodsBanner;
  8. use App\Constants\v3\Store;
  9. use App\Constants\v3\goods as goodsConstants;
  10. class GoodsService implements GoodsServiceInterface
  11. {
  12. public function do($goodsId)
  13. {
  14. }
  15. public function check(Goods $goods,$num = 1)
  16. {
  17. // 商户歇业
  18. if($goods->store->is_rest == 1){
  19. return ErrorCode::GOODS_ON_SALE_NO;
  20. }
  21. // 商品下架或已删除
  22. if($goods->on_sale == 0 || !is_null($goods->deleted_at)){
  23. return ErrorCode::GOODS_ON_SALE_NO;
  24. }
  25. // 商品库存不足
  26. if($goods->is_infinite != 1 && $goods->inventory < $num){
  27. return ErrorCode::GOODS_INVENTORY_ERROR;
  28. }
  29. return true;
  30. }
  31. public function undo()
  32. {
  33. // TODO: Implement undo() method.
  34. }
  35. public function getBanner($goodsId)
  36. {
  37. $banner = GoodsBanner::query()->where('goods_id',$goodsId)->orderByDesc('type')->get();
  38. return $banner;
  39. }
  40. public function detail($goodsId)
  41. {
  42. $res = Goods::query()->with('store')->where('id',$goodsId)->first();
  43. return $res;
  44. }
  45. }