lszyh
parent
1d97d0a0db
commit
ab925a4b92
@ -0,0 +1,78 @@ |
|||||||
|
<?php |
||||||
|
// +---------------------------------------------------------------------- |
||||||
|
// | 萤火商城系统 [ 致力于通过产品和服务,帮助商家高效化开拓市场 ] |
||||||
|
// +---------------------------------------------------------------------- |
||||||
|
// | Copyright (c) 2017~2023 https://www.yiovo.com All rights reserved. |
||||||
|
// +---------------------------------------------------------------------- |
||||||
|
// | Licensed 这不是一个自由软件,不允许对程序代码以任何形式任何目的的再发行 |
||||||
|
// +---------------------------------------------------------------------- |
||||||
|
// | Author: 萤火科技 <admin@yiovo.com> |
||||||
|
// +---------------------------------------------------------------------- |
||||||
|
declare (strict_types=1); |
||||||
|
|
||||||
|
namespace app\store\model; |
||||||
|
|
||||||
|
use app\common\model\RetailOrder as RetailOrderModel; |
||||||
|
|
||||||
|
class RetailOrder extends RetailOrderModel |
||||||
|
{ |
||||||
|
/** |
||||||
|
* 获取订单列表 |
||||||
|
* @param array $param |
||||||
|
* @return \think\Paginator |
||||||
|
*/ |
||||||
|
public function getList(array $param = []): \think\Paginator |
||||||
|
{ |
||||||
|
// 设置查询条件 |
||||||
|
$filter = $this->getFilter($param); |
||||||
|
|
||||||
|
// 获取列表数据 |
||||||
|
$list = $this->alias('order') |
||||||
|
->field('order.*') |
||||||
|
->where($filter) |
||||||
|
->join('user', 'user.user_id = order.user_id') |
||||||
|
->order(['order.create_time' => 'desc']) |
||||||
|
->paginate($param['pageSize'] ?? 15); |
||||||
|
// var_dump($list); |
||||||
|
// exit(); |
||||||
|
//return $list; |
||||||
|
// 加载订单的关联数据 |
||||||
|
return static::preload($list, ['user.avatar']); |
||||||
|
} |
||||||
|
|
||||||
|
/** |
||||||
|
* 设置查询条件 |
||||||
|
* @param array $param |
||||||
|
* @return array |
||||||
|
*/ |
||||||
|
private function getFilter(array $param): array |
||||||
|
{ |
||||||
|
// 设置默认的检索数据 |
||||||
|
$params = $this->setQueryDefaultValue($param, [ |
||||||
|
'user_id' => 0, // 用户ID |
||||||
|
'search' => '', // 查询内容 |
||||||
|
'order_type' => 0, // 充值方式 |
||||||
|
'pay_method' => "", // 充值方式 |
||||||
|
'pay_status' => 0, // 支付状态 |
||||||
|
'betweenTime' => [] // 起止时间 |
||||||
|
]); |
||||||
|
// 检索查询条件 |
||||||
|
$filter = []; |
||||||
|
// 用户ID |
||||||
|
$params['user_id'] > 0 && $filter[] = ['order.user_id', '=', $params['user_id']]; |
||||||
|
// 用户昵称/订单号 |
||||||
|
!empty($params['search']) && $filter[] = ['order.order_no|user.nick_name', 'like', "%{$params['search']}%"]; |
||||||
|
!empty($params['pay_method']) && $filter[] = ['order.pay_method', '=', $params['pay_method']]; |
||||||
|
// 充值方式 |
||||||
|
$params['order_type'] > 0 && $filter[] = ['order.order_type', '=', (int)$params['order_type']]; |
||||||
|
// 支付状态 |
||||||
|
$params['pay_status'] > 0 && $filter[] = ['order.pay_status', '=', (int)$params['pay_status']]; |
||||||
|
// 起止时间 |
||||||
|
if (!empty($params['pay_time'])) { |
||||||
|
$times = between_time($params['pay_time']); |
||||||
|
$filter[] = ['order.pay_time', '>=', $times['start_time']]; |
||||||
|
$filter[] = ['order.pay_time', '<', $times['end_time'] + 86400]; |
||||||
|
} |
||||||
|
return $filter; |
||||||
|
} |
||||||
|
} |
Loading…
Reference in new issue