| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179 | <?php/** * Created by PhpStorm. * User: 中闽 < 1464674022@qq.com > * Date: 2019/12/5 * Time: 17:44 */namespace app\admin\controller;use app\admin\controller\base\Permissions;use app\common\model\ConfigOption as optionModel;use think\Db;use think\Log;class ConfigOption extends Permissions{    public function index()    {        $pid = $this->request->param('pid', 0, 'intval');        if ($this->request->isAjax()) {            $post = $this->request->param();            $where = [                'pid' => $pid,            ];            if (isset($post['keywords']) and !empty($post['keywords'])) {                $where['name'] = ['like', '%' . $post['keywords'] . '%'];            }            $model = new optionModel();            $count = $model->where($where)->count();            $data = $model->where($where)->page($post['page']??0, $post['limit']??15)->order('sort desc')->select();            foreach ($data as $k => $v) {                $v['cate_name'] = $v->config['name'];                $v['thumb_url'] = geturl($v['image']);                $v['group_type'] = $v->config['type'];                $data[$k] = $v;            }            return array('code' => 0, 'count' => $count, 'data' => $data);        } else {            $this->assign('config', \app\common\model\Config::get($pid));            return $this->fetch();        }    }    public function publish()    {        $id = $this->request->param('id', 0, 'intval');        $pid = $this->request->param('pid', 0, 'intval');        $this->assign('pid', $pid);        $model = new optionModel();        $post = $this->request->post();        if ($this->request->isPost()) {            $validate = new \think\Validate([                ['name', 'require', '标题不能为空'],                ['pid', 'require', '请选择分类'],            ]);            if (!$validate->check($post)) {                $this->error('提交失败:' . $validate->getError());            }        } else {            $this->assign('config', \app\common\model\Config::get($pid));        }        if ($id > 0) {            //是修改操作            $link = $model->where('id', $id)->find();            if (empty($link)) {                $this->error('id不正确');            }            if ($this->request->isPost()) {                if (false == $model->allowField(true)->save($post, ['id' => $id])) {                    $this->error('修改失败');                } else {                    $this->success('修改成功', 'index', ['pid' => $pid]);                }            } else {                $this->assign('link', $link);                return $this->fetch();            }        } else {            //是新增操作            if ($this->request->isPost()) {                if ($model->where('pid', $pid)->count() == 0) {                    $config = \app\common\model\Config::get($pid);                    if (!$config) {                        $this->error('pid异常');                    }                    if ($config->type == \app\common\model\Config::TYPE_RADIO) {                        $post['single_status'] = 1;                    }                }                if (false == $model->allowField(true)->save($post)) {                    $this->error('添加失败');                } else {                    $this->success('添加成功', 'index', ['pid' => $pid]);                }            } else {                return $this->fetch();            }        }    }    public function delete()    {        if ($this->request->isAjax()) {            $id = $this->request->param('id', 0, 'intval');            if (false == Db::name('config_option')->where('id', $id)->delete()) {                $this->error('删除失败');            } else {                $this->success('删除成功', 'index');            }        }    }    public function deletes()    {        if ($this->request->isAjax()) {            $post = $this->request->param();            $ids = $post['ids'];            $model = new optionModel();            if ($model->where('id', 'in', $ids)->delete()) {                Log::log("批量删除链接:" . implode(',', $ids));                $this->success('删除成功');            }        }    }    //排序    public function sort()    {        if ($this->request->isPost() && $this->request->has('ids')) {            $post = $this->request->post();            $i = 0;            foreach ($post['ids'] as $k => $id) {                $sort = Db::name('config_option')->where('id', $id)->value('sort');                $newsort = $post['sorts'][$k]??$sort;                if ($sort != $newsort) {                    if (false == Db::name('config_option')->where('id', $id)->update(['sort' => $newsort])) {                        $this->error('更新失败');                    } else {                        $i++;                    }                }            }            $this->success('成功更新' . $i . '个数据', 'index');        } else {            $this->error('无数据更新', 'index');        }    }    public function status()    {        if ($this->request->isPost()) {            $post = $this->request->post();            if (false == Db::name('config_option')->where('id', $post['id'])->update(['status' => $post['status']])) {                $this->error('设置失败');            } else {                $this->success('设置成功', 'index');            }        }    }    //单选状态    public function single_status()    {        if ($this->request->isPost()) {            $post = $this->request->post();            Db::name('config_option')->where('pid', $post['pid'])->update(['single_status' => 0]);            if (false == Db::name('config_option')->where('id', $post['id'])->update(['single_status' => $post['status']])) {                $this->error('设置失败');            } else {                $this->success('设置成功', 'index');            }        }    }}
 |