From 5ce77f5db9439fb12dde261363c3cbaf4fdebb1e Mon Sep 17 00:00:00 2001 From: yuxc <653031404@qq.com> Date: 星期二, 11 四月 2023 19:24:16 +0800 Subject: [PATCH] 主题库相关的代码实现功能 --- Source/UBCS/ubcs-service/ubcs-code/src/main/java/com/vci/ubcs/code/controller/CodeClassifyController.java | 230 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 230 insertions(+), 0 deletions(-) diff --git a/Source/UBCS/ubcs-service/ubcs-code/src/main/java/com/vci/ubcs/code/controller/CodeClassifyController.java b/Source/UBCS/ubcs-service/ubcs-code/src/main/java/com/vci/ubcs/code/controller/CodeClassifyController.java new file mode 100644 index 0000000..add68b8 --- /dev/null +++ b/Source/UBCS/ubcs-service/ubcs-code/src/main/java/com/vci/ubcs/code/controller/CodeClassifyController.java @@ -0,0 +1,230 @@ +/* + * Copyright (c) 2018-2028, Chill Zhuang All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions are met: + * + * Redistributions of source code must retain the above copyright notice, + * this list of conditions and the following disclaimer. + * Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * Neither the name of the dreamlu.net developer nor the names of its + * contributors may be used to endorse or promote products derived from + * this software without specific prior written permission. + * Author: Chill 搴勯獮 (smallchill@163.com) + */ +package com.vci.ubcs.code.controller; + +import com.baomidou.mybatisplus.core.metadata.IPage; +import com.baomidou.mybatisplus.extension.toolkit.SqlHelper; +import com.vci.ubcs.code.entity.CodeClassify; +import com.vci.ubcs.code.mapper.CodeClassifyMapper; +import com.vci.ubcs.code.vo.pagemodel.CodeClassifyVO; +import com.vci.ubcs.code.vo.pagemodel.TreeQueryObject; +import com.vci.ubcs.com.vci.starter.web.pagemodel.Tree; +import com.vci.ubcs.com.vci.starter.web.util.VciBaseUtil; +import io.swagger.annotations.Api; +import io.swagger.annotations.ApiOperation; +import io.swagger.annotations.ApiParam; +import com.github.xiaoymin.knife4j.annotations.ApiOperationSupport; +import lombok.AllArgsConstructor; + +import javax.servlet.http.HttpServletResponse; +import javax.validation.Valid; + +import org.springblade.core.mp.support.Condition; +import org.springblade.core.mp.support.Query; +import org.springblade.core.secure.utils.AuthUtil; +import org.springblade.core.tool.api.IResultCode; +import org.springblade.core.tool.api.R; +import org.springblade.core.tool.utils.Func; +import org.springframework.web.bind.annotation.*; +import com.vci.ubcs.code.wrapper.CodeClassifyWrapper; +import com.vci.ubcs.code.service.ICodeClassifyService; +import org.springblade.core.boot.ctrl.BladeController; + +import java.io.File; +import java.io.IOException; +import java.util.Collection; +import java.util.Date; +import java.util.List; + +import static com.vci.ubcs.code.constant.FrameWorkDefaultValueConstant.FRAMEWORK_DATA_DISABLED; +import static com.vci.ubcs.code.constant.FrameWorkDefaultValueConstant.FRAMEWORK_DATA_ENABLED; + +/** + * 涓婚搴撳畾涔夎〃 鎺у埗鍣� + * + * @author yuxc + * @since 2023-04-06 + */ +@RestController +@AllArgsConstructor +@RequestMapping("ubcs-code/codeClassify") +@Api(value = "涓婚搴撳畾涔夎〃", tags = "涓婚搴撳畾涔夎〃鎺ュ彛") +public class CodeClassifyController extends BladeController { + + private final ICodeClassifyService codeClassifyService; + + CodeClassifyMapper codeClassifyMapper; + /** + * 涓婚搴撳畾涔夎〃 璇︽儏 + */ + @GetMapping("/detail") + @ApiOperationSupport(order = 1) + @ApiOperation(value = "璇︽儏", notes = "浼犲叆plCodeClassify") + public R<CodeClassifyVO> detail(CodeClassify codeClassify) { + CodeClassify detail = codeClassifyMapper.selectOne(Condition.getQueryWrapper(codeClassify)); + return R.data(CodeClassifyWrapper.build().entityVO(detail)); + } + /** + * 涓婚搴撳畾涔夎〃 鍒嗛〉 + */ + @GetMapping("/list") + @ApiOperationSupport(order = 2) + @ApiOperation(value = "鍒嗛〉", notes = "浼犲叆plCodeClassify") + public R<IPage<CodeClassifyVO>> list(CodeClassify codeClassify, Query query) { + IPage<CodeClassify> pages = codeClassifyMapper.selectPage(Condition.getPage(query), Condition.getQueryWrapper(codeClassify)); + return R.data(CodeClassifyWrapper.build().pageVO(pages)); + } + + /** + * 涓婚搴撳畾涔夎〃 鑷畾涔夊垎椤� + */ + @GetMapping("/page") + @ApiOperationSupport(order = 3) + @ApiOperation(value = "鍒嗛〉", notes = "浼犲叆plCodeClassify") + public R<IPage<CodeClassifyVO>> page(CodeClassifyVO codeClassify, Query query) { + IPage<CodeClassifyVO> pages = codeClassifyService.selectPlCodeClassifyPage(Condition.getPage(query), codeClassify); + return R.data(pages); + } + + /** + * 涓婚搴撳畾涔夎〃 鏂板 + */ + @PostMapping("/save") + @ApiOperationSupport(order = 4) + @ApiOperation(value = "鏂板", notes = "浼犲叆plCodeClassify") + public R save(@Valid @RequestBody CodeClassify codeClassify) { + if(codeClassify.getOrderNum() == null){ + codeClassify.setOrderNum(0); + } + return codeClassifyService.addSave(codeClassify); + } + + /** + * 涓婚搴撳畾涔夎〃 淇敼 + */ + @PostMapping("/editSave") + @ApiOperationSupport(order = 5) + @ApiOperation(value = "淇敼", notes = "浼犲叆plCodeClassify") + public R editSave(@Valid @RequestBody CodeClassify codeClassify) { + return codeClassifyService.editSave(codeClassify); +// return R.status(SqlHelper.retBool(codeClassifyMapper.updateById(codeClassify))); + } + + /** + * 涓婚搴撳畾涔夎〃 鏂板鎴栦慨鏀� + */ + @PostMapping("/submit") + @ApiOperationSupport(order = 6) + @ApiOperation(value = "鏂板鎴栦慨鏀�", notes = "浼犲叆plCodeClassify") + public R submit(@Valid @RequestBody CodeClassify codeClassify) { + if(codeClassify.getOid() != null){ + codeClassify.setLastModifier(AuthUtil.getUser().getUserName()); + codeClassify.setLastModifyTime(new Date()); + return R.status(SqlHelper.retBool(codeClassifyMapper.updateById(codeClassify))); + } + return codeClassifyService.addSave(codeClassify); + } + + /** + * 涓婚搴撳畾涔夎〃 鍒犻櫎 + */ + @PostMapping("/remove") + @ApiOperationSupport(order = 7) + @ApiOperation(value = "閫昏緫鍒犻櫎", notes = "浼犲叆oids") + public R remove(@ApiParam(value = "涓婚敭闆嗗悎", required = true) @RequestParam String oids) { + return R.status(SqlHelper.retBool(codeClassifyMapper.deleteBatchIds(Func.toLongList(oids)))); + } + + /** + * 妫�鏌� 涓婚搴撳垎绫绘槸鍚﹀垹闄� + * @param codeClassify 涓婚搴撳垎绫绘暟鎹紶杈撳璞★紝蹇呴』瑕佹湁oid鍜宼s灞炴�� + * @return 鎵ц缁撴灉 success涓簍rue涓哄彲浠ュ垹闄わ紝false琛ㄧず鏈夋暟鎹紩鐢� + */ + @PostMapping( "/checkIsCanDelete") + public R checkIsCanDelete(CodeClassify codeClassify) { + return codeClassifyService.checkIsCanDelete(codeClassify); + } + + /** + * 鍒犻櫎涓婚搴撳垎绫� + * @param codeClassify锛宱id鍜宼s闇�瑕佷紶杈� + * @return 鍒犻櫎缁撴灉鍙嶉锛氾細success锛氭垚鍔燂紝fail锛氬け璐� + */ + @DeleteMapping( "/deleteData") + public R delCodeClassify(CodeClassify codeClassify) { + return codeClassifyService.deleteCodeClassify(codeClassify); + } + + /** + * 鍚敤 + * @param codeClassify + * @return + */ + @PostMapping( "/enableData") + public R enable(CodeClassify codeClassify) { + return codeClassifyService.updateLcStatus(codeClassify.getOid(),FRAMEWORK_DATA_ENABLED); + } + + /** + * 鍋滅敤 + * @param codeClassify + * @return + */ + @PostMapping( "/disableData") + public R disable(CodeClassify codeClassify) { + return codeClassifyService.updateLcStatus(codeClassify.getOid(),FRAMEWORK_DATA_DISABLED); + } + + /** + * 涓婚敭鎵归噺鑾峰彇涓婚搴撳垎绫� + * @param oids 涓婚敭锛屽涓互閫楀彿鍒嗛殧锛屼絾鏄彈鎬ц兘褰卞搷锛屽缓璁竴娆℃煡璇笉瓒呰繃10000涓� + * @return 涓婚搴撳垎绫绘樉绀哄璞� + */ + @GetMapping("/listDataByOids") + public R listCodeClassifyByOids(String oids){ + Collection<CodeClassifyVO> voCollection = codeClassifyService.listCodeClassifyByOids(VciBaseUtil.str2List(oids)); + return R.data(voCollection); + } + + /** + * 鍙傜収鏍� 涓婚搴撳垎绫� + * @param treeQueryObject 鏍戝舰鏌ヨ瀵硅薄 + * @return 涓婚搴撳垎绫绘樉绀烘爲 + */ + @GetMapping("/referTree") + public List<Tree> referTree(TreeQueryObject treeQueryObject) { + return codeClassifyService.referTree(treeQueryObject); + } + + /** + * 瀵煎嚭鍒嗙被 + * @param oid 鍒嗙被涓婚敭 + */ + @GetMapping("/exportClassify") + public void exportClassify(String oid, HttpServletResponse response) throws IOException { + String excelName = codeClassifyService.exportClassify(oid); +// try { +// ControllerUtil.writeFileToResponse(response,excelName); +// } catch (Throwable e) { +// //濡傛灉鍑洪敊,鎶婇敊璇俊鎭啓鍒皌ext +// String msg = LangBaseUtil.getErrorMsg(e); +// String errorFile = LocalFileUtil.getDefaultTempFolder() + File.separator + "閿欒.txt"; +// LocalFileUtil.writeContentToFile(msg,errorFile); +// ControllerUtil.writeFileToResponse(response,errorFile); +// } + } +} -- Gitblit v1.9.3