You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
zhishifufei_php/application/admin/controller/download/DataDownloadCategpry.php

163 lines
5.4 KiB

11 months ago
<?php
// +----------------------------------------------------------------------
// | 天诚科技 [ 刘海东 17600099397赋能开发者,助力企业发展 ]
// +----------------------------------------------------------------------
// | Copyright (c) 2016~2020 https://www.tczxkj.com All rights reserved.
// +----------------------------------------------------------------------
// | Licensed 该系统并不是自由软件,未经许可不能去掉相关版权
// +----------------------------------------------------------------------
// | Author:甘肃天诚志信电子商务有限公司 刘海东 联系电话维系17600099397
// +----------------------------------------------------------------------
namespace app\admin\controller\download;
use app\admin\controller\AuthController;
use app\admin\model\download\DataDownloadCategpry as DataCategpryModel;
use service\JsonService as Json;
use app\admin\model\download\DataDownload;
/**
* 资料分类控制器
* Class DataDownloadCategpry
* @package app\admin\controller\download
*/
class DataDownloadCategpry extends AuthController
{
public function index()
{
return $this->fetch();
}
public function get_download_cate_list()
{
$where = parent::getMore([
['page', 1],
['limit', 20],
['pid', $this->request->param('pid', '')],
['title', '']
]);
return Json::successful(DataCategpryModel::get_download_cate_list($where));
}
/**
* 创建分类
* @param int $id
* @return mixed
* @throws \think\exception\DbException
*/
public function create($id = 0)
{
$cate = $id > 0 ? DataCategpryModel::get($id) : [];
$this->assign(['cate' => json_encode($cate), 'id' => $id]);
return $this->fetch();
}
/**获取一级分类
* @param int $sid
* @throws \think\db\exception\DataNotFoundException
* @throws \think\db\exception\ModelNotFoundException
* @throws \think\exception\DbException
*/
public function get_cate_list()
{
$cate = DataCategpryModel::specialCategoryAll(1);
$array = [];
$oneCate['id'] = 0;
$oneCate['title'] = '顶级分类';
array_push($array, $oneCate);
foreach ($cate as $key => $value) {
array_push($array, $value);
}
return Json::successful($array);
}
/**
* 新增或者修改
*
* @return json
*/
public function save($id = 0)
{
$post = parent::postMore([
['title', ''],
['pid', 0],
['sort', 0],
['is_show', 0],
]);
if (!$post['title']) return Json::fail('请输入分类名称');
if ($id) {
$cate = DataCategpryModel::get($id);
if (!$cate['pid'] && $post['pid'] && DataCategpryModel::be(['pid' => $id, 'is_del' => 0])) return Json::fail('无法移动有下级的分类');
if (DataCategpryModel::where(['title' => $post['title'], 'is_del' => 0])->where('id', '<>', $id)->count() >= 1) return Json::fail('分类名称已存在');
$res = DataCategpryModel::edit($post, $id);
if ($res)
return Json::successful('修改成功');
else
return Json::fail('修改失败');
} else {
$post['add_time'] = time();
if (DataCategpryModel::be(['title' => $post['title'], 'is_del' => 0])) {
return Json::fail('分类名称已存在!');
}
$res = DataCategpryModel::set($post);
if ($res)
return Json::successful('添加成功');
else
return Json::fail('添加失败');
}
}
/**
* 快速编辑
*
* @return json
*/
public function set_value($field = '', $id = '', $value = '')
{
($field == '' || $id == '' || $value == '') && Json::fail('缺少参数');
$res = DataCategpryModel::where(['id' => $id])->update([$field => $value]);
if ($res)
return Json::successful('保存成功');
else
return Json::fail('保存失败');
}
/**二级分是否显示快捷操作
* @param string $is_show
* @param string $id
* @return mixed
*/
public function set_show($is_show = '', $id = '')
{
($is_show == '' || $id == '') && Json::fail('缺少参数');
$res = DataCategpryModel::where(['id' => $id])->update(['is_show' => (int)$is_show]);
if ($res) {
return Json::successful($is_show == 1 ? '显示成功' : '隐藏成功');
} else {
return Json::fail($is_show == 1 ? '显示失败' : '隐藏失败');
}
}
/**
* 删除
*
* @return json
*/
public function delete($id = 0)
{
if (!$id) return Json::fail('缺少参数');
$cate = DataCategpryModel::get($id);
if ($cate['pid']) {
if (DataDownload::PreWhere()->where('cate_id', $id)->count()) return Json::fail('暂无法删除,请先去除资料关联');
} else {
if (DataCategpryModel::where('pid', $id)->where('is_del', 0)->count()) return Json::fail('暂无法删除,请删除下级分类');
}
$data['is_del'] = 1;
$res = DataCategpryModel::edit($data, $id);
if ($res)
return Json::successful('删除成功');
else
return Json::fail('删除成功');
}
}