UserExtract.php 9.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234
  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 app\admin\model\order\StoreOrderCartInfo;
  11. use app\admin\model\wechat\WechatUser;
  12. use think\facade\Route as Url;
  13. use crmeb\services\JsonService;
  14. use app\admin\model\user\UserExtract as UserExtractModel;
  15. use crmeb\services\{PHPExcelService, UtilService as Util, FormBuilder as Form};
  16. /**
  17. * 用户提现管理
  18. * Class UserExtract
  19. * @package app\admin\controller\finance
  20. */
  21. class UserExtract extends AuthController
  22. {
  23. public function index()
  24. {
  25. $where = Util::getMore([
  26. ['status', ''],
  27. ['nickname', ''],
  28. ['extract_type', ''],
  29. ['nireid', ''],
  30. ['date', ''],
  31. ], $this->request);
  32. $limitTimeList = [
  33. 'today' => implode(' - ', [date('Y/m/d'), date('Y/m/d', strtotime('+1 day'))]),
  34. 'week' => implode(' - ', [
  35. date('Y/m/d', (time() - ((date('w') == 0 ? 7 : date('w')) - 1) * 24 * 3600)),
  36. date('Y-m-d', (time() + (7 - (date('w') == 0 ? 7 : date('w'))) * 24 * 3600))
  37. ]),
  38. 'month' => implode(' - ', [date('Y/m') . '/01', date('Y/m') . '/' . date('t')]),
  39. 'quarter' => implode(' - ', [
  40. date('Y') . '/' . (ceil((date('n')) / 3) * 3 - 3 + 1) . '/01',
  41. date('Y') . '/' . (ceil((date('n')) / 3) * 3) . '/' . date('t', mktime(0, 0, 0, (ceil((date('n')) / 3) * 3), 1, date('Y')))
  42. ]),
  43. 'year' => implode(' - ', [
  44. date('Y') . '/01/01', date('Y/m/d', strtotime(date('Y') . '/01/01 + 1year -1 day'))
  45. ])
  46. ];
  47. $this->assign('where', $where);
  48. $this->assign('limitTimeList', $limitTimeList);
  49. $this->assign(UserExtractModel::extractStatistics());
  50. $this->assign(UserExtractModel::systemPage($where));
  51. return $this->fetch();
  52. }
  53. public function excel()
  54. {
  55. $data = Util::getMore([
  56. ['status', ''],
  57. ['nickname', ''],
  58. ['extract_type', ''],
  59. ['nireid', ''],
  60. ['date', ''],
  61. ], $this->request);
  62. $where = [];
  63. if ($data['status'] == 0) {
  64. $where[] = ['a.status', '=', 0];
  65. }elseif ($data['status'] == 1){
  66. $where[] = ['a.status', '=', 1];
  67. }elseif ($data['status'] < 0){
  68. $where[] = ['a.status', '=', -1];
  69. }
  70. if ($data['nickname']) $where[] = ['a.nickname', '=', $data['nickname']];
  71. if ($data['extract_type']) $where[] = ['a.extract_type', '=', $data['extract_type']];
  72. if ($data['nireid']) $where[] = ['a.nireid', '=', $data['nireid']];
  73. $model = UserExtractModel::where($where)->alias('a')
  74. ->field('a.*,b.uid,b.nickname,b.phone')
  75. ->leftJoin('user b', 'b.uid = a.uid');
  76. if ($data['date']){
  77. list($startTime, $endTime) = explode(' - ', $data['date']);
  78. $model = $model->whereBetweenTime('a.add_time', $startTime, $endTime);
  79. }
  80. $list = $model->select();
  81. if ($list) self::SaveExcel($list);
  82. return JsonService::fail('没有数据');
  83. }
  84. /*
  85. * 保存并下载excel
  86. * $list array
  87. * return
  88. */
  89. public static function SaveExcel($list)
  90. {
  91. $export = [];
  92. foreach ($list as $index => $item) {
  93. if ($item['extract_type'] == 'weixin'){
  94. $type = '微信';
  95. $account = $item['wechat'];
  96. }elseif ($item['extract_type'] == 'alipay'){
  97. $type = '支付宝';
  98. $account = $item['alipay_code'];
  99. }elseif ($item['extract_type'] == 'bank'){
  100. $type = '银行卡';
  101. $account = $item['bank_code'];
  102. }
  103. if ($item['status'] == 0) $status = '审核中';
  104. if ($item['status'] == 1) $status = '已提现';
  105. if ($item['status'] < 0) $status = '未通过';
  106. $export[] = [
  107. $item['uid'],
  108. $item['nickname'],
  109. $item['phone'],
  110. $item['extract_price'],
  111. $type,
  112. $account,
  113. $item['bank_address'],
  114. $status,
  115. $item['fail_msg'],
  116. date('Y-m-d H:i:s', $item['add_time'])
  117. ];
  118. }
  119. PHPExcelService::setExcelHeader(['UID', '用户昵称', '手机号', '提现金额', '提现方式','微信|支付宝|银行卡', '银行卡地址', '状态',
  120. '未通过原因', '提现时间'])
  121. ->setExcelTile('提现导出' . date('YmdHis', time()), '提现信息' . time(), ' 生成时间:' . date('Y-m-d H:i:s', time()))
  122. ->setExcelContent($export)
  123. ->ExcelSave();
  124. }
  125. public function edit($id)
  126. {
  127. if (!$id) return $this->failed('数据不存在');
  128. $UserExtract = UserExtractModel::get($id);
  129. if (!$UserExtract) return JsonService::fail('数据不存在!');
  130. $f = array();
  131. $f[] = Form::input('real_name', '姓名', $UserExtract['real_name']);
  132. $f[] = Form::number('extract_price', '提现金额', $UserExtract['extract_price'])->precision(2);
  133. if ($UserExtract['extract_type'] == 'alipay') {
  134. $f[] = Form::input('alipay_code', '支付宝账号', $UserExtract['alipay_code']);
  135. } else if ($UserExtract['extract_type'] == 'weixin') {
  136. $f[] = Form::input('wechat', '微信号', $UserExtract['wechat']);
  137. } else {
  138. $f[] = Form::input('bank_code', '银行卡号', $UserExtract['bank_code']);
  139. $f[] = Form::input('bank_address', '开户行', $UserExtract['bank_address']);
  140. }
  141. $f[] = Form::input('mark', '备注', $UserExtract['mark'])->type('textarea');
  142. $form = Form::make_post_form('编辑', $f, Url::buildUrl('update', array('id' => $id)));
  143. $this->assign(compact('form'));
  144. return $this->fetch('public/form-builder');
  145. }
  146. public function update($id)
  147. {
  148. $UserExtract = UserExtractModel::get($id);
  149. if (!$UserExtract) return JsonService::fail('数据不存在!');
  150. if ($UserExtract['extract_type'] == 'alipay') {
  151. $data = Util::postMore([
  152. 'real_name',
  153. 'mark',
  154. 'extract_price',
  155. 'alipay_code',
  156. ]);
  157. if (!$data['real_name']) return JsonService::fail('请输入姓名');
  158. if ($data['extract_price'] <= -1) return JsonService::fail('请输入提现金额');
  159. if (!$data['alipay_code']) return JsonService::fail('请输入支付宝账号');
  160. } else if ($UserExtract['extract_type'] == 'weixin') {
  161. $data = Util::postMore([
  162. 'real_name',
  163. 'mark',
  164. 'extract_price',
  165. 'wechat',
  166. ]);
  167. // if(!$data['real_name']) return JsonService::fail('请输入姓名');
  168. if ($data['extract_price'] <= -1) return JsonService::fail('请输入提现金额');
  169. if (!$data['wechat']) return JsonService::fail('请输入微信账号');
  170. } else {
  171. $data = Util::postMore([
  172. 'real_name',
  173. 'extract_price',
  174. 'mark',
  175. 'bank_code',
  176. 'bank_address',
  177. ]);
  178. if (!$data['real_name']) return JsonService::fail('请输入姓名');
  179. if ($data['extract_price'] <= -1) return JsonService::fail('请输入提现金额');
  180. if (!$data['bank_code']) return JsonService::fail('请输入银行卡号');
  181. if (!$data['bank_address']) return JsonService::fail('请输入开户行');
  182. }
  183. if (!UserExtractModel::edit($data, $id))
  184. return JsonService::fail(UserExtractModel::getErrorInfo('修改失败'));
  185. else
  186. return JsonService::successful('修改成功!');
  187. }
  188. public function fail($id)
  189. {
  190. if (!UserExtractModel::be(['id' => $id, 'status' => 0])) return JsonService::fail('操作记录不存在或状态错误!');
  191. $fail_msg = request()->post();
  192. $extract = UserExtractModel::get($id);
  193. if (!$extract) return JsonService::fail('操作记录不存在!');
  194. if ($extract->status == 1) return JsonService::fail('已经提现,错误操作');
  195. if ($extract->status == -1) return JsonService::fail('您的提现申请已被拒绝,请勿重复操作!');
  196. $res = UserExtractModel::changeFail($id, $fail_msg['message']);
  197. if ($res) {
  198. return JsonService::successful('操作成功!');
  199. } else {
  200. return JsonService::fail('操作失败!');
  201. }
  202. }
  203. public function succ($id)
  204. {
  205. if (!UserExtractModel::be(['id' => $id, 'status' => 0]))
  206. return JsonService::fail('操作记录不存在或状态错误!');
  207. UserExtractModel::beginTrans();
  208. $extract = UserExtractModel::get($id);
  209. if (!$extract) return JsonService::fail('操作记录不存!');
  210. if ($extract->status == 1) return JsonService::fail('您已提现,请勿重复提现!');
  211. if ($extract->status == -1) return JsonService::fail('您的提现申请已被拒绝!');
  212. $res = UserExtractModel::changeSuccess($id);
  213. $res1 = json_decode(do_request(' https://api.mall.hqgjsmc.com/service-php-api/member/comfireOrder', ['orderno' => $extract['order_id'], 'confireDate' => date('Y-m-d H:m:s')]));
  214. if ($res1->status != 200) return JsonService::fail($res1->msg);
  215. if ($res && $res1) {
  216. UserExtractModel::commitTrans();
  217. return JsonService::successful('操作成功!');
  218. } else {
  219. UserExtractModel::rollbackTrans();
  220. return JsonService::fail('操作失败!');
  221. }
  222. }
  223. }