Asklist.php 3.7 KB
<?php

namespace app\admin\controller\river;

use app\common\controller\Backend;
use think\Db;

/**
 * 问题台账管理
 *
 * @icon fa fa-circle-o
 */
class Asklist extends Backend
{

    /**
     * Asklist模型对象
     * @var \app\admin\model\river\Asklist
     */
    protected $model = null;

    public function _initialize()
    {
        parent::_initialize();
        $this->model = new \app\admin\model\river\Asklist;

    }

    public function import()
    {
        parent::import();
    }


    /**
     * 查看
     */
    public function index()
    {
        //当前是否为关联查询
        $this->relationSearch = false;
        //设置过滤方法
        $this->request->filter(['strip_tags', 'trim']);

        if ($this->request->isAjax()) {
            $ids = $this->request->param("ids", 0);
            //如果发送的来源是Selectpage,则转发到Selectpage
            if ($this->request->request('keyField')) {
                return $this->selectpage();
            }
            list($where, $sort, $order, $offset, $limit) = $this->buildparams();

            $list = $this->model
                ->with(['riveraskcat', 'inspectionstaff'])
                ->where($where)
                ->where(['river_pid' => $ids])
                ->order($sort, $order)
                ->paginate($limit);

            foreach ($list as $row) {
                $row->visible(['id', 'title', 'image', 'vdourl', 'river_id','river_pid','cat_id', 'createtime','status','status_msg','add_username','user_id','address','lat','lng','ask_com','catname','river_name']);
                $row->visible(['riveraskcat', 'inspectionstaff']);
                $row->getRelation('riveraskcat');
                $row->getRelation('inspectionstaff');
            }
            $rows = $list->items();
            foreach ($rows as $kk => $vv) {
                if ($vv['status'] == 0) {
                    $stu = '未处理';
                }
                if ($vv['status'] == 1) {
                    $stu = '转办';
                }
                if ($vv['status'] == 2) {
                    $stu = '受理';
                }
                if ($vv['status'] == 3) {
                    $stu = '完成';
                }
                $rows[$kk]['status_msg'] = $stu;
                //关联上报人信息
                //河长上报
                if ($vv['ask_com'] == '0') {
                    $staffinfo = Db::name('inspection_staff')
                        ->where(['user_id' => $vv['user_id']])
                        ->find();
                    $rows[$kk]['add_username'] = $staffinfo['staff_name'];
                }
                //用户上报
                if ($vv['ask_com'] == '1') {
                    $staffinfo = Db::name('user')
                        ->where(['id' => $vv['user_id']])
                        ->find();
                    $rows[$kk]['add_username'] = $staffinfo['nickname'];
                }
                //问题分类信息
                $catinfo = Db::name('river_ask_cat')
                    ->where(['id' => $vv['cat_id']])
                    ->find();
                $rows[$kk]['catname'] = $catinfo['catname'];
                //河段信息
                $river = DB::name('river_list')
                    ->where(['id' => $vv['river_id']])
                    ->field('id,name')
                    ->find();
                $rows[$kk]['river_name'] = $river['name'];

            }

            $result = array("total" => $list->total(), "rows" => $rows);

            return json($result);
        }
        $ids = $this->request->param("ids", 0);
        $this->assign('ids', $ids);
        return $this->view->fetch();
    }

}