coupon-admin/app/repository/BillRepository.php

323 lines
11 KiB
PHP
Raw Normal View History

2021-11-25 10:11:50 +00:00
<?php
namespace app\repository;
use app\model\CouponBill;
2021-12-01 08:53:44 +00:00
use app\model\Deduction;
2021-11-30 07:26:38 +00:00
use app\model\Member as MemberModel;
2021-12-01 08:53:44 +00:00
use app\model\Recharge;
2021-11-25 10:11:50 +00:00
use app\service\Repository;
use think\Collection;
use think\Model;
/**
* 流水相关
*
* Class BusinessRepository
* @package app\repository
* @method self getInstance(Model $model = null) static
*/
class BillRepository extends Repository
{
/**
* 流水列表
* @param $page
* @param $size
2021-11-29 05:56:26 +00:00
* @param $keyword
2021-12-13 07:57:27 +00:00
* @param null $businessCode
2021-11-29 05:56:26 +00:00
* @param null $startTime
* @param null $endTime
* @param array $orders
* @return array
2021-11-25 10:11:50 +00:00
*/
2021-12-13 07:57:27 +00:00
public function billList($page, $size, $keyword = null, $businessCode = null,$startTime = null, $endTime = null, $orders = ["a.id" => "desc"])
2021-11-25 10:11:50 +00:00
{
$failData = [
'total' => 0,
'current' => $page,
'size' => $size,
'list' => new Collection(),
];
2021-11-30 07:26:38 +00:00
$rep = CouponBill::alias("a")
2021-12-01 08:53:44 +00:00
->join("business b", "a.business_code = b.code")
->join("account c", "a.user_code = c.user_code")
->join("coupon_main d", "a.coupon_main_id = d.id")
->when(!empty($keyword), function ($q) use ($keyword) {
2021-11-30 07:26:38 +00:00
$q->where("b.business_name|c.nick_name|d.name", "like", "%$keyword%");
})
2021-12-13 07:57:27 +00:00
->when(!empty($businessCode), function ($q) use ($businessCode) {
$q->where("b.code", "=", $businessCode);
})
2021-12-01 08:53:44 +00:00
->when(MemberModel::is_agency(session("auth")['roles']), function ($q) {
2021-11-30 07:26:38 +00:00
$q->where("b.agency_code", "=", session("auth")['business_code']);
})
2021-11-29 05:56:26 +00:00
->when(!empty($startTime), function ($q) use ($startTime) {
2021-11-30 07:26:38 +00:00
$q->whereTime("a.create_time", ">=", $startTime);
2021-11-29 05:56:26 +00:00
})
->when(!empty($endTime), function ($q) use ($endTime) {
2021-11-30 07:26:38 +00:00
$q->whereTime("a.create_time", "<=", $endTime);
})
2021-12-01 08:53:44 +00:00
->field("a.*,b.business_name,c.nick_name,c.avatar_url,d.name as coupon_main_name");
2021-11-30 07:26:38 +00:00
2021-12-01 08:53:44 +00:00
$failData ['total'] = $rep->count();
$failData ['list'] = $rep
->page($page, $size)
->order($orders)
->select();
return $failData;
}
2021-11-30 07:26:38 +00:00
2021-12-13 07:57:27 +00:00
/**
* api获取签到流水列表
* @param $page
* @param $size
* @param $keyword
* @param null $businessCode
* @param null $startTime
* @param null $endTime
* @param array $orders
* @return array
*/
public function apiBillList($page, $size, $businessCode = null,$startTime = null, $endTime = null, $orders = ["id" => "desc"])
{
return CouponBill::with(["couponMain","account"])
->when(!empty($businessCode), function ($q) use ($businessCode) {
$q->where("business_code", "=", $businessCode);
})
->when(!empty($startTime), function ($q) use ($startTime) {
$q->whereTime("create_time", ">=", $startTime);
})
->when(!empty($endTime), function ($q) use ($endTime) {
$q->whereTime("create_time", "<=", $endTime);
})
->page($page,$size)
->order($orders)
->select();
}
2021-12-01 08:53:44 +00:00
/**
* 充值流水列表
* @param $page
* @param $size
* @param $keyword
* @param null $startTime
* @param null $endTime
* @param array $orders
* @return array
*/
public function rechargeBillList($page, $size, $keyword = null, $startTime = null, $endTime = null, $orders = ["a.id" => "desc"])
{
2021-11-30 07:26:38 +00:00
2021-12-01 08:53:44 +00:00
$failData = [
'total' => 0,
'current' => $page,
'size' => $size,
'list' => new Collection(),
];
$rep = Recharge::alias("a")
->join("account b", "a.open_id = b.open_id")
->join("business c", "a.business_code = c.code")
->join("member d", "a.member_id = d.id", "left")
->join("business e", "c.agency_code = e.code", "left")
->when(!empty($startTime), function ($q) use ($startTime) {
$q->whereTime("a.update_time", ">=", $startTime);
})
->when(!empty($keyword), function ($q) use ($keyword) {
$q->where("c.business_name|e.business_name", "like", "%$keyword%");
})
->when(!empty($endTime), function ($q) use ($endTime) {
$q->whereTime("a.update_time", "<=", $endTime);
})
->field(
[
"a.*",
"b.nick_name",
"b.avatar_url",
"d.nickname as member_nickname",
"c.business_name",
"e.business_name as agency_business_name",
]
);
2021-11-25 10:11:50 +00:00
$failData ['total'] = $rep->count();
2021-11-29 05:56:26 +00:00
$failData ['list'] = $rep
2021-11-25 10:11:50 +00:00
->page($page, $size)
->order($orders)
->select();
return $failData;
}
2021-12-01 08:53:44 +00:00
/**
* 扣款流水列表
* @param $page
* @param $size
* @param $keyword
* @param null $startTime
* @param null $endTime
* @param array $orders
* @return array
*/
public function deductionBillList($page, $size, $keyword = null, $startTime = null, $endTime = null, $orders = ["id" => "desc"])
{
$failData = [
'total' => 0,
'current' => $page,
'size' => $size,
'list' => new Collection(),
];
$rep = Deduction::alias("a")
->join("business c", "a.business_code = c.code")
->join("business f", "f.code = c.agency_code", "left")
->join("coupon_main e", "a.coupon_main_id = e.id")
->join("coupon_bill d", "a.bill_id = d.id")
->join("account b", "d.user_code = b.user_code", "left")
->when(!empty($startTime), function ($q) use ($startTime) {
$q->whereTime("a.create_time", ">=", $startTime);
})
->when(!empty($keyword), function ($q) use ($keyword) {
$q->where("c.business_name|f.business_name", "like", "%" . $keyword . "%");
})
->when(!empty($endTime), function ($q) use ($endTime) {
$q->whereTime("a.create_time", "<=", $endTime);
})
->field(
[
"a.money",
"a.balance",
"a.create_time",
"b.nick_name",
"b.avatar_url",
"e.name as coupon_main_name",
"c.business_name",
"f.business_name as agency_business_name",
"d.consumer_money",
"d.admin_money",
"d.agency_money",
"d.lat",
"d.lng",
]
);
$failData ['total'] = $rep->count();
$failData ['list'] = $rep
->page($page, $size)
->order($orders)
->select();
return $failData;
}
2021-11-25 10:11:50 +00:00
2021-11-29 05:56:26 +00:00
/**
* 总收益
* @param $field
2021-12-01 08:53:44 +00:00
* @param null $keyword
2021-11-29 05:56:26 +00:00
* @param null $start_time
* @param null $end_time
* @return float
*/
2021-12-01 08:53:44 +00:00
public function getAgencyMoneySum($field, $keyword = null, $start_time = null, $end_time = null)
2021-11-29 05:56:26 +00:00
{
2021-12-01 08:53:44 +00:00
return CouponBill::alias("a")
->join("business b", "a.business_code = b.code", "left")
->join("business e", "a.agency_code = e.code", "left")
->join("account c", "a.user_code = c.user_code")
->join("coupon_main d", "a.coupon_main_id = d.id")
->when(!empty($keyword), function ($q) use ($keyword) {
$q->whereTime("c.business_name|e.business_name", "like", "%" . $keyword . "%");
})
->when(!empty($start_time), function ($q) use ($start_time) {
$q->whereTime("a.create_time", ">=", $start_time);
})
->when(!empty($end_time), function ($q) use ($end_time) {
$q->whereTime("a.create_time", "<=", $end_time);
})
->when(MemberModel::is_agency(session("auth")['roles']), function ($q) {
$q->where("a.agency_code", "=", session("auth")['business_code']);
})
->sum("a." . $field);
}
2021-12-13 07:57:27 +00:00
/**
* 总流水
* @param $businessCode
* @param null $startTime
* @param null $endTime
* @return float
*/
public function getBillMoneySum($businessCode, $startTime=null, $endTime=null )
{
return CouponBill::alias("a")
->join("account c", "a.user_code = c.user_code")
->join("coupon_main b", "a.coupon_main_id = b.id")
->where("a.business_code",$businessCode)
->when(!empty($startTime), function ($q) use ($startTime) {
$q->whereTime("a.create_time", ">=", $startTime);
})
->when(!empty($endTime), function ($q) use ($endTime) {
$q->whereTime("a.create_time", "<=", $endTime);
})
->sum("b.deduction_money");
}
2021-12-01 08:53:44 +00:00
/**
* 总充值流水
* @param null $keyword
* @param null $start_time
* @param null $end_time
* @return float
*/
public function getRechargeMoneySum($keyword = null, $start_time = null, $end_time = null)
{
return Recharge::alias("a")
->join("account b", "a.open_id = b.open_id")
->join("business c", "a.business_code = c.code")
->join("member d", "a.member_id = d.id", "left")
->join("business e", "c.agency_code = e.code", "left")
->when(!empty($keyword), function ($q) use ($keyword) {
$q->whereTime("c.business_name|e.business_name", "like", "%" . $keyword . "%");
})
->when(!empty($start_time), function ($q) use ($start_time) {
$q->whereTime("a.update_time", ">=", $start_time);
})
->when(!empty($end_time), function ($q) use ($end_time) {
$q->whereTime("a.update_time", "<=", $end_time);
})
->sum("a.money");
}
/**
* 总扣款流水
* @param null $keyword
* @param null $start_time
* @param null $end_time
* @return float
*/
public function getDeductionMoneySum($keyword = null,$start_time = null, $end_time = null)
{
return Deduction::alias("a")
->join("business c", "a.business_code = c.code")
->join("business f", "f.code = c.agency_code", "left")
->join("coupon_main e", "a.coupon_main_id = e.id")
->join("coupon_bill d", "a.bill_id = d.id")
->join("account b", "d.user_code = b.user_code", "left")
->when(!empty($keyword), function ($q) use ($keyword) {
$q->where("c.business_name|f.business_name", "like", "%" . $keyword . "%");
})
->when(!empty($start_time), function ($q) use ($start_time) {
$q->whereTime("a.create_time", ">=", $start_time);
})
2021-11-30 07:26:38 +00:00
->when(!empty($end_time), function ($q) use ($end_time) {
2021-12-01 08:53:44 +00:00
$q->whereTime("a.create_time", "<=", $end_time);
2021-11-30 07:26:38 +00:00
})
2021-12-01 08:53:44 +00:00
->sum("a.money");
2021-11-29 05:56:26 +00:00
}
2021-11-25 10:11:50 +00:00
}