['paid', 'status', 'is_writeoff','reservation'], 'between_time' => 'create_time', '%like%' => ['order_id'], ]; } /** * @notes 零售订单列表 * @return array * @throws \think\db\exception\DataNotFoundException * @throws \think\db\exception\DbException * @throws \think\db\exception\ModelNotFoundException * @date 2024/04/27 11:26 */ public function lists(): array { $userId = $this->request->userId; if (!$userId) return []; $data = StoreOrder::with(['store'])->where($this->searchWhere)->where(['uid'=>$userId]) ->limit($this->limitOffset, $this->limitLength) ->order(['id' => 'desc']) ->select() ->each(function ($item) { $item['goods_list'] = StoreOrderCartInfo::where('oid', $item['id']) ->field('id,product_id,cart_num,verify_code,is_writeoff,writeoff_time,cart_info,status') ->limit(3) ->select() ->each(function ($v) use ($item) { $v['store_name'] = ''; $v['image'] = ''; $v['price'] = ''; $v['unit_name']=''; $v['cart_num']=floatval($v['cart_num']); if(isset($v['cart_info'])){ // foreach( $v['cart_info'] as $k=>$vv){ $v['store_name'] =$v['cart_info']['name']; $v['image'] =$v['cart_info'] ['image']; $v['price'] = $v['cart_info']['price']; $v['unit_name']=$v['cart_info']['unit_name']??''; // } } }); $item['goods_count'] = count(explode(',', $item['cart_id'])); if ($item['refund_reason_time']) { $item['refund_reason_time'] = date('Y-m-d H:i:s', $item['refund_reason_time']); } if ($item['pay_time']) { $item['pay_time'] = date('Y-m-d H:i:s', $item['pay_time']); } if($item['verify_img']){ $item['verify_img'] = 'https://'.$this->request->host(true).$item['verify_img']; } if($item['is_writeoff']==0){ $generator = new BarcodeGeneratorPNG(); $tmpFilename = $generator->getBarcode($item['verify_code'], $generator::TYPE_CODE_128); $item['verify_base64'] ='data:image/png;base64,'.base64_encode($tmpFilename); } }) ->toArray(); return $data; } /** * @notes 零售订单数量 * @return int * @date 2024/04/27 11:26 */ public function count(): int { $userId = $this->request->userId; return StoreOrder::where($this->searchWhere)->whereIn('shipping_type',[1,2])->where('uid', $userId)->count(); } }