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.
yanzong/app/api/model/user/BalanceLog.php

60 lines
2.1 KiB

<?php
// +----------------------------------------------------------------------
// | 萤火商城系统 [ 致力于通过产品和服务,帮助商家高效化开拓市场 ]
// +----------------------------------------------------------------------
// | Copyright (c) 2017~2023 https://www.yiovo.com All rights reserved.
// +----------------------------------------------------------------------
// | Licensed 这不是一个自由软件,不允许对程序代码以任何形式任何目的的再发行
// +----------------------------------------------------------------------
// | Author: 萤火科技 <admin@yiovo.com>
// +----------------------------------------------------------------------
declare (strict_types=1);
namespace app\api\model\user;
use app\api\service\User as UserService;
use app\common\model\user\BalanceLog as BalanceLogModel;
/**
* 用户余额变动明细模型
* Class BalanceLog
* @package app\api\model\user
*/
class BalanceLog extends BalanceLogModel
{
/**
* 隐藏字段
* @var array
*/
protected $hidden = [
'store_id',
];
/**
* 获取账单明细列表
* @return \think\Paginator
* @throws \cores\exception\BaseException
* @throws \think\db\exception\DbException
*/
public function getList($params): \think\Paginator
{
// 当前用户ID
$userId = UserService::getCurrentLoginUserId();
// $userId = 10089;
// 获取列表数据
$query = $this->where('user_id', '=', $userId);
if (!empty($params['type'])) {
if($params['type']==10){
$query = $query->whereIn('scene', [10,30]);
}else{
$query = $query->where('scene', '=', $params['type']);
}
}
if (!empty($params['start_at']) && !empty($params['end_at'])) {
$query = $query->where('create_time', '>=', strtotime($params['start_at']));
$query = $query->where('create_time', '<=', strtotime($params['end_at']));
}
return $query->order(['create_time' => 'desc'])
->paginate(15);
}
}