海南旅游SAAS
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

111 lines
3.5 KiB

4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
  1. <?php
  2. namespace App\AdminSupplier\Controllers;
  3. use App\AdminAgent\Repositories\WithdrawalAlipay;
  4. use App\Common\StatementType;
  5. use App\Models\Agent;
  6. use App\Models\Supplier;
  7. use App\Models\SystemSetting;
  8. use App\Models\Withdrawal;
  9. use App\Service\WithdrawalService;
  10. use App\Traits\DemandTraits;
  11. use App\Traits\WithdrawalTraits;
  12. use Dcat\Admin\Admin;
  13. use Dcat\Admin\Form;
  14. use Dcat\Admin\Grid;
  15. use Dcat\Admin\Repositories\EloquentRepository;
  16. use Dcat\Admin\Show;
  17. use Dcat\Admin\Http\Controllers\AdminController;
  18. use Illuminate\Database\Eloquent\Model;
  19. use Illuminate\Support\Facades\DB;
  20. class WithdrawalAlipayController extends AdminController
  21. {
  22. /**
  23. * Make a form builder.
  24. *
  25. * @return Form
  26. */
  27. protected function form()
  28. {
  29. return Form::make(new WithdrawalAlipay(), function (Form $form) {
  30. $auto = Withdrawal::query()
  31. ->with('pay')
  32. ->where([
  33. 'user_id' => Admin::user()->id,
  34. 'user_type' => DemandTraits::$col[1],
  35. 'status' => WithdrawalTraits::$state[3],
  36. 'pay_type' => WithdrawalTraits::$userType[0],
  37. ])
  38. ->orderByDesc('updated_at')
  39. ->first();
  40. $form->display('id');
  41. $min = SystemSetting::val('withdrawal', WithdrawalTraits::$adminType[3]) ?? 0;
  42. $form->decimal('price','提现金额')->rules('required|numeric|min:'.$min.'|not_in:0',[
  43. '*' => '提现金额为必填字段且必须大于'.$min,
  44. ])
  45. ->default($auto->price ?? 0)
  46. ->help('含手续费' . SystemSetting::val('withdrawal', WithdrawalTraits::$adminType[1]) . ' %,最小提现金额'.$min);
  47. $form->text('account')->required()->maxLength(50)->default($auto->pay->account ?? '');
  48. $form->text('name')->required()->maxLength(50)->default($auto->pay->name ?? '');
  49. $form->image('qrcode');
  50. $form->hidden('withdrawal_id');
  51. $form->saving(function (Form $form) {
  52. DB::beginTransaction();
  53. try {
  54. $user = Supplier::query()->where('id', Admin::user()->id)->lockForUpdate()->first();
  55. //手续费
  56. $cutPrice = bcmul($form->price, SystemSetting::val('withdrawal', WithdrawalTraits::$adminType[1]), 6);
  57. $cutPrice = $cutPrice > 0 ? bcdiv($cutPrice, 100, 6) : 0;
  58. //总花费
  59. $total = bcadd($form->price, $cutPrice,6);
  60. if ($total > $user->balance) {
  61. return $form->response()->error('余额不足,本次提现需花费'.bcadd($total,0,2).'(含手续费),当前可用余额为' . $user->balance);
  62. }
  63. //提现扣钱流水
  64. $service = new WithdrawalService();
  65. $service->create(
  66. bcmul($form->price, -1, 6),
  67. StatementType::WITHDRAWAL,
  68. Admin::user()->id,
  69. DemandTraits::$col[1]
  70. );
  71. //提现手续费流水
  72. $service->create(
  73. bcmul($cutPrice, -1, 6),
  74. StatementType::WITHDRAWAL_CAT,
  75. Admin::user()->id,
  76. DemandTraits::$col[1]
  77. );
  78. $user->balance = bcsub($user->balance, $total, 6);
  79. $user->save();
  80. $withdrawal = new Withdrawal();
  81. $withdrawal->user_id = Admin::user()->id;
  82. $withdrawal->user_type = DemandTraits::$col[1];
  83. $withdrawal->price = request('price', 0);
  84. $withdrawal->cut_price = $cutPrice;
  85. //$withdrawal->pay_id = $form->getKey();
  86. $withdrawal->pay_type = WithdrawalTraits::$userType[0];
  87. $withdrawal->save();
  88. $form->withdrawal_id = $withdrawal->id;
  89. $form->deleteInput('price');
  90. DB::commit();
  91. } catch (\Exception $e) {
  92. DB::rollBack();
  93. return $form->response()->error($e->getMessage());
  94. }
  95. });
  96. $form->saved(function (Form $form) {
  97. $withdrawal = Withdrawal::find($form->withdrawal_id);
  98. $withdrawal->pay_id = $form->getKey();
  99. $withdrawal->save();
  100. });
  101. });
  102. }
  103. }