// +---------------------------------------------------------------------- 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 = 10001; $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(); $value['image_id'] = $value['image_id'] ? $this->copyImage($value['image_id'], $new_store_id) : 0; $value['rank_image_id'] = $value['rank_image_id'] ? $this->copyImage($value['rank_image_id'], $new_store_id) : 0; $temp = $value; unset($temp['children']); unset($temp['image']); unset($temp['rankimage']); 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(); $value1['image_id'] = $value1['image_id'] ? $this->copyImage($value1['image_id'], $new_store_id) : 0; $value1['rank_image_id'] = $value1['rank_image_id'] ? $this->copyImage($value1['rank_image_id'], $new_store_id) : 0; $temp1 = $value1; unset($temp1['children']); unset($temp1['image']); unset($temp1['rankimage']); 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(); $value2['image_id'] = $value2['image_id'] ? $this->copyImage($value2['image_id'], $new_store_id) : 0; $value2['rank_image_id'] = $value2['rank_image_id'] ? $this->copyImage($value2['rank_image_id'], $new_store_id) : 0; $temp2 = $value2; unset($temp2['children']); unset($temp2['image']); unset($temp2['rankimage']); unset($temp2['category_id']); Db::table('yoshop_category')->insertGetId($temp2); if (!isset($value2['children']) || !$value2['children']) { continue; } foreach ($value2['children'] as $value3) { $value3 = $value3->toArray(); $value3['parent_id'] = $secondid; $value3['store_id'] = $new_store_id; $value3['create_time'] = time(); $value3['update_time'] = time(); $value3['image_id'] = $value3['image_id'] ? $this->copyImage($value3['image_id'], $new_store_id) : 0; $value3['rank_image_id'] = $value3['rank_image_id'] ? $this->copyImage($value3['rank_image_id'], $new_store_id) : 0; $temp3 = $value3; unset($temp3['children']); unset($temp3['image']); unset($temp3['rankimage']); unset($temp3['category_id']); Db::table('yoshop_category')->insertGetId($temp3); } } } } return $this->renderSuccess($list); } public function copyImage($image_id, $store_id){ $upload_file = DB::table("yoshop_upload_file")->where('file_id', $image_id)->find(); if (!$upload_file) { return 0; } $upload_file['store_id'] = $store_id; $upload_file['create_time'] = time(); unset($upload_file['file_id']); $new_image_id = DB::table("yoshop_upload_file")->insertGetId($upload_file); return $new_image_id; } }