You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

673 lines
25 KiB

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

<?php
// +----------------------------------------------------------------------
// | Description: 项目控制器
// +----------------------------------------------------------------------
// | Author: yykun
// +----------------------------------------------------------------------
namespace app\work\controller;
use app\crm\model\Activity;
use app\work\logic\WorkLogic;
use app\work\traits\WorkAuthTrait;
use think\Request;
use think\Hook;
use app\admin\controller\ApiCommon;
use think\Db;
class work extends ApiCommon
{
# 项目权限
use WorkAuthTrait;
/**
* 用于判断权限
* @permission 无限制
* @allow 登录用户可访问
* @other 其他根据系统设置
**/
public function _initialize()
{
$action = [
'permission'=>[''],
'allow'=>[
'index',
'filelist',
'delete',
'read',
'archive',
'owneradd',
'ownerdel',
'ownerlist',
'leave',
'archivelist',
'arrecover',
'statistic',
'grouplist',
'addusergroup',
'update',
'follow',
'updateWorkOrder'
]
];
Hook::listen('check_auth',$action);
$request = Request::instance();
$a = strtolower($request->action());
if (!in_array($a, $action['permission'])) {
parent::_initialize();
}
}
/**
* 项目列表
*
* @param WorkLogic $workLogic
* @return \think\response\Json
*/
public function index(WorkLogic $workLogic)
{
$this->param['user_id'] = $this->userInfo['id'];
$data = $workLogic->index($this->param);
return resultArray(['data' => $data]);
}
/**
* 创建项目
*
* @return \think\response\Json
*/
public function save()
{
$userId = $this->userInfo['id'];
$param = $this->param;
$workModel = model('Work');
if (empty($param['name'])) return resultArray(['error' => '项目名称不能为空']);
if (empty($param['cover_url'])) return resultArray(['error' => '请选择项目封面!']);
# 设置项目创建人和成员
$param['create_user_id'] = $userId;
$ownerUserId = !empty($param['owner_user_id']) ? $param['owner_user_id'] : [$userId];
if (!in_array($userId, $ownerUserId)) $owner_user_id[] = $userId;
$param['owner_user_id'] = $ownerUserId;
$workId = $workModel->createData($param);
if (!$workId) return resultArray(['error' => $workModel->getError()]);
# 更新项目排序表
$workModel->updateWorkOrder($workId, $userId);
return resultArray(['data' => '操作成功!']);
}
/**
* 编辑项目
*
* @return \think\response\Json
* @throws \think\db\exception\DataNotFoundException
* @throws \think\db\exception\ModelNotFoundException
* @throws \think\exception\DbException
*/
public function update()
{
if (empty($this->param['work_id'])) return resultArray(['error' => '缺少项目ID']);
if (empty($this->param['name'])) return resultArray(['error' => '项目名称不能为空']);
if (!empty($this->param['is_open']) && empty($this->param['group_id'])) {
return resultArray(['error' => '请选择公开项目成员权限!']);
}
// if (empty($this->param['cover_url'])) return resultArray(['error' => '请选择项目封面!']);
$workModel = model('Work');
$userId = $this->userInfo['id'];
# 权限判断
if (!$this->checkWorkOperationAuth('setWork', $this->param['work_id'], $userId)) {
header('Content-Type:application/json; charset=utf-8');
exit(json_encode(['code' => 102, 'error' => '无权操作!']));
}
$this->param['user_id'] = $userId;
if (!$workModel->updateDataById($this->param)) return resultArray(['error' => $workModel->getError()]);
return resultArray(['data' => '操作成功!']);
}
/**
* 项目详情
*
* @return \think\response\Json
* @throws \think\db\exception\DataNotFoundException
* @throws \think\db\exception\ModelNotFoundException
* @throws \think\exception\DbException
*/
public function read()
{
if (empty($this->param['work_id'])) return resultArray(['error' => '请选择要查看的项目!']);
$workModel = model('Work');
$workInfo = $workModel->getDataById($this->param['work_id']);
# 是否是公开项目
$userId = $this->userInfo['id'];
$groupId = !empty($workInfo['is_open']) ? $workInfo['group_id'] : 0;
# 项目成员
$workInfo['ownerUser'] = db('admin_user')->field(['id', 'realname'])->whereIn('id', trim($workInfo['owner_user_id'], ','))->select();
$workInfo['auth'] = $this->getRuleList($this->param['work_id'], $userId, $groupId);
$userInfo=$this->userInfo;
$rule=db('work_user')
->where('user_id',$userInfo['id'])
->value('group_id');
$list=db('admin_rule')->where('name','manageTaskOwnerUser')->value('id');
$groupList = db('admin_group')->where(['pid' => 5, 'types' => 7, 'type' => 0,'id'=>$rule])->order('system desc')->value('rules');
if(!in_array($list,stringToArray($groupList))){
$workInfo['is_open']=1;
}
return resultArray(['data' => $workInfo]);
}
/**
* 删除项目
*
* @return \think\response\Json
* @throws \think\Exception
* @throws \think\exception\PDOException
*/
public function delete()
{
$param = $this->param;
$userInfo = $this->userInfo;
$workModel = model('Work');
if (empty($param['work_id'])) return resultArray(['error' => '请选择要删除的项目!']);
$dataInfo=db('work')->where('work_id',$param['work_id'])->find();
# 权限判断
if (!$this->checkWorkOperationAuth('setWork', $param['work_id'], $userInfo['id'])) {
header('Content-Type:application/json; charset=utf-8');
exit(json_encode(['code' => 102, 'error' => '无权操作!']));
}
// if (!$workModel->isCheck('work','work','update',$param['work_id'],$userInfo['id'])) {
// header('Content-Type:application/json; charset=utf-8');
// exit(json_encode(['code'=>102,'error'=>'无权操作']));
// }
$param['create_user_id'] = $userInfo['id'];
$resWork = $workModel->delWorkById($param);
if ($resWork) {
// 删除项目下所有任务
db('task')->where(['work_id' => $param['work_id']])->delete();
// 删除项目排序
db('work_order')->where('work_id', $param['work_id'])->delete();
RecordActionLog($userInfo['id'], 'work', 'delete',$dataInfo['name'], '','','删除了项目:'.$dataInfo['name']);
return resultArray(['data'=>'删除成功']);
} else {
return resultArray(['error'=>$workModel->getError()]);
}
}
/**
* 归档项目
* @author yykun
* @return
*/
public function archive()
{
$param = $this->param;
$userInfo = $this->userInfo;
$workModel = model('Work');
if (!$param['work_id']) {
return resultArray(['error'=>'参数错误']);
}
# 权限判断
if (!$this->checkWorkOperationAuth('setWork', $param['work_id'], $userInfo['id'])) {
header('Content-Type:application/json; charset=utf-8');
exit(json_encode(['code' => 102, 'error' => '无权操作!']));
}
// if (!$workModel->isCheck('work','work','update',$param['work_id'],$userInfo['id'])) {
// header('Content-Type:application/json; charset=utf-8');
// exit(json_encode(['code'=>102,'error'=>'无权操作']));
// }
$param['create_user_id'] = $userInfo['id'];
$flag = $workModel->archiveData($param);
if ($flag) {
return resultArray(['data'=>'归档成功']);
} else {
return resultArray(['error'=>$workModel->getError()]);
}
}
/**
* 参与人添加
*
* @return \think\response\Json
* @throws \think\db\exception\DataNotFoundException
* @throws \think\db\exception\ModelNotFoundException
* @throws \think\exception\DbException
*/
public function ownerAdd()
{
$param = $this->param;
$userInfo = $this->userInfo;
if (!$param['work_id'] || !$param['owner_user_id']) {
return resultArray(['error'=>'参数错误']);
}
$dataInfo=db('work')->where('work_id',$param['work_id'])->find();
$workModel = model('Work');
# 权限判断
if (!$this->checkWorkOperationAuth('setWork', $param['work_id'], $userInfo['id'])) {
header('Content-Type:application/json; charset=utf-8');
exit(json_encode(['code' => 102, 'error' => '无权操作!']));
}
// if (!$workModel->isCheck('work','work','update',$param['work_id'],$userInfo['id'])) {
// header('Content-Type:application/json; charset=utf-8');
// exit(json_encode(['code'=>102,'error'=>'无权操作']));
// }
$res = $workModel->addOwner($param);
$user= new \app\admin\model\User();
if ($res) {
$temp['work_id'] = $param['work_id'];
$list = $workModel->ownerList($temp); //获取参与人列表
foreach ($param['owner_user_id'] as $value){
$user_info=$user->getUserById($value);
RecordActionLog($userInfo['id'], 'work', 'save',$dataInfo['name'], '','','增加了项目成员:'.$user_info['realname']);
}
return resultArray(['data'=>$list]);
} else {
return resultArray(['error'=>'操作失败']);
}
}
/**
* 参与人删除
* @author yykun
* @return
*/
public function ownerDel()
{
$param = $this->param;
$userInfo = $this->userInfo;
if (!$param['work_id'] || !$param['owner_user_id']) {
return resultArray(['error'=>'参数错误']);
}
$workModel = model('Work');
# 权限判断
if (!$this->checkWorkOperationAuth('setWork', $param['work_id'], $userInfo['id'])) {
header('Content-Type:application/json; charset=utf-8');
exit(json_encode(['code' => 102, 'error' => '无权操作!']));
}
// if (!$workModel->isCheck('work','work','update',$param['work_id'],$userInfo['id'])) {
// header('Content-Type:application/json; charset=utf-8');
// exit(json_encode(['code'=>102,'error'=>'无权操作']));
// }
$res = $workModel->delOwner($param);
if ($res) {
return resultArray(['data'=>'操作成功']);
} else {
return resultArray(['error'=>$workModel->getError()]);
}
}
/**
* 参与人列表
* @author yykun
* @return
*/
public function ownerList()
{
$param = $this->param;
$workModel = model('Work');
$list = $workModel->ownerList($param);
return resultArray(['data'=>$list]);
}
/**
* 退出项目
* @author yykun
* @return
*/
public function leave()
{
$param = $this->param;
$userInfo = $this->userInfo;
$workModel = model('Work');
if (!$param['work_id']) {
return resultArray(['error'=>'参数错误']);
}
$ret = $workModel->leaveById($param['work_id'],$userInfo['id']);
if ($ret) {
return resultArray(['data'=>'操作成功']);
} else {
return resultArray(['error'=>$workModel->getError()]);
}
}
/**
* 归档项目列表
* @author yykun
* @return
*/
public function archiveList()
{
$param = $this->param;
$userInfo = $this->userInfo;
$param['user_id'] = $userInfo['id'];
$workModel = model('Work');
$list = $workModel->archiveList($param);
return resultArray(['data'=>$list]);
}
/**
* 恢复归档项目
* @author yykun
* @return
*/
public function arRecover()
{
$param = $this->param;
$userInfo = $this->userInfo;
if (!$param['work_id']) {
return resultArray(['error'=>'参数错误']);
}
$workModel = Model('Work');
# 权限判断
if (!$this->checkWorkOperationAuth('setWork', $param['work_id'], $userInfo['id'])) {
header('Content-Type:application/json; charset=utf-8');
exit(json_encode(['code' => 102, 'error' => '无权操作!']));
}
// if (!$workModel->isCheck('work','work','update',$param['work_id'],$userInfo['id'])) {
// header('Content-Type:application/json; charset=utf-8');
// exit(json_encode(['code'=>102,'error'=>'无权操作']));
// }
$ret = $workModel->arRecover($param['work_id']);
if ($ret) {
return resultArray(['data'=>'操作成功']);
} else {
return resultArray(['error'=>$workModel->getError()]);
}
}
/**
* 项目任务统计
*
* @return \think\response\Json
* @throws \think\db\exception\DataNotFoundException
* @throws \think\db\exception\ModelNotFoundException
* @throws \think\exception\DbException
*/
public function statistic()
{
if (empty($this->param['work_id'])) return resultArray(['error'=>'参数错误']);
$userModel = new \app\admin\model\User();
$workModel = model('work');
$param = $this->param;
$work_id = $param['work_id'];
$userInfo = $this->userInfo;
$dataCount = [];
if ($work_id !== 'all') $workInfo = Db::name('Work')->where(['work_id' => $work_id])->find();
$lableary = []; # 标签
$main_user_arr = []; # 成员
$allNum = 0; # 总任务数
$undoneNum = 0; # 总未完成数
$doneNum = 0; # 总完成数
$overtimeNum = 0; # 总延期数
$archiveNum = 0; # 总归档数
$completionRate = 0; # 总完成率
$delayRate = 0; # 总延期率
$workIds = [];
$groupIds = db('admin_access')->where('user_id', $userInfo['id'])->column('group_id');
$isSuperAdmin = $userInfo['id'] == 1 || in_array(1, (array)$groupIds); # 是否是超管
if (empty($isSuperAdmin)) $workIds = db('work_user')->where('user_id', $userInfo['id'])->column('work_id');
//公开项目
if ($work_id !== 'all') {
$taskList = Db::name('Task')->where(['work_id' => $work_id, 'ishidden' => 0, 'pid' => 0])->field('task_id,main_user_id,lable_id,status,owner_user_id,stop_time,is_archive')->select();
} else {
$where['work_id'] = !empty($isSuperAdmin) ? ['gt', 0] : ['in', $workIds];
$where['ishidden'] = 0;
$where['pid'] = 0;
$taskList = Db::name('Task')->where($where)->field('task_id,main_user_id,lable_id,status,owner_user_id,stop_time,is_archive')->select();
}
foreach ($taskList as $key => $value) {
if (empty($value['is_archive'])) {
$allNum += 1;
if ($value['status'] == 1) {
$undoneNum += 1;
}
if ($value['status'] == 1 && $value['stop_time'] && ($value['stop_time'] < time())) {
$overtimeNum += 1;
}
}
if ($value['is_archive'] == 1) $archiveNum += 1;
if ($value['status'] == 5) $doneNum += 1;
//获取项目下成员ID
// if ($value['owner_user_id'] && $workInfo['is_open'] == 1) $main_user_arr[] = $value['main_user_id']; //负责人
// if ($work_id == 'all') $main_user_arr[] = $value['main_user_id']; //负责人
$main_user_arr[] = $value['main_user_id'];
$lableArray = [];
$lableArray = $value['lable_id'] ? stringToArray($value['lable_id']) : []; //标签
$lableary = $lableArray ? array_merge($lableary,$lableArray) : $lableary;
}
$main_user_arr = $main_user_arr ? array_filter(array_unique($main_user_arr)) : [];
$lableary = array_filter(array_unique($lableary));
$completionRate = $allNum ? round(($doneNum / $allNum) * 100,2) : 0;
$delayRate = $allNum ? round(($overtimeNum / $allNum) * 100,2) : 0;
$dataCount['allNum'] = !empty($allNum) ? $allNum : 0;
$dataCount['undoneNum'] = !empty($undoneNum) ? $undoneNum : 0;
$dataCount['doneNum'] = !empty($doneNum) ? $doneNum : 0;
$dataCount['overtimeNum'] = !empty($overtimeNum) ? $overtimeNum : 0;
$dataCount['archiveNum'] = !empty($archiveNum) ? $archiveNum : 0;
$dataCount['completionRate'] = !empty($completionRate) ? round($completionRate) : 0;
$dataCount['delayRate'] = !empty($delayRate) ? $delayRate : 0;
//项目负责人
$ownerArr = [];
if ($workInfo && $workInfo['is_open'] == 0) {
//私有项目
// $main_user_arr = db('work_user')->where(['work_id' => $work_id])->column('user_id');
$ownerArr = db('work_user')->where(['work_id' => $work_id,'types' => 1])->column('user_id');
} elseif ($work_id !== 'all') {
$ownerArr[] = $workInfo['create_user_id'];
}
$ownerList = [];
foreach ($ownerArr as $k3=>$v3) {
$ownerList[] = $userModel->getUserById($v3);
}
$dataAry['ownerList'] = $ownerList ? : [];
// $dataAry['workInfo'] = $workInfo ? : [];
//成员统计
$list = [];
$i = 0;
$main_user_arr = $main_user_arr ? array_merge($main_user_arr) : [];
foreach ($main_user_arr as $key => $value) {
//参与项目数量
$userInfo = [];
$userInfo = $userModel->getUserById($value);
if (!$userInfo) continue;
$list[$i]['userInfo'] = $userInfo ? : [];
// $workCount = 0; //项目总数
$allCount = 0; //任务总数
$undoneCount = 0; //待完成任务总数
$doneCount = 0; //已完成任务总数
$overtimeCount = 0; //延期任务总数
$archiveCount = 0; //归档任务总数
$completionRate = 0; //完成率
$taskArr = [];
if ($work_id == 'all') {
$taskWhere['work_id'] = !empty($isSuperAdmin) ? ['gt', 0] : ['in', $workIds];
$taskWhere['main_user_id'] = $value;
$taskWhere['ishidden'] = 0;
$taskWhere['pid'] = 0;
$taskArr = db('task')->where($taskWhere)->field('status,stop_time,is_archive,task_id')->select();
} else {
$taskArr = db('task')->where(['work_id' => $work_id, 'main_user_id' => $value, 'ishidden' => 0, 'pid' => 0])->field('status,stop_time,is_archive,task_id')->select();
}
foreach ($taskArr as $v) {
$allCount += 1;
if ($v['status'] == 1 && empty($v['is_archive'])) $undoneCount += 1;
if (($v['status'] == 1 && empty($v['is_archive'])) && $v['stop_time'] && ($v['stop_time'] < time())) $overtimeCount += 1;
if ($v['is_archive'] == 1) $archiveCount += 1;
if ($v['status'] == 5) $doneCount += 1;
}
$completionRate = $allCount ? round(($doneCount/$allCount),2)*100 : 0;
$list[$i]['allCount'] = $allCount ? : 0;
$list[$i]['undoneCount'] = $undoneCount ? : 0;
$list[$i]['doneCount'] = $doneCount ? : 0;
$list[$i]['overtimeCount'] = $overtimeCount ? : 0;
$list[$i]['archiveCount'] = $archiveCount ? : 0;
$list[$i]['completionRate'] = $completionRate ? : 0;
$list[$i]['realname'] = !empty($userInfo) ? $userInfo['realname'] : '';
$i++;
}
$dataAry['dataCount'] = $dataCount;
$dataAry['userList'] = $list;
if ($work_id !== 'all') {
//任务列表统计
$dataAry['classList'] = $workModel->classList($work_id);
//标签统计
$dataAry['labelList'] = $workModel->labelList($work_id,$lableary);
}
return resultArray(['data'=>$dataAry]);
}
/**
* 参与人角色添加
*
* @return \think\response\Json
* @throws \think\Exception
* @throws \think\db\exception\DataNotFoundException
* @throws \think\db\exception\ModelNotFoundException
* @throws \think\exception\DbException
* @throws \think\exception\PDOException
*/
public function addUserGroup()
{
$param = $this->param;
$userInfo = $this->userInfo;
$workModel = model('Work');
$list = $param['list'] ? : [];
$work_id = $param['work_id'] ? : [];
if (!is_array($list) || !$work_id) {
return resultArray(['error'=>'参数错误']);
}
# 权限判断
if (!$this->checkWorkOperationAuth('setWork', $work_id, $userInfo['id'])) {
header('Content-Type:application/json; charset=utf-8');
exit(json_encode(['code' => 102, 'error' => '无权操作!']));
}
// if (!$workModel->isCheck('work','work','update',$param['work_id'],$userInfo['id'])) {
// header('Content-Type:application/json; charset=utf-8');
// exit(json_encode(['code'=>102,'error'=>'无权操作1']));
// }
foreach ($list as $value) {
$data = array();
$types = 0;
$data['work_id'] = $work_id;
$data['user_id'] = $value['user_id'];
$flag = db('work_user')->where($data)->find();
$data['group_id'] = $value['group_id'];
if ($value['group_id'] == 1) $types = 1; //项目管理员,不能删除
$data['types'] = $types;
if (!$flag) {
db('work_user')->insert($data);
} else {
db('work_user')->where(['work_id' => $work_id,'user_id' => $value['user_id']])->update($data);
}
}
$dataList = db('work_user')->where(['work_id' => $work_id])->select();
return resultArray(['data'=>$dataList]);
}
/**
* 项目下附件列表
*
* @param
* @return
*/
public function fileList()
{
$param = $this->param;
$userInfo = $this->userInfo;
$workModel = model('Work');
$work_id = $param['work_id'];
if (!$work_id) {
return resultArray(['error'=>'参数错误']);
}
//判断权限
$checkRes = $workModel->checkWork($work_id, $userInfo['id']);
if ($checkRes !== true) {
return resultArray(['error' => $workModel->getError()]);
}
$task_ids = db('task')->where(['work_id' => $work_id])->column('task_id');
$request = [];
$request['module'] = 'work_task';
$request['module_id'] = $task_ids;
$fileModel = new \app\admin\model\File();
$data = $fileModel->getDataList($request, $param['by']);
return resultArray(['data' => $data]);
}
/**
* 项目角色列表
*
* @return \think\response\Json
* @throws \think\db\exception\DataNotFoundException
* @throws \think\db\exception\ModelNotFoundException
* @throws \think\exception\DbException
*/
public function groupList()
{
$list[] = ['id' => 1,'title' => '管理', 'remark' => '系统默认权限,包含项目所有权限,不可修改/删除'];
$groupList = db('admin_group')->where(['pid' => 5, 'types' => 7, 'type' => 0])->order('system desc')->field('id, title, remark,rules')->select();
$listArr = array_merge($list, $groupList) ? : [];
return resultArray(['data' => $listArr]);
}
/**
* 项目关注
*
* @return \think\response\Json
* @throws \think\Exception
* @throws \think\exception\PDOException
*/
public function follow()
{
if (!isset($this->param['follow']) || empty($this->param['work_id'])) return resultArray(['error' => '参数错误!']);
$this->param['follow'] = !empty($this->param['follow']) ? $this->param['follow'] : 0;
if (!Db::name('work')->where('work_id', $this->param['work_id'])->update(['is_follow' => $this->param['follow']])) {
return resultArray(['error' => '操作失败!']);
}
return resultArray(['data' => '操作成功!']);
}
/**
* 项目列表排序
*
* @author fanqi
* @date 2021-03-11
* @param WorkLogic $workLogic
*/
public function updateWorkOrder(WorkLogic $workLogic)
{
$workIds = $this->param['workIds'];
$userInfo = $this->userInfo;
$workLogic->setWorkOrder($workIds, $userInfo['id']);
return resultArray(['data' => '操作成功!']);
}
}