123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166 |
- <?php
- namespace app\controller;
- use app\BaseController;
- use app\model\LinkFolderModel;
- use app\model\LinkStoreModel;
- use think\facade\Db;
- class LinkStore extends BaseController
- {
- public function list(): \think\response\Json
- {
- $limit = $this->request->post('limit', 15);
- $name = $this->request->post('name', false);
- $area = $this->request->post('area', false);
- $sql = [];
- if ($name) {
- $sql[] = ['name|tips', 'like', "%" . $name . "%"];
- }
- $list = LinkStoreModel::where($sql);
- //area需要使用find_in_set来匹配
- if ($area && $area != 0) {
- $list = $list->whereRaw("find_in_set('$area',area)");
- }
- $list = $list->order("create_time", 'desc')->paginate($limit);
- return $this->success('ok', $list);
- }
- public function ListManager(): \think\response\Json
- {
- $admin = $this->getAdmin();
- $limit = $this->request->post('limit', 15);
- $name = $this->request->post('search.name', false);
- $area = $this->request->post('search.area', false);
- $sql = [];
- if ($name) {
- $sql[] = ['name|tips', 'like', '%' . $name . '%'];
- }
- $list = LinkStoreModel::where($sql);
- //area需要使用find_in_set来匹配
- if ($area && $area != '全部') {
- $list = $list->whereRaw("find_in_set('$area',area)");
- }
- $list = $list->order($this->request->post('sort.prop', 'id'), $this->request->post('sort.order', 'asc'))->paginate($limit);
- return $this->success('ok', $list);
- }
- function getFolder(): \think\response\Json
- {
- return $this->success("ok", LinkFolderModel::order("sort", "desc")->select());
- }
- private function update(): \think\response\Json
- {
- is_demo_mode(true);
- $admin = $this->getAdmin();
- $data = $this->request->post("form");
- $info = LinkStoreModel::where("id", $data['id'])->update($data);
- return $this->success('修改成功', $info);
- }
- public function add(): \think\response\Json
- {
- $admin = $this->getAdmin();
- is_demo_mode(true);
- $data = $this->request->post('form');
- if ($data) {
- if (isset($data['id']) && $data['id']) { //更新
- return $this->update();
- } else {
- $data['create_time'] = date("Y-m-d H:i:s");
- $info = (new \app\model\LinkStoreModel)->insert($data);
- return $this->success('添加成功', $info);
- }
- }
- return $this->error('缺少数据');
- }
- public function getIcon(): \think\response\Json
- {
- $url = $this->request->post('url', false);
- if ($url) {
- if (mb_substr($url, 0, 4) == 'tab:') {
- } else {
- if (mb_substr($url, 0, 4) != 'http') {
- $url = 'https://' . $url;
- }
- $url = parse_url($url);
- $url = $url['host'];
- }
- $data = LinkStoreModel::whereRaw("FIND_IN_SET('$url',domain)")->find();
- if ($data) {
- return $this->success('ok', $data);
- }
- }
- return $this->error('no', '未查询到相关信息');
- }
- function install_num(): \think\response\Json
- {
- $id = $this->request->post('id', false);
- //给标签+=1
- $res = Db::table("linkstore")->where('id', $id)->inc('install_num')->update();
- if ($res) {
- return $this->success('ok');
- }
- return $this->error('fail');
- }
- function createFolder(): \think\response\Json
- {
- is_demo_mode(true);
- $type = $this->request->post('type', false);
- $this->getAdmin();
- if ($type === 'edit') {
- $form = $this->request->post('info');
- $id = $this->request->post('info.id', false);
- if ($id && $id > 0) {
- $model = LinkFolderModel::find($id);
- $model->update($form);
- } else {
- $model = new LinkFolderModel();
- $model->insert($form);
- }
- } else if ($type === 'del') {
- $id = $this->request->post('id');
- $result = LinkFolderModel::where("id", $id)->find();
- if ($result) {
- $result->delete();
- Db::query(
- "UPDATE linkstore
- SET area = TRIM(BOTH ',' FROM REPLACE(CONCAT(',', area, ','), ',$id,', ','))
- WHERE FIND_IN_SET('$id', area) > 0;"
- );
- }
- }
- return $this->success('处理完毕!');
- }
- function moveFolder(): \think\response\Json
- {
- is_demo_mode(true);
- $this->getAdmin();
- $ids = $this->request->post('link', []);
- $area = $this->request->post('area', '');
- LinkStoreModel::where('id', 'in', $ids)->update(['area' => $area]);
- return $this->success('处理完毕!');
- }
- function sortFolder()
- {
- $sort = (array)$this->request->post();
- foreach ($sort as $key => $value) {
- LinkFolderModel::where("id", $value['id'])->update(['sort' => $value['sort']]);
- }
- return $this->success("ok");
- }
- public function del(): \think\response\Json
- {
- is_demo_mode(true);
- $this->getAdmin();
- $ids = $this->request->post('ids', []);
- LinkStoreModel::where("id", 'in', $ids)->delete();
- return $this->success('删除成功');
- }
- }
|