diff --git a/continew-admin-common/src/main/java/top/charles7c/cnadmin/common/model/request/UpdateStatusRequest.java b/continew-admin-common/src/main/java/top/charles7c/cnadmin/common/model/request/UpdateStatusRequest.java new file mode 100644 index 00000000..c39fa5c9 --- /dev/null +++ b/continew-admin-common/src/main/java/top/charles7c/cnadmin/common/model/request/UpdateStatusRequest.java @@ -0,0 +1,46 @@ +/* + * Copyright (c) 2022-present Charles7c Authors. All Rights Reserved. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package top.charles7c.cnadmin.common.model.request; + +import java.io.Serializable; + +import javax.validation.constraints.NotNull; + +import lombok.Data; + +import io.swagger.v3.oas.annotations.media.Schema; + +import top.charles7c.cnadmin.common.enums.DisEnableStatusEnum; + +/** + * 修改状态信息 + * + * @author Charles7c + * @since 2023/1/24 19:51 + */ +@Data +public class UpdateStatusRequest implements Serializable { + + private static final long serialVersionUID = 1L; + + /** + * 状态(1启用 2禁用) + */ + @Schema(description = "状态(1启用 2禁用)") + @NotNull(message = "状态非法") + private DisEnableStatusEnum status; +} diff --git a/continew-admin-system/src/main/java/top/charles7c/cnadmin/system/service/DeptService.java b/continew-admin-system/src/main/java/top/charles7c/cnadmin/system/service/DeptService.java index 9116ce94..7ae22896 100644 --- a/continew-admin-system/src/main/java/top/charles7c/cnadmin/system/service/DeptService.java +++ b/continew-admin-system/src/main/java/top/charles7c/cnadmin/system/service/DeptService.java @@ -20,6 +20,7 @@ import java.util.List; import cn.hutool.core.lang.tree.Tree; +import top.charles7c.cnadmin.common.enums.DisEnableStatusEnum; import top.charles7c.cnadmin.system.model.query.DeptQuery; import top.charles7c.cnadmin.system.model.request.CreateDeptRequest; import top.charles7c.cnadmin.system.model.vo.DeptVO; @@ -68,6 +69,24 @@ public interface DeptService { */ Long create(CreateDeptRequest request); + /** + * 修改状态 + * + * @param ids + * ID 列表 + * @param status + * 状态 + */ + void updateStatus(List ids, DisEnableStatusEnum status); + + /** + * 删除 + * + * @param ids + * ID 列表 + */ + void delete(List ids); + /** * 检查部门名称是否存在 * diff --git a/continew-admin-system/src/main/java/top/charles7c/cnadmin/system/service/impl/DeptServiceImpl.java b/continew-admin-system/src/main/java/top/charles7c/cnadmin/system/service/impl/DeptServiceImpl.java index 793af09e..edeff341 100644 --- a/continew-admin-system/src/main/java/top/charles7c/cnadmin/system/service/impl/DeptServiceImpl.java +++ b/continew-admin-system/src/main/java/top/charles7c/cnadmin/system/service/impl/DeptServiceImpl.java @@ -140,6 +140,20 @@ public class DeptServiceImpl implements DeptService { return sysDept.getDeptId(); } + @Override + @Transactional(rollbackFor = Exception.class) + public void updateStatus(List ids, DisEnableStatusEnum status) { + deptMapper.update(null, + Wrappers.lambdaUpdate().set(SysDept::getStatus, status).in(SysDept::getDeptId, ids)); + } + + @Override + @Transactional(rollbackFor = Exception.class) + public void delete(List ids) { + deptMapper.deleteBatchIds(ids); + deptMapper.delete(Wrappers.lambdaQuery().in(SysDept::getParentId, ids)); + } + @Override public boolean checkDeptNameExist(String deptName, Long parentId, Long deptId) { return deptMapper.exists(Wrappers.lambdaQuery().eq(SysDept::getDeptName, deptName) diff --git a/continew-admin-ui/components.d.ts b/continew-admin-ui/components.d.ts index 9ba2091b..54544f7b 100644 --- a/continew-admin-ui/components.d.ts +++ b/continew-admin-ui/components.d.ts @@ -49,6 +49,7 @@ declare module '@vue/runtime-core' { AMenuItem: typeof import('@arco-design/web-vue')['MenuItem'] AModal: typeof import('@arco-design/web-vue')['Modal'] AOption: typeof import('@arco-design/web-vue')['Option'] + APopconfirm: typeof import('@arco-design/web-vue')['Popconfirm'] APopover: typeof import('@arco-design/web-vue')['Popover'] ARadio: typeof import('@arco-design/web-vue')['Radio'] ARadioGroup: typeof import('@arco-design/web-vue')['RadioGroup'] @@ -73,6 +74,7 @@ declare module '@vue/runtime-core' { ATag: typeof import('@arco-design/web-vue')['Tag'] ATextarea: typeof import('@arco-design/web-vue')['Textarea'] ATooltip: typeof import('@arco-design/web-vue')['Tooltip'] + ATreeSelect: typeof import('@arco-design/web-vue')['TreeSelect'] ATypographyParagraph: typeof import('@arco-design/web-vue')['TypographyParagraph'] ATypographyText: typeof import('@arco-design/web-vue')['TypographyText'] ATypographyTitle: typeof import('@arco-design/web-vue')['TypographyTitle'] diff --git a/continew-admin-ui/src/api/system/dept.ts b/continew-admin-ui/src/api/system/dept.ts index 0d21ef6d..a0ea815d 100644 --- a/continew-admin-ui/src/api/system/dept.ts +++ b/continew-admin-ui/src/api/system/dept.ts @@ -2,12 +2,12 @@ import axios from 'axios'; import qs from 'query-string'; export interface DeptRecord { - deptId: string; + deptId?: number; deptName: string; - parentId: number; + parentId?: number; deptSort: number; description: string; - status: number; + status?: number; updateUserString: string; updateTime: string; children: Array, @@ -35,4 +35,15 @@ export interface CreateDeptReq { } export function createDept(req: CreateDeptReq) { return axios.post('/system/dept', req); +} + +export interface UpdateDeptStatusReq { + status: number; +} +export function updateDeptStatus(ids: Array, req: UpdateDeptStatusReq) { + return axios.patch(`/system/dept/${ids}`, req); +} + +export function deleteDept(ids: Array) { + return axios.delete(`/system/dept/${ids}`); } \ No newline at end of file diff --git a/continew-admin-ui/src/views/system/dept/index.vue b/continew-admin-ui/src/views/system/dept/index.vue index 81f3139a..02baf762 100644 --- a/continew-admin-ui/src/views/system/dept/index.vue +++ b/continew-admin-ui/src/views/system/dept/index.vue @@ -19,7 +19,7 @@ - diff --git a/continew-admin-webapi/src/main/java/top/charles7c/cnadmin/webapi/controller/system/DeptController.java b/continew-admin-webapi/src/main/java/top/charles7c/cnadmin/webapi/controller/system/DeptController.java index a5c5190c..39cc293f 100644 --- a/continew-admin-webapi/src/main/java/top/charles7c/cnadmin/webapi/controller/system/DeptController.java +++ b/continew-admin-webapi/src/main/java/top/charles7c/cnadmin/webapi/controller/system/DeptController.java @@ -21,12 +21,15 @@ import java.util.List; import lombok.RequiredArgsConstructor; import io.swagger.v3.oas.annotations.Operation; +import io.swagger.v3.oas.annotations.Parameter; +import io.swagger.v3.oas.annotations.enums.ParameterIn; import io.swagger.v3.oas.annotations.tags.Tag; import org.springframework.http.MediaType; import org.springframework.validation.annotation.Validated; import org.springframework.web.bind.annotation.*; +import top.charles7c.cnadmin.common.model.request.UpdateStatusRequest; import top.charles7c.cnadmin.common.model.vo.R; import top.charles7c.cnadmin.system.model.query.DeptQuery; import top.charles7c.cnadmin.system.model.request.CreateDeptRequest; @@ -67,4 +70,19 @@ public class DeptController { return R.ok("新增成功", deptService.create(request)); } + + @Operation(summary = "修改部门状态") + @PatchMapping("/{ids}") + public R updateStatus(@PathVariable List ids, @Validated @RequestBody UpdateStatusRequest request) { + deptService.updateStatus(ids, request.getStatus()); + return R.ok(String.format("%s成功", request.getStatus().getDescription())); + } + + @Operation(summary = "删除部门") + @Parameter(name = "ids", description = "ID 列表", in = ParameterIn.PATH) + @DeleteMapping("/{ids}") + public R delete(@PathVariable List ids) { + deptService.delete(ids); + return R.ok("删除成功"); + } }