'未设置', self::ONE => '低', self::TWO => '中', self::THREE => '高', self::FOUR => '紧急', ]; public static $FlowStatus = [ self::ZERO => '未设置', self::ONE => '未开始', self::TWO => '进行中', self::THREE => '已完成', self::FOUR => '已拒绝', self::FIVE => '已关闭', self::SIX => '未解决', ]; //列表 function list($param) { $where = array(); $map1 = []; $map2 = []; $map3 = []; $map4 = []; if (!empty($param['project_id'])) { $where[] = ['project_id', '=', $param['project_id']]; } else { $project_ids = Db::name('ProjectUser')->where(['uid' => $param['uid'], 'delete_time' => 0])->column('project_id'); $map1[] = ['admin_id', '=', $param['uid']]; $map2[] = ['director_uid', '=', $param['uid']]; $map3[] = ['', 'exp', Db::raw("FIND_IN_SET({$param['uid']},assist_admin_ids)")]; $map4[] = ['project_id', 'in', $project_ids]; } if (!empty($param['admin_id'])) { $where[] = ['admin_id', '=', $param['admin_id']]; } if (!empty($param['type'])) { $where[] = ['type', '=', $param['type']]; } if (!empty($param['flow_status'])) { $where[] = ['flow_status', '=', $param['flow_status']]; } if (!empty($param['priority'])) { $where[] = ['priority', '=', $param['priority']]; } if (!empty($param['cate'])) { $where[] = ['cate', '=', $param['cate']]; } if (!empty($param['is_new'])) { $where[] = ['is_new', '=', $param['is_new']]; } if (!empty($param['is_bug'])) { $where[] = ['is_bug', '=', $param['is_new']]; } if (!empty($param['director_uid'])) { $where[] = ['director_uid', 'in', $param['director_uid']]; } if (!empty($param['keywords'])) { $where[] = ['title|content', 'like', '%' . $param['keywords'] . '%']; } $where[] = ['delete_time', '=', 0]; $rows = empty($param['limit']) ? get_config('app.page_size') : $param['limit']; $list = Db::name('Task')->where(function ($query) use ($map1, $map2, $map3, $map4) { $query->where($map1)->whereor($map2)->whereor($map3)->whereor($map4); })->where($where) ->withoutField('content,md_content') ->orderRaw("FIELD(flow_status, 6, 1, 2, 4, 5, 3)") ->order('id', 'desc') ->paginate($rows, false, ['query' => $param]) ->each(function ($item, $key) { $item['director_name'] = Db::name('Admin')->where(['id' => $item['director_uid']])->value('name'); $item['creater_name'] = Db::name('Admin')->where(['id' => $item['admin_id']])->value('name'); $item['creater_id'] = Db::name('Admin')->where(['id' => $item['admin_id']])->value('id'); $assist_admin_names = Db::name('Admin')->where([['id', 'in', $item['assist_admin_ids']]])->column('name'); $item['cate_name'] = Db::name('WorkCate')->where(['id' => $item['cate']])->value('title'); $item['type_name'] = Db::name('TaskCate')->where(['id' => $item['type']])->value('title'); $tid = $item['id']; //tid的值等于当前任务的id $is_new = Db::name('Schedule')->where('tid', $tid)->column('is_new'); // 判断is_new数组中是否存在1 if (in_array(1, $is_new)) { $item['is_new'] = 1; } else { $item['is_new'] = 0; } //$item['belong_project'] = Db::name('Project')->where(['id' => $v['project_id']])->value('name_short'); $item['belong_project'] = Db::name('Project')->where(['id' => $item['project_id']])->order('id desc')->value('name_short'); if (empty($assist_admin_names)) { $item['assist_admin_names'] = '-'; } else { $item['assist_admin_names'] = implode(',', $assist_admin_names); } $item['end_time'] = date('Y-m-d', $item['end_time']); $item['delay'] = 0; if ($item['over_time'] > 0 && $item['flow_status'] < 4) { $item['delay'] = countDays($item['end_time'], date('Y-m-d', $item['over_time'])); } if ($item['over_time'] == 0 && $item['flow_status'] < 4) { $item['delay'] = countDays($item['end_time']); } $item['priority_name'] = self::$Priority[(int) $item['priority']]; $item['flow_name'] = self::$FlowStatus[(int) $item['flow_status']]; return $item; }); return $list; } //详情 public function detail($id) { $detail = Db::name('Task')->where(['id' => $id])->find(); if (!empty($detail)) { $detail['product_name'] = ''; $detail['project_name'] = ''; if ($detail['project_id'] > 0) { $project = Db::name('Project')->where(['id' => $detail['project_id']])->field('product_id,name')->find(); $detail['product_name'] = Db::name('Product')->where(['id' => $project['product_id']])->value('name'); $detail['project_name'] = $project['name']; } $detail['admin_name'] = Db::name('Admin')->where(['id' => $detail['admin_id']])->value('name'); //将admin_id转换为name $detail['creater_name'] = Db::name('Admin')->where(['id' => $detail['id']])->value('name'); $detail['creater_id'] = Db::name('Admin')->where(['id' => $detail['id']])->value('id'); $detail['director_name'] = Db::name('Admin')->where(['id' => $detail['director_uid']])->value('name'); $detail['work_hours'] = Db::name('Schedule')->where(['delete_time' => 0, 'tid' => $detail['id']])->sum('labor_time'); $detail['cate_name'] = Db::name('WorkCate')->where(['id' => $detail['cate']])->value('title'); $detail['type_name'] = Db::name('TaskCate')->where(['id' => $detail['type']])->value('title'); $detail['logs'] = Db::name('Log')->where(['module' => 'task', 'task_id' => $detail['id']])->count(); $detail['comments'] = Db::name('Comment')->where(['module' => 4, 'delete_time' => 0, 'topic_id' => $detail['id']])->count(); $detail['assist_admin_names'] = ''; if (!empty($detail['assist_admin_ids'])) { $assist_admin_names = Db::name('Admin')->where('id', 'in', $detail['assist_admin_ids'])->column('name'); $detail['assist_admin_names'] = implode(',', $assist_admin_names); } $detail['priority_name'] = self::$Priority[(int) $detail['priority']]; //$detail['belong_project'] = Db::name('Project')->where(['id' => $v['project_id']])->value('name_short'); $detail['flow_name'] = self::$FlowStatus[(int) $detail['flow_status']]; $detail['times'] = time_trans($detail['create_time']); $detail['end_time'] = date('Y-m-d', $detail['end_time']); $detail['delay'] = 0; if ($detail['over_time'] > 0 && $detail['flow_status'] < 4) { $detail['delay'] = countDays($detail['end_time'], date('Y-m-d', $detail['over_time'])); } if ($detail['over_time'] == 0 && $detail['flow_status'] < 4) { $detail['delay'] = countDays($detail['end_time']); } } return $detail; } }