| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251 |
- <?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\api\BaseController;
- use app\customer\model\Customer;
- use app\customer\model\CustomerTrace;
- use app\customer\model\CustomerContact;
- use app\customer\model\CustomerChance;
- use think\facade\Db;
- use think\facade\View;
- class Api extends BaseController
- {
- //获取客户列表
- public function get_customer()
- {
- $param = get_params();
- $uid = $this->uid;
- $where = array();
- $whereOr = array();
- if (!empty($param['keywords'])) {
- $where[] = ['id|name', 'like', '%' . $param['keywords'] . '%'];
- }
- $where[]=['delete_time','=',0];
- $where[]=['discard_time','=',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];
- }
- }
- }
-
- $model = new Customer();
- $list = $model->datalist($param,$where,$whereOr);
- table_assign(0, '', $list);
- }
- //分配客户
- public function distribute()
- {
- if (request()->isAjax()) {
- $params = get_params();
- //是否是客户管理员
- $auth = isAuth($this->uid,'customer_admin','conf_1');
- if($auth==0){
- return to_assign(1, "只有客户管理员才有权限操作");
- }
- $data['id'] = $params['id'];
- $data['belong_uid'] = $params['uid'];
- $data['belong_did'] = $params['did'];
- $data['distribute_time'] = time();
- if (Db::name('Customer')->update($data) !== false) {
- add_log('allot', $data['id'],[],'客户');
- return to_assign(0, "操作成功");
- } else {
- return to_assign(1, "操作失败");
- }
- } else {
- return to_assign(1, "错误的请求");
- }
- }
-
- //锁住、解锁客户
- public function customer_lock()
- {
- if (request()->isAjax()) {
- $params = get_params();
- //是否是客户管理员
- $auth = isAuth($this->uid,'customer_admin','conf_1');
- if($auth==0){
- return to_assign(1, "只有客户管理员才有权限操作");
- }
- $data['id'] = $params['id'];
- $data['is_lock'] = $params['is_lock'];
- if (Db::name('Customer')->update($data) !== false) {
- if($data['is_lock']==1){
- add_log('lock', $data['id'],[],'客户');
- }
- else{
- add_log('unlock', $data['id'],[],'客户');
- }
- return to_assign(0, "操作成功");
- } else {
- return to_assign(1, "操作失败");
- }
- } else {
- return to_assign(1, "错误的请求");
- }
- }
-
-
- //彻底删除客户
- public function delete()
- {
- if (request()->isDelete()) {
- $params = get_params();
- //是否是客户管理员
- $auth = isAuth($this->uid,'customer_admin','conf_1');
- if($auth==0){
- return to_assign(1, "只有客户管理员才有权限操作");
- }
- $data['id'] = $params['id'];
- $data['delete_time'] = -1;
- if (Db::name('Customer')->update($data) !== false) {
- //删除客户联系人
- Db::name('CustomerContact')->where(['cid' => $params['id']])->update(['delete_time'=>time()]);
- //删除客户机会
- Db::name('CustomerChance')->where(['cid' => $params['id']])->update(['delete_time'=>time()]);
- add_log('delete', $params['id']);
- return to_assign();
- } else {
- return to_assign(1, "操作失败");
- }
- } else {
- return to_assign(1, "错误的请求");
- }
- }
-
- //跟进记录列表
- public function get_trace()
- {
- $param = get_params();
- $where = array();
- $where[] = ['a.delete_time', '=', 0];
- $where[] = ['a.cid', '=', $param['cid']];
- $model = new CustomerTrace();
- $list = $model->datalist($param,$where);
- return table_assign(0, '', $list);
- }
-
- //销售机会列表
- public function get_chance()
- {
- $param = get_params();
- $where = array();
- $where[] = ['a.delete_time', '=', 0];
- $where[] = ['a.cid', '=', $param['cid']];
- if (!empty($param['keywords'])) {
- $where[] = ['a.title|a.content', 'like', '%' . $param['keywords'] . '%'];
- }
- $model = new CustomerChance();
- $list = $model->datalist($param,$where);
- return table_assign(0, '', $list);
- }
-
- //获取联系人数据
- public function get_contact()
- {
- $param = get_params();
- $where = array();
- $where[] = ['delete_time', '=', 0];
- $where[] = ['cid', '=', $param['cid']];
- $model = new CustomerContact();
- $list = $model->datalist($param,$where);
- return table_assign(0, '', $list);
- }
-
- //设置联系人
- public function set_contact()
- {
- if (request()->isAjax()) {
- $param = get_params();
- $detail= Db::name('CustomerContact')->where(['id' => $param['id']])->find();
- CustomerContact::where(['cid' => $detail['cid']])->update(['is_default'=>0]);
- $res = CustomerContact::where(['id' => $param['id']])->update(['is_default'=>1]);
- if ($res) {
- add_log('edit', $param['id'], $param,'客户联系人');
- return to_assign();
- } else {
- return to_assign(1, '操作失败');
- }
- } else {
- return to_assign(1, '参数错误');
- }
- }
-
- //添加附件
- public function add_file()
- {
- $param = get_params();
- $param['create_time'] = time();
- $param['admin_id'] = $this->uid;
- $fid = Db::name('CustomerFile')->strict(false)->field(true)->insertGetId($param);
- if ($fid) {
- return to_assign(0, '上传成功', $fid);
- }
- }
-
- //删除附件
- public function delete_file()
- {
- if (request()->isDelete()) {
- $id = get_params("id");
- $data['id'] = $id;
- $data['delete_time'] = time();
- if (Db::name('CustomerFile')->update($data) !== false) {
- $detail = Db::name('CustomerFile')->where('id', $id)->find();
- $file_name = Db::name('File')->where('id', $detail['file_id'])->value('name');
- return to_assign(0, "删除成功");
- } else {
- return to_assign(1, "删除失败");
- }
- } else {
- return to_assign(1, "错误的请求");
- }
- }
-
- //获取客户等级
- public function get_customer_grade()
- {
- $list = get_base_data('customer_grade');
- return to_assign(0, '', $list);
- }
- //获取客户状态
- public function get_customer_status()
- {
- $list = get_base_type_data('basic_customer',1);
- return to_assign(0, '', $list);
- }
- //获取客户意向
- public function get_intent_status()
- {
- $list = get_base_type_data('basic_customer',2);
- return to_assign(0, '', $list);
- }
- }
|