123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138 |
- <?php
- namespace app\admin\controller;
- use think\exception\ValidateException;
- use Overtrue\Pinyin\Pinyin;
- use app\model\Area;
- class AreaController extends Base
- {
- function index()
- {
- $keyword = input('post.keyword', '', 'serach_in');
- $parent_id = input('post.parent_id', '', 'serach_in');
- if (empty($parent_id)) {
- $parent_id = 0;
- }
- $query = Area::where('area_parent_id', $parent_id);
- if (!empty($keyword)) {
- $query->where('area_name|keyword', 'like', '%' . $keyword . '%');
- }
- $pages = getpage();
- $pages['list_rows'] = 50;
- $res = $query->order('area_sort asc,id asc')
- ->paginate($pages)
- ->toArray();
- $data['data'] = $res;
- return $this->json($data);
- }
- function listUpdate()
- {
- $data = only('id,area_sort');
- if (!$data['id']) throw new ValidateException('参数错误');
- Area::update($data);
- return $this->json(['msg' => '操作成功']);
- }
- public function update()
- {
- $id = $this->request->post('id');
- $data = input('post.');
- $data['area_parent_id'] = (int)$data['area_parent_id'];
- $pinyin = new Pinyin();
- $data['letter'] = strtoupper($pinyin->permalink($data['area_name'], '')[0]);
- $data['keyword'] = $data['area_name'] . strtoupper($pinyin->permalink($data['area_name'], ''));
- if (empty($id)) {
- try {
- $res = Area::create($data);
- if ($res->id && empty($data['area_sort'])) {
- Area::update(['area_sort' => $res->id, 'id' => $res->id]);
- }
- } catch (\Exception $e) {
- throw new ValidateException($e->getMessage());
- }
- return $this->json(['msg' => '添加成功', 'data' => $res->id]);
- } else {
- try {
- Area::update($data);
- } catch (\Exception $e) {
- throw new ValidateException($e->getMessage());
- }
- return $this->json(['msg' => '修改成功']);
- }
- }
- function getInfo()
- {
- $id = $this->request->post('id', '', 'serach_in');
- if (!$id) throw new ValidateException('参数错误');
- $res = Area::find($id);
- if ($res) {
- $res = $res->toArray();
- }
- return $this->json(['data' => $res]);
- }
- function delete()
- {
- return $this->del(new Area());
- }
- function getField()
- {
- $data['pids'] = _generateSelectTree(Area::getpcTree());
- return $this->json(['data' => $data]);
- }
- function getpcTree()
- {
- $data['data'] = Area::getpcTree();
- return $this->json($data);
- }
- public function geteltree()
- {
- $data = $this->eltree(0);
- return $this->json(['data' => $data]);
- }
- private function eltree($pid)
- {
- $field = 'id,area_name';
- $list = Area::field($field)
- ->where(['area_parent_id' => $pid])
- ->select()
- ->toArray();
- if ($list) {
- foreach ($list as $key => $val) {
- $datas[$key]['id'] = $val['id'];
- $datas[$key]['title'] = $val['area_name'];
- $sublist = Area::field($field)
- ->where(['area_parent_id' => $val['id']])
- ->select()
- ->toArray();
- if ($sublist) {
- $datas[$key]['children'] = $this->eltree($val['id']);
- }
- }
- if(is_array($datas)){
- $datas = array_values($datas);
- }
- return $datas;
- }
- }
- }
|