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/special/Subject.php

166 lines
5.5 KiB

11 months ago
<?php
// +----------------------------------------------------------------------
// | 天诚科技 [ 刘海东 17600099397赋能开发者,助力企业发展 ]
// +----------------------------------------------------------------------
// | Copyright (c) 2016~2020 https://www.tczxkj.com All rights reserved.
// +----------------------------------------------------------------------
// | Licensed 该系统并不是自由软件,未经许可不能去掉相关版权
// +----------------------------------------------------------------------
// | Author:甘肃天诚志信电子商务有限公司 刘海东 联系电话维系17600099397
// +----------------------------------------------------------------------
namespace app\admin\controller\special;
use app\admin\model\special\SpecialSubject;
use app\admin\model\special\Special;
use think\Url;
use service\FormBuilder as Form;
use service\JsonService as Json;
use app\admin\controller\AuthController;
/**
* 课程分类控制器
* Class Subject
* @package app\admin\controller\special
*/
class Subject extends AuthController
{
public function index()
{
return $this->fetch();
}
public function get_subject_list()
{
$where = parent::getMore([
['page', 1],
['limit', 20],
['pid', $this->request->param('pid', '')],
['name', ''],
]);
return Json::successful(SpecialSubject::get_subject_list($where));
}
/**
* 创建分类
* @param int $id
* @return mixed
* @throws \think\exception\DbException
*/
public function create($id = 0)
{
$cate = $id > 0 ? SpecialSubject::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 = SpecialSubject::specialCategoryAll(1);
$array = [];
$oneCate['id'] = 0;
$oneCate['name'] = '顶级分类';
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([
['name', ''],
['pic', ''],
['grade_id', 0],
['sort', 0],
['is_show', 0],
]);
if (!$post['name']) return Json::fail('请输入分类名称');
if ($post['grade_id'] && !$post['pic']) return Json::fail('请选择分类图标');
if ($id) {
$cate = SpecialSubject::get($id);
if (!$cate['grade_id'] && $post['grade_id'] && SpecialSubject::be(['grade_id' => $id, 'is_del' => 0])) return Json::fail('无法移动有下级的分类');
if (SpecialSubject::where(['name' => $post['name'], 'is_del' => 0])->where('id', '<>', $id)->count() >= 1) return Json::fail('分类名称已存在');
$res = SpecialSubject::edit($post, $id);
if ($res)
return Json::successful('修改成功');
else
return Json::fail('修改失败');
} else {
$post['add_time'] = time();
if (SpecialSubject::be(['name' => $post['name'], 'is_del' => 0])) {
return Json::fail('分类名称已存在!');
}
$res = SpecialSubject::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 = parent::getDataModification('subject', $id, $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 = parent::getDataModification('subject', $id, '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('缺少参数');
$subject = SpecialSubject::get($id);
if ($subject['grade_id']) {
if (Special::where('subject_id', $id)->where('is_del', 0)->count()) return Json::fail('暂无法删除,请先去除专题关联');
} else {
if (SpecialSubject::where('grade_id', $id)->where('is_del', 0)->count()) return Json::fail('暂无法删除,请删除下级分类');
}
$res = parent::getDataModification('subject', $id, 'is_del', 1);
if ($res)
return Json::successful('删除成功');
else
return Json::fail('删除成功');
}
}