378 lines
13 KiB
PHP
378 lines
13 KiB
PHP
|
<?php
|
||
|
|
||
|
|
||
|
namespace app\admin\logic\finance;
|
||
|
|
||
|
|
||
|
use app\common\basics\Logic;
|
||
|
use app\common\enum\ShopEnum;
|
||
|
use app\common\enum\WithdrawalEnum;
|
||
|
use app\common\model\shop\Shop;
|
||
|
use app\common\model\shop\ShopAccountLog;
|
||
|
use app\common\model\shop\ShopBank;
|
||
|
use app\common\model\shop\ShopWithdrawal;
|
||
|
use app\common\server\ExportExcelServer;
|
||
|
use app\common\server\UrlServer;
|
||
|
|
||
|
class ShopWithdrawalLogic extends Logic
|
||
|
{
|
||
|
/**
|
||
|
* @Notes: 申请提现记录列表
|
||
|
* @Author: 张无忌
|
||
|
* @param $get
|
||
|
* @return array
|
||
|
*/
|
||
|
public static function lists($get, $is_export = false)
|
||
|
{
|
||
|
try {
|
||
|
$where[] = ['status', '=', $get['type'] ?? 0];
|
||
|
|
||
|
if (!empty($get['start_time']) and $get['start_time']) {
|
||
|
$where[] = ['create_time', '>=', strtotime($get['start_time'])];
|
||
|
}
|
||
|
|
||
|
if (!empty($get['end_time']) and $get['end_time']) {
|
||
|
$where[] = ['create_time', '<=', strtotime($get['start_time'])];
|
||
|
}
|
||
|
|
||
|
// 导出
|
||
|
if (true === $is_export) {
|
||
|
return self::withdrawalExport($where);
|
||
|
}
|
||
|
|
||
|
$model = new ShopWithdrawal();
|
||
|
$lists = $model->field(true)
|
||
|
->where($where)
|
||
|
->with(['shop'])
|
||
|
->paginate([
|
||
|
'page' => $get['page'],
|
||
|
'list_rows' => $get['limit'],
|
||
|
'var_page' => 'page'
|
||
|
])->toArray();
|
||
|
|
||
|
foreach ($lists['data'] as &$item) {
|
||
|
$item['status_text'] = WithdrawalEnum::getStatusDesc($item['status']);
|
||
|
}
|
||
|
|
||
|
return ['count'=>$lists['total'], 'lists'=>$lists['data']];
|
||
|
} catch (\Exception $e) {
|
||
|
static::$error = $e->getMessage();
|
||
|
return ['error'=>$e->getMessage()];
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @Notes: 统计
|
||
|
* @Author: 张无忌
|
||
|
* @return array
|
||
|
*/
|
||
|
public static function statistics()
|
||
|
{
|
||
|
$model = new ShopWithdrawal();
|
||
|
$apply = $model->where(['status'=>WithdrawalEnum::APPLY_STATUS])->count();
|
||
|
$handle = $model->where(['status'=>WithdrawalEnum::HANDLE_STATUS])->count();
|
||
|
$success = $model->where(['status'=>WithdrawalEnum::SUCCESS_STATUS])->count();
|
||
|
$error = $model->where(['status'=>WithdrawalEnum::ERROR_STATUS])->count();
|
||
|
|
||
|
return ['apply'=>$apply, 'handle'=>$handle, 'success'=>$success, 'error'=>$error];
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @Notes: 数据汇总
|
||
|
* @Author: 张无忌
|
||
|
*/
|
||
|
public static function summary()
|
||
|
{
|
||
|
$model = new ShopWithdrawal();
|
||
|
$successWithdrawn = $model->where(['status'=>WithdrawalEnum::SUCCESS_STATUS])->sum('apply_amount');
|
||
|
$handleWithdrawn = $model->where(['status'=>WithdrawalEnum::HANDLE_STATUS])->sum('apply_amount');
|
||
|
$totalWallet = (new Shop())->where(['del'=>0])->sum('wallet');
|
||
|
|
||
|
return ['successWithdrawn'=>$successWithdrawn, 'handleWithdrawn'=>$handleWithdrawn, 'totalWallet'=>$totalWallet];
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @Notes: 提现详细
|
||
|
* @Author: 张无忌
|
||
|
* @param $id
|
||
|
* @return array
|
||
|
*/
|
||
|
public static function detail($id)
|
||
|
{
|
||
|
$withdrawal = (new ShopWithdrawal())->findOrEmpty($id)->toArray();
|
||
|
$shop = (new Shop())->with(['category'])->findOrEmpty($withdrawal['shop_id'])->toArray();
|
||
|
$bank = (new ShopBank())->findOrEmpty($withdrawal['bank_id'])->toArray();
|
||
|
|
||
|
$shop['type'] = ShopEnum::getShopTypeDesc($shop['type']);
|
||
|
$withdrawal['status_text'] = WithdrawalEnum::getStatusDesc($withdrawal['status']);
|
||
|
|
||
|
return ['withdrawal'=>$withdrawal, 'shop'=>$shop, 'bank'=>$bank];
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @Notes: 审核提现
|
||
|
* @Author: 张无忌
|
||
|
* @param $post
|
||
|
* @return bool
|
||
|
*/
|
||
|
public static function examine($post)
|
||
|
{
|
||
|
try {
|
||
|
if ($post['is_examine']) {
|
||
|
// 同意提现
|
||
|
ShopWithdrawal::update([
|
||
|
'explain' => $post['explain'] ?? '',
|
||
|
'status' => WithdrawalEnum::HANDLE_STATUS,
|
||
|
'update_time' => time()
|
||
|
], ['id'=>$post['id']]);
|
||
|
|
||
|
} else {
|
||
|
// 拒绝提现
|
||
|
$withdrawal = (new ShopWithdrawal())->findOrEmpty($post['id'])->toArray();
|
||
|
ShopWithdrawal::update([
|
||
|
'explain' => $post['explain'] ?? '',
|
||
|
'status' => WithdrawalEnum::ERROR_STATUS,
|
||
|
'update_time' => time()
|
||
|
], ['id'=>$post['id']]);
|
||
|
|
||
|
Shop::update([
|
||
|
'wallet' => ['inc', $withdrawal['apply_amount']],
|
||
|
'update_time' => time()
|
||
|
], ['id'=>$withdrawal['shop_id']]);
|
||
|
|
||
|
(new ShopAccountLog())->where([
|
||
|
'source_id' => $withdrawal['id'],
|
||
|
'source_sn' => $withdrawal['sn']
|
||
|
])->update([
|
||
|
'change_type' => 1,
|
||
|
'left_amount' => ['inc', $withdrawal['apply_amount']],
|
||
|
'source_type' => ShopAccountLog::withdrawal_fail_money
|
||
|
]);
|
||
|
}
|
||
|
|
||
|
return true;
|
||
|
} catch (\Exception $e) {
|
||
|
static::$error = $e->getMessage();
|
||
|
return false;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @Notes: 审核提现转账
|
||
|
* @Author: 张无忌
|
||
|
* @param $post
|
||
|
* @return bool
|
||
|
*/
|
||
|
public static function transfer($post)
|
||
|
{
|
||
|
try {
|
||
|
if ($post['is_examine']) {
|
||
|
// 转账成功
|
||
|
ShopWithdrawal::update([
|
||
|
'explain' => $post['explain'] ?? '',
|
||
|
'status' => WithdrawalEnum::SUCCESS_STATUS,
|
||
|
'transfer_voucher' => $post['image'] ?? '',
|
||
|
'transfer_time' => time(),
|
||
|
'update_time' => time()
|
||
|
], ['id'=>(int)$post['id']]);
|
||
|
|
||
|
$withdrawal = (new ShopWithdrawal())->findOrEmpty($post['id'])->toArray();
|
||
|
(new ShopAccountLog())->where([
|
||
|
'source_id' => $withdrawal['id'],
|
||
|
'source_sn' => $withdrawal['sn']
|
||
|
])->update([
|
||
|
'change_type' => 2,
|
||
|
'source_type' => ShopAccountLog::withdrawal_dec_money
|
||
|
]);
|
||
|
|
||
|
} else {
|
||
|
// 转账失败
|
||
|
$withdrawal = (new ShopWithdrawal())->findOrEmpty($post['id'])->toArray();
|
||
|
ShopWithdrawal::update([
|
||
|
'explain' => $post['explain'] ?? '',
|
||
|
'status' => WithdrawalEnum::ERROR_STATUS,
|
||
|
'transfer_voucher' => $post['image'] ?? '',
|
||
|
'transfer_time' => time(),
|
||
|
'update_time' => time()
|
||
|
], ['id'=>$post['id']]);
|
||
|
|
||
|
Shop::update([
|
||
|
'wallet' => ['inc', $withdrawal['apply_amount']],
|
||
|
'update_time' => time()
|
||
|
], ['id'=>$withdrawal['shop_id']]);
|
||
|
|
||
|
(new ShopAccountLog())->where([
|
||
|
'source_id' => $withdrawal['id'],
|
||
|
'source_sn' => $withdrawal['sn']
|
||
|
])->update([
|
||
|
'change_type' => 1,
|
||
|
'left_amount' => ['inc', $withdrawal['apply_amount']],
|
||
|
'source_type' => ShopAccountLog::withdrawal_fail_money
|
||
|
]);
|
||
|
}
|
||
|
|
||
|
return true;
|
||
|
} catch (\Exception $e) {
|
||
|
static::$error = $e->getMessage();
|
||
|
return false;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* @Notes: 账户明细
|
||
|
* @Author: 张无忌
|
||
|
* @param $get
|
||
|
* @return array
|
||
|
*/
|
||
|
public static function account($get, $is_export = false)
|
||
|
{
|
||
|
$where = [];
|
||
|
if (isset($get['shop_name']) && $get['shop_name']) {
|
||
|
$where[] = ['S.name', 'like', '%' . $get['shop_name'] . '%'];
|
||
|
}
|
||
|
if (isset($get['search_key']) && $get['search_key']) {
|
||
|
switch($get['search_key']){
|
||
|
case 'settle':
|
||
|
$where[] = ['SAL.source_type', '=', ShopAccountLog::settlement_add_money];
|
||
|
break;
|
||
|
case 'withdrawal':
|
||
|
$where[] = ['SAL.source_type', '=', ShopAccountLog::withdrawal_dec_money];
|
||
|
break;
|
||
|
case 'withdrawal_error':
|
||
|
$where[] = ['SAL.source_type', '=', ShopAccountLog::withdrawal_fail_money];
|
||
|
break;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
if (!empty($get['start_time']) and $get['start_time']) {
|
||
|
$where[] = ['SAL.create_time', '>=', strtotime($get['start_time'])];
|
||
|
}
|
||
|
|
||
|
if (!empty($get['end_time']) and $get['end_time']) {
|
||
|
$where[] = ['SAL.create_time', '<=', strtotime($get['end_time'])];
|
||
|
}
|
||
|
|
||
|
// 导出
|
||
|
if (true === $is_export) {
|
||
|
return self::accountExport($where);
|
||
|
}
|
||
|
|
||
|
$model = new ShopAccountLog();
|
||
|
$lists = $model->alias('SAL')
|
||
|
->field(['SAL.*', 'S.name,S.logo,S.type'])
|
||
|
->join('shop S', 'S.id = SAL.shop_id')
|
||
|
->order('SAL.id desc')
|
||
|
->where($where)
|
||
|
->paginate([
|
||
|
'page' => $get['page'],
|
||
|
'list_rows' => $get['limit'],
|
||
|
'var_page' => 'page'
|
||
|
])->toArray();
|
||
|
|
||
|
|
||
|
foreach ($lists['data'] as &$item) {
|
||
|
$item['logo'] = empty($item['logo']) ? '' : UrlServer::getFileUrl($item['logo']);
|
||
|
$item['type'] = ShopEnum::getShopTypeDesc($item['type']);
|
||
|
$item['source_type'] = ShopAccountLog::getSourceType($item['source_type']);
|
||
|
$item['change_amount'] = $item['change_type'] == 1 ? '+'.$item['change_amount'] : '-'.$item['change_amount'];
|
||
|
$item['logo'] = !empty($item['logo']) ? UrlServer::getFileUrl($item['logo']) : "";
|
||
|
}
|
||
|
|
||
|
return ['count'=>$lists['total'], 'lists'=>$lists['data']];
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @notes 导出商家明细Excel
|
||
|
* @param array $where
|
||
|
* @return array|false
|
||
|
* @author 段誉
|
||
|
* @date 2022/4/24 10:10
|
||
|
*/
|
||
|
public static function withdrawalExport($where)
|
||
|
{
|
||
|
try {
|
||
|
$model = new ShopWithdrawal();
|
||
|
$lists = $model->field(true)
|
||
|
->where($where)
|
||
|
->with(['shop'])
|
||
|
->select()->toArray();
|
||
|
|
||
|
foreach ($lists as &$item) {
|
||
|
$item['status_text'] = WithdrawalEnum::getStatusDesc($item['status']);
|
||
|
$item['shop_name'] = $item['shop']['name'];
|
||
|
$item['shop_type'] = ShopEnum::getShopTypeDesc($item['shop']['type']);
|
||
|
}
|
||
|
|
||
|
$excelFields = [
|
||
|
'shop_name' => '商家名称',
|
||
|
'shop_type' => '商家类型',
|
||
|
'sn' => '提现单号',
|
||
|
'apply_amount' => '提现金额',
|
||
|
'poundage_amount' => '提现手续费',
|
||
|
'left_amount' => '到账金额',
|
||
|
'status_text' => '提现状态',
|
||
|
'create_time' => '提现时间',
|
||
|
];
|
||
|
|
||
|
$export = new ExportExcelServer();
|
||
|
$export->setFileName('商家提现');
|
||
|
$result = $export->createExcel($excelFields, $lists);
|
||
|
|
||
|
return ['url' => $result];
|
||
|
|
||
|
} catch (\Exception $e) {
|
||
|
self::$error = $e->getMessage();
|
||
|
return false;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* @notes 导出商家账户明细Excel
|
||
|
* @param array $where
|
||
|
* @return array|false
|
||
|
* @author 段誉
|
||
|
* @date 2022/4/24 10:10
|
||
|
*/
|
||
|
public static function accountExport($where)
|
||
|
{
|
||
|
try {
|
||
|
$model = new ShopAccountLog();
|
||
|
$lists = $model->alias('SAL')
|
||
|
->field(['SAL.*', 'S.name,S.type'])
|
||
|
->join('shop S', 'S.id = SAL.shop_id')
|
||
|
->order('SAL.id desc')
|
||
|
->where($where)
|
||
|
->select()->toArray();
|
||
|
|
||
|
foreach ($lists as &$item) {
|
||
|
$item['type'] = ShopEnum::getShopTypeDesc($item['type']);
|
||
|
$item['source_type'] = ShopAccountLog::getSourceType($item['source_type']);
|
||
|
$item['change_amount'] = $item['change_type'] == 1 ? '+'.$item['change_amount'] : '-'.$item['change_amount'];
|
||
|
}
|
||
|
|
||
|
$excelFields = [
|
||
|
'name' => '商家名称',
|
||
|
'type' => '商家类型',
|
||
|
'log_sn' => '明细流水号',
|
||
|
'source_sn' => '来源单号',
|
||
|
'source_type' => '明细类型',
|
||
|
'change_amount' => '变动金额',
|
||
|
'left_amount' => '剩余金额',
|
||
|
'create_time' => '记录时间',
|
||
|
];
|
||
|
|
||
|
$export = new ExportExcelServer();
|
||
|
$export->setFileName('商家账户明细');
|
||
|
$export->setExportNumber(['log_sn', 'source_sn']);
|
||
|
$result = $export->createExcel($excelFields, $lists);
|
||
|
|
||
|
return ['url' => $result];
|
||
|
|
||
|
} catch (\Exception $e) {
|
||
|
self::$error = $e->getMessage();
|
||
|
return false;
|
||
|
}
|
||
|
}
|
||
|
}
|