isPost()) { $params = input('post.item/a', []); $params = arrayHtmlFilter($params); $params['image'] = input('img'); try { validate(HonourValidate::class)->check($params); $newItem = MHonour::create($params); MLog::write('honour', 'add', '新增荣誉资质,ID:'.$newItem->id); } catch (ValidateException $e) { return $this->json(1, $e->getError()); } return $this->json(); } else { $categoryId = input('param.category_id/d', 0); $category = MCategory::getById($categoryId); if (count($category) > 0 && $category['img_width'] && $category['img_height']) { $imgSize = $category['img_width'].'像素 X '.$category['img_height'].'像素'; } else { $imgSize = System::getArticleImageSize(); } $this->data['imgSize'] = $imgSize; $this->data['category'] = $category; return $this->view(); } } /** * @return Json|View */ public function edit() { $id = input('param.id/d', 0); $item = MHonour::getById($id); if (count($item) == 0) { return $this->json(1, '该荣誉资质不存在'); } if (request()->isPost()) { $params = input('post.item/a', []); $params = arrayHtmlFilter($params); $params['image'] = input('img'); try { validate(HonourValidate::class)->check($params); MHonour::updateById($id, $params); MLog::write('honour', 'edit', '修改荣誉资质,ID:'.$id); } catch (ValidateException $e) { return $this->json(2, $e->getError()); } return $this->json(); } else { $category = MCategory::getById($item['category_id']); if (count($category) > 0 && $category['img_width'] && $category['img_height']) { $imgSize = $category['img_width'].'像素 X '.$category['img_height'].'像素'; } else { $imgSize = System::getArticleImageSize(); } $this->data['imgSize'] = $imgSize; $this->data['item'] = $item; return $this->view(); } } public function sort() { if (request()->isPost()) { $id = input('post.id/d'); $sort = input('post.sort'); $num = input('post.num/d', 1); if ($num <= 0) { $num = 1; } if (!in_array($sort, ['up', 'down'], true)) { return $this->json(2, '参数错误'); } $item = MHonour::getById($id); if (empty($item)) { return $this->json(3, '该荣誉资质不存在'); } if ($sort == 'up') { $where = "category_id='{$item['category_id']}' and sort < {$item['sort']}"; $order = "sort desc"; } else { $where = "category_id='{$item['category_id']}' and sort > {$item['sort']}"; $order = "sort asc"; } $forSortItems = MHonour::getListByWhereAndOrder($where, $order, $num); if (!empty($forSortItems)) { $updateData = []; $forSortCount = count($forSortItems); for ($i = 0; $i < $forSortCount; $i++) { if ($i == 0) { $updateData[] = [ 'id' => $forSortItems[$i]['id'], 'sort' => $item['sort'] ]; } else { $updateData[] = [ 'id' => $forSortItems[$i]['id'], 'sort' => $forSortItems[$i - 1]['sort'] ]; } } $updateData[] = [ 'id' => $item['id'], 'sort' => $forSortItems[$i - 1]['sort'] ]; if (!empty($updateData)) { $model = new MHonour(); $model->saveAll($updateData); $sortStr = $sort == 'up' ? '上移' : '下调'; MLog::write('history', 'sort', "荣誉资质排序,ID:{$id} ,{$sortStr}了{$num}位"); return $this->json(); } } return $this->json(4, '无须调整排序!'); } return $this->json(1, '无此操作'); } // 删除历程和历程相关的事例 public function del() { if (request()->isPost()) { $historyId = input('param.id/d', 0); $item = MHonour::getById($historyId); if (count($item) == 0) { return $this->json(2, '该荣誉资质不存在'); } try { MHonour::destroy($historyId); MLog::write('honour', 'del', '删除荣誉资质,ID:'.$historyId); } catch (\Exception $e) { return $this->json(3, '删除失败,'.$e->getMessage()); } return $this->json(); } return $this->json(1, '无此操作'); } }