From c39f17103e9f12f68e5863b03cdd9868e8f492fb Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E8=B5=B5=E5=BF=A0=E6=9E=97?= <170083662@qq.com> Date: Tue, 27 Aug 2024 15:31:58 +0800 Subject: [PATCH] =?UTF-8?q?=E6=96=B0=E5=A2=9E=E5=85=AC=E5=85=B1=E7=9A=84?= =?UTF-8?q?=E7=BD=91=E7=AB=99=E5=8F=82=E6=95=B0=E6=95=B0=E6=8D=AE=E6=BA=90?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../controller/WebsiteFieldController.java | 143 ++++++++++++++++++ .../common/system/entity/WebsiteField.java | 64 ++++++++ .../system/mapper/WebsiteFieldMapper.java | 37 +++++ .../system/mapper/xml/WebsiteFieldMapper.xml | 62 ++++++++ .../system/param/WebsiteFieldParam.java | 56 +++++++ .../system/service/WebsiteFieldService.java | 42 +++++ .../service/impl/WebsiteFieldServiceImpl.java | 47 ++++++ 7 files changed, 451 insertions(+) create mode 100644 src/main/java/com/gxwebsoft/common/system/controller/WebsiteFieldController.java create mode 100644 src/main/java/com/gxwebsoft/common/system/entity/WebsiteField.java create mode 100644 src/main/java/com/gxwebsoft/common/system/mapper/WebsiteFieldMapper.java create mode 100644 src/main/java/com/gxwebsoft/common/system/mapper/xml/WebsiteFieldMapper.xml create mode 100644 src/main/java/com/gxwebsoft/common/system/param/WebsiteFieldParam.java create mode 100644 src/main/java/com/gxwebsoft/common/system/service/WebsiteFieldService.java create mode 100644 src/main/java/com/gxwebsoft/common/system/service/impl/WebsiteFieldServiceImpl.java diff --git a/src/main/java/com/gxwebsoft/common/system/controller/WebsiteFieldController.java b/src/main/java/com/gxwebsoft/common/system/controller/WebsiteFieldController.java new file mode 100644 index 0000000..4c27bea --- /dev/null +++ b/src/main/java/com/gxwebsoft/common/system/controller/WebsiteFieldController.java @@ -0,0 +1,143 @@ +package com.gxwebsoft.common.system.controller; + +import com.gxwebsoft.common.core.web.BaseController; +import com.gxwebsoft.common.system.entity.User; +import com.gxwebsoft.common.system.service.WebsiteFieldService; +import com.gxwebsoft.common.system.entity.WebsiteField; +import com.gxwebsoft.common.system.param.WebsiteFieldParam; +import com.gxwebsoft.common.core.web.ApiResult; +import com.gxwebsoft.common.core.web.PageResult; +import com.gxwebsoft.common.core.web.PageParam; +import com.gxwebsoft.common.core.web.BatchParam; +import com.gxwebsoft.common.core.annotation.OperationLog; +import io.swagger.annotations.Api; +import io.swagger.annotations.ApiOperation; +import org.springframework.security.access.prepost.PreAuthorize; +import org.springframework.web.bind.annotation.*; + +import javax.annotation.Resource; +import java.util.HashMap; +import java.util.List; + +/** + * 应用参数控制器 + * + * @author 科技小王子 + * @since 2024-08-27 15:18:05 + */ +@Api(tags = "应用参数管理") +@RestController +@RequestMapping("/api/system/website-field") +public class WebsiteFieldController extends BaseController { + @Resource + private WebsiteFieldService websiteFieldService; + + @ApiOperation("分页查询应用参数") + @GetMapping("/page") + public ApiResult> page(WebsiteFieldParam param) { + PageParam page = new PageParam<>(param); + page.setDefaultOrder("create_time desc"); + return success(websiteFieldService.page(page, page.getWrapper())); + // 使用关联查询 + //return success(websiteFieldService.pageRel(param)); + } + + @ApiOperation("查询全部应用参数") + @GetMapping() + public ApiResult> list(WebsiteFieldParam param) { + PageParam page = new PageParam<>(param); + page.setDefaultOrder("create_time desc"); + return success(websiteFieldService.list(page.getOrderWrapper())); + // 使用关联查询 + //return success(websiteFieldService.listRel(param)); + } + + @ApiOperation("根据id查询应用参数") + @GetMapping("/{id}") + public ApiResult get(@PathVariable("id") Integer id) { + return success(websiteFieldService.getById(id)); + // 使用关联查询 + //return success(websiteFieldService.getByIdRel(id)); + } + + @PreAuthorize("hasAuthority('system:websiteField:save')") + @OperationLog + @ApiOperation("添加应用参数") + @PostMapping() + public ApiResult save(@RequestBody WebsiteField websiteField) { + if (websiteFieldService.save(websiteField)) { + return success("添加成功"); + } + return fail("添加失败"); + } + + @PreAuthorize("hasAuthority('system:websiteField:update')") + @OperationLog + @ApiOperation("修改应用参数") + @PutMapping() + public ApiResult update(@RequestBody WebsiteField websiteField) { + if (websiteFieldService.updateById(websiteField)) { + return success("修改成功"); + } + return fail("修改失败"); + } + + @PreAuthorize("hasAuthority('system:websiteField:remove')") + @OperationLog + @ApiOperation("删除应用参数") + @DeleteMapping("/{id}") + public ApiResult remove(@PathVariable("id") Integer id) { + if (websiteFieldService.removeById(id)) { + return success("删除成功"); + } + return fail("删除失败"); + } + + @PreAuthorize("hasAuthority('system:websiteField:save')") + @OperationLog + @ApiOperation("批量添加应用参数") + @PostMapping("/batch") + public ApiResult saveBatch(@RequestBody List list) { + if (websiteFieldService.saveBatch(list)) { + return success("添加成功"); + } + return fail("添加失败"); + } + + @PreAuthorize("hasAuthority('system:websiteField:update')") + @OperationLog + @ApiOperation("批量修改应用参数") + @PutMapping("/batch") + public ApiResult removeBatch(@RequestBody BatchParam batchParam) { + if (batchParam.update(websiteFieldService, "id")) { + return success("修改成功"); + } + return fail("修改失败"); + } + + @PreAuthorize("hasAuthority('system:websiteField:remove')") + @OperationLog + @ApiOperation("批量删除应用参数") + @DeleteMapping("/batch") + public ApiResult removeBatch(@RequestBody List ids) { + if (websiteFieldService.removeByIds(ids)) { + return success("删除成功"); + } + return fail("删除失败"); + } + + @ApiOperation("获取网站配置参数-对象形式") + @GetMapping("/config") + public ApiResult getConfig(WebsiteFieldParam param) { + // 使用关联查询 + final List fields = websiteFieldService.listRel(param); + + HashMap config = new HashMap<>(); + fields.forEach(d -> { + config.put(d.getName(), d.getValue()); + }); + System.out.println("config = " + config); + return success(config); + } + +} diff --git a/src/main/java/com/gxwebsoft/common/system/entity/WebsiteField.java b/src/main/java/com/gxwebsoft/common/system/entity/WebsiteField.java new file mode 100644 index 0000000..64563a9 --- /dev/null +++ b/src/main/java/com/gxwebsoft/common/system/entity/WebsiteField.java @@ -0,0 +1,64 @@ +package com.gxwebsoft.common.system.entity; + +import com.baomidou.mybatisplus.annotation.TableName; +import com.baomidou.mybatisplus.annotation.IdType; +import com.baomidou.mybatisplus.annotation.TableId; +import java.time.LocalDateTime; +import com.baomidou.mybatisplus.annotation.TableLogic; +import java.io.Serializable; +import java.util.Date; + +import io.swagger.annotations.ApiModel; +import io.swagger.annotations.ApiModelProperty; +import lombok.Data; +import lombok.EqualsAndHashCode; + +/** + * 应用参数 + * + * @author 科技小王子 + * @since 2024-08-27 15:18:05 + */ +@Data +@EqualsAndHashCode(callSuper = false) +@ApiModel(value = "WebsiteField对象", description = "应用参数") +@TableName("sys_website_field") +public class WebsiteField implements Serializable { + private static final long serialVersionUID = 1L; + + @ApiModelProperty(value = "自增ID") + @TableId(value = "id", type = IdType.AUTO) + private Integer id; + + @ApiModelProperty(value = "类型,0文本 1图片 2其他") + private Integer type; + + @ApiModelProperty(value = "名称") + private String name; + + @ApiModelProperty(value = "默认值") + private String defaultValue; + + @ApiModelProperty(value = "可修改的值 [on|off]") + private String modifyRange; + + @ApiModelProperty(value = "备注") + private String comments; + + @ApiModelProperty(value = "名称") + private String value; + + @ApiModelProperty(value = "排序(数字越小越靠前)") + private Integer sortNumber; + + @ApiModelProperty(value = "是否删除, 0否, 1是") + @TableLogic + private Integer deleted; + + @ApiModelProperty(value = "租户id") + private Integer tenantId; + + @ApiModelProperty(value = "创建时间") + private Date createTime; + +} diff --git a/src/main/java/com/gxwebsoft/common/system/mapper/WebsiteFieldMapper.java b/src/main/java/com/gxwebsoft/common/system/mapper/WebsiteFieldMapper.java new file mode 100644 index 0000000..2e15906 --- /dev/null +++ b/src/main/java/com/gxwebsoft/common/system/mapper/WebsiteFieldMapper.java @@ -0,0 +1,37 @@ +package com.gxwebsoft.common.system.mapper; + +import com.baomidou.mybatisplus.core.mapper.BaseMapper; +import com.baomidou.mybatisplus.core.metadata.IPage; +import com.gxwebsoft.common.system.entity.WebsiteField; +import com.gxwebsoft.common.system.param.WebsiteFieldParam; +import org.apache.ibatis.annotations.Param; + +import java.util.List; + +/** + * 应用参数Mapper + * + * @author 科技小王子 + * @since 2024-08-27 15:18:05 + */ +public interface WebsiteFieldMapper extends BaseMapper { + + /** + * 分页查询 + * + * @param page 分页对象 + * @param param 查询参数 + * @return List + */ + List selectPageRel(@Param("page") IPage page, + @Param("param") WebsiteFieldParam param); + + /** + * 查询全部 + * + * @param param 查询参数 + * @return List + */ + List selectListRel(@Param("param") WebsiteFieldParam param); + +} diff --git a/src/main/java/com/gxwebsoft/common/system/mapper/xml/WebsiteFieldMapper.xml b/src/main/java/com/gxwebsoft/common/system/mapper/xml/WebsiteFieldMapper.xml new file mode 100644 index 0000000..db4dc7b --- /dev/null +++ b/src/main/java/com/gxwebsoft/common/system/mapper/xml/WebsiteFieldMapper.xml @@ -0,0 +1,62 @@ + + + + + + + SELECT a.* + FROM sys_website_field a + + + AND a.id = #{param.id} + + + AND a.type = #{param.type} + + + AND a.name LIKE CONCAT('%', #{param.name}, '%') + + + AND a.default_value LIKE CONCAT('%', #{param.defaultValue}, '%') + + + AND a.modify_range LIKE CONCAT('%', #{param.modifyRange}, '%') + + + AND a.comments LIKE CONCAT('%', #{param.comments}, '%') + + + AND a.value LIKE CONCAT('%', #{param.value}, '%') + + + AND a.sort_number = #{param.sortNumber} + + + AND a.deleted = #{param.deleted} + + + AND a.deleted = 0 + + + AND a.tenant_id = #{param.tenantId} + + + AND a.create_time >= #{param.createTimeStart} + + + AND a.create_time <= #{param.createTimeEnd} + + + + + + + + + + + diff --git a/src/main/java/com/gxwebsoft/common/system/param/WebsiteFieldParam.java b/src/main/java/com/gxwebsoft/common/system/param/WebsiteFieldParam.java new file mode 100644 index 0000000..66d0be1 --- /dev/null +++ b/src/main/java/com/gxwebsoft/common/system/param/WebsiteFieldParam.java @@ -0,0 +1,56 @@ +package com.gxwebsoft.common.system.param; + +import com.fasterxml.jackson.annotation.JsonInclude; +import com.gxwebsoft.common.core.annotation.QueryField; +import com.gxwebsoft.common.core.annotation.QueryType; +import com.gxwebsoft.common.core.web.BaseParam; +import io.swagger.annotations.ApiModel; +import io.swagger.annotations.ApiModelProperty; +import lombok.Data; +import lombok.EqualsAndHashCode; + +/** + * 应用参数查询参数 + * + * @author 科技小王子 + * @since 2024-08-27 15:18:05 + */ +@Data +@EqualsAndHashCode(callSuper = false) +@JsonInclude(JsonInclude.Include.NON_NULL) +@ApiModel(value = "WebsiteFieldParam对象", description = "应用参数查询参数") +public class WebsiteFieldParam extends BaseParam { + private static final long serialVersionUID = 1L; + + @ApiModelProperty(value = "自增ID") + @QueryField(type = QueryType.EQ) + private Integer id; + + @ApiModelProperty(value = "类型,0文本 1图片 2其他") + @QueryField(type = QueryType.EQ) + private Integer type; + + @ApiModelProperty(value = "名称") + private String name; + + @ApiModelProperty(value = "默认值") + private String defaultValue; + + @ApiModelProperty(value = "可修改的值 [on|off]") + private String modifyRange; + + @ApiModelProperty(value = "备注") + private String comments; + + @ApiModelProperty(value = "名称") + private String value; + + @ApiModelProperty(value = "排序(数字越小越靠前)") + @QueryField(type = QueryType.EQ) + private Integer sortNumber; + + @ApiModelProperty(value = "是否删除, 0否, 1是") + @QueryField(type = QueryType.EQ) + private Integer deleted; + +} diff --git a/src/main/java/com/gxwebsoft/common/system/service/WebsiteFieldService.java b/src/main/java/com/gxwebsoft/common/system/service/WebsiteFieldService.java new file mode 100644 index 0000000..efc4fcb --- /dev/null +++ b/src/main/java/com/gxwebsoft/common/system/service/WebsiteFieldService.java @@ -0,0 +1,42 @@ +package com.gxwebsoft.common.system.service; + +import com.baomidou.mybatisplus.extension.service.IService; +import com.gxwebsoft.common.core.web.PageResult; +import com.gxwebsoft.common.system.entity.WebsiteField; +import com.gxwebsoft.common.system.param.WebsiteFieldParam; + +import java.util.List; + +/** + * 应用参数Service + * + * @author 科技小王子 + * @since 2024-08-27 15:18:05 + */ +public interface WebsiteFieldService extends IService { + + /** + * 分页关联查询 + * + * @param param 查询参数 + * @return PageResult + */ + PageResult pageRel(WebsiteFieldParam param); + + /** + * 关联查询全部 + * + * @param param 查询参数 + * @return List + */ + List listRel(WebsiteFieldParam param); + + /** + * 根据id查询 + * + * @param id 自增ID + * @return WebsiteField + */ + WebsiteField getByIdRel(Integer id); + +} diff --git a/src/main/java/com/gxwebsoft/common/system/service/impl/WebsiteFieldServiceImpl.java b/src/main/java/com/gxwebsoft/common/system/service/impl/WebsiteFieldServiceImpl.java new file mode 100644 index 0000000..929e8e1 --- /dev/null +++ b/src/main/java/com/gxwebsoft/common/system/service/impl/WebsiteFieldServiceImpl.java @@ -0,0 +1,47 @@ +package com.gxwebsoft.common.system.service.impl; + +import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.gxwebsoft.common.system.mapper.WebsiteFieldMapper; +import com.gxwebsoft.common.system.service.WebsiteFieldService; +import com.gxwebsoft.common.system.entity.WebsiteField; +import com.gxwebsoft.common.system.param.WebsiteFieldParam; +import com.gxwebsoft.common.core.web.PageParam; +import com.gxwebsoft.common.core.web.PageResult; +import org.springframework.stereotype.Service; + +import java.util.List; + +/** + * 应用参数Service实现 + * + * @author 科技小王子 + * @since 2024-08-27 15:18:05 + */ +@Service +public class WebsiteFieldServiceImpl extends ServiceImpl implements WebsiteFieldService { + + @Override + public PageResult pageRel(WebsiteFieldParam param) { + PageParam page = new PageParam<>(param); + page.setDefaultOrder("sort_number asc, create_time asc"); + List list = baseMapper.selectPageRel(page, param); + return new PageResult<>(list, page.getTotal()); + } + + @Override + public List listRel(WebsiteFieldParam param) { + List list = baseMapper.selectListRel(param); + // 排序 + PageParam page = new PageParam<>(); + page.setDefaultOrder("sort_number asc, create_time asc"); + return page.sortRecords(list); + } + + @Override + public WebsiteField getByIdRel(Integer id) { + WebsiteFieldParam param = new WebsiteFieldParam(); + param.setId(id); + return param.getOne(baseMapper.selectListRel(param)); + } + +}