feat: 新增系统管理/字典管理(列表、新增、修改、删除、导出、查询字典项列表、新增字典项、修改字典项、删除字典项)
This commit is contained in:
parent
375810772a
commit
ca51702035
@ -0,0 +1,28 @@
|
|||||||
|
/*
|
||||||
|
* 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.system.mapper;
|
||||||
|
|
||||||
|
import top.charles7c.cnadmin.common.base.BaseMapper;
|
||||||
|
import top.charles7c.cnadmin.system.model.entity.DictItemDO;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 字典项 Mapper
|
||||||
|
*
|
||||||
|
* @author Charles7c
|
||||||
|
* @since 2023/9/11 21:29
|
||||||
|
*/
|
||||||
|
public interface DictItemMapper extends BaseMapper<DictItemDO> {}
|
@ -0,0 +1,28 @@
|
|||||||
|
/*
|
||||||
|
* 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.system.mapper;
|
||||||
|
|
||||||
|
import top.charles7c.cnadmin.common.base.BaseMapper;
|
||||||
|
import top.charles7c.cnadmin.system.model.entity.DictDO;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 字典 Mapper
|
||||||
|
*
|
||||||
|
* @author Charles7c
|
||||||
|
* @since 2023/9/11 21:29
|
||||||
|
*/
|
||||||
|
public interface DictMapper extends BaseMapper<DictDO> {}
|
@ -0,0 +1,51 @@
|
|||||||
|
/*
|
||||||
|
* 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.system.model.entity;
|
||||||
|
|
||||||
|
import lombok.Data;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.annotation.TableName;
|
||||||
|
|
||||||
|
import top.charles7c.cnadmin.common.base.BaseDO;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 字典实体
|
||||||
|
*
|
||||||
|
* @author Charles7c
|
||||||
|
* @since 2023/9/11 21:29
|
||||||
|
*/
|
||||||
|
@Data
|
||||||
|
@TableName("sys_dict")
|
||||||
|
public class DictDO extends BaseDO {
|
||||||
|
|
||||||
|
private static final long serialVersionUID = 1L;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 字典名称
|
||||||
|
*/
|
||||||
|
private String name;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 字典编码
|
||||||
|
*/
|
||||||
|
private String code;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 描述
|
||||||
|
*/
|
||||||
|
private String description;
|
||||||
|
}
|
@ -0,0 +1,66 @@
|
|||||||
|
/*
|
||||||
|
* 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.system.model.entity;
|
||||||
|
|
||||||
|
import lombok.Data;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.annotation.TableName;
|
||||||
|
|
||||||
|
import top.charles7c.cnadmin.common.base.BaseDO;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 字典项实体
|
||||||
|
*
|
||||||
|
* @author Charles7c
|
||||||
|
* @since 2023/9/11 21:29
|
||||||
|
*/
|
||||||
|
@Data
|
||||||
|
@TableName("sys_dict_item")
|
||||||
|
public class DictItemDO extends BaseDO {
|
||||||
|
|
||||||
|
private static final long serialVersionUID = 1L;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 字典标签
|
||||||
|
*/
|
||||||
|
private String label;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 字典值
|
||||||
|
*/
|
||||||
|
private String value;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 背景颜色
|
||||||
|
*/
|
||||||
|
private String color;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 排序
|
||||||
|
*/
|
||||||
|
private Integer sort;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 描述
|
||||||
|
*/
|
||||||
|
private String description;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 字典ID
|
||||||
|
*/
|
||||||
|
private Long dictId;
|
||||||
|
}
|
@ -0,0 +1,45 @@
|
|||||||
|
/*
|
||||||
|
* 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.system.model.query;
|
||||||
|
|
||||||
|
import java.io.Serializable;
|
||||||
|
|
||||||
|
import lombok.Data;
|
||||||
|
|
||||||
|
import io.swagger.v3.oas.annotations.media.Schema;
|
||||||
|
|
||||||
|
import top.charles7c.cnadmin.common.annotation.Query;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 字典项查询条件
|
||||||
|
*
|
||||||
|
* @author Charles7c
|
||||||
|
* @since 2023/9/11 21:29
|
||||||
|
*/
|
||||||
|
@Data
|
||||||
|
@Schema(description = "字典项查询条件")
|
||||||
|
public class DictItemQuery implements Serializable {
|
||||||
|
|
||||||
|
private static final long serialVersionUID = 1L;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 字典 ID
|
||||||
|
*/
|
||||||
|
@Schema(description = "字典 ID")
|
||||||
|
@Query
|
||||||
|
private Long dictId;
|
||||||
|
}
|
@ -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.system.model.query;
|
||||||
|
|
||||||
|
import java.io.Serializable;
|
||||||
|
|
||||||
|
import lombok.Data;
|
||||||
|
|
||||||
|
import io.swagger.v3.oas.annotations.media.Schema;
|
||||||
|
|
||||||
|
import top.charles7c.cnadmin.common.annotation.Query;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 字典查询条件
|
||||||
|
*
|
||||||
|
* @author Charles7c
|
||||||
|
* @since 2023/9/11 21:29
|
||||||
|
*/
|
||||||
|
@Data
|
||||||
|
@Schema(description = "字典查询条件")
|
||||||
|
public class DictQuery implements Serializable {
|
||||||
|
|
||||||
|
private static final long serialVersionUID = 1L;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 字典名称
|
||||||
|
*/
|
||||||
|
@Schema(description = "字典名称")
|
||||||
|
@Query(blurry = {"code", "name", "description"})
|
||||||
|
private String name;
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,80 @@
|
|||||||
|
/*
|
||||||
|
* 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.system.model.request;
|
||||||
|
|
||||||
|
import javax.validation.constraints.*;
|
||||||
|
|
||||||
|
import lombok.Data;
|
||||||
|
|
||||||
|
import io.swagger.v3.oas.annotations.media.Schema;
|
||||||
|
|
||||||
|
import org.hibernate.validator.constraints.Length;
|
||||||
|
|
||||||
|
import top.charles7c.cnadmin.common.base.BaseRequest;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 创建或修改字典项信息
|
||||||
|
*
|
||||||
|
* @author Charles7c
|
||||||
|
* @since 2023/9/11 21:29
|
||||||
|
*/
|
||||||
|
@Data
|
||||||
|
@Schema(description = "创建或修改字典项信息")
|
||||||
|
public class DictItemRequest extends BaseRequest {
|
||||||
|
|
||||||
|
private static final long serialVersionUID = 1L;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 字典标签
|
||||||
|
*/
|
||||||
|
@Schema(description = "字典标签", example = "通知")
|
||||||
|
@NotBlank(message = "字典标签不能为空")
|
||||||
|
private String label;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 字典值
|
||||||
|
*/
|
||||||
|
@Schema(description = "字典值", example = "1")
|
||||||
|
@NotBlank(message = "字典值不能为空")
|
||||||
|
private String value;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 背景颜色
|
||||||
|
*/
|
||||||
|
@Schema(description = "背景颜色", example = "blue")
|
||||||
|
private String color;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 排序
|
||||||
|
*/
|
||||||
|
@Schema(description = "排序", example = "1")
|
||||||
|
private Integer sort;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 描述
|
||||||
|
*/
|
||||||
|
@Schema(description = "描述", example = "通知描述信息")
|
||||||
|
@Length(max = 200, message = "描述长度不能超过 {max} 个字符")
|
||||||
|
private String description;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 所属字典
|
||||||
|
*/
|
||||||
|
@Schema(description = "所属字典", example = "1")
|
||||||
|
@NotNull(message = "所属字典不能为空")
|
||||||
|
private Long dictId;
|
||||||
|
}
|
@ -0,0 +1,61 @@
|
|||||||
|
/*
|
||||||
|
* 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.system.model.request;
|
||||||
|
|
||||||
|
import javax.validation.constraints.*;
|
||||||
|
|
||||||
|
import lombok.Data;
|
||||||
|
|
||||||
|
import io.swagger.v3.oas.annotations.media.Schema;
|
||||||
|
|
||||||
|
import org.hibernate.validator.constraints.Length;
|
||||||
|
|
||||||
|
import top.charles7c.cnadmin.common.base.BaseRequest;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 创建或修改字典信息
|
||||||
|
*
|
||||||
|
* @author Charles7c
|
||||||
|
* @since 2023/9/11 21:29
|
||||||
|
*/
|
||||||
|
@Data
|
||||||
|
@Schema(description = "创建或修改字典信息")
|
||||||
|
public class DictRequest extends BaseRequest {
|
||||||
|
|
||||||
|
private static final long serialVersionUID = 1L;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 字典名称
|
||||||
|
*/
|
||||||
|
@Schema(description = "字典名称", example = "公告类型")
|
||||||
|
@NotBlank(message = "字典名称不能为空")
|
||||||
|
private String name;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 字典编码
|
||||||
|
*/
|
||||||
|
@Schema(description = "字典编码", example = "announcement_type")
|
||||||
|
@NotBlank(message = "字典编码不能为空")
|
||||||
|
private String code;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 描述
|
||||||
|
*/
|
||||||
|
@Schema(description = "描述", example = "公告类型描述信息")
|
||||||
|
@Length(max = 200, message = "描述长度不能超过 {max} 个字符")
|
||||||
|
private String description;
|
||||||
|
}
|
@ -0,0 +1,61 @@
|
|||||||
|
/*
|
||||||
|
* 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.system.model.vo;
|
||||||
|
|
||||||
|
import lombok.Data;
|
||||||
|
|
||||||
|
import io.swagger.v3.oas.annotations.media.Schema;
|
||||||
|
|
||||||
|
import com.alibaba.excel.annotation.ExcelIgnoreUnannotated;
|
||||||
|
import com.alibaba.excel.annotation.ExcelProperty;
|
||||||
|
|
||||||
|
import top.charles7c.cnadmin.common.base.BaseDetailVO;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 字典详情信息
|
||||||
|
*
|
||||||
|
* @author Charles7c
|
||||||
|
* @since 2023/9/11 21:29
|
||||||
|
*/
|
||||||
|
@Data
|
||||||
|
@ExcelIgnoreUnannotated
|
||||||
|
@Schema(description = "字典详情信息")
|
||||||
|
public class DictDetailVO extends BaseDetailVO {
|
||||||
|
|
||||||
|
private static final long serialVersionUID = 1L;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 字典名称
|
||||||
|
*/
|
||||||
|
@Schema(description = "字典名称", example = "公告类型")
|
||||||
|
@ExcelProperty(value = "字典名称")
|
||||||
|
private String name;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 字典编码
|
||||||
|
*/
|
||||||
|
@Schema(description = "字典编码", example = "announcement_type")
|
||||||
|
@ExcelProperty(value = "字典编码")
|
||||||
|
private String code;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 描述
|
||||||
|
*/
|
||||||
|
@Schema(description = "描述", example = "公告类型描述信息")
|
||||||
|
@ExcelProperty(value = "描述")
|
||||||
|
private String description;
|
||||||
|
}
|
@ -0,0 +1,82 @@
|
|||||||
|
/*
|
||||||
|
* 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.system.model.vo;
|
||||||
|
|
||||||
|
import lombok.Data;
|
||||||
|
|
||||||
|
import io.swagger.v3.oas.annotations.media.Schema;
|
||||||
|
|
||||||
|
import com.alibaba.excel.annotation.ExcelIgnoreUnannotated;
|
||||||
|
import com.alibaba.excel.annotation.ExcelProperty;
|
||||||
|
|
||||||
|
import top.charles7c.cnadmin.common.base.BaseDetailVO;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 字典项详情信息
|
||||||
|
*
|
||||||
|
* @author Charles7c
|
||||||
|
* @since 2023/9/11 21:29
|
||||||
|
*/
|
||||||
|
@Data
|
||||||
|
@ExcelIgnoreUnannotated
|
||||||
|
@Schema(description = "字典项详情信息")
|
||||||
|
public class DictItemDetailVO extends BaseDetailVO {
|
||||||
|
|
||||||
|
private static final long serialVersionUID = 1L;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 字典标签
|
||||||
|
*/
|
||||||
|
@Schema(description = "字典标签", example = "通知")
|
||||||
|
@ExcelProperty(value = "字典标签")
|
||||||
|
private String label;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 字典值
|
||||||
|
*/
|
||||||
|
@Schema(description = "字典值", example = "1")
|
||||||
|
@ExcelProperty(value = "字典值")
|
||||||
|
private String value;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 背景颜色
|
||||||
|
*/
|
||||||
|
@Schema(description = "背景颜色", example = "blue")
|
||||||
|
@ExcelProperty(value = "背景颜色")
|
||||||
|
private String color;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 排序
|
||||||
|
*/
|
||||||
|
@Schema(description = "排序", example = "1")
|
||||||
|
@ExcelProperty(value = "排序")
|
||||||
|
private Integer sort;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 描述
|
||||||
|
*/
|
||||||
|
@Schema(description = "描述", example = "通知描述信息")
|
||||||
|
@ExcelProperty(value = "描述")
|
||||||
|
private String description;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 所属字典
|
||||||
|
*/
|
||||||
|
@Schema(description = "所属字典", example = "1")
|
||||||
|
@ExcelProperty(value = "所属字典")
|
||||||
|
private Long dictId;
|
||||||
|
}
|
@ -0,0 +1,66 @@
|
|||||||
|
/*
|
||||||
|
* 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.system.model.vo;
|
||||||
|
|
||||||
|
import lombok.Data;
|
||||||
|
|
||||||
|
import io.swagger.v3.oas.annotations.media.Schema;
|
||||||
|
|
||||||
|
import top.charles7c.cnadmin.common.base.BaseVO;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 字典项信息
|
||||||
|
*
|
||||||
|
* @author Charles7c
|
||||||
|
* @since 2023/9/11 21:29
|
||||||
|
*/
|
||||||
|
@Data
|
||||||
|
@Schema(description = "字典项信息")
|
||||||
|
public class DictItemVO extends BaseVO {
|
||||||
|
|
||||||
|
private static final long serialVersionUID = 1L;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 字典标签
|
||||||
|
*/
|
||||||
|
@Schema(description = "字典标签", example = "通知")
|
||||||
|
private String label;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 字典值
|
||||||
|
*/
|
||||||
|
@Schema(description = "字典值", example = "1")
|
||||||
|
private String value;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 背景颜色
|
||||||
|
*/
|
||||||
|
@Schema(description = "背景颜色", example = "blue")
|
||||||
|
private String color;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 描述
|
||||||
|
*/
|
||||||
|
@Schema(description = "描述", example = "通知描述信息")
|
||||||
|
private String description;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 排序
|
||||||
|
*/
|
||||||
|
@Schema(description = "排序", example = "1")
|
||||||
|
private Integer sort;
|
||||||
|
}
|
@ -0,0 +1,54 @@
|
|||||||
|
/*
|
||||||
|
* 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.system.model.vo;
|
||||||
|
|
||||||
|
import lombok.Data;
|
||||||
|
|
||||||
|
import io.swagger.v3.oas.annotations.media.Schema;
|
||||||
|
|
||||||
|
import top.charles7c.cnadmin.common.base.BaseVO;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 字典信息
|
||||||
|
*
|
||||||
|
* @author Charles7c
|
||||||
|
* @since 2023/9/11 21:29
|
||||||
|
*/
|
||||||
|
@Data
|
||||||
|
@Schema(description = "字典信息")
|
||||||
|
public class DictVO extends BaseVO {
|
||||||
|
|
||||||
|
private static final long serialVersionUID = 1L;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 字典名称
|
||||||
|
*/
|
||||||
|
@Schema(description = "字典名称", example = "公告类型")
|
||||||
|
private String name;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 字典编码
|
||||||
|
*/
|
||||||
|
@Schema(description = "字典编码", example = "announcement_type")
|
||||||
|
private String code;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 描述
|
||||||
|
*/
|
||||||
|
@Schema(description = "描述", example = "公告类型描述信息")
|
||||||
|
private String description;
|
||||||
|
}
|
@ -0,0 +1,42 @@
|
|||||||
|
/*
|
||||||
|
* 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.system.service;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import top.charles7c.cnadmin.common.base.BaseService;
|
||||||
|
import top.charles7c.cnadmin.system.model.query.DictItemQuery;
|
||||||
|
import top.charles7c.cnadmin.system.model.request.DictItemRequest;
|
||||||
|
import top.charles7c.cnadmin.system.model.vo.DictItemDetailVO;
|
||||||
|
import top.charles7c.cnadmin.system.model.vo.DictItemVO;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 字典项业务接口
|
||||||
|
*
|
||||||
|
* @author Charles7c
|
||||||
|
* @since 2023/9/11 21:29
|
||||||
|
*/
|
||||||
|
public interface DictItemService extends BaseService<DictItemVO, DictItemDetailVO, DictItemQuery, DictItemRequest> {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 根据字典 ID 列表删除
|
||||||
|
*
|
||||||
|
* @param dictIds
|
||||||
|
* 字典 ID 列表
|
||||||
|
*/
|
||||||
|
void deleteByDictIds(List<Long> dictIds);
|
||||||
|
}
|
@ -0,0 +1,31 @@
|
|||||||
|
/*
|
||||||
|
* 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.system.service;
|
||||||
|
|
||||||
|
import top.charles7c.cnadmin.common.base.BaseService;
|
||||||
|
import top.charles7c.cnadmin.system.model.query.DictQuery;
|
||||||
|
import top.charles7c.cnadmin.system.model.request.DictRequest;
|
||||||
|
import top.charles7c.cnadmin.system.model.vo.DictDetailVO;
|
||||||
|
import top.charles7c.cnadmin.system.model.vo.DictVO;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 字典业务接口
|
||||||
|
*
|
||||||
|
* @author Charles7c
|
||||||
|
* @since 2023/9/11 21:29
|
||||||
|
*/
|
||||||
|
public interface DictService extends BaseService<DictVO, DictDetailVO, DictQuery, DictRequest> {}
|
@ -0,0 +1,84 @@
|
|||||||
|
/*
|
||||||
|
* 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.system.service.impl;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import lombok.RequiredArgsConstructor;
|
||||||
|
|
||||||
|
import org.springframework.stereotype.Service;
|
||||||
|
import org.springframework.transaction.annotation.Transactional;
|
||||||
|
|
||||||
|
import top.charles7c.cnadmin.common.base.BaseServiceImpl;
|
||||||
|
import top.charles7c.cnadmin.common.util.validate.CheckUtils;
|
||||||
|
import top.charles7c.cnadmin.system.mapper.DictItemMapper;
|
||||||
|
import top.charles7c.cnadmin.system.model.entity.DictItemDO;
|
||||||
|
import top.charles7c.cnadmin.system.model.query.DictItemQuery;
|
||||||
|
import top.charles7c.cnadmin.system.model.request.DictItemRequest;
|
||||||
|
import top.charles7c.cnadmin.system.model.vo.DictItemDetailVO;
|
||||||
|
import top.charles7c.cnadmin.system.model.vo.DictItemVO;
|
||||||
|
import top.charles7c.cnadmin.system.service.DictItemService;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 字典项业务实现
|
||||||
|
*
|
||||||
|
* @author Charles7c
|
||||||
|
* @since 2023/9/11 21:29
|
||||||
|
*/
|
||||||
|
@Service
|
||||||
|
@RequiredArgsConstructor
|
||||||
|
public class DictItemServiceImpl
|
||||||
|
extends BaseServiceImpl<DictItemMapper, DictItemDO, DictItemVO, DictItemDetailVO, DictItemQuery, DictItemRequest>
|
||||||
|
implements DictItemService {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
@Transactional(rollbackFor = Exception.class)
|
||||||
|
public Long add(DictItemRequest request) {
|
||||||
|
String value = request.getValue();
|
||||||
|
CheckUtils.throwIf(this.checkValueExists(value, null, request.getDictId()), "新增失败,字典值 [{}] 已存在", value);
|
||||||
|
return super.add(request);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
@Transactional(rollbackFor = Exception.class)
|
||||||
|
public void update(DictItemRequest request, Long id) {
|
||||||
|
String value = request.getValue();
|
||||||
|
CheckUtils.throwIf(this.checkValueExists(value, id, request.getDictId()), "修改失败,字典值 [{}] 已存在", value);
|
||||||
|
super.update(request, id);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void deleteByDictIds(List<Long> dictIds) {
|
||||||
|
baseMapper.lambdaUpdate().in(DictItemDO::getDictId, dictIds).remove();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 检查字典值是否存在
|
||||||
|
*
|
||||||
|
* @param value
|
||||||
|
* 字典值
|
||||||
|
* @param id
|
||||||
|
* ID
|
||||||
|
* @param dictId
|
||||||
|
* 字典 ID
|
||||||
|
* @return 是否存在
|
||||||
|
*/
|
||||||
|
private boolean checkValueExists(String value, Long id, Long dictId) {
|
||||||
|
return baseMapper.lambdaQuery().eq(DictItemDO::getValue, value).eq(DictItemDO::getDictId, dictId)
|
||||||
|
.ne(null != id, DictItemDO::getId, id).exists();
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,102 @@
|
|||||||
|
/*
|
||||||
|
* 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.system.service.impl;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import lombok.RequiredArgsConstructor;
|
||||||
|
|
||||||
|
import org.springframework.stereotype.Service;
|
||||||
|
import org.springframework.transaction.annotation.Transactional;
|
||||||
|
|
||||||
|
import top.charles7c.cnadmin.common.base.BaseServiceImpl;
|
||||||
|
import top.charles7c.cnadmin.common.util.validate.CheckUtils;
|
||||||
|
import top.charles7c.cnadmin.system.mapper.DictMapper;
|
||||||
|
import top.charles7c.cnadmin.system.model.entity.DictDO;
|
||||||
|
import top.charles7c.cnadmin.system.model.query.DictQuery;
|
||||||
|
import top.charles7c.cnadmin.system.model.request.DictRequest;
|
||||||
|
import top.charles7c.cnadmin.system.model.vo.DictDetailVO;
|
||||||
|
import top.charles7c.cnadmin.system.model.vo.DictVO;
|
||||||
|
import top.charles7c.cnadmin.system.service.DictItemService;
|
||||||
|
import top.charles7c.cnadmin.system.service.DictService;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 字典业务实现
|
||||||
|
*
|
||||||
|
* @author Charles7c
|
||||||
|
* @since 2023/9/11 21:29
|
||||||
|
*/
|
||||||
|
@Service
|
||||||
|
@RequiredArgsConstructor
|
||||||
|
public class DictServiceImpl extends BaseServiceImpl<DictMapper, DictDO, DictVO, DictDetailVO, DictQuery, DictRequest>
|
||||||
|
implements DictService {
|
||||||
|
|
||||||
|
private final DictItemService dictItemService;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
@Transactional(rollbackFor = Exception.class)
|
||||||
|
public Long add(DictRequest request) {
|
||||||
|
String name = request.getName();
|
||||||
|
CheckUtils.throwIf(this.checkNameExists(name, null), "新增失败,[{}] 已存在", name);
|
||||||
|
String code = request.getCode();
|
||||||
|
CheckUtils.throwIf(this.checkCodeExists(code, null), "新增失败,[{}] 已存在", code);
|
||||||
|
return super.add(request);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
@Transactional(rollbackFor = Exception.class)
|
||||||
|
public void update(DictRequest request, Long id) {
|
||||||
|
String name = request.getName();
|
||||||
|
CheckUtils.throwIf(this.checkNameExists(name, id), "修改失败,[{}] 已存在", name);
|
||||||
|
String code = request.getCode();
|
||||||
|
CheckUtils.throwIf(this.checkCodeExists(code, id), "修改失败,[{}] 已存在", code);
|
||||||
|
super.update(request, id);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
@Transactional(rollbackFor = Exception.class)
|
||||||
|
public void delete(List<Long> ids) {
|
||||||
|
dictItemService.deleteByDictIds(ids);
|
||||||
|
super.delete(ids);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 检查名称是否存在
|
||||||
|
*
|
||||||
|
* @param name
|
||||||
|
* 名称
|
||||||
|
* @param id
|
||||||
|
* ID
|
||||||
|
* @return 是否存在
|
||||||
|
*/
|
||||||
|
private boolean checkNameExists(String name, Long id) {
|
||||||
|
return baseMapper.lambdaQuery().eq(DictDO::getName, name).ne(null != id, DictDO::getId, id).exists();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 检查编码是否存在
|
||||||
|
*
|
||||||
|
* @param code
|
||||||
|
* 编码
|
||||||
|
* @param id
|
||||||
|
* ID
|
||||||
|
* @return 是否存在
|
||||||
|
*/
|
||||||
|
private boolean checkCodeExists(String code, Long id) {
|
||||||
|
return baseMapper.lambdaQuery().eq(DictDO::getCode, code).ne(null != id, DictDO::getId, id).exists();
|
||||||
|
}
|
||||||
|
}
|
57
continew-admin-ui/src/api/system/dict-item.ts
Normal file
57
continew-admin-ui/src/api/system/dict-item.ts
Normal file
@ -0,0 +1,57 @@
|
|||||||
|
import axios from 'axios';
|
||||||
|
import qs from 'query-string';
|
||||||
|
|
||||||
|
const BASE_URL = '/system/dict/item';
|
||||||
|
|
||||||
|
export interface DataRecord {
|
||||||
|
id?: number;
|
||||||
|
label: string;
|
||||||
|
value: string;
|
||||||
|
color?: string;
|
||||||
|
sort?: number;
|
||||||
|
description: string;
|
||||||
|
dictId?: number;
|
||||||
|
createUser?: string;
|
||||||
|
createTime?: string;
|
||||||
|
updateUser?: string;
|
||||||
|
updateTime?: string;
|
||||||
|
createUserString?: string;
|
||||||
|
updateUserString?: string;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface ListParam {
|
||||||
|
dictId?: number;
|
||||||
|
page?: number;
|
||||||
|
size?: number;
|
||||||
|
sort?: Array<string>;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface ListRes {
|
||||||
|
list: DataRecord[];
|
||||||
|
total: number;
|
||||||
|
}
|
||||||
|
|
||||||
|
export function list(params: ListParam) {
|
||||||
|
return axios.get<ListRes>(`${BASE_URL}`, {
|
||||||
|
params,
|
||||||
|
paramsSerializer: (obj) => {
|
||||||
|
return qs.stringify(obj);
|
||||||
|
},
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
export function get(id: number) {
|
||||||
|
return axios.get<DataRecord>(`${BASE_URL}/${id}`);
|
||||||
|
}
|
||||||
|
|
||||||
|
export function add(req: DataRecord) {
|
||||||
|
return axios.post(BASE_URL, req);
|
||||||
|
}
|
||||||
|
|
||||||
|
export function update(req: DataRecord, id: number) {
|
||||||
|
return axios.put(`${BASE_URL}/${id}`, req);
|
||||||
|
}
|
||||||
|
|
||||||
|
export function del(ids: number | Array<number>) {
|
||||||
|
return axios.delete(`${BASE_URL}/${ids}`);
|
||||||
|
}
|
54
continew-admin-ui/src/api/system/dict.ts
Normal file
54
continew-admin-ui/src/api/system/dict.ts
Normal file
@ -0,0 +1,54 @@
|
|||||||
|
import axios from 'axios';
|
||||||
|
import qs from 'query-string';
|
||||||
|
|
||||||
|
const BASE_URL = '/system/dict';
|
||||||
|
|
||||||
|
export interface DataRecord {
|
||||||
|
id?: number;
|
||||||
|
name: string;
|
||||||
|
code: string;
|
||||||
|
description?: string;
|
||||||
|
createUser?: string;
|
||||||
|
createTime?: string;
|
||||||
|
updateUser?: string;
|
||||||
|
updateTime?: string;
|
||||||
|
createUserString?: string;
|
||||||
|
updateUserString?: string;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface ListParam {
|
||||||
|
name?: string;
|
||||||
|
page?: number;
|
||||||
|
size?: number;
|
||||||
|
sort?: Array<string>;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface ListRes {
|
||||||
|
list: DataRecord[];
|
||||||
|
total: number;
|
||||||
|
}
|
||||||
|
|
||||||
|
export function list(params: ListParam) {
|
||||||
|
return axios.get<ListRes>(`${BASE_URL}`, {
|
||||||
|
params,
|
||||||
|
paramsSerializer: (obj) => {
|
||||||
|
return qs.stringify(obj);
|
||||||
|
},
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
export function get(id: number) {
|
||||||
|
return axios.get<DataRecord>(`${BASE_URL}/${id}`);
|
||||||
|
}
|
||||||
|
|
||||||
|
export function add(req: DataRecord) {
|
||||||
|
return axios.post(BASE_URL, req);
|
||||||
|
}
|
||||||
|
|
||||||
|
export function update(req: DataRecord, id: number) {
|
||||||
|
return axios.put(`${BASE_URL}/${id}`, req);
|
||||||
|
}
|
||||||
|
|
||||||
|
export function del(ids: number | Array<number>) {
|
||||||
|
return axios.delete(`${BASE_URL}/${ids}`);
|
||||||
|
}
|
@ -5,6 +5,7 @@ import localeRole from '@/views/system/role/locale/en-US';
|
|||||||
import localeMenu from '@/views/system/menu/locale/en-US';
|
import localeMenu from '@/views/system/menu/locale/en-US';
|
||||||
import localeDept from '@/views/system/dept/locale/en-US';
|
import localeDept from '@/views/system/dept/locale/en-US';
|
||||||
import localeAnnouncement from '@/views/system/announcement/locale/en-US';
|
import localeAnnouncement from '@/views/system/announcement/locale/en-US';
|
||||||
|
import localeDict from '@/views/system/dict/locale/en-US';
|
||||||
|
|
||||||
import localeGenerator from '@/views/tool/generator/locale/en-US';
|
import localeGenerator from '@/views/tool/generator/locale/en-US';
|
||||||
|
|
||||||
@ -60,6 +61,7 @@ export default {
|
|||||||
...localeMenu,
|
...localeMenu,
|
||||||
...localeDept,
|
...localeDept,
|
||||||
...localeAnnouncement,
|
...localeAnnouncement,
|
||||||
|
...localeDict,
|
||||||
|
|
||||||
...localeGenerator,
|
...localeGenerator,
|
||||||
|
|
||||||
|
@ -5,6 +5,7 @@ import localeRole from '@/views/system/role/locale/zh-CN';
|
|||||||
import localeMenu from '@/views/system/menu/locale/zh-CN';
|
import localeMenu from '@/views/system/menu/locale/zh-CN';
|
||||||
import localeDept from '@/views/system/dept/locale/zh-CN';
|
import localeDept from '@/views/system/dept/locale/zh-CN';
|
||||||
import localeAnnouncement from '@/views/system/announcement/locale/zh-CN';
|
import localeAnnouncement from '@/views/system/announcement/locale/zh-CN';
|
||||||
|
import localeDict from '@/views/system/dict/locale/zh-CN';
|
||||||
|
|
||||||
import localeGenerator from '@/views/tool/generator/locale/zh-CN';
|
import localeGenerator from '@/views/tool/generator/locale/zh-CN';
|
||||||
|
|
||||||
@ -60,6 +61,7 @@ export default {
|
|||||||
...localeMenu,
|
...localeMenu,
|
||||||
...localeDept,
|
...localeDept,
|
||||||
...localeAnnouncement,
|
...localeAnnouncement,
|
||||||
|
...localeDict,
|
||||||
|
|
||||||
...localeGenerator,
|
...localeGenerator,
|
||||||
|
|
||||||
|
@ -7,7 +7,7 @@ const FORM: AppRouteRecordRaw = {
|
|||||||
component: DEFAULT_LAYOUT,
|
component: DEFAULT_LAYOUT,
|
||||||
meta: {
|
meta: {
|
||||||
locale: 'menu.form',
|
locale: 'menu.form',
|
||||||
icon: 'bookmark',
|
icon: 'select-all',
|
||||||
requiresAuth: true,
|
requiresAuth: true,
|
||||||
order: 901,
|
order: 901,
|
||||||
},
|
},
|
||||||
|
@ -21,6 +21,15 @@ const System: AppRouteRecordRaw = {
|
|||||||
requiresAuth: true,
|
requiresAuth: true,
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
name: 'Dept',
|
||||||
|
path: '/system/dept',
|
||||||
|
component: () => import('@/views/system/dept/index.vue'),
|
||||||
|
meta: {
|
||||||
|
locale: 'menu.system.dept.list',
|
||||||
|
requiresAuth: true,
|
||||||
|
},
|
||||||
|
},
|
||||||
{
|
{
|
||||||
name: 'Role',
|
name: 'Role',
|
||||||
path: '/system/role',
|
path: '/system/role',
|
||||||
@ -30,6 +39,15 @@ const System: AppRouteRecordRaw = {
|
|||||||
requiresAuth: true,
|
requiresAuth: true,
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
name: 'Announcement',
|
||||||
|
path: '/system/announcement',
|
||||||
|
component: () => import('@/views/system/announcement/index.vue'),
|
||||||
|
meta: {
|
||||||
|
locale: 'menu.system.announcement.list',
|
||||||
|
requiresAuth: true,
|
||||||
|
},
|
||||||
|
},
|
||||||
{
|
{
|
||||||
name: 'Menu',
|
name: 'Menu',
|
||||||
path: '/system/menu',
|
path: '/system/menu',
|
||||||
@ -40,20 +58,11 @@ const System: AppRouteRecordRaw = {
|
|||||||
},
|
},
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
name: 'Dept',
|
name: 'Dict',
|
||||||
path: '/system/dept',
|
path: '/system/dict',
|
||||||
component: () => import('@/views/system/dept/index.vue'),
|
component: () => import('@/views/system/dict/index.vue'),
|
||||||
meta: {
|
meta: {
|
||||||
locale: 'menu.system.dept.list',
|
locale: 'menu.system.dict.list',
|
||||||
requiresAuth: true,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
name: 'Announcement',
|
|
||||||
path: '/system/announcement',
|
|
||||||
component: () => import('@/views/system/announcement/index.vue'),
|
|
||||||
meta: {
|
|
||||||
locale: 'menu.system.announcement.list',
|
|
||||||
requiresAuth: true,
|
requiresAuth: true,
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
453
continew-admin-ui/src/views/system/dict/index.vue
Normal file
453
continew-admin-ui/src/views/system/dict/index.vue
Normal file
@ -0,0 +1,453 @@
|
|||||||
|
<template>
|
||||||
|
<div class="app-container">
|
||||||
|
<Breadcrumb :items="['menu.system', 'menu.system.dict.list']" />
|
||||||
|
<a-card class="general-card" :title="$t('menu.system.dict.list')">
|
||||||
|
<a-row>
|
||||||
|
<a-col :xs="24" :sm="24" :md="12" :lg="12" :xl="12">
|
||||||
|
<!-- 头部区域 -->
|
||||||
|
<div class="header">
|
||||||
|
<!-- 搜索栏 -->
|
||||||
|
<div v-if="showQuery" class="header-query">
|
||||||
|
<a-form ref="queryRef" :model="queryParams" layout="inline">
|
||||||
|
<a-form-item field="name" hide-label>
|
||||||
|
<a-input
|
||||||
|
v-model="queryParams.name"
|
||||||
|
placeholder="输入字典名称搜索"
|
||||||
|
allow-clear
|
||||||
|
style="width: 150px"
|
||||||
|
@press-enter="handleQuery"
|
||||||
|
/>
|
||||||
|
</a-form-item>
|
||||||
|
<a-form-item hide-label>
|
||||||
|
<a-space>
|
||||||
|
<a-button type="primary" @click="handleQuery">
|
||||||
|
<template #icon><icon-search /></template>查询
|
||||||
|
</a-button>
|
||||||
|
<a-button @click="resetQuery">
|
||||||
|
<template #icon><icon-refresh /></template>重置
|
||||||
|
</a-button>
|
||||||
|
</a-space>
|
||||||
|
</a-form-item>
|
||||||
|
</a-form>
|
||||||
|
</div>
|
||||||
|
<!-- 操作栏 -->
|
||||||
|
<div class="header-operation">
|
||||||
|
<a-row>
|
||||||
|
<a-col :span="12">
|
||||||
|
<a-space>
|
||||||
|
<a-button
|
||||||
|
v-permission="['system:dict:add']"
|
||||||
|
type="primary"
|
||||||
|
@click="toAdd"
|
||||||
|
>
|
||||||
|
<template #icon><icon-plus /></template>新增
|
||||||
|
</a-button>
|
||||||
|
<a-button
|
||||||
|
v-permission="['system:dict:update']"
|
||||||
|
type="primary"
|
||||||
|
status="success"
|
||||||
|
:disabled="single"
|
||||||
|
:title="single ? '请选择一条要修改的数据' : ''"
|
||||||
|
@click="toUpdate(ids[0])"
|
||||||
|
>
|
||||||
|
<template #icon><icon-edit /></template>修改
|
||||||
|
</a-button>
|
||||||
|
<a-button
|
||||||
|
v-permission="['system:dict:delete']"
|
||||||
|
type="primary"
|
||||||
|
status="danger"
|
||||||
|
:disabled="multiple"
|
||||||
|
:title="multiple ? '请选择要删除的数据' : ''"
|
||||||
|
@click="handleBatchDelete"
|
||||||
|
>
|
||||||
|
<template #icon><icon-delete /></template>删除
|
||||||
|
</a-button>
|
||||||
|
<a-button
|
||||||
|
v-permission="['system:dict:export']"
|
||||||
|
:loading="exportLoading"
|
||||||
|
type="primary"
|
||||||
|
status="warning"
|
||||||
|
@click="handleExport"
|
||||||
|
>
|
||||||
|
<template #icon><icon-download /></template>导出
|
||||||
|
</a-button>
|
||||||
|
</a-space>
|
||||||
|
</a-col>
|
||||||
|
<a-col :span="12">
|
||||||
|
<right-toolbar
|
||||||
|
v-model:show-query="showQuery"
|
||||||
|
@refresh="handleQuery"
|
||||||
|
/>
|
||||||
|
</a-col>
|
||||||
|
</a-row>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- 列表区域 -->
|
||||||
|
<a-table
|
||||||
|
ref="tableRef"
|
||||||
|
row-key="id"
|
||||||
|
:data="dataList"
|
||||||
|
:loading="loading"
|
||||||
|
:row-selection="{
|
||||||
|
type: 'checkbox',
|
||||||
|
showCheckedAll: true,
|
||||||
|
onlyCurrent: false,
|
||||||
|
}"
|
||||||
|
:pagination="{
|
||||||
|
showTotal: true,
|
||||||
|
showPageSize: true,
|
||||||
|
total: total,
|
||||||
|
current: queryParams.page,
|
||||||
|
}"
|
||||||
|
:bordered="false"
|
||||||
|
column-resizable
|
||||||
|
size="large"
|
||||||
|
@page-change="handlePageChange"
|
||||||
|
@page-size-change="handlePageSizeChange"
|
||||||
|
@selection-change="handleSelectionChange"
|
||||||
|
@row-click="handleSelect"
|
||||||
|
>
|
||||||
|
<template #columns>
|
||||||
|
<a-table-column title="序号" :width="60">
|
||||||
|
<template #cell="{ rowIndex }">
|
||||||
|
{{ rowIndex + 1 + (queryParams.page - 1) * queryParams.size }}
|
||||||
|
</template>
|
||||||
|
</a-table-column>
|
||||||
|
<a-table-column title="字典名称" data-index="name" :width="100" />
|
||||||
|
<a-table-column
|
||||||
|
title="字典编码"
|
||||||
|
data-index="code"
|
||||||
|
ellipsis
|
||||||
|
tooltip
|
||||||
|
/>
|
||||||
|
<a-table-column title="描述" data-index="description" />
|
||||||
|
<a-table-column
|
||||||
|
v-if="
|
||||||
|
checkPermission(['system:dict:update', 'system:dict:delete'])
|
||||||
|
"
|
||||||
|
title="操作"
|
||||||
|
align="center"
|
||||||
|
:width="191"
|
||||||
|
>
|
||||||
|
<template #cell="{ record }">
|
||||||
|
<a-button
|
||||||
|
v-permission="['system:dict:update']"
|
||||||
|
type="text"
|
||||||
|
size="small"
|
||||||
|
title="修改"
|
||||||
|
@click="toUpdate(record.id)"
|
||||||
|
>
|
||||||
|
<template #icon><icon-edit /></template>修改
|
||||||
|
</a-button>
|
||||||
|
<a-popconfirm
|
||||||
|
content="确定要删除当前选中的数据吗?"
|
||||||
|
type="warning"
|
||||||
|
@ok="handleDelete([record.id])"
|
||||||
|
>
|
||||||
|
<a-button
|
||||||
|
v-permission="['system:dict:delete']"
|
||||||
|
type="text"
|
||||||
|
size="small"
|
||||||
|
title="删除"
|
||||||
|
:disabled="record.disabled"
|
||||||
|
>
|
||||||
|
<template #icon><icon-delete /></template>删除
|
||||||
|
</a-button>
|
||||||
|
</a-popconfirm>
|
||||||
|
</template>
|
||||||
|
</a-table-column>
|
||||||
|
</template>
|
||||||
|
</a-table>
|
||||||
|
</a-col>
|
||||||
|
<a-col :xs="24" :sm="24" :md="12" :lg="12" :xl="12">
|
||||||
|
<dictItem ref="dictItemRef" :dict-id="dictId" />
|
||||||
|
</a-col>
|
||||||
|
</a-row>
|
||||||
|
|
||||||
|
<!-- 表单区域 -->
|
||||||
|
<a-modal
|
||||||
|
:title="title"
|
||||||
|
:visible="visible"
|
||||||
|
:mask-closable="false"
|
||||||
|
:esc-to-close="false"
|
||||||
|
unmount-on-close
|
||||||
|
render-to-body
|
||||||
|
@ok="handleOk"
|
||||||
|
@cancel="handleCancel"
|
||||||
|
>
|
||||||
|
<a-form ref="formRef" :model="form" :rules="rules" size="large">
|
||||||
|
<a-form-item label="字典名称" field="name">
|
||||||
|
<a-input v-model="form.name" placeholder="请输入字典名称" />
|
||||||
|
</a-form-item>
|
||||||
|
<a-form-item label="字典编码" field="code">
|
||||||
|
<a-input v-model="form.code" placeholder="请输入字典编码" />
|
||||||
|
</a-form-item>
|
||||||
|
<a-form-item label="描述" field="description">
|
||||||
|
<a-textarea
|
||||||
|
v-model="form.description"
|
||||||
|
:max-length="200"
|
||||||
|
placeholder="请输入描述"
|
||||||
|
:auto-size="{
|
||||||
|
minRows: 3,
|
||||||
|
}"
|
||||||
|
show-word-limit
|
||||||
|
/>
|
||||||
|
</a-form-item>
|
||||||
|
</a-form>
|
||||||
|
</a-modal>
|
||||||
|
</a-card>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script lang="ts" setup>
|
||||||
|
import { getCurrentInstance, ref, toRefs, reactive } from 'vue';
|
||||||
|
import { TableData } from '@arco-design/web-vue';
|
||||||
|
import {
|
||||||
|
DataRecord,
|
||||||
|
ListParam,
|
||||||
|
list,
|
||||||
|
get,
|
||||||
|
add,
|
||||||
|
update,
|
||||||
|
del,
|
||||||
|
} from '@/api/system/dict';
|
||||||
|
import checkPermission from '@/utils/permission';
|
||||||
|
import dictItem from './item.vue';
|
||||||
|
|
||||||
|
const { proxy } = getCurrentInstance() as any;
|
||||||
|
|
||||||
|
const dataList = ref<DataRecord[]>([]);
|
||||||
|
const total = ref(0);
|
||||||
|
const ids = ref<Array<number>>([]);
|
||||||
|
const title = ref('');
|
||||||
|
const single = ref(true);
|
||||||
|
const multiple = ref(true);
|
||||||
|
const showQuery = ref(true);
|
||||||
|
const loading = ref(false);
|
||||||
|
const exportLoading = ref(false);
|
||||||
|
const visible = ref(false);
|
||||||
|
const dictId = ref();
|
||||||
|
|
||||||
|
const data = reactive({
|
||||||
|
// 查询参数
|
||||||
|
queryParams: {
|
||||||
|
name: undefined,
|
||||||
|
page: 1,
|
||||||
|
size: 10,
|
||||||
|
sort: ['createTime,desc'],
|
||||||
|
},
|
||||||
|
// 表单数据
|
||||||
|
form: {} as DataRecord,
|
||||||
|
// 表单验证规则
|
||||||
|
rules: {
|
||||||
|
name: [{ required: true, message: '字典名称不能为空' }],
|
||||||
|
code: [{ required: true, message: '字典编码不能为空' }],
|
||||||
|
},
|
||||||
|
});
|
||||||
|
const { queryParams, form, rules } = toRefs(data);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 选中行
|
||||||
|
*
|
||||||
|
* @param record 所选行记录
|
||||||
|
*/
|
||||||
|
const handleSelect = (record: TableData) => {
|
||||||
|
proxy.$refs.tableRef.selectAll(false);
|
||||||
|
proxy.$refs.tableRef.select(record.id);
|
||||||
|
dictId.value = record.id;
|
||||||
|
proxy.$refs.dictItemRef.getList(record.id);
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 查询列表
|
||||||
|
*
|
||||||
|
* @param params 查询参数
|
||||||
|
*/
|
||||||
|
const getList = (params: ListParam = { ...queryParams.value }) => {
|
||||||
|
dictId.value = null;
|
||||||
|
loading.value = true;
|
||||||
|
list(params)
|
||||||
|
.then((res) => {
|
||||||
|
dataList.value = res.data.list;
|
||||||
|
total.value = res.data.total;
|
||||||
|
})
|
||||||
|
.finally(() => {
|
||||||
|
loading.value = false;
|
||||||
|
});
|
||||||
|
};
|
||||||
|
getList();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 打开新增对话框
|
||||||
|
*/
|
||||||
|
const toAdd = () => {
|
||||||
|
reset();
|
||||||
|
title.value = '新增字典';
|
||||||
|
visible.value = true;
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 打开修改对话框
|
||||||
|
*
|
||||||
|
* @param id ID
|
||||||
|
*/
|
||||||
|
const toUpdate = (id: number) => {
|
||||||
|
reset();
|
||||||
|
get(id).then((res) => {
|
||||||
|
form.value = res.data;
|
||||||
|
title.value = '修改字典';
|
||||||
|
visible.value = true;
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 重置表单
|
||||||
|
*/
|
||||||
|
const reset = () => {
|
||||||
|
form.value = {
|
||||||
|
id: undefined,
|
||||||
|
name: '',
|
||||||
|
code: '',
|
||||||
|
description: '',
|
||||||
|
};
|
||||||
|
proxy.$refs.formRef?.resetFields();
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 取消
|
||||||
|
*/
|
||||||
|
const handleCancel = () => {
|
||||||
|
visible.value = false;
|
||||||
|
proxy.$refs.formRef.resetFields();
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 确定
|
||||||
|
*/
|
||||||
|
const handleOk = () => {
|
||||||
|
proxy.$refs.formRef.validate((valid: any) => {
|
||||||
|
if (!valid) {
|
||||||
|
if (form.value.id !== undefined) {
|
||||||
|
update(form.value, form.value.id).then((res) => {
|
||||||
|
handleCancel();
|
||||||
|
getList();
|
||||||
|
proxy.$message.success(res.msg);
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
add(form.value).then((res) => {
|
||||||
|
handleCancel();
|
||||||
|
getList();
|
||||||
|
proxy.$message.success(res.msg);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 批量删除
|
||||||
|
*/
|
||||||
|
const handleBatchDelete = () => {
|
||||||
|
if (ids.value.length === 0) {
|
||||||
|
proxy.$message.info('请选择要删除的数据');
|
||||||
|
} else {
|
||||||
|
proxy.$modal.warning({
|
||||||
|
title: '警告',
|
||||||
|
titleAlign: 'start',
|
||||||
|
content: '确定要删除当前选中的数据吗?',
|
||||||
|
hideCancel: false,
|
||||||
|
onOk: () => {
|
||||||
|
handleDelete(ids.value);
|
||||||
|
},
|
||||||
|
});
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 删除
|
||||||
|
*
|
||||||
|
* @param ids ID 列表
|
||||||
|
*/
|
||||||
|
const handleDelete = (ids: Array<number>) => {
|
||||||
|
del(ids).then((res) => {
|
||||||
|
proxy.$message.success(res.msg);
|
||||||
|
getList();
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 已选择的数据行发生改变时触发
|
||||||
|
*
|
||||||
|
* @param rowKeys ID 列表
|
||||||
|
*/
|
||||||
|
const handleSelectionChange = (rowKeys: Array<any>) => {
|
||||||
|
ids.value = rowKeys;
|
||||||
|
single.value = rowKeys.length !== 1;
|
||||||
|
multiple.value = !rowKeys.length;
|
||||||
|
if (!rowKeys.length) {
|
||||||
|
dictId.value = null;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 导出
|
||||||
|
*/
|
||||||
|
const handleExport = () => {
|
||||||
|
if (exportLoading.value) return;
|
||||||
|
exportLoading.value = true;
|
||||||
|
proxy
|
||||||
|
.download('/system/dict/export', { ...queryParams.value }, '字典数据')
|
||||||
|
.finally(() => {
|
||||||
|
exportLoading.value = false;
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 查询
|
||||||
|
*/
|
||||||
|
const handleQuery = () => {
|
||||||
|
proxy.$refs.tableRef.selectAll(false);
|
||||||
|
getList();
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 重置
|
||||||
|
*/
|
||||||
|
const resetQuery = () => {
|
||||||
|
proxy.$refs.queryRef.resetFields();
|
||||||
|
handleQuery();
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 切换页码
|
||||||
|
*
|
||||||
|
* @param current 页码
|
||||||
|
*/
|
||||||
|
const handlePageChange = (current: number) => {
|
||||||
|
queryParams.value.page = current;
|
||||||
|
getList();
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 切换每页条数
|
||||||
|
*
|
||||||
|
* @param pageSize 每页条数
|
||||||
|
*/
|
||||||
|
const handlePageSizeChange = (pageSize: number) => {
|
||||||
|
queryParams.value.size = pageSize;
|
||||||
|
getList();
|
||||||
|
};
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<script lang="ts">
|
||||||
|
export default {
|
||||||
|
name: 'Dict',
|
||||||
|
};
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style scoped lang="less">
|
||||||
|
:deep(.arco-table-td) {
|
||||||
|
cursor: pointer;
|
||||||
|
}
|
||||||
|
</style>
|
363
continew-admin-ui/src/views/system/dict/item.vue
Normal file
363
continew-admin-ui/src/views/system/dict/item.vue
Normal file
@ -0,0 +1,363 @@
|
|||||||
|
<template>
|
||||||
|
<div class="app-container">
|
||||||
|
<!-- 头部区域 -->
|
||||||
|
<div style="margin-bottom: 18px">
|
||||||
|
<a-row>
|
||||||
|
<a-col :span="18" />
|
||||||
|
<a-col :span="6" style="display: flex; justify-content: end">
|
||||||
|
<a-button
|
||||||
|
v-permission="['system:dictItem:add']"
|
||||||
|
type="primary"
|
||||||
|
:disabled="!dictId"
|
||||||
|
:title="!dictId ? '请先点击左侧字典' : ''"
|
||||||
|
@click="toAdd"
|
||||||
|
>
|
||||||
|
<template #icon><icon-plus /></template>新增
|
||||||
|
</a-button>
|
||||||
|
</a-col>
|
||||||
|
</a-row>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- 列表区域 -->
|
||||||
|
<a-table
|
||||||
|
ref="tableRef"
|
||||||
|
row-key="id"
|
||||||
|
:data="dictId ? dataList : []"
|
||||||
|
:loading="loading"
|
||||||
|
:pagination="{
|
||||||
|
showTotal: true,
|
||||||
|
showPageSize: true,
|
||||||
|
total: total,
|
||||||
|
current: queryParams.page,
|
||||||
|
}"
|
||||||
|
:bordered="false"
|
||||||
|
column-resizable
|
||||||
|
stripe
|
||||||
|
size="large"
|
||||||
|
@page-change="handlePageChange"
|
||||||
|
@page-size-change="handlePageSizeChange"
|
||||||
|
>
|
||||||
|
<template #columns>
|
||||||
|
<a-table-column title="字典标签" align="center">
|
||||||
|
<template #cell="{ record }">
|
||||||
|
<a-tag v-if="record.color === 'primary'" color="arcoblue">{{
|
||||||
|
record.label
|
||||||
|
}}</a-tag>
|
||||||
|
<a-tag v-else-if="record.color === 'success'" color="green">{{
|
||||||
|
record.label
|
||||||
|
}}</a-tag>
|
||||||
|
<a-tag
|
||||||
|
v-else-if="record.color === 'warning'"
|
||||||
|
color="orangered"
|
||||||
|
>{{ record.label }}</a-tag
|
||||||
|
>
|
||||||
|
<a-tag v-else-if="record.color === 'error'" color="red">{{
|
||||||
|
record.label
|
||||||
|
}}</a-tag>
|
||||||
|
<a-tag v-else-if="record.color === 'default'" color="gray">{{
|
||||||
|
record.label
|
||||||
|
}}</a-tag>
|
||||||
|
<span v-else-if="!record.color">{{ record.label }}</span>
|
||||||
|
<a-tag v-else :color="record.color">{{ record.label }}</a-tag>
|
||||||
|
</template>
|
||||||
|
</a-table-column>
|
||||||
|
<a-table-column title="字典值" align="center" data-index="value" />
|
||||||
|
<a-table-column title="排序" align="center" data-index="sort" />
|
||||||
|
<a-table-column title="描述" data-index="description" />
|
||||||
|
<a-table-column
|
||||||
|
v-if="
|
||||||
|
checkPermission([
|
||||||
|
'system:dictItem:update',
|
||||||
|
'system:dictItem:delete',
|
||||||
|
])
|
||||||
|
"
|
||||||
|
title="操作"
|
||||||
|
align="center"
|
||||||
|
>
|
||||||
|
<template #cell="{ record }">
|
||||||
|
<a-button
|
||||||
|
v-permission="['system:dictItem:update']"
|
||||||
|
type="text"
|
||||||
|
size="small"
|
||||||
|
title="修改"
|
||||||
|
@click="toUpdate(record.id)"
|
||||||
|
>
|
||||||
|
<template #icon><icon-edit /></template>修改
|
||||||
|
</a-button>
|
||||||
|
<a-popconfirm
|
||||||
|
content="确定要删除当前选中的数据吗?"
|
||||||
|
type="warning"
|
||||||
|
@ok="handleDelete([record.id])"
|
||||||
|
>
|
||||||
|
<a-button
|
||||||
|
v-permission="['system:dictItem:delete']"
|
||||||
|
type="text"
|
||||||
|
size="small"
|
||||||
|
title="删除"
|
||||||
|
:disabled="record.disabled"
|
||||||
|
>
|
||||||
|
<template #icon><icon-delete /></template>删除
|
||||||
|
</a-button>
|
||||||
|
</a-popconfirm>
|
||||||
|
</template>
|
||||||
|
</a-table-column>
|
||||||
|
</template>
|
||||||
|
</a-table>
|
||||||
|
|
||||||
|
<!-- 表单区域 -->
|
||||||
|
<a-modal
|
||||||
|
:title="title"
|
||||||
|
:visible="visible"
|
||||||
|
:mask-closable="false"
|
||||||
|
:esc-to-close="false"
|
||||||
|
unmount-on-close
|
||||||
|
render-to-body
|
||||||
|
@ok="handleOk"
|
||||||
|
@cancel="handleCancel"
|
||||||
|
>
|
||||||
|
<a-form ref="formRef" :model="form" :rules="rules" size="large">
|
||||||
|
<a-form-item label="字典标签" field="label">
|
||||||
|
<a-input v-model="form.label" placeholder="请输入字典标签" />
|
||||||
|
</a-form-item>
|
||||||
|
<a-form-item label="字典值" field="value">
|
||||||
|
<a-input v-model="form.value" placeholder="请输入字典值" />
|
||||||
|
</a-form-item>
|
||||||
|
<a-form-item label="背景颜色" field="color">
|
||||||
|
<a-auto-complete
|
||||||
|
v-model="form.color"
|
||||||
|
:data="colors"
|
||||||
|
placeholder="请选择或输入背景颜色"
|
||||||
|
allow-clear
|
||||||
|
>
|
||||||
|
<template #option="{ data }">
|
||||||
|
<a-tag v-if="data.value === 'primary'" color="arcoblue">{{
|
||||||
|
data.value
|
||||||
|
}}</a-tag>
|
||||||
|
<a-tag v-else-if="data.value === 'success'" color="green">{{
|
||||||
|
data.value
|
||||||
|
}}</a-tag>
|
||||||
|
<a-tag v-else-if="data.value === 'warning'" color="orangered">{{
|
||||||
|
data.value
|
||||||
|
}}</a-tag>
|
||||||
|
<a-tag v-else-if="data.value === 'error'" color="red">{{
|
||||||
|
data.value
|
||||||
|
}}</a-tag>
|
||||||
|
<a-tag v-else color="gray">{{ data.value }}</a-tag>
|
||||||
|
</template>
|
||||||
|
</a-auto-complete>
|
||||||
|
</a-form-item>
|
||||||
|
<a-form-item label="排序" field="sort">
|
||||||
|
<a-input-number
|
||||||
|
v-model="form.sort"
|
||||||
|
placeholder="请输入排序"
|
||||||
|
:min="1"
|
||||||
|
mode="button"
|
||||||
|
/>
|
||||||
|
</a-form-item>
|
||||||
|
<a-form-item label="描述" field="description">
|
||||||
|
<a-textarea
|
||||||
|
v-model="form.description"
|
||||||
|
:max-length="200"
|
||||||
|
placeholder="请输入描述"
|
||||||
|
:auto-size="{
|
||||||
|
minRows: 3,
|
||||||
|
}"
|
||||||
|
show-word-limit
|
||||||
|
/>
|
||||||
|
</a-form-item>
|
||||||
|
</a-form>
|
||||||
|
</a-modal>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script lang="ts" setup>
|
||||||
|
import { getCurrentInstance, ref, toRefs, reactive, computed } from 'vue';
|
||||||
|
import {
|
||||||
|
DataRecord,
|
||||||
|
ListParam,
|
||||||
|
list,
|
||||||
|
get,
|
||||||
|
add,
|
||||||
|
update,
|
||||||
|
del,
|
||||||
|
} from '@/api/system/dict-item';
|
||||||
|
import checkPermission from '@/utils/permission';
|
||||||
|
|
||||||
|
const props = defineProps({
|
||||||
|
dictId: {
|
||||||
|
type: Number,
|
||||||
|
required: true,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
const { proxy } = getCurrentInstance() as any;
|
||||||
|
const dataList = ref<DataRecord[]>([]);
|
||||||
|
const colors = ref(['primary', 'success', 'warning', 'error', 'default']);
|
||||||
|
const total = ref(0);
|
||||||
|
const title = ref('');
|
||||||
|
const loading = ref(false);
|
||||||
|
const visible = ref(false);
|
||||||
|
const dictId = computed(() => props.dictId);
|
||||||
|
|
||||||
|
const data = reactive({
|
||||||
|
// 查询参数
|
||||||
|
queryParams: {
|
||||||
|
page: 1,
|
||||||
|
size: 10,
|
||||||
|
sort: ['createTime,desc'],
|
||||||
|
} as ListParam,
|
||||||
|
// 表单数据
|
||||||
|
form: {} as DataRecord,
|
||||||
|
// 表单验证规则
|
||||||
|
rules: {
|
||||||
|
label: [{ required: true, message: '字典标签不能为空' }],
|
||||||
|
value: [{ required: true, message: '字典值不能为空' }],
|
||||||
|
},
|
||||||
|
});
|
||||||
|
const { queryParams, form, rules } = toRefs(data);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 查询列表
|
||||||
|
*
|
||||||
|
* @param dictId 字典 ID
|
||||||
|
*/
|
||||||
|
const getList = (dictId: number) => {
|
||||||
|
queryParams.value.dictId = dictId;
|
||||||
|
loading.value = true;
|
||||||
|
list(queryParams.value)
|
||||||
|
.then((res) => {
|
||||||
|
dataList.value = res.data.list;
|
||||||
|
total.value = res.data.total;
|
||||||
|
})
|
||||||
|
.finally(() => {
|
||||||
|
loading.value = false;
|
||||||
|
});
|
||||||
|
};
|
||||||
|
defineExpose({
|
||||||
|
getList,
|
||||||
|
});
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 打开新增对话框
|
||||||
|
*/
|
||||||
|
const toAdd = () => {
|
||||||
|
reset();
|
||||||
|
title.value = '新增字典项';
|
||||||
|
visible.value = true;
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 打开修改对话框
|
||||||
|
*
|
||||||
|
* @param id ID
|
||||||
|
*/
|
||||||
|
const toUpdate = (id: number) => {
|
||||||
|
reset();
|
||||||
|
get(id).then((res) => {
|
||||||
|
form.value = res.data;
|
||||||
|
title.value = '修改字典项';
|
||||||
|
visible.value = true;
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 重置表单
|
||||||
|
*/
|
||||||
|
const reset = () => {
|
||||||
|
form.value = {
|
||||||
|
id: undefined,
|
||||||
|
label: '',
|
||||||
|
value: '',
|
||||||
|
color: '',
|
||||||
|
sort: 999,
|
||||||
|
description: '',
|
||||||
|
dictId: dictId.value,
|
||||||
|
};
|
||||||
|
proxy.$refs.formRef?.resetFields();
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 取消
|
||||||
|
*/
|
||||||
|
const handleCancel = () => {
|
||||||
|
visible.value = false;
|
||||||
|
proxy.$refs.formRef.resetFields();
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 确定
|
||||||
|
*/
|
||||||
|
const handleOk = () => {
|
||||||
|
proxy.$refs.formRef.validate((valid: any) => {
|
||||||
|
if (!valid) {
|
||||||
|
if (form.value.id !== undefined) {
|
||||||
|
update(form.value, form.value.id).then((res) => {
|
||||||
|
handleCancel();
|
||||||
|
getList(dictId.value);
|
||||||
|
proxy.$message.success(res.msg);
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
add(form.value).then((res) => {
|
||||||
|
handleCancel();
|
||||||
|
getList(dictId.value);
|
||||||
|
proxy.$message.success(res.msg);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 删除
|
||||||
|
*
|
||||||
|
* @param ids ID 列表
|
||||||
|
*/
|
||||||
|
const handleDelete = (ids: Array<number>) => {
|
||||||
|
del(ids).then((res) => {
|
||||||
|
proxy.$message.success(res.msg);
|
||||||
|
getList(dictId.value);
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 查询
|
||||||
|
*/
|
||||||
|
const handleQuery = () => {
|
||||||
|
getList(dictId.value);
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 重置
|
||||||
|
*/
|
||||||
|
const resetQuery = () => {
|
||||||
|
proxy.$refs.queryRef.resetFields();
|
||||||
|
handleQuery();
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 切换页码
|
||||||
|
*
|
||||||
|
* @param current 页码
|
||||||
|
*/
|
||||||
|
const handlePageChange = (current: number) => {
|
||||||
|
queryParams.value.page = current;
|
||||||
|
getList(dictId.value);
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 切换每页条数
|
||||||
|
*
|
||||||
|
* @param pageSize 每页条数
|
||||||
|
*/
|
||||||
|
const handlePageSizeChange = (pageSize: number) => {
|
||||||
|
queryParams.value.size = pageSize;
|
||||||
|
getList(dictId.value);
|
||||||
|
};
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<script lang="ts">
|
||||||
|
export default {
|
||||||
|
name: 'DictItem',
|
||||||
|
};
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style scoped lang="less"></style>
|
3
continew-admin-ui/src/views/system/dict/locale/en-US.ts
Normal file
3
continew-admin-ui/src/views/system/dict/locale/en-US.ts
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
export default {
|
||||||
|
'menu.system.dict.list': 'Dictionary management',
|
||||||
|
};
|
3
continew-admin-ui/src/views/system/dict/locale/zh-CN.ts
Normal file
3
continew-admin-ui/src/views/system/dict/locale/zh-CN.ts
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
export default {
|
||||||
|
'menu.system.dict.list': '字典管理',
|
||||||
|
};
|
@ -0,0 +1,42 @@
|
|||||||
|
/*
|
||||||
|
* 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.webapi.controller.system;
|
||||||
|
|
||||||
|
import static top.charles7c.cnadmin.common.annotation.CrudRequestMapping.Api;
|
||||||
|
|
||||||
|
import io.swagger.v3.oas.annotations.tags.Tag;
|
||||||
|
|
||||||
|
import org.springframework.web.bind.annotation.*;
|
||||||
|
|
||||||
|
import top.charles7c.cnadmin.common.annotation.CrudRequestMapping;
|
||||||
|
import top.charles7c.cnadmin.common.base.BaseController;
|
||||||
|
import top.charles7c.cnadmin.system.model.query.DictQuery;
|
||||||
|
import top.charles7c.cnadmin.system.model.request.DictRequest;
|
||||||
|
import top.charles7c.cnadmin.system.model.vo.DictDetailVO;
|
||||||
|
import top.charles7c.cnadmin.system.model.vo.DictVO;
|
||||||
|
import top.charles7c.cnadmin.system.service.DictService;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 字典管理 API
|
||||||
|
*
|
||||||
|
* @author Charles7c
|
||||||
|
* @since 2023/9/11 21:29
|
||||||
|
*/
|
||||||
|
@Tag(name = "字典管理 API")
|
||||||
|
@RestController
|
||||||
|
@CrudRequestMapping(value = "/system/dict", api = {Api.PAGE, Api.GET, Api.ADD, Api.UPDATE, Api.DELETE, Api.EXPORT})
|
||||||
|
public class DictController extends BaseController<DictService, DictVO, DictDetailVO, DictQuery, DictRequest> {}
|
@ -0,0 +1,43 @@
|
|||||||
|
/*
|
||||||
|
* 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.webapi.controller.system;
|
||||||
|
|
||||||
|
import static top.charles7c.cnadmin.common.annotation.CrudRequestMapping.Api;
|
||||||
|
|
||||||
|
import io.swagger.v3.oas.annotations.tags.Tag;
|
||||||
|
|
||||||
|
import org.springframework.web.bind.annotation.*;
|
||||||
|
|
||||||
|
import top.charles7c.cnadmin.common.annotation.CrudRequestMapping;
|
||||||
|
import top.charles7c.cnadmin.common.base.BaseController;
|
||||||
|
import top.charles7c.cnadmin.system.model.query.DictItemQuery;
|
||||||
|
import top.charles7c.cnadmin.system.model.request.DictItemRequest;
|
||||||
|
import top.charles7c.cnadmin.system.model.vo.DictItemDetailVO;
|
||||||
|
import top.charles7c.cnadmin.system.model.vo.DictItemVO;
|
||||||
|
import top.charles7c.cnadmin.system.service.DictItemService;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 字典项管理 API
|
||||||
|
*
|
||||||
|
* @author Charles7c
|
||||||
|
* @since 2023/9/11 21:29
|
||||||
|
*/
|
||||||
|
@Tag(name = "字典项管理 API")
|
||||||
|
@RestController
|
||||||
|
@CrudRequestMapping(value = "/system/dict/item", api = {Api.PAGE, Api.GET, Api.ADD, Api.UPDATE, Api.DELETE})
|
||||||
|
public class DictItemController
|
||||||
|
extends BaseController<DictItemService, DictItemVO, DictItemDetailVO, DictItemQuery, DictItemRequest> {}
|
@ -11,3 +11,9 @@ databaseChangeLog:
|
|||||||
file: db/changelog/v1.1.0/continew-admin_column.sql
|
file: db/changelog/v1.1.0/continew-admin_column.sql
|
||||||
- include:
|
- include:
|
||||||
file: db/changelog/v1.1.0/continew-admin_data.sql
|
file: db/changelog/v1.1.0/continew-admin_data.sql
|
||||||
|
- include:
|
||||||
|
file: db/changelog/v1.2.0/continew-admin_table.sql
|
||||||
|
- include:
|
||||||
|
file: db/changelog/v1.2.0/continew-admin_column.sql
|
||||||
|
- include:
|
||||||
|
file: db/changelog/v1.2.0/continew-admin_data.sql
|
||||||
|
@ -13,21 +13,21 @@ VALUES
|
|||||||
(1014, '用户导出', 1010, 3, NULL, NULL, NULL, NULL, b'0', b'0', b'0', 'system:user:export', 4, 1, 1, NOW(), NULL, NULL),
|
(1014, '用户导出', 1010, 3, NULL, NULL, NULL, NULL, b'0', b'0', b'0', 'system:user:export', 4, 1, 1, NOW(), NULL, NULL),
|
||||||
(1015, '重置密码', 1010, 3, NULL, NULL, NULL, NULL, b'0', b'0', b'0', 'system:user:password:reset', 5, 1, 1, NOW(), NULL, NULL),
|
(1015, '重置密码', 1010, 3, NULL, NULL, NULL, NULL, b'0', b'0', b'0', 'system:user:password:reset', 5, 1, 1, NOW(), NULL, NULL),
|
||||||
(1016, '分配角色', 1010, 3, NULL, NULL, NULL, NULL, b'0', b'0', b'0', 'system:user:role:update', 6, 1, 1, NOW(), NULL, NULL),
|
(1016, '分配角色', 1010, 3, NULL, NULL, NULL, NULL, b'0', b'0', b'0', 'system:user:role:update', 6, 1, 1, NOW(), NULL, NULL),
|
||||||
(1020, '角色管理', 1000, 2, '/system/role', 'Role', 'system/role/index', 'safe', b'0', b'0', b'0', 'system:role:list', 2, 1, 1, NOW(), NULL, NULL),
|
(1020, '部门管理', 1000, 2, '/system/dept', 'Dept', 'system/dept/index', 'user-group', b'0', b'0', b'0', 'system:dept:list', 2, 1, 1, NOW(), NULL, NULL),
|
||||||
(1021, '角色新增', 1020, 3, NULL, NULL, NULL, NULL, b'0', b'0', b'0', 'system:role:add', 1, 1, 1, NOW(), NULL, NULL),
|
(1021, '部门新增', 1020, 3, NULL, NULL, NULL, NULL, b'0', b'0', b'0', 'system:dept:add', 1, 1, 1, NOW(), NULL, NULL),
|
||||||
(1022, '角色修改', 1020, 3, NULL, NULL, NULL, NULL, b'0', b'0', b'0', 'system:role:update', 2, 1, 1, NOW(), NULL, NULL),
|
(1022, '部门修改', 1020, 3, NULL, NULL, NULL, NULL, b'0', b'0', b'0', 'system:dept:update', 2, 1, 1, NOW(), NULL, NULL),
|
||||||
(1023, '角色删除', 1020, 3, NULL, NULL, NULL, NULL, b'0', b'0', b'0', 'system:role:delete', 3, 1, 1, NOW(), NULL, NULL),
|
(1023, '部门删除', 1020, 3, NULL, NULL, NULL, NULL, b'0', b'0', b'0', 'system:dept:delete', 3, 1, 1, NOW(), NULL, NULL),
|
||||||
(1024, '角色导出', 1020, 3, NULL, NULL, NULL, NULL, b'0', b'0', b'0', 'system:role:export', 4, 1, 1, NOW(), NULL, NULL),
|
(1024, '部门导出', 1020, 3, NULL, NULL, NULL, NULL, b'0', b'0', b'0', 'system:dept:export', 4, 1, 1, NOW(), NULL, NULL),
|
||||||
(1030, '部门管理', 1000, 2, '/system/dept', 'Dept', 'system/dept/index', 'user-group', b'0', b'0', b'0', 'system:dept:list', 3, 1, 1, NOW(), NULL, NULL),
|
(1030, '角色管理', 1000, 2, '/system/role', 'Role', 'system/role/index', 'safe', b'0', b'0', b'0', 'system:role:list', 3, 1, 1, NOW(), NULL, NULL),
|
||||||
(1031, '部门新增', 1030, 3, NULL, NULL, NULL, NULL, b'0', b'0', b'0', 'system:dept:add', 1, 1, 1, NOW(), NULL, NULL),
|
(1031, '角色新增', 1030, 3, NULL, NULL, NULL, NULL, b'0', b'0', b'0', 'system:role:add', 1, 1, 1, NOW(), NULL, NULL),
|
||||||
(1032, '部门修改', 1030, 3, NULL, NULL, NULL, NULL, b'0', b'0', b'0', 'system:dept:update', 2, 1, 1, NOW(), NULL, NULL),
|
(1032, '角色修改', 1030, 3, NULL, NULL, NULL, NULL, b'0', b'0', b'0', 'system:role:update', 2, 1, 1, NOW(), NULL, NULL),
|
||||||
(1033, '部门删除', 1030, 3, NULL, NULL, NULL, NULL, b'0', b'0', b'0', 'system:dept:delete', 3, 1, 1, NOW(), NULL, NULL),
|
(1033, '角色删除', 1030, 3, NULL, NULL, NULL, NULL, b'0', b'0', b'0', 'system:role:delete', 3, 1, 1, NOW(), NULL, NULL),
|
||||||
(1034, '部门导出', 1030, 3, NULL, NULL, NULL, NULL, b'0', b'0', b'0', 'system:dept:export', 4, 1, 1, NOW(), NULL, NULL),
|
(1034, '角色导出', 1030, 3, NULL, NULL, NULL, NULL, b'0', b'0', b'0', 'system:role:export', 4, 1, 1, NOW(), NULL, NULL),
|
||||||
(1900, '菜单管理', 1000, 2, '/system/menu', 'Menu', 'system/menu/index', 'menu', b'0', b'0', b'0', 'system:menu:list', 999, 1, 1, NOW(), NULL, NULL),
|
(1040, '菜单管理', 1000, 2, '/system/menu', 'Menu', 'system/menu/index', 'menu', b'0', b'0', b'0', 'system:menu:list', 4, 1, 1, NOW(), NULL, NULL),
|
||||||
(1901, '菜单新增', 1900, 3, NULL, NULL, NULL, NULL, b'0', b'0', b'0', 'system:menu:add', 1, 1, 1, NOW(), NULL, NULL),
|
(1041, '菜单新增', 1040, 3, NULL, NULL, NULL, NULL, b'0', b'0', b'0', 'system:menu:add', 1, 1, 1, NOW(), NULL, NULL),
|
||||||
(1902, '菜单修改', 1900, 3, NULL, NULL, NULL, NULL, b'0', b'0', b'0', 'system:menu:update', 2, 1, 1, NOW(), NULL, NULL),
|
(1042, '菜单修改', 1040, 3, NULL, NULL, NULL, NULL, b'0', b'0', b'0', 'system:menu:update', 2, 1, 1, NOW(), NULL, NULL),
|
||||||
(1903, '菜单删除', 1900, 3, NULL, NULL, NULL, NULL, b'0', b'0', b'0', 'system:menu:delete', 3, 1, 1, NOW(), NULL, NULL),
|
(1043, '菜单删除', 1040, 3, NULL, NULL, NULL, NULL, b'0', b'0', b'0', 'system:menu:delete', 3, 1, 1, NOW(), NULL, NULL),
|
||||||
(1904, '菜单导出', 1900, 3, NULL, NULL, NULL, NULL, b'0', b'0', b'0', 'system:menu:export', 4, 1, 1, NOW(), NULL, NULL),
|
(1044, '菜单导出', 1040, 3, NULL, NULL, NULL, NULL, b'0', b'0', b'0', 'system:menu:export', 4, 1, 1, NOW(), NULL, NULL),
|
||||||
(9000, '系统监控', 0, 1, '/monitor', 'Monitor', NULL, 'computer', b'0', b'0', b'0', NULL, 899, 1, 1, NOW(), NULL, NULL),
|
(9000, '系统监控', 0, 1, '/monitor', 'Monitor', NULL, 'computer', b'0', b'0', b'0', NULL, 899, 1, 1, NOW(), NULL, NULL),
|
||||||
(9010, '在线用户', 9000, 2, '/monitor/online', 'OnlineUser', 'monitor/online/index', 'anonymity', b'0', b'0', b'0', 'monitor:online:user:list', 1, 1, 1, NOW(), NULL, NULL),
|
(9010, '在线用户', 9000, 2, '/monitor/online', 'OnlineUser', 'monitor/online/index', 'anonymity', b'0', b'0', b'0', 'monitor:online:user:list', 1, 1, 1, NOW(), NULL, NULL),
|
||||||
(9011, '强退用户', 9010, 3, NULL, NULL, NULL, NULL, b'0', b'0', b'0', 'monitor:online:user:delete', 1, 1, 1, NOW(), NULL, NULL),
|
(9011, '强退用户', 9010, 3, NULL, NULL, NULL, NULL, b'0', b'0', b'0', 'monitor:online:user:delete', 1, 1, 1, NOW(), NULL, NULL),
|
||||||
|
@ -1,13 +1,14 @@
|
|||||||
-- liquibase formatted sql
|
-- liquibase formatted sql
|
||||||
|
|
||||||
-- changeset Charles7c:1
|
-- changeset Charles7c:1
|
||||||
|
-- 初始化默认菜单
|
||||||
INSERT IGNORE INTO `sys_menu`
|
INSERT IGNORE INTO `sys_menu`
|
||||||
(`id`, `title`, `parent_id`, `type`, `path`, `name`, `component`, `icon`, `is_external`, `is_cache`, `is_hidden`, `permission`, `sort`, `status`, `create_user`, `create_time`, `update_user`, `update_time`)
|
(`id`, `title`, `parent_id`, `type`, `path`, `name`, `component`, `icon`, `is_external`, `is_cache`, `is_hidden`, `permission`, `sort`, `status`, `create_user`, `create_time`, `update_user`, `update_time`)
|
||||||
VALUES
|
VALUES
|
||||||
(1040, '公告管理', 1000, 2, '/system/announcement', 'Announcement', 'system/announcement/index', 'advertising', b'0', b'0', b'0', 'system:announcement:list', 4, 1, 1, NOW(), NULL, NULL),
|
(1050, '公告管理', 1000, 2, '/system/announcement', 'Announcement', 'system/announcement/index', 'advertising', b'0', b'0', b'0', 'system:announcement:list', 5, 1, 1, NOW(), NULL, NULL),
|
||||||
(1041, '公告新增', 1040, 3, NULL, NULL, NULL, NULL, b'0', b'0', b'0', 'system:announcement:add', 1, 1, 1, NOW(), NULL, NULL),
|
(1051, '公告新增', 1050, 3, NULL, NULL, NULL, NULL, b'0', b'0', b'0', 'system:announcement:add', 1, 1, 1, NOW(), NULL, NULL),
|
||||||
(1042, '公告修改', 1040, 3, NULL, NULL, NULL, NULL, b'0', b'0', b'0', 'system:announcement:update', 2, 1, 1, NOW(), NULL, NULL),
|
(1052, '公告修改', 1050, 3, NULL, NULL, NULL, NULL, b'0', b'0', b'0', 'system:announcement:update', 2, 1, 1, NOW(), NULL, NULL),
|
||||||
(1043, '公告删除', 1040, 3, NULL, NULL, NULL, NULL, b'0', b'0', b'0', 'system:announcement:delete', 3, 1, 1, NOW(), NULL, NULL),
|
(1053, '公告删除', 1050, 3, NULL, NULL, NULL, NULL, b'0', b'0', b'0', 'system:announcement:delete', 3, 1, 1, NOW(), NULL, NULL),
|
||||||
(1044, '公告导出', 1040, 3, NULL, NULL, NULL, NULL, b'0', b'0', b'0', 'system:announcement:export', 4, 1, 1, NOW(), NULL, NULL),
|
(1054, '公告导出', 1050, 3, NULL, NULL, NULL, NULL, b'0', b'0', b'0', 'system:announcement:export', 4, 1, 1, NOW(), NULL, NULL),
|
||||||
(2000, '系统工具', 0, 1, '/tool', 'Tool', NULL, 'tool', b'0', b'0', b'0', NULL, 2, 1, 1, NOW(), NULL, NULL),
|
(2000, '系统工具', 0, 1, '/tool', 'Tool', NULL, 'tool', b'0', b'0', b'0', NULL, 2, 1, 1, NOW(), NULL, NULL),
|
||||||
(2010, '代码生成', 2000, 2, '/tool/generator', 'Generator', 'tool/generator/index', 'code', b'0', b'0', b'0', 'tool:generator:list', 1, 1, 1, NOW(), NULL, NULL);
|
(2010, '代码生成', 2000, 2, '/tool/generator', 'Generator', 'tool/generator/index', 'code', b'0', b'0', b'0', 'tool:generator:list', 1, 1, 1, NOW(), NULL, NULL);
|
@ -0,0 +1,2 @@
|
|||||||
|
-- liquibase formatted sql
|
||||||
|
|
@ -0,0 +1,25 @@
|
|||||||
|
-- liquibase formatted sql
|
||||||
|
|
||||||
|
-- changeset Charles7c:1
|
||||||
|
-- 初始化默认菜单
|
||||||
|
INSERT IGNORE INTO `sys_menu`
|
||||||
|
(`id`, `title`, `parent_id`, `type`, `path`, `name`, `component`, `icon`, `is_external`, `is_cache`, `is_hidden`, `permission`, `sort`, `status`, `create_user`, `create_time`, `update_user`, `update_time`)
|
||||||
|
VALUES
|
||||||
|
(1060, '字典管理', 1000, 2, '/system/dict', 'Dict', 'system/dict/index', 'bookmark', b'0', b'0', b'0', 'system:dict:list', 6, 1, 1, NOW(), NULL, NULL),
|
||||||
|
(1061, '字典新增', 1060, 3, NULL, NULL, NULL, NULL, b'0', b'0', b'0', 'system:dict:add', 1, 1, 1, NOW(), NULL, NULL),
|
||||||
|
(1062, '字典修改', 1060, 3, NULL, NULL, NULL, NULL, b'0', b'0', b'0', 'system:dict:update', 2, 1, 1, NOW(), NULL, NULL),
|
||||||
|
(1063, '字典删除', 1060, 3, NULL, NULL, NULL, NULL, b'0', b'0', b'0', 'system:dict:delete', 3, 1, 1, NOW(), NULL, NULL),
|
||||||
|
(1064, '字典导出', 1060, 3, NULL, NULL, NULL, NULL, b'0', b'0', b'0', 'system:dict:export', 4, 1, 1, NOW(), NULL, NULL);
|
||||||
|
|
||||||
|
-- 初始化默认字典
|
||||||
|
INSERT IGNORE INTO `sys_dict`
|
||||||
|
(`id`, `name`, `code`, `description`, `create_user`, `create_time`, `update_user`, `update_time`)
|
||||||
|
VALUES
|
||||||
|
(1, '公告类型', 'announcement_type', NULL, 1, NOW(), NULL, NULL);
|
||||||
|
|
||||||
|
-- 初始化默认字典项
|
||||||
|
INSERT IGNORE INTO `sys_dict_item`
|
||||||
|
(`id`, `label`, `value`, `color`, `sort`, `description`, `dict_id`, `create_user`, `create_time`, `update_user`, `update_time`)
|
||||||
|
VALUES
|
||||||
|
(1, '通知', '1', 'blue', 1, NULL, 1, 1, NOW(), NULL, NULL),
|
||||||
|
(2, '活动', '2', 'orangered', 2, NULL, 1, 1, NOW(), NULL, NULL);
|
@ -0,0 +1,35 @@
|
|||||||
|
-- liquibase formatted sql
|
||||||
|
|
||||||
|
-- changeset Charles7c:1
|
||||||
|
CREATE TABLE IF NOT EXISTS `sys_dict` (
|
||||||
|
`id` bigint(20) UNSIGNED AUTO_INCREMENT COMMENT 'ID',
|
||||||
|
`name` varchar(50) NOT NULL COMMENT '字典名称',
|
||||||
|
`code` varchar(50) NOT NULL COMMENT '字典编码',
|
||||||
|
`description` varchar(512) DEFAULT NULL COMMENT '描述',
|
||||||
|
`create_user` bigint(20) UNSIGNED NOT NULL COMMENT '创建人',
|
||||||
|
`create_time` datetime NOT NULL COMMENT '创建时间',
|
||||||
|
`update_user` bigint(20) UNSIGNED DEFAULT NULL COMMENT '修改人',
|
||||||
|
`update_time` datetime DEFAULT NULL COMMENT '修改时间',
|
||||||
|
PRIMARY KEY (`id`) USING BTREE,
|
||||||
|
UNIQUE INDEX `uk_name`(`name`) USING BTREE,
|
||||||
|
UNIQUE INDEX `uk_code`(`code`) USING BTREE
|
||||||
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='字典表';
|
||||||
|
|
||||||
|
CREATE TABLE IF NOT EXISTS `sys_dict_item` (
|
||||||
|
`id` bigint(20) UNSIGNED AUTO_INCREMENT COMMENT 'ID',
|
||||||
|
`label` varchar(50) NOT NULL COMMENT '字典标签',
|
||||||
|
`value` varchar(50) NOT NULL COMMENT '字典值',
|
||||||
|
`color` varchar(20) DEFAULT NULL COMMENT '背景颜色',
|
||||||
|
`sort` int(11) UNSIGNED DEFAULT 999 COMMENT '字典项排序',
|
||||||
|
`description` varchar(512) DEFAULT NULL COMMENT '描述',
|
||||||
|
`dict_id` bigint(20) UNSIGNED NOT NULL COMMENT '字典ID',
|
||||||
|
`create_user` bigint(20) UNSIGNED NOT NULL COMMENT '创建人',
|
||||||
|
`create_time` datetime NOT NULL COMMENT '创建时间',
|
||||||
|
`update_user` bigint(20) UNSIGNED DEFAULT NULL COMMENT '修改人',
|
||||||
|
`update_time` datetime DEFAULT NULL COMMENT '修改时间',
|
||||||
|
PRIMARY KEY (`id`) USING BTREE,
|
||||||
|
UNIQUE INDEX `uk_value_dict_id`(`value`, `dict_id`) USING BTREE,
|
||||||
|
INDEX `idx_dict_id`(`dict_id`) USING BTREE,
|
||||||
|
INDEX `idx_create_user`(`create_user`) USING BTREE,
|
||||||
|
INDEX `idx_update_user`(`update_user`) USING BTREE
|
||||||
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='字典项表';
|
Loading…
Reference in New Issue
Block a user