<?php
namespace app\store\model\user;
use app\common\model\user\BalanceLog as BalanceLogModel;
class BalanceLog extends BalanceLogModel
{
public function getList($query = [])
{
!empty($query) && $this->setQueryWhere($query);
return $this->with(['user'])
->alias('log')
->field('log.*')
->join('user', 'user.user_id = log.user_id')
->order(['log.create_time' => 'desc'])
->paginate(15, false, [
'query' => \request()->request()
]);
}
private function setQueryWhere($query)
{
$params = $this->setQueryDefaultValue($query, [
'user_id' => 0,
'search' => '',
'scene' => -1,
'start_time' => '',
'end_time' => '',
]);
$params['user_id'] > 0 && $this->where('log.user_id', '=', $params['user_id']);
!empty($params['search']) && $this->where('user.nickName', 'like', "%{$params['search']}%");
$params['scene'] > -1 && $this->where('log.scene', '=', (int)$params['scene']);
!empty($params['start_time']) && $this->where('log.create_time', '>=', strtotime($params['start_time']));
!empty($params['end_time']) && $this->where('log.create_time', '<', strtotime($params['end_time']) + 86400);
}
}