UserExtract.php 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177
  1. <?php
  2. /**
  3. * Created by PhpStorm.
  4. * User: lianghuan
  5. * Date: 2018-03-03
  6. * Time: 16:37
  7. */
  8. namespace app\admin\controller\finance;
  9. use app\admin\controller\AuthController;
  10. use think\facade\Route as Url;
  11. use crmeb\services\JsonService;
  12. use app\admin\model\user\UserExtract as UserExtractModel;
  13. use crmeb\services\{UtilService as Util, FormBuilder as Form};
  14. /**
  15. * 用户提现管理
  16. * Class UserExtract
  17. * @package app\admin\controller\finance
  18. */
  19. class UserExtract extends AuthController
  20. {
  21. public function index()
  22. {
  23. $where = Util::getMore([
  24. ['status', ''],
  25. ['nickname', ''],
  26. ['extract_type', ''],
  27. ['nireid', ''],
  28. ['date', ''],
  29. ], $this->request);
  30. $limitTimeList = [
  31. 'today' => implode(' - ', [date('Y/m/d'), date('Y/m/d', strtotime('+1 day'))]),
  32. 'week' => implode(' - ', [
  33. date('Y/m/d', (time() - ((date('w') == 0 ? 7 : date('w')) - 1) * 24 * 3600)),
  34. date('Y-m-d', (time() + (7 - (date('w') == 0 ? 7 : date('w'))) * 24 * 3600))
  35. ]),
  36. 'month' => implode(' - ', [date('Y/m') . '/01', date('Y/m') . '/' . date('t')]),
  37. 'quarter' => implode(' - ', [
  38. date('Y') . '/' . (ceil((date('n')) / 3) * 3 - 3 + 1) . '/01',
  39. date('Y') . '/' . (ceil((date('n')) / 3) * 3) . '/' . date('t', mktime(0, 0, 0, (ceil((date('n')) / 3) * 3), 1, date('Y')))
  40. ]),
  41. 'year' => implode(' - ', [
  42. date('Y') . '/01/01', date('Y/m/d', strtotime(date('Y') . '/01/01 + 1year -1 day'))
  43. ])
  44. ];
  45. $res = UserExtractModel::systemPage($where);
  46. $money_type = sys_data('money_type');
  47. foreach ($res['list'] as &$v) {
  48. if ($v['money_type'] != 'brokerage') {
  49. foreach ($money_type as $vv) {
  50. if ($vv['code'] == $v['money_type']) {
  51. $usdt_price = $vv['usdt_price'];
  52. if ($vv['usdt_price'] == 0) {
  53. $usdt_price = get_huobi_price($vv['code']);
  54. }
  55. if ($v['code'] == 'LALA') {
  56. $usdt_price = get_lala_ratio();
  57. }
  58. $usdt = bcmul($v['real_get'], $usdt_price, 8);
  59. $rmb = bcmul($usdt, us_price(), 2);
  60. $v['get_rmb'] = $rmb;
  61. }
  62. }
  63. } else {
  64. $v['real_get'] = $v['extract_price'];
  65. $v['get_rmb'] = $v['extract_price'];
  66. }
  67. }
  68. $this->assign('where', $where);
  69. $this->assign('limitTimeList', $limitTimeList);
  70. $this->assign(UserExtractModel::extractStatistics());
  71. $this->assign($res);
  72. return $this->fetch();
  73. }
  74. public function edit($id)
  75. {
  76. if (!$id) return $this->failed('数据不存在');
  77. $UserExtract = UserExtractModel::get($id);
  78. if (!$UserExtract) return JsonService::fail('数据不存在!');
  79. $f = array();
  80. // $f[] = Form::input('real_name', '姓名', $UserExtract['real_name']);
  81. // $f[] = Form::number('extract_price', '提现金额', $UserExtract['extract_price'])->precision(2);
  82. // if ($UserExtract['extract_type'] == 'alipay') {
  83. // $f[] = Form::input('alipay_code', '支付宝账号', $UserExtract['alipay_code']);
  84. // } else if ($UserExtract['extract_type'] == 'weixin') {
  85. // $f[] = Form::input('wechat', '微信号', $UserExtract['wechat']);
  86. // } else {
  87. // $f[] = Form::input('bank_code', '银行卡号', $UserExtract['bank_code']);
  88. // $f[] = Form::input('bank_address', '开户行', $UserExtract['bank_address']);
  89. // }
  90. $f[] = Form::input('mark', '备注', $UserExtract['mark'])->type('textarea')->rows(20);
  91. $form = Form::make_post_form('编辑', $f, Url::buildUrl('update', array('id' => $id)));
  92. $this->assign(compact('form'));
  93. return $this->fetch('public/form-builder');
  94. }
  95. public function update($id)
  96. {
  97. $UserExtract = UserExtractModel::get($id);
  98. if (!$UserExtract) return JsonService::fail('数据不存在!');
  99. // if ($UserExtract['extract_type'] == 'alipay') {
  100. $data = Util::postMore([
  101. // 'real_name',
  102. 'mark',
  103. // 'extract_price',
  104. // 'alipay_code',
  105. ]);
  106. // if (!$data['real_name']) return JsonService::fail('请输入姓名');
  107. // if ($data['extract_price'] <= -1) return JsonService::fail('请输入提现金额');
  108. // if (!$data['alipay_code']) return JsonService::fail('请输入支付宝账号');
  109. // } else if ($UserExtract['extract_type'] == 'weixin') {
  110. // $data = Util::postMore([
  111. // 'real_name',
  112. // 'mark',
  113. // 'extract_price',
  114. // 'wechat',
  115. // ]);
  116. //// if(!$data['real_name']) return JsonService::fail('请输入姓名');
  117. // if ($data['extract_price'] <= -1) return JsonService::fail('请输入提现金额');
  118. // if (!$data['wechat']) return JsonService::fail('请输入微信账号');
  119. // } else {
  120. // $data = Util::postMore([
  121. // 'real_name',
  122. // 'extract_price',
  123. // 'mark',
  124. // 'bank_code',
  125. // 'bank_address',
  126. // ]);
  127. // if (!$data['real_name']) return JsonService::fail('请输入姓名');
  128. // if ($data['extract_price'] <= -1) return JsonService::fail('请输入提现金额');
  129. // if (!$data['bank_code']) return JsonService::fail('请输入银行卡号');
  130. // if (!$data['bank_address']) return JsonService::fail('请输入开户行');
  131. // }
  132. if (!UserExtractModel::edit($data, $id))
  133. return JsonService::fail(UserExtractModel::getErrorInfo('备注失败'));
  134. else
  135. return JsonService::successful('备注成功!');
  136. }
  137. public function fail($id)
  138. {
  139. if (!UserExtractModel::be(['id' => $id, 'status' => 0])) return JsonService::fail('操作记录不存在或状态错误!');
  140. $fail_msg = request()->post();
  141. $extract = UserExtractModel::get($id);
  142. if (!$extract) return JsonService::fail('操作记录不存在!');
  143. if ($extract->status == 1) return JsonService::fail('已经提现,错误操作');
  144. if ($extract->status == -1) return JsonService::fail('您的提现申请已被拒绝,请勿重复操作!');
  145. $res = UserExtractModel::changeFail($id, $fail_msg['message']);
  146. if ($res) {
  147. return JsonService::successful('操作成功!');
  148. } else {
  149. return JsonService::fail('操作失败!');
  150. }
  151. }
  152. public function succ($id)
  153. {
  154. if (!UserExtractModel::be(['id' => $id, 'status' => 0]))
  155. return JsonService::fail('操作记录不存在或状态错误!');
  156. UserExtractModel::beginTrans();
  157. $extract = UserExtractModel::get($id);
  158. if (!$extract) return JsonService::fail('操作记录不存!');
  159. if ($extract->status == 1) return JsonService::fail('您已提现,请勿重复提现!');
  160. if ($extract->status == -1) return JsonService::fail('您的提现申请已被拒绝!');
  161. $res = UserExtractModel::changeSuccess($id);
  162. if ($res) {
  163. UserExtractModel::commitTrans();
  164. return JsonService::successful('操作成功!');
  165. } else {
  166. UserExtractModel::rollbackTrans();
  167. return JsonService::fail('操作失败!');
  168. }
  169. }
  170. }