coupon-admin/app/controller/manager/Business.php

436 lines
15 KiB
PHP
Raw Normal View History

2021-11-18 09:57:04 +00:00
<?php
namespace app\controller\manager;
use app\exception\RepositoryException;
2021-11-30 07:26:38 +00:00
use app\model\Account;
2021-11-18 09:57:04 +00:00
use app\model\Coupon;
use app\model\CouponMain;
2021-11-29 09:32:48 +00:00
use app\model\Category as CategoryModel;
2021-11-18 09:57:04 +00:00
use app\model\Business as BusinessModel;
use app\model\Member;
2021-11-29 09:32:48 +00:00
use app\model\BusinessCircle as BusinessCircleModel ;
2021-11-30 07:26:38 +00:00
use app\repository\AccountRepository;
2021-11-18 09:57:04 +00:00
use app\repository\BusinessRepository;
use app\repository\RechargeRepository;
use app\service\wx\WechatPay;
use Exception;
2021-11-29 09:32:48 +00:00
use think\exception\ValidateException;
2021-11-18 09:57:04 +00:00
use think\facade\Db;
use think\response\Json;
use think\response\View;
/*商家*/
class Business extends Base
{
/**
* 商家列表列表
*
* @return Json|View
* @throws Exception
*/
public function index()
{
if ($this->request->isPost()) {
2021-11-30 07:26:38 +00:00
$repo = BusinessRepository::getInstance();
2021-11-18 09:57:04 +00:00
$keyword = $this->request->param('keyword/s', '');
$page = $this->request->param('page/d', 1);
$size = $this->request->param('size/d', 30);
2021-12-23 08:30:22 +00:00
$whereMap = [
2022-01-13 02:55:53 +00:00
["a.state", "=", BusinessModel::state_on],
["b.type", "=", Account::type_business]
2021-12-23 08:30:22 +00:00
];
2021-11-29 05:56:26 +00:00
$orders = ['a.id' => 'desc'];
2021-11-18 09:57:04 +00:00
if (!empty($keyword)) {
2021-12-23 01:49:15 +00:00
$whereMap[] = ['b.nick_name|a.business_name|a.business_subtitle', 'like', "%$keyword%"];
2021-11-30 07:26:38 +00:00
}
//如果是渠道商或者工作人员 只查看自己的下级商家
if(Member::is_agency($this->auth['roles'])){
$whereMap[] = ['a.agency_code', '=', $this->auth['business_code']];
2021-11-18 09:57:04 +00:00
}
$list = $repo->businessList($whereMap, $page, $size, $orders);
$list["list"]->each(function ($item) {
2022-01-19 05:40:46 +00:00
//得到当前商家的所有商圈码
2021-11-18 09:57:04 +00:00
$date = date("Y-m-d H:i:s");
2022-01-19 05:40:46 +00:00
//商圈码总数
2021-11-29 05:56:26 +00:00
$item->coupon_total_count = CouponMain::where(["business_code" => $item->business_code])->sum("count");
2021-11-18 09:57:04 +00:00
2022-01-19 05:40:46 +00:00
//进行中商圈码总数
2021-11-29 05:56:26 +00:00
$item->coupon_doing_count = CouponMain::where(["business_code" => $item->business_code])
2021-11-18 09:57:04 +00:00
->whereTime("start_time", "<", $date)
->whereTime("end_time", ">", $date)
->where("status", CouponMain::status_on)
->where("on_shelf", CouponMain::on_shelf_on)
->sum("count");
2022-01-19 05:40:46 +00:00
//进行中商圈码总数
2021-11-29 05:56:26 +00:00
$item->coupon_receive_count = CouponMain::where(["business_code" => $item->business_code])->sum("received_count");
2021-11-18 09:57:04 +00:00
2022-01-19 05:40:46 +00:00
//过期未使用商圈码总数
2021-11-29 05:56:26 +00:00
$item->coupon_be_overdue_count = Coupon::where(["business_code" => $item->business_code])
2021-11-18 09:57:04 +00:00
->where("is_verificated", "=", Coupon::is_verificated_off)
->whereTime("end_time", "<", $date)
->count();
2022-01-19 05:40:46 +00:00
//已使用商圈码总数
2021-11-29 05:56:26 +00:00
$item->coupon_used_count = Coupon::where(["business_code" => $item->business_code])
2021-11-18 09:57:04 +00:00
->where("is_verificated", "=", Coupon::is_verificated_on)
->count();
2021-11-30 07:26:38 +00:00
//产生的总收益数
$item->coupon_profit_count = BusinessRepository::getInstance()->businessProfitTotal( $item->business_code);
2021-11-18 09:57:04 +00:00
//商家充值总额
2021-11-29 05:56:26 +00:00
$item->recharge_total_money = $item->total_recharge;
2021-11-18 09:57:04 +00:00
});
return $this->json(0, 'success', $list);
}
return $this->view();
}
/**
2022-01-19 05:40:46 +00:00
* 商家商圈码列表
2021-11-18 09:57:04 +00:00
*
* @return Json|View
* @throws Exception
*/
public function businessCouponList()
{
$businessCode = input("business_code/s", "");
if ($this->request->isPost()) {
event('CouponStatusCheck');
$repo = BusinessRepository::getInstance();
$keyword = $this->request->param('keyword/s', '');
$page = $this->request->param('page/d', 1);
$size = $this->request->param('size/d', 30);
$whereMap = ["business_code" => $businessCode];
if (!empty($keyword)) {
$whereMap[] = ['name', 'like', "%$keyword%"];
}
$list = $repo->businessCouponList($whereMap, $page, $size, ["create_time" => "desc", "id" => "desc"]);
return $this->json(0, 'success', $list);
}
$this->data["businessCode"] = $businessCode;
return $this->view();
}
/**
* 商家扣费记录列表
*
* @return Json|View
* @throws Exception
*/
public function businessDeductionList()
{
$businessCode = input("business_code/s", "");
if ($this->request->isPost()) {
$repo = BusinessRepository::getInstance();
$keyword = $this->request->param('keyword/s', '');
$page = $this->request->param('page/d', 1);
$size = $this->request->param('size/d', 30);
$whereMap = ["business_code" => $businessCode];
if (!empty($keyword)) {
2021-12-23 01:49:15 +00:00
$whereMap[] = ['reason', 'like', "%$keyword%"];
2021-11-18 09:57:04 +00:00
}
$list = $repo->businessDeductionList($whereMap, $page, $size, ["create_time" => "desc", "id" => "desc"]);
return $this->json(0, 'success', $list);
}
$this->data["businessCode"] = $businessCode;
return $this->view();
}
/**
* 商家充值记录列表
*
* @return Json|View
* @throws Exception
*/
public function businessRechargeList()
{
$businessCode = input("business_code/s", "");
if ($this->request->isPost()) {
$repo = BusinessRepository::getInstance();
$keyword = $this->request->param('keyword/s', '');
$page = $this->request->param('page/d', 1);
$size = $this->request->param('size/d', 30);
$whereMap = ["business_code" => $businessCode];
if (!empty($keyword)) {
$whereMap[] = ['order_num', 'like', "%$keyword%"];
}
$list = $repo->businessRechargeList($whereMap, $page, $size, ["create_time" => "desc", "id" => "desc"]);
return $this->json(0, 'success', $list);
}
$this->data["businessCode"] = $businessCode;
return $this->view();
}
/**
* 商家详情
*
* @return Json|View
* @throws Exception
*/
public function businessDetail()
{
$businessCode = input("business_code/s", "");
2021-11-30 07:26:38 +00:00
$business = BusinessRepository::getInstance()->findOneByWhere(['code' => $businessCode]);
2021-11-18 09:57:04 +00:00
if ($this->request->isPost()) {
2021-11-29 09:32:48 +00:00
if(empty($business)){
return $this->json(4001,"商家不存在");
}
$item = input('post.');
$validate = $this->validateByApi($item, [
'business_name|商家名称' => 'require|max:100',
'business_subtitle|商家简称' => 'max:100',
'lat|纬度' => 'require',
'lng|经度' => 'require',
'province|省市区' => 'require',
'city|省市区' => 'require',
'county|省市区' => 'require',
'business_address|地址' => 'require|min:3',
'contact_name|联系人' => 'require|min:1',
'contact_phone|联系电话' => 'require|mobile',
'state|审核状态' => 'require|in:0,1,2',
'enable|启用状态' => 'require|in:0,1',
'type|分类' => 'require|number',
'characteristic|特色' => 'max:100',
'intro|介绍' => 'require',
'business_circle_id|商圈' => 'require',
'background|背景图' => 'require',
'score|评分' => 'require|in:1,2,3,4,5',
'reason|驳回原因' => 'max:100',
]);
if ($validate !== true) {
return $validate;
}
Db::startTrans();
try {
$business->save($item);
Db::commit();
return $this->json();
} catch (ValidateException $e) {
Db::rollback();
return $this->json(4001, $e->getError());
}
2021-11-18 09:57:04 +00:00
}
2021-11-29 09:32:48 +00:00
2021-11-18 09:57:04 +00:00
if (empty($business)) {
return $this->error("商家不存在");
}
$this->data["item"] = $business;
2021-11-29 09:32:48 +00:00
$this->data["type"] = CategoryModel::getByGroup();
$this->data["businessCircle"] = BusinessCircleModel::getList();
2021-12-16 02:34:06 +00:00
$this->data["model"] = BusinessModel::allModel();
2021-11-29 09:32:48 +00:00
2021-11-18 09:57:04 +00:00
return $this->view();
}
/**
* 商家认证列表
*
* @return Json|View
* @throws Exception
*/
public function businessWaitList()
{
if ($this->request->isPost()) {
2021-11-30 07:26:38 +00:00
$repo = BusinessRepository::getInstance();
2021-11-18 09:57:04 +00:00
$keyword = $this->request->param('keyword/s', '');
$page = $this->request->param('page/d', 1);
$size = $this->request->param('size/d', 30);
2021-11-30 07:26:38 +00:00
2022-01-13 02:55:53 +00:00
$whereMap = [
["a.state", "in", [BusinessModel::state_reviewing, BusinessModel::state_off]],
["b.type", "=", Account::type_consumer]
];
2021-11-30 07:26:38 +00:00
//如果是渠道商或者工作人员 只查看自己的下级商家
if(Member::is_agency($this->auth['roles'])){
$whereMap[] = ['a.agency_code', '=', $this->auth['business_code']];
}
$orders = ['a.id' => 'desc'];
2021-11-18 09:57:04 +00:00
if (!empty($keyword)) {
2021-11-30 07:26:38 +00:00
$whereMap[] = ['b.nick_name|a.business_name', 'like', "%$keyword%"];
2021-11-18 09:57:04 +00:00
}
$list = $repo->businessList($whereMap, $page, $size, $orders);
return $this->json(0, 'success', $list);
}
return $this->view();
}
/**
* 执行商家认证
*
* @return Json|View
* @throws Exception
*/
public function businessWait()
{
if ($this->request->isPost()) {
$businessCode = input("business_code/s", "");
$state = input("state/d", 0);
2021-11-25 10:11:50 +00:00
$reason = input("reason/s", '');
2021-11-30 07:26:38 +00:00
if (!in_array($state, [BusinessModel::state_off, BusinessModel::state_on])) {
return $this->json(4001, "错误的审核状态");
}
2021-11-18 09:57:04 +00:00
$business = BusinessRepository::getInstance()->findOneByWhere(["code" => $businessCode]);
if (empty($business)) {
return $this->json(4001, "商家不存在");
}
if ($business['state'] != BusinessModel::state_reviewing) {
return $this->json(4001, "商家当前状态不可审核");
}
2021-11-30 07:26:38 +00:00
$account = AccountRepository::getInstance()->findOneByWhere(["business_code" => $businessCode]);
if (empty($account)) {
return $this->json(4001, "关联用户不存在");
2021-11-18 09:57:04 +00:00
}
2021-11-30 07:26:38 +00:00
2021-11-18 09:57:04 +00:00
Db::startTrans();
try {
2021-11-25 10:11:50 +00:00
$business->save(["state" => $state, "reason" => $reason]);
2021-12-09 05:36:47 +00:00
//通过 就改变用户为商家
if($state == BusinessModel::state_on){
$account->save(["type" => Account::type_business]);
}
2021-11-18 09:57:04 +00:00
Db::commit();
2021-11-25 10:11:50 +00:00
return $this->json();
} catch (RepositoryException $e) {
2021-11-18 09:57:04 +00:00
Db::rollback();
2021-11-25 10:11:50 +00:00
return $this->json("5001", "审核失败");
} catch (\think\Exception $e) {
2021-11-18 09:57:04 +00:00
Db::rollback();
2021-11-25 10:11:50 +00:00
return $this->json("5002", "审核失败");
2021-11-18 09:57:04 +00:00
}
}
}
/**
* 给商家指派代理商
*
* @return Json|View
* @throws Exception
*/
public function assign()
{
$businessCode = input("business_code/s", "");
$business = BusinessRepository::getInstance()->findOneByWhere(["code" => $businessCode]);
if ($this->request->isPost()) {
$anent_code = input("agency_code/s", "");
2021-11-25 10:11:50 +00:00
if (empty($business)) {
return $this->json(4001, "商家不存在");
2021-11-18 09:57:04 +00:00
}
Db::startTrans();
try {
2021-11-25 10:11:50 +00:00
$business->save(["agency_code" => $anent_code]);
2021-11-18 09:57:04 +00:00
Db::commit();
2021-11-25 10:11:50 +00:00
return $this->json();
} catch (RepositoryException $e) {
2021-11-18 09:57:04 +00:00
Db::rollback();
2021-11-25 10:11:50 +00:00
return $this->json("5001", "指派失败");
} catch (\think\Exception $e) {
2021-11-18 09:57:04 +00:00
Db::rollback();
2021-11-25 10:11:50 +00:00
return $this->json("5002", "指派失败");
2021-11-18 09:57:04 +00:00
}
}
2021-11-25 10:11:50 +00:00
if (empty($business)) {
return $this->error("商家不存在");
2021-11-18 09:57:04 +00:00
}
$this->data["agent"] = Member::getAgentAll();
$this->data["businessCode"] = $businessCode;
$this->data["business"] = $business;
return $this->view();
}
/**
* 代为充值
*
* @throws Exception
*/
public function rechargeBehalf()
{
$businessCode = input("business_code/s", "");
$business = BusinessRepository::getInstance()->findOneByWhere(["code" => $businessCode]);
if ($this->request->isPost()) {
2021-11-25 10:11:50 +00:00
$money = input("money/f", 0, "abs");
if ($money <= 0) {
return $this->json(4001, "金额错误");
2021-11-18 09:57:04 +00:00
}
$money = floor($money * 100) / 100;
2021-11-25 10:11:50 +00:00
if (empty($business)) {
return $this->json(4001, "商家不存在");
2021-11-18 09:57:04 +00:00
}
Db::startTrans();
try {
//创建充值订单
2021-11-29 05:56:26 +00:00
if (!$order = RechargeRepository::getInstance()->adminCreateOrder($businessCode, $money)) {
2021-11-18 09:57:04 +00:00
throw new RepositoryException('订单创建失败,请稍后重试');
}
//生成支付
$res = WechatPay::getInstance()->order->unify([
2021-11-25 10:11:50 +00:00
'body' => '商家充值',
2021-11-18 09:57:04 +00:00
'out_trade_no' => $order->order_num,
2021-11-25 10:11:50 +00:00
'total_fee' => $money * 100,
'trade_type' => 'NATIVE',
'product_id' => $order->id,
'notify_url' => $this->request->domain() . "/api/recharge/notify.html",
2021-11-18 09:57:04 +00:00
]);
2021-11-25 10:11:50 +00:00
if (!isset($res['code_url'])) {
2021-11-18 09:57:04 +00:00
throw new RepositoryException('订单创建失败,请稍后重试');
}
Db::commit();
2021-11-25 10:11:50 +00:00
return $this->json(0, "success", ["order_num" => $order->order_num, "code_url" => $res['code_url']]);
} catch (RepositoryException $e) {
2021-11-18 09:57:04 +00:00
Db::rollback();
2021-11-25 10:11:50 +00:00
return $this->json("5001", $e->getMessage());
} catch (Exception $e) {
2021-11-18 09:57:04 +00:00
Db::rollback();
2021-11-29 05:56:26 +00:00
return $this->json("5002", $e->getMessage());
2021-11-18 09:57:04 +00:00
}
}
2021-11-25 10:11:50 +00:00
if (empty($business)) {
return $this->error("商家不存在");
2021-11-18 09:57:04 +00:00
}
$this->data["businessCode"] = $businessCode;
return $this->view();
}
}