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.

53 lines
1.3 KiB

5 years ago
5 years ago
5 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($goodsId,$num = 1)
  16. {
  17. $data = Goods::query()->with('store')->where('id', $goodsId)->first();
  18. if($data->store->is_rest == 1){
  19. return ErrorCode::GOODS_ON_SALE_NO;
  20. }
  21. if($data->on_sale == 0 || !is_null($data->deleted_at)){
  22. return ErrorCode::GOODS_ON_SALE_NO;
  23. }
  24. if($data->is_infinite != 1 && $data->inventory < $num){
  25. return ErrorCode::GOODS_INVENTORY_ERROR;
  26. }
  27. return true;
  28. }
  29. public function undo()
  30. {
  31. // TODO: Implement undo() method.
  32. }
  33. public function getBanner($goodsId)
  34. {
  35. $banner = GoodsBanner::query()->where('goods_id',$goodsId)->orderByDesc('type')->get();
  36. return $banner;
  37. }
  38. public function detail($goodsId)
  39. {
  40. $res = Goods::query()->with('store')->where('id',$goodsId)->first();
  41. return $res;
  42. }
  43. }