+----------------------------------------------------------------------------------------------- */ declare (strict_types = 1); namespace app\home\controller; use app\api\BaseController; use think\facade\Db; class api extends BaseController { //首页公告 public function get_note_list() { $list = Db::name('Note') ->field('a.id,a.title,a.create_time,c.title as cate_title') ->alias('a') ->join('note_cate c', 'a.cate_id = c.id') ->where(['a.status' => 1,'a.delete_time' => 0]) ->order('a.end_time desc,a.sort desc,a.create_time desc') ->limit(8) ->select()->toArray(); foreach ($list as $key => $val) { $list[$key]['create_time'] = date('Y-m-d H:i', $val['create_time']); } $res['data'] = $list; return table_assign(0, '', $res); } //首页知识列表 public function get_article_list() { $prefix = get_config('database.connections.mysql.prefix');//判断是否安装了文章模块 $exist = Db::query('show tables like "'.$prefix.'article"'); $res['data'] = []; if($exist){ $list = Db::name('Article') ->field('a.id,a.title,a.create_time,a.read,c.title as cate_title') ->alias('a') ->join('article_cate c', 'a.cate_id = c.id') ->where(['a.delete_time' => 0]) ->order('a.id desc') ->limit(8) ->select()->toArray(); foreach ($list as $key => $val) { $list[$key]['create_time'] = date('Y-m-d H:i', $val['create_time']); } $res['data'] = $list; } return table_assign(0, '', $res); } //获取访问记录 public function get_view_data() { $param = get_params(); $first_time = time(); $second_time = $first_time - 86400; $three_time = $first_time - 86400 * 365; $begin_first = strtotime(date('Y-m-d', $first_time) . " 00:00:00"); $end_first = strtotime(date('Y-m-d', $first_time) . " 23:59:59"); $begin_second = strtotime(date('Y-m-d', $second_time) . " 00:00:00"); $end_second = strtotime(date('Y-m-d', $second_time) . " 23:59:59"); $begin_three = strtotime(date('Y-m-d', $three_time) . " 00:00:00"); $data_first = Db::name('AdminLog')->field('create_time')->whereBetween('create_time', "$begin_first,$end_first")->select(); $data_second = Db::name('AdminLog')->field('create_time')->whereBetween('create_time', "$begin_second,$end_second")->select(); $data_three = Db::name('AdminLog')->field('create_time')->whereBetween('create_time', "$begin_three,$end_first")->select(); return to_assign(0, '', ['data_first' => hour_document($data_first), 'data_second' => hour_document($data_second), 'data_three' => $data_three]); } //获取员工活跃数据 public function get_view_log() { $times = strtotime("-30 day"); $where = []; $where[] = ['uid','<>',1]; $where[] = ['create_time', '>', $times]; $list = Db::name('AdminLog')->field("id,uid")->where($where)->select(); $logs = array(); foreach ($list as $key => $value) { $uid = $value['uid']; if (empty($logs[$uid])) { $logs[$uid]['count'] = 1; $logs[$uid]['name'] = Db::name('Admin')->where('id',$uid)->value('name'); } else { $logs[$uid]['count'] += 1; } } $counts = array_column($logs, 'count'); array_multisort($counts, SORT_DESC, $logs); //攫取前10 $data_logs = array_slice($logs, 0, 10); return to_assign(0, '', ['data_logs' => $data_logs]); } public function areaJson($type) { if($type=='province'){ $data = Db::name('Area')->where(['level'=>1,'status'=>1])->column('name', 'id'); } if($type=='city'){ $data = Db::name('Area')->where(['level'=>2,'status'=>1])->column('name', 'id'); } if($type=='district'){ $data = Db::name('Area')->where(['level'=>3,'status'=>1])->column('name', 'id'); } // 导出为 JSON 格式 $json = json_encode($data, JSON_UNESCAPED_UNICODE | JSON_PRETTY_PRINT); return $json; /* 输出Json文件 // 设置响应头 header('Content-Type: application/json'); header('Content-Disposition: attachment; filename="oa_area.json"'); // 输出 JSON 数据 echo $json; */ } }