'integer', 'spu_id' => 'integer', 'chef_id' => 'integer', 'total_stock' => 'integer', 'surplus_stock' => 'integer', 'sales_num' => 'integer', 'order_num' => 'integer', 'cancel_num' => 'integer', 'refund_num' => 'integer', 'saleable' => 'integer', 'sort' => 'integer', 'is_add_staple_food' => 'integer', 'code_number' => 'integer', 'occupied' => 'integer', ]; const string CREATED_AT = 'create_time'; const string UPDATED_AT = 'update_time'; /** * @param int $id * @return Builder|\Hyperf\Database\Model\Model|null */ public function getInfoById(int $id): \Hyperf\Database\Model\Model|Builder|null { return $this->where('id',$id)->where('is_del',GoodCode::SKU_IS_NO_DEL)->first(); } /** * @param array $spuIds * @return Collection */ public function getListBySpuIds(array $spuIds): Collection { return $this ->whereIn('spu_id',$spuIds) ->where('is_del',GoodCode::SKU_IS_NO_DEL) ->where('saleable',GoodCode::LISTING) // ->where('is_add_staple_food',GoodCode::IS_NOT_ADD_STAPLE_FOOD) ->orderBy('sort') ->select(['id','spu_id','title','image_ids','price','param','extra','total_stock','surplus_stock','order_num','is_add_staple_food','occupied','chef_id']) ->get(); } /** * @param array $spuIds * @return \Hyperf\Database\Model\Model|\Hyperf\Database\Query\Builder|null */ public function getAddStapleFoodListBySpuIds(array $spuIds): \Hyperf\Database\Query\Builder|\Hyperf\Database\Model\Model|null { return $this ->whereIn('spu_id',$spuIds) ->where('is_del',GoodCode::SKU_IS_NO_DEL) ->where('saleable',GoodCode::LISTING) ->where('is_add_staple_food',GoodCode::IS_ADD_STAPLE_FOOD) ->orderBy('sort') ->select(['id','spu_id','title','image_ids','price','param','extra','total_stock','surplus_stock','order_num','is_add_staple_food','occupied','chef_id']) ->first(); } /** * @param int $spuId * @return Builder[]|\Hyperf\Database\Model\Collection */ public function getListBySpuId(int $spuId): \Hyperf\Database\Model\Collection|array { return $this ->where('spu_id',$spuId) ->where('is_del',GoodCode::SKU_IS_NO_DEL) ->where('saleable',GoodCode::LISTING) ->orderBy('sort') ->select(['id','spu_id','title','image_ids','price','param','extra','total_stock','surplus_stock','order_num','is_add_staple_food','occupied','chef_id','sub_title']) ->get(); } /** * @param array $ids * @return array */ public function getDataArrByIds(array $ids): array { $res = $this ->whereIn('id',$ids) ->orderBy('sort') ->get(); if ($res->isEmpty()) return []; return $res->toArray(); } }