694 lines
		
	
	
		
			30 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			694 lines
		
	
	
		
			30 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | ||
| /**
 | ||
|  * @copyright Copyright (c) 2023-2024 美天智能科技
 | ||
|  * @author 李志强
 | ||
|  * @link http://www.meteteme.com
 | ||
|  */
 | ||
| 
 | ||
| declare(strict_types=1);
 | ||
| 
 | ||
| namespace app\project\controller;
 | ||
| 
 | ||
| use app\base\BaseController;
 | ||
| use app\model\Project as ProjectList;
 | ||
| use app\model\Business as BusinessList;
 | ||
| use app\project\validate\ProjectCheck;
 | ||
| use think\exception\ValidateException;
 | ||
| use think\facade\Db;
 | ||
| use think\facade\View;
 | ||
| 
 | ||
| class Index extends BaseController
 | ||
| {
 | ||
|     public function index()
 | ||
|     {
 | ||
|         if (request()->isAjax()) {
 | ||
|             $param = get_params();
 | ||
|             $project_ids = Db::name('ProjectUser')->where(['uid' => $this->uid, 'delete_time' => null])->column('project_id');
 | ||
|             $rows = empty($param['limit']) ? get_config('app.page_size') : $param['limit'];
 | ||
|             $list = ProjectList::withoutField('content,md_content')
 | ||
|                 // ->where([['delete_time', '=', 0], ['id', 'in', $project_ids]])
 | ||
|                 ->where([['delete_time', '=', 0]])
 | ||
|                 ->order('status asc')
 | ||
|                 ->paginate($rows, false, ['query' => $param])
 | ||
|                 ->each(function ($item, $key) {
 | ||
|                     $item->director_name = Db::name('Admin')->where(['id' => $item->director_uid])->value('name');
 | ||
|                     // 判断时间戳是否为空,如果为空则返回“-”
 | ||
|                     $item->plan_time = $item->start_time && $item->end_time
 | ||
|                         ? date('Y-m-d', $item->start_time) . ' ~ ' . date('Y-m-d', $item->end_time)
 | ||
|                         : '-';
 | ||
|                     $item->project_plan_time = $item->project_start_time
 | ||
|                         ? (
 | ||
|                             $item->project_end_time
 | ||
|                             ? (
 | ||
|                                 date('Y-m-d', $item->project_end_time) === '1970-01-01'
 | ||
|                                 ? date('Y-m-d', $item->project_start_time) . '  ~  至今'
 | ||
|                                 : date('Y-m-d', $item->project_start_time) . '  ~  ' . date('Y-m-d', $item->project_end_time)
 | ||
|                             )
 | ||
|                             : date('Y-m-d', $item->project_start_time) . '  ~  至今'
 | ||
|                         )
 | ||
|                         : '-';
 | ||
|                     $item->status_name = ProjectList::$Status[(int) $item->status];
 | ||
| 
 | ||
|                     $business = BusinessList::where('id', $item->business_id)->find();
 | ||
|                     $item->business_id = $business ? ($business->name_short ?: $business->name) : null;
 | ||
| 
 | ||
|                     $task_map = [];
 | ||
|                     $task_map[] = ['project_id', '=', $item->id];
 | ||
|                     $task_map[] = ['delete_time', '=', 0];
 | ||
| 
 | ||
| 
 | ||
|                     //任务
 | ||
|                     $task_map_a = $task_map;
 | ||
|                     $task_map_a[] = ['is_bug', '=', 0];
 | ||
|                     //任务总数
 | ||
|                     $item->tasks_a_total = Db::name('Task')->where($task_map_a)->count();
 | ||
|                     //已完成任务
 | ||
|                     $task_map_a[] = ['flow_status', '>', 2]; //已完成
 | ||
|                     $item->tasks_a_finish = Db::name('Task')->where($task_map_a)->count();
 | ||
|                     //未完成任务
 | ||
|                     $item->tasks_a_unfinish = $item->tasks_a_total - $item->tasks_a_finish;
 | ||
|                     if ($item->tasks_a_total > 0) {
 | ||
|                         $item->tasks_a_pensent = round($item->tasks_a_finish / $item->tasks_a_total * 100, 2) . "%";
 | ||
|                     } else {
 | ||
|                         $item->tasks_a_pensent = "100%";
 | ||
|                     }
 | ||
| 
 | ||
|                     //缺陷
 | ||
|                     $task_map_b = $task_map;
 | ||
|                     $task_map_b[] = ['is_bug', '=', 1];
 | ||
|                     //缺陷总数
 | ||
|                     $item->tasks_b_total = Db::name('Task')->where($task_map_b)->count();
 | ||
|                     //已完成缺陷
 | ||
|                     $task_map_b[] = ['flow_status', '>', 2]; //已完成
 | ||
|                     $item->tasks_b_finish = Db::name('Task')->where($task_map_b)->count();
 | ||
|                     //未完成缺陷
 | ||
|                     $item->tasks_b_unfinish = $item->tasks_b_total - $item->tasks_b_finish;
 | ||
|                     if ($item->tasks_b_total > 0) {
 | ||
|                         $item->tasks_b_pensent = round($item->tasks_b_finish / $item->tasks_b_total * 100, 2) . "%";
 | ||
|                     } else {
 | ||
|                         $item->tasks_b_pensent = "100%";
 | ||
|                     }
 | ||
|                 });
 | ||
|             return table_assign(0, '', $list);
 | ||
|         } else {
 | ||
|             return view();
 | ||
|         }
 | ||
|     }
 | ||
| 
 | ||
|     //添加
 | ||
|     public function add()
 | ||
|     {
 | ||
|         $param = get_params();
 | ||
|         if (request()->isPost()) {
 | ||
|             if (isset($param['start_time'])) {
 | ||
|                 // 仅保留日期部分(年-月-日),忽略时间(时:分:秒)
 | ||
|                 $param['start_time'] = strtotime(date('Y-m-d', strtotime(urldecode($param['start_time']))));
 | ||
|             }
 | ||
| 
 | ||
|             if (isset($param['end_time'])) {
 | ||
|                 // 仅保留日期部分(年-月-日),忽略时间(时:分:秒)
 | ||
|                 $param['end_time'] = strtotime(date('Y-m-d', strtotime(urldecode($param['end_time']))));
 | ||
|             }
 | ||
| 
 | ||
|             $param['step_sort'] = 0;
 | ||
|             $flowNameData = isset($param['flowName']) ? $param['flowName'] : '';
 | ||
|             $flowUidsData = isset($param['chargeIds']) ? $param['chargeIds'] : '';
 | ||
|             $flowIdsData = isset($param['membeIds']) ? $param['membeIds'] : '';
 | ||
|             //            $flowDateData = isset($param['cycleDate']) ? $param['cycleDate'] : '';
 | ||
|             $flow = [];
 | ||
|             $time_1 = $param['start_time'];
 | ||
|             $time_2 = $param['end_time'];
 | ||
|             foreach ($flowNameData as $key => $value) {
 | ||
|                 if (!$value) {
 | ||
|                     continue;
 | ||
|                 }
 | ||
|                 //                $flowDate = explode('到', $flowDateData[$key]);
 | ||
| //                $start_time = strtotime(urldecode(trim($flowDate[0])));
 | ||
| //                $end_time = strtotime(urldecode(trim($flowDate[1])));
 | ||
| //                if ($start_time < $time_1) {
 | ||
| //                    if ($key == 0) {
 | ||
| //                        return to_assign(1, '第' . ($key + 1) . '阶段的开始时间不能小于计划开始时间');
 | ||
| //                    } else {
 | ||
| //                        return to_assign(1, '第' . ($key + 1) . '阶段的开始时间不能小于第' . ($key) . '阶段的结束时间');
 | ||
| //                    }
 | ||
| //                    break;
 | ||
| //                }
 | ||
| //                if ($end_time > $time_2) {
 | ||
| //                    return to_assign(1, '第' . ($key + 1) . '阶段的结束时间不能大于计划结束时间');
 | ||
| //                    break;
 | ||
| //                } else {
 | ||
| //                    $time_1 = $end_time;
 | ||
| //                }
 | ||
|                 $item = [];
 | ||
|                 $item['flow_name'] = $value;
 | ||
|                 $item['type'] = 1;
 | ||
|                 $item['flow_uid'] = $flowUidsData[$key];
 | ||
|                 $item['flow_ids'] = $flowIdsData[$key];
 | ||
|                 $item['sort'] = $key;
 | ||
|                 //                $item['start_time'] = $start_time;
 | ||
| //                $item['end_time'] = $end_time;
 | ||
|                 $item['create_time'] = time();
 | ||
|                 $flow[] = $item;
 | ||
|             }
 | ||
|             //var_dump($flow);exit;
 | ||
| 
 | ||
|             try {
 | ||
|                 validate(ProjectCheck::class)->scene('add')->check($param);
 | ||
|             } catch (ValidateException $e) {
 | ||
|                 // 验证失败 输出错误信息
 | ||
|                 return to_assign(1, $e->getError());
 | ||
|             }
 | ||
|             $param['create_time'] = time();
 | ||
|             $param['admin_id'] = $this->uid;
 | ||
|             $sid = ProjectList::strict(false)->field(true)->insertGetId($param);
 | ||
|             if ($sid) {
 | ||
|                 $project_users = $this->uid;
 | ||
|                 if (!empty($param['director_uid'])) {
 | ||
|                     $project_users .= "," . $param['director_uid'];
 | ||
|                 }
 | ||
|                 if (!empty($param['team_admin_ids'])) {
 | ||
|                     $project_users .= "," . $param['team_admin_ids'];
 | ||
|                 }
 | ||
|                 $project_array = explode(",", (string) $project_users);
 | ||
|                 $project_array = array_unique($project_array);
 | ||
|                 $project_user_array = [];
 | ||
|                 foreach ($project_array as $k => $v) {
 | ||
|                     if (is_numeric($v)) {
 | ||
|                         $project_user_array[] = array(
 | ||
|                             'uid' => $v,
 | ||
|                             'admin_id' => $this->uid,
 | ||
|                             'project_id' => $sid,
 | ||
|                             'create_time' => time(),
 | ||
|                         );
 | ||
|                     }
 | ||
|                 }
 | ||
|                 Db::name('ProjectUser')->strict(false)->field(true)->insertAll($project_user_array);
 | ||
| 
 | ||
|                 //增加阶段
 | ||
|                 foreach ($flow as $key => &$value) {
 | ||
|                     $value['action_id'] = $sid;
 | ||
|                 }
 | ||
|                 Db::name('Step')->strict(false)->field(true)->insertAll($flow);
 | ||
| 
 | ||
|                 add_log('add', $sid, $param);
 | ||
|                 $log_data = array(
 | ||
|                     'module' => 'project',
 | ||
|                     'project_id' => $sid,
 | ||
|                     'new_content' => $param['name'],
 | ||
|                     'field' => 'new',
 | ||
|                     'action' => 'add',
 | ||
|                     'admin_id' => $this->uid,
 | ||
|                     'old_content' => '',
 | ||
|                     'create_time' => time(),
 | ||
|                 );
 | ||
|                 Db::name('Log')->strict(false)->field(true)->insert($log_data);
 | ||
|             }
 | ||
|             return to_assign();
 | ||
|         } else {
 | ||
|             $id = isset($param['id']) ? $param['id'] : 0;
 | ||
|             if ($id > 0) {
 | ||
|                 $detail = (new ProjectList())->detail($id);
 | ||
|                 if (empty($detail)) {
 | ||
|                     return to_assign(1, '项目不存在');
 | ||
|                 }
 | ||
|                 View::assign('detail', $detail);
 | ||
|             }
 | ||
|             $section = ['项目开始', '调研阶段', '报价阶段', '招投标阶段', '签约阶段', '研发阶段', '测试阶段', '交付阶段', '项目完结'];
 | ||
|             View::assign('section', $section);
 | ||
|             View::assign('user_info', get_login_admin());
 | ||
|             View::assign('id', $id);
 | ||
|             return view();
 | ||
|         }
 | ||
|     }
 | ||
| 
 | ||
|     //编辑
 | ||
|     public function edit()
 | ||
|     {
 | ||
|         $param = get_params();
 | ||
|         $id = isset($param['id']) ? $param['id'] : 0;
 | ||
|         $detail = (new ProjectList())->detail($id);
 | ||
| 
 | ||
|         if (request()->isPost()) {
 | ||
|             if ($this->uid == $detail['admin_id'] || $this->uid == $detail['director_uid']) {
 | ||
|                 try {
 | ||
|                     validate(ProjectCheck::class)->scene('edit')->check($param);
 | ||
|                 } catch (ValidateException $e) {
 | ||
|                     return json(['code' => 1, 'msg' => $e->getError()]);
 | ||
|                 }
 | ||
| 
 | ||
|                 // 将时间从日期字符串转换为Unix时间戳
 | ||
|                 if (!empty($param['start_time'])) {
 | ||
|                     $param['start_time'] = strtotime($param['start_time']);
 | ||
|                 }
 | ||
|                 if (!empty($param['end_time'])) {
 | ||
|                     $param['end_time'] = strtotime($param['end_time']);
 | ||
|                 }
 | ||
|                 if (!empty($param['project_start_time'])) {
 | ||
|                     $param['project_start_time'] = strtotime($param['project_start_time']);
 | ||
|                 }
 | ||
|                 if (!empty($param['project_end_time'])) {
 | ||
|                     $param['project_end_time'] = strtotime($param['project_end_time']);
 | ||
|                 }
 | ||
| 
 | ||
|                 $param['update_time'] = time();
 | ||
|                 $res = ProjectList::where('id', $param['id'])->strict(false)->field(true)->update($param);
 | ||
|                 if ($res) {
 | ||
|                     // 新增 team_admin_ids 处理逻辑
 | ||
|                     $project_users = $this->uid;
 | ||
|                     if (!empty($param['director_uid'])) {
 | ||
|                         $project_users .= "," . $param['director_uid'];
 | ||
|                     }
 | ||
| 
 | ||
|                     // 如果 team_admin_ids 存在,则拆解并加入到 $project_users
 | ||
|                     if (!empty($param['team_admin_ids'])) {
 | ||
|                         $project_users .= "," . $param['team_admin_ids'];
 | ||
|                     }
 | ||
| 
 | ||
|                     // 将 $project_users 拆解为数组,去重
 | ||
|                     $project_array = explode(",", (string) $project_users);
 | ||
|                     $project_array = array_unique($project_array);
 | ||
| 
 | ||
|                     // 获取当前已有的项目用户
 | ||
|                     $existing_users = Db::name('ProjectUser')->where('project_id', $param['id'])->column('uid');
 | ||
|                     $delete_users = array_diff($existing_users, $project_array); // 找出要删除的用户
 | ||
| 
 | ||
|                     // 删除用户,将 `delete_time` 设置为当前时间
 | ||
|                     if (!empty($delete_users)) {
 | ||
|                         Db::name('ProjectUser')->where('project_id', $param['id'])
 | ||
|                             ->whereIn('uid', $delete_users)
 | ||
|                             ->update(['delete_time' => time()]);
 | ||
|                     }
 | ||
| 
 | ||
|                     // 插入新用户(如果之前没有的话)
 | ||
|                     $project_user_array = [];
 | ||
|                     foreach ($project_array as $k => $v) {
 | ||
|                         if (is_numeric($v)) {
 | ||
|                             $project_user_array[] = array(
 | ||
|                                 'uid' => $v,
 | ||
|                                 'admin_id' => $this->uid,
 | ||
|                                 'project_id' => $param['id'],
 | ||
|                                 'create_time' => time(),
 | ||
|                             );
 | ||
|                         }
 | ||
|                     }
 | ||
| 
 | ||
|                     // 插入或更新 ProjectUser 表
 | ||
|                     Db::name('ProjectUser')->strict(false)->field(true)->insertAll($project_user_array);
 | ||
| 
 | ||
|                     // 更新阶段的处理逻辑(保持不变)
 | ||
|                     if (isset($param['director_uid'])) {
 | ||
|                         $project_user = [
 | ||
|                             'uid' => $param['director_uid'],
 | ||
|                             'admin_id' => $this->uid,
 | ||
|                             'project_id' => $param['id'],
 | ||
|                             'create_time' => time(),
 | ||
|                             'delete_time' => 0,
 | ||
|                         ];
 | ||
|                         $has = Db::name('ProjectUser')->where(['uid' => $param['director_uid'], 'project_id' => $param['id']])->find();
 | ||
|                         if (empty($has)) {
 | ||
|                             Db::name('ProjectUser')->strict(false)->field(true)->insert($project_user);
 | ||
|                         } else {
 | ||
|                             Db::name('ProjectUser')->where(['id' => $has['id']])->strict(false)->field(true)->update($project_user);
 | ||
|                         }
 | ||
|                     }
 | ||
| 
 | ||
|                     add_log('edit', $param['id'], $param, $detail);
 | ||
|                 }
 | ||
|                 return json(['code' => 0, 'msg' => '编辑成功']);
 | ||
|             } else {
 | ||
|                 return json(['code' => 1, 'msg' => '只有创建人或者负责人才有权限编辑']);
 | ||
|             }
 | ||
|         } else {
 | ||
|             if (empty($detail)) {
 | ||
|                 return json(['code' => 1, 'msg' => '项目不存在']);
 | ||
|             } else {
 | ||
|                 $step_array = Db::name('Step')
 | ||
|                     ->field('s.*,a.name as check_name')
 | ||
|                     ->alias('s')
 | ||
|                     ->join('Admin a', 'a.id = s.flow_uid', 'LEFT')
 | ||
|                     ->order('s.sort asc')
 | ||
|                     ->where(['s.action_id' => $id, 's.type' => 1, 's.delete_time' => 0])
 | ||
|                     ->select()->toArray();
 | ||
|                 foreach ($step_array as &$vv) {
 | ||
|                     $flow_names = Db::name('Admin')->where([['id', 'in', $vv['flow_ids']]])->column('name');
 | ||
|                     $vv['flow_names'] = implode(',', $flow_names);
 | ||
|                 }
 | ||
| 
 | ||
|                 $file_array = Db::name('FileInterfix')
 | ||
|                     ->field('mf.id,mf.topic_id,mf.admin_id,f.name,f.filesize,f.filepath,a.name as admin_name')
 | ||
|                     ->alias('mf')
 | ||
|                     ->join('File f', 'mf.file_id = f.id', 'LEFT')
 | ||
|                     ->join('Admin a', 'mf.admin_id = a.id', 'LEFT')
 | ||
|                     ->order('mf.create_time desc')
 | ||
|                     ->where(['mf.topic_id' => $id, 'mf.module' => 'project'])
 | ||
|                     ->select()->toArray();
 | ||
| 
 | ||
|                 return json([
 | ||
|                     'code' => 0,
 | ||
|                     'msg' => '成功',
 | ||
|                     'data' => [
 | ||
|                         'detail' => $detail,
 | ||
|                         'step_array' => $step_array,
 | ||
|                         'file_array' => $file_array,
 | ||
|                     ]
 | ||
|                 ]);
 | ||
|             }
 | ||
|         }
 | ||
|     }
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
|     //	public function edit()
 | ||
| //	{
 | ||
| //		$param = get_params();
 | ||
| //		$id = isset($param['id']) ? $param['id'] : 0;
 | ||
| //		$detail = (new ProjectList())->detail($id);
 | ||
| //		if (request()->isPost()) {
 | ||
| //			if ($this->uid == $detail['admin_id'] || $this->uid == $detail['director_uid']) {
 | ||
| //				if (isset($param['start_time'])) {
 | ||
| //					$param['start_time'] = strtotime(urldecode($param['start_time']));
 | ||
| //					if ($param['start_time'] >= $detail['end_time']) {
 | ||
| //						return to_assign(1, '开始时间不能大于计划结束时间');
 | ||
| //					}
 | ||
| //				}
 | ||
| //				if (isset($param['end_time'])) {
 | ||
| //					$param['end_time'] = strtotime(urldecode($param['end_time']));
 | ||
| //					if ($param['end_time'] <= $detail['start_time']) {
 | ||
| //						return to_assign(1, '计划结束时间不能小于开始时间');
 | ||
| //					}
 | ||
| //				}
 | ||
| //				try {
 | ||
| //					validate(ProjectCheck::class)->scene('edit')->check($param);
 | ||
| //				} catch (ValidateException $e) {
 | ||
| //					// 验证失败 输出错误信息
 | ||
| //					return to_assign(1, $e->getError());
 | ||
| //				}
 | ||
| //				$param['update_time'] = time();
 | ||
| //				$res = ProjectList::where('id', $param['id'])->strict(false)->field(true)->update($param);
 | ||
| //				if ($res) {
 | ||
| //					if (isset($param['director_uid'])) {
 | ||
| //						$project_user = array(
 | ||
| //							'uid' => $param['director_uid'],
 | ||
| //							'admin_id' => $this->uid,
 | ||
| //							'project_id' => $param['id'],
 | ||
| //							'create_time' => time(),
 | ||
| //							'delete_time' => 0,
 | ||
| //						);
 | ||
| //						$has = Db::name('ProjectUser')->where(array('uid' => $param['director_uid'], 'project_id' => $param['id']))->find();
 | ||
| //						if (empty($has)) {
 | ||
| //							Db::name('ProjectUser')->strict(false)->field(true)->insert($project_user);
 | ||
| //						} else {
 | ||
| //							Db::name('ProjectUser')->where(array('id' => $has['id']))->strict(false)->field(true)->update($project_user);
 | ||
| //						}
 | ||
| //
 | ||
| //					}
 | ||
| //
 | ||
| //					add_log('edit', $param['id'], $param, $detail);
 | ||
| //				}
 | ||
| //				return to_assign();
 | ||
| //			} else {
 | ||
| //				return to_assign(1, '只有创建人或者负责人才有权限编辑');
 | ||
| //			}
 | ||
| //		} else {
 | ||
| //			if (empty($detail)) {
 | ||
| //				return to_assign(1, '项目不存在');
 | ||
| //			} else {
 | ||
| //				//项目阶段
 | ||
| //				$step_array = Db::name('Step')
 | ||
| //					->field('s.*,a.name as check_name')
 | ||
| //					->alias('s')
 | ||
| //					->join('Admin a', 'a.id = s.flow_uid', 'LEFT')
 | ||
| //					->order('s.sort asc')
 | ||
| //					->where(array('s.action_id' => $id, 's.type' => 1, 's.delete_time' => 0))
 | ||
| //					->select()->toArray();
 | ||
| //				foreach ($step_array as $kk => &$vv) {
 | ||
| //					$vv['start_time'] = date('Y-m-d', $vv['start_time']);
 | ||
| //					$vv['end_time'] = date('Y-m-d', $vv['end_time']);
 | ||
| //					$flow_names = Db::name('Admin')->where([['id', 'in', $vv['flow_ids']]])->column('name');
 | ||
| //					$vv['flow_names'] = implode(',', $flow_names);
 | ||
| //				}
 | ||
| //
 | ||
| //				$file_array = Db::name('FileInterfix')
 | ||
| //					->field('mf.id,mf.topic_id,mf.admin_id,f.name,f.filesize,f.filepath,a.name as admin_name')
 | ||
| //					->alias('mf')
 | ||
| //					->join('File f', 'mf.file_id = f.id', 'LEFT')
 | ||
| //					->join('Admin a', 'mf.admin_id = a.id', 'LEFT')
 | ||
| //					->order('mf.create_time desc')
 | ||
| //					->where(array('mf.topic_id' => $id, 'mf.module' => 'project'))
 | ||
| //					->select()->toArray();
 | ||
| //				View::assign('file_array', $file_array);
 | ||
| //
 | ||
| //				View::assign('step_array', $step_array);
 | ||
| //				View::assign('detail', $detail);
 | ||
| //				View::assign('id', $id);
 | ||
| //				return view();
 | ||
| //			}
 | ||
| //		}
 | ||
| //	}
 | ||
| 
 | ||
|     //编辑项目阶段
 | ||
|     public function editstep()
 | ||
|     {
 | ||
|         // 获取请求参数
 | ||
|         $param = get_params();
 | ||
|         $id = isset($param['id']) ? $param['id'] : 0;
 | ||
| 
 | ||
|         //        print_r('id是:'.$id);
 | ||
| 
 | ||
|         // 获取项目详细信息
 | ||
|         $detail = (new ProjectList())->detail($id);
 | ||
|         if (!$detail) {
 | ||
|             $detail = [];
 | ||
|         }
 | ||
| 
 | ||
|         $step_array = [];
 | ||
|         $step_array = Db::name('Step')
 | ||
|             ->where('action_id', '=', $id)
 | ||
|             ->where('delete_time', '=', 0)
 | ||
|             ->select()
 | ||
|             ->toArray();
 | ||
| 
 | ||
|         // 处理查询结果
 | ||
|         foreach ($step_array as &$vv) {
 | ||
|             // 格式化时间字段
 | ||
| //            $vv['start_time'] = date('Y-m-d', $vv['start_time']);
 | ||
| //            $vv['end_time'] = date('Y-m-d', $vv['end_time']);
 | ||
| 
 | ||
|             // 获取相关的人员名字
 | ||
|             $flow_names = Db::name('Admin')
 | ||
|                 ->whereIn('id', explode(',', $vv['flow_ids']))
 | ||
|                 ->column('name');
 | ||
|             $vv['flow_names'] = implode(',', $flow_names);
 | ||
| 
 | ||
|             // 获取负责人名字(只有一个负责人)
 | ||
|             $vv['check_name'] = Db::name('Admin')
 | ||
|                 ->where('id', $vv['flow_uid']) // 只查找一个负责人
 | ||
|                 ->value('name'); // 获取负责人名称
 | ||
|         }
 | ||
| 
 | ||
| 
 | ||
|         View::assign('step_array', $step_array);
 | ||
|         View::assign('id', $id);
 | ||
|         View::assign('detail', $detail);  // 传递 detail
 | ||
|         return view();
 | ||
| 
 | ||
|         //        return json([
 | ||
| //            'code' => 1,
 | ||
| //            'msg' => '获取项目阶段信息成功',
 | ||
| //            'data' => [
 | ||
| //                'step_array' => $step_array,
 | ||
| //                'id' => $id,
 | ||
| //                'detail' => $detail
 | ||
| //            ]
 | ||
| //        ]);
 | ||
|     }
 | ||
| 
 | ||
| 
 | ||
|     //查看
 | ||
|     public function view()
 | ||
|     {
 | ||
|         $param = get_params();
 | ||
|         $id = isset($param['id']) ? $param['id'] : 0;
 | ||
|         $detail = (new ProjectList())->detail($id);
 | ||
|         if (empty($detail)) {
 | ||
|             return to_assign(1, '项目不存在');
 | ||
|         } else {
 | ||
|             $tids = Db::name('Task')->where([['project_id', '=', $detail['id']], ['delete_time', '=', 0]])->column('id');
 | ||
|             $detail['schedules'] = Db::name('Schedule')->where([['tid', 'in', $tids], ['delete_time', '=', 0]])->count();
 | ||
|             $detail['hours'] = Db::name('Schedule')->where([['tid', 'in', $tids], ['delete_time', '=', 0]])->sum('labor_time');
 | ||
|             $detail['plan_hours'] = Db::name('Task')->where([['project_id', '=', $detail['id']], ['delete_time', '=', 0]])->sum('plan_hours');
 | ||
|             $detail['documents'] = Db::name('Document')->where([['module', '=', 'project'], ['topic_id', '=', $detail['id']], ['delete_time', '=', 0]])->count();
 | ||
|             $detail['tasks'] = Db::name('Task')->where([['project_id', '=', $detail['id']], ['delete_time', '=', 0]])->count();
 | ||
|             $detail['tasks_finish'] = Db::name('Task')->where([['project_id', '=', $detail['id']], ['flow_status', '>', 2], ['delete_time', '=', 0]])->count();
 | ||
|             $detail['tasks_unfinish'] = $detail['tasks'] - $detail['tasks_finish'];
 | ||
|             $detail['business_id'] = BusinessList::where('id', $detail['business_id'])->value('name');
 | ||
| 
 | ||
|             $task_map = [];
 | ||
|             $task_map[] = ['project_id', '=', $detail['id']];
 | ||
|             $task_map[] = ['delete_time', '=', 0];
 | ||
| 
 | ||
|             //任务
 | ||
|             $task_cate = Db::name('TaskCate')->where(['status' => 1])->select()->toArray();
 | ||
|             foreach ($task_cate as $k => $v) {
 | ||
|                 $task_map_item = $task_map;
 | ||
|                 $task_map_item[] = ['type', '=', $v['id']];
 | ||
|                 $task_cate[$k]['count'] = Db::name('Task')->where($task_map_item)->count();
 | ||
|                 $task_map_item[] = ['flow_status', '>', 2];
 | ||
|                 $task_cate[$k]['unfinish'] = Db::name('Task')->where($task_map_item)->count();
 | ||
|             }
 | ||
|             $detail['task_cate'] = $task_cate;
 | ||
|             //判断是否是创建者或者负责人
 | ||
|             $role = 0;
 | ||
|             if ($detail['director_uid'] == $this->uid) {
 | ||
|                 $role = 1; //负责人
 | ||
|             }
 | ||
|             if ($detail['admin_id'] == $this->uid) {
 | ||
|                 $role = 2; //创建人
 | ||
|             }
 | ||
| 
 | ||
|             $file_array = Db::name('FileInterfix')
 | ||
|                 ->field('mf.id,mf.topic_id,mf.admin_id,f.name,f.filesize,f.filepath,a.name as admin_name')
 | ||
|                 ->alias('mf')
 | ||
|                 ->join('File f', 'mf.file_id = f.id', 'LEFT')
 | ||
|                 ->join('Admin a', 'mf.admin_id = a.id', 'LEFT')
 | ||
|                 ->order('mf.create_time desc')
 | ||
|                 ->where(array('mf.topic_id' => $id, 'mf.module' => 'project'))
 | ||
|                 ->select()->toArray();
 | ||
| 
 | ||
|             $link_array = Db::name('LinkInterfix')
 | ||
|                 ->field('i.id,i.topic_id,i.admin_id,i.desc,i.url,a.name as admin_name')
 | ||
|                 ->alias('i')
 | ||
|                 ->join('Admin a', 'i.admin_id = a.id', 'LEFT')
 | ||
|                 ->order('i.create_time desc')
 | ||
|                 ->where(array('i.topic_id' => $id, 'i.module' => 'project', 'delete_time' => 0))
 | ||
|                 ->select()->toArray();
 | ||
| 
 | ||
|             //项目阶段
 | ||
|             $step_array = Db::name('Step')
 | ||
|                 ->field('s.*,a.name as check_name')
 | ||
|                 ->alias('s')
 | ||
|                 ->join('Admin a', 'a.id = s.flow_uid', 'LEFT')
 | ||
|                 ->order('s.sort asc')
 | ||
|                 ->where(array('s.action_id' => $id, 's.type' => 1, 's.delete_time' => 0))
 | ||
|                 ->select()->toArray();
 | ||
| 
 | ||
|             //阶段操作记录
 | ||
|             $step_record = Db::name('StepRecord')
 | ||
|                 ->field('s.*,a.name as check_name,p.flow_name')
 | ||
|                 ->alias('s')
 | ||
|                 ->join('Admin a', 'a.id = s.check_uid', 'LEFT')
 | ||
|                 ->join('Step p', 'p.id = s.step_id', 'LEFT')
 | ||
|                 ->order('s.check_time asc')
 | ||
|                 ->where(array('s.action_id' => $id, 's.type' => 1))
 | ||
|                 ->select()->toArray();
 | ||
|             foreach ($step_record as $kk => &$vv) {
 | ||
|                 $vv['check_time_str'] = date('Y-m-d :H:i', $vv['check_time']);
 | ||
|                 $vv['status_str'] = '提交';
 | ||
|                 if ($vv['status'] == 0) {
 | ||
|                     $vv['status_str'] = '重新设置';
 | ||
|                 } else if ($vv['status'] == 1) {
 | ||
|                     $vv['status_str'] = '确认完成';
 | ||
|                 } else if ($vv['status'] == 2) {
 | ||
|                     $vv['status_str'] = '回退';
 | ||
|                 }
 | ||
|                 if ($vv['status'] == 3) {
 | ||
|                     $vv['status_str'] = '撤销';
 | ||
|                 }
 | ||
|                 if ($vv['content'] == '') {
 | ||
|                     $vv['content'] = '无';
 | ||
|                 }
 | ||
|             }
 | ||
| 
 | ||
|             //当前项目阶段
 | ||
|             $step = Db::name('Step')->where(array('action_id' => $id, 'type' => 1, 'sort' => $detail['step_sort'], 'delete_time' => 0))->find();
 | ||
|             if (!empty($step)) {
 | ||
|                 $step['check_name'] = Db::name('Admin')->where(['id' => $step['flow_uid']])->value('name');
 | ||
|                 $flow_names = Db::name('Admin')->where([['id', 'in', $step['flow_ids']]])->column('name');
 | ||
|                 $step['flow_names'] = implode(',', $flow_names);
 | ||
|                 if ($this->uid == $step['flow_uid']) {
 | ||
|                     $is_check_admin = 1;
 | ||
|                 }
 | ||
|             }
 | ||
| 
 | ||
|             View::assign('step', $step);
 | ||
|             View::assign('step_array', $step_array);
 | ||
|             View::assign('step_record', $step_record);
 | ||
| 
 | ||
|             View::assign('file_array', $file_array);
 | ||
|             View::assign('link_array', $link_array);
 | ||
|             View::assign('detail', $detail);
 | ||
|             View::assign('role', $role);
 | ||
|             View::assign('id', $id);
 | ||
|             View::assign('login_user', $this->uid);
 | ||
|             return view();
 | ||
|         }
 | ||
|     }
 | ||
| 
 | ||
|     //删除
 | ||
|     public function delete()
 | ||
|     {
 | ||
|         if (request()->isDelete()) {
 | ||
|             $id = get_params("id");
 | ||
|             $count_task = Db::name('Task')->where([['project_id', '=', $id], ['delete_time', '=', 0]])->count();
 | ||
|             if ($count_task > 0) {
 | ||
|                 return to_assign(1, "该项目下有关联的任务,无法删除");
 | ||
|             }
 | ||
|             $detail = Db::name('Project')->where('id', $id)->find();
 | ||
|             if ($detail['admin_id'] != $this->uid) {
 | ||
|                 return to_assign(1, "你不是该项目的创建人,无权限删除");
 | ||
|             }
 | ||
|             if (Db::name('Project')->where('id', $id)->update(['delete_time' => time()]) !== false) {
 | ||
|                 $log_data = array(
 | ||
|                     'module' => 'project',
 | ||
|                     'field' => 'delete',
 | ||
|                     'action' => 'delete',
 | ||
|                     'project_id' => $detail['id'],
 | ||
|                     'admin_id' => $this->uid,
 | ||
|                     'old_content' => '',
 | ||
|                     'new_content' => $detail['name'],
 | ||
|                     'create_time' => time(),
 | ||
|                 );
 | ||
|                 Db::name('Log')->strict(false)->field(true)->insert($log_data);
 | ||
|                 return to_assign(0, "删除成功");
 | ||
|             } else {
 | ||
|                 return to_assign(0, "删除失败");
 | ||
|             }
 | ||
|         } else {
 | ||
|             return to_assign(1, "错误的请求");
 | ||
|         }
 | ||
|     }
 | ||
| 
 | ||
|     //关闭项目
 | ||
|     public function close()
 | ||
|     {
 | ||
|         if (request()->isPost()) {
 | ||
|             $id = get_params("id");
 | ||
|             $detail = Db::name('Project')->where('id', $id)->find();
 | ||
|             if (empty($detail)) {
 | ||
|                 return to_assign(1, "项目不存在");
 | ||
|             }
 | ||
|             Db::name('Project')->where('id', $id)->update(['status' => 4]);
 | ||
|             return to_assign(0, "关闭成功");
 | ||
|         } else {
 | ||
|             return to_assign(1, "错误的请求方式");
 | ||
|         }
 | ||
|     }
 | ||
| 
 | ||
|     //开启项目
 | ||
|     public function open()
 | ||
|     {
 | ||
|         if (request()->isPost()) {
 | ||
|             $id = get_params("id");
 | ||
|             $detail = Db::name('Project')->where('id', $id)->find();
 | ||
|             if (empty($detail)) {
 | ||
|                 return to_assign(1, "项目不存在");
 | ||
|             }
 | ||
|             Db::name('Project')->where('id', $id)->update(['status' => 2]);
 | ||
|             return to_assign(0, "开启成功");
 | ||
|         } else {
 | ||
|             return to_assign(1, "错误的请求方式");
 | ||
|         }
 | ||
|     }
 | ||
| 
 | ||
| } |