// +---------------------------------------------------------------------- declare (strict_types=1); namespace app\admin\controller; use think\response\Json; use app\store\model\Category as CategoryModel; use think\facade\Db; /** * 商品分类 * Class Category * @package app\store\controller\goods */ class Category extends Controller { /** * 商品分类列表 * @return Json * @throws \think\db\exception\DataNotFoundException * @throws \think\db\exception\DbException * @throws \think\db\exception\ModelNotFoundException */ public function list(): Json { $model = new CategoryModel; $list = $model->getList(['store_id' =>0]); return $this->renderSuccess(compact('list')); } /** * 删除商品分类 * @param int $categoryId * @return Json */ public function delete(int $categoryId): Json { // 分类详情 $model = CategoryModel::detail($categoryId); if (!$model->remove()) { return $this->renderError($model->getError() ?: '删除失败'); } return $this->renderSuccess('删除成功'); } /** * 添加商品分类 * @return Json */ public function add(): Json { // 新增记录 $model = new CategoryModel; $params = $this->postForm(); $params['store_id'] = 0; if ($model->add($params)) { return $this->renderSuccess('添加成功'); } return $this->renderError($model->getError() ?: '添加失败'); } /** * 编辑商品分类 * @param int $categoryId * @return Json * @throws \think\db\exception\DataNotFoundException * @throws \think\db\exception\DbException * @throws \think\db\exception\ModelNotFoundException */ public function edit(int $categoryId): Json { // 分类详情 $model = CategoryModel::detail($categoryId, ['image']); // 更新记录 if ($model->edit($this->postForm())) { return $this->renderSuccess('更新成功'); } return $this->renderError($model->getError() ?: '更新失败'); } public function copyCategory(int $new_store_id){ $store_id = 0; $model = new CategoryModel; $list = $model->getList(['store_id' =>$store_id]); if (!$list) { return; } foreach ($list as $value) { $value = $value->toArray(); $value['store_id'] = $new_store_id; $value['create_time'] = time(); $value['update_time'] = time(); $temp = $value; unset($temp['children']); unset($temp['image']); unset($temp['category_id']); $firstid = Db::table('yoshop_category')->insertGetId($temp); if (!isset($value['children']) || !$value['children']) { continue; } foreach ($value['children'] as $value1) { $value1 = $value1->toArray(); $value1['parent_id'] = $firstid; $value1['store_id'] = $new_store_id; $value1['create_time'] = time(); $value1['update_time'] = time(); $temp1 = $value1; unset($temp1['children']); unset($temp1['image']); unset($temp1['category_id']); $secondid = Db::table('yoshop_category')->insertGetId($temp1); if (!isset($value1['children']) || !$value1['children']) { continue; } foreach ($value1['children'] as $value2) { $value2 = $value2->toArray(); $value2['parent_id'] = $secondid; $value2['store_id'] = $new_store_id; $value2['create_time'] = time(); $value2['update_time'] = time(); $temp2 = $value2; unset($temp2['children']); unset($temp2['image']); unset($temp2['category_id']); Db::table('yoshop_category')->insertGetId($temp2); } } } return $this->renderSuccess($list); } }