|
@@ -0,0 +1,122 @@
|
|
|
+<?php
|
|
|
+
|
|
|
+namespace Modules\Jiesuan\Http\Controllers;
|
|
|
+
|
|
|
+use Catch\Base\CatchController;
|
|
|
+use Illuminate\Foundation\Validation\ValidatesRequests;
|
|
|
+use Illuminate\Http\Request;
|
|
|
+use Illuminate\Support\Facades\DB;
|
|
|
+use Modules\Jiesuan\Services\BusinessmanService;
|
|
|
+use Modules\Jiesuan\Services\ConstService;
|
|
|
+use Modules\User\Http\Controllers\UserTrait;
|
|
|
+
|
|
|
+
|
|
|
+class BankAccountController extends CatchController
|
|
|
+{
|
|
|
+ use UserTrait;
|
|
|
+ use ValidatesRequests;
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 添加公司结算银行卡
|
|
|
+ * @param Request $request
|
|
|
+ */
|
|
|
+ public function addCompanyCard(Request $request) {
|
|
|
+ $this->validate($request, [
|
|
|
+ 'owner_name' => 'required|string|max:64',
|
|
|
+ 'name_of_payee' => 'required|string|max:128',
|
|
|
+ 'card_no' => 'required',
|
|
|
+ 'bank_name' => 'required|string|max:128',
|
|
|
+ 'sub_bank_name' => 'required|string|max:256',
|
|
|
+ 'phone_of_payee' => 'required',
|
|
|
+ 'business_id' => 'required',
|
|
|
+ ]);
|
|
|
+
|
|
|
+ $company_uid = $this->getLoginUserId();
|
|
|
+ $id = $request->input('id');
|
|
|
+ $data = $request->all();
|
|
|
+ $now = date('Y-m-d H:i:s');
|
|
|
+ if($id) {
|
|
|
+ $data['updated_at'] = $now;
|
|
|
+ // 只有待审核的允许修改
|
|
|
+ DB::table('bank_cards')
|
|
|
+ ->where([
|
|
|
+ 'id' => $id, 'status' => 1, 'company_uid'=> $company_uid
|
|
|
+ ])->update($data);
|
|
|
+ } else {
|
|
|
+ $data['status'] = 1;
|
|
|
+ $data['updated_at'] = $data['created_at'] = $now;
|
|
|
+ DB::table('bank_cards')
|
|
|
+ ->insert($data);
|
|
|
+ }
|
|
|
+ return 'ok';
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 商务列表
|
|
|
+ * @param Request $request
|
|
|
+ */
|
|
|
+ public function listShangwu(Request $request) {
|
|
|
+ return BusinessmanService::list();
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 银行列表
|
|
|
+ * @param Request $request
|
|
|
+ */
|
|
|
+ public function listBank(Request $request) {
|
|
|
+ return DB::table('banks')
|
|
|
+ ->where(['is_show' => 1])
|
|
|
+ ->select('id', 'name')
|
|
|
+ ->get();
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 公司银行卡列表
|
|
|
+ * @param Request $request
|
|
|
+ */
|
|
|
+ public function listCompanyCard(Request $request) {
|
|
|
+ $company_uid = $this->getLoginUserId();
|
|
|
+ $ownerName = $request->input('owner_name');
|
|
|
+ $businessId = $request->input('business_id');
|
|
|
+ $createStartAt = $request->input('create_start_at');
|
|
|
+ $createEndAt = $request->input('create_end_at');
|
|
|
+ $bankCards = DB::table('bank_cards')
|
|
|
+ ->where([
|
|
|
+ 'company_uid' => $company_uid
|
|
|
+ ])->where('status', '<>', 0)
|
|
|
+ ->when($ownerName, function ($query, $ownerName){
|
|
|
+ return $query->where('owner_name', 'like', '%'. $ownerName . '%');
|
|
|
+ })->when($businessId, function ($query, $businessId){
|
|
|
+ return $query->where('business_id', $businessId);
|
|
|
+ })->when($createStartAt, function ($query, $createStartAt) {
|
|
|
+ return $query->where('created_at', '>=', $createStartAt);
|
|
|
+ })->when($createEndAt, function ($query, $createEndAt){
|
|
|
+ return $query->where('created_at', '<=', $createEndAt);
|
|
|
+ })
|
|
|
+ ->orderBy('id', 'desc')
|
|
|
+ ->paginate($request->input('limit', 15));
|
|
|
+ $businessmans = BusinessmanService::list()->keyBy('id');
|
|
|
+ foreach ($bankCards as $bankCard) {
|
|
|
+ $bankCard->status_str = ConstService::BANK_CARD_CHECK_STATUS[$bankCard->status] ?? '';
|
|
|
+ $bankCard->business_str = $businessmans->get($bankCard->business_id)->username ?? '';
|
|
|
+ }
|
|
|
+
|
|
|
+ return $bankCards;
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 合作信息
|
|
|
+ * @param Request $request
|
|
|
+ */
|
|
|
+ public function hezuoInfo(Request $request) {
|
|
|
+ $shareRate = DB::table('company_share_rates')
|
|
|
+ ->whereIn('company_uid', [0, $this->getLoginUserId()])
|
|
|
+ ->select('company_uid', 'share_rate')
|
|
|
+ ->orderBy('company_uid', 'desc')
|
|
|
+ ->first()->share_rate ?? '89.1';
|
|
|
+
|
|
|
+ return [
|
|
|
+ 'share_rate' => $shareRate . '%',
|
|
|
+ ];
|
|
|
+ }
|
|
|
+}
|