123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384 |
- <?php
- /**
- * Created by PhpStorm.
- * User: lianghuan
- * Date: 2018-03-03
- * Time: 16:37
- */
- namespace app\admin\controller\finance;
- use app\admin\controller\AuthController;
- use app\admin\model\order\StoreOrderCartInfo;
- use app\admin\model\wechat\WechatUser;
- use think\facade\Route as Url;
- use crmeb\services\JsonService;
- use app\admin\model\user\UserExtract as UserExtractModel;
- use crmeb\services\{PHPExcelService, UtilService as Util, FormBuilder as Form};
- /**
- * 用户提现管理
- * Class UserExtract
- * @package app\admin\controller\finance
- */
- class UserExtract extends AuthController
- {
- public function index()
- {
- $admin = $this->adminInfo;
- $where = Util::getMore([
- ['status', ''],
- ['nickname', ''],
- ['extract_type', ''],
- ['nireid', ''],
- ['date', ''],
- ['is_examine', '']
- ], $this->request);
- $limitTimeList = [
- 'today' => implode(' - ', [date('Y/m/d'), date('Y/m/d', strtotime('+1 day'))]),
- 'week' => implode(' - ', [
- date('Y/m/d', (time() - ((date('w') == 0 ? 7 : date('w')) - 1) * 24 * 3600)),
- date('Y-m-d', (time() + (7 - (date('w') == 0 ? 7 : date('w'))) * 24 * 3600))
- ]),
- 'month' => implode(' - ', [date('Y/m') . '/01', date('Y/m') . '/' . date('t')]),
- 'quarter' => implode(' - ', [
- date('Y') . '/' . (ceil((date('n')) / 3) * 3 - 3 + 1) . '/01',
- date('Y') . '/' . (ceil((date('n')) / 3) * 3) . '/' . date('t', mktime(0, 0, 0, (ceil((date('n')) / 3) * 3), 1, date('Y')))
- ]),
- 'year' => implode(' - ', [
- date('Y') . '/01/01', date('Y/m/d', strtotime(date('Y') . '/01/01 + 1year -1 day'))
- ])
- ];
- $this->assign('roles', $admin['roles']);
- $this->assign('where', $where);
- $this->assign('limitTimeList', $limitTimeList);
- $this->assign(UserExtractModel::extractStatistics());
- $this->assign(UserExtractModel::systemPage($where));
- return $this->fetch();
- }
- public function shichang_index()
- {
- $admin = $this->adminInfo;
- $where = Util::getMore([
- ['status', ''],
- ['nickname', ''],
- ['extract_type', ''],
- ['nireid', ''],
- ['date', ''],
- ['is_examine', '']
- ], $this->request);
- $limitTimeList = [
- 'today' => implode(' - ', [date('Y/m/d'), date('Y/m/d', strtotime('+1 day'))]),
- 'week' => implode(' - ', [
- date('Y/m/d', (time() - ((date('w') == 0 ? 7 : date('w')) - 1) * 24 * 3600)),
- date('Y-m-d', (time() + (7 - (date('w') == 0 ? 7 : date('w'))) * 24 * 3600))
- ]),
- 'month' => implode(' - ', [date('Y/m') . '/01', date('Y/m') . '/' . date('t')]),
- 'quarter' => implode(' - ', [
- date('Y') . '/' . (ceil((date('n')) / 3) * 3 - 3 + 1) . '/01',
- date('Y') . '/' . (ceil((date('n')) / 3) * 3) . '/' . date('t', mktime(0, 0, 0, (ceil((date('n')) / 3) * 3), 1, date('Y')))
- ]),
- 'year' => implode(' - ', [
- date('Y') . '/01/01', date('Y/m/d', strtotime(date('Y') . '/01/01 + 1year -1 day'))
- ])
- ];
- $this->assign('roles', $admin['roles']);
- $this->assign('where', $where);
- $this->assign('limitTimeList', $limitTimeList);
- $this->assign(UserExtractModel::extractStatistics());
- $this->assign(UserExtractModel::systemPage($where));
- return $this->fetch();
- }
- public function caiwu_index()
- {
- $admin = $this->adminInfo;
- $where = Util::getMore([
- ['status', ''],
- ['nickname', ''],
- ['extract_type', ''],
- ['nireid', ''],
- ['date', ''],
- ['is_examine', '']
- ], $this->request);
- $limitTimeList = [
- 'today' => implode(' - ', [date('Y/m/d'), date('Y/m/d', strtotime('+1 day'))]),
- 'week' => implode(' - ', [
- date('Y/m/d', (time() - ((date('w') == 0 ? 7 : date('w')) - 1) * 24 * 3600)),
- date('Y-m-d', (time() + (7 - (date('w') == 0 ? 7 : date('w'))) * 24 * 3600))
- ]),
- 'month' => implode(' - ', [date('Y/m') . '/01', date('Y/m') . '/' . date('t')]),
- 'quarter' => implode(' - ', [
- date('Y') . '/' . (ceil((date('n')) / 3) * 3 - 3 + 1) . '/01',
- date('Y') . '/' . (ceil((date('n')) / 3) * 3) . '/' . date('t', mktime(0, 0, 0, (ceil((date('n')) / 3) * 3), 1, date('Y')))
- ]),
- 'year' => implode(' - ', [
- date('Y') . '/01/01', date('Y/m/d', strtotime(date('Y') . '/01/01 + 1year -1 day'))
- ])
- ];
- $this->assign('roles', $admin['roles']);
- $this->assign('where', $where);
- $this->assign('limitTimeList', $limitTimeList);
- $this->assign(UserExtractModel::extractStatistics());
- $this->assign(UserExtractModel::systemPage($where));
- return $this->fetch();
- }
- public function jishu_index()
- {
- $admin = $this->adminInfo;
- $where = Util::getMore([
- ['status', ''],
- ['nickname', ''],
- ['extract_type', ''],
- ['nireid', ''],
- ['date', ''],
- ['is_examine', '']
- ], $this->request);
- $limitTimeList = [
- 'today' => implode(' - ', [date('Y/m/d'), date('Y/m/d', strtotime('+1 day'))]),
- 'week' => implode(' - ', [
- date('Y/m/d', (time() - ((date('w') == 0 ? 7 : date('w')) - 1) * 24 * 3600)),
- date('Y-m-d', (time() + (7 - (date('w') == 0 ? 7 : date('w'))) * 24 * 3600))
- ]),
- 'month' => implode(' - ', [date('Y/m') . '/01', date('Y/m') . '/' . date('t')]),
- 'quarter' => implode(' - ', [
- date('Y') . '/' . (ceil((date('n')) / 3) * 3 - 3 + 1) . '/01',
- date('Y') . '/' . (ceil((date('n')) / 3) * 3) . '/' . date('t', mktime(0, 0, 0, (ceil((date('n')) / 3) * 3), 1, date('Y')))
- ]),
- 'year' => implode(' - ', [
- date('Y') . '/01/01', date('Y/m/d', strtotime(date('Y') . '/01/01 + 1year -1 day'))
- ])
- ];
- $this->assign('roles', $admin['roles']);
- $this->assign('where', $where);
- $this->assign('limitTimeList', $limitTimeList);
- $this->assign(UserExtractModel::extractStatistics());
- $this->assign(UserExtractModel::systemPage($where));
- return $this->fetch();
- }
- public function excel()
- {
- $data = Util::getMore([
- ['status', ''],
- ['nickname', ''],
- ['extract_type', ''],
- ['nireid', ''],
- ['date', ''],
- ], $this->request);
- $where = [];
- if ($data['status'] == 0) {
- $where[] = ['a.status', '=', 0];
- }elseif ($data['status'] == 1){
- $where[] = ['a.status', '=', 1];
- }elseif ($data['status'] < 0){
- $where[] = ['a.status', '=', -1];
- }
- if ($data['nickname']) $where[] = ['a.nickname', '=', $data['nickname']];
- if ($data['extract_type']) $where[] = ['a.extract_type', '=', $data['extract_type']];
- if ($data['nireid']) $where[] = ['a.nireid', '=', $data['nireid']];
- $model = UserExtractModel::where($where)->alias('a')
- ->field('a.*,b.uid,b.nickname,b.phone')
- ->leftJoin('user b', 'b.uid = a.uid');
- if ($data['date']){
- list($startTime, $endTime) = explode(' - ', $data['date']);
- $endTime = (int)bcadd(strtotime($endTime), 86400, 0);
- $model = $model->whereBetweenTime('a.add_time', $startTime, $endTime);
- }
- $list = $model->select();
- if ($list) self::SaveExcel($list);
- return JsonService::fail('没有数据');
- }
- /*
- * 保存并下载excel
- * $list array
- * return
- */
- public static function SaveExcel($list)
- {
- $export = [];
- foreach ($list as $index => $item) {
- if ($item['extract_type'] == 'weixin'){
- $type = '微信';
- $account = $item['wechat'];
- }elseif ($item['extract_type'] == 'alipay'){
- $type = '支付宝';
- $account = $item['alipay_code'];
- }elseif ($item['extract_type'] == 'bank'){
- $type = '银行卡';
- $account = $item['bank_code'];
- }
- if ($item['status'] == 0) $status = '审核中';
- if ($item['status'] == 1) $status = '已提现';
- if ($item['status'] < 0) $status = '未通过';
- $export[] = [
- $item['uid'],
- $item['nickname'],
- $item['real_name'],
- $item['phone'],
- $item['extract_price'],
- $type,
- $account.' ',
- $item['bank_address'],
- $item['bank_belonging'],
- $status,
- $item['fail_msg'],
- date('Y-m-d H:i:s', $item['add_time'])
- ];
- }
- PHPExcelService::setExcelHeader(['UID', '用户昵称', '姓名','手机号', '提现金额', '提现方式','微信|支付宝|银行卡', '银行卡地址','所属支行名称', '状态',
- '未通过原因', '提现时间'])
- ->setExcelTile('提现导出' . date('YmdHis', time()), '提现信息' . time(), ' 生成时间:' . date('Y-m-d H:i:s', time()))
- ->setExcelContent($export)
- ->ExcelSave();
- }
- public function edit($id)
- {
- if (!$id) return $this->failed('数据不存在');
- $UserExtract = UserExtractModel::get($id);
- if (!$UserExtract) return JsonService::fail('数据不存在!');
- $f = array();
- $f[] = Form::input('real_name', '姓名', $UserExtract['real_name']);
- $f[] = Form::number('extract_price', '提现金额', $UserExtract['extract_price'])->precision(2);
- if ($UserExtract['extract_type'] == 'alipay') {
- $f[] = Form::input('alipay_code', '支付宝账号', $UserExtract['alipay_code']);
- } else if ($UserExtract['extract_type'] == 'weixin') {
- $f[] = Form::input('wechat', '微信号', $UserExtract['wechat']);
- } else {
- $f[] = Form::input('bank_code', '银行卡号', $UserExtract['bank_code']);
- $f[] = Form::input('bank_address', '开户行', $UserExtract['bank_address']);
- }
- $f[] = Form::input('mark', '备注', $UserExtract['mark'])->type('textarea');
- $form = Form::make_post_form('编辑', $f, Url::buildUrl('update', array('id' => $id)));
- $this->assign(compact('form'));
- return $this->fetch('public/form-builder');
- }
- public function update($id)
- {
- $UserExtract = UserExtractModel::get($id);
- if (!$UserExtract) return JsonService::fail('数据不存在!');
- if ($UserExtract['extract_type'] == 'alipay') {
- $data = Util::postMore([
- 'real_name',
- 'mark',
- 'extract_price',
- 'alipay_code',
- ]);
- if (!$data['real_name']) return JsonService::fail('请输入姓名');
- if ($data['extract_price'] <= -1) return JsonService::fail('请输入提现金额');
- if (!$data['alipay_code']) return JsonService::fail('请输入支付宝账号');
- } else if ($UserExtract['extract_type'] == 'weixin') {
- $data = Util::postMore([
- 'real_name',
- 'mark',
- 'extract_price',
- 'wechat',
- ]);
- // if(!$data['real_name']) return JsonService::fail('请输入姓名');
- if ($data['extract_price'] <= -1) return JsonService::fail('请输入提现金额');
- if (!$data['wechat']) return JsonService::fail('请输入微信账号');
- } else {
- $data = Util::postMore([
- 'real_name',
- 'extract_price',
- 'mark',
- 'bank_code',
- 'bank_address',
- ]);
- if (!$data['real_name']) return JsonService::fail('请输入姓名');
- if ($data['extract_price'] <= -1) return JsonService::fail('请输入提现金额');
- if (!$data['bank_code']) return JsonService::fail('请输入银行卡号');
- if (!$data['bank_address']) return JsonService::fail('请输入开户行');
- }
- if (!UserExtractModel::edit($data, $id))
- return JsonService::fail(UserExtractModel::getErrorInfo('修改失败'));
- else
- return JsonService::successful('修改成功!');
- }
- public function fail($id)
- {
- if (!UserExtractModel::be(['id' => $id, 'status' => 0])) return JsonService::fail('操作记录不存在或状态错误!');
- $fail_msg = request()->post();
- $extract = UserExtractModel::get($id);
- if (!$extract) return JsonService::fail('操作记录不存在!');
- if ($extract->status == 1) return JsonService::fail('已经提现,错误操作');
- if ($extract->status == -1) return JsonService::fail('您的提现申请已被拒绝,请勿重复操作!');
- $res = UserExtractModel::changeFail($id, $fail_msg['message']);
- if ($res) {
- return JsonService::successful('操作成功!');
- } else {
- return JsonService::fail('操作失败!');
- }
- }
- public function succ($id)
- {
- if (!UserExtractModel::be(['id' => $id, 'status' => 0]))
- return JsonService::fail('操作记录不存在或状态错误!');
- UserExtractModel::beginTrans();
- $extract = UserExtractModel::get($id);
- if (!$extract) return JsonService::fail('操作记录不存!');
- if ($extract->status == 1) return JsonService::fail('您已提现,请勿重复提现!');
- if ($extract->status == -1) return JsonService::fail('您的提现申请已被拒绝!');
- $res = UserExtractModel::changeSuccess($id);
- if($extract['type'] == 2){
- $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')]));
- if ($res1->status != 200) return JsonService::fail($res1->msg);
- }
- if ($res) {
- UserExtractModel::commitTrans();
- return JsonService::successful('操作成功!');
- } else {
- UserExtractModel::rollbackTrans();
- return JsonService::fail('操作失败!');
- }
- }
- public function examine($id)
- {
- if (!UserExtractModel::be(['id' => $id, 'status' => 0]))
- return JsonService::fail('操作记录不存在或状态错误!');
- UserExtractModel::beginTrans();
- $extract = UserExtractModel::get($id);
- if (!$extract) return JsonService::fail('操作记录不存!');
- $admin = $this->adminInfo;
- if ($admin['roles'] == 5){
- if ($extract->is_examine > 0) return JsonService::fail('该记录已审核');
- $extract['is_examine'] = 1;
- $extract['reviewed'] = $admin['real_name'];
- }elseif ($admin['roles'] == 6){
- if ($extract->is_examine > 1) return JsonService::fail('该记录已审核');
- $extract['is_examine'] = 2;
- $extract['reviewed'] = $extract['reviewed'].','.$admin['real_name'];
- }elseif ($admin['roles'] == 3){
- if ($extract->examine_status > 0) return JsonService::fail('该记录已审核');
- $extract['examine_status'] = 1;
- $extract['reviewed'] = $extract['reviewed'].','.$admin['real_name'];
- }else{
- return JsonService::fail('身份不对!');
- }
- $res = $extract->save();
- if ($res) {
- UserExtractModel::commitTrans();
- return JsonService::successful('操作成功!');
- } else {
- UserExtractModel::rollbackTrans();
- return JsonService::fail('操作失败!');
- }
- }
- }
|