coupon-admin/app/repository/BusinessRepository.php

138 lines
3.9 KiB
PHP

<?php
namespace app\repository;
use app\exception\RepositoryException;
use app\model\Business;
use app\model\BusinessFlow;
use app\model\CouponMain;
use app\model\Deduction;
use app\model\Recharge;
use app\service\Repository;
use think\Collection;
use think\Model;
/**
* 商家域 相关操作
*
* Class BusinessRepository
* @package app\repository
* @method self getInstance(Model $model = null) static
*/
class BusinessRepository extends Repository
{
/**
* 根据条件查询列表
*
* @param array $where 查询条件
* @param int $page 默认第一页 0不限制
* @param int $limit 限制条数 0不限制
* @param array $order
* @return array
* @throws RepositoryException
*/
public function businessList(array $where = [], int $page = 1, int $limit = 0, array $order = [])
{
$q = $this->model->alias("a")->field("id")->withJoin(["account" => ["avatar_url", "nick_name"], "business"]);
$data = [
'total' => 0,
'current' => $page,
'size' => $limit,
'list' => new Collection(),
];
if (count($where)) {
$q = $q->where($where);
}
if (count($order)) {
$q = $q->order($order);
}
$data['total'] = $q->count();
if ($data['total']) {
if ($limit) {
if ($page) {
$q = $q->page($page);
}
$q = $q->limit($limit);
}
$data['list'] = $q->select();
}
return $data;
}
/**
* 优惠券列表
*
* @param string $businessCode 商家code
* @param int $page 默认第一页 0不限制
* @param int $limit 限制条数 0不限制
* @param array $order
* @return array
* @throws RepositoryException
*/
public function businessCouponList($where, int $page = 1, int $limit = 0, array $order = ["create_time" => "desc", "id" => "desc"])
{
return CouponMain::findList($where, [], $page, $limit, null, $order);
}
/**
* 扣费记录
*
* @param string $businessCode 商家code
* @param int $page 默认第一页 0不限制
* @param int $limit 限制条数 0不限制
* @param array $order
* @return array
* @throws RepositoryException
*/
public function businessDeductionList($where, int $page = 1, int $limit = 0, array $order = ["create_time" => "desc", "id" => "desc"])
{
return Deduction::findList($where, [], $page, $limit, null, $order);
}
/**
* 充值记录
*
* @param string $businessCode 商家code
* @param int $page 默认第一页 0不限制
* @param int $limit 限制条数 0不限制
* @param array $order
* @return array
* @throws RepositoryException
*/
public function businessRechargeList($where, int $page = 1, int $limit = 0, array $order = ["create_time" => "desc", "id" => "desc"])
{
return Recharge::findList($where, [], $page, $limit, function ($q) {
return $q->withJoin(["business" => ["business_name"]]);
}, $order);
}
/* 获取所有的商家*/
public function getBusinessAll()
{
return Business:: where("state", Business::state_on)->select();
}
/**
* 获取单个商家详情
* @param $businessCode
* @param bool $lock
* @return BusinessFlow|array|Model|null
* @throws \think\db\exception\DataNotFoundException
* @throws \think\db\exception\DbException
* @throws \think\db\exception\ModelNotFoundException
*/
public function getBusinessAccount($businessCode,bool $lock = false)
{
$Flow = BusinessFlow::with(["account", "business"])->where("business_code", $businessCode)->when($lock,function ($q){
$q->lock(true);
})->find();
if (empty($Flow) || empty($Flow->account) || empty($Flow->business)) {
return null;
}
return $Flow;
}
}