diff --git a/app/admin/controller/supplychain/Extract.php b/app/admin/controller/supplychain/Extract.php new file mode 100644 index 0000000..d9ecd2e --- /dev/null +++ b/app/admin/controller/supplychain/Extract.php @@ -0,0 +1,209 @@ +adminInfo = get_login_admin(); + $this->category_id = 354; + $this->url=[ + '/admin/supplychain.extract/index?category_id='.$this->category_id, + '/admin/supplychain.extract/add', + '/admin/supplychain.extract/cancel', + '/admin/supplychain.extract/accountInfo', + ]; + } + + /** + * + * 数据列表 + * + */ + public function index() + { + + if (request()->isAjax()) + { + + $params= get_params(); + + $where[]= ['status','=',0]; + + if (isset($params['keywords']) && !empty($params['keywords'])){ + $where[]= ['name','like','%'.$params['keywords'].'%']; + } + if($this->adminInfo['position_id'] != 1){ //不是超级管理员 + $www['admin_id'] = $this->adminInfo['id']; + $user_address = Db::table('fa_szxc_information_useraddress')->where($www)->find(); + if ($user_address){ + if($user_address['auth_range'] == 1){ + $where[] = ['village_id','=',$user_address['village_id']]; + }elseif ($user_address['auth_range'] == 2){ + $where[] = ['street_id','=',$user_address['street_id']]; + }elseif ($user_address['auth_range'] == 3){ + $where[] = ['area_id','=',$user_address['area_id']]; + }else{ + $where[] = ['village_id','=',$user_address['village_id']]; + } + }else{ + $where[] = ['village_id','=','']; + } + } + + $total = SupplyExtract::where($where)->count(); + + $list = SupplyExtract::with(['user', 'adminUser'])->order('id desc')->select(); + + $result = ['total' => $total, 'data' => $list]; + + return table_assign(0, '', $result); + + }else{ + + $list = SupplyExtract::with(['user', 'adminUser'])->select(); + + View::assign('list', $list); + View::assign('teamId', 12); + View::assign('url', $this->url); + return view(); + + } + } + + + /** + * + * 申请提现 + * + */ + public function add() + { + $params = get_params(); + + if (request()->isAjax()) + { + // 取出供应链小组信息 + $team = SupplyTeam::find($params['teamId']); + // 取出账号信息 + $accountInfo = SupplyAccountModel::where('fa_supply_team_id', $params['teamId'])->find(); + + // 验证金额 + if($team['brokerage'] < $params['extract_price']) + { + return to_assign(1, '操作失败,可提现余额不足'); + } + + // 开启事务,处理提现 + Db::startTrans(); + try { + + // 1、减去余额 + SupplyTeam::where('id', $params['teamId']) + ->dec('brokerage', $params['extract_price']) + ->update(); + + // 2、写入提现记录 + $data = [ + 'uid' => $this->adminInfo['id'], + 'extract_sn' => $this->build_order_no(), // 流水号 + 'real_name' => $accountInfo['name'], // 姓名 + 'extract_type' => 0, // 提现类型,目前只支持银行卡,默认 0 + 'bank_code' => $accountInfo['account'], // 银行卡号 + 'bank_address' => $accountInfo['bank'], // 开户地址 + // 'alipay_code' => , + // 'wechat' => , + // 'extract_pic' => , + 'extract_price' => $params['extract_price'], // 提现金额 + 'balance' => $team['brokerage'], + 'mark' => '当前金额:' . $team['brokerage'] . ',申请提现金额:' . $params['extract_price'], + 'create_time' => date('Y-m-d H:i:s'), // 申请时间 + 'bank_name' => $accountInfo['bank'], // 银行名称 + 'source' => 1, // 提现来源 1 供应链服务商团队 + 'fa_supply_team_id' => $accountInfo['fa_supply_team_id'], // 提现团队ID + ]; + + // 写入提现记录 + $status = SupplyExtract::create($data); + + // 提交事务 + Db::commit(); + + } catch (\Exception $e) { + + // 回滚事务 + Db::rollback(); + return to_assign(1, '操作失败,原因:' . $e->getMessage()); + } + + return to_assign(0, '操作成功'); + + }else{ + + // 取出账号信息 + $accountInfo = SupplyAccountModel::where('fa_supply_team_id', $params['teamId'])->find(); + $team = SupplyTeam::find($params['teamId']); + + if(!$accountInfo) // 验证是否有提现账户 + { + return redirect('/admin/supply_account/add'); + } + + View::assign('teamId', $params['teamId']); + View::assign('team', $team); + View::assign('accountInfo', $accountInfo); + View::assign('url', $this->url); + View::assign('mer_id', 123); + return view(); + } + + } + + /** + * + * 撤回提现 + * + */ + public function cancel() + { + + } + + /** + * + * 提现账户信息 多提现账户预留 + * + */ + public function accountInfo() + { + $params = get_params(); + $teamId = $params['teamId']; + + return json($accountInfo); + } + + public function build_order_no() { + return date('Ymd').substr(implode(NULL, array_map('ord', str_split(substr(uniqid(), 7, 13), 1))), 0, 8); + } +} \ No newline at end of file diff --git a/app/admin/view/supply_account/add.html b/app/admin/view/supply_account/add.html index 0bff322..4e4196e 100644 --- a/app/admin/view/supply_account/add.html +++ b/app/admin/view/supply_account/add.html @@ -2,7 +2,7 @@ {block name="body"}
-

新建供应链团队角色提现账户信息

+

新建提现账户信息

diff --git a/app/admin/view/supplychain/extract/add.html b/app/admin/view/supplychain/extract/add.html new file mode 100644 index 0000000..58b6d7d --- /dev/null +++ b/app/admin/view/supplychain/extract/add.html @@ -0,0 +1,101 @@ +{extend name="common/base"/} +{block name="style"} + +{/block} + +{block name="body"} + +

关联商户

+
账号* 用户名*
+ + + + + + + + +
+
+ +
+ 账户名:{$accountInfo.name}
+ 账号:{$accountInfo.account}
+ 开户行地址:{$accountInfo.bank}
+ 可提现金额:{$team.brokerage}
+ 冻结金额:{$team.free_brokerage}
+ 已提现金额:{$team.withdraw_brokerage} +
+
+
+
+ +
+ + +
+
+
+
+ + +
+ +
+{/block} + + + +{block name="script"} + + + +{/block} + \ No newline at end of file diff --git a/app/admin/view/supplychain/extract/index.html b/app/admin/view/supplychain/extract/index.html new file mode 100644 index 0000000..b7dad22 --- /dev/null +++ b/app/admin/view/supplychain/extract/index.html @@ -0,0 +1,219 @@ +{extend name="common/base"/} + +{block name="body"} + +
+
+
+ +
+ +
+
+
+ + + + + + + + +{/block} + + + +{block name="script"} + +{/block} + \ No newline at end of file diff --git a/app/common/model/SupplyExtract.php b/app/common/model/SupplyExtract.php index 41413fb..0831a08 100644 --- a/app/common/model/SupplyExtract.php +++ b/app/common/model/SupplyExtract.php @@ -4,7 +4,8 @@ * @license https://opensource.org/licenses/Apache-2.0 * @link https://www.gougucms.com */ -namespace app\admin\model; +namespace app\common\model; + use think\model; use app\common\model\User; use app\admin\model\ShopUser; @@ -19,4 +20,23 @@ class SupplyExtract extends Model // 设置当前模型对应的完整数据表名称 protected $table = 'supply_extract'; + /** + * + * 关联用户信息 + * + */ + public function user() + { + return $this->hasOne(ShopUser::class, 'uid', 'uid'); + } + + /*** + * + * 关联审核信息 + * + */ + public function adminUser() + { + return $this->hasOne(ShopUser::class, 'uid', 'admin_id'); + } } \ No newline at end of file