Cate.php 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181
  1. <?php
  2. /**
  3. * Created by PhpStorm.
  4. * User: wugg
  5. * Date: 2024/6/28
  6. * Time: 16:03
  7. * description:分类控制器
  8. */
  9. namespace app\admin\controller;
  10. use app\admin\model\CatSpecs;
  11. use app\admin\model\Cat;
  12. use think\App;
  13. use think\facade\Validate;
  14. class Cate extends Base{
  15. public function __construct(App $app) {
  16. parent::__construct($app);
  17. $this->model = new Cat();
  18. }
  19. /**
  20. * @param pid=0,cat_name="",status="",page=1,size=10
  21. * 获取分类列表
  22. */
  23. public function list(){
  24. $param=$this->request->param(["pid"=>0,"cat_name"=>"","status"=>"","page"=>1,"size"=>10],"post","trim");
  25. $where=[["is_del","=",0]];
  26. if($param["pid"]!=="")$where[]=["pid","=",$param["pid"]];
  27. if($param["cat_name"]!=="")$where[]=["cat_name","like","%".$param["cat_name"]."%"];
  28. if($param["status"]!=="")$where[]=["status","=",$param["status"]];
  29. $data=$this->model->where($where)->order("id","desc")->paginate(['page'=>$param['page'],'list_rows'=>$param['size']])
  30. ->each(function($item){
  31. return $item["im"]=CatSpecs::with(["specs"])->where("cat_id",$item["id"])->field(["specs_id"])->select();
  32. });
  33. return success("获取成功",$data);
  34. }
  35. /**
  36. * @param cat_name 分类名称
  37. * @param pid 父级分类id
  38. * @param cat_desc 分类描述
  39. * @param fund_code 财务代码
  40. * @param specs_id 规格id
  41. * @param weight 权重
  42. * @param status 状态 0正常 1禁用
  43. * @return
  44. *
  45. */
  46. public function create(){
  47. $param=$this->request->param(['cat_name', 'pid', 'cat_desc' => '', 'fund_code' => '', 'specs_id'=>[], 'weight'
  48. => 0, 'status' => 0],"post","trim");
  49. $valid=Validate::rule([
  50. "cat_name|分类名称"=>"require|max:255|unique:app\admin\model\Cat,cat_name^is_del",
  51. "pid|父级分类"=>"require|integer|egt:0",
  52. "cat_desc|分类描述"=>"max:255",
  53. "fund_code|财务代码"=>"max:255",
  54. "specs_id|规格id"=>"require|array",
  55. "weight|权重"=>"integer",
  56. "status|状态"=>"integer|in:0,1",
  57. ]);
  58. if(!$valid->check($param))return error($valid->getError());
  59. if($param['pid']!=0){
  60. $parent = $this->model->where('id',$param['pid'])->findOrEmpty();
  61. if($parent->isEmpty())return error('父级分类不存在');
  62. }
  63. if($parent->isEmpty())return error("父级分类不存在");
  64. $this->model->startTrans();
  65. try{
  66. $create=[
  67. "cat_name"=>$param['cat_name'],
  68. "pid"=>$param["pid"],
  69. "cat_desc"=>$param["cat_desc"],
  70. "fund_code"=>$param["fund_code"],
  71. "weight"=>$param["weight"],
  72. "status"=>$param["status"],
  73. 'creater' => $this->uname,
  74. 'createrid' =>$this->uid,
  75. ];
  76. $data=$this->model->create($create);
  77. if($data->isEmpty())return error("添加失败");
  78. $spec=$data->specs()->saveAll($param["specs_id"]);
  79. if($spec->isEmpty())return error("添加失败");
  80. $this->model->commit();
  81. }catch (\Exception $e){
  82. $this->model->rollback();
  83. return error($e->getMessage());
  84. }
  85. event("PlatCat",["type"=>"add","data"=>$data]);
  86. return success("添加成功");
  87. }
  88. /**
  89. * @param id 分类id
  90. * @param cat_name 分类名称
  91. * @param pid 父级分类id
  92. * @param cat_desc 分类描述
  93. * @param fund_code 财务代码
  94. * @param specs_id 规格id
  95. * @param weight 权重
  96. * @param status 状态 0正常 1禁用
  97. * @return
  98. */
  99. public function save(){
  100. $param=$this->request->param(['id','cat_name', 'pid', 'cat_desc' => '', 'fund_code' => '', 'specs_id'=>[], 'weight'
  101. => 0, 'status' => 0],"post","trim");
  102. $valid=Validate::rule([
  103. "id|分类id"=>"require|integer|egt:1",
  104. "cat_name|分类名称"=>"require|max:255|unique:app\admin\model\Cat,cat_name^is_del",
  105. "pid|父级分类"=>"require|integer|egt:0",
  106. "cat_desc|分类描述"=>"max:255",
  107. "fund_code|财务代码"=>"max:255",
  108. "specs_id|规格id"=>"require|array",
  109. "weight|权重"=>"integer",
  110. "status|状态"=>"integer|in:0,1",
  111. ]);
  112. if(!$valid->check($param))return error($valid->getError());
  113. if($param['pid']!=0){
  114. $parent = $this->model->where("id",$param["pid"])->findOrEmpty();
  115. if($parent->isEmpty())return error("父级分类不存在");
  116. }
  117. $this->model->startTrans();
  118. try{
  119. $data=$this->model->with(["specs"])->findOrEmpty($param["id"]);
  120. if($data->isEmpty())return error("分类不存在");
  121. $data->cat_name=$param["cat_name"];
  122. $data->pid=$param["pid"];
  123. $data->cat_desc=$param["cat_desc"];
  124. $data->fund_code=$param["fund_code"];
  125. $data->weight=$param["weight"];
  126. $data->status=$param["status"];
  127. $save=$data->save();
  128. if(!$save)return error("修改失败");
  129. $add=array_diff($param["specs_id"],$data->specs->column("specs_id"));
  130. $delte=$data->specs()->whereNotIn("specs_id",$param["specs_id"])->save(["is_del"=>1]);
  131. if($delte===false)return error("删除失败");
  132. $spec=$data->specs()->saveAll($add);
  133. if($spec->isEmpty())return error("添加失败");
  134. $this->model->commit();
  135. }catch (\Exception $e){
  136. $this->model->rollback();
  137. return error($e->getMessage());
  138. }
  139. return success("修改成功");
  140. }
  141. /**
  142. * @param id 分类id
  143. * @return
  144. */
  145. public function delete(){
  146. $param=$this->request->param(["id"=>0],"post","trim");
  147. $valid=Validate::rule([
  148. "id|分类id"=>"require|integer|egt:1",
  149. ]);
  150. if(!$valid->check($param))return error($valid->getError());
  151. $data=$this->model->with(["specs"])->findOrEmpty($param["id"]);
  152. if($data->isEmpty())return error("分类不存在");
  153. $data->is_del=1;
  154. if(!$data->save())return error("删除失败");
  155. event("PlatCat",["type"=>"delete","data"=>$data]);
  156. return success("删除成功");
  157. }
  158. public function status(){
  159. $param=$this->request->param(["id"=>0,"status"=>0],"post","trim");
  160. $valid=Validate::rule([
  161. "id|分类id"=>"require|integer|egt:1",
  162. "status|状态"=>"require|integer|in:0,1",
  163. ]);
  164. if(!$valid->check($param))return error($valid->getError());
  165. $data=$this->model->findOrEmpty($param["id"]);
  166. if($data->isEmpty())return error("分类不存在");
  167. if($data->status==$param["status"])return error("状态未改变");
  168. if($param["status"]==1){
  169. $parent = $this->model->where("id",$data->pid)->findOrEmpty();
  170. if($parent->isEmpty())return error("父级分类不存在");
  171. if($parent->status!=1)return error("父级分类未启用");
  172. }
  173. $data->status=$param['status'];
  174. if(!$data->save())return error(Cat::$statusCn[$param['status']]. "失败");
  175. event("PlatCat",["type"=>"status","data"=>$data]);
  176. return success(Cat::$statusCn[$param['status']]."成功");
  177. }
  178. }