projectSelect) ->join('project_users', 'projects.id', '=', 'project_users.project_id') ->where('project_users.userid', $user->userid) ->orderByDesc('projects.id') ->paginate(Base::getPaginate(200, 100)); // return Base::retSuccess('success', $list); } /** * 项目详情 * * @apiParam {Number} project_id 项目ID */ public function detail() { $user = User::authE(); if (Base::isError($user)) { return $user; } else { $user = User::IDE($user['data']); } // $project_id = intval(Request::input('project_id')); // $project = Project::with(['projectColumn' => function($query) { $query->with(['projectTask' => function($taskQuery) { $taskQuery->with(['taskUser', 'taskTag'])->where('parent_id', 0); }]); }, 'projectUser']) ->select($this->projectSelect) ->join('project_users', 'projects.id', '=', 'project_users.project_id') ->where('projects.id', $project_id) ->where('project_users.userid', $user->userid) ->first(); if ($project) { $owner_user = $project->projectUser->where('owner', 1)->first(); $project->owner_userid = $owner_user ? $owner_user->userid : 0; } // return Base::retSuccess('success', $project); } /** * 添加项目 * * @apiParam {String} name 项目名称 * @apiParam {String} [desc] 项目描述 * @apiParam {Array} [columns] 流程,格式[流程1, 流程2] */ public function add() { $user = User::authE(); if (Base::isError($user)) { return $user; } else { $user = User::IDE($user['data']); } //项目名称 $name = trim(Request::input('name', '')); $desc = trim(Request::input('desc', '')); if (mb_strlen($name) < 2) { return Base::retError('项目名称不可以少于2个字'); } elseif (mb_strlen($name) > 32) { return Base::retError('项目名称最多只能设置32个字'); } if (mb_strlen($desc) > 255) { return Base::retError('项目描述最多只能设置255个字'); } //流程 $columns = Request::input('columns'); if (!is_array($columns)) $columns = []; $insertColumns = []; $inorder = 0; foreach ($columns AS $column) { $column = trim($column); if ($column) { $insertColumns[] = [ 'name' => $column, 'inorder' => $inorder++, ]; } } if (empty($insertColumns)) { $insertColumns[] = [ 'name' => 'Default', 'inorder' => 0, ]; } if (count($insertColumns) > 30) { return Base::retError('项目流程最多不能超过30个'); } //开始创建 $project = Project::createInstance([ 'name' => $name, 'desc' => $desc, 'userid' => $user->userid, ]); return AbstractModel::transaction(function() use ($insertColumns, $project) { $project->save(); ProjectUser::createInstance([ 'project_id' => $project->id, 'userid' => $project->userid, 'owner' => 1, ])->save(); ProjectLog::createInstance([ 'project_id' => $project->id, 'userid' => $project->userid, 'detail' => '创建项目', ])->save(); foreach ($insertColumns AS $column) { $column['project_id'] = $project->id; ProjectColumn::createInstance($column)->save(); } return Base::retSuccess('添加成功'); }); } /** * 修改项目 * * @apiParam {Number} project_id 项目ID * @apiParam {String} name 项目名称 * @apiParam {String} [desc] 项目描述 */ public function edit() { $user = User::authE(); if (Base::isError($user)) { return $user; } else { $user = User::IDE($user['data']); } // $project_id = intval(Request::input('project_id')); $name = trim(Request::input('name', '')); $desc = trim(Request::input('desc', '')); if (mb_strlen($name) < 2) { return Base::retError('项目名称不可以少于2个字'); } elseif (mb_strlen($name) > 32) { return Base::retError('项目名称最多只能设置32个字'); } if (mb_strlen($desc) > 255) { return Base::retError('项目描述最多只能设置255个字'); } // $project = Project::select($this->projectSelect) ->join('project_users', 'projects.id', '=', 'project_users.project_id') ->where('projects.id', $project_id) ->where('project_users.userid', $user->userid) ->first(); if (empty($project)) { return Base::retError('项目不存在或不在成员列表内'); } if (!$project->owner) { return Base::retError('你不是项目负责人'); } // $project->name = $name; $project->desc = $desc; $project->save(); // return Base::retSuccess('修改成功'); } /** * 移交项目 * * @apiParam {Number} project_id 项目ID * @apiParam {Number} owner_userid 新的项目负责人ID */ public function transfer() { $user = User::authE(); if (Base::isError($user)) { return $user; } else { $user = User::IDE($user['data']); } // $project_id = intval(Request::input('project_id')); $owner_userid = intval(Request::input('owner_userid')); // $project = Project::select($this->projectSelect) ->join('project_users', 'projects.id', '=', 'project_users.project_id') ->where('projects.id', $project_id) ->where('project_users.userid', $user->userid) ->first(); if (empty($project)) { return Base::retError('项目不存在或不在成员列表内'); } if (!$project->owner) { return Base::retError('你不是项目负责人'); } // if (!User::whereUserid($owner_userid)->exists()) { return Base::retError('会员不存在'); } // return AbstractModel::transaction(function() use ($owner_userid, $project) { ProjectUser::whereProjectId($project->id)->update(['owner' => 0]); ProjectUser::updateInsert([ 'project_id' => $project->id, 'userid' => $owner_userid, ], [ 'owner' => 1, ]); // return Base::retSuccess('移交成功'); }); } /** * 删除项目 * * @apiParam {Number} project_id 项目ID */ public function delete() { $user = User::authE(); if (Base::isError($user)) { return $user; } else { $user = User::IDE($user['data']); } // $project_id = intval(Request::input('project_id')); // $project = Project::select($this->projectSelect) ->join('project_users', 'projects.id', '=', 'project_users.project_id') ->where('projects.id', $project_id) ->where('project_users.userid', $user->userid) ->first(); if (empty($project)) { return Base::retError('项目不存在或不在成员列表内'); } if (!$project->owner) { return Base::retError('你不是项目负责人'); } // return AbstractModel::transaction(function() use ($project) { ProjectTask::whereProjectId($project->id)->delete(); $project->delete(); // return Base::retSuccess('删除成功'); }); } /** * {post}【任务】添加任务 * * @apiParam {Number} project_id 项目ID * @apiParam {Number} [column_id] 列表ID,留空取第一个 * @apiParam {String} name 任务描述 * @apiParam {String} [content] 任务详情 * @apiParam {Array} [times] 计划时间(格式:开始时间,结束时间;如:2020-01-01 00:00,2020-01-01 23:59) * @apiParam {Number} [owner] 负责人,留空为自己 * @apiParam {Array} [subtasks] 子任务(格式:[{name,owner,times}]) */ public function task__add() { $user = User::authE(); if (Base::isError($user)) { return $user; } else { $user = User::IDE($user['data']); } $project_id = Base::getPostInt('project_id'); $column_id = Base::getPostValue('column_id'); $name = Base::getPostValue('name'); $content = Base::getPostValue('content'); $times = Base::getPostValue('times'); $owner = Base::getPostValue('owner'); $subtasks = Base::getPostValue('subtasks'); $p_level = Base::getPostValue('p_level'); $p_name = Base::getPostValue('p_name'); $p_color = Base::getPostValue('p_color'); // 项目 $project = Project::select($this->projectSelect) ->join('project_users', 'projects.id', '=', 'project_users.project_id') ->where('projects.id', $project_id) ->where('project_users.userid', $user->userid) ->first(); if (empty($project)) { return Base::retError('项目不存在或不在成员列表内'); } // 列表 if (is_array($column_id)) { $column_id = Base::arrayFirst($column_id); } if (empty($column_id)) { $column = $project->projectColumn->first(); } elseif (intval($column_id) > 0) { $column = $project->projectColumn->where('id', $column_id)->first(); } else { $column = ProjectColumn::whereProjectId($project->id)->whereName($column_id)->first(); if (empty($column)) { $column = ProjectColumn::createInstance([ 'project_id' => $project->id, 'name' => $column_id, ]); $column->save(); } } if (empty($column)) { return Base::retError('任务列表不存在或已被删除'); } // return ProjectTask::addTask([ 'parent_id' => 0, 'project_id' => $project->id, 'column_id' => $column->id, 'name' => $name, 'content' => $content, 'times' => $times, 'owner' => $owner, 'subtasks' => $subtasks, 'p_level' => $p_level, 'p_name' => $p_name, 'p_color' => $p_color, ]); } }