BankAccountController.php 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174
  1. <?php
  2. namespace Modules\Jiesuan\Http\Controllers;
  3. use Catch\Base\CatchController;
  4. use Illuminate\Foundation\Validation\ValidatesRequests;
  5. use Illuminate\Http\Request;
  6. use Illuminate\Support\Facades\DB;
  7. use Modules\Jiesuan\Services\BusinessmanService;
  8. use Modules\Jiesuan\Services\ConstService;
  9. use Modules\User\Http\Controllers\UserTrait;
  10. class BankAccountController extends CatchController
  11. {
  12. use UserTrait;
  13. use ValidatesRequests;
  14. /**
  15. * 添加公司结算银行卡
  16. * @param Request $request
  17. */
  18. public function addCompanyCard(Request $request) {
  19. $this->validate($request, [
  20. 'owner_name' => 'required|string|max:64',
  21. 'name_of_payee' => 'required|string|max:128',
  22. 'card_no' => 'required',
  23. 'bank_name' => 'required|string|max:128',
  24. 'sub_bank_name' => 'required|string|max:256',
  25. 'phone_of_payee' => 'required',
  26. // 'business_id' => 'required',
  27. ]);
  28. $company_uid = $this->getLoginUserId();
  29. $id = $request->input('id');
  30. $now = date('Y-m-d H:i:s');
  31. if($id) {
  32. // $data = $request->only(['owner_name', 'name_of_payee', 'card_no','bank_name', 'sub_bank_name', 'phone_of_payee', 'business_id']);
  33. $data = $request->only(['owner_name', 'name_of_payee', 'card_no','bank_name', 'sub_bank_name', 'phone_of_payee']);
  34. $data['updated_at'] = $now;
  35. // 只有待审核的允许修改 --放弃
  36. // DB::table('bank_cards')
  37. // ->where([
  38. // 'id' => $id, 'status' => 1, 'company_uid'=> $company_uid
  39. // ])->update($data);
  40. DB::table('bank_cards')
  41. ->where([
  42. 'id' => $id, 'company_uid'=> $company_uid
  43. ])->update($data);
  44. } else {
  45. $data = $request->all();
  46. $data['status'] = 2; // 免审直接通过
  47. $data['updated_at'] = $data['created_at'] = $now;
  48. $data['company_uid'] = $company_uid;
  49. DB::table('bank_cards')
  50. ->insert($data);
  51. }
  52. return 'ok';
  53. }
  54. /**
  55. * 商务列表
  56. * @param Request $request
  57. */
  58. public function listShangwu(Request $request) {
  59. return BusinessmanService::list();
  60. }
  61. /**
  62. * 银行列表
  63. * @param Request $request
  64. */
  65. public function listBank(Request $request) {
  66. return DB::table('banks')
  67. ->where(['is_show' => 1])
  68. ->select('id', 'name')
  69. ->get();
  70. }
  71. /**
  72. * 公司银行卡列表
  73. * @param Request $request
  74. */
  75. public function listCompanyCard(Request $request) {
  76. $company_uid = $this->getLoginUserId();
  77. $ownerName = $request->input('owner_name');
  78. $businessId = $request->input('business_id');
  79. $createStartAt = $request->input('create_start_at');
  80. $createEndAt = $request->input('create_end_at');
  81. $nameOfPayee = $request->input('name_of_payee');
  82. $bankCards = DB::table('bank_cards')
  83. ->where([
  84. 'company_uid' => $company_uid
  85. ])->where('status', '<>', 0)
  86. ->when($ownerName, function ($query, $ownerName){
  87. return $query->where('owner_name', 'like', '%'. $ownerName . '%');
  88. })->when($businessId, function ($query, $businessId){
  89. return $query->where('business_id', $businessId);
  90. })->when($createStartAt, function ($query, $createStartAt) {
  91. return $query->where('created_at', '>=', $createStartAt);
  92. })->when($createEndAt, function ($query, $createEndAt){
  93. return $query->where('created_at', '<=', $createEndAt . ' 23:59:59');
  94. })->when($nameOfPayee,function ($query, $nameOfPayee){
  95. return $query->where('name_of_payee', 'like', '%'. $nameOfPayee . '%');
  96. })
  97. ->orderBy('id', 'desc')
  98. ->paginate($request->input('limit', 15));
  99. $businessmans = BusinessmanService::list()->keyBy('id');
  100. foreach ($bankCards as $bankCard) {
  101. $bankCard->status_str = ConstService::BANK_CARD_CHECK_STATUS[$bankCard->status] ?? '';
  102. if ($bankCard->business_id > 0){
  103. $bankCard->business_str = $businessmans->get($bankCard->business_id)->username ?? '';
  104. }else{
  105. $bankCard->business_str = "";
  106. }
  107. }
  108. return $bankCards;
  109. }
  110. /**
  111. * 公司管理员可用的银行卡列表
  112. * @param Request $request
  113. */
  114. public function listAvailableBankCard(Request $request) {
  115. $company_uid = $this->getLoginUserId();
  116. return DB::table('bank_cards')
  117. ->where([
  118. 'company_uid' => $company_uid,
  119. // 'status' => 2
  120. ])->where('status','>',0)
  121. ->select('id', 'bank_name', 'card_no', 'sub_bank_name')
  122. ->get();
  123. }
  124. /**
  125. * 合作信息
  126. * @param Request $request
  127. */
  128. public function hezuoInfo(Request $request) {
  129. $shareRate = DB::table('company_share_rates')
  130. ->whereIn('company_uid', [0, $this->getLoginUserId()])
  131. ->select('company_uid', 'share_rate')
  132. ->orderBy('company_uid', 'desc')
  133. ->first()->share_rate ?? '89.1';
  134. return [
  135. 'share_rate' => $shareRate . '%',
  136. ];
  137. }
  138. /**
  139. * 删除银行卡信息
  140. * @param Request $request
  141. */
  142. public function delCompanyCard(Request $request) {
  143. $this->validate($request, [
  144. 'id' => 'required'
  145. ]);
  146. $company_uid = $this->getLoginUserId();
  147. DB::table('bank_cards')
  148. ->where([
  149. 'company_uid' => $company_uid,
  150. 'id' => $request->input('id'),
  151. ])
  152. // ->where('status', '<>', 2)
  153. ->update([
  154. 'status' => 0,
  155. 'updated_at' => date('Y-m-d H:i:s')
  156. ]);
  157. return 'ok';
  158. }
  159. }