AreaExtend.php
3.1 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
<?php
namespace app\admin\controller;
use app\common\controller\Backend;
use think\Db;
/**
* 地区配送管理
*
* @icon fa fa-circle-o
*/
class AreaExtend extends Backend
{
/**
* AreaExtend模型对象
* @var \app\admin\model\AreaExtend
*/
protected $model = null;
protected $searchFields = 'province.name,city.name,county.name';
public function _initialize()
{
parent::_initialize();
$this->model = new \app\admin\model\AreaExtend;
$this->view->assign("isSpecialList", $this->model->getIsSpecialList());
}
/**
* 默认生成的控制器所继承的父类中有index/add/edit/del/multi五个基础方法、destroy/restore/recyclebin三个回收站方法
* 因此在当前控制器中可不用编写增删改查的代码,除非需要自己控制这部分逻辑
* 需要将application/admin/library/traits/Backend.php中对应的方法复制到当前控制器,然后进行修改
*/
/**
* 查看
*/
public function index()
{
//当前是否为关联查询
$this->relationSearch = true;
//设置过滤方法
$this->request->filter(['strip_tags', 'trim']);
if ($this->request->isAjax()) {
//如果发送的来源是Selectpage,则转发到Selectpage
if ($this->request->request('keyField')) {
return $this->selectpage();
}
$where1 = [];
if(!$this->request->param('level')){
$admin = session('admin');
$depotId = Db::name('auth_group_access')->alias('aga')
->join('fa_auth_group ag', 'aga.group_id=ag.id')
->where('aga.uid', $admin['id'])
->column('ag.depot_id');
foreach ($depotId as $k => $v){
if (strpos($v,',')) $depotId = explode(',',$v);
} $admin['depot_id'] = $depotId;
$areaIds = Db::name('depot')->where(['id'=>['in',$depotId]])->column('area_ids');
$areaIds = implode(',',$areaIds);
$where1['province_id'] = ['in',$areaIds];
}
list($where, $sort, $order, $offset, $limit) = $this->buildparams();
$total = $this->model
->with(['province', 'city', 'county'])
->where($where)
->where($where1)
->order($sort, $order)
->count();
$list = $this->model
->with(['province', 'city', 'county'])
->where($where)
->where($where1)
->order($sort, $order)
->limit($offset, $limit)
->select();
foreach ($list as $row) {
$row->getRelation('province')->visible(['name']);
$row->getRelation('city')->visible(['name']);
$row->getRelation('county')->visible(['name']);
}
$list = collection($list)->toArray();
$result = array("total" => $total, "rows" => $list);
return json($result);
}
return $this->view->fetch();
}
}