| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236 |
- <?php
- /**
- +-----------------------------------------------------------------------------------------------
- * GouGuOPEN [ 左手研发,右手开源,未来可期!]
- +-----------------------------------------------------------------------------------------------
- * @Copyright (c) 2021~2024 http://www.gouguoa.com All rights reserved.
- +-----------------------------------------------------------------------------------------------
- * @Licensed 勾股OA,开源且可免费使用,但并不是自由软件,未经授权许可不能去除勾股OA的相关版权信息
- +-----------------------------------------------------------------------------------------------
- * @Author 勾股工作室 <hdm58@qq.com>
- +-----------------------------------------------------------------------------------------------
- */
-
- declare (strict_types = 1);
- namespace app\customer\controller;
- use app\base\BaseController;
- use app\customer\model\Customer as CustomerModel;
- use app\customer\validate\CustomerValidate;
- use think\exception\ValidateException;
- use think\facade\Db;
- use think\facade\View;
- class Customer extends BaseController
- {
- /**
- * 构造函数
- */
- protected $model;
- public function __construct()
- {
- parent::__construct(); // 调用父类构造函数
- $this->model = new CustomerModel();
- }
-
- /**
- * 数据列表
- */
- public function datalist()
- {
- $param = get_params();
- if (request()->isAjax()) {
- $where=[];
- $whereOr = [];
- $uid = $this->uid;
- $tab = isset($param['tab']) ? $param['tab'] : 0;
- if (!empty($param['keywords'])) {
- $where[] = ['id|name', 'like', '%' . $param['keywords'] . '%'];
- }
- if (!empty($param['customer_status'])) {
- $where[] = ['customer_status', '=', $param['customer_status']];
- }
- if (!empty($param['industry_id'])) {
- $where[] = ['industry_id', '=', $param['industry_id']];
- }
- if (!empty($param['source_id'])) {
- $where[] = ['source_id', '=', $param['source_id']];
- }
- if (!empty($param['grade_id'])) {
- $where[] = ['grade_id', '=', $param['grade_id']];
- }
- if (!empty($param['intent_status'])) {
- $where[] = ['intent_status', '=', $param['intent_status']];
- }
- if (!empty($param['follow_time'])) {
- $follow_time =explode('~', $param['follow_time']);
- $where[] = ['follow_time', 'between',[strtotime(urldecode($follow_time[0])),strtotime(urldecode($follow_time[1].' 23:59:59'))]];
- }
- if (!empty($param['next_time'])) {
- $next_time =explode('~', $param['next_time']);
- $where[] = ['next_time', 'between',[strtotime(urldecode($next_time[0])),strtotime(urldecode($next_time[1].' 23:59:59'))]];
- }
- $where[]=['delete_time','=',0];
- $where[]=['discard_time','=',0];
-
- if($tab == 0){
- if (!empty($param['uid'])) {
- $where[] = ['belong_uid', '=', $param['uid']];
- }
- else{
- //是否是客户管理员
- $auth = isAuth($uid,'customer_admin','conf_1');
- if($auth == 0){
- $whereOr[] = ['belong_uid','=',$uid];
- $whereOr[] = ['', 'exp', Db::raw("FIND_IN_SET('{$uid}',share_ids)")];
- $dids_a = get_leader_departments($uid);
- $dids_b = get_role_departments($uid);
- $dids = array_merge($dids_a, $dids_b);
- if(!empty($dids)){
- $whereOr[] = ['belong_did','in',$dids];
- }
- }
- else{
- $where[] = ['belong_did','<>',0];
- }
- }
- }
- //我的客户
- if($tab == 1){
- $where[] = ['belong_uid','=',$uid];
- }
- //下属客户
- if($tab == 2){
- $where[] = ['belong_uid','<>',$uid];
- $dids_a = get_leader_departments($uid);
- if(!empty($dids_a)){
- $where[] = ['belong_did','in',$dids_a];
- }
- }
- //分享客户
- if($tab == 3){
- $where[] = ['', 'exp', Db::raw("FIND_IN_SET('{$uid}',share_ids)")];
- }
- $list = $this->model->datalist($param,$where,$whereOr);
- return table_assign(0, '', $list);
- }
- else{
- View::assign('is_leader', isLeader($this->uid));
- return view();
- }
- }
-
- /**
- * 添加/编辑
- */
- public function add()
- {
- $param = get_params();
- if (request()->isAjax()) {
- try {
- validate(CustomerValidate::class)->scene($param['scene'])->check($param);
- } catch (ValidateException $e) {
- // 验证失败 输出错误信息
- return to_assign(1, $e->getError());
- }
- if (!empty($param['id']) && $param['id'] > 0) {
- $param['edit_id'] = $this->uid;
- $this->model->edit($param);
- } else {
- $param['admin_id'] = $this->uid;
- $this->model->add($param);
- }
- }else{
- $id = isset($param['id']) ? $param['id'] : 0;
- $sea = isset($param['sea']) ? $param['sea'] : 0;
- View::assign('sea', $sea);
- if ($id>0) {
- $detail = $this->model->getById($id);
- View::assign('detail', $detail);
- return view('edit');
- }
- if($this->uid>1){
- View::assign('userinfo', get_admin($this->uid));
- }
- if(is_mobile()){
- return view('qiye@/customer/add');
- }
- return view();
- }
- }
-
- /**
- * 查看
- */
- public function view($id)
- {
- $detail = $this->model->getById($id);
- $detail['admin_name'] = Db::name('Admin')->where(['id' => $detail['admin_id']])->value('name');
- if($detail['customer_status']>0){
- $detail['customer_status_name'] = Db::name('BasicCustomer')->where(['id' => $detail['customer_status']])->value('title');
- }
- else{
- $detail['customer_status_name']='-';
- }
- if($detail['intent_status']>0){
- $detail['intent_status_name'] = Db::name('BasicCustomer')->where(['id' => $detail['intent_status']])->value('title');
- }
- else{
- $detail['intent_status_name']='-';
- }
-
- $detail['industry'] = Db::name('Industry')->where(['id' => $detail['industry_id']])->value('title');
- $detail['source'] = Db::name('CustomerSource')->where(['id' => $detail['source_id']])->value('title');
- $detail['grade'] = Db::name('CustomerGrade')->where(['id' => $detail['grade_id']])->value('title');
-
- //附件
- $file_array = Db::name('CustomerFile')
- ->field('cf.id,f.filepath,f.name,f.filesize,f.fileext,f.create_time,f.admin_id')
- ->alias('cf')
- ->join('File f', 'f.id = cf.file_id', 'LEFT')
- ->order('cf.create_time asc')
- ->where(array('cf.customer_id' => $id, 'cf.delete_time' => 0))
- ->select()->toArray();
- $detail['file_array'] = $file_array;
-
- $role=0;
- if($detail['belong_uid'] == $this->uid && $detail['is_lock'] == 0){
- $role=1;
- }
- View::assign('detail', $detail);
- View::assign('role', $role);
- if(is_mobile()){
- return view('qiye@/customer/view');
- }
- return view();
- }
-
- /**
- * 删除
- */
- public function del()
- {
- $param = get_params();
- if (request()->isDelete()) {
- $id = get_params("id");
- $idArray = explode(',', strval($id));
- $list = [];
- foreach ($idArray as $key => $val) {
- $list[] = [
- 'id' => $val,
- 'discard_time' => time()
- ];
- }
- foreach ($list as $key => $v) {
- if (Db::name('Customer')->update($v) !== false) {
- add_log('delete', $param['id']);
- }
- }
- return to_assign(0, '操作成功');
- } else {
- return to_assign(1, "错误的请求");
- }
- }
- }
|