diff --git a/ruoyi-admin/src/main/java/com/ruoyi/system/controller/BsDistributionController.java b/ruoyi-admin/src/main/java/com/ruoyi/system/controller/BsDistributionController.java new file mode 100644 index 00000000..092ffe23 --- /dev/null +++ b/ruoyi-admin/src/main/java/com/ruoyi/system/controller/BsDistributionController.java @@ -0,0 +1,175 @@ +package com.ruoyi.system.controller; + +import com.ruoyi.common.annotation.Anonymous; +import com.ruoyi.common.annotation.Log; +import com.ruoyi.common.core.controller.BaseController; +import com.ruoyi.common.core.domain.AjaxResult; +import com.ruoyi.common.core.domain.entity.SysUser; +import com.ruoyi.common.core.page.TableDataInfo; +import com.ruoyi.common.enums.BusinessType; +import com.ruoyi.common.utils.SecurityUtils; +import com.ruoyi.common.utils.StringUtils; +import com.ruoyi.common.utils.poi.ExcelUtil; +import com.ruoyi.system.domain.BsDistribution; +import com.ruoyi.system.domain.vo.BsDistributionVO; +import com.ruoyi.system.service.IBsDistributionService; +import com.ruoyi.system.service.ISysDeptService; +import com.ruoyi.system.service.ISysRoleService; +import com.ruoyi.system.service.ISysUserService; +import org.apache.commons.lang3.ArrayUtils; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.security.access.prepost.PreAuthorize; +import org.springframework.web.bind.annotation.*; + +import javax.servlet.http.HttpServletResponse; +import java.util.List; + +/** + * 分销商信息Controller + * + * @author ruoyi + * @date 2024-11-18 + */ +@RestController +@RequestMapping("/system/distribution") +public class BsDistributionController extends BaseController +{ + @Autowired + private IBsDistributionService bsDistributionService; + + @Autowired + private ISysUserService userService; + + @Autowired + private ISysRoleService roleService; + + @Autowired + private ISysDeptService deptService; + + /** + * 查询分销商信息列表 + */ + @PreAuthorize("@ss.hasPermi('system:distribution:list')") + @GetMapping("/list") + public TableDataInfo list(BsDistribution bsDistribution) + { + startPage(); + List list = bsDistributionService.selectBsDistributionList(bsDistribution); + return getDataTable(list); + } + + /** + * 导出分销商信息列表 + */ + @PreAuthorize("@ss.hasPermi('system:distribution:export')") + @Log(title = "分销商信息", businessType = BusinessType.EXPORT) + @PostMapping("/export") + public void export(HttpServletResponse response, BsDistribution bsDistribution) + { + List list = bsDistributionService.selectBsDistributionList(bsDistribution); + ExcelUtil util = new ExcelUtil(BsDistribution.class); + util.exportExcel(response, list, "分销商信息数据"); + } + + /** + * 获取分销商信息详细信息 + */ + @PreAuthorize("@ss.hasPermi('system:distribution:query')") + @GetMapping(value = "/{id}") + public AjaxResult getInfo(@PathVariable("id") Long id) + { + return success(bsDistributionService.selectBsDistributionById(id)); + } + + /** + * 新增分销商信息 + */ + @PreAuthorize("@ss.hasPermi('system:distribution:add')") + @Log(title = "分销商信息", businessType = BusinessType.INSERT) + @PostMapping + public AjaxResult add(@RequestBody BsDistribution bsDistribution) + { + SysUser sysUser = new SysUser(); + Long[] ids = {101L}; + sysUser.setDeptId(200L); + sysUser.setNickName(bsDistribution.getName()); + sysUser.setPassword("123456"); + sysUser.setPhonenumber(bsDistribution.getPhone()); + sysUser.setUserName(bsDistribution.getPhone()); + sysUser.setRoleIds(ids); + + deptService.checkDeptDataScope(sysUser.getDeptId()); + roleService.checkRoleDataScope(sysUser.getRoleIds()); + if (!userService.checkUserNameUnique(sysUser)) + { + return error("新增用户'" + sysUser.getUserName() + "'失败,登录账号已存在"); + } + else if (StringUtils.isNotEmpty(sysUser.getPhonenumber()) && !userService.checkPhoneUnique(sysUser)) + { + return error("新增用户'" + sysUser.getUserName() + "'失败,手机号码已存在"); + } + else if (StringUtils.isNotEmpty(sysUser.getEmail()) && !userService.checkEmailUnique(sysUser)) + { + return error("新增用户'" + sysUser.getUserName() + "'失败,邮箱账号已存在"); + } + sysUser.setCreateBy(getUsername()); + sysUser.setPassword(SecurityUtils.encryptPassword(sysUser.getPassword())); + userService.insertUser(sysUser); + + return toAjax(bsDistributionService.insertBsDistribution(bsDistribution)); + } + + /** + * 修改分销商信息 + */ + @PreAuthorize("@ss.hasPermi('system:distribution:edit')") + @Log(title = "分销商信息", businessType = BusinessType.UPDATE) + @PutMapping + public AjaxResult edit(@RequestBody BsDistribution bsDistribution) + { + return toAjax(bsDistributionService.updateBsDistribution(bsDistribution)); + } + + /** + * 删除分销商信息 + */ + @PreAuthorize("@ss.hasPermi('system:distribution:remove')") + @Log(title = "分销商信息", businessType = BusinessType.DELETE) + @DeleteMapping("/{ids}") + public AjaxResult remove(@PathVariable Long[] ids) + { + List sysUserId = bsDistributionService.getSysUserId(ids); + Long[] array = sysUserId.toArray(new Long[0]); + if (ArrayUtils.contains(array, getUserId())) { + return error("当前用户不能删除"); + } + userService.deleteUserByIds(array); + return toAjax(bsDistributionService.deleteBsDistributionByIds(ids)); + } + + /** + * 查询订单信息 + */ + @GetMapping("disAllOrder") + public TableDataInfo disAllOrder(BsDistribution bsDistribution) + { + startPage(); + List list = bsDistributionService.disAllOrder(bsDistribution); + return getDataTable(list); + } + + /** + * 查询分销商信息 + */ + @GetMapping("/getDisMsg") + public AjaxResult getDisMsg() + { + String phone = getLoginUser().getUser().getPhonenumber(); + BsDistribution bsDistribution = bsDistributionService.selectOneMsg(phone); + if(bsDistribution == null){ + return success(""); + } + return success(bsDistribution.getId()); + } + +} diff --git a/ruoyi-admin/src/main/java/com/ruoyi/system/controller/BsOrderController.java b/ruoyi-admin/src/main/java/com/ruoyi/system/controller/BsOrderController.java index 6d28bd08..cb7b3f32 100644 --- a/ruoyi-admin/src/main/java/com/ruoyi/system/controller/BsOrderController.java +++ b/ruoyi-admin/src/main/java/com/ruoyi/system/controller/BsOrderController.java @@ -1,7 +1,13 @@ package com.ruoyi.system.controller; +import java.util.Collections; import java.util.List; import javax.servlet.http.HttpServletResponse; + +import com.ruoyi.system.domain.BsDistribution; +import com.ruoyi.system.domain.dto.BsOrderDTO; +import com.ruoyi.system.domain.vo.BsOrdersVO; +import com.ruoyi.system.service.IBsDistributionService; import org.springframework.security.access.prepost.PreAuthorize; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.GetMapping; @@ -34,6 +40,9 @@ public class BsOrderController extends BaseController @Autowired private IBsOrderService bsOrderService; + @Autowired + private IBsDistributionService bsDistributionService; + /** * 查询订单列表 */ @@ -131,4 +140,31 @@ public class BsOrderController extends BaseController { return success(bsOrderService.userGetOrder(orderNo)); } + + /** + * 查询订单信息(包含分销商信息) + */ + @GetMapping("/allOrderList") + public TableDataInfo allOrderList(BsOrderDTO bsOrderDTO) + { + startPage(); + List list = bsOrderService.selectAllList(bsOrderDTO); + return getDataTable(list); + } + + /** + * 分销商查询订单信息 + */ + @GetMapping("/distributionOrder") + public TableDataInfo distributionGetOrder(){ + String phonenumber = getLoginUser().getUser().getPhonenumber(); + BsDistribution bsDistribution = bsDistributionService.selectOneMsg(phonenumber); + if (bsDistribution == null) { + // 返回空数据,或者可以返回一个特定的错误信息 + return getDataTable(Collections.emptyList()); + } + Long id = bsDistribution.getId(); + List list = bsOrderService.distributionGetOrder(id.intValue()); + return getDataTable(list); + } } diff --git a/ruoyi-admin/src/main/java/com/ruoyi/system/domain/BsDistribution.java b/ruoyi-admin/src/main/java/com/ruoyi/system/domain/BsDistribution.java new file mode 100644 index 00000000..9b3b1146 --- /dev/null +++ b/ruoyi-admin/src/main/java/com/ruoyi/system/domain/BsDistribution.java @@ -0,0 +1,94 @@ +package com.ruoyi.system.domain; + +import com.ruoyi.common.annotation.Excel; +import com.ruoyi.common.core.domain.BaseEntity; +import org.apache.commons.lang3.builder.ToStringBuilder; +import org.apache.commons.lang3.builder.ToStringStyle; + +/** + * 分销商信息对象 bs_distribution + * + * @author ruoyi + * @date 2024-11-18 + */ +public class BsDistribution extends BaseEntity +{ + private static final long serialVersionUID = 1L; + + /** 主键id */ + private Long id; + + /** 姓名 */ + @Excel(name = "姓名") + private String name; + + /** 联系方式 */ + @Excel(name = "联系方式") + private String phone; + + /** 来源 */ + @Excel(name = "来源") + private String source; + + /** 提成 */ + @Excel(name = "提成") + private Long commission; + + public void setId(Long id) + { + this.id = id; + } + + public Long getId() + { + return id; + } + public void setName(String name) + { + this.name = name; + } + + public String getName() + { + return name; + } + public void setPhone(String phone) + { + this.phone = phone; + } + + public String getPhone() + { + return phone; + } + public void setSource(String source) + { + this.source = source; + } + + public String getSource() + { + return source; + } + public void setCommission(Long commission) + { + this.commission = commission; + } + + public Long getCommission() + { + return commission; + } + + @Override + public String toString() { + return new ToStringBuilder(this,ToStringStyle.MULTI_LINE_STYLE) + .append("id", getId()) + .append("name", getName()) + .append("phone", getPhone()) + .append("source", getSource()) + .append("remark", getRemark()) + .append("commission", getCommission()) + .toString(); + } +} diff --git a/ruoyi-admin/src/main/java/com/ruoyi/system/domain/BsOrder.java b/ruoyi-admin/src/main/java/com/ruoyi/system/domain/BsOrder.java index face386a..bf88cb54 100644 --- a/ruoyi-admin/src/main/java/com/ruoyi/system/domain/BsOrder.java +++ b/ruoyi-admin/src/main/java/com/ruoyi/system/domain/BsOrder.java @@ -2,6 +2,7 @@ package com.ruoyi.system.domain; import java.math.BigDecimal; import java.util.Date; + import com.fasterxml.jackson.annotation.JsonFormat; import org.apache.commons.lang3.builder.ToStringBuilder; import org.apache.commons.lang3.builder.ToStringStyle; @@ -14,129 +15,149 @@ import com.ruoyi.common.core.domain.BaseEntity; * @author ruoyi * @date 2024-10-25 */ -public class BsOrder extends BaseEntity -{ +public class BsOrder extends BaseEntity { private static final long serialVersionUID = 1L; - /** 主键 */ + /** + * 主键 + */ private Long id; - /** 商户单号 */ + /** + * 商户单号 + */ @Excel(name = "商户单号") private String orderNo; - /** 订单号 */ + /** + * 订单号 + */ @Excel(name = "交易流水号") private String transactionId; - /** 1:微信,2:支付宝 */ + /** + * 1:微信,2:支付宝 + */ @Excel(name = "1:微信,2:支付宝") private Long channel; - /** 支付时间 */ + /** + * 支付时间 + */ @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss") @Excel(name = "支付时间", width = 50, dateFormat = "yyyy-MM-dd HH:mm:ss") private Date payTime; - /** 创建时间 */ + /** + * 创建时间 + */ @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss") @Excel(name = "创建时间", width = 50, dateFormat = "yyyy-MM-dd HH:mm:ss") private Date createTime; - /** 商品名称 */ + /** + * 商品名称 + */ @Excel(name = "商品名称") private String goodsName; - /** 商品id */ + /** + * 商品id + */ @Excel(name = "商品id") private Long goodsmin; - /** 订单价格 */ + /** + * 订单价格 + */ @Excel(name = "订单价格") private BigDecimal price; - /** 购买人id */ + /** + * 购买人id + */ @Excel(name = "购买人id") private String createId; - /** 支付状态 */ + /** + * 支付状态 + */ @Excel(name = "支付状态") private int payStatus; - /** 购买人openid */ + /** + * 购买人openid + */ @Excel(name = "购买人openid") private String openid; - public void setId(Long id) - { + /** + * 分销商id + */ + @Excel(name = "分销商id") + private int distributor; + + public void setId(Long id) { this.id = id; } - public Long getId() - { + public Long getId() { return id; } - public void setOrderNo(String orderNo) - { + + public void setOrderNo(String orderNo) { this.orderNo = orderNo; } - public String getOrderNo() - { + public String getOrderNo() { return orderNo; } - public void setChannel(Long channel) - { + + public void setChannel(Long channel) { this.channel = channel; } - public Long getChannel() - { + public Long getChannel() { return channel; } - public void setPayTime(Date payTime) - { + + public void setPayTime(Date payTime) { this.payTime = payTime; } - public Date getPayTime() - { + public Date getPayTime() { return payTime; } - public void setGoodsName(String goodsName) - { + + public void setGoodsName(String goodsName) { this.goodsName = goodsName; } - public String getGoodsName() - { + public String getGoodsName() { return goodsName; } - public void setGoodsmin(Long goodsmin) - { + + public void setGoodsmin(Long goodsmin) { this.goodsmin = goodsmin; } - public Long getGoodsmin() - { + public Long getGoodsmin() { return goodsmin; } - public void setPrice(BigDecimal price) - { + + public void setPrice(BigDecimal price) { this.price = price; } - public BigDecimal getPrice() - { + public BigDecimal getPrice() { return price; } - public void setCreateId(String createId) - { + + public void setCreateId(String createId) { this.createId = createId; } - public String getCreateId() - { + public String getCreateId() { return createId; } @@ -174,21 +195,30 @@ public class BsOrder extends BaseEntity this.openid = openid; } + public int getDistributor() { + return distributor; + } + + public void setDistributor(int distributor) { + this.distributor = distributor; + } + @Override public String toString() { - return new ToStringBuilder(this,ToStringStyle.MULTI_LINE_STYLE) - .append("id", getId()) - .append("orderNo", getOrderNo()) - .append("channel", getChannel()) - .append("payTime", getPayTime()) - .append("goodsName", getGoodsName()) - .append("goodsmin", getGoodsmin()) - .append("price", getPrice()) - .append("createId", getCreateId()) - .append("createTime", getCreateTime()) - .append("payStatus", getPayStatus()) - .append("openid", getOpenid()) - .append("transactionId", getTransactionId()) - .toString(); + return new ToStringBuilder(this, ToStringStyle.MULTI_LINE_STYLE) + .append("id", getId()) + .append("orderNo", getOrderNo()) + .append("channel", getChannel()) + .append("payTime", getPayTime()) + .append("goodsName", getGoodsName()) + .append("goodsmin", getGoodsmin()) + .append("price", getPrice()) + .append("createId", getCreateId()) + .append("createTime", getCreateTime()) + .append("payStatus", getPayStatus()) + .append("openid", getOpenid()) + .append("transactionId", getTransactionId()) + .append("distributor", getDistributor()) + .toString(); } } diff --git a/ruoyi-admin/src/main/java/com/ruoyi/system/domain/dto/BsOrderDTO.java b/ruoyi-admin/src/main/java/com/ruoyi/system/domain/dto/BsOrderDTO.java new file mode 100644 index 00000000..c4071dcb --- /dev/null +++ b/ruoyi-admin/src/main/java/com/ruoyi/system/domain/dto/BsOrderDTO.java @@ -0,0 +1,27 @@ +package com.ruoyi.system.domain.dto; + +import com.ruoyi.system.domain.BsOrder; +import lombok.AllArgsConstructor; +import lombok.Data; +import lombok.NoArgsConstructor; + +@Data +@AllArgsConstructor +@NoArgsConstructor +public class BsOrderDTO extends BsOrder { + + /** + * 分销商姓名 + */ + private String distributionName; + + /** + * 分销商联系方式 + */ + private String distributionPhone; + + /** + * 分销商distributionId + */ + private Long distributionId; +} diff --git a/ruoyi-admin/src/main/java/com/ruoyi/system/domain/vo/BsDistributionVO.java b/ruoyi-admin/src/main/java/com/ruoyi/system/domain/vo/BsDistributionVO.java new file mode 100644 index 00000000..35ff4121 --- /dev/null +++ b/ruoyi-admin/src/main/java/com/ruoyi/system/domain/vo/BsDistributionVO.java @@ -0,0 +1,16 @@ +package com.ruoyi.system.domain.vo; + +import com.ruoyi.system.domain.BsDistribution; +import lombok.AllArgsConstructor; +import lombok.Data; +import lombok.NoArgsConstructor; + +@Data +@AllArgsConstructor +@NoArgsConstructor +public class BsDistributionVO extends BsDistribution { + + private int allOrderCount; + + private int monthOrderCount; +} diff --git a/ruoyi-admin/src/main/java/com/ruoyi/system/domain/vo/BsOrdersVO.java b/ruoyi-admin/src/main/java/com/ruoyi/system/domain/vo/BsOrdersVO.java new file mode 100644 index 00000000..02aee320 --- /dev/null +++ b/ruoyi-admin/src/main/java/com/ruoyi/system/domain/vo/BsOrdersVO.java @@ -0,0 +1,27 @@ +package com.ruoyi.system.domain.vo; + +import com.ruoyi.system.domain.BsOrder; +import lombok.AllArgsConstructor; +import lombok.Data; +import lombok.NoArgsConstructor; + +@Data +@AllArgsConstructor +@NoArgsConstructor +public class BsOrdersVO extends BsOrder { + + /** + * 分销商姓名 + */ + private String distributionName; + + /** + * 分销商联系方式 + */ + private String distributionPhone; + + /** + * 分销商distributionId + */ + private Long distributionId; +} diff --git a/ruoyi-admin/src/main/java/com/ruoyi/system/mapper/BsDistributionMapper.java b/ruoyi-admin/src/main/java/com/ruoyi/system/mapper/BsDistributionMapper.java new file mode 100644 index 00000000..b85ef8fc --- /dev/null +++ b/ruoyi-admin/src/main/java/com/ruoyi/system/mapper/BsDistributionMapper.java @@ -0,0 +1,85 @@ +package com.ruoyi.system.mapper; + +import com.ruoyi.system.domain.BsDistribution; +import com.ruoyi.system.domain.vo.BsDistributionVO; +import org.apache.ibatis.annotations.Param; + +import java.util.List; + +/** + * 分销商信息Mapper接口 + * + * @author ruoyi + * @date 2024-11-18 + */ +public interface BsDistributionMapper +{ + /** + * 查询分销商信息 + * + * @param id 分销商信息主键 + * @return 分销商信息 + */ + public BsDistribution selectBsDistributionById(Long id); + + /** + * 查询分销商信息列表 + * + * @param bsDistribution 分销商信息 + * @return 分销商信息集合 + */ + public List selectBsDistributionList(BsDistribution bsDistribution); + + /** + * 新增分销商信息 + * + * @param bsDistribution 分销商信息 + * @return 结果 + */ + public int insertBsDistribution(BsDistribution bsDistribution); + + /** + * 修改分销商信息 + * + * @param bsDistribution 分销商信息 + * @return 结果 + */ + public int updateBsDistribution(BsDistribution bsDistribution); + + /** + * 删除分销商信息 + * + * @param id 分销商信息主键 + * @return 结果 + */ + public int deleteBsDistributionById(Long id); + + /** + * 批量删除分销商信息 + * + * @param ids 需要删除的数据主键集合 + * @return 结果 + */ + public int deleteBsDistributionByIds(Long[] ids); + + + /** + * 根据手机号查询分销商信息 + */ + public BsDistribution selectOneMsg(String phone); + + /** + * 查询分销商所有订单信息 + */ + public List disAllOrder(BsDistribution bsDistribution); + + /** + * 根据手机号查询分销商信息是否存在 + */ + public boolean existsByPhone(@Param("phone") String phone, @Param("id") Long id); + + /** + * 联合删除用户信息 + */ + public List getSysUserId(Long[] ids); +} diff --git a/ruoyi-admin/src/main/java/com/ruoyi/system/mapper/BsOrderMapper.java b/ruoyi-admin/src/main/java/com/ruoyi/system/mapper/BsOrderMapper.java index 89e9281e..fc66b0a1 100644 --- a/ruoyi-admin/src/main/java/com/ruoyi/system/mapper/BsOrderMapper.java +++ b/ruoyi-admin/src/main/java/com/ruoyi/system/mapper/BsOrderMapper.java @@ -2,6 +2,8 @@ package com.ruoyi.system.mapper; import java.util.List; import com.ruoyi.system.domain.BsOrder; +import com.ruoyi.system.domain.dto.BsOrderDTO; +import com.ruoyi.system.domain.vo.BsOrdersVO; /** * 订单Mapper接口 @@ -82,4 +84,14 @@ public interface BsOrderMapper * @return 结果 */ public BsOrder userGetOrder(String orderNo); + + /** + * 所有分销商订单 + */ + public List getAllOrder(BsOrderDTO bsOrderDTO); + + /** + * 分销商查询订单 + */ + public List distributionGetOrder(int distributorId); } diff --git a/ruoyi-admin/src/main/java/com/ruoyi/system/service/IBsDistributionService.java b/ruoyi-admin/src/main/java/com/ruoyi/system/service/IBsDistributionService.java new file mode 100644 index 00000000..92bc092e --- /dev/null +++ b/ruoyi-admin/src/main/java/com/ruoyi/system/service/IBsDistributionService.java @@ -0,0 +1,83 @@ +package com.ruoyi.system.service; + +import com.ruoyi.system.domain.BsDistribution; +import com.ruoyi.system.domain.vo.BsDistributionVO; + +import java.util.List; + +/** + * 分销商信息Service接口 + * + * @author ruoyi + * @date 2024-11-18 + */ +public interface IBsDistributionService +{ + /** + * 查询分销商信息 + * + * @param id 分销商信息主键 + * @return 分销商信息 + */ + public BsDistribution selectBsDistributionById(Long id); + + /** + * 查询分销商信息列表 + * + * @param bsDistribution 分销商信息 + * @return 分销商信息集合 + */ + public List selectBsDistributionList(BsDistribution bsDistribution); + + /** + * 新增分销商信息 + * + * @param bsDistribution 分销商信息 + * @return 结果 + */ + public int insertBsDistribution(BsDistribution bsDistribution); + + /** + * 修改分销商信息 + * + * @param bsDistribution 分销商信息 + * @return 结果 + */ + public int updateBsDistribution(BsDistribution bsDistribution); + + /** + * 批量删除分销商信息 + * + * @param ids 需要删除的分销商信息主键集合 + * @return 结果 + */ + public int deleteBsDistributionByIds(Long[] ids); + + /** + * 删除分销商信息信息 + * + * @param id 分销商信息主键 + * @return 结果 + */ + public int deleteBsDistributionById(Long id); + + /** + * 根据手机号查询分销商信息 + */ + public BsDistribution selectOneMsg(String phone); + + /** + * 查询分销商所有订单信息 + */ + public List disAllOrder(BsDistribution bsDistribution); + + /** + * 根据手机号查询分销商信息是否存在 + */ + public boolean existsByPhone(String phone); + + /** + * 联合删除用户信息 + */ + public List getSysUserId(Long[] ids); +} diff --git a/ruoyi-admin/src/main/java/com/ruoyi/system/service/IBsOrderService.java b/ruoyi-admin/src/main/java/com/ruoyi/system/service/IBsOrderService.java index ab5724a6..cd86a795 100644 --- a/ruoyi-admin/src/main/java/com/ruoyi/system/service/IBsOrderService.java +++ b/ruoyi-admin/src/main/java/com/ruoyi/system/service/IBsOrderService.java @@ -2,6 +2,8 @@ package com.ruoyi.system.service; import java.util.List; import com.ruoyi.system.domain.BsOrder; +import com.ruoyi.system.domain.dto.BsOrderDTO; +import com.ruoyi.system.domain.vo.BsOrdersVO; /** * 订单Service接口 @@ -82,4 +84,14 @@ public interface IBsOrderService * @return 结果 */ public BsOrder userGetOrder(String orderNo); + + /** + * 所有分销商订单 + */ + public List selectAllList(BsOrderDTO bsOrderDTO); + + /** + * 分销商查询订单 + */ + public List distributionGetOrder(int distributorId); } diff --git a/ruoyi-admin/src/main/java/com/ruoyi/system/service/impl/BsDistributionServiceImpl.java b/ruoyi-admin/src/main/java/com/ruoyi/system/service/impl/BsDistributionServiceImpl.java new file mode 100644 index 00000000..41746723 --- /dev/null +++ b/ruoyi-admin/src/main/java/com/ruoyi/system/service/impl/BsDistributionServiceImpl.java @@ -0,0 +1,131 @@ +package com.ruoyi.system.service.impl; + +import com.ruoyi.system.domain.BsDistribution; +import com.ruoyi.system.domain.vo.BsDistributionVO; +import com.ruoyi.system.mapper.BsDistributionMapper; +import com.ruoyi.system.service.IBsDistributionService; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.stereotype.Service; + +import java.util.List; + +/** + * 分销商信息Service业务层处理 + * + * @author ruoyi + * @date 2024-11-18 + */ +@Service +public class BsDistributionServiceImpl implements IBsDistributionService +{ + @Autowired + private BsDistributionMapper bsDistributionMapper; + + /** + * 查询分销商信息 + * + * @param id 分销商信息主键 + * @return 分销商信息 + */ + @Override + public BsDistribution selectBsDistributionById(Long id) + { + return bsDistributionMapper.selectBsDistributionById(id); + } + + /** + * 查询分销商信息列表 + * + * @param bsDistribution 分销商信息 + * @return 分销商信息 + */ + @Override + public List selectBsDistributionList(BsDistribution bsDistribution) + { + return bsDistributionMapper.selectBsDistributionList(bsDistribution); + } + + /** + * 新增分销商信息 + * + * @param bsDistribution 分销商信息 + * @return 结果 + */ + @Override + public int insertBsDistribution(BsDistribution bsDistribution) + { + if(bsDistributionMapper.existsByPhone(bsDistribution.getPhone(), bsDistribution.getId())){ + throw new RuntimeException("该手机号已存在!"); + } + return bsDistributionMapper.insertBsDistribution(bsDistribution); + } + + /** + * 修改分销商信息 + * + * @param bsDistribution 分销商信息 + * @return 结果 + */ + @Override + public int updateBsDistribution(BsDistribution bsDistribution) + { + if(bsDistributionMapper.existsByPhone(bsDistribution.getPhone(), bsDistribution.getId())){ + throw new RuntimeException("该手机号已存在!"); + } + return bsDistributionMapper.updateBsDistribution(bsDistribution); + } + + /** + * 批量删除分销商信息 + * + * @param ids 需要删除的分销商信息主键 + * @return 结果 + */ + @Override + public int deleteBsDistributionByIds(Long[] ids) + { + return bsDistributionMapper.deleteBsDistributionByIds(ids); + } + + /** + * 删除分销商信息信息 + * + * @param id 分销商信息主键 + * @return 结果 + */ + @Override + public int deleteBsDistributionById(Long id) + { + return bsDistributionMapper.deleteBsDistributionById(id); + } + + /** + * 根据手机号查询分销商信息 + */ + @Override + public BsDistribution selectOneMsg(String phone) { + return bsDistributionMapper.selectOneMsg(phone); + } + + /** + * 查询分销商所有订单信息 + */ + @Override + public List disAllOrder(BsDistribution bsDistribution) { + return bsDistributionMapper.disAllOrder(bsDistribution); + } + + @Override + public boolean existsByPhone(String phone) { + return false; + } + + /** + * 联合删除用户信息 + */ + @Override + public List getSysUserId(Long[] ids) { + return bsDistributionMapper.getSysUserId(ids); + } + +} diff --git a/ruoyi-admin/src/main/java/com/ruoyi/system/service/impl/BsOrderServiceImpl.java b/ruoyi-admin/src/main/java/com/ruoyi/system/service/impl/BsOrderServiceImpl.java index 1262858e..e22105a7 100644 --- a/ruoyi-admin/src/main/java/com/ruoyi/system/service/impl/BsOrderServiceImpl.java +++ b/ruoyi-admin/src/main/java/com/ruoyi/system/service/impl/BsOrderServiceImpl.java @@ -3,6 +3,8 @@ package com.ruoyi.system.service.impl; import java.util.List; import com.ruoyi.common.utils.DateUtils; import com.ruoyi.common.utils.uuid.IdUtils; +import com.ruoyi.system.domain.dto.BsOrderDTO; +import com.ruoyi.system.domain.vo.BsOrdersVO; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import com.ruoyi.system.mapper.BsOrderMapper; @@ -128,4 +130,20 @@ public class BsOrderServiceImpl implements IBsOrderService public BsOrder userGetOrder(String orderNo) { return bsOrderMapper.userGetOrder(orderNo); } + + /** + * 所有分销商订单 + */ + @Override + public List selectAllList(BsOrderDTO bsOrderDTO) { + return bsOrderMapper.getAllOrder(bsOrderDTO); + } + + /** + * 分销商查询订单 + */ + @Override + public List distributionGetOrder(int distributorId) { + return bsOrderMapper.distributionGetOrder(distributorId); + } } diff --git a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/system/SysProfileController.java b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/system/SysProfileController.java index cd8abd6f..a32a9f70 100644 --- a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/system/SysProfileController.java +++ b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/system/SysProfileController.java @@ -1,5 +1,7 @@ package com.ruoyi.web.controller.system; +import com.ruoyi.system.domain.BsDistribution; +import com.ruoyi.system.service.IBsDistributionService; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.PostMapping; @@ -25,7 +27,7 @@ import com.ruoyi.system.service.ISysUserService; /** * 个人信息 业务处理 - * + * * @author ruoyi */ @RestController @@ -38,6 +40,9 @@ public class SysProfileController extends BaseController @Autowired private TokenService tokenService; + @Autowired + private IBsDistributionService bsDistributionService; + /** * 个人信息 */ @@ -60,11 +65,19 @@ public class SysProfileController extends BaseController public AjaxResult updateProfile(@RequestBody SysUser user) { LoginUser loginUser = getLoginUser(); + System.out.println("登录人手机号"+loginUser.getUser().getPhonenumber()); SysUser currentUser = loginUser.getUser(); + BsDistribution bsDistribution = bsDistributionService.selectOneMsg(currentUser.getPhonenumber()); + + if (bsDistribution != null) { + bsDistribution.setPhone(user.getPhonenumber()); + System.out.println("影响行数"); + } currentUser.setNickName(user.getNickName()); currentUser.setEmail(user.getEmail()); currentUser.setPhonenumber(user.getPhonenumber()); currentUser.setSex(user.getSex()); + if (StringUtils.isNotEmpty(user.getPhonenumber()) && !userService.checkPhoneUnique(currentUser)) { return error("修改用户'" + loginUser.getUsername() + "'失败,手机号码已存在"); @@ -77,6 +90,7 @@ public class SysProfileController extends BaseController { // 更新缓存用户信息 tokenService.setLoginUser(loginUser); + bsDistributionService.updateBsDistribution(bsDistribution); return success(); } return error("修改个人信息异常,请联系管理员"); diff --git a/ruoyi-admin/src/main/resources/application.yml b/ruoyi-admin/src/main/resources/application.yml index af72f2a0..68e04368 100644 --- a/ruoyi-admin/src/main/resources/application.yml +++ b/ruoyi-admin/src/main/resources/application.yml @@ -21,6 +21,7 @@ server: servlet: # 应用的访问路径 context-path: /bsw +# context-path: tomcat: # tomcat的URI编码 uri-encoding: UTF-8 @@ -142,6 +143,7 @@ wechat: pay: merchantId: 1695785302 privateKeyPath: /www/wwwroot/bishe/apiclient_key.pem +# privateKeyPath: D:\Code\bishe2\RuoYi-Vue\ruoyi-admin\src\main\resources\apiclient_key.pem merchantSerialNumber: 3E96EC705218574D63ECE2EA792B83B224FE9319 apiV3Key: Su7vFDrgVScnUqABUrIWLYyrNapWeH1a appId: wxb1f71e5e0c5f9ee7 diff --git a/ruoyi-admin/src/main/resources/mapper/system/BsDistributionMapper.xml b/ruoyi-admin/src/main/resources/mapper/system/BsDistributionMapper.xml new file mode 100644 index 00000000..52b3da24 --- /dev/null +++ b/ruoyi-admin/src/main/resources/mapper/system/BsDistributionMapper.xml @@ -0,0 +1,142 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + select id, name, phone, source, remark, commission from bs_distribution + + + + + + + + insert into bs_distribution + + id, + name, + phone, + source, + remark, + commission, + + + #{id}, + #{name}, + #{phone}, + #{source}, + #{remark}, + #{commission}, + + + + + update bs_distribution + + name = #{name}, + phone = #{phone}, + source = #{source}, + remark = #{remark}, + commission = #{commission}, + + where id = #{id} + + + + delete from bs_distribution where id = #{id} + + + + delete from bs_distribution where id in + + #{id} + + + + + + + + + + + + diff --git a/ruoyi-admin/src/main/resources/mapper/system/BsOrderMapper.xml b/ruoyi-admin/src/main/resources/mapper/system/BsOrderMapper.xml index 2a67e92d..1ddf1758 100644 --- a/ruoyi-admin/src/main/resources/mapper/system/BsOrderMapper.xml +++ b/ruoyi-admin/src/main/resources/mapper/system/BsOrderMapper.xml @@ -17,6 +17,26 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" + + + + + + + + + + + + + + + + + + + + @@ -32,7 +52,8 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" create_id, create_time, payStatus, - openid + openid, + distributor from bs_order select order_no,channel,transaction_id,pay_time,goods_name,goodsmin,price,create_time from bs_order where order_no = #{orderNo} and payStatus = 1 + + + + diff --git a/ruoyi-ui/.env.development b/ruoyi-ui/.env.development index d93ce12e..06bd2a99 100644 --- a/ruoyi-ui/.env.development +++ b/ruoyi-ui/.env.development @@ -6,7 +6,7 @@ ENV = 'development' # 若依管理系统/开发环境 # VUE_APP_BASE_API = '/dev-api' -# VUE_APP_BASE_API = 'http://124.222.105.7:7198/bsw' +# VUE_APP_BASE_API = 'http://127.0.0.1:40506' VUE_APP_BASE_API = 'https://bishe.lighting-it.cn/bsw' # 路由懒加载 diff --git a/ruoyi-ui/src/api/system/distribution.js b/ruoyi-ui/src/api/system/distribution.js new file mode 100644 index 00000000..d78dfdea --- /dev/null +++ b/ruoyi-ui/src/api/system/distribution.js @@ -0,0 +1,61 @@ +import request from '@/utils/request' + +// 查询分销商信息列表 +export function listDistribution(query) { + return request({ + url: '/system/distribution/list', + method: 'get', + params: query + }) +} + +// 查询分销商信息列表2 +export function disAllOrder(query) { + return request({ + url: '/system/distribution/disAllOrder', + method: 'get', + params: query + }) +} + +// 查询分销商信息详细 +export function getDistribution(id) { + return request({ + url: '/system/distribution/' + id, + method: 'get' + }) +} + +// 查询分销商信息详细2 +export function getDisMsg() { + return request({ + url: '/system/distribution/getDisMsg', + method: 'get' + }) +} + +// 新增分销商信息 +export function addDistribution(data) { + return request({ + url: '/system/distribution', + method: 'post', + data: data + }) +} + +// 修改分销商信息 +export function updateDistribution(data) { + return request({ + url: '/system/distribution', + method: 'put', + data: data + }) +} + +// 删除分销商信息 +export function delDistribution(id) { + return request({ + url: '/system/distribution/' + id, + method: 'delete' + }) +} diff --git a/ruoyi-ui/src/api/system/order.js b/ruoyi-ui/src/api/system/order.js index 3522b29d..5f8c4090 100644 --- a/ruoyi-ui/src/api/system/order.js +++ b/ruoyi-ui/src/api/system/order.js @@ -9,6 +9,15 @@ export function listOrder(query) { }) } +// 查询订单列表2 +export function listAllOrder(query) { + return request({ + url: '/system/order/allOrderList', + method: 'get', + params: query + }) +} + // 查询订单详细 export function getOrder(id) { return request({ @@ -73,3 +82,12 @@ export function userGetOrder(orderNo) { method: 'get' }) } + +// 分销商订单详细 +export function distributionOrder(query) { + return request({ + url: '/system/order/distributionOrder', + method: 'get', + params: query + }) +} diff --git a/ruoyi-ui/src/router/index.js b/ruoyi-ui/src/router/index.js index 13722ae7..2d5fe4a6 100644 --- a/ruoyi-ui/src/router/index.js +++ b/ruoyi-ui/src/router/index.js @@ -101,6 +101,11 @@ export const constantRoutes = [ component: () => import('@/views/system/userFront/precautions'), hidden: true }, + { + path: '/distributorOrder', + component: () => import('@/views/system/distribution/distributorOrder'), + hidden: true + }, { path: '', component: Layout, diff --git a/ruoyi-ui/src/views/index.vue b/ruoyi-ui/src/views/index.vue index a17811f5..3fdd56e0 100644 --- a/ruoyi-ui/src/views/index.vue +++ b/ruoyi-ui/src/views/index.vue @@ -2,1015 +2,15 @@
-
- 领取阿里云通用云产品1888优惠券 -
- https://www.aliyun.com/minisite/goods?userCode=brki8iof -
- 领取腾讯云通用云产品2860优惠券 -
- https://cloud.tencent.com/redirect.php?redirect=1025&cps_key=198c8df2ed259157187173bc7f4f32fd&from=console -
- 阿里云服务器折扣区 - >☛☛点我进入☚☚ -     腾讯云服务器秒杀区 - >☛☛点我进入☚☚
-

- 云产品通用红包,可叠加官网常规优惠使用。(仅限新用户) -

-
-
-

若依后台管理框架

-

- 一直想做一款后台管理系统,看了很多优秀的开源项目但是发现没有合适自己的。于是利用空闲休息时间开始自己写一套后台系统。如此有了若依管理系统,她可以用于所有的Web应用程序,如网站管理后台,网站会员中心,CMS,CRM,OA等等,当然,您也可以对她进行深度定制,以做出更强系统。所有前端后台代码封装过后十分精简易上手,出错概率低。同时支持移动客户端访问。系统会陆续更新一些实用功能。 -

-

- 当前版本: v{{ version }} -

-

- ¥免费开源 -

-

- 访问码云 - 访问主页 -

-
- - - - -

技术选型

-
-
- - -

后端技术

-
    -
  • SpringBoot
  • -
  • Spring Security
  • -
  • JWT
  • -
  • MyBatis
  • -
  • Druid
  • -
  • Fastjson
  • -
  • ...
  • -
-
- -

前端技术

-
    -
  • Vue
  • -
  • Vuex
  • -
  • Element-ui
  • -
  • Axios
  • -
  • Sass
  • -
  • Quill
  • -
  • ...
  • -
-
-
+

欢迎使用

- - - -
- 联系信息 -
-
-

- 官网:http://www.ruoyi.vip -

-

- QQ群: 满937441 满887144332 - 满180251782 满104180207 满186866453 满201396349 - 满101456076 满101539465 满264312783 满167385320 - 满104748341 满160110482 满170801498 满108482800 - 满101046199 满136919097 满143961921 满174951577 - 满161281055 满138988063 151450850 -

-

- 微信:/ *若依 -

-

- 支付宝:/ *若依 -

-
-
-
- - -
- 更新日志 -
- - -
    -
  1. 菜单管理新增路由名称
  2. -
  3. 新增数据脱敏过滤注解
  4. -
  5. 用户密码新增非法字符验证
  6. -
  7. 限制用户操作数据权限范围
  8. -
  9. 代码生成新增创建表结构功能
  10. -
  11. 定时任务白名单配置范围缩小
  12. -
  13. 优化代码生成主子表关联查询方式
  14. -
  15. Excel注解新增属性comboReadDict
  16. -
  17. Excel注解ColumnType类型新增文本
  18. -
  19. 新增国际化资源文件配置
  20. -
  21. 升级oshi到最新版本6.6.1
  22. -
  23. 升级druid到最新版本1.2.23
  24. -
  25. 升级core-js到最新版本3.37.1
  26. -
  27. 更新HttpUtils中的User-Agent
  28. -
  29. 更新compressionPlugin到6.1.2以兼容node18+
  30. -
  31. 升级spring-security到安全版本,防止漏洞风险
  32. -
  33. 升级spring-framework到安全版本,防止漏洞风险
  34. -
  35. 优化自定义XSS注解匹配方式
  36. -
  37. 优化缓存监控键名列表排序显示
  38. -
  39. 优化定时任务日志默认按时间排序
  40. -
  41. 优化默认文件大小超过2G无效的问题
  42. -
  43. 优化查表特殊字符使用反斜杠进行转义
  44. -
  45. 优化定时任务cron表达式小时配置显示错误问题
  46. -
  47. 优化多个自定数据权限使用in查询,避免多次拼接
  48. -
  49. 优化导入Excel时设置dictType属性重复查缓存问题
  50. -
  51. 其他细节优化
  52. -
-
- -
    -
  1. 操作日志记录部门名称
  2. -
  3. 全局数据存储用户编号
  4. -
  5. 新增编程式判断资源访问权限
  6. -
  7. 操作日志列表新增IP地址查询
  8. -
  9. 定时任务新增页去除状态选项
  10. -
  11. 代码生成支持选择前端模板类型
  12. -
  13. 显隐列组件支持复选框弹出类型
  14. -
  15. 通用排序属性orderBy参数限制长度
  16. -
  17. Excel自定义数据处理器增加单元格/工作簿对象
  18. -
  19. 升级oshi到最新版本6.4.8
  20. -
  21. 升级druid到最新版本1.2.20
  22. -
  23. 升级fastjson到最新版2.0.43
  24. -
  25. 升级pagehelper到最新版1.4.7
  26. -
  27. 升级commons.io到最新版本2.13.0
  28. -
  29. 升级element-ui到最新版本2.15.14
  30. -
  31. 修复五级路由缓存无效问题
  32. -
  33. 修复外链带端口出现的异常
  34. -
  35. 修复树模板父级编码变量错误
  36. -
  37. 修复字典表详情页面搜索问题
  38. -
  39. 修复内链iframe没有传递参数问题
  40. -
  41. 修复自定义字典样式不生效的问题
  42. -
  43. 修复字典缓存删除方法参数错误问题
  44. -
  45. 修复Excel导入数据临时文件无法删除问题
  46. -
  47. 修复未登录带参数访问成功后参数丢失问题
  48. -
  49. 修复HeaderSearch组件跳转query参数丢失问题
  50. -
  51. 修复代码生成导入后必填项与数据库不匹配问题
  52. -
  53. 修复Excels导入时无法获取到dictType字典值问题
  54. -
  55. 优化下载zip方法新增遮罩层
  56. -
  57. 优化头像上传参数新增文件名称
  58. -
  59. 优化字典标签支持自定义分隔符
  60. -
  61. 优化菜单管理类型为按钮状态可选
  62. -
  63. 优化前端防重复提交数据大小限制
  64. -
  65. 优化TopNav菜单没有图标svg不显示
  66. -
  67. 优化数字金额大写转换精度丢失问题
  68. -
  69. 优化富文本Editor组件检验图片格式
  70. -
  71. 优化页签在Firefox浏览器被遮挡的问题
  72. -
  73. 优化个人中心/基本资料修改时数据显示问题
  74. -
  75. 优化缓存监控图表支持跟随屏幕大小自适应调整
  76. -
  77. 其他细节优化
  78. -
-
- -
    -
  1. 支持登录IP黑名单限制
  2. -
  3. 新增监控页面图标显示
  4. -
  5. 操作日志新增消耗时间属性
  6. -
  7. 屏蔽定时任务bean违规的字符
  8. -
  9. 日志管理使用索引提升查询性能
  10. -
  11. 日志注解支持排除指定的请求参数
  12. -
  13. 支持自定义隐藏属性列过滤子对象
  14. -
  15. 升级oshi到最新版本6.4.3
  16. -
  17. 升级druid到最新版本1.2.16
  18. -
  19. 升级fastjson到最新版2.0.34
  20. -
  21. 升级spring-boot到最新版本2.5.15
  22. -
  23. 升级element-ui到最新版本2.15.13
  24. -
  25. 移除apache/commons-fileupload依赖
  26. -
  27. 修复页面切换时布局错乱的问题
  28. -
  29. 修复匿名注解Anonymous空指针问题
  30. -
  31. 修复路由跳转被阻止时内部产生报错信息问题
  32. -
  33. 修复isMatchedIp的参数判断产生空指针的问题
  34. -
  35. 修复用户多角色数据权限可能出现权限抬升的情况
  36. -
  37. 修复开启TopNav后一级菜单路由参数设置无效问题
  38. -
  39. 修复DictTag组件value没有匹配的值时则展示value
  40. -
  41. 优化文件下载出现的异常
  42. -
  43. 优化选择图标组件高亮回显
  44. -
  45. 优化弹窗后导航栏偏移的问题
  46. -
  47. 优化修改密码日志存储明文问题
  48. -
  49. 优化页签栏关闭其他出现的异常问题
  50. -
  51. 优化页签关闭左侧选项排除首页选项
  52. -
  53. 优化关闭当前tab页跳转最右侧tab页
  54. -
  55. 优化缓存列表清除操作提示不变的问题
  56. -
  57. 优化字符未使用下划线不进行驼峰式处理
  58. -
  59. 优化用户导入更新时需获取用户编号问题
  60. -
  61. 优化侧边栏的平台标题与VUE_APP_TITLE保持同步
  62. -
  63. 优化导出Excel时设置dictType属性重复查缓存问题
  64. -
  65. 连接池Druid支持新的配置connectTimeout和socketTimeout
  66. -
  67. 其他细节优化
  68. -
-
- -
    -
  1. 定时任务违规的字符
  2. -
  3. 重置时取消部门选中
  4. -
  5. 新增返回警告消息提示
  6. -
  7. 忽略不必要的属性数据返回
  8. -
  9. 修改参数键名时移除前缓存配置
  10. -
  11. 导入更新用户数据前校验数据权限
  12. -
  13. 兼容Excel下拉框内容过多无法显示的问题
  14. -
  15. 升级echarts到最新版本5.4.0
  16. -
  17. 升级core-js到最新版本3.25.3
  18. -
  19. 升级oshi到最新版本6.4.0
  20. -
  21. 升级kaptcha到最新版2.3.3
  22. -
  23. 升级druid到最新版本1.2.15
  24. -
  25. 升级fastjson到最新版2.0.20
  26. -
  27. 升级pagehelper到最新版1.4.6
  28. -
  29. 优化弹窗内容过多展示不全问题
  30. -
  31. 优化swagger-ui静态资源使用缓存
  32. -
  33. 开启TopNav没有子菜单隐藏侧边栏
  34. -
  35. 删除fuse无效选项maxPatternLength
  36. -
  37. 优化导出对象的子列表为空会出现[]问题
  38. -
  39. 优化编辑头像时透明部分会变成黑色问题
  40. -
  41. 优化小屏幕上修改头像界面布局错位的问题
  42. -
  43. 修复代码生成勾选属性无效问题
  44. -
  45. 修复文件上传组件格式验证问题
  46. -
  47. 修复回显数据字典数组异常问题
  48. -
  49. 修复sheet超出最大行数异常问题
  50. -
  51. 修复Log注解GET请求记录不到参数问题
  52. -
  53. 修复调度日志点击多次数据不变化的问题
  54. -
  55. 修复主题颜色在Drawer组件不会加载问题
  56. -
  57. 修复文件名包含特殊字符的文件无法下载问题
  58. -
  59. 修复table中更多按钮切换主题色未生效修复问题
  60. -
  61. 修复某些特性的环境生成代码变乱码TXT文件问题
  62. -
  63. 修复代码生成图片/文件/单选时选择必填无法校验问题
  64. -
  65. 修复某些特性的情况用户编辑对话框中角色和部门无法修改问题
  66. -
  67. 其他细节优化
  68. -
-
- -
    -
  1. 数据逻辑删除不进行唯一验证
  2. -
  3. Excel注解支持导出对象的子列表方法
  4. -
  5. Excel注解支持自定义隐藏属性列
  6. -
  7. Excel注解支持backgroundColor属性设置背景色
  8. -
  9. 支持配置密码最大错误次数/锁定时间
  10. -
  11. 登录日志新增解锁账户功能
  12. -
  13. 通用下载方法新增config配置选项
  14. -
  15. 支持多权限字符匹配角色数据权限
  16. -
  17. 页面内嵌iframe切换tab不刷新数据
  18. -
  19. 操作日志记录支持排除敏感属性字段
  20. -
  21. 修复多文件上传报错出现的异常问题
  22. -
  23. 修复图片预览组件src属性为null值控制台报错问题
  24. -
  25. 升级oshi到最新版本6.2.2
  26. -
  27. 升级fastjson到最新版2.0.14
  28. -
  29. 升级pagehelper到最新版1.4.3
  30. -
  31. 升级core-js到最新版本3.25.2
  32. -
  33. 升级element-ui到最新版本2.15.10
  34. -
  35. 优化任务过期不执行调度
  36. -
  37. 优化字典数据使用store存取
  38. -
  39. 优化修改资料头像被覆盖的问题
  40. -
  41. 优化修改用户登录账号重复验证
  42. -
  43. 优化代码生成同步后值NULL问题
  44. -
  45. 优化定时任务支持执行父类方法
  46. -
  47. 优化用户个人信息接口防止修改部门
  48. -
  49. 优化布局设置使用el-drawer抽屉显示
  50. -
  51. 优化没有权限的用户编辑部门缺少数据
  52. -
  53. 优化日志注解记录限制请求地址的长度
  54. -
  55. 优化excel/scale属性导出单元格数值类型
  56. -
  57. 优化日志操作中重置按钮时重复查询的问题
  58. -
  59. 优化多个相同角色数据导致权限SQL重复问题
  60. -
  61. 优化表格上右侧工具条(搜索按钮显隐&右侧样式凸出)
  62. -
  63. 其他细节优化
  64. -
-
- -
    -
  1. 新增缓存列表菜单功能
  2. -
  3. 代码生成树表新增(展开/折叠)
  4. -
  5. Excel注解支持color字体颜色
  6. -
  7. 新增Anonymous匿名访问不鉴权注解
  8. -
  9. 用户头像上传限制只能为图片格式
  10. -
  11. 接口使用泛型使其看到响应属性字段
  12. -
  13. 检查定时任务bean所在包名是否为白名单配置
  14. -
  15. 添加页签openPage支持传递参数
  16. -
  17. 用户缓存信息添加部门ancestors祖级列表
  18. -
  19. 升级element-ui到最新版本2.15.8
  20. -
  21. 升级oshi到最新版本6.1.6
  22. -
  23. 升级druid到最新版本1.2.11
  24. -
  25. 升级fastjson到最新版2.0.8
  26. -
  27. 升级spring-boot到最新版本2.5.14
  28. -
  29. 降级jsencrypt版本兼容IE浏览器
  30. -
  31. 删除多余的salt字段
  32. -
  33. 新增获取不带后缀文件名称方法
  34. -
  35. 新增获取配置文件中的属性值方法
  36. -
  37. 新增内容编码/解码方便插件集成使用
  38. -
  39. 字典类型必须以字母开头,且只能为(小写字母,数字,下滑线)
  40. -
  41. 优化设置分页参数默认值
  42. -
  43. 优化对空字符串参数处理的过滤
  44. -
  45. 优化显示顺序orderNum类型为整型
  46. -
  47. 优化表单构建按钮不显示正则校验
  48. -
  49. 优化字典数据回显样式下拉框显示值
  50. -
  51. 优化R响应成功状态码与全局保持一致
  52. -
  53. 优化druid开启wall过滤器出现的异常问题
  54. -
  55. 优化用户管理左侧树型组件增加选中高亮保持
  56. -
  57. 优化新增用户与角色信息&用户与岗位信息逻辑
  58. -
  59. 优化默认不启用压缩文件缓存防止node_modules过大
  60. -
  61. 修复字典数据显示不全问题
  62. -
  63. 修复操作日志查询类型条件为0时会查到所有数据
  64. -
  65. 修复Excel注解prompt/combo同时使用不生效问题
  66. -
  67. 其他细节优化
  68. -
-
- -
    -
  1. 前端支持设置是否需要防止数据重复提交
  2. -
  3. 开启TopNav没有子菜单情况隐藏侧边栏
  4. -
  5. 侧边栏菜单名称过长悬停显示标题
  6. -
  7. 用户访问控制时校验数据权限,防止越权
  8. -
  9. 导出Excel时屏蔽公式,防止CSV注入风险
  10. -
  11. 组件ImagePreview支持多图预览显示
  12. -
  13. 组件ImageUpload支持多图同时选择上传
  14. -
  15. 组件FileUpload支持多文件同时选择上传
  16. -
  17. 服务监控新增运行参数信息显示
  18. -
  19. 定时任务目标字符串过滤特殊字符
  20. -
  21. 定时任务目标字符串验证包名白名单
  22. -
  23. 代码生成列表图片支持预览
  24. -
  25. 代码生成编辑修改打开新页签
  26. -
  27. 代码生成新增Java类型Boolean
  28. -
  29. 代码生成子表支持日期/字典配置
  30. -
  31. 代码生成同步保留必填/类型选项
  32. -
  33. 升级oshi到最新版本6.1.2
  34. -
  35. 升级fastjson到最新版1.2.80
  36. -
  37. 升级pagehelper到最新版1.4.1
  38. -
  39. 升级spring-boot到最新版本2.5.11
  40. -
  41. 升级spring-boot-mybatis到最新版2.2.2
  42. -
  43. 添加遗漏的分页参数合理化属性
  44. -
  45. 修改npm即将过期的注册源地址
  46. -
  47. 修复分页组件请求两次问题
  48. -
  49. 修复通用文件下载接口跨域问题
  50. -
  51. 修复Xss注解字段值为空时的异常问题
  52. -
  53. 修复选项卡点击右键刷新丢失参数问题
  54. -
  55. 修复表单清除元素位置未垂直居中问题
  56. -
  57. 修复服务监控中运行参数显示条件错误
  58. -
  59. 修复导入Excel时字典字段类型为Long转义为空问题
  60. -
  61. 修复登录超时刷新页面跳转登录页面还提示重新登录问题
  62. -
  63. 优化加载字典缓存数据
  64. -
  65. 优化IP地址获取到多个的问题
  66. -
  67. 优化任务队列满时任务拒绝策略
  68. -
  69. 优化文件上传兼容Weblogic环境
  70. -
  71. 优化定时任务默认保存到内存中执行
  72. -
  73. 优化部门修改缩放后出现的错位问题
  74. -
  75. 优化Excel格式化不同类型的日期对象
  76. -
  77. 优化菜单表关键字导致的插件报错问题
  78. -
  79. 优化Oracle用户头像列为空时不显示问题
  80. -
  81. 优化页面若未匹配到字典标签则返回原字典值
  82. -
  83. 优化修复登录失效后多次请求提示多次弹窗问题
  84. -
  85. 其他细节优化
  86. -
-
- -
    -
  1. 新增Vue3前端代码生成模板
  2. -
  3. 新增图片预览组件
  4. -
  5. 新增压缩插件实现打包Gzip
  6. -
  7. 自定义xss校验注解实现
  8. -
  9. 自定义文字复制剪贴指令
  10. -
  11. 代码生成预览支持复制内容
  12. -
  13. 路由支持单独配置菜单或角色权限
  14. -
  15. 用户管理部门查询选择节点后分页参数初始
  16. -
  17. 修复用户分配角色属性错误
  18. -
  19. 修复打包后字体图标偶现的乱码问题
  20. -
  21. 修复菜单管理重置表单出现的错误
  22. -
  23. 修复版本差异导致的懒加载报错问题
  24. -
  25. 修复Cron组件中周回显问题
  26. -
  27. 修复定时任务多参数逗号分隔的问题
  28. -
  29. 修复根据ID查询列表可能出现的主键溢出问题
  30. -
  31. 修复tomcat配置参数已过期问题
  32. -
  33. 升级clipboard到最新版本2.0.8
  34. -
  35. 升级oshi到最新版本v5.8.6
  36. -
  37. 升级fastjson到最新版1.2.79
  38. -
  39. 升级spring-boot到最新版本2.5.8
  40. -
  41. 升级log4j2到2.17.1,防止漏洞风险
  42. -
  43. 优化下载解析blob异常提示
  44. -
  45. 优化代码生成字典组重复问题
  46. -
  47. 优化查询用户的角色组&岗位组代码
  48. -
  49. 优化定时任务cron表达式小时设置24
  50. -
  51. 优化用户导入提示溢出则显示滚动条
  52. -
  53. 优化防重复提交标识组合为(key+url+header)
  54. -
  55. 优化分页方法设置成通用方便灵活调用
  56. -
  57. 其他细节优化
  58. -
-
- -
    -
  1. 新增配套并同步的Vue3前端版本
  2. -
  3. 新增通用方法简化模态/缓存/下载/权限/页签使用
  4. -
  5. 优化导出数据/使用通用下载方法
  6. -
  7. Excel注解支持自定义数据处理器
  8. -
  9. Excel注解支持导入导出标题信息
  10. -
  11. Excel导入支持@Excels注解
  12. -
  13. 新增组件data-dict,简化数据字典使用
  14. -
  15. 新增Jaxb依赖,防止jdk8以上出现的兼容错误
  16. -
  17. 生产环境使用路由懒加载提升页面响应速度
  18. -
  19. 修复五级以上菜单出现的404问题
  20. -
  21. 防重提交注解支持配置间隔时间/提示消息
  22. -
  23. 日志注解新增是否保存响应参数
  24. -
  25. 任务屏蔽违规字符&参数忽略双引号中的逗号
  26. -
  27. 升级SpringBoot到最新版本2.5.6
  28. -
  29. 升级pagehelper到最新版1.4.0
  30. -
  31. 升级spring-boot-mybatis到最新版2.2.0
  32. -
  33. 升级oshi到最新版本v5.8.2
  34. -
  35. 升级druid到最新版1.2.8
  36. -
  37. 升级velocity到最新版本2.3
  38. -
  39. 升级fastjson到最新版1.2.78
  40. -
  41. 升级axios到最新版本0.24.0
  42. -
  43. 升级dart-sass到版本1.32.13
  44. -
  45. 升级core-js到最新版本3.19.1
  46. -
  47. 升级jsencrypt到最新版本3.2.1
  48. -
  49. 升级js-cookie到最新版本3.0.1
  50. -
  51. 升级file-saver到最新版本2.0.5
  52. -
  53. 升级sass-loader到最新版本10.1.1
  54. -
  55. 升级element-ui到最新版本2.15.6
  56. -
  57. 新增sendGet无参请求方法
  58. -
  59. 禁用el-tag组件的渐变动画
  60. -
  61. 代码生成点击预览重置激活tab
  62. -
  63. AjaxResult重写put方法,以方便链式调用
  64. -
  65. 优化登录/验证码请求headers不设置token
  66. -
  67. 优化用户个人信息接口防止修改用户名
  68. -
  69. 优化Cron表达式生成器关闭时销毁避免缓存
  70. -
  71. 优化注册成功提示消息类型success
  72. -
  73. 优化aop语法,使用spring自动注入注解
  74. -
  75. 优化记录登录信息,移除不必要的修改
  76. -
  77. 优化mybatis全局默认的执行器
  78. -
  79. 优化Excel导入图片可能出现的异常
  80. -
  81. 修复代码生成模板主子表删除缺少事务
  82. -
  83. 修复日志记录可能出现的转换异常
  84. -
  85. 修复代码生成复选框字典遗漏问题
  86. -
  87. 修复关闭xss功能导致可重复读RepeatableFilter失效
  88. -
  89. 修复字符串无法被反转义问题
  90. -
  91. 修复后端主子表代码模板方法名生成错误问题
  92. -
  93. 修复xss过滤后格式出现的异常
  94. -
  95. 修复swagger没有指定dataTypeClass导致启动出现warn日志
  96. -
  97. 其他细节优化
  98. -
-
- -
    -
  1. 参数管理支持配置验证码开关
  2. -
  3. 新增是否开启用户注册功能
  4. -
  5. 定时任务支持在线生成cron表达式
  6. -
  7. 菜单管理支持配置路由参数
  8. -
  9. 支持自定义注解实现接口限流
  10. -
  11. Excel注解支持Image图片导入
  12. -
  13. 自定义弹层溢出滚动样式
  14. -
  15. 自定义可拖动弹窗宽度指令
  16. -
  17. 自定义可拖动弹窗高度指令
  18. -
  19. 修复任意账户越权问题
  20. -
  21. 修改时检查用户数据权限范围
  22. -
  23. 修复保存配置主题颜色失效问题
  24. -
  25. 新增暗色菜单风格主题
  26. -
  27. 菜单&部门新增展开/折叠功能
  28. -
  29. 页签新增关闭左侧&添加图标
  30. -
  31. 顶部菜单排除隐藏的默认路由
  32. -
  33. 顶部菜单同步系统主题样式
  34. -
  35. 跳转路由高亮相对应的菜单栏
  36. -
  37. 代码生成主子表多选行数据
  38. -
  39. 日期范围支持添加多组
  40. -
  41. 升级element-ui到最新版本2.15.5
  42. -
  43. 升级oshi到最新版本v5.8.0
  44. -
  45. 升级commons.io到最新版本v2.11.0
  46. -
  47. 定时任务屏蔽ldap远程调用
  48. -
  49. 定时任务屏蔽http(s)远程调用
  50. -
  51. 补充定时任务表字段注释
  52. -
  53. 定时任务对检查异常进行事务回滚
  54. -
  55. 启用父部门状态排除顶级节点
  56. -
  57. 富文本新增上传文件大小限制
  58. -
  59. 默认首页使用keep-alive缓存
  60. -
  61. 修改代码生成字典回显样式
  62. -
  63. 自定义分页合理化传入参数
  64. -
  65. 修复字典组件值为整形不显示问题
  66. -
  67. 修复定时任务日志执行状态显示
  68. -
  69. 角色&菜单新增字段属性提示信息
  70. -
  71. 修复角色分配用户页面参数类型错误提醒
  72. -
  73. 优化布局设置动画特效
  74. -
  75. 优化异常处理信息
  76. -
  77. 优化错误token导致的解析异常
  78. -
  79. 密码框新增显示切换密码图标
  80. -
  81. 定时任务新增更多操作
  82. -
  83. 更多操作按钮添加权限控制
  84. -
  85. 导入用户样式优化
  86. -
  87. 提取通用方法到基类控制器
  88. -
  89. 优化使用权限工具获取用户信息
  90. -
  91. 优化用户不能删除自己
  92. -
  93. 优化XSS跨站脚本过滤
  94. -
  95. 优化代码生成模板
  96. -
  97. 验证码默认20s超时
  98. -
  99. BLOB下载时清除URL对象引用
  100. -
  101. 代码生成导入表按创建时间排序
  102. -
  103. 修复代码生成页面数据编辑保存之后总是跳转第一页的问题
  104. -
  105. 修复带safari浏览器无法格式化utc日期格式yyyy-MM-dd'T'HH:mm:ss.SSS问题
  106. -
  107. 多图上传组件移除多余的api地址&验证失败导致图片删除问题&无法删除相应图片修复
  108. -
  109. 其他细节优化
  110. -
-
- -
    -
  1. 角色管理新增分配用户功能
  2. -
  3. 用户管理新增分配角色功能
  4. -
  5. 日志列表支持排序操作
  6. -
  7. 优化参数&字典缓存操作
  8. -
  9. 系统布局配置支持动态标题开关
  10. -
  11. 菜单路由配置支持内链访问
  12. -
  13. 默认访问后端首页新增提示语
  14. -
  15. 富文本默认上传返回url类型
  16. -
  17. 新增自定义弹窗拖拽指令
  18. -
  19. 全局注册常用通用组件
  20. -
  21. 全局挂载字典标签组件
  22. -
  23. ImageUpload组件支持多图片上传
  24. -
  25. FileUpload组件支持多文件上传
  26. -
  27. 文件上传组件添加数量限制属性
  28. -
  29. 富文本编辑组件添加类型属性
  30. -
  31. 富文本组件工具栏配置视频
  32. -
  33. 封装通用iframe组件
  34. -
  35. 限制超级管理员不允许操作
  36. -
  37. 用户信息长度校验限制
  38. -
  39. 分页组件新增pagerCount属性
  40. -
  41. 添加bat脚本执行应用
  42. -
  43. 升级oshi到最新版本v5.7.4
  44. -
  45. 升级element-ui到最新版本2.15.2
  46. -
  47. 升级pagehelper到最新版1.3.1
  48. -
  49. 升级commons.io到最新版本v2.10.0
  50. -
  51. 升级commons.fileupload到最新版本v1.4
  52. -
  53. 升级swagger到最新版本v3.0.0
  54. -
  55. 修复关闭confirm提示框控制台报错问题
  56. -
  57. 修复存在的SQL注入漏洞问题
  58. -
  59. 定时任务屏蔽rmi远程调用
  60. -
  61. 修复用户搜索分页变量错误
  62. -
  63. 修复导出角色数据范围翻译缺少仅本人
  64. -
  65. 修复表单构建选择下拉选择控制台报错问题
  66. -
  67. 优化图片工具类读取文件
  68. -
  69. 其他细节优化
  70. -
-
- -
    -
  1. 新增菜单导航显示风格TopNav(false为左侧导航菜单,true为顶部导航菜单)
  2. -
  3. 布局设置支持保存&重置配置
  4. -
  5. 修复树表数据显示不全&加载慢问题
  6. -
  7. 新增IE浏览器版本过低提示页面
  8. -
  9. 用户登录后记录最后登录IP&时间
  10. -
  11. 页面导出按钮点击之后添加遮罩
  12. -
  13. 富文本编辑器支持自定义上传地址
  14. -
  15. 富文本编辑组件新增readOnly属性
  16. -
  17. 页签TagsView新增关闭右侧功能
  18. -
  19. 显隐列组件加载初始默认隐藏列
  20. -
  21. 关闭头像上传窗口还原默认图片
  22. -
  23. 个人信息添加手机&邮箱重复验证
  24. -
  25. 代码生成模板导出按钮点击后添加遮罩
  26. -
  27. 代码生成模板树表操作列添加新增按钮
  28. -
  29. 代码生成模板修复主子表字段重名问题
  30. -
  31. 升级fastjson到最新版1.2.76
  32. -
  33. 升级druid到最新版本v1.2.6
  34. -
  35. 升级mybatis到最新版3.5.6 阻止远程代码执行漏洞
  36. -
  37. 升级oshi到最新版本v5.6.0
  38. -
  39. velocity剔除commons-collections版本,防止3.2.1版本的反序列化漏洞
  40. -
  41. 数据监控页默认账户密码防止越权访问
  42. -
  43. 修复firefox下表单构建拖拽会新打卡一个选项卡
  44. -
  45. 修正后端导入表权限标识
  46. -
  47. 修正前端操作日志&登录日志权限标识
  48. -
  49. 设置Redis配置HashKey序列化
  50. -
  51. 删除操作日志记录信息
  52. -
  53. 上传媒体类型添加视频格式
  54. -
  55. 修复请求形参未传值记录日志异常问题
  56. -
  57. 优化xss校验json请求条件
  58. -
  59. 树级结构更新子节点使用replaceFirst
  60. -
  61. 优化ExcelUtil空值处理
  62. -
  63. 日志记录过滤BindingResult对象,防止异常
  64. -
  65. 修改主题后mini类型按钮无效问题
  66. -
  67. 优化通用下载完成后删除节点
  68. -
  69. 通用Controller添加响应返回消息
  70. -
  71. 其他细节优化
  72. -
-
- -
    -
  1. 代码生成模板支持主子表
  2. -
  3. 表格右侧工具栏组件支持显隐列
  4. -
  5. 图片组件添加预览&移除功能
  6. -
  7. Excel注解支持Image图片导出
  8. -
  9. 操作按钮组调整为朴素按钮样式
  10. -
  11. 代码生成支持文件上传组件
  12. -
  13. 代码生成日期控件区分范围
  14. -
  15. 代码生成数据库文本类型生成表单文本域
  16. -
  17. 用户手机邮箱&菜单组件修改允许空字符串
  18. -
  19. 升级SpringBoot到最新版本2.2.13 提升启动速度
  20. -
  21. 升级druid到最新版本v1.2.4
  22. -
  23. 升级fastjson到最新版1.2.75
  24. -
  25. 升级element-ui到最新版本2.15.0
  26. -
  27. 修复IE11浏览器报错问题
  28. -
  29. 优化多级菜单之间切换无法缓存的问题
  30. -
  31. 修复四级菜单无法显示问题
  32. -
  33. 修正侧边栏静态路由丢失问题
  34. -
  35. 修复角色管理-编辑角色-功能权限显示异常
  36. -
  37. 配置文件新增redis数据库索引属性
  38. -
  39. 权限工具类增加admin判断
  40. -
  41. 角色非自定义权限范围清空选择值
  42. -
  43. 修复导入数据为负浮点数时丢失精度问题
  44. -
  45. 移除path-to-regexp正则匹配插件
  46. -
  47. 修复生成树表代码异常
  48. -
  49. 修改ip字段长度防止ipv6地址长度不够
  50. -
  51. 防止get请求参数值为false或0等特殊值会导致无法正确的传参
  52. -
  53. 登录后push添加catch防止出现检查错误
  54. -
  55. 其他细节优化
  56. -
-
- -
    -
  1. 新增缓存监控功能
  2. -
  3. 支持主题风格配置
  4. -
  5. 修复多级菜单之间切换无法缓存的问题
  6. -
  7. 多级菜单自动配置组件
  8. -
  9. 代码生成预览支持高亮显示
  10. -
  11. 支持Get请求映射Params参数
  12. -
  13. 删除用户和角色解绑关联
  14. -
  15. 去除用户手机邮箱部门必填验证
  16. -
  17. Excel支持注解align对齐方式
  18. -
  19. Excel支持导入Boolean型数据
  20. -
  21. 优化头像样式,鼠标移入悬停遮罩
  22. -
  23. 代码生成预览提供滚动机制
  24. -
  25. 代码生成删除多余的数字float类型
  26. -
  27. 修正转换字符串的目标字符集属性
  28. -
  29. 回显数据字典防止空值报错
  30. -
  31. 日志记录增加过滤多文件场景
  32. -
  33. 修改缓存Set方法可能导致嵌套的问题
  34. -
  35. 移除前端一些多余的依赖
  36. -
  37. 防止安全扫描YUI出现的风险提示
  38. -
  39. 修改node-sass为dart-sass
  40. -
  41. 升级SpringBoot到最新版本2.1.18
  42. -
  43. 升级poi到最新版本4.1.2
  44. -
  45. 升级oshi到最新版本v5.3.6
  46. -
  47. 升级bitwalker到最新版本1.21
  48. -
  49. 升级axios到最新版本0.21.0
  50. -
  51. 升级element-ui到最新版本2.14.1
  52. -
  53. 升级vue到最新版本2.6.12
  54. -
  55. 升级vuex到最新版本3.6.0
  56. -
  57. 升级vue-cli到版本4.5.9
  58. -
  59. 升级vue-router到最新版本3.4.9
  60. -
  61. 升级vue-cli到最新版本4.4.6
  62. -
  63. 升级vue-cropper到最新版本0.5.5
  64. -
  65. 升级clipboard到最新版本2.0.6
  66. -
  67. 升级core-js到最新版本3.8.1
  68. -
  69. 升级echarts到最新版本4.9.0
  70. -
  71. 升级file-saver到最新版本2.0.4
  72. -
  73. 升级fuse.js到最新版本6.4.3
  74. -
  75. 升级js-beautify到最新版本1.13.0
  76. -
  77. 升级js-cookie到最新版本2.2.1
  78. -
  79. 升级path-to-regexp到最新版本6.2.0
  80. -
  81. 升级quill到最新版本1.3.7
  82. -
  83. 升级screenfull到最新版本5.0.2
  84. -
  85. 升级sortablejs到最新版本1.10.2
  86. -
  87. 升级vuedraggable到最新版本2.24.3
  88. -
  89. 升级chalk到最新版本4.1.0
  90. -
  91. 升级eslint到最新版本7.15.0
  92. -
  93. 升级eslint-plugin-vue到最新版本7.2.0
  94. -
  95. 升级lint-staged到最新版本10.5.3
  96. -
  97. 升级runjs到最新版本4.4.2
  98. -
  99. 升级sass-loader到最新版本10.1.0
  100. -
  101. 升级script-ext-html-webpack-plugin到最新版本2.1.5
  102. -
  103. 升级svg-sprite-loader到最新版本5.1.1
  104. -
  105. 升级vue-template-compiler到最新版本2.6.12
  106. -
  107. 其他细节优化
  108. -
-
- -
    -
  1. 阻止任意文件下载漏洞
  2. -
  3. 代码生成支持上传控件
  4. -
  5. 新增图片上传组件
  6. -
  7. 调整默认首页
  8. -
  9. 升级druid到最新版本v1.2.2
  10. -
  11. mapperLocations配置支持分隔符
  12. -
  13. 权限信息调整
  14. -
  15. 调整sql默认时间
  16. -
  17. 解决代码生成没有bit类型的问题
  18. -
  19. 升级pagehelper到最新版1.3.0
  20. -
-
- -
    -
  1. 升级springboot版本到2.1.17 提升安全性
  2. -
  3. 升级oshi到最新版本v5.2.5
  4. -
  5. 升级druid到最新版本v1.2.1
  6. -
  7. 升级jjwt到版本0.9.1
  8. -
  9. 升级fastjson到最新版1.2.74
  10. -
  11. 修改sass为node-sass,避免el-icon图标乱码
  12. -
  13. 代码生成支持同步数据库
  14. -
  15. 代码生成支持富文本控件
  16. -
  17. 代码生成页面时不忽略remark属性
  18. -
  19. 代码生成添加select必填选项
  20. -
  21. Excel导出类型NUMERIC支持精度浮点类型
  22. -
  23. Excel导出targetAttr优化获取值,防止get方法不规范
  24. -
  25. Excel注解支持自动统计数据总和
  26. -
  27. Excel注解支持设置BigDecimal精度&舍入规则
  28. -
  29. 菜单&数据权限新增(展开/折叠 全选/全不选 父子联动)
  30. -
  31. 允许用户分配到部门父节点
  32. -
  33. 菜单新增是否缓存keep-alive
  34. -
  35. 表格操作列间距调整
  36. -
  37. 限制系统内置参数不允许删除
  38. -
  39. 富文本组件优化,支持自定义高度&图片冲突问题
  40. -
  41. 富文本工具栏样式对齐
  42. -
  43. 导入excel整形值校验优化
  44. -
  45. 修复页签关闭所有时固定标签路由不刷新问题
  46. -
  47. 表单构建布局型组件新增按钮
  48. -
  49. 左侧菜单文字过长显示省略号
  50. -
  51. 修正根节点为子部门时,树状结构显示问题
  52. -
  53. 修正调用目标字符串最大长度
  54. -
  55. 修正菜单提示信息错误
  56. -
  57. 修正定时任务执行一次权限标识
  58. -
  59. 修正数据库字符串类型nvarchar
  60. -
  61. 优化递归子节点
  62. -
  63. 优化数据权限判断
  64. -
  65. 其他细节优化
  66. -
-
- - -
    -
  1. 表格工具栏右侧添加刷新&显隐查询组件
  2. -
  3. 后端支持CORS跨域请求
  4. -
  5. 代码生成支持选择上级菜单
  6. -
  7. 代码生成支持自定义路径
  8. -
  9. 代码生成支持复选框
  10. -
  11. Excel导出导入支持dictType字典类型
  12. -
  13. Excel支持分割字符串组内容
  14. -
  15. 验证码类型支持(数组计算、字符验证)
  16. -
  17. 升级vue-cli版本到4.4.4
  18. -
  19. 修改 node-sass 为 dart-sass
  20. -
  21. 表单类型为Integer/Long设置整形默认值
  22. -
  23. 代码生成器默认mapper路径与默认mapperScan路径不一致
  24. -
  25. 优化防重复提交拦截器
  26. -
  27. 优化上级菜单不能选择自己
  28. -
  29. 修复角色的权限分配后,未实时生效问题
  30. -
  31. 修复在线用户日志记录类型
  32. -
  33. 修复富文本空格和缩进保存后不生效问题
  34. -
  35. 修复在线用户判断逻辑
  36. -
  37. 唯一限制条件只返回单条数据
  38. -
  39. 添加获取当前的环境配置方法
  40. -
  41. 超时登录后页面跳转到首页
  42. -
  43. 全局异常状态汉化拦截处理
  44. -
  45. HTML过滤器改为将html转义
  46. -
  47. 检查字符支持小数点&降级改成异常提醒
  48. -
  49. 其他细节优化
  50. -
-
- - -
    -
  1. 单应用调整为多模块项目
  2. -
  3. 升级element-ui版本到2.13.2
  4. -
  5. 删除babel,提高编译速度。
  6. -
  7. 新增菜单默认主类目
  8. -
  9. 编码文件名修改为uuid方式
  10. -
  11. 定时任务cron表达式验证
  12. -
  13. 角色权限修改时已有权限未自动勾选异常修复
  14. -
  15. 防止切换权限用户后登录出现404
  16. -
  17. Excel支持sort导出排序
  18. -
  19. 创建用户不允许选择超级管理员角色
  20. -
  21. 修复代码生成导入表结构出现异常页面不提醒问题
  22. -
  23. 修复代码生成点击多次表修改数据不变化的问题
  24. -
  25. 修复头像上传成功二次打开无法改变裁剪框大小和位置问题
  26. -
  27. 修复布局为small者mini用户表单显示错位问题
  28. -
  29. 修复热部署导致的强换异常问题
  30. -
  31. 修改用户管理复选框宽度,防止部分浏览器出现省略号
  32. -
  33. IpUtils工具,清除Xss特殊字符,防止Xff注入攻击
  34. -
  35. 生成domain 如果是浮点型 统一用BigDecimal
  36. -
  37. 定时任务调整label-width,防止部署出现错位
  38. -
  39. 调整表头固定列默认样式
  40. -
  41. 代码生成模板调整,字段为String并且必填则加空串条件
  42. -
  43. 代码生成字典Integer/Long使用parseInt
  44. -
  45. - 修复dict_sort不可update为0的问题&查询返回增加dict_sort升序排序 -
  46. -
  47. 修正岗位导出权限注解
  48. -
  49. 禁止加密密文返回前端
  50. -
  51. 修复代码生成页面中的查询条件创建时间未生效的问题
  52. -
  53. 修复首页搜索菜单外链无法点击跳转问题
  54. -
  55. 修复菜单管理选择图标,backspace删除时不过滤数据
  56. -
  57. 用户管理部门分支节点不可检查&显示计数
  58. -
  59. 数据范围过滤属性调整
  60. -
  61. 其他细节优化
  62. -
-
- - -
    -
  1. 升级fastjson到最新版1.2.70 修复高危安全漏洞
  2. -
  3. dev启动默认打开浏览器
  4. -
  5. vue-cli使用默认source-map
  6. -
  7. slidebar eslint报错优化
  8. -
  9. 当tags-view滚动关闭右键菜单
  10. -
  11. 字典管理添加缓存读取
  12. -
  13. 参数管理支持缓存操作
  14. -
  15. 支持一级菜单(和主页同级)在main区域显示
  16. -
  17. 限制外链地址必须以http(s)开头
  18. -
  19. tagview & sidebar 主题颜色与element ui(全局)同步
  20. -
  21. 修改数据源类型优先级,先根据方法,再根据类
  22. -
  23. 支持是否需要设置token属性,自定义返回码消息。
  24. -
  25. swagger请求前缀加入配置。
  26. -
  27. 登录地点设置内容过长则隐藏显示
  28. -
  29. 修复定时任务执行一次按钮后不提示消息问题
  30. -
  31. 修改上级部门(选择项排除本身和下级)
  32. -
  33. 通用http发送方法增加参数 contentType 编码类型
  34. -
  35. 更换IP地址查询接口
  36. -
  37. 修复页签变量undefined
  38. -
  39. 添加校验部门包含未停用的子部门
  40. -
  41. 修改定时任务详情下次执行时间日期显示错误
  42. -
  43. 角色管理查询设置默认排序字段
  44. -
  45. swagger添加enable参数控制是否启用
  46. -
  47. 只对json类型请求构建可重复读取inputStream的request
  48. -
  49. 修改代码生成字典字段int类型没有自动选中问题
  50. -
  51. vuex用户名取值修正
  52. -
  53. 表格树模板去掉多余的)
  54. -
  55. 代码生成序号修正
  56. -
  57. 全屏情况下不调整上外边距
  58. -
  59. 代码生成Date字段添加默认格式
  60. -
  61. 用户管理角色选择权限控制
  62. -
  63. 修复路由懒加载报错问题
  64. -
  65. 模板sql.vm添加菜单状态
  66. -
  67. 设置用户名称不能修改
  68. -
  69. dialog添加append-to-body属性,防止ie遮罩
  70. -
  71. 菜单区分状态和显示隐藏功能
  72. -
  73. 升级fastjson到最新版1.2.68 修复安全加固
  74. -
  75. 修复代码生成如果选择字典类型缺失逗号问题
  76. -
  77. 登录请求params更换为data,防止暴露url
  78. -
  79. 日志返回时间格式处理
  80. -
  81. 添加handle控制允许拖动的元素
  82. -
  83. 布局设置点击扩大范围
  84. -
  85. 代码生成列属性排序查询
  86. -
  87. 代码生成列支持拖动排序
  88. -
  89. 修复时间格式不支持ios问题
  90. -
  91. 表单构建添加父级class,防止冲突
  92. -
  93. 定时任务并发属性修正
  94. -
  95. 角色禁用&菜单隐藏不查询权限
  96. -
  97. 其他细节优化
  98. -
-
- - -
    -
  1. 系统监控新增定时任务功能
  2. -
  3. 添加一个打包Web工程bat
  4. -
  5. 修复页签鼠标滚轮按下的时候,可以关闭不可关闭的tag
  6. -
  7. 修复点击退出登录有时会无提示问题
  8. -
  9. 修复防重复提交注解无效问题
  10. -
  11. 修复通知公告批量删除异常问题
  12. -
  13. 添加菜单时路由地址必填限制
  14. -
  15. 代码生成字段描述可编辑
  16. -
  17. 修复用户修改个人信息导致缓存不过期问题
  18. -
  19. 个人信息创建时间获取正确属性值
  20. -
  21. 操作日志详细显示正确类型
  22. -
  23. 导入表单击行数据时选中对应的复选框
  24. -
  25. 批量替换表前缀逻辑调整
  26. -
  27. 固定重定向路径表达式
  28. -
  29. 升级element-ui版本到2.13.0
  30. -
  31. 操作日志排序调整
  32. -
  33. 修复charts切换侧边栏或者缩放窗口显示bug
  34. -
  35. 其他细节优化
  36. -
-
- - -
    -
  1. 新增表单构建
  2. -
  3. 代码生成支持树表结构
  4. -
  5. 新增用户导入
  6. -
  7. 修复动态加载路由页面刷新问题
  8. -
  9. 修复地址开关无效问题
  10. -
  11. 汉化错误提示页面
  12. -
  13. 代码生成已知问题修改
  14. -
  15. 修复多数据源下配置关闭出现异常处理
  16. -
  17. 添加HTML过滤器,用于去除XSS漏洞隐患
  18. -
  19. 修复上传头像控制台出现异常
  20. -
  21. 修改用户管理分页不正确的问题
  22. -
  23. 修复验证码记录提示错误
  24. -
  25. 修复request.js缺少Message引用
  26. -
  27. 修复表格时间为空出现的异常
  28. -
  29. 添加Jackson日期反序列化时区配置
  30. -
  31. 调整根据用户权限加载菜单数据树形结构
  32. -
  33. 调整成功登录不恢复按钮,防止多次点击
  34. -
  35. 修改用户个人资料同步缓存信息
  36. -
  37. 修复页面同时出现el-upload和Editor不显示处理
  38. -
  39. 修复在角色管理页修改菜单权限偶尔未选中问题
  40. -
  41. 配置文件新增redis密码属性
  42. -
  43. 设置mybatis全局的配置文件
  44. -
  45. 其他细节优化
  46. -
-
- - -
    -
  1. 新增代码生成
  2. -
  3. 新增@RepeatSubmit注解,防止重复提交
  4. -
  5. 新增菜单主目录添加/删除操作
  6. -
  7. 日志记录过滤特殊对象,防止转换异常
  8. -
  9. 修改代码生成路由脚本错误
  10. -
  11. 用户上传头像实时同步缓存,无需重新登录
  12. -
  13. 调整切换页签后不重新加载数据
  14. -
  15. 添加jsencrypt实现参数的前端加密
  16. -
  17. 系统退出删除用户缓存记录
  18. -
  19. 其他细节优化
  20. -
-
- -
    -
  1. 新增在线用户管理
  2. -
  3. 新增按钮组功能实现(批量删除、导出、清空)
  4. -
  5. 新增查询条件重置按钮
  6. -
  7. 新增Swagger全局Token配置
  8. -
  9. 新增后端参数校验
  10. -
  11. 修复字典管理页面的日期查询异常
  12. -
  13. 修改时间函数命名防止冲突
  14. -
  15. 去除菜单上级校验,默认为顶级
  16. -
  17. 修复用户密码无法修改问题
  18. -
  19. 修复菜单类型为按钮时不显示权限标识
  20. -
  21. 其他细节优化
  22. -
-
- -
    -
  1. 若依前后端分离系统正式发布
  2. -
-
-
-
-
- - -
- 捐赠支持 -
-
- donate - 你可以请作者喝杯咖啡表示鼓励 -
-
-
-
diff --git a/ruoyi-ui/src/views/system/distribution/distributorOrder.vue b/ruoyi-ui/src/views/system/distribution/distributorOrder.vue new file mode 100644 index 00000000..23b989ef --- /dev/null +++ b/ruoyi-ui/src/views/system/distribution/distributorOrder.vue @@ -0,0 +1,308 @@ + + + + diff --git a/ruoyi-ui/src/views/system/distribution/index.vue b/ruoyi-ui/src/views/system/distribution/index.vue new file mode 100644 index 00000000..54354e0e --- /dev/null +++ b/ruoyi-ui/src/views/system/distribution/index.vue @@ -0,0 +1,345 @@ + + + + diff --git a/ruoyi-ui/src/views/system/order/index.vue b/ruoyi-ui/src/views/system/order/index.vue index 15a8c09d..a01729be 100644 --- a/ruoyi-ui/src/views/system/order/index.vue +++ b/ruoyi-ui/src/views/system/order/index.vue @@ -10,6 +10,15 @@ /> + + + + --> - + @@ -102,7 +111,7 @@ @@ -116,15 +125,10 @@ {{ parseTime(scope.row.createTime, '{y}-{m}-{d}:{h}:{m}:{s}') }} - + + + - - - - - - 删除 - + -->