|
@@ -0,0 +1,162 @@
|
|
|
+/**
|
|
|
+ * BladeX Commercial License Agreement
|
|
|
+ * Copyright (c) 2018-2099, https://bladex.cn. All rights reserved.
|
|
|
+ * <p>
|
|
|
+ * Use of this software is governed by the Commercial License Agreement
|
|
|
+ * obtained after purchasing a license from BladeX.
|
|
|
+ * <p>
|
|
|
+ * 1. This software is for development use only under a valid license
|
|
|
+ * from BladeX.
|
|
|
+ * <p>
|
|
|
+ * 2. Redistribution of this software's source code to any third party
|
|
|
+ * without a commercial license is strictly prohibited.
|
|
|
+ * <p>
|
|
|
+ * 3. Licensees may copyright their own code but cannot use segments
|
|
|
+ * from this software for such purposes. Copyright of this software
|
|
|
+ * remains with BladeX.
|
|
|
+ * <p>
|
|
|
+ * Using this software signifies agreement to this License, and the software
|
|
|
+ * must not be used for illegal purposes.
|
|
|
+ * <p>
|
|
|
+ * THIS SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY. The author is
|
|
|
+ * not liable for any claims arising from secondary or illegal development.
|
|
|
+ * <p>
|
|
|
+ * Author: Chill Zhuang (bladejava@qq.com)
|
|
|
+ */
|
|
|
+package org.springblade.modules.project.controller;
|
|
|
+
|
|
|
+import io.swagger.v3.oas.annotations.tags.Tag;
|
|
|
+import io.swagger.v3.oas.annotations.Operation;
|
|
|
+import io.swagger.v3.oas.annotations.Parameter;
|
|
|
+import com.github.xiaoymin.knife4j.annotations.ApiOperationSupport;
|
|
|
+import lombok.AllArgsConstructor;
|
|
|
+import jakarta.validation.Valid;
|
|
|
+
|
|
|
+import org.springblade.core.secure.BladeUser;
|
|
|
+import org.springblade.core.secure.annotation.PreAuth;
|
|
|
+import org.springblade.core.mp.support.Condition;
|
|
|
+import org.springblade.core.mp.support.Query;
|
|
|
+import org.springblade.core.tool.api.R;
|
|
|
+import org.springblade.core.tool.utils.Func;
|
|
|
+import org.springframework.web.bind.annotation.*;
|
|
|
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
|
|
+import com.baomidou.mybatisplus.core.metadata.IPage;
|
|
|
+import org.springblade.modules.project.pojo.entity.WorkFocusEntity;
|
|
|
+import org.springblade.modules.project.pojo.vo.WorkFocusVO;
|
|
|
+import org.springblade.modules.project.pojo.excel.WorkFocusExcel;
|
|
|
+import org.springblade.modules.project.wrapper.WorkFocusWrapper;
|
|
|
+import org.springblade.modules.project.service.IWorkFocusService;
|
|
|
+import org.springblade.core.boot.ctrl.BladeController;
|
|
|
+import org.springblade.core.tool.utils.DateUtil;
|
|
|
+import org.springblade.core.excel.util.ExcelUtil;
|
|
|
+import org.springblade.core.tool.constant.BladeConstant;
|
|
|
+import org.springblade.core.tool.constant.RoleConstant;
|
|
|
+import java.util.Map;
|
|
|
+import java.util.List;
|
|
|
+import jakarta.servlet.http.HttpServletResponse;
|
|
|
+
|
|
|
+/**
|
|
|
+ * 附件表 控制器
|
|
|
+ *
|
|
|
+ * @author BladeX
|
|
|
+ * @since 2024-04-09
|
|
|
+ */
|
|
|
+@RestController
|
|
|
+@AllArgsConstructor
|
|
|
+@RequestMapping("blade-attach/workfocus")
|
|
|
+@Tag(name = "附件表", description = "附件表接口")
|
|
|
+public class WorkFocusController extends BladeController {
|
|
|
+
|
|
|
+ private final IWorkFocusService workfocusService;
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 附件表 详情
|
|
|
+ */
|
|
|
+ @GetMapping("/detail")
|
|
|
+ @ApiOperationSupport(order = 1)
|
|
|
+ @Operation(summary = "详情", description = "传入workfocus")
|
|
|
+ public R<WorkFocusVO> detail(WorkFocusEntity workfocus) {
|
|
|
+ WorkFocusEntity detail = workfocusService.getOne(Condition.getQueryWrapper(workfocus));
|
|
|
+ return R.data(WorkFocusWrapper.build().entityVO(detail));
|
|
|
+ }
|
|
|
+ /**
|
|
|
+ * 附件表 分页
|
|
|
+ */
|
|
|
+ @GetMapping("/list")
|
|
|
+ @ApiOperationSupport(order = 2)
|
|
|
+ @Operation(summary = "分页", description = "传入workfocus")
|
|
|
+ public R<IPage<WorkFocusVO>> list(@Parameter(hidden = true) @RequestParam Map<String, Object> workfocus, Query query) {
|
|
|
+ IPage<WorkFocusEntity> pages = workfocusService.page(Condition.getPage(query), Condition.getQueryWrapper(workfocus, WorkFocusEntity.class));
|
|
|
+ return R.data(WorkFocusWrapper.build().pageVO(pages));
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 附件表 自定义分页
|
|
|
+ */
|
|
|
+ @GetMapping("/page")
|
|
|
+ @ApiOperationSupport(order = 3)
|
|
|
+ @Operation(summary = "分页", description = "传入workfocus")
|
|
|
+ public R<IPage<WorkFocusVO>> page(WorkFocusVO workfocus, Query query) {
|
|
|
+ IPage<WorkFocusVO> pages = workfocusService.selectWorkFocusPage(Condition.getPage(query), workfocus);
|
|
|
+ return R.data(pages);
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 附件表 新增
|
|
|
+ */
|
|
|
+ @PostMapping("/save")
|
|
|
+ @ApiOperationSupport(order = 4)
|
|
|
+ @Operation(summary = "新增", description = "传入workfocus")
|
|
|
+ public R save(@Valid @RequestBody WorkFocusEntity workfocus) {
|
|
|
+ return R.status(workfocusService.save(workfocus));
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 附件表 修改
|
|
|
+ */
|
|
|
+ @PostMapping("/update")
|
|
|
+ @ApiOperationSupport(order = 5)
|
|
|
+ @Operation(summary = "修改", description = "传入workfocus")
|
|
|
+ public R update(@Valid @RequestBody WorkFocusEntity workfocus) {
|
|
|
+ return R.status(workfocusService.updateById(workfocus));
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 附件表 新增或修改
|
|
|
+ */
|
|
|
+ @PostMapping("/submit")
|
|
|
+ @ApiOperationSupport(order = 6)
|
|
|
+ @Operation(summary = "新增或修改", description = "传入workfocus")
|
|
|
+ public R submit(@Valid @RequestBody WorkFocusEntity workfocus) {
|
|
|
+ return R.status(workfocusService.saveOrUpdate(workfocus));
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 附件表 删除
|
|
|
+ */
|
|
|
+ @PostMapping("/remove")
|
|
|
+ @ApiOperationSupport(order = 7)
|
|
|
+ @Operation(summary = "逻辑删除", description = "传入ids")
|
|
|
+ public R remove(@Parameter(name = "主键集合", required = true) @RequestParam String ids) {
|
|
|
+ return R.status(workfocusService.deleteLogic(Func.toLongList(ids)));
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 导出数据
|
|
|
+ */
|
|
|
+ @PreAuth(RoleConstant.HAS_ROLE_ADMIN)
|
|
|
+ @GetMapping("/export-workfocus")
|
|
|
+ @ApiOperationSupport(order = 9)
|
|
|
+ @Operation(summary = "导出数据", description = "传入workfocus")
|
|
|
+ public void exportWorkFocus(@Parameter(hidden = true) @RequestParam Map<String, Object> workfocus, BladeUser bladeUser, HttpServletResponse response) {
|
|
|
+ QueryWrapper<WorkFocusEntity> queryWrapper = Condition.getQueryWrapper(workfocus, WorkFocusEntity.class);
|
|
|
+ //if (!AuthUtil.isAdministrator()) {
|
|
|
+ // queryWrapper.lambda().eq(WorkFocus::getTenantId, bladeUser.getTenantId());
|
|
|
+ //}
|
|
|
+ queryWrapper.lambda().eq(WorkFocusEntity::getIsDeleted, BladeConstant.DB_NOT_DELETED);
|
|
|
+ List<WorkFocusExcel> list = workfocusService.exportWorkFocus(queryWrapper);
|
|
|
+ ExcelUtil.export(response, "附件表数据" + DateUtil.time(), "附件表数据表", list, WorkFocusExcel.class);
|
|
|
+ }
|
|
|
+
|
|
|
+}
|