UserCarkController.php 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172
  1. <?php
  2. namespace plugin\admin\app\controller;
  3. use app\api\repositories\MoneyLogRepositories;
  4. use app\business\StreamBusiness;
  5. use Illuminate\Support\Arr;
  6. use plugin\admin\app\model\ApplyRecord;
  7. use plugin\admin\app\model\UserCark;
  8. use plugin\admin\app\repositories\WithdrawRepositories;
  9. use Respect\Validation\Validator;
  10. use support\Db;
  11. use support\Log;
  12. use support\Request;
  13. use support\Response;
  14. use plugin\admin\app\model\Withdraw;
  15. use plugin\admin\app\controller\Crud;
  16. use support\exception\BusinessException;
  17. /**
  18. * 提现列表
  19. */
  20. class UserCarkController extends Crud
  21. {
  22. /**
  23. * @var UserCark
  24. */
  25. protected $model = null;
  26. /**
  27. * 构造函数
  28. * @return void
  29. */
  30. public function __construct()
  31. {
  32. $this->model = new UserCark();
  33. }
  34. /**
  35. * 浏览
  36. * @return Response
  37. */
  38. public function index(): Response
  39. {
  40. return view('usercark/index');
  41. }
  42. /**
  43. * 更新
  44. * @param Request $request
  45. * @return Response
  46. * @throws BusinessException
  47. */
  48. public function update(Request $request): Response
  49. {
  50. if ($request->method() === 'POST') {
  51. return parent::update($request);
  52. }
  53. return view('usercark/update');
  54. }
  55. /**查询收银余额
  56. * @param Request $request
  57. * @return Response
  58. */
  59. public function select(Request $request): Response
  60. {
  61. $param = $request->all();
  62. $data = UserCark::query()->where(function ($query) use ($param) {
  63. if (Arr::get($param, 'created_at.0') && Arr::get($param, 'created_at.1')) {
  64. $query->whereBetween('created_at', [$param['created_at'][0], $param['created_at'][1]]);
  65. } elseif (Arr::get($param, 'created_at.0')) {
  66. $query->where('created_at', '>=', $param['created_at'][0]);
  67. } elseif (Arr::get($param, 'created_at.1')) {
  68. $query->where('created_at', '<=', $param['created_at'][1]);
  69. }
  70. if (Arr::get($param, 'status')) {
  71. $query->where('status', $param['status']);
  72. }
  73. if (Arr::get($param, 'id')) {
  74. $query->where('id', $param['id']);
  75. }
  76. })->whereExists(function ($query) use ($param) {
  77. $query->from('wa_users')->whereRaw('wa_users.id=wa_user_social_cark.user_id');
  78. if (Arr::get($param, 'user_name')) {
  79. $query->where('name', 'like', '%' . $param['user_name'] . '%');
  80. }
  81. if (Arr::get($param, 'user_mobile')) {
  82. $query->where('mobile', 'like', '%' . $param['user_mobile'] . '%');
  83. }
  84. })
  85. ->with('userData:id,name,mobile');
  86. if (Arr::get($param, 'field')) {
  87. $order = 'asc';
  88. if (Arr::get($param, 'order')) {
  89. $order = 'desc';
  90. }
  91. $data = $data->orderBy($param['field'], $order);
  92. } else {
  93. $data = $data->orderBy('updated_at', 'desc');
  94. }
  95. $data = $data->paginate(Arr::get($param, 'limit', 10))->toArray();
  96. $arr = [];
  97. foreach ($data['data'] as $k => $v) {
  98. $arr[] = [
  99. 'id' => $v['id'],
  100. 'user_name' => $v['user_data']['name'],
  101. 'user_mobile' => $v['user_data']['mobile'],
  102. 'name' => $v['name'],
  103. 'number' => $v['number'],
  104. 'mobile' => $v['mobile'],
  105. 'card_num' => $v['card_num'],
  106. 'status' => $v['status'],
  107. 'created_at' => $v['created_at'],
  108. 'updated_at' => $v['updated_at'],
  109. 'address' => $v['address'],
  110. ];
  111. }
  112. return json(['code' => 0, 'data' => $arr, 'msg' => 'ok', 'count' => $data['total']]);
  113. }
  114. /** 批量通过
  115. * @param Request $request
  116. * @return Response
  117. */
  118. public function pass(Request $request): Response
  119. {
  120. try {
  121. $param = $request->all();
  122. Validator::input($param, [
  123. 'id' => Validator::notEmpty()->ArrayType()->setName('标识'),
  124. ]);
  125. $applyRecordModel = UserCark::query();
  126. foreach ($param['id'] as $k => $v) {
  127. Db::beginTransaction();
  128. try {
  129. $system = Db::table('wa_system')->first();
  130. $has = (clone $applyRecordModel)->where('id', $v)->lock(true)->first();
  131. if (empty($has)) {
  132. throw new \Exception('数据不存在!');
  133. }
  134. if ($has->status != 1) {
  135. throw new \Exception('数据已经处理!');
  136. }
  137. if ($has && $has->status == 1) {
  138. $has->status = 2;
  139. $has->updated_at = date('Y-m-d H:i:s');
  140. $has->save();
  141. } else {
  142. throw new \Exception('已处理请不要重复提交!');
  143. }
  144. Db::commit();
  145. } catch (\Throwable $exception) {
  146. Db::rollBack();
  147. throw new \Exception($exception->getMessage());
  148. }
  149. }
  150. } catch (\Throwable $exception) {
  151. return $this->fail($exception->getMessage());
  152. }
  153. return $this->success();
  154. }
  155. }