CRMEB_PRO_M/app/controller/admin/v1/supplier/SupplierExtract.php

145 lines
4.2 KiB
PHP
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<?php
// +----------------------------------------------------------------------
// | CRMEB [ CRMEB赋能开发者助力企业发展 ]
// +----------------------------------------------------------------------
// | Copyright (c) 2016~2020 https://www.crmeb.com All rights reserved.
// +----------------------------------------------------------------------
// | Licensed CRMEB并不是自由软件未经许可不能去掉CRMEB相关版权
// +----------------------------------------------------------------------
// | Author: CRMEB Team <admin@crmeb.com>
// +----------------------------------------------------------------------
namespace app\controller\admin\v1\supplier;
use think\facade\App;
use app\controller\admin\AuthController;
use app\services\supplier\finance\SupplierExtractServices;
/**
* 供应商提现
* Class SupplierExtract
* @package app\controller\admin\v1\supplier
*/
class SupplierExtract extends AuthController
{
/**
* StoreExtract constructor.
* @param App $app
* @param SupplierExtractServices $services
*/
public function __construct(App $app, SupplierExtractServices $services)
{
parent::__construct($app);
$this->services = $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'],
['supplier_id', '']
]);
if (isset($where['extract_type']) && $where['extract_type'] == 'wx') {
$where['extract_type'] = 'weixin';
}
$whereData = [
'supplier_id' => $where['supplier_id'],
'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) {
return app('json')->fail('缺少参数');
}
if (!$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 $id
* @return mixed
*/
public function verify($id)
{
if (!$id) $this->fail('缺少参数');
[$type, $message] = $this->request->postMore([
['type', 1],
['message', '']
], true);
$adminId = $this->adminId;
if ($type == 1) {
$res = $this->services->adopt($id, $adminId);
} else {
$res = $this->services->refuse((int)$id, $message, $adminId);
}
return $this->success($res ? '操作成功' : '操作失败');
}
/**
* 转账表单
* @param $id
* @return mixed
*/
public function transfer($id)
{
if (!$id) $this->fail('缺少参数');
return $this->success($this->services->add_transfer((int)$id));
}
/**
* 转账提交
* @param $id
* @return mixed
*/
public function save_transfer($id)
{
$data = $this->request->postMore([
['voucher_image', ''],
['voucher_title', '']
]);
$info = $this->services->getExtract($id);
if (!$info) $this->fail('提现记录不存在');
if ($info['status'] != 1) $this->fail('请先审核提现记录');
if ($info['pay_status'] == 1) $this->fail('请勿重复提现');
$data['pay_status'] = 1;
if (!$this->services->update($id, $data)) {
return app('json')->fail('转账失败');
}
return app('json')->success('转账成功');
}
}