Files
huangjingfen/pro_v3.5.1/app/controller/supplier/finance/SupplierExtract.php
panchengyong c1e74d8e68 chore(php): 统一 ScottPan 文件头与注释域名替换
- 按 docs/renew-code-comment.md 将 PHP 文件头改为带边框的 Author 注释\n- 注释中的 crmeb.com 替换为 uj345.cn(代码字符串中的外链未改)\n- 新增 docs/renew-code-comment.md 说明

Made-with: Cursor
2026-03-29 11:22:58 +08:00

124 lines
4.1 KiB
PHP

<?php
// +----------------------------------------------------------------------
// | Author: ScottPan Team
// +----------------------------------------------------------------------
namespace app\controller\supplier\finance;
use app\services\supplier\finance\SupplierFlowingWaterServices;
use think\annotation\Inject;
use think\exception\ValidateException;
use think\facade\App;
use think\facade\Config;
use app\controller\supplier\AuthController;
use app\services\supplier\finance\SupplierExtractServices;
/**
* 供应商提现
* Class SupplierExtract
* @package app\controller\supplier\finance
*/
class SupplierExtract extends AuthController
{
/**
* @var SupplierExtractServices
*/
#[Inject]
protected SupplierExtractServices $services;
/**
* 显示资源列表
* @return mixed
* @throws \think\db\exception\DataNotFoundException
* @throws \think\db\exception\DbException
* @throws \think\db\exception\ModelNotFoundException
*/
public function index()
{
$where = $this->request->getMore([
['status', ''],
['pay_status', ''],
['extract_type', ''],
['nireid', '', '', 'like'],
['data', '', '', 'time'],
]);
if (isset($where['extract_type']) && $where['extract_type'] == 'wx') {
$where['extract_type'] = 'weixin';
}
$where['supplier_id'] = $this->supplierId;
$whereData = [
'supplier_id' => $this->supplierId,
'is_del' => 0,
];
return app('json')->success($this->services->index($where,$whereData));
}
/**
* 增加备注
* @param $id
* @return mixed
*/
public function mark($id)
{
[$mark] = $this->request->getMore([
['mark', '']
], true);
if (!$id || !$mark) {
return app('json')->fail('缺少参数');
}
$extract = $this->services->get((int)$id);
if (!$extract) {
return app('json')->fail('转账记录不存在');
}
if (!$this->services->update($id, ['supplier_mark' => $mark])) {
return app('json')->fail('备注失败');
}
return app('json')->success('备注成功');
}
/**
* 提现申请
* @param Request $request
* @return mixed
*/
public function cash()
{
$extractInfo = $this->request->postMore([
['extract_type', ''],
['money', 0],
['mark', '']
]);
$extractType = Config::get('pay.extractType', []);
//最低提现
$supplier_extract_min_price = sys_config('supplier_extract_min_price') ?? 0;
//最高提现
$supplier_extract_max_price = sys_config('supplier_extract_max_price') ?? 0;
if ($extractInfo['money'] < $supplier_extract_min_price)
return app('json')->fail('最低提现' . $supplier_extract_min_price . '元');
if ($extractInfo['money'] > $supplier_extract_max_price)
return app('json')->fail('最高提现' . $supplier_extract_max_price . '元');
//可提现金额
/** @var SupplierFlowingWaterServices $financeFlowServices */
$financeFlowServices = app()->make(SupplierFlowingWaterServices::class);
$whereData = [
'supplier_id' => $this->supplierId,
'is_del' => 0,
];
$price_not = $financeFlowServices->getSumFinance(['supplier_id' => $this->supplierId], $whereData);
if ($extractInfo['money'] > $price_not) {
throw new ValidateException($price_not > 0 ? '可提现金额为' . $price_not . '元': '暂无可提现金额');
}
if (!in_array($extractInfo['extract_type'], $extractType))
return app('json')->fail('转账方式不存在');
if (!preg_match('/^[0-9]+(.[0-9]{1,2})?$/', (float)$extractInfo['money'])) return app('json')->fail('转账金额输入有误');
if ($this->services->cash((int)$this->supplierId, $extractInfo))
return app('json')->successful('申请转账成功!');
else
return app('json')->fail('转账失败');
}
}