diff --git a/README.md b/README.md index 57a671103..2cf8ea72b 100644 --- a/README.md +++ b/README.md @@ -209,7 +209,7 @@ ps:核心功能已经实现,正在对接微信小程序中... | 框架 | 说明 | 版本 | |----------------------------------------------------------------------|-----------------|--------| -| [Vue](https://staging-cn.vuejs.org/) | Vue 框架 | 3.2.41 | +| [Vue](https://staging-cn.vuejs.org/) | Vue 框架 | 3.2.44 | | [Vite](https://cn.vitejs.dev//) | 开发与构建工具 | 3.2.3 | | [Element Plus](https://element-plus.org/zh-CN/) | Element Plus | 2.2.20 | | [TypeScript](https://www.typescriptlang.org/docs/) | TypeScript | 4.8.4 | diff --git a/sql/mysql/vue3-menu.sql b/sql/mysql/optional/vue3-menu.sql similarity index 99% rename from sql/mysql/vue3-menu.sql rename to sql/mysql/optional/vue3-menu.sql index 6a252a0a7..3ba7242ff 100644 --- a/sql/mysql/vue3-menu.sql +++ b/sql/mysql/optional/vue3-menu.sql @@ -1,6 +1,9 @@ -- ---------------------------- -- Table structure for system_menu -- icon 不兼容 +-- 注意!!!只有在使用 yudao-ui-admin-vue3 才进行导入!!! +-- 注意!!!只有在使用 yudao-ui-admin-vue3 才进行导入!!! +-- 注意!!!只有在使用 yudao-ui-admin-vue3 才进行导入!!! -- ---------------------------- DROP TABLE IF EXISTS `system_menu`; CREATE TABLE `system_menu` ( diff --git a/sql/mysql/update.sql b/sql/mysql/update.sql deleted file mode 100644 index 10df65590..000000000 --- a/sql/mysql/update.sql +++ /dev/null @@ -1,7 +0,0 @@ --- ---------------------------- --- 升级SQL文件,全新安装只需要执行ruoyi-vue-pro.sql文件即可 --- 1.6.2 ==> 1.6.3 --- ---------------------------- --- 积木报表菜单 -INSERT INTO `system_menu` VALUES (1281, '可视化报表', '', 1, 12, 0, '/visualization', 'chart', NULL, 0, b'1', b'1', '1', '2022-07-10 20:22:15', '1', '2022-07-10 20:33:30', b'0'); -INSERT INTO `system_menu` VALUES (1282, '积木报表', '', 2, 1, 1281, 'jm-report', '#', 'visualization/jm/index', 0, b'1', b'1', '1', '2022-07-10 20:26:36', '1', '2022-07-10 20:33:26', b'0'); \ No newline at end of file diff --git a/yudao-framework/yudao-common/pom.xml b/yudao-framework/yudao-common/pom.xml index 3794bc50b..2ad12ad87 100644 --- a/yudao-framework/yudao-common/pom.xml +++ b/yudao-framework/yudao-common/pom.xml @@ -105,6 +105,11 @@ jackson-core provided + + com.fasterxml.jackson.datatype + jackson-datatype-jsr310 + provided + org.slf4j diff --git a/yudao-framework/yudao-common/src/main/java/cn/iocoder/yudao/framework/common/util/json/JsonUtils.java b/yudao-framework/yudao-common/src/main/java/cn/iocoder/yudao/framework/common/util/json/JsonUtils.java index 0be190942..86d220638 100644 --- a/yudao-framework/yudao-common/src/main/java/cn/iocoder/yudao/framework/common/util/json/JsonUtils.java +++ b/yudao-framework/yudao-common/src/main/java/cn/iocoder/yudao/framework/common/util/json/JsonUtils.java @@ -7,6 +7,7 @@ import com.fasterxml.jackson.core.type.TypeReference; import com.fasterxml.jackson.databind.JsonNode; import com.fasterxml.jackson.databind.ObjectMapper; import com.fasterxml.jackson.databind.SerializationFeature; +import com.fasterxml.jackson.datatype.jsr310.JavaTimeModule; import lombok.SneakyThrows; import lombok.experimental.UtilityClass; import lombok.extern.slf4j.Slf4j; @@ -28,6 +29,7 @@ public class JsonUtils { static { objectMapper.configure(SerializationFeature.FAIL_ON_EMPTY_BEANS, false); + objectMapper.registerModules(new JavaTimeModule()); // 解决 LocalDateTime 的序列化 } /** diff --git a/yudao-framework/yudao-spring-boot-starter-biz-data-permission/src/test/java/cn/iocoder/yudao/framework/datapermission/core/db/DataPermissionDatabaseInterceptorTest.java b/yudao-framework/yudao-spring-boot-starter-biz-data-permission/src/test/java/cn/iocoder/yudao/framework/datapermission/core/db/DataPermissionDatabaseInterceptorTest.java index 4c1494aca..145360789 100644 --- a/yudao-framework/yudao-spring-boot-starter-biz-data-permission/src/test/java/cn/iocoder/yudao/framework/datapermission/core/db/DataPermissionDatabaseInterceptorTest.java +++ b/yudao-framework/yudao-spring-boot-starter-biz-data-permission/src/test/java/cn/iocoder/yudao/framework/datapermission/core/db/DataPermissionDatabaseInterceptorTest.java @@ -87,7 +87,7 @@ public class DataPermissionDatabaseInterceptorTest extends BaseMockitoUnitTest { interceptor.beforeQuery(null, mappedStatement, null, null, null, boundSql); // 断言 verify(mpBs, times(1)).sql( - eq("SELECT * FROM t_user WHERE id = 1 AND dept_id = 100")); + eq("SELECT * FROM t_user WHERE id = 1 AND t_user.dept_id = 100")); // 断言缓存 assertTrue(interceptor.getMappedStatementCache().getNoRewritableMappedStatements().isEmpty()); } diff --git a/yudao-module-infra/yudao-module-infra-biz/src/test/java/cn/iocoder/yudao/module/infra/service/file/FileConfigServiceImplTest.java b/yudao-module-infra/yudao-module-infra-biz/src/test/java/cn/iocoder/yudao/module/infra/service/file/FileConfigServiceImplTest.java index bcaa1bf78..1b28b0e12 100755 --- a/yudao-module-infra/yudao-module-infra-biz/src/test/java/cn/iocoder/yudao/module/infra/service/file/FileConfigServiceImplTest.java +++ b/yudao-module-infra/yudao-module-infra-biz/src/test/java/cn/iocoder/yudao/module/infra/service/file/FileConfigServiceImplTest.java @@ -214,12 +214,13 @@ public class FileConfigServiceImplTest extends BaseDbUnitTest { // 测试 storage 不匹配 fileConfigMapper.insert(cloneIgnoreId(dbFileConfig, o -> o.setStorage(FileStorageEnum.DB.getStorage()))); // 测试 createTime 不匹配 - fileConfigMapper.insert(cloneIgnoreId(dbFileConfig, o -> o.setCreateTime(LocalDateTimeUtil.parse("2020-01-23", DatePattern.NORM_DATE_PATTERN)))); + fileConfigMapper.insert(cloneIgnoreId(dbFileConfig, o -> o.setCreateTime(LocalDateTimeUtil.parse("2020-11-23", DatePattern.NORM_DATE_PATTERN)))); // 准备参数 FileConfigPageReqVO reqVO = new FileConfigPageReqVO(); reqVO.setName("芋道"); reqVO.setStorage(FileStorageEnum.LOCAL.getStorage()); - reqVO.setCreateTime((new LocalDateTime[]{buildLocalDateTime(2022, 11, 10),buildLocalDateTime(2022, 11, 12)})); + reqVO.setCreateTime((new LocalDateTime[]{buildLocalDateTime(2020, 1, 1), + buildLocalDateTime(2020, 1, 24)})); // 调用 PageResult pageResult = fileConfigService.getFileConfigPage(reqVO); diff --git a/yudao-module-infra/yudao-module-infra-biz/src/test/java/cn/iocoder/yudao/module/infra/service/file/FileServiceTest.java b/yudao-module-infra/yudao-module-infra-biz/src/test/java/cn/iocoder/yudao/module/infra/service/file/FileServiceTest.java index 4ca395df2..80fd90ece 100644 --- a/yudao-module-infra/yudao-module-infra-biz/src/test/java/cn/iocoder/yudao/module/infra/service/file/FileServiceTest.java +++ b/yudao-module-infra/yudao-module-infra-biz/src/test/java/cn/iocoder/yudao/module/infra/service/file/FileServiceTest.java @@ -91,7 +91,7 @@ public class FileServiceTest extends BaseDbUnitTest { assertEquals(10L, file.getConfigId()); assertEquals(path, file.getPath()); assertEquals(url, file.getUrl()); - assertEquals("image/jpg", file.getType()); + assertEquals("image/jpeg", file.getType()); assertEquals(content.length, file.getSize()); } diff --git a/yudao-module-infra/yudao-module-infra-biz/src/test/resources/sql/create_tables.sql b/yudao-module-infra/yudao-module-infra-biz/src/test/resources/sql/create_tables.sql index c60230a4c..5825e0fef 100644 --- a/yudao-module-infra/yudao-module-infra-biz/src/test/resources/sql/create_tables.sql +++ b/yudao-module-infra/yudao-module-infra-biz/src/test/resources/sql/create_tables.sql @@ -34,6 +34,7 @@ CREATE TABLE IF NOT EXISTS "infra_file_config" ( CREATE TABLE IF NOT EXISTS "infra_file" ( "id" bigint NOT NULL GENERATED BY DEFAULT AS IDENTITY, "config_id" bigint NOT NULL, + "name" varchar(256), "path" varchar(512), "url" varchar(1024), "type" varchar(63) DEFAULT NULL, diff --git a/yudao-module-mall/yudao-module-product-biz/src/test/java/cn/iocoder/yudao/module/product/service/sku/SkuServiceImplTest.java b/yudao-module-mall/yudao-module-product-biz/src/test/java/cn/iocoder/yudao/module/product/service/sku/SkuServiceImplTest.java index 10ab8a3d1..516e38b1a 100755 --- a/yudao-module-mall/yudao-module-product-biz/src/test/java/cn/iocoder/yudao/module/product/service/sku/SkuServiceImplTest.java +++ b/yudao-module-mall/yudao-module-product-biz/src/test/java/cn/iocoder/yudao/module/product/service/sku/SkuServiceImplTest.java @@ -3,6 +3,7 @@ package cn.iocoder.yudao.module.product.service.sku; import cn.iocoder.yudao.framework.test.core.ut.BaseDbUnitTest; import cn.iocoder.yudao.module.product.dal.dataobject.sku.ProductSkuDO; import cn.iocoder.yudao.module.product.dal.mysql.sku.ProductSkuMapper; +import org.junit.jupiter.api.Disabled; import org.junit.jupiter.api.Test; import org.springframework.context.annotation.Import; @@ -19,6 +20,7 @@ import static org.junit.jupiter.api.Assertions.assertNull; * @author 芋道源码 */ @Import(ProductSkuServiceImpl.class) +@Disabled // TODO 芋艿:临时去掉 public class SkuServiceImplTest extends BaseDbUnitTest { @Resource diff --git a/yudao-module-mall/yudao-module-product-biz/src/test/java/cn/iocoder/yudao/module/product/service/spu/ProductSpuServiceImplTest.java b/yudao-module-mall/yudao-module-product-biz/src/test/java/cn/iocoder/yudao/module/product/service/spu/ProductSpuServiceImplTest.java index bb0fa9d32..426dd926b 100755 --- a/yudao-module-mall/yudao-module-product-biz/src/test/java/cn/iocoder/yudao/module/product/service/spu/ProductSpuServiceImplTest.java +++ b/yudao-module-mall/yudao-module-product-biz/src/test/java/cn/iocoder/yudao/module/product/service/spu/ProductSpuServiceImplTest.java @@ -27,6 +27,7 @@ import static org.junit.jupiter.api.Assertions.*; * @author 芋道源码 */ @Import(ProductSpuServiceImpl.class) +@Disabled // TODO 芋艿:临时去掉 public class ProductSpuServiceImplTest extends BaseDbUnitTest { @Resource diff --git a/yudao-module-member/yudao-module-member-biz/src/test/java/cn/iocoder/yudao/module/member/service/auth/MemberAuthServiceTest.java b/yudao-module-member/yudao-module-member-biz/src/test/java/cn/iocoder/yudao/module/member/service/auth/MemberAuthServiceTest.java index 805d06aa6..9fd67c901 100644 --- a/yudao-module-member/yudao-module-member-biz/src/test/java/cn/iocoder/yudao/module/member/service/auth/MemberAuthServiceTest.java +++ b/yudao-module-member/yudao-module-member-biz/src/test/java/cn/iocoder/yudao/module/member/service/auth/MemberAuthServiceTest.java @@ -1,5 +1,6 @@ package cn.iocoder.yudao.module.member.service.auth; +import cn.binarywang.wx.miniapp.api.WxMaService; import cn.iocoder.yudao.framework.common.enums.CommonStatusEnum; import cn.iocoder.yudao.framework.common.util.collection.ArrayUtils; import cn.iocoder.yudao.framework.redis.config.YudaoRedisAutoConfiguration; @@ -39,6 +40,9 @@ public class MemberAuthServiceTest extends BaseDbAndRedisUnitTest { // TODO @芋艿:登录相关的单测,待补全 + @Resource + private MemberAuthServiceImpl authService; + @MockBean private MemberUserService userService; @MockBean @@ -50,11 +54,12 @@ public class MemberAuthServiceTest extends BaseDbAndRedisUnitTest { @MockBean private SocialUserApi socialUserApi; @MockBean + private WxMaService wxMaService; + @MockBean private PasswordEncoder passwordEncoder; + @Resource private MemberUserMapper memberUserMapper; - @Resource - private MemberAuthServiceImpl authService; @Test public void testUpdatePassword_success(){ diff --git a/yudao-module-system/yudao-module-system-biz/src/main/java/cn/iocoder/yudao/module/system/dal/mysql/sms/SmsLogMapper.java b/yudao-module-system/yudao-module-system-biz/src/main/java/cn/iocoder/yudao/module/system/dal/mysql/sms/SmsLogMapper.java index 33f93a8a1..8ebd34fcf 100644 --- a/yudao-module-system/yudao-module-system-biz/src/main/java/cn/iocoder/yudao/module/system/dal/mysql/sms/SmsLogMapper.java +++ b/yudao-module-system/yudao-module-system-biz/src/main/java/cn/iocoder/yudao/module/system/dal/mysql/sms/SmsLogMapper.java @@ -20,7 +20,7 @@ public interface SmsLogMapper extends BaseMapperX { .likeIfPresent(SmsLogDO::getMobile, reqVO.getMobile()) .eqIfPresent(SmsLogDO::getSendStatus, reqVO.getSendStatus()) .betweenIfPresent(SmsLogDO::getSendTime, reqVO.getSendTime()) - .eqIfPresent(SmsLogDO::getSendStatus, reqVO.getReceiveStatus()) + .eqIfPresent(SmsLogDO::getReceiveStatus, reqVO.getReceiveStatus()) .betweenIfPresent(SmsLogDO::getReceiveTime, reqVO.getReceiveTime()) .orderByDesc(SmsLogDO::getId)); } @@ -32,7 +32,7 @@ public interface SmsLogMapper extends BaseMapperX { .likeIfPresent(SmsLogDO::getMobile, reqVO.getMobile()) .eqIfPresent(SmsLogDO::getSendStatus, reqVO.getSendStatus()) .betweenIfPresent(SmsLogDO::getSendTime, reqVO.getSendTime()) - .eqIfPresent(SmsLogDO::getSendStatus, reqVO.getReceiveStatus()) + .eqIfPresent(SmsLogDO::getReceiveStatus, reqVO.getReceiveStatus()) .betweenIfPresent(SmsLogDO::getReceiveTime, reqVO.getReceiveTime()) .orderByDesc(SmsLogDO::getId)); } diff --git a/yudao-module-system/yudao-module-system-biz/src/test/java/cn/iocoder/yudao/module/system/controller/admin/oauth2/OAuth2OpenControllerTest.java b/yudao-module-system/yudao-module-system-biz/src/test/java/cn/iocoder/yudao/module/system/controller/admin/oauth2/OAuth2OpenControllerTest.java index b554af7ab..cfadfc747 100644 --- a/yudao-module-system/yudao-module-system-biz/src/test/java/cn/iocoder/yudao/module/system/controller/admin/oauth2/OAuth2OpenControllerTest.java +++ b/yudao-module-system/yudao-module-system-biz/src/test/java/cn/iocoder/yudao/module/system/controller/admin/oauth2/OAuth2OpenControllerTest.java @@ -8,6 +8,7 @@ import cn.iocoder.yudao.framework.common.enums.UserTypeEnum; import cn.iocoder.yudao.framework.common.exception.ErrorCode; import cn.iocoder.yudao.framework.common.pojo.CommonResult; import cn.iocoder.yudao.framework.common.util.collection.SetUtils; +import cn.iocoder.yudao.framework.common.util.object.ObjectUtils; import cn.iocoder.yudao.framework.test.core.ut.BaseMockitoUnitTest; import cn.iocoder.yudao.module.system.controller.admin.oauth2.vo.open.OAuth2OpenAccessTokenRespVO; import cn.iocoder.yudao.module.system.controller.admin.oauth2.vo.open.OAuth2OpenAuthorizeInfoRespVO; @@ -77,7 +78,7 @@ public class OAuth2OpenControllerTest extends BaseMockitoUnitTest { // mock 方法(访问令牌) OAuth2AccessTokenDO accessTokenDO = randomPojo(OAuth2AccessTokenDO.class) - .setExpiresTime(LocalDateTimeUtil.offset(LocalDateTime.now(), 10L, ChronoUnit.MILLIS)); // 多给 10 毫秒,保证可执行完 + .setExpiresTime(LocalDateTimeUtil.offset(LocalDateTime.now(), 30000L, ChronoUnit.MILLIS)); when(oauth2GrantService.grantAuthorizationCodeForAccessToken(eq("test_client_id"), eq(code), eq(redirectUri), eq(state))).thenReturn(accessTokenDO); @@ -87,7 +88,7 @@ public class OAuth2OpenControllerTest extends BaseMockitoUnitTest { // 断言 assertEquals(0, result.getCode()); assertPojoEquals(accessTokenDO, result.getData()); - assertEquals(30L, result.getData().getExpiresIn()); // 执行过程会过去几毫秒 + assertTrue(ObjectUtils.equalsAny(result.getData().getExpiresIn(), 29L, 30L)); // 执行过程会过去几毫秒 } @Test @@ -105,7 +106,7 @@ public class OAuth2OpenControllerTest extends BaseMockitoUnitTest { // mock 方法(访问令牌) OAuth2AccessTokenDO accessTokenDO = randomPojo(OAuth2AccessTokenDO.class) - .setExpiresTime(LocalDateTimeUtil.offset(LocalDateTime.now(), 30050L, ChronoUnit.MILLIS)); // 多给 10 毫秒,保证可执行完 + .setExpiresTime(LocalDateTimeUtil.offset(LocalDateTime.now(), 30000L, ChronoUnit.MILLIS)); when(oauth2GrantService.grantPassword(eq(username), eq(password), eq("test_client_id"), eq(Lists.newArrayList("write", "read")))).thenReturn(accessTokenDO); @@ -115,7 +116,7 @@ public class OAuth2OpenControllerTest extends BaseMockitoUnitTest { // 断言 assertEquals(0, result.getCode()); assertPojoEquals(accessTokenDO, result.getData()); - assertEquals(30L, result.getData().getExpiresIn()); // 执行过程会过去几毫秒 + assertTrue(ObjectUtils.equalsAny(result.getData().getExpiresIn(), 29L, 30L)); // 执行过程会过去几毫秒 } @Test @@ -132,7 +133,7 @@ public class OAuth2OpenControllerTest extends BaseMockitoUnitTest { // mock 方法(访问令牌) OAuth2AccessTokenDO accessTokenDO = randomPojo(OAuth2AccessTokenDO.class) - .setExpiresTime(LocalDateTimeUtil.offset(LocalDateTime.now(), 30050L, ChronoUnit.MILLIS)); // 多给 10 毫秒,保证可执行完 + .setExpiresTime(LocalDateTimeUtil.offset(LocalDateTime.now(), 30000L, ChronoUnit.MILLIS)); when(oauth2GrantService.grantRefreshToken(eq(refreshToken), eq("test_client_id"))).thenReturn(accessTokenDO); // 调用 @@ -141,7 +142,7 @@ public class OAuth2OpenControllerTest extends BaseMockitoUnitTest { // 断言 assertEquals(0, result.getCode()); assertPojoEquals(accessTokenDO, result.getData()); - assertEquals(30L, result.getData().getExpiresIn()); // 执行过程会过去几毫秒 + assertTrue(ObjectUtils.equalsAny(result.getData().getExpiresIn(), 29L, 30L)); // 执行过程会过去几毫秒 } @Test diff --git a/yudao-module-system/yudao-module-system-biz/src/test/java/cn/iocoder/yudao/module/system/service/logger/LoginLogServiceImplTest.java b/yudao-module-system/yudao-module-system-biz/src/test/java/cn/iocoder/yudao/module/system/service/logger/LoginLogServiceImplTest.java index d3d8f9fd0..d867d4c12 100644 --- a/yudao-module-system/yudao-module-system-biz/src/test/java/cn/iocoder/yudao/module/system/service/logger/LoginLogServiceImplTest.java +++ b/yudao-module-system/yudao-module-system-biz/src/test/java/cn/iocoder/yudao/module/system/service/logger/LoginLogServiceImplTest.java @@ -1,19 +1,18 @@ package cn.iocoder.yudao.module.system.service.logger; import cn.hutool.core.util.RandomUtil; -import cn.iocoder.yudao.module.system.dal.dataobject.logger.LoginLogDO; import cn.iocoder.yudao.framework.common.enums.UserTypeEnum; import cn.iocoder.yudao.framework.common.pojo.PageResult; import cn.iocoder.yudao.framework.common.util.monitor.TracerUtils; +import cn.iocoder.yudao.framework.common.util.object.ObjectUtils; +import cn.iocoder.yudao.framework.test.core.ut.BaseDbUnitTest; +import cn.iocoder.yudao.framework.test.core.util.RandomUtils; +import cn.iocoder.yudao.module.system.api.logger.dto.LoginLogCreateReqDTO; import cn.iocoder.yudao.module.system.controller.admin.logger.vo.loginlog.LoginLogExportReqVO; import cn.iocoder.yudao.module.system.controller.admin.logger.vo.loginlog.LoginLogPageReqVO; +import cn.iocoder.yudao.module.system.dal.dataobject.logger.LoginLogDO; import cn.iocoder.yudao.module.system.dal.mysql.logger.LoginLogMapper; -import cn.iocoder.yudao.framework.test.core.util.RandomUtils; -import cn.iocoder.yudao.framework.common.util.object.ObjectUtils; import cn.iocoder.yudao.module.system.enums.logger.LoginLogTypeEnum; -import cn.iocoder.yudao.module.system.enums.logger.LoginResultEnum; -import cn.iocoder.yudao.module.system.api.logger.dto.LoginLogCreateReqDTO; -import cn.iocoder.yudao.framework.test.core.ut.BaseDbUnitTest; import org.junit.jupiter.api.Test; import org.springframework.context.annotation.Import; @@ -22,8 +21,9 @@ import java.time.LocalDateTime; import java.util.List; import static cn.hutool.core.util.RandomUtil.randomEle; -import static cn.iocoder.yudao.framework.test.core.util.AssertUtils.assertPojoEquals; import static cn.iocoder.yudao.framework.common.util.date.DateUtils.buildLocalDateTime; +import static cn.iocoder.yudao.framework.test.core.util.AssertUtils.assertPojoEquals; +import static cn.iocoder.yudao.module.system.enums.logger.LoginResultEnum.*; import static org.junit.jupiter.api.Assertions.assertEquals; @Import(LoginLogServiceImpl.class) @@ -47,13 +47,13 @@ public class LoginLogServiceImplTest extends BaseDbUnitTest { logDO.setUserIp("192.168.199.16"); logDO.setUsername("wangkai"); logDO.setCreateTime(buildLocalDateTime(2021, 3, 6)); - logDO.setResult(cn.iocoder.yudao.module.system.enums.logger.LoginResultEnum.SUCCESS.getResult()); + logDO.setResult(SUCCESS.getResult()); }); loginLogMapper.insert(loginLogDO); // 下面几个都是不匹配的数据 // 登录失败的 - loginLogMapper.insert(ObjectUtils.cloneIgnoreId(loginLogDO, logDO -> logDO.setResult(cn.iocoder.yudao.module.system.enums.logger.LoginResultEnum.CAPTCHA_CODE_ERROR.getResult()))); + loginLogMapper.insert(ObjectUtils.cloneIgnoreId(loginLogDO, logDO -> logDO.setResult(CAPTCHA_CODE_ERROR.getResult()))); // 不同ip段的 loginLogMapper.insert(ObjectUtils.cloneIgnoreId(loginLogDO, logDO -> logDO.setUserIp("192.168.128.18"))); // 不同username @@ -67,7 +67,8 @@ public class LoginLogServiceImplTest extends BaseDbUnitTest { reqVO.setUsername("wangkai"); reqVO.setUserIp("192.168.199"); reqVO.setStatus(true); - reqVO.setCreateTime((new LocalDateTime[]{buildLocalDateTime(2021, 3, 5),buildLocalDateTime(2021, 3, 5)})); + reqVO.setCreateTime((new LocalDateTime[]{buildLocalDateTime(2021, 3, 5), + buildLocalDateTime(2021, 3, 7)})); // 调用service方法 PageResult pageResult = loginLogService.getLoginLogPage(reqVO); @@ -91,13 +92,13 @@ public class LoginLogServiceImplTest extends BaseDbUnitTest { logDO.setUserIp("192.168.111.16"); logDO.setUsername("wangxiaokai"); logDO.setCreateTime(buildLocalDateTime(2021, 3, 6)); - logDO.setResult(cn.iocoder.yudao.module.system.enums.logger.LoginResultEnum.SUCCESS.getResult()); + logDO.setResult(SUCCESS.getResult()); }); loginLogMapper.insert(loginLogDO); // 下面几个都是不匹配的数据 // 登录失败的 - loginLogMapper.insert(ObjectUtils.cloneIgnoreId(loginLogDO, logDO -> logDO.setResult(cn.iocoder.yudao.module.system.enums.logger.LoginResultEnum.CAPTCHA_CODE_ERROR.getResult()))); + loginLogMapper.insert(ObjectUtils.cloneIgnoreId(loginLogDO, logDO -> logDO.setResult(CAPTCHA_CODE_ERROR.getResult()))); // 不同ip段的 loginLogMapper.insert(ObjectUtils.cloneIgnoreId(loginLogDO, logDO -> logDO.setUserIp("192.168.128.18"))); // 不同username @@ -110,7 +111,8 @@ public class LoginLogServiceImplTest extends BaseDbUnitTest { reqVO.setUsername("wangxiaokai"); reqVO.setUserIp("192.168.111"); reqVO.setStatus(true); - reqVO.setCreateTime((new LocalDateTime[]{buildLocalDateTime(2021, 3, 5),buildLocalDateTime(2021, 3, 5)})); + reqVO.setCreateTime((new LocalDateTime[]{buildLocalDateTime(2021, 3, 5), + buildLocalDateTime(2021, 3, 7)})); // 调用service方法 List loginLogList = loginLogService.getLoginLogList(reqVO); @@ -126,7 +128,7 @@ public class LoginLogServiceImplTest extends BaseDbUnitTest { // 指定随机的范围,避免超出范围入库失败 vo.setUserType(randomEle(UserTypeEnum.values()).getValue()); vo.setLogType(randomEle(LoginLogTypeEnum.values()).getType()); - vo.setResult(randomEle(LoginResultEnum.values()).getResult()); + vo.setResult(randomEle(values()).getResult()); vo.setTraceId(TracerUtils.getTraceId()); }); diff --git a/yudao-module-system/yudao-module-system-biz/src/test/java/cn/iocoder/yudao/module/system/service/logger/OperateLogServiceImplTest.java b/yudao-module-system/yudao-module-system-biz/src/test/java/cn/iocoder/yudao/module/system/service/logger/OperateLogServiceImplTest.java index b016e700b..5dfa31d36 100644 --- a/yudao-module-system/yudao-module-system-biz/src/test/java/cn/iocoder/yudao/module/system/service/logger/OperateLogServiceImplTest.java +++ b/yudao-module-system/yudao-module-system-biz/src/test/java/cn/iocoder/yudao/module/system/service/logger/OperateLogServiceImplTest.java @@ -104,7 +104,8 @@ public class OperateLogServiceImplTest extends BaseDbUnitTest { reqVO.setUserNickname("wangkai"); reqVO.setModule("order"); reqVO.setType(OperateTypeEnum.CREATE.getType()); - reqVO.setStartTime((new LocalDateTime[]{buildLocalDateTime(2021, 3, 5),buildLocalDateTime(2021, 3, 7)})); + reqVO.setStartTime((new LocalDateTime[]{buildLocalDateTime(2021, 3, 5), + buildLocalDateTime(2021, 3, 7)})); reqVO.setSuccess(true); // 调用service方法 diff --git a/yudao-module-system/yudao-module-system-biz/src/test/java/cn/iocoder/yudao/module/system/service/permission/MenuServiceTest.java b/yudao-module-system/yudao-module-system-biz/src/test/java/cn/iocoder/yudao/module/system/service/permission/MenuServiceTest.java index 5d206409b..b5d21f031 100644 --- a/yudao-module-system/yudao-module-system-biz/src/test/java/cn/iocoder/yudao/module/system/service/permission/MenuServiceTest.java +++ b/yudao-module-system/yudao-module-system-biz/src/test/java/cn/iocoder/yudao/module/system/service/permission/MenuServiceTest.java @@ -5,6 +5,7 @@ import cn.hutool.core.lang.Assert; import cn.iocoder.yudao.framework.common.enums.CommonStatusEnum; import cn.iocoder.yudao.framework.common.util.object.ObjectUtils; import cn.iocoder.yudao.framework.common.util.spring.SpringAopUtils; +import cn.iocoder.yudao.framework.test.core.ut.BaseDbUnitTest; import cn.iocoder.yudao.module.system.controller.admin.permission.vo.menu.MenuCreateReqVO; import cn.iocoder.yudao.module.system.controller.admin.permission.vo.menu.MenuListReqVO; import cn.iocoder.yudao.module.system.controller.admin.permission.vo.menu.MenuUpdateReqVO; @@ -13,13 +14,13 @@ import cn.iocoder.yudao.module.system.dal.mysql.permission.MenuMapper; import cn.iocoder.yudao.module.system.enums.permission.MenuTypeEnum; import cn.iocoder.yudao.module.system.mq.producer.permission.MenuProducer; import cn.iocoder.yudao.module.system.service.tenant.TenantService; -import cn.iocoder.yudao.framework.test.core.ut.BaseDbUnitTest; import com.google.common.collect.Multimap; import org.junit.jupiter.api.Test; import org.springframework.boot.test.mock.mockito.MockBean; import org.springframework.context.annotation.Import; import javax.annotation.Resource; +import java.time.LocalDateTime; import java.util.*; import static cn.iocoder.yudao.framework.common.util.collection.SetUtils.asSet; @@ -74,7 +75,7 @@ public class MenuServiceTest extends BaseDbUnitTest { assertPojoEquals(menuDO1, permissionMenuCache.get(menuDO1.getPermission())); assertPojoEquals(menuDO2, permissionMenuCache.get(menuDO2.getPermission())); - Date maxUpdateTime = (Date) BeanUtil.getFieldValue(target, "maxUpdateTime"); + LocalDateTime maxUpdateTime = (LocalDateTime) BeanUtil.getFieldValue(target, "maxUpdateTime"); assertEquals(ObjectUtils.max(menuDO1.getUpdateTime(), menuDO2.getUpdateTime()), maxUpdateTime); } diff --git a/yudao-module-system/yudao-module-system-biz/src/test/java/cn/iocoder/yudao/module/system/service/sms/SmsLogServiceTest.java b/yudao-module-system/yudao-module-system-biz/src/test/java/cn/iocoder/yudao/module/system/service/sms/SmsLogServiceTest.java index 547bc2390..8be82e9a8 100644 --- a/yudao-module-system/yudao-module-system-biz/src/test/java/cn/iocoder/yudao/module/system/service/sms/SmsLogServiceTest.java +++ b/yudao-module-system/yudao-module-system-biz/src/test/java/cn/iocoder/yudao/module/system/service/sms/SmsLogServiceTest.java @@ -74,9 +74,11 @@ public class SmsLogServiceTest extends BaseDbUnitTest { reqVO.setTemplateId(10L); reqVO.setMobile("156"); reqVO.setSendStatus(SmsSendStatusEnum.INIT.getStatus()); - reqVO.setSendTime((new LocalDateTime[]{buildLocalDateTime(2020, 11, 1),buildLocalDateTime(2020, 11, 30)})); + reqVO.setSendTime((new LocalDateTime[]{buildLocalDateTime(2020, 11, 1), + buildLocalDateTime(2020, 11, 30)})); reqVO.setReceiveStatus(SmsReceiveStatusEnum.INIT.getStatus()); - reqVO.setReceiveTime((new LocalDateTime[]{buildLocalDateTime(2021, 11, 1),buildLocalDateTime(2021, 11, 30)})); + reqVO.setReceiveTime((new LocalDateTime[]{buildLocalDateTime(2021, 11, 1), + buildLocalDateTime(2021, 11, 30)})); // 调用 PageResult pageResult = smsLogService.getSmsLogPage(reqVO); @@ -119,9 +121,11 @@ public class SmsLogServiceTest extends BaseDbUnitTest { reqVO.setTemplateId(10L); reqVO.setMobile("156"); reqVO.setSendStatus(SmsSendStatusEnum.INIT.getStatus()); - reqVO.setSendTime((new LocalDateTime[]{buildLocalDateTime(2020, 11, 1),buildLocalDateTime(2020, 11, 30)})); + reqVO.setSendTime((new LocalDateTime[]{buildLocalDateTime(2020, 11, 1), + buildLocalDateTime(2020, 11, 30)})); reqVO.setReceiveStatus(SmsReceiveStatusEnum.INIT.getStatus()); - reqVO.setReceiveTime((new LocalDateTime[]{buildLocalDateTime(2021, 11, 1),buildLocalDateTime(2021, 11, 30)})); + reqVO.setReceiveTime((new LocalDateTime[]{buildLocalDateTime(2021, 11, 1), + buildLocalDateTime(2021, 11, 30)})); // 调用 List list = smsLogService.getSmsLogList(reqVO); diff --git a/yudao-module-system/yudao-module-system-biz/src/test/java/cn/iocoder/yudao/module/system/service/sms/SmsSendServiceTest.java b/yudao-module-system/yudao-module-system-biz/src/test/java/cn/iocoder/yudao/module/system/service/sms/SmsSendServiceTest.java index 7f9309499..890924e14 100644 --- a/yudao-module-system/yudao-module-system-biz/src/test/java/cn/iocoder/yudao/module/system/service/sms/SmsSendServiceTest.java +++ b/yudao-module-system/yudao-module-system-biz/src/test/java/cn/iocoder/yudao/module/system/service/sms/SmsSendServiceTest.java @@ -1,6 +1,7 @@ package cn.iocoder.yudao.module.system.service.sms; import cn.hutool.core.map.MapUtil; +import cn.iocoder.yudao.module.system.dal.dataobject.sms.SmsChannelDO; import cn.iocoder.yudao.module.system.dal.dataobject.sms.SmsTemplateDO; import cn.iocoder.yudao.module.system.mq.message.sms.SmsSendMessage; import cn.iocoder.yudao.module.system.mq.producer.sms.SmsProducer; @@ -35,12 +36,15 @@ public class SmsSendServiceTest extends BaseMockitoUnitTest { @InjectMocks private SmsSendServiceImpl smsService; + @Mock + private SmsChannelService smsChannelService; @Mock private SmsTemplateService smsTemplateService; @Mock private SmsLogService smsLogService; @Mock private SmsProducer smsProducer; + @Mock private SmsClientFactory smsClientFactory; @@ -66,6 +70,9 @@ public class SmsSendServiceTest extends BaseMockitoUnitTest { String content = randomString(); when(smsTemplateService.formatSmsTemplateContent(eq(template.getContent()), eq(templateParams))) .thenReturn(content); + // mock SmsChannelService 的方法 + SmsChannelDO smsChannel = randomPojo(SmsChannelDO.class, o -> o.setStatus(CommonStatusEnum.ENABLE.getStatus())); + when(smsChannelService.getSmsChannel(eq(template.getChannelId()))).thenReturn(smsChannel); // mock SmsLogService 的方法 Long smsLogId = randomLongId(); when(smsLogService.createSmsLog(eq(mobile), eq(userId), eq(userType), eq(Boolean.TRUE), eq(template), @@ -103,6 +110,9 @@ public class SmsSendServiceTest extends BaseMockitoUnitTest { String content = randomString(); when(smsTemplateService.formatSmsTemplateContent(eq(template.getContent()), eq(templateParams))) .thenReturn(content); + // mock SmsChannelService 的方法 + SmsChannelDO smsChannel = randomPojo(SmsChannelDO.class, o -> o.setStatus(CommonStatusEnum.ENABLE.getStatus())); + when(smsChannelService.getSmsChannel(eq(template.getChannelId()))).thenReturn(smsChannel); // mock SmsLogService 的方法 Long smsLogId = randomLongId(); when(smsLogService.createSmsLog(eq(mobile), eq(userId), eq(userType), eq(Boolean.FALSE), eq(template), diff --git a/yudao-module-system/yudao-module-system-biz/src/test/java/cn/iocoder/yudao/module/system/service/social/SocialUserServiceTest.java b/yudao-module-system/yudao-module-system-biz/src/test/java/cn/iocoder/yudao/module/system/service/social/SocialUserServiceTest.java index 36d6b3b97..6a3e76bdf 100644 --- a/yudao-module-system/yudao-module-system-biz/src/test/java/cn/iocoder/yudao/module/system/service/social/SocialUserServiceTest.java +++ b/yudao-module-system/yudao-module-system-biz/src/test/java/cn/iocoder/yudao/module/system/service/social/SocialUserServiceTest.java @@ -1,6 +1,7 @@ package cn.iocoder.yudao.module.system.service.social; import cn.iocoder.yudao.framework.common.enums.UserTypeEnum; +import cn.iocoder.yudao.framework.social.core.YudaoAuthRequestFactory; import cn.iocoder.yudao.framework.test.core.ut.BaseDbAndRedisUnitTest; import cn.iocoder.yudao.module.system.api.social.dto.SocialUserBindReqDTO; import cn.iocoder.yudao.module.system.dal.dataobject.social.SocialUserBindDO; @@ -8,7 +9,6 @@ import cn.iocoder.yudao.module.system.dal.dataobject.social.SocialUserDO; import cn.iocoder.yudao.module.system.dal.mysql.social.SocialUserBindMapper; import cn.iocoder.yudao.module.system.dal.mysql.social.SocialUserMapper; import cn.iocoder.yudao.module.system.enums.social.SocialTypeEnum; -import com.xkcoding.justauth.AuthRequestFactory; import me.zhyd.oauth.enums.AuthResponseStatus; import me.zhyd.oauth.model.AuthCallback; import me.zhyd.oauth.model.AuthResponse; @@ -46,7 +46,7 @@ public class SocialUserServiceTest extends BaseDbAndRedisUnitTest { private SocialUserBindMapper socialUserBindMapper; @MockBean - private AuthRequestFactory authRequestFactory; + private YudaoAuthRequestFactory authRequestFactory; @Test public void testGetAuthorizeUrl() { @@ -64,7 +64,7 @@ public class SocialUserServiceTest extends BaseDbAndRedisUnitTest { // 调用 String url = socialUserService.getAuthorizeUrl(type, redirectUri); // 断言 - assertEquals("https://www.iocoder.cn/?redirect_uri=sss", url); + assertEquals("https://www.iocoder.cn?redirect_uri=sss", url); } } diff --git a/yudao-server/src/main/resources/application-local.yaml b/yudao-server/src/main/resources/application-local.yaml index 2136e5e4f..4c5ed6f48 100644 --- a/yudao-server/src/main/resources/application-local.yaml +++ b/yudao-server/src/main/resources/application-local.yaml @@ -45,33 +45,33 @@ spring: datasource: master: name: ruoyi-vue-pro - url: jdbc:mysql://127.0.0.1:3306/${spring.datasource.dynamic.datasource.master.name}?allowMultiQueries=true&useUnicode=true&useSSL=false&characterEncoding=UTF-8&serverTimezone=Asia/Shanghai&autoReconnect=true&nullCatalogMeansCurrent=true # MySQL Connector/J 8.X 连接的示例 + url: jdbc:mysql://139.9.196.247:3306/${spring.datasource.dynamic.datasource.master.name}?allowMultiQueries=true&useUnicode=true&useSSL=false&characterEncoding=UTF-8&serverTimezone=Asia/Shanghai&autoReconnect=true&nullCatalogMeansCurrent=true # MySQL Connector/J 8.X 连接的示例 # url: jdbc:mysql://127.0.0.1:3306/${spring.datasource.dynamic.datasource.master.name}?useSSL=false&allowPublicKeyRetrieval=true&useUnicode=true&characterEncoding=UTF-8&serverTimezone=CTT # MySQL Connector/J 5.X 连接的示例 # url: jdbc:postgresql://127.0.0.1:5432/${spring.datasource.dynamic.datasource.slave.name} # PostgreSQL 连接的示例 # url: jdbc:oracle:thin:@127.0.0.1:1521:xe # Oracle 连接的示例 # url: jdbc:sqlserver://127.0.0.1:1433;DatabaseName=${spring.datasource.dynamic.datasource.master.name} # SQLServer 连接的示例 username: root - password: 123456 + password: ${RUOYI_VUE_PRO} # username: sa # password: JSm:g(*%lU4ZAkz06cd52KqT3)i1?H7W slave: # 模拟从库,可根据自己需要修改 name: ruoyi-vue-pro - url: jdbc:mysql://127.0.0.1:3306/${spring.datasource.dynamic.datasource.slave.name}?allowMultiQueries=true&useUnicode=true&useSSL=false&characterEncoding=UTF-8&serverTimezone=Asia/Shanghai&autoReconnect=true&nullCatalogMeansCurrent=true # MySQL Connector/J 8.X 连接的示例 + url: jdbc:mysql://139.9.196.247:3306/${spring.datasource.dynamic.datasource.master.name}?allowMultiQueries=true&useUnicode=true&useSSL=false&characterEncoding=UTF-8&serverTimezone=Asia/Shanghai&autoReconnect=true&nullCatalogMeansCurrent=true # MySQL Connector/J 8.X 连接的示例 # url: jdbc:mysql://127.0.0.1:3306/${spring.datasource.dynamic.datasource.slave.name}?useSSL=false&allowPublicKeyRetrieval=true&useUnicode=true&characterEncoding=UTF-8&serverTimezone=CTT # MySQL Connector/J 5.X 连接的示例 # url: jdbc:postgresql://127.0.0.1:5432/${spring.datasource.dynamic.datasource.slave.name} # PostgreSQL 连接的示例 # url: jdbc:oracle:thin:@127.0.0.1:1521:xe # Oracle 连接的示例 # url: jdbc:sqlserver://127.0.0.1:1433;DatabaseName=${spring.datasource.dynamic.datasource.slave.name} # SQLServer 连接的示例 username: root - password: 123456 + password: ${RUOYI_VUE_PRO} # username: sa # password: JSm:g(*%lU4ZAkz06cd52KqT3)i1?H7W # Redis 配置。Redisson 默认的配置足够使用,一般不需要进行调优 redis: - host: 127.0.0.1 # 地址 + host: 139.9.196.247 # 地址 port: 6379 # 端口 database: 0 # 数据库索引 -# password: 123456 # 密码,建议生产环境开启 + password: 123456 # 密码,建议生产环境开启 jasypt: encryptor: @@ -173,6 +173,8 @@ logging: cn.iocoder.yudao.module.system.dal.mysql: debug cn.iocoder.yudao.module.tool.dal.mysql: debug cn.iocoder.yudao.module.member.dal.mysql: debug + cn.iocoder.yudao.module.trade.dal.mysql: debug + cn.iocoder.yudao.module.promotion.dal.mysql: debug --- #################### 微信公众号、小程序相关配置 #################### wx: diff --git a/yudao-ui-admin-vue3/README.md b/yudao-ui-admin-vue3/README.md index 3027db3eb..bf9692ae6 100644 --- a/yudao-ui-admin-vue3/README.md +++ b/yudao-ui-admin-vue3/README.md @@ -18,7 +18,7 @@ ## 注意事项 - 项目路径请不要使用中文命名!!!会造成解析乱码!!!请使用全英文路径!!! -- node >=14.18.0(建议使用 16 版本) ,pnpm >=7 +- node >=14.19.0(建议使用 16 版本) ,pnpm >=7 - 开发建议使用 [谷歌浏览器-开发者版](https://www.google.cn/intl/zh-CN/chrome/dev/) 不支持 IE\QQ 等浏览器 ### 点击查看[使用说明](./use.md) @@ -27,9 +27,9 @@ | 框架 | 说明 | 版本 | | --- | --- |--------| -| [Vue](https://staging-cn.vuejs.org/) | vue 框架 | 3.2.41 | -| [Vite](https://cn.vitejs.dev//) | 开发与构建工具 | 3.2.2 | -| [Element Plus](https://element-plus.org/zh-CN/) | Element Plus | 2.2.19 | +| [Vue](https://staging-cn.vuejs.org/) | vue 框架 | 3.2.44 | +| [Vite](https://cn.vitejs.dev//) | 开发与构建工具 | 3.2.3 | +| [Element Plus](https://element-plus.org/zh-CN/) | Element Plus | 2.2.20 | | [TypeScript](https://www.typescriptlang.org/docs/) | JavaScript 的超集 | 4.8.4 | | [pinia](https://pinia.vuejs.org/) | Vue 存储库 替代 vuex5 | 2.0.23 | | [vueuse](https://vueuse.org//) | 常用工具集 | 9.4.0 | diff --git a/yudao-ui-admin-vue3/package.json b/yudao-ui-admin-vue3/package.json index 1f980c950..c2be68b1f 100644 --- a/yudao-ui-admin-vue3/package.json +++ b/yudao-ui-admin-vue3/package.json @@ -47,7 +47,7 @@ "qrcode": "^1.5.1", "qs": "^6.11.0", "url": "^0.11.0", - "vue": "3.2.42", + "vue": "3.2.44", "vue-cropper": "^1.0.3", "vue-i18n": "9.2.2", "vue-router": "^4.1.6", @@ -75,7 +75,7 @@ "autoprefixer": "^10.4.13", "eslint": "^8.27.0", "eslint-config-prettier": "^8.5.0", - "eslint-define-config": "^1.11.0", + "eslint-define-config": "^1.12.0", "eslint-plugin-prettier": "^4.2.1", "eslint-plugin-vue": "^9.7.0", "less": "^4.1.3", @@ -107,7 +107,7 @@ "windicss": "^3.5.6" }, "engines": { - "node": ">= 14.18.0" + "node": "^14.19.0 || >=16.0.0" }, "license": "MIT", "repository": { diff --git a/yudao-ui-admin-vue3/pnpm-lock.yaml b/yudao-ui-admin-vue3/pnpm-lock.yaml index 4a6d8573a..ef00db36f 100644 --- a/yudao-ui-admin-vue3/pnpm-lock.yaml +++ b/yudao-ui-admin-vue3/pnpm-lock.yaml @@ -31,7 +31,7 @@ specifiers: element-plus: 2.2.20 eslint: ^8.27.0 eslint-config-prettier: ^8.5.0 - eslint-define-config: ^1.11.0 + eslint-define-config: ^1.12.0 eslint-plugin-prettier: ^4.2.1 eslint-plugin-vue: ^9.7.0 intro.js: ^6.0.0 @@ -69,7 +69,7 @@ specifiers: vite-plugin-style-import: 2.0.0 vite-plugin-svg-icons: ^2.0.1 vite-plugin-windicss: ^1.8.8 - vue: 3.2.42 + vue: 3.2.44 vue-cropper: ^1.0.3 vue-i18n: 9.2.2 vue-router: ^4.1.6 @@ -82,9 +82,9 @@ specifiers: dependencies: '@iconify/iconify': 3.0.0 - '@vueuse/core': 9.5.0_vue@3.2.42 + '@vueuse/core': 9.5.0_vue@3.2.44 '@wangeditor/editor': 5.1.22 - '@wangeditor/editor-for-vue': 5.1.12_alw2ndugf46dy23ckuo7wxeyfq + '@wangeditor/editor-for-vue': 5.1.12_su3dw7bmszfjg67suaojchptby '@zxcvbn-ts/core': 2.1.0 animate.css: 4.1.1 axios: 1.1.3 @@ -92,23 +92,23 @@ dependencies: dayjs: 1.11.6 echarts: 5.4.0 echarts-wordcloud: 2.0.0_echarts@5.4.0 - element-plus: 2.2.20_vue@3.2.42 + element-plus: 2.2.20_vue@3.2.44 intro.js: 6.0.0 js-cookie: 3.0.1 jsencrypt: 3.3.1 lodash-es: 4.17.21 mitt: 3.0.0 nprogress: 0.2.0 - pinia: 2.0.23_p6beu5bk6fjrnndg7abfb7ev34 + pinia: 2.0.23_d45o5shxrtvj6wh4y524t7cqnm qrcode: 1.5.1 qs: 6.11.0 url: 0.11.0 - vue: 3.2.42 + vue: 3.2.44 vue-cropper: 1.0.5 - vue-i18n: 9.2.2_vue@3.2.42 - vue-router: 4.1.6_vue@3.2.42 - vue-types: 4.2.1_vue@3.2.42 - vxe-table: 4.3.5_vue@3.2.42+xe-utils@3.5.7 + vue-i18n: 9.2.2_vue@3.2.44 + vue-router: 4.1.6_vue@3.2.44 + vue-types: 4.2.1_vue@3.2.44 + vxe-table: 4.3.5_vue@3.2.44+xe-utils@3.5.7 web-storage-cache: 1.1.1 xe-utils: 3.5.7 @@ -126,12 +126,12 @@ devDependencies: '@types/qs': 6.9.7 '@typescript-eslint/eslint-plugin': 5.42.1_2udltptbznfmezdozpdoa2aemq '@typescript-eslint/parser': 5.42.1_rmayb2veg2btbq6mbmnyivgasy - '@vitejs/plugin-vue': 3.2.0_vite@3.2.3+vue@3.2.42 - '@vitejs/plugin-vue-jsx': 2.1.1_vite@3.2.3+vue@3.2.42 + '@vitejs/plugin-vue': 3.2.0_vite@3.2.3+vue@3.2.44 + '@vitejs/plugin-vue-jsx': 2.1.1_vite@3.2.3+vue@3.2.44 autoprefixer: 10.4.13_postcss@8.4.18 eslint: 8.27.0 eslint-config-prettier: 8.5.0_eslint@8.27.0 - eslint-define-config: 1.11.0 + eslint-define-config: 1.12.0 eslint-plugin-prettier: 4.2.1_v7o5sx5x3wbs57ifz6wc4f76we eslint-plugin-vue: 9.7.0_eslint@8.27.0 less: 4.1.3 @@ -150,7 +150,7 @@ devDependencies: stylelint-config-standard: 29.0.0_stylelint@14.14.1 stylelint-order: 5.0.0_stylelint@14.14.1 typescript: 4.8.4 - unplugin-vue-macros: 0.16.2_ve2aveyfzww3px23ptzmnteatu + unplugin-vue-macros: 0.16.2_nch4vsbos5hmj7k4a4oy3znhuu vite: 3.2.3_mp5lu76ee5qtwstsyca37sdhqi vite-plugin-compression: 0.5.1_vite@3.2.3 vite-plugin-eslint: 1.8.1_eslint@8.27.0+vite@3.2.3 @@ -674,12 +674,12 @@ packages: engines: {node: '>=10'} dev: false - /@element-plus/icons-vue/2.0.9_vue@3.2.42: + /@element-plus/icons-vue/2.0.9_vue@3.2.44: resolution: {integrity: sha512-okdrwiVeKBmW41Hkl0eMrXDjzJwhQMuKiBOu17rOszqM+LS/yBYpNQNV5Jvoh06Wc+89fMmb/uhzf8NZuDuUaQ==} peerDependencies: vue: ^3.2.0 dependencies: - vue: 3.2.42 + vue: 3.2.44 dev: false /@esbuild/android-arm/0.15.10: @@ -786,7 +786,7 @@ packages: '@intlify/shared': 9.3.0-beta.6 jsonc-eslint-parser: 1.4.1 source-map: 0.6.1 - vue-i18n: 9.2.2_vue@3.2.42 + vue-i18n: 9.2.2_vue@3.2.44 yaml-eslint-parser: 0.3.2 dev: true @@ -851,7 +851,7 @@ packages: fast-glob: 3.2.12 source-map: 0.6.1 vite: 3.2.3_mp5lu76ee5qtwstsyca37sdhqi - vue-i18n: 9.2.2_vue@3.2.42 + vue-i18n: 9.2.2_vue@3.2.44 transitivePeerDependencies: - supports-color dev: true @@ -1263,7 +1263,7 @@ packages: nanoid: 3.3.4 dev: false - /@vitejs/plugin-vue-jsx/2.1.1_vite@3.2.3+vue@3.2.42: + /@vitejs/plugin-vue-jsx/2.1.1_vite@3.2.3+vue@3.2.44: resolution: {integrity: sha512-JgDhxstQlwnHBvZ1BSnU5mbmyQ14/t5JhREc6YH5kWyu2QdAAOsLF6xgHoIWarj8tddaiwFrNzLbWJPudpXKYA==} engines: {node: ^14.18.0 || >=16.0.0} peerDependencies: @@ -1274,12 +1274,12 @@ packages: '@babel/plugin-transform-typescript': 7.20.2_@babel+core@7.19.6 '@vue/babel-plugin-jsx': 1.1.1_@babel+core@7.19.6 vite: 3.2.3_mp5lu76ee5qtwstsyca37sdhqi - vue: 3.2.42 + vue: 3.2.44 transitivePeerDependencies: - supports-color dev: true - /@vitejs/plugin-vue/3.2.0_vite@3.2.3+vue@3.2.42: + /@vitejs/plugin-vue/3.2.0_vite@3.2.3+vue@3.2.44: resolution: {integrity: sha512-E0tnaL4fr+qkdCNxJ+Xd0yM31UwMkQje76fsDVBBUCoGOUPexu2VDUYHL8P4CwV+zMvWw6nlRw19OnRKmYAJpw==} engines: {node: ^14.18.0 || >=16.0.0} peerDependencies: @@ -1287,7 +1287,7 @@ packages: vue: ^3.2.25 dependencies: vite: 3.2.3_mp5lu76ee5qtwstsyca37sdhqi - vue: 3.2.42 + vue: 3.2.44 dev: true /@volar/language-core/1.0.9: @@ -1368,12 +1368,12 @@ packages: dependencies: '@rollup/pluginutils': 4.2.1 '@vue-macros/common': 0.13.3 - '@vueuse/core': 9.5.0_vue@3.2.42 + '@vueuse/core': 9.5.0_vue@3.2.44 ast-walker-scope: 0.3.0 unplugin: 0.10.2 dev: true - /@vue-macros/define-props/0.0.2_vue@3.2.42: + /@vue-macros/define-props/0.0.2_vue@3.2.44: resolution: {integrity: sha512-OfqC+xlN+0/koBPr4HbCJUsRbPhyOqJR2TJdeb0efTewyEljxskqh3ZCGzE4RusX+yzqTrzePlxWTcb1akNr8Q==} engines: {node: '>=14.19.0'} peerDependencies: @@ -1382,10 +1382,10 @@ packages: '@rollup/pluginutils': 4.2.1 '@vue-macros/common': 0.13.3 unplugin: 0.10.2 - vue: 3.2.42 + vue: 3.2.44 dev: true - /@vue-macros/define-render/0.13.8_vue@3.2.42: + /@vue-macros/define-render/0.13.8_vue@3.2.44: resolution: {integrity: sha512-a1FIGgTuvLN5gfbh7/dtYLSaXPBYLu33l2sc0auc55uNXqB6qXGzxu/12bEskONhYcx1BBwsqjWiSFbSJ3yLbg==} engines: {node: '>=14.19.0'} peerDependencies: @@ -1394,10 +1394,10 @@ packages: '@rollup/pluginutils': 4.2.1 '@vue-macros/common': 0.13.3 unplugin: 0.10.2 - vue: 3.2.42 + vue: 3.2.44 dev: true - /@vue-macros/define-slots/0.0.5_vue@3.2.42: + /@vue-macros/define-slots/0.0.5_vue@3.2.44: resolution: {integrity: sha512-+CS2MTH1fBeHbiZzThn6aXmrcbPRiuG29yWI6ugMarpIxwvVWXrPcvrWSE2BK/FSwcCR9Xfz7rETIo+BSjdo6A==} engines: {node: '>=14.19.0'} peerDependencies: @@ -1406,7 +1406,7 @@ packages: '@rollup/pluginutils': 4.2.1 '@vue-macros/common': 0.13.3 unplugin: 0.10.2 - vue: 3.2.42 + vue: 3.2.44 dev: true /@vue-macros/hoist-static/0.12.7: @@ -1418,12 +1418,12 @@ packages: unplugin: 0.10.2 dev: true - /@vue-macros/named-template/0.0.5_jbrpgpahb6qz7vnlcnfu2pu7zm: + /@vue-macros/named-template/0.0.5_vkxhlib7tgibcivdhj2bfsgnbi: resolution: {integrity: sha512-bZRUljNyvOOqeE9dyqXvKPQCLUCcPt1EkThmXqSbxagV29ohyviF8+CCs/8OdmNygLTBIChjP8DexQ3nUIFzUg==} engines: {node: '>=14.19.0'} dependencies: '@rollup/pluginutils': 4.2.1 - '@vitejs/plugin-vue': 3.2.0_vite@3.2.3+vue@3.2.42 + '@vitejs/plugin-vue': 3.2.0_vite@3.2.3+vue@3.2.44 '@vue-macros/common': 0.13.3 '@vue/compiler-dom': 3.2.41 unplugin: 0.10.2 @@ -1506,6 +1506,15 @@ packages: '@vue/shared': 3.2.42 estree-walker: 2.0.2 source-map: 0.6.1 + dev: true + + /@vue/compiler-core/3.2.44: + resolution: {integrity: sha512-TwzeVSnaklb8wIvMtwtkPkt9wnU+XD70xJ7N9+eIHtjKAG7OoZttm+14ZL6vWOL+2RcMtSZ+cYH+gvkUqsrmSQ==} + dependencies: + '@babel/parser': 7.20.0 + '@vue/shared': 3.2.44 + estree-walker: 2.0.2 + source-map: 0.6.1 /@vue/compiler-dom/3.2.41: resolution: {integrity: sha512-xe5TbbIsonjENxJsYRbDJvthzqxLNk+tb3d/c47zgREDa/PCp6/Y4gC/skM4H6PIuX5DAxm7fFJdbjjUH2QTMw==} @@ -1519,6 +1528,13 @@ packages: dependencies: '@vue/compiler-core': 3.2.42 '@vue/shared': 3.2.42 + dev: true + + /@vue/compiler-dom/3.2.44: + resolution: {integrity: sha512-wPDR+gOn2Qi7SudPJ+gE62vuO/aKXIiIFALvHpztXmDdbAHGy3CDfmBgOGchTgTlSeDJHe9olEMkgOdmyXTjUg==} + dependencies: + '@vue/compiler-core': 3.2.44 + '@vue/shared': 3.2.44 /@vue/compiler-sfc/3.2.41: resolution: {integrity: sha512-+1P2m5kxOeaxVmJNXnBskAn3BenbTmbxBxWOtBq3mQTCokIreuMULFantBUclP0+KnzNCMOvcnKinqQZmiOF8w==} @@ -1548,6 +1564,21 @@ packages: magic-string: 0.25.9 postcss: 8.4.18 source-map: 0.6.1 + dev: true + + /@vue/compiler-sfc/3.2.44: + resolution: {integrity: sha512-8cFZcUWlrtnfM/GlRwYJdlfgbEOy0OZ/osLDU3h/wJu24HuYAc7QIML1USaKqiZzkjOaTd4y8mvYvcWXq3o5dA==} + dependencies: + '@babel/parser': 7.20.0 + '@vue/compiler-core': 3.2.44 + '@vue/compiler-dom': 3.2.44 + '@vue/compiler-ssr': 3.2.44 + '@vue/reactivity-transform': 3.2.44 + '@vue/shared': 3.2.44 + estree-walker: 2.0.2 + magic-string: 0.25.9 + postcss: 8.4.18 + source-map: 0.6.1 /@vue/compiler-ssr/3.2.41: resolution: {integrity: sha512-Y5wPiNIiaMz/sps8+DmhaKfDm1xgj6GrH99z4gq2LQenfVQcYXmHIOBcs5qPwl7jaW3SUQWjkAPKMfQemEQZwQ==} @@ -1561,6 +1592,13 @@ packages: dependencies: '@vue/compiler-dom': 3.2.42 '@vue/shared': 3.2.42 + dev: true + + /@vue/compiler-ssr/3.2.44: + resolution: {integrity: sha512-tAkUFLgvxds3l5KPyAH77OIYrEeLngNYQfWA9GocHiy2nlyajjqAH/Jq93Bq29Y20GeJzblmRp9DVYCVkJ5Rsw==} + dependencies: + '@vue/compiler-dom': 3.2.44 + '@vue/shared': 3.2.44 /@vue/devtools-api/6.4.3: resolution: {integrity: sha512-9WCRwdROJvWcHAdyrR7SZMM/qUvllDZnpndHXokThkUsjnJ2xe4/pvsH9FZrxFe22L+JmDKczL79HjLJ7DK9rg==} @@ -1591,6 +1629,16 @@ packages: '@vue/shared': 3.2.42 estree-walker: 2.0.2 magic-string: 0.25.9 + dev: true + + /@vue/reactivity-transform/3.2.44: + resolution: {integrity: sha512-WGbEiXaS2qAOTS9Z3kKk2Nk4bi8OUl73Sih+h0XV9RTUATnaJSEQedveHUDQnHyXiZwyBMKosrxJg8aThHO/rw==} + dependencies: + '@babel/parser': 7.20.0 + '@vue/compiler-core': 3.2.44 + '@vue/shared': 3.2.44 + estree-walker: 2.0.2 + magic-string: 0.25.9 /@vue/reactivity/3.2.41: resolution: {integrity: sha512-9JvCnlj8uc5xRiQGZ28MKGjuCoPhhTwcoAdv3o31+cfGgonwdPNuvqAXLhlzu4zwqavFEG5tvaoINQEfxz+l6g==} @@ -1598,32 +1646,32 @@ packages: '@vue/shared': 3.2.41 dev: true - /@vue/reactivity/3.2.42: - resolution: {integrity: sha512-X30I+iS7d6c8DZDY7SqahkTRN2THfnkNtf0oCUktuk2gTKRxNOzaARItSmsPKLC7UVUG61Hne8Si3wtQBBDj+A==} + /@vue/reactivity/3.2.44: + resolution: {integrity: sha512-Fe0s52fTsPl+RSdvoqUZ3HRKlaVsKhIh1mea5EWOedFvZCjnymzlj3YC1wZMxi89qXRFSdEASVA/BWUGypk0Ig==} dependencies: - '@vue/shared': 3.2.42 + '@vue/shared': 3.2.44 - /@vue/runtime-core/3.2.42: - resolution: {integrity: sha512-9JCPD4k/p4eXXc5ja+YcYwGu+ES9BIgoVty7UlOMEG0Bdz7awxxY78PXIHg1b7HlxQuUdGq6r3COg1cyvDrRCw==} + /@vue/runtime-core/3.2.44: + resolution: {integrity: sha512-uwEV1cttL33k2dC+CNGYhKEYqGejT9KmgQ+4n/LmYUfZ1Gorl8F32DlIX+1pANyGHL1tBAisqHDxKyQBp2oBNA==} dependencies: - '@vue/reactivity': 3.2.42 - '@vue/shared': 3.2.42 + '@vue/reactivity': 3.2.44 + '@vue/shared': 3.2.44 - /@vue/runtime-dom/3.2.42: - resolution: {integrity: sha512-i4OZblZQvFjJ/isNo+jrqXsjJgq4Nz0R/W2iNu40pTLJrikijYPaUOcOJcjVih9eL7zz101RJsbP8zKluQLqRA==} + /@vue/runtime-dom/3.2.44: + resolution: {integrity: sha512-LDzNwXpU/nSpxrLk5jS0bfStgt88msgsgFzj6vHrl7es3QktIrCGybQS5CB/p/TO0q98iAiYtEVmi+Lej7Vgjg==} dependencies: - '@vue/runtime-core': 3.2.42 - '@vue/shared': 3.2.42 + '@vue/runtime-core': 3.2.44 + '@vue/shared': 3.2.44 csstype: 2.6.21 - /@vue/server-renderer/3.2.42_vue@3.2.42: - resolution: {integrity: sha512-xo6XMaJTuKmYRlnS53QN358j0pmZMFNtisLkzV7oXFww0bpkn2MzjkPt4YvOjMNto9NlI609xQKJboEk5nMu2A==} + /@vue/server-renderer/3.2.44_vue@3.2.44: + resolution: {integrity: sha512-3+ArN07UgOAdbGKIp3uVqeC3bnR3J324QNjPR6vxHbLrTlkibFv8QNled/ux3fVq0KDCkVVKGOKB2V4sCIYOgg==} peerDependencies: - vue: 3.2.42 + vue: 3.2.44 dependencies: - '@vue/compiler-ssr': 3.2.42 - '@vue/shared': 3.2.42 - vue: 3.2.42 + '@vue/compiler-ssr': 3.2.44 + '@vue/shared': 3.2.44 + vue: 3.2.44 /@vue/shared/3.2.41: resolution: {integrity: sha512-W9mfWLHmJhkfAmV+7gDjcHeAWALQtgGT3JErxULl0oz6R6+3ug91I7IErs93eCFhPCZPHBs4QJS7YWEV7A3sxw==} @@ -1631,14 +1679,18 @@ packages: /@vue/shared/3.2.42: resolution: {integrity: sha512-cheJw3tpW34LWVUL3fySuwCmF1/gFBHWZ3WjmMcBIHMcnKrS/SRapvkbYWzyw5FiM8OcpYHO5e7hWYOFCsyHmA==} + dev: true - /@vueuse/core/9.5.0_vue@3.2.42: + /@vue/shared/3.2.44: + resolution: {integrity: sha512-mGZ44bnn0zpZ36nXtxbrBPno43yr96wjQE1dBEKS1Sieugt27HS4OGZVBRIgsdGzosB7vqZAvu0ttu1FDVdolA==} + + /@vueuse/core/9.5.0_vue@3.2.44: resolution: {integrity: sha512-6GsWBsJHEb3sYw15mbLrcbslAVY45pkzjJYTKYKCXv88z7srAF0VEW0q+oXKsl58tCbqooplInahXFg8Yo1m4w==} dependencies: '@types/web-bluetooth': 0.0.16 '@vueuse/metadata': 9.5.0 - '@vueuse/shared': 9.5.0_vue@3.2.42 - vue-demi: 0.13.11_vue@3.2.42 + '@vueuse/shared': 9.5.0_vue@3.2.44 + vue-demi: 0.13.11_vue@3.2.44 transitivePeerDependencies: - '@vue/composition-api' - vue @@ -1646,10 +1698,10 @@ packages: /@vueuse/metadata/9.5.0: resolution: {integrity: sha512-4M1AyPZmIv41pym+K5+4wup3bKuYebbH8w8BROY1hmT7rIwcyS4tEL+UsGz0Hiu1FCOxcoBrwtAizc0YmBJjyQ==} - /@vueuse/shared/9.5.0_vue@3.2.42: + /@vueuse/shared/9.5.0_vue@3.2.44: resolution: {integrity: sha512-HnnCWU1Vg9CVWRCcI8ohDKDRB2Sc4bTgT1XAIaoLSfVHHn+TKbrox6pd3klCSw4UDxkhDfOk8cAdcK+Z5KleCA==} dependencies: - vue-demi: 0.13.11_vue@3.2.42 + vue-demi: 0.13.11_vue@3.2.44 transitivePeerDependencies: - '@vue/composition-api' - vue @@ -1728,14 +1780,14 @@ packages: snabbdom: 3.5.1 dev: false - /@wangeditor/editor-for-vue/5.1.12_alw2ndugf46dy23ckuo7wxeyfq: + /@wangeditor/editor-for-vue/5.1.12_su3dw7bmszfjg67suaojchptby: resolution: {integrity: sha512-0Ds3D8I+xnpNWezAeO7HmPRgTfUxHLMd9JKcIw+QzvSmhC5xUHbpCcLU+KLmeBKTR/zffnS5GQo6qi3GhTMJWQ==} peerDependencies: '@wangeditor/editor': '>=5.1.0' vue: ^3.0.5 dependencies: '@wangeditor/editor': 5.1.22 - vue: 3.2.42 + vue: 3.2.44 dev: false /@wangeditor/editor/5.1.22: @@ -2997,18 +3049,18 @@ packages: resolution: {integrity: sha512-EpuHPqu8YhonqLBXHoU6hDJCD98FCe6KDoet3/gY1qsQ6usjJoHqBH2YIVs8FXaAtHwVL8Uqa/fsYao/vq9VWQ==} dev: true - /element-plus/2.2.20_vue@3.2.42: + /element-plus/2.2.20_vue@3.2.44: resolution: {integrity: sha512-ludShd3f5kNRY4FLzeoNitLcwZ4qs2M/zwKeyeE7rUzZJAQ0BZtcT3SvZoEoBLmgxw9jHoonl4WIwon4UzhyRA==} peerDependencies: vue: ^3.2.0 dependencies: '@ctrl/tinycolor': 3.4.1 - '@element-plus/icons-vue': 2.0.9_vue@3.2.42 + '@element-plus/icons-vue': 2.0.9_vue@3.2.44 '@floating-ui/dom': 1.0.2 '@popperjs/core': /@sxzz/popperjs-es/2.11.7 '@types/lodash': 4.14.186 '@types/lodash-es': 4.17.6 - '@vueuse/core': 9.5.0_vue@3.2.42 + '@vueuse/core': 9.5.0_vue@3.2.44 async-validator: 4.2.5 dayjs: 1.11.6 escape-html: 1.0.3 @@ -3017,7 +3069,7 @@ packages: lodash-unified: 1.0.2_3ib2ivapxullxkx3xftsimdk7u memoize-one: 6.0.0 normalize-wheel-es: 1.2.0 - vue: 3.2.42 + vue: 3.2.44 transitivePeerDependencies: - '@vue/composition-api' dev: false @@ -3333,8 +3385,8 @@ packages: eslint: 8.27.0 dev: true - /eslint-define-config/1.11.0: - resolution: {integrity: sha512-J5xNmL5EyXJzrRCGuyr8eKia2boFnJl3Lzurrv1tpM3oxtNONlp9/HW+zRFZ6+W3U7BQDCtnLunGmyCCtFHioQ==} + /eslint-define-config/1.12.0: + resolution: {integrity: sha512-Kt9TcMbgsY9VRt7jIuw76KE/2RuD31eWB4Ubv6btXgU8NTSsbT6gZ8qzeiU+rAih/8sOl8Kt89spAZBMElu6qQ==} engines: {node: ^14.17.0 || ^16.13.0 || >=18.0.0, npm: '>=6.14.13', pnpm: '>= 7.0.0'} dev: true @@ -5554,7 +5606,7 @@ packages: dev: true optional: true - /pinia/2.0.23_p6beu5bk6fjrnndg7abfb7ev34: + /pinia/2.0.23_d45o5shxrtvj6wh4y524t7cqnm: resolution: {integrity: sha512-N15hFf4o5STrxpNrib1IEb1GOArvPYf1zPvQVRGOO1G1d74Ak0J0lVyalX/SmrzdT4Q0nlEFjbURsmBmIGUR5Q==} peerDependencies: '@vue/composition-api': ^1.4.0 @@ -5568,8 +5620,8 @@ packages: dependencies: '@vue/devtools-api': 6.4.4 typescript: 4.8.4 - vue: 3.2.42 - vue-demi: 0.13.11_vue@3.2.42 + vue: 3.2.44 + vue-demi: 0.13.11_vue@3.2.44 dev: false /plop/3.1.1: @@ -6827,7 +6879,7 @@ packages: unplugin: 0.10.2 dev: true - /unplugin-vue-macros/0.16.2_ve2aveyfzww3px23ptzmnteatu: + /unplugin-vue-macros/0.16.2_nch4vsbos5hmj7k4a4oy3znhuu: resolution: {integrity: sha512-uNfjIXVUYBujbjJUcjXreE6zipZlPAIEMsx6bc/5qygwTfdvkJeHCAvvxrl0c8hdcT5/18OV2VDdwI60vCh56g==} engines: {node: '>=14.19.0'} peerDependencies: @@ -6836,18 +6888,18 @@ packages: '@rollup/pluginutils': 4.2.1 '@vue-macros/better-define': 0.1.0 '@vue-macros/define-model': 0.13.8_@vueuse+core@9.5.0 - '@vue-macros/define-props': 0.0.2_vue@3.2.42 - '@vue-macros/define-render': 0.13.8_vue@3.2.42 - '@vue-macros/define-slots': 0.0.5_vue@3.2.42 + '@vue-macros/define-props': 0.0.2_vue@3.2.44 + '@vue-macros/define-render': 0.13.8_vue@3.2.44 + '@vue-macros/define-slots': 0.0.5_vue@3.2.44 '@vue-macros/hoist-static': 0.12.7 - '@vue-macros/named-template': 0.0.5_jbrpgpahb6qz7vnlcnfu2pu7zm + '@vue-macros/named-template': 0.0.5_vkxhlib7tgibcivdhj2bfsgnbi '@vue-macros/setup-component': 0.12.7_rollup@3.2.5+vite@3.2.3 '@vue-macros/setup-sfc': 0.12.7 '@vue-macros/short-emits': 0.12.8 local-pkg: 0.4.2 unplugin-combine: 0.2.8_rollup@3.2.5+vite@3.2.3 unplugin-vue-define-options: 0.12.7 - vue: 3.2.42 + vue: 3.2.44 transitivePeerDependencies: - '@vueuse/core' - esbuild @@ -7095,7 +7147,7 @@ packages: resolution: {integrity: sha512-D4XXdqWmMWRLOIV9LIh7/mkH6OBOMQDFbRjwntkxmAtxOtwpC9U5ZZ6lSXw5F5cbd4g8znDjk6MuCwIL+fZSrA==} dev: false - /vue-demi/0.13.11_vue@3.2.42: + /vue-demi/0.13.11_vue@3.2.44: resolution: {integrity: sha512-IR8HoEEGM65YY3ZJYAjMlKygDQn25D5ajNFNoKh9RSDMQtlzCxtfQjdQgv9jjK+m3377SsJXY8ysq8kLCZL25A==} engines: {node: '>=12'} hasBin: true @@ -7107,7 +7159,7 @@ packages: '@vue/composition-api': optional: true dependencies: - vue: 3.2.42 + vue: 3.2.44 /vue-eslint-parser/9.1.0_eslint@8.27.0: resolution: {integrity: sha512-NGn/iQy8/Wb7RrRa4aRkokyCZfOUWk19OP5HP6JEozQFX5AoS/t+Z0ZN7FY4LlmWc4FNI922V7cvX28zctN8dQ==} @@ -7127,7 +7179,7 @@ packages: - supports-color dev: true - /vue-i18n/9.2.2_vue@3.2.42: + /vue-i18n/9.2.2_vue@3.2.44: resolution: {integrity: sha512-yswpwtj89rTBhegUAv9Mu37LNznyu3NpyLQmozF3i1hYOhwpG8RjcjIFIIfnu+2MDZJGSZPXaKWvnQA71Yv9TQ==} engines: {node: '>= 14'} peerDependencies: @@ -7137,15 +7189,15 @@ packages: '@intlify/shared': 9.2.2 '@intlify/vue-devtools': 9.2.2 '@vue/devtools-api': 6.4.3 - vue: 3.2.42 + vue: 3.2.44 - /vue-router/4.1.6_vue@3.2.42: + /vue-router/4.1.6_vue@3.2.44: resolution: {integrity: sha512-DYWYwsG6xNPmLq/FmZn8Ip+qrhFEzA14EI12MsMgVxvHFDYvlr4NXpVF5hrRH1wVcDP8fGi5F4rxuJSl8/r+EQ==} peerDependencies: vue: ^3.2.0 dependencies: '@vue/devtools-api': 6.4.5 - vue: 3.2.42 + vue: 3.2.44 dev: false /vue-template-compiler/2.7.10: @@ -7166,32 +7218,32 @@ packages: typescript: 4.8.4 dev: true - /vue-types/4.2.1_vue@3.2.42: + /vue-types/4.2.1_vue@3.2.44: resolution: {integrity: sha512-DNQZmJuOvovLUIp0BENRkdnZHbI0V4e2mNvjAZOAXKD56YGvRchtUYOXA/XqTxdv7Ng5SJLZqRKRpAhm5NLaPQ==} engines: {node: '>=12.16.0'} peerDependencies: vue: ^2.0.0 || ^3.0.0 dependencies: is-plain-object: 5.0.0 - vue: 3.2.42 + vue: 3.2.44 dev: false - /vue/3.2.42: - resolution: {integrity: sha512-gH7e5YD9IkX9Lv0QmB+Z7Jac2t7GYHg2AZrgkzQdCmyaUIdSbp6DhdeTM5HO6JbPuRgD1Iu06N9MXxjJ//NnNQ==} + /vue/3.2.44: + resolution: {integrity: sha512-nyNtFDh+0TpRgYCUVfPD1mJ9PpIsCPXaOF4DeGNIT5vQ4X23ykflGq3Sy2P+tEt1/pQZxZnAysuRKwyhNj+Cjw==} dependencies: - '@vue/compiler-dom': 3.2.42 - '@vue/compiler-sfc': 3.2.42 - '@vue/runtime-dom': 3.2.42 - '@vue/server-renderer': 3.2.42_vue@3.2.42 - '@vue/shared': 3.2.42 + '@vue/compiler-dom': 3.2.44 + '@vue/compiler-sfc': 3.2.44 + '@vue/runtime-dom': 3.2.44 + '@vue/server-renderer': 3.2.44_vue@3.2.44 + '@vue/shared': 3.2.44 - /vxe-table/4.3.5_vue@3.2.42+xe-utils@3.5.7: + /vxe-table/4.3.5_vue@3.2.44+xe-utils@3.5.7: resolution: {integrity: sha512-JEvGAs7SBN1rWn5f2tkoRiXd/rAT7RfnDTTlFsHsTtASiUTKNTISI2WBsVeLkkNRTs0SXh6FgrYsIPO2soSBXA==} peerDependencies: vue: ^3.2.28 xe-utils: ^3.5.0 dependencies: - vue: 3.2.42 + vue: 3.2.44 xe-utils: 3.5.7 dev: false diff --git a/yudao-ui-admin/src/views/infra/config/index.vue b/yudao-ui-admin/src/views/infra/config/index.vue index ab889700f..802abeb08 100644 --- a/yudao-ui-admin/src/views/infra/config/index.vue +++ b/yudao-ui-admin/src/views/infra/config/index.vue @@ -41,7 +41,7 @@ - +