476 lines
		
	
	
		
			14 KiB
		
	
	
	
		
			PHP
		
	
	
		
		
			
		
	
	
			476 lines
		
	
	
		
			14 KiB
		
	
	
	
		
			PHP
		
	
	
|  | <?php | |||
|  | // +----------------------------------------------------------------------
 | |||
|  | // | likeshop开源商城系统
 | |||
|  | // +----------------------------------------------------------------------
 | |||
|  | // | 欢迎阅读学习系统程序代码,建议反馈是我们前进的动力
 | |||
|  | // | gitee下载:https://gitee.com/likeshop_gitee
 | |||
|  | // | github下载:https://github.com/likeshop-github
 | |||
|  | // | 访问官网:https://www.likeshop.cn
 | |||
|  | // | 访问社区:https://home.likeshop.cn
 | |||
|  | // | 访问手册:http://doc.likeshop.cn
 | |||
|  | // | 微信公众号:likeshop技术社区
 | |||
|  | // | likeshop系列产品在gitee、github等公开渠道开源版本可免费商用,未经许可不能去除前后端官方版权标识
 | |||
|  | // |  likeshop系列产品收费版本务必购买商业授权,购买去版权授权后,方可去除前后端官方版权标识
 | |||
|  | // | 禁止对系统程序代码以任何目的,任何形式的再发布
 | |||
|  | // | likeshop团队版权所有并拥有最终解释权
 | |||
|  | // +----------------------------------------------------------------------
 | |||
|  | // | author: likeshop.cn.team
 | |||
|  | // +----------------------------------------------------------------------
 | |||
|  | 
 | |||
|  | namespace app\admin\controller\finance; | |||
|  | 
 | |||
|  | use app\common\basics\AdminBase; | |||
|  | use app\common\model\AccountLog; | |||
|  | use app\common\server\JsonServer; | |||
|  | use app\admin\logic\finance\WithdrawLogic; | |||
|  | use app\common\model\order\Order as OrderModel; | |||
|  | use app\common\model\Client_; | |||
|  | use app\common\enum\PayEnum; | |||
|  | 
 | |||
|  | /** | |||
|  |  * 财务-会员相关 | |||
|  |  * Class User | |||
|  |  * @package app\admin\controller\finance | |||
|  |  */ | |||
|  | class User extends AdminBase | |||
|  | { | |||
|  |     /** | |||
|  |      * @notes 会员佣金提现列表 | |||
|  |      * @return \think\response\Json|\think\response\View | |||
|  |      * @throws \think\db\exception\DataNotFoundException | |||
|  |      * @throws \think\db\exception\DbException | |||
|  |      * @throws \think\db\exception\ModelNotFoundException | |||
|  |      * @author suny | |||
|  |      * @date 2021/7/13 7:01 下午 | |||
|  |      */ | |||
|  |     public function withdrawal() | |||
|  |     { | |||
|  | 
 | |||
|  |         if ($this->request->isAjax()) { | |||
|  |             $get = $this->request->get(); | |||
|  |             $data = WithdrawLogic::lists($get); | |||
|  |             return JsonServer::success('', $data, 1); | |||
|  |         } | |||
|  |         $today = [ | |||
|  |             date('Y-m-d H:i:s', strtotime(date("Y-m-d", time()))), | |||
|  |             date('Y-m-d H:i:s', strtotime(date("Y-m-d", time())) + 86399) | |||
|  |         ]; | |||
|  | 
 | |||
|  |         $yesterday = [ | |||
|  |             date('Y-m-d H:i:s', strtotime(date("Y-m-d", strtotime("-1 day")))), | |||
|  |             date('Y-m-d H:i:s', strtotime(date("Y-m-d", strtotime("-1 day"))) + 86399) | |||
|  |         ]; | |||
|  | 
 | |||
|  | 
 | |||
|  |         $days_ago7 = [ | |||
|  |             date('Y-m-d H:i:s', strtotime(date("Y-m-d", strtotime("-7 day")))), | |||
|  |             date('Y-m-d 23:59:59', time()) | |||
|  |         ]; | |||
|  | 
 | |||
|  |         $days_ago30 = [ | |||
|  |             date('Y-m-d 00:00:00', strtotime("-30 day")), | |||
|  |             date('Y-m-d 23:59:59', time()) | |||
|  |         ]; | |||
|  |         $summary = WithdrawLogic::summary(); | |||
|  |         return view('', [ | |||
|  |             'today' => $today, | |||
|  |             'yesterday' => $yesterday, | |||
|  |             'days_ago7' => $days_ago7, | |||
|  |             'days_ago30' => $days_ago30, | |||
|  |             'summary' => $summary | |||
|  |         ]); | |||
|  |     } | |||
|  | 
 | |||
|  |     /** | |||
|  |      * @notes 会员佣金明细列表 | |||
|  |      * @return \think\response\Json|\think\response\View | |||
|  |      * @throws \think\db\exception\DataNotFoundException | |||
|  |      * @throws \think\db\exception\DbException | |||
|  |      * @throws \think\db\exception\ModelNotFoundException | |||
|  |      * @author suny | |||
|  |      * @date 2021/7/13 7:01 下午 | |||
|  |      */ | |||
|  |     public function commission() | |||
|  |     { | |||
|  | 
 | |||
|  |         if ($this->request->isAjax()) { | |||
|  |             $get = $this->request->get(); | |||
|  |             $data = WithdrawLogic::commission($get); | |||
|  |             return JsonServer::success('', $data, 1); | |||
|  |         } | |||
|  |         $today = [ | |||
|  |             date('Y-m-d H:i:s', strtotime(date("Y-m-d", time()))), | |||
|  |             date('Y-m-d H:i:s', strtotime(date("Y-m-d", time())) + 86399) | |||
|  |         ]; | |||
|  | 
 | |||
|  |         $yesterday = [ | |||
|  |             date('Y-m-d H:i:s', strtotime(date("Y-m-d", strtotime("-1 day")))), | |||
|  |             date('Y-m-d H:i:s', strtotime(date("Y-m-d", strtotime("-1 day"))) + 86399) | |||
|  |         ]; | |||
|  | 
 | |||
|  | 
 | |||
|  |         $days_ago7 = [ | |||
|  |             date('Y-m-d H:i:s', strtotime(date("Y-m-d", strtotime("-7 day")))), | |||
|  |             date('Y-m-d 23:59:59', time()) | |||
|  |         ]; | |||
|  | 
 | |||
|  |         $days_ago30 = [ | |||
|  |             date('Y-m-d 00:00:00', strtotime("-30 day")), | |||
|  |             date('Y-m-d 23:59:59', time()) | |||
|  |         ]; | |||
|  |         return view('', [ | |||
|  |             'today' => $today, | |||
|  |             'yesterday' => $yesterday, | |||
|  |             'days_ago7' => $days_ago7, | |||
|  |             'days_ago30' => $days_ago30, | |||
|  |             'source_type' => AccountLog::getEarningsChange() | |||
|  |         ]); | |||
|  |     } | |||
|  | 
 | |||
|  |     /** | |||
|  |      * @notes 充值明细列表 | |||
|  |      * @return \think\response\Json|\think\response\View | |||
|  |      * @author suny | |||
|  |      * @date 2021/7/13 7:01 下午 | |||
|  |      */ | |||
|  |     public function recharge() | |||
|  |     { | |||
|  | 
 | |||
|  |         if ($this->request->isAjax()) { | |||
|  |             $get = $this->request->get(); | |||
|  |             $data = WithdrawLogic::recharge($get); | |||
|  |             return JsonServer::success('', $data, 1); | |||
|  |         } | |||
|  |         // 订单状态
 | |||
|  |         $order_status = OrderModel::getOrderStatus(true); | |||
|  |         // 订单类型
 | |||
|  |         $order_type = OrderModel::getOrderType(true); | |||
|  |         // 订单来源
 | |||
|  |         $order_source = Client_::getClient(true); | |||
|  |         unset($order_source[2]); | |||
|  |         // 支付方式
 | |||
|  |         $pay_way = PayEnum::getPayWay(true); | |||
|  |         unset($pay_way[3], $pay_way[4]); | |||
|  |         // 配送方式
 | |||
|  |         $today = [ | |||
|  |             date('Y-m-d H:i:s', strtotime(date("Y-m-d", time()))), | |||
|  |             date('Y-m-d H:i:s', strtotime(date("Y-m-d", time())) + 86399) | |||
|  |         ]; | |||
|  | 
 | |||
|  |         $yesterday = [ | |||
|  |             date('Y-m-d H:i:s', strtotime(date("Y-m-d", strtotime("-1 day")))), | |||
|  |             date('Y-m-d H:i:s', strtotime(date("Y-m-d", strtotime("-1 day"))) + 86399) | |||
|  |         ]; | |||
|  | 
 | |||
|  | 
 | |||
|  |         $days_ago7 = [ | |||
|  |             date('Y-m-d H:i:s', strtotime(date("Y-m-d", strtotime("-7 day")))), | |||
|  |             date('Y-m-d 23:59:59', time()) | |||
|  |         ]; | |||
|  | 
 | |||
|  |         $days_ago30 = [ | |||
|  |             date('Y-m-d 00:00:00', strtotime("-30 day")), | |||
|  |             date('Y-m-d 23:59:59', time()) | |||
|  |         ]; | |||
|  |         return view('', [ | |||
|  |             'order_status' => $order_status, | |||
|  |             'order_type' => $order_type, | |||
|  |             'order_source' => $order_source, | |||
|  |             'pay_way' => $pay_way, | |||
|  |             'today' => $today, | |||
|  |             'yesterday' => $yesterday, | |||
|  |             'days_ago7' => $days_ago7, | |||
|  |             'days_ago30' => $days_ago30, | |||
|  |         ]); | |||
|  |     } | |||
|  | 
 | |||
|  | 
 | |||
|  |     /** | |||
|  |      * @notes 账户明细列表 | |||
|  |      * @return \think\response\Json|\think\response\View | |||
|  |      * @throws \think\db\exception\DataNotFoundException | |||
|  |      * @throws \think\db\exception\DbException | |||
|  |      * @throws \think\db\exception\ModelNotFoundException | |||
|  |      * @author suny | |||
|  |      * @date 2021/7/13 7:02 下午 | |||
|  |      */ | |||
|  |     public function account() | |||
|  |     { | |||
|  | 
 | |||
|  |         if ($this->request->isAjax()) { | |||
|  |             $get = $this->request->get(); | |||
|  |             $data = WithdrawLogic::account($get); | |||
|  |             return JsonServer::success('', $data, 1); | |||
|  |         } | |||
|  |         $today = [ | |||
|  |             date('Y-m-d H:i:s', strtotime(date("Y-m-d", time()))), | |||
|  |             date('Y-m-d H:i:s', strtotime(date("Y-m-d", time())) + 86399) | |||
|  |         ]; | |||
|  | 
 | |||
|  |         $yesterday = [ | |||
|  |             date('Y-m-d H:i:s', strtotime(date("Y-m-d", strtotime("-1 day")))), | |||
|  |             date('Y-m-d H:i:s', strtotime(date("Y-m-d", strtotime("-1 day"))) + 86399) | |||
|  |         ]; | |||
|  | 
 | |||
|  | 
 | |||
|  |         $days_ago7 = [ | |||
|  |             date('Y-m-d H:i:s', strtotime(date("Y-m-d", strtotime("-7 day")))), | |||
|  |             date('Y-m-d 23:59:59', time()) | |||
|  |         ]; | |||
|  | 
 | |||
|  |         $days_ago30 = [ | |||
|  |             date('Y-m-d 00:00:00', strtotime("-30 day")), | |||
|  |             date('Y-m-d 23:59:59', time()) | |||
|  |         ]; | |||
|  |         return view('', [ | |||
|  |             'today' => $today, | |||
|  |             'yesterday' => $yesterday, | |||
|  |             'days_ago7' => $days_ago7, | |||
|  |             'days_ago30' => $days_ago30, | |||
|  |         ]); | |||
|  |     } | |||
|  | 
 | |||
|  |     /** | |||
|  |      * @notes 会员佣金提现详情 | |||
|  |      * @return \think\response\View | |||
|  |      * @author suny | |||
|  |      * @date 2021/7/13 7:02 下午 | |||
|  |      */ | |||
|  |     public function withdraw_detail() | |||
|  |     { | |||
|  | 
 | |||
|  |         $id = $this->request->get('id', '', 'intval'); | |||
|  |         $detail = WithdrawLogic::detail($id); | |||
|  |         return view('detail', [ | |||
|  |             'detail' => $detail | |||
|  |         ]); | |||
|  |     } | |||
|  | 
 | |||
|  |     /** | |||
|  |      * @notes 显示提现审核界面 | |||
|  |      * @return \think\response\View | |||
|  |      * @author suny | |||
|  |      * @date 2021/7/13 7:02 下午 | |||
|  |      */ | |||
|  |     public function withdraw_review() | |||
|  |     { | |||
|  | 
 | |||
|  |         $id = $this->request->get('id', '', 'intval'); | |||
|  |         return view('review', [ | |||
|  |             'id' => $id | |||
|  |         ]); | |||
|  |     } | |||
|  | 
 | |||
|  |     /** | |||
|  |      * @notes 审核通过 | |||
|  |      * @return \think\response\Json | |||
|  |      * @throws \think\db\exception\DataNotFoundException | |||
|  |      * @throws \think\db\exception\DbException | |||
|  |      * @throws \think\db\exception\ModelNotFoundException | |||
|  |      * @throws \think\exception\DbException | |||
|  |      * @author suny | |||
|  |      * @date 2021/7/13 7:02 下午 | |||
|  |      */ | |||
|  |     public function confirm() | |||
|  |     { | |||
|  | 
 | |||
|  |         if ($this->request->isAjax()) { | |||
|  |             $post = $this->request->post(); | |||
|  |             $result = WithdrawLogic::confirm($post); | |||
|  |             if ($result['code']) { | |||
|  |                 return JsonServer::success($result['msg']); | |||
|  |             } else { | |||
|  |                 return JsonServer::error($result['msg']); | |||
|  |             } | |||
|  |         } | |||
|  |     } | |||
|  | 
 | |||
|  |     /** | |||
|  |      * @notes 审核拒绝 | |||
|  |      * @return \think\response\Json | |||
|  |      * @throws \think\exception\PDOException | |||
|  |      * @author suny | |||
|  |      * @date 2021/7/13 7:02 下午 | |||
|  |      */ | |||
|  |     public function refuse() | |||
|  |     { | |||
|  | 
 | |||
|  |         if ($this->request->isAjax()) { | |||
|  |             $post = $this->request->post(); | |||
|  |             WithdrawLogic::refuse($post); | |||
|  |             return JsonServer::success('已拒绝提现'); | |||
|  |         } | |||
|  |     } | |||
|  | 
 | |||
|  |     /** | |||
|  |      * @notes 显示提现转账界面 | |||
|  |      * @return \think\response\View | |||
|  |      * @author suny | |||
|  |      * @date 2021/7/13 7:02 下午 | |||
|  |      */ | |||
|  |     public function transfer() | |||
|  |     { | |||
|  | 
 | |||
|  |         $id = $this->request->get('id', '', 'intval'); | |||
|  |         return view('', [ | |||
|  |             'id' => $id | |||
|  |         ]); | |||
|  |     } | |||
|  | 
 | |||
|  |     /** | |||
|  |      * @notes 转账失败 | |||
|  |      * @return \think\response\Json | |||
|  |      * @throws \think\db\exception\DataNotFoundException | |||
|  |      * @throws \think\db\exception\DbException | |||
|  |      * @throws \think\db\exception\ModelNotFoundException | |||
|  |      * @throws \think\exception\DbException | |||
|  |      * @author suny | |||
|  |      * @date 2021/7/13 7:02 下午 | |||
|  |      */ | |||
|  |     public function transferFail() | |||
|  |     { | |||
|  | 
 | |||
|  |         $post = $this->request->post(); | |||
|  |         $result = WithdrawLogic::transferFail($post); | |||
|  |         if ($result['code']) { | |||
|  |             return JsonServer::success($result['msg']); | |||
|  |         } else { | |||
|  |             return JsonServer::error($result['msg']); | |||
|  |         } | |||
|  |     } | |||
|  | 
 | |||
|  |     /** | |||
|  |      * @notes 转账成功 | |||
|  |      * @return \think\response\Json | |||
|  |      * @author suny | |||
|  |      * @date 2021/7/13 7:02 下午 | |||
|  |      */ | |||
|  |     public function transferSuccess() | |||
|  |     { | |||
|  | 
 | |||
|  |         $post = $this->request->post(); | |||
|  |         $result = WithdrawLogic::transferSuccess($post); | |||
|  |         if ($result['code']) { | |||
|  |             return JsonServer::success($result['msg']); | |||
|  |         } else { | |||
|  |             return JsonServer::error($result['msg']); | |||
|  |         } | |||
|  |     } | |||
|  | 
 | |||
|  |     /** | |||
|  |      * @notes 提现结果查询 | |||
|  |      * @return \think\response\Json | |||
|  |      * @author suny | |||
|  |      * @date 2021/7/13 7:02 下午 | |||
|  |      */ | |||
|  |     public function search() | |||
|  |     { | |||
|  | 
 | |||
|  |         $id = $this->request->post('id', '', 'intval'); | |||
|  |         $result = WithdrawLogic::search($id); | |||
|  |         if ($result['code']) { | |||
|  |             return JsonServer::success($result['msg']); | |||
|  |         } else { | |||
|  |             return JsonServer::error($result['msg']); | |||
|  |         } | |||
|  |     } | |||
|  | 
 | |||
|  |     /** | |||
|  |      * @notes 提现失败 | |||
|  |      * @return \think\response\Json | |||
|  |      * @throws \think\db\exception\DataNotFoundException | |||
|  |      * @throws \think\db\exception\DbException | |||
|  |      * @throws \think\db\exception\ModelNotFoundException | |||
|  |      * @throws \think\exception\DbException | |||
|  |      * @author suny | |||
|  |      * @date 2021/7/13 7:03 下午 | |||
|  |      */ | |||
|  |     public function withdrawFailed() | |||
|  |     { | |||
|  | 
 | |||
|  |         $id = $this->request->post('id', '', 'intval'); | |||
|  |         WithdrawLogic::withdrawFailed($id); | |||
|  |         return JsonServer::success('提现失败已回退佣金'); | |||
|  |     } | |||
|  | 
 | |||
|  | 
 | |||
|  |     /** | |||
|  |      * @notes 导出充值明细Excel | |||
|  |      * @return \think\response\Json | |||
|  |      * @throws \think\db\exception\DataNotFoundException | |||
|  |      * @throws \think\db\exception\DbException | |||
|  |      * @throws \think\db\exception\ModelNotFoundException | |||
|  |      * @author 段誉 | |||
|  |      * @date 2022/4/24 10:20 | |||
|  |      */ | |||
|  |     public function rechargeExport() | |||
|  |     { | |||
|  |         $params = $this->request->get(); | |||
|  |         $result = WithdrawLogic::recharge($params, true); | |||
|  |         if(false === $result) { | |||
|  |             return JsonServer::error(WithdrawLogic::getError() ?: '导出失败'); | |||
|  |         } | |||
|  |         return JsonServer::success('', $result); | |||
|  |     } | |||
|  | 
 | |||
|  | 
 | |||
|  |     /** | |||
|  |      * @notes 导出账户明细Excel | |||
|  |      * @return \think\response\Json | |||
|  |      * @throws \think\db\exception\DataNotFoundException | |||
|  |      * @throws \think\db\exception\DbException | |||
|  |      * @throws \think\db\exception\ModelNotFoundException | |||
|  |      * @author 段誉 | |||
|  |      * @date 2022/4/24 10:20 | |||
|  |      */ | |||
|  |     public function accountExport() | |||
|  |     { | |||
|  |         $params = $this->request->get(); | |||
|  |         $result = WithdrawLogic::account($params, true); | |||
|  |         if(false === $result) { | |||
|  |             return JsonServer::error(WithdrawLogic::getError() ?: '导出失败'); | |||
|  |         } | |||
|  |         return JsonServer::success('', $result); | |||
|  |     } | |||
|  | 
 | |||
|  | 
 | |||
|  |     /** | |||
|  |      * @notes 导出佣金明细Excel | |||
|  |      * @return \think\response\Json | |||
|  |      * @throws \think\db\exception\DataNotFoundException | |||
|  |      * @throws \think\db\exception\DbException | |||
|  |      * @throws \think\db\exception\ModelNotFoundException | |||
|  |      * @author 段誉 | |||
|  |      * @date 2022/4/24 10:20 | |||
|  |      */ | |||
|  |     public function commissionExport() | |||
|  |     { | |||
|  |         $params = $this->request->get(); | |||
|  |         $result = WithdrawLogic::commission($params, true); | |||
|  |         if(false === $result) { | |||
|  |             return JsonServer::error(WithdrawLogic::getError() ?: '导出失败'); | |||
|  |         } | |||
|  |         return JsonServer::success('', $result); | |||
|  |     } | |||
|  | 
 | |||
|  | 
 | |||
|  | 
 | |||
|  |     /** | |||
|  |      * @notes 导出佣金提现Excel | |||
|  |      * @return \think\response\Json | |||
|  |      * @throws \think\db\exception\DataNotFoundException | |||
|  |      * @throws \think\db\exception\DbException | |||
|  |      * @throws \think\db\exception\ModelNotFoundException | |||
|  |      * @author 段誉 | |||
|  |      * @date 2022/4/24 10:20 | |||
|  |      */ | |||
|  |     public function withdrawalExport() | |||
|  |     { | |||
|  |         $params = $this->request->get(); | |||
|  |         $result = WithdrawLogic::lists($params, true); | |||
|  |         if(false === $result) { | |||
|  |             return JsonServer::error(WithdrawLogic::getError() ?: '导出失败'); | |||
|  |         } | |||
|  |         return JsonServer::success('', $result); | |||
|  |     } | |||
|  | } |