UserExtract.php 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384
  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. $admin = $this->adminInfo;
  26. $where = Util::getMore([
  27. ['status', ''],
  28. ['nickname', ''],
  29. ['extract_type', ''],
  30. ['nireid', ''],
  31. ['date', ''],
  32. ['is_examine', '']
  33. ], $this->request);
  34. $limitTimeList = [
  35. 'today' => implode(' - ', [date('Y/m/d'), date('Y/m/d', strtotime('+1 day'))]),
  36. 'week' => implode(' - ', [
  37. date('Y/m/d', (time() - ((date('w') == 0 ? 7 : date('w')) - 1) * 24 * 3600)),
  38. date('Y-m-d', (time() + (7 - (date('w') == 0 ? 7 : date('w'))) * 24 * 3600))
  39. ]),
  40. 'month' => implode(' - ', [date('Y/m') . '/01', date('Y/m') . '/' . date('t')]),
  41. 'quarter' => implode(' - ', [
  42. date('Y') . '/' . (ceil((date('n')) / 3) * 3 - 3 + 1) . '/01',
  43. date('Y') . '/' . (ceil((date('n')) / 3) * 3) . '/' . date('t', mktime(0, 0, 0, (ceil((date('n')) / 3) * 3), 1, date('Y')))
  44. ]),
  45. 'year' => implode(' - ', [
  46. date('Y') . '/01/01', date('Y/m/d', strtotime(date('Y') . '/01/01 + 1year -1 day'))
  47. ])
  48. ];
  49. $this->assign('roles', $admin['roles']);
  50. $this->assign('where', $where);
  51. $this->assign('limitTimeList', $limitTimeList);
  52. $this->assign(UserExtractModel::extractStatistics());
  53. $this->assign(UserExtractModel::systemPage($where));
  54. return $this->fetch();
  55. }
  56. public function shichang_index()
  57. {
  58. $admin = $this->adminInfo;
  59. $where = Util::getMore([
  60. ['status', ''],
  61. ['nickname', ''],
  62. ['extract_type', ''],
  63. ['nireid', ''],
  64. ['date', ''],
  65. ['is_examine', '']
  66. ], $this->request);
  67. $limitTimeList = [
  68. 'today' => implode(' - ', [date('Y/m/d'), date('Y/m/d', strtotime('+1 day'))]),
  69. 'week' => implode(' - ', [
  70. date('Y/m/d', (time() - ((date('w') == 0 ? 7 : date('w')) - 1) * 24 * 3600)),
  71. date('Y-m-d', (time() + (7 - (date('w') == 0 ? 7 : date('w'))) * 24 * 3600))
  72. ]),
  73. 'month' => implode(' - ', [date('Y/m') . '/01', date('Y/m') . '/' . date('t')]),
  74. 'quarter' => implode(' - ', [
  75. date('Y') . '/' . (ceil((date('n')) / 3) * 3 - 3 + 1) . '/01',
  76. date('Y') . '/' . (ceil((date('n')) / 3) * 3) . '/' . date('t', mktime(0, 0, 0, (ceil((date('n')) / 3) * 3), 1, date('Y')))
  77. ]),
  78. 'year' => implode(' - ', [
  79. date('Y') . '/01/01', date('Y/m/d', strtotime(date('Y') . '/01/01 + 1year -1 day'))
  80. ])
  81. ];
  82. $this->assign('roles', $admin['roles']);
  83. $this->assign('where', $where);
  84. $this->assign('limitTimeList', $limitTimeList);
  85. $this->assign(UserExtractModel::extractStatistics());
  86. $this->assign(UserExtractModel::systemPage($where));
  87. return $this->fetch();
  88. }
  89. public function caiwu_index()
  90. {
  91. $admin = $this->adminInfo;
  92. $where = Util::getMore([
  93. ['status', ''],
  94. ['nickname', ''],
  95. ['extract_type', ''],
  96. ['nireid', ''],
  97. ['date', ''],
  98. ['is_examine', '']
  99. ], $this->request);
  100. $limitTimeList = [
  101. 'today' => implode(' - ', [date('Y/m/d'), date('Y/m/d', strtotime('+1 day'))]),
  102. 'week' => implode(' - ', [
  103. date('Y/m/d', (time() - ((date('w') == 0 ? 7 : date('w')) - 1) * 24 * 3600)),
  104. date('Y-m-d', (time() + (7 - (date('w') == 0 ? 7 : date('w'))) * 24 * 3600))
  105. ]),
  106. 'month' => implode(' - ', [date('Y/m') . '/01', date('Y/m') . '/' . date('t')]),
  107. 'quarter' => implode(' - ', [
  108. date('Y') . '/' . (ceil((date('n')) / 3) * 3 - 3 + 1) . '/01',
  109. date('Y') . '/' . (ceil((date('n')) / 3) * 3) . '/' . date('t', mktime(0, 0, 0, (ceil((date('n')) / 3) * 3), 1, date('Y')))
  110. ]),
  111. 'year' => implode(' - ', [
  112. date('Y') . '/01/01', date('Y/m/d', strtotime(date('Y') . '/01/01 + 1year -1 day'))
  113. ])
  114. ];
  115. $this->assign('roles', $admin['roles']);
  116. $this->assign('where', $where);
  117. $this->assign('limitTimeList', $limitTimeList);
  118. $this->assign(UserExtractModel::extractStatistics());
  119. $this->assign(UserExtractModel::systemPage($where));
  120. return $this->fetch();
  121. }
  122. public function jishu_index()
  123. {
  124. $admin = $this->adminInfo;
  125. $where = Util::getMore([
  126. ['status', ''],
  127. ['nickname', ''],
  128. ['extract_type', ''],
  129. ['nireid', ''],
  130. ['date', ''],
  131. ['is_examine', '']
  132. ], $this->request);
  133. $limitTimeList = [
  134. 'today' => implode(' - ', [date('Y/m/d'), date('Y/m/d', strtotime('+1 day'))]),
  135. 'week' => implode(' - ', [
  136. date('Y/m/d', (time() - ((date('w') == 0 ? 7 : date('w')) - 1) * 24 * 3600)),
  137. date('Y-m-d', (time() + (7 - (date('w') == 0 ? 7 : date('w'))) * 24 * 3600))
  138. ]),
  139. 'month' => implode(' - ', [date('Y/m') . '/01', date('Y/m') . '/' . date('t')]),
  140. 'quarter' => implode(' - ', [
  141. date('Y') . '/' . (ceil((date('n')) / 3) * 3 - 3 + 1) . '/01',
  142. date('Y') . '/' . (ceil((date('n')) / 3) * 3) . '/' . date('t', mktime(0, 0, 0, (ceil((date('n')) / 3) * 3), 1, date('Y')))
  143. ]),
  144. 'year' => implode(' - ', [
  145. date('Y') . '/01/01', date('Y/m/d', strtotime(date('Y') . '/01/01 + 1year -1 day'))
  146. ])
  147. ];
  148. $this->assign('roles', $admin['roles']);
  149. $this->assign('where', $where);
  150. $this->assign('limitTimeList', $limitTimeList);
  151. $this->assign(UserExtractModel::extractStatistics());
  152. $this->assign(UserExtractModel::systemPage($where));
  153. return $this->fetch();
  154. }
  155. public function excel()
  156. {
  157. $data = Util::getMore([
  158. ['status', ''],
  159. ['nickname', ''],
  160. ['extract_type', ''],
  161. ['nireid', ''],
  162. ['date', ''],
  163. ], $this->request);
  164. $where = [];
  165. if ($data['status'] == 0) {
  166. $where[] = ['a.status', '=', 0];
  167. }elseif ($data['status'] == 1){
  168. $where[] = ['a.status', '=', 1];
  169. }elseif ($data['status'] < 0){
  170. $where[] = ['a.status', '=', -1];
  171. }
  172. if ($data['nickname']) $where[] = ['a.nickname', '=', $data['nickname']];
  173. if ($data['extract_type']) $where[] = ['a.extract_type', '=', $data['extract_type']];
  174. if ($data['nireid']) $where[] = ['a.nireid', '=', $data['nireid']];
  175. $model = UserExtractModel::where($where)->alias('a')
  176. ->field('a.*,b.uid,b.nickname,b.phone')
  177. ->leftJoin('user b', 'b.uid = a.uid');
  178. if ($data['date']){
  179. list($startTime, $endTime) = explode(' - ', $data['date']);
  180. $endTime = (int)bcadd(strtotime($endTime), 86400, 0);
  181. $model = $model->whereBetweenTime('a.add_time', $startTime, $endTime);
  182. }
  183. $list = $model->select();
  184. if ($list) self::SaveExcel($list);
  185. return JsonService::fail('没有数据');
  186. }
  187. /*
  188. * 保存并下载excel
  189. * $list array
  190. * return
  191. */
  192. public static function SaveExcel($list)
  193. {
  194. $export = [];
  195. foreach ($list as $index => $item) {
  196. if ($item['extract_type'] == 'weixin'){
  197. $type = '微信';
  198. $account = $item['wechat'];
  199. }elseif ($item['extract_type'] == 'alipay'){
  200. $type = '支付宝';
  201. $account = $item['alipay_code'];
  202. }elseif ($item['extract_type'] == 'bank'){
  203. $type = '银行卡';
  204. $account = $item['bank_code'];
  205. }
  206. if ($item['status'] == 0) $status = '审核中';
  207. if ($item['status'] == 1) $status = '已提现';
  208. if ($item['status'] < 0) $status = '未通过';
  209. $export[] = [
  210. $item['uid'],
  211. $item['nickname'],
  212. $item['real_name'],
  213. $item['phone'],
  214. $item['extract_price'],
  215. $type,
  216. $account.' ',
  217. $item['bank_address'],
  218. $item['bank_belonging'],
  219. $status,
  220. $item['fail_msg'],
  221. date('Y-m-d H:i:s', $item['add_time'])
  222. ];
  223. }
  224. PHPExcelService::setExcelHeader(['UID', '用户昵称', '姓名','手机号', '提现金额', '提现方式','微信|支付宝|银行卡', '银行卡地址','所属支行名称', '状态',
  225. '未通过原因', '提现时间'])
  226. ->setExcelTile('提现导出' . date('YmdHis', time()), '提现信息' . time(), ' 生成时间:' . date('Y-m-d H:i:s', time()))
  227. ->setExcelContent($export)
  228. ->ExcelSave();
  229. }
  230. public function edit($id)
  231. {
  232. if (!$id) return $this->failed('数据不存在');
  233. $UserExtract = UserExtractModel::get($id);
  234. if (!$UserExtract) return JsonService::fail('数据不存在!');
  235. $f = array();
  236. $f[] = Form::input('real_name', '姓名', $UserExtract['real_name']);
  237. $f[] = Form::number('extract_price', '提现金额', $UserExtract['extract_price'])->precision(2);
  238. if ($UserExtract['extract_type'] == 'alipay') {
  239. $f[] = Form::input('alipay_code', '支付宝账号', $UserExtract['alipay_code']);
  240. } else if ($UserExtract['extract_type'] == 'weixin') {
  241. $f[] = Form::input('wechat', '微信号', $UserExtract['wechat']);
  242. } else {
  243. $f[] = Form::input('bank_code', '银行卡号', $UserExtract['bank_code']);
  244. $f[] = Form::input('bank_address', '开户行', $UserExtract['bank_address']);
  245. }
  246. $f[] = Form::input('mark', '备注', $UserExtract['mark'])->type('textarea');
  247. $form = Form::make_post_form('编辑', $f, Url::buildUrl('update', array('id' => $id)));
  248. $this->assign(compact('form'));
  249. return $this->fetch('public/form-builder');
  250. }
  251. public function update($id)
  252. {
  253. $UserExtract = UserExtractModel::get($id);
  254. if (!$UserExtract) return JsonService::fail('数据不存在!');
  255. if ($UserExtract['extract_type'] == 'alipay') {
  256. $data = Util::postMore([
  257. 'real_name',
  258. 'mark',
  259. 'extract_price',
  260. 'alipay_code',
  261. ]);
  262. if (!$data['real_name']) return JsonService::fail('请输入姓名');
  263. if ($data['extract_price'] <= -1) return JsonService::fail('请输入提现金额');
  264. if (!$data['alipay_code']) return JsonService::fail('请输入支付宝账号');
  265. } else if ($UserExtract['extract_type'] == 'weixin') {
  266. $data = Util::postMore([
  267. 'real_name',
  268. 'mark',
  269. 'extract_price',
  270. 'wechat',
  271. ]);
  272. // if(!$data['real_name']) return JsonService::fail('请输入姓名');
  273. if ($data['extract_price'] <= -1) return JsonService::fail('请输入提现金额');
  274. if (!$data['wechat']) return JsonService::fail('请输入微信账号');
  275. } else {
  276. $data = Util::postMore([
  277. 'real_name',
  278. 'extract_price',
  279. 'mark',
  280. 'bank_code',
  281. 'bank_address',
  282. ]);
  283. if (!$data['real_name']) return JsonService::fail('请输入姓名');
  284. if ($data['extract_price'] <= -1) return JsonService::fail('请输入提现金额');
  285. if (!$data['bank_code']) return JsonService::fail('请输入银行卡号');
  286. if (!$data['bank_address']) return JsonService::fail('请输入开户行');
  287. }
  288. if (!UserExtractModel::edit($data, $id))
  289. return JsonService::fail(UserExtractModel::getErrorInfo('修改失败'));
  290. else
  291. return JsonService::successful('修改成功!');
  292. }
  293. public function fail($id)
  294. {
  295. if (!UserExtractModel::be(['id' => $id, 'status' => 0])) return JsonService::fail('操作记录不存在或状态错误!');
  296. $fail_msg = request()->post();
  297. $extract = UserExtractModel::get($id);
  298. if (!$extract) return JsonService::fail('操作记录不存在!');
  299. if ($extract->status == 1) return JsonService::fail('已经提现,错误操作');
  300. if ($extract->status == -1) return JsonService::fail('您的提现申请已被拒绝,请勿重复操作!');
  301. $res = UserExtractModel::changeFail($id, $fail_msg['message']);
  302. if ($res) {
  303. return JsonService::successful('操作成功!');
  304. } else {
  305. return JsonService::fail('操作失败!');
  306. }
  307. }
  308. public function succ($id)
  309. {
  310. if (!UserExtractModel::be(['id' => $id, 'status' => 0]))
  311. return JsonService::fail('操作记录不存在或状态错误!');
  312. UserExtractModel::beginTrans();
  313. $extract = UserExtractModel::get($id);
  314. if (!$extract) return JsonService::fail('操作记录不存!');
  315. if ($extract->status == 1) return JsonService::fail('您已提现,请勿重复提现!');
  316. if ($extract->status == -1) return JsonService::fail('您的提现申请已被拒绝!');
  317. $res = UserExtractModel::changeSuccess($id);
  318. if($extract['type'] == 2){
  319. $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')]));
  320. if ($res1->status != 200) return JsonService::fail($res1->msg);
  321. }
  322. if ($res) {
  323. UserExtractModel::commitTrans();
  324. return JsonService::successful('操作成功!');
  325. } else {
  326. UserExtractModel::rollbackTrans();
  327. return JsonService::fail('操作失败!');
  328. }
  329. }
  330. public function examine($id)
  331. {
  332. if (!UserExtractModel::be(['id' => $id, 'status' => 0]))
  333. return JsonService::fail('操作记录不存在或状态错误!');
  334. UserExtractModel::beginTrans();
  335. $extract = UserExtractModel::get($id);
  336. if (!$extract) return JsonService::fail('操作记录不存!');
  337. $admin = $this->adminInfo;
  338. if ($admin['roles'] == 5){
  339. if ($extract->is_examine > 0) return JsonService::fail('该记录已审核');
  340. $extract['is_examine'] = 1;
  341. $extract['reviewed'] = $admin['real_name'];
  342. }elseif ($admin['roles'] == 6){
  343. if ($extract->is_examine > 1) return JsonService::fail('该记录已审核');
  344. $extract['is_examine'] = 2;
  345. $extract['reviewed'] = $extract['reviewed'].','.$admin['real_name'];
  346. }elseif ($admin['roles'] == 3){
  347. if ($extract->examine_status > 0) return JsonService::fail('该记录已审核');
  348. $extract['examine_status'] = 1;
  349. $extract['reviewed'] = $extract['reviewed'].','.$admin['real_name'];
  350. }else{
  351. return JsonService::fail('身份不对!');
  352. }
  353. $res = $extract->save();
  354. if ($res) {
  355. UserExtractModel::commitTrans();
  356. return JsonService::successful('操作成功!');
  357. } else {
  358. UserExtractModel::rollbackTrans();
  359. return JsonService::fail('操作失败!');
  360. }
  361. }
  362. }