| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324 |
- <?php
- /**
- * User: nickbai
- * Date: 2017/10/23 13:33
- * Email: 1902822973@qq.com
- */
- namespace app\admin\controller;
- use app\admin\model\Office;
- class Accounts extends Base
- {
- // 用户列表
- public function index()
- {
- $toExcel = input('param.toExcel', 0);
- if(request()->isAjax()){
- $param = input('param.');
- $limit = $param['pageSize'];
- $offset = (($param['pageNumber'] - 1) * $limit);
- $where = [];
- if (empty($param['searchText']) === false) {
- $where['account_name'] = ['like', '%' . $param['searchText'] . '%'];
- }
- //标签
- if ($param['label_id'] != '' && $param['label_id'] != 0) {
- $where['label_id'] = $param['label_id'];
- }
- if (empty($param['start']) === false && empty($param['end']) === false && $param['start'] <= $param['end']) {
- $start = strtotime($param['start']);
- $end = strtotime($param['end'] . ' 23:59:59');
- $return['total'] = db('accounts')->whereBetween('add_time', [$start, $end])->count(); //总数据
- }
- $result = db('accounts')->whereBetween('add_time', [$start, $end])->where($where)->limit($offset, $limit)->order('add_time', 'desc')->select();
- //所有客服
- $users = db('users')->select();
- //所有标签
- $label = db('accountslabel')->select();
- foreach($result as $key=>$vo){
- $result[$key]['add_time'] = date('Y-m-d H:i:s',$result[$key]['add_time']);
- $result[$key]['last_login_time'] = date('Y-m-d H:i:s',$result[$key]['last_login_time']);
- for($i=0;$i<count($users);$i++){
- if($vo['user_id'] == $users[$i]['id']){
- $result[$key]['user_name'] = $users[$i]['user_name'];
- }
- }
- for($j=0;$j<count($label);$j++){
- if($vo['label_id'] == $label[$j]['id']){
- $result[$key]['label'] = $label[$j]['name'];
- }
- }
- // 生成操作按钮
- $result[$key]['operate'] = $this->makeBtn($vo['id']);
- }
- //$return['total'] = db('accounts')->count(); //总数据
- $return['rows'] = $result;
- return json($return);
- }
- //所有标签
- $label = db('accountslabel')->select();
- if(!empty($label)){
- $option = '<option value="0">全部</option>';
- for($i=0;$i<count($label);$i++){
- $option = $option.'<option value="'.$label[$i]['id'].'">'.$label[$i]['name'].'</option>';
- }
- $labeloption = '<select lay-verify="required" lay-filter="label">'.$option.'</select>';
- }
- $this->assign([
- 'label' => $label,
- 'labeloption' => $labeloption,
- 'status' => config('kf_status')
- ]);
- return $this->fetch();
- }
- //用户信息导出
- public function toexcel()
- {
- $result = db('accounts')->select();
- //所有标签
- $label = db('accountslabel')->select();
- foreach($result as $key=>$vo){
- $result[$key]['add_time'] = date('Y-m-d H:i:s',$result[$key]['add_time']);
- $result[$key]['last_login_time'] = date('Y-m-d H:i:s',$result[$key]['last_login_time']);
- for($j=0;$j<count($label);$j++){
- if($vo['label_id'] == $label[$j]['id']){
- $result[$key]['label'] = $label[$j]['name'];
- }
- }
- }
- $head = ['账号', '昵称', '邮箱', '电话', '注册时间', '最近一次访问时间', '标签', '备注'];
- $key = ['account_name', 'nick_name', 'account_email', 'account_phone', 'add_time', 'last_login_time', 'label', 'remark'];
- (new Office())->outdata('会员数据导出', $result, $head, $key);
- return true;
- }
- // 重置用户密码为 123456
- public function resetPwd()
- {
- if(request()->isAjax()){
- $id = input('param.id/d');
- $password = md5('123456' . config('salt'));
- try{
- db('accounts')->where('id', $id)->update(['password' => $password]);
- }catch(\Exception $e){
- return json(['code' => -1, 'data' => '', 'msg' => $e->getMessage()]);
- }
- return json(['code' => 1, 'data' => 'accounts/index', 'msg' => '重置密码成功']);
- }
- }
- // 编辑用户
- public function edit()
- {
- if(request()->isAjax()){
- $param = input('post.');
- $info = array();
- $rules = '/^([a-zA-Z0-9_\.\-])+\@(([a-zA-Z0-9\-])+\.)+([a-zA-Z0-9]{2,4})+$/';
- if(!empty($param['account_email'])){
- if(!preg_match($rules,$param['account_email'])){
- return json(['code' => -9, 'data' => '', 'msg' => '请输入正确的邮箱']);
- }
- }
- if(!empty($param['account_phone'])){
- if(!preg_match("/^1[34578]\d{9}$/", $param['account_phone'])){
- return json(['code' => -10, 'data' => '', 'msg' => '请输入正确的手机号码']);
- }
- }
- $info['nick_name'] = $param['nick_name'];
- $info['account_email'] = $param['account_email'];
- $info['account_phone'] = $param['account_phone'];
- $info['address'] = $param['address'];
- $info['label_id'] = $param['label_id'];
- $info['remark'] = $param['remark'];
- if(!empty($param['user_id']) && $param['user_id'] != 0){
- $info['user_id'] = $param['user_id'];
- }
- try{
- db('accounts')->where('id', $param['id'])->update($info);
- }catch(\Exception $e){
- return json(['code' => -6, 'data' => '', 'msg' => $e->getMessage()]);
- }
- return json(['code' => 1, 'data' => url('accounts/index'), 'msg' => '编辑用户成功']);
- }
- $id = input('param.id/d');
- $info = db('accounts')->where('id', $id)->find();
- $label = db('accountslabel')->where('id', $info['label_id'])->find();
- $info['label'] = $label['name'];
- //所有标签
- $label = db('accountslabel')->select();
- //服务记录
- //前一个月的时间戳
- $start = time()-2592000;
- //当前时间戳
- $end = time();
- $service_log = db('service_log a')->join('users b','a.kf_id=b.id')->field('a.servicelog_id,a.start_time,b.user_name')->whereBetween('a.start_time', [$start, $end])->where('a.user_id', $id)->select();
- for($i=0;$i<count($service_log);$i++){
- $service_log[$i]['start_time'] = date("Y-m-d H:i:s",$service_log[$i]['start_time']);
- }
- //转为日期时间格式
- $info['add_time'] = date('Y-m-d H:i:s',$info['add_time']);
- //所有客服
- $users = db('users')->select();
- $this->assign([
- 'info' => $info,
- 'users' => $users,
- 'label' => $label,
- 'service_log' => $service_log,
- 'status' => config('kf_status')
- ]);
- return $this->fetch();
- }
- // 删除用户
- public function delAccount()
- {
- if(request()->isAjax()){
- $id = input('param.id/d');
- try{
- db('accounts')->where('id', $id)->delete();
- }catch(\Exception $e){
- return json(['code' => -1, 'data' => '', 'msg' => $e->getMessage()]);
- }
- return json(['code' => 1, 'data' => 'accounts/index', 'msg' => '删除客服成功']);
- }
- }
- // 生成按钮
- private function makeBtn($id)
- {
- //$operate = '<a href="javascript:resetPwd(' . $id . ')"><button type="button" class="btn btn-primary btn-sm"><i class="fa fa-paste"></i> 重置密码</button></a>';
- $operate = '<a style="margin-left:5px;" href="' . url('Accounts/edit', ['id' => $id]) . '"><button type="button" class="btn btn-primary btn-sm"><i class="fa fa-paste"></i> 编辑</button></a> ';
- // $operate .= '<a href="javascript:accountDel(' . $id . ')"><button type="button" class="btn btn-danger btn-sm">';
- // $operate .= '<i class="fa fa-trash-o"></i> 删除</button></a> ';
- return $operate;
- }
- // 用户标签列表
- public function label()
- {
- if(request()->isAjax()){
- $param = input('param.');
- $limit = $param['pageSize'];
- $offset = (($param['pageNumber'] - 1) * $limit);
- $where = [];
- if (empty($param['searchText']) === false) {
- $where['name'] = ['like', '%' . $param['searchText'] . '%'];
- }
- $result = db('accountslabel')->where($where)->limit($offset, $limit)->order('add_time', 'desc')->select();
- foreach($result as $key=>$vo){
- $result[$key]['add_time'] = date('Y-m-d H:i:s',$result[$key]['add_time']);
- // 生成操作按钮
- $result[$key]['operate'] = $this->makeBtnLabel($vo['id']);
- }
- $return['total'] = db('accountslabel')->count(); //总数据
- $return['rows'] = $result;
- return json($return);
- }
- return $this->fetch();
- }
- // 添加用户标签
- public function addlabel()
- {
- if (request()->isAjax()) {
- $param = input('post.');
- $has = db('accountslabel')->where('name',$param['name'])->find();
- if(!empty($has)){
- return json(['code' => -1, 'data' => '', 'msg' => '此用户标签已存在']);
- }
- $info = array();
- $info['name'] = $param['name'];
- $info['add_time'] = time();
- try {
- db('accountslabel')->insert($info);
- } catch (\Exception $e) {
- return json(['code' => -2, 'data' => '', 'msg' => $e->getMessage()]);
- }
- return json(['code' => 1, 'data' => '', 'msg' => '添加用户标签成功']);
- }
- $this->assign([
- 'status' => config('kf_status')
- ]);
- return $this->fetch();
- }
- // 编辑用户标签
- public function editlabel()
- {
- // 菜单id
- $id = input('param.id/d');
- if (request()->isAjax()) {
- $param = input('post.');
- $has = db('accountslabel')->where('name',$param['name'])->where('id','<>',$id)->find();
- if(!empty($has)){
- return json(['code' => -1, 'data' => '', 'msg' => '此用户标签已存在']);
- }
- $info = array();
- $info['name'] = $param['name'];
- try {
- db('accountslabel')->where('id', $param['id'])->update($info);
- } catch (\Exception $e) {
- return json(['code' => -2, 'data' => '', 'msg' => $e->getMessage()]);
- }
- return json(['code' => 1, 'data' => '', 'msg' => '编辑用户标签成功']);
- }
- $label = db('accountslabel')->where('id',$id)->find();
- $this->assign([
- 'label' => $label,
- 'id' => $id,
- 'status' => config('kf_status')
- ]);
- return $this->fetch();
- }
- // 删除用户标签
- public function delLabel()
- {
- if (request()->isAjax()) {
- //留言类型id
- $id = input('param.id/d');
- try {
- db('accountslabel')->where('id', $id)->delete();
- } catch (\Exception $e) {
- return json(['code' => -1, 'data' => '', 'msg' => $e->getMessage()]);
- }
- return json(['code' => 1, 'data' => '', 'msg' => '删除用户标签成功']);
- }
- }
- // 生成标签按钮
- private function makeBtnLabel($id)
- {
- $operate = '<a style="margin-left:5px;" href="' . url('Accounts/editlabel', ['id' => $id]) . '"><button type="button" class="btn btn-primary btn-sm"><i class="fa fa-paste"></i> 编辑</button></a> ';
- $operate .= '<a href="javascript:labelDel(' . $id . ')"><button type="button" class="btn btn-danger btn-sm">';
- $operate .= '<i class="fa fa-trash-o"></i> 删除</button></a> ';
- return $operate;
- }
- }
|