From d6cad41d76410cac79f6ed237231b2c63ef7e3c3 Mon Sep 17 00:00:00 2001 From: zhaohe Date: Sat, 8 Feb 2025 17:10:31 +0800 Subject: [PATCH] update --- .../java/iflytop/app/config/AppConstantConfig.java | 10 + src/main/java/iflytop/app/config/CorsConfig.java | 17 ++ .../java/iflytop/app/config/SpringDocConfig.java | 39 +++ .../iflytop/app/config/WebSocketConfiguration.java | 13 + .../app/controler/LocalDeviceControler.java | 34 +++ .../app/controler/ws/AppEventWSEndpoint.java | 48 ---- .../app/controler/ws/AppStateWSEndpoint.java | 47 ---- .../iflytop/app/controler/ws/EventWSChannel.java | 80 ++++++ .../iflytop/app/controler/ws/StateWSChannel.java | 80 ++++++ .../service/backgroud/SensorReportPreAnalysis.java | 2 + src/main/java/iflytop/app/type/XYPoint.java | 2 + .../type/event/MeasurementTaskReportPosEvent.java | 11 + .../app/type/protocol/TPMISensorValReport.java | 33 +++ src/main/java/iflytop/app/type/ui/MessageBox.java | 16 -- .../java/iflytop/app/type/ui/MessageLevel.java | 8 - .../iflytop/app/type/ui/ZAppErrorStackInfo.java | 5 - src/main/java/iflytop/app/type/ui/ZAppPromopt.java | 91 ------ .../app/type/ui/ZAppPromoptDetailInfoType.java | 7 - .../iflytop/app/type/ui/ZAppPromoptFormsItem.java | 11 - .../java/iflytop/app/type/ui/ZAppPromoptTable.java | 39 --- .../iflytop/app/type/ui/message/ZAppMessage.java | 91 ++++++ .../app/type/ui/message/basic/MessageLevel.java | 8 + .../type/ui/message/basic/ZAppErrorStackInfo.java | 5 + .../message/basic/ZAppPromoptDetailInfoType.java | 7 + .../ui/message/basic/ZAppPromoptFormsItem.java | 11 + .../type/ui/message/basic/ZAppPromoptTable.java | 39 +++ .../iflytop/app/utils/CoordinateCalculator.java | 2 + src/main/java/iflytop/config/CorsConfig.java | 17 -- src/main/java/iflytop/config/SpringDocConfig.java | 39 --- .../iflytop/config/WebSocketConfiguration.java | 13 - .../controler/EngineerRootPageControler.java | 30 -- .../iflytop/engineer/service/RootMgrService.java | 37 --- .../java/iflytop/engineer/type/EngineerPage.java | 7 - src/main/java/iflytop/zamis/type/display/Icon.java | 11 - .../java/iflytop/zamis/type/display/Remark.java | 17 -- .../iflytop/zamis/type/features/ActionButton.java | 30 -- .../zamis/type/features/DropDownButton.java | 25 -- src/main/java/iflytop/zamis/type/features/Nav.java | 71 ----- .../zamis/type/features/ServiceContainer.java | 27 -- src/main/java/iflytop/zamis/type/form/Form.java | 67 ----- .../java/iflytop/zamis/type/form/FormItem.java | 48 ---- .../java/iflytop/zamis/type/form/InputNumber.java | 12 - .../java/iflytop/zamis/type/form/InputText.java | 13 - src/main/java/iflytop/zamis/type/form/Select.java | 19 -- src/main/java/iflytop/zamis/type/layout/Flex.java | 23 -- src/main/java/iflytop/zamis/type/layout/Page.java | 36 --- src/main/java/iflytop/zamis/type/layout/Tabs.java | 53 ---- .../java/iflytop/zamis/type/options/Align.java | 5 - .../java/iflytop/zamis/type/options/Position.java | 5 - .../java/iflytop/zamis/type/options/Shape.java | 5 - src/main/java/iflytop/zamis/type/options/Size.java | 5 - .../java/iflytop/zamis/type/options/Trigger.java | 5 - .../controler/EngineerRootPageControler.java | 30 ++ .../iflytoplib/amiseui/service/RootMgrService.java | 37 +++ .../java/iflytoplib/amiseui/type/EngineerPage.java | 7 + .../java/iflytoplib/amiseui/type/display/Icon.java | 11 + .../iflytoplib/amiseui/type/display/Remark.java | 17 ++ .../amiseui/type/features/ActionButton.java | 30 ++ .../amiseui/type/features/DropDownButton.java | 25 ++ .../java/iflytoplib/amiseui/type/features/Nav.java | 71 +++++ .../amiseui/type/features/ServiceContainer.java | 27 ++ .../java/iflytoplib/amiseui/type/form/Form.java | 67 +++++ .../iflytoplib/amiseui/type/form/FormItem.java | 48 ++++ .../iflytoplib/amiseui/type/form/InputNumber.java | 12 + .../iflytoplib/amiseui/type/form/InputText.java | 13 + .../java/iflytoplib/amiseui/type/form/Select.java | 19 ++ .../java/iflytoplib/amiseui/type/layout/Flex.java | 23 ++ .../java/iflytoplib/amiseui/type/layout/Page.java | 36 +++ .../java/iflytoplib/amiseui/type/layout/Tabs.java | 53 ++++ .../iflytoplib/amiseui/type/options/Align.java | 5 + .../iflytoplib/amiseui/type/options/Position.java | 5 + .../iflytoplib/amiseui/type/options/Shape.java | 5 + .../java/iflytoplib/amiseui/type/options/Size.java | 5 + .../iflytoplib/amiseui/type/options/Trigger.java | 5 + .../zextui/controler/ExtApiControler.java | 305 +++++++++++++++++++++ .../zextui/controler/ExtApiControllerAdvice.java | 21 ++ .../zextui/mgr/ExtApiPageGroupCfgMgr.java | 69 +++++ .../java/iflytoplib/zextui/mgr/ExtApiPageMgr.java | 31 +++ .../java/iflytoplib/zextui/type/ExApiPage.java | 5 + .../java/iflytoplib/zextui/type/ExUIFunction.java | 110 ++++++++ .../java/iflytoplib/zextui/type/ExUIParam.java | 11 + .../zextui/type/ExUIParamGetInitValFnType1.java | 6 + .../zextui/type/ExUIParamGetInitValFnType2.java | 6 + src/main/java/iflytoplib/zextui/type/ExtApiFn.java | 16 ++ .../java/iflytoplib/zextui/type/ExtApiStatu.java | 14 + .../java/iflytoplib/zextui/type/ExtUIPageCfg.java | 204 ++++++++++++++ src/main/java/iflytoplib/zextui/type/ExtUITab.java | 11 + .../java/iflytoplib/zextui/type/ExtUiTable.java | 110 ++++++++ src/main/java/iflytoplib/zextui/type/TabCfg.java | 19 ++ .../iflytoplib/zextui/type/param/ExtUIFile.java | 12 + .../iflytoplib/zextui/type/ret/EngineerUIRet.java | 39 +++ .../iflytoplib/zextui/type/ret/ExtApiCurve.java | 16 ++ .../zextui/type/ret/ExtUIDownloadTasks.java | 8 + .../zextui/type/ret/FileToBeDownload.java | 9 + .../java/iflytoplib/zextui/utils/FieldUtils.java | 69 +++++ 95 files changed, 2126 insertions(+), 892 deletions(-) create mode 100644 src/main/java/iflytop/app/config/AppConstantConfig.java create mode 100644 src/main/java/iflytop/app/config/CorsConfig.java create mode 100644 src/main/java/iflytop/app/config/SpringDocConfig.java create mode 100644 src/main/java/iflytop/app/config/WebSocketConfiguration.java create mode 100644 src/main/java/iflytop/app/controler/LocalDeviceControler.java delete mode 100644 src/main/java/iflytop/app/controler/ws/AppEventWSEndpoint.java delete mode 100644 src/main/java/iflytop/app/controler/ws/AppStateWSEndpoint.java create mode 100644 src/main/java/iflytop/app/controler/ws/EventWSChannel.java create mode 100644 src/main/java/iflytop/app/controler/ws/StateWSChannel.java create mode 100644 src/main/java/iflytop/app/service/backgroud/SensorReportPreAnalysis.java create mode 100644 src/main/java/iflytop/app/type/XYPoint.java create mode 100644 src/main/java/iflytop/app/type/event/MeasurementTaskReportPosEvent.java create mode 100644 src/main/java/iflytop/app/type/protocol/TPMISensorValReport.java delete mode 100644 src/main/java/iflytop/app/type/ui/MessageBox.java delete mode 100644 src/main/java/iflytop/app/type/ui/MessageLevel.java delete mode 100644 src/main/java/iflytop/app/type/ui/ZAppErrorStackInfo.java delete mode 100644 src/main/java/iflytop/app/type/ui/ZAppPromopt.java delete mode 100644 src/main/java/iflytop/app/type/ui/ZAppPromoptDetailInfoType.java delete mode 100644 src/main/java/iflytop/app/type/ui/ZAppPromoptFormsItem.java delete mode 100644 src/main/java/iflytop/app/type/ui/ZAppPromoptTable.java create mode 100644 src/main/java/iflytop/app/type/ui/message/ZAppMessage.java create mode 100644 src/main/java/iflytop/app/type/ui/message/basic/MessageLevel.java create mode 100644 src/main/java/iflytop/app/type/ui/message/basic/ZAppErrorStackInfo.java create mode 100644 src/main/java/iflytop/app/type/ui/message/basic/ZAppPromoptDetailInfoType.java create mode 100644 src/main/java/iflytop/app/type/ui/message/basic/ZAppPromoptFormsItem.java create mode 100644 src/main/java/iflytop/app/type/ui/message/basic/ZAppPromoptTable.java create mode 100644 src/main/java/iflytop/app/utils/CoordinateCalculator.java delete mode 100644 src/main/java/iflytop/config/CorsConfig.java delete mode 100644 src/main/java/iflytop/config/SpringDocConfig.java delete mode 100644 src/main/java/iflytop/config/WebSocketConfiguration.java delete mode 100644 src/main/java/iflytop/engineer/controler/EngineerRootPageControler.java delete mode 100644 src/main/java/iflytop/engineer/service/RootMgrService.java delete mode 100644 src/main/java/iflytop/engineer/type/EngineerPage.java delete mode 100644 src/main/java/iflytop/zamis/type/display/Icon.java delete mode 100644 src/main/java/iflytop/zamis/type/display/Remark.java delete mode 100644 src/main/java/iflytop/zamis/type/features/ActionButton.java delete mode 100644 src/main/java/iflytop/zamis/type/features/DropDownButton.java delete mode 100644 src/main/java/iflytop/zamis/type/features/Nav.java delete mode 100644 src/main/java/iflytop/zamis/type/features/ServiceContainer.java delete mode 100644 src/main/java/iflytop/zamis/type/form/Form.java delete mode 100644 src/main/java/iflytop/zamis/type/form/FormItem.java delete mode 100644 src/main/java/iflytop/zamis/type/form/InputNumber.java delete mode 100644 src/main/java/iflytop/zamis/type/form/InputText.java delete mode 100644 src/main/java/iflytop/zamis/type/form/Select.java delete mode 100644 src/main/java/iflytop/zamis/type/layout/Flex.java delete mode 100644 src/main/java/iflytop/zamis/type/layout/Page.java delete mode 100644 src/main/java/iflytop/zamis/type/layout/Tabs.java delete mode 100644 src/main/java/iflytop/zamis/type/options/Align.java delete mode 100644 src/main/java/iflytop/zamis/type/options/Position.java delete mode 100644 src/main/java/iflytop/zamis/type/options/Shape.java delete mode 100644 src/main/java/iflytop/zamis/type/options/Size.java delete mode 100644 src/main/java/iflytop/zamis/type/options/Trigger.java create mode 100644 src/main/java/iflytoplib/amiseui/controler/EngineerRootPageControler.java create mode 100644 src/main/java/iflytoplib/amiseui/service/RootMgrService.java create mode 100644 src/main/java/iflytoplib/amiseui/type/EngineerPage.java create mode 100644 src/main/java/iflytoplib/amiseui/type/display/Icon.java create mode 100644 src/main/java/iflytoplib/amiseui/type/display/Remark.java create mode 100644 src/main/java/iflytoplib/amiseui/type/features/ActionButton.java create mode 100644 src/main/java/iflytoplib/amiseui/type/features/DropDownButton.java create mode 100644 src/main/java/iflytoplib/amiseui/type/features/Nav.java create mode 100644 src/main/java/iflytoplib/amiseui/type/features/ServiceContainer.java create mode 100644 src/main/java/iflytoplib/amiseui/type/form/Form.java create mode 100644 src/main/java/iflytoplib/amiseui/type/form/FormItem.java create mode 100644 src/main/java/iflytoplib/amiseui/type/form/InputNumber.java create mode 100644 src/main/java/iflytoplib/amiseui/type/form/InputText.java create mode 100644 src/main/java/iflytoplib/amiseui/type/form/Select.java create mode 100644 src/main/java/iflytoplib/amiseui/type/layout/Flex.java create mode 100644 src/main/java/iflytoplib/amiseui/type/layout/Page.java create mode 100644 src/main/java/iflytoplib/amiseui/type/layout/Tabs.java create mode 100644 src/main/java/iflytoplib/amiseui/type/options/Align.java create mode 100644 src/main/java/iflytoplib/amiseui/type/options/Position.java create mode 100644 src/main/java/iflytoplib/amiseui/type/options/Shape.java create mode 100644 src/main/java/iflytoplib/amiseui/type/options/Size.java create mode 100644 src/main/java/iflytoplib/amiseui/type/options/Trigger.java create mode 100644 src/main/java/iflytoplib/zextui/controler/ExtApiControler.java create mode 100644 src/main/java/iflytoplib/zextui/controler/ExtApiControllerAdvice.java create mode 100644 src/main/java/iflytoplib/zextui/mgr/ExtApiPageGroupCfgMgr.java create mode 100644 src/main/java/iflytoplib/zextui/mgr/ExtApiPageMgr.java create mode 100644 src/main/java/iflytoplib/zextui/type/ExApiPage.java create mode 100644 src/main/java/iflytoplib/zextui/type/ExUIFunction.java create mode 100644 src/main/java/iflytoplib/zextui/type/ExUIParam.java create mode 100644 src/main/java/iflytoplib/zextui/type/ExUIParamGetInitValFnType1.java create mode 100644 src/main/java/iflytoplib/zextui/type/ExUIParamGetInitValFnType2.java create mode 100644 src/main/java/iflytoplib/zextui/type/ExtApiFn.java create mode 100644 src/main/java/iflytoplib/zextui/type/ExtApiStatu.java create mode 100644 src/main/java/iflytoplib/zextui/type/ExtUIPageCfg.java create mode 100644 src/main/java/iflytoplib/zextui/type/ExtUITab.java create mode 100644 src/main/java/iflytoplib/zextui/type/ExtUiTable.java create mode 100644 src/main/java/iflytoplib/zextui/type/TabCfg.java create mode 100644 src/main/java/iflytoplib/zextui/type/param/ExtUIFile.java create mode 100644 src/main/java/iflytoplib/zextui/type/ret/EngineerUIRet.java create mode 100644 src/main/java/iflytoplib/zextui/type/ret/ExtApiCurve.java create mode 100644 src/main/java/iflytoplib/zextui/type/ret/ExtUIDownloadTasks.java create mode 100644 src/main/java/iflytoplib/zextui/type/ret/FileToBeDownload.java create mode 100644 src/main/java/iflytoplib/zextui/utils/FieldUtils.java diff --git a/src/main/java/iflytop/app/config/AppConstantConfig.java b/src/main/java/iflytop/app/config/AppConstantConfig.java new file mode 100644 index 0000000..cc1bbc5 --- /dev/null +++ b/src/main/java/iflytop/app/config/AppConstantConfig.java @@ -0,0 +1,10 @@ +package iflytop.config; + +public class AppConstantConfig { + public static final int HEARTBEAT_INTERVAL = 5000; + + public static final double SENSOR_ARM0_LENGTH_MM = 0.5; + public static final double SENSOR_ARM1_LENGTH_MM = 0.5; + + public static final int ENCODER_ACCURACY = 4096; +} diff --git a/src/main/java/iflytop/app/config/CorsConfig.java b/src/main/java/iflytop/app/config/CorsConfig.java new file mode 100644 index 0000000..443aa3a --- /dev/null +++ b/src/main/java/iflytop/app/config/CorsConfig.java @@ -0,0 +1,17 @@ +package iflytop.config; +import org.springframework.context.annotation.Configuration; +import org.springframework.web.servlet.config.annotation.CorsRegistry; +import org.springframework.web.servlet.config.annotation.WebMvcConfigurer; + +@Configuration +public class CorsConfig implements WebMvcConfigurer { + + @Override + public void addCorsMappings(CorsRegistry registry) { + // 允许所有域名进行跨域访问,实际使用时应根据需要进行配置 + registry.addMapping("/**") + .allowedOrigins("*") + .allowedMethods("GET", "POST", "PUT", "DELETE") + .allowedHeaders("*"); + } +} \ No newline at end of file diff --git a/src/main/java/iflytop/app/config/SpringDocConfig.java b/src/main/java/iflytop/app/config/SpringDocConfig.java new file mode 100644 index 0000000..42a8619 --- /dev/null +++ b/src/main/java/iflytop/app/config/SpringDocConfig.java @@ -0,0 +1,39 @@ +package iflytop.config; + +import io.swagger.v3.oas.models.OpenAPI; +import io.swagger.v3.oas.models.info.Info; +import org.springdoc.core.models.GroupedOpenApi; +import org.springframework.context.annotation.Bean; +import org.springframework.context.annotation.Configuration; + +/** + * 接口文档配置类 + */ +@Configuration +public class SpringDocConfig { + @Bean + public OpenAPI myOpenAPI() { + return new OpenAPI() + .info(new Info() + .title("接口说明")); + } + + + @Bean + public GroupedOpenApi allApi() { + return GroupedOpenApi.builder() + .group("app") + .packagesToScan("iflytop.app.controler") + .build(); + } + + + @Bean + public GroupedOpenApi enginnerConfig() { + return GroupedOpenApi.builder() + .group("enginner") + .packagesToScan("iflytop.engineer.controler") + .build(); + } + +} \ No newline at end of file diff --git a/src/main/java/iflytop/app/config/WebSocketConfiguration.java b/src/main/java/iflytop/app/config/WebSocketConfiguration.java new file mode 100644 index 0000000..adf7d41 --- /dev/null +++ b/src/main/java/iflytop/app/config/WebSocketConfiguration.java @@ -0,0 +1,13 @@ +package iflytop.config; + +import org.springframework.context.annotation.Bean; +import org.springframework.context.annotation.Configuration; +import org.springframework.web.socket.server.standard.ServerEndpointExporter; + +@Configuration +public class WebSocketConfiguration { + @Bean + public ServerEndpointExporter serverEndpointExporter() { + return new ServerEndpointExporter(); + } +} diff --git a/src/main/java/iflytop/app/controler/LocalDeviceControler.java b/src/main/java/iflytop/app/controler/LocalDeviceControler.java new file mode 100644 index 0000000..034b9a2 --- /dev/null +++ b/src/main/java/iflytop/app/controler/LocalDeviceControler.java @@ -0,0 +1,34 @@ +package iflytop.app.controler; + + +import iflytop.app.service.data.UserMgrService; +import iflytop.app.type.db.AppUser; +import iflytop.app.type.db.IflytopRet; +import iflytop.app.type.exception.AppException; +import io.swagger.v3.oas.annotations.Operation; +import io.swagger.v3.oas.annotations.tags.Tag; +import jakarta.annotation.Resource; +import lombok.extern.slf4j.Slf4j; +import org.springframework.stereotype.Controller; +import org.springframework.web.bind.annotation.PostMapping; +import org.springframework.web.bind.annotation.RequestMapping; +import org.springframework.web.bind.annotation.ResponseBody; + +@Tag(name = "用户", description = "") +@Slf4j +@Controller +@RequestMapping(value = "/user/") +@ResponseBody +public class UserControler { + + @Resource + UserMgrService appUserMgrService; + + @Operation(summary = "用户登录") + @PostMapping("login") + public IflytopRet login(Integer id, String password) throws AppException { + return IflytopRet.success(appUserMgrService.login(id, password)); + } + + +} diff --git a/src/main/java/iflytop/app/controler/ws/AppEventWSEndpoint.java b/src/main/java/iflytop/app/controler/ws/AppEventWSEndpoint.java deleted file mode 100644 index fc1a5ad..0000000 --- a/src/main/java/iflytop/app/controler/ws/AppEventWSEndpoint.java +++ /dev/null @@ -1,48 +0,0 @@ -package iflytop.app.controler.ws; - -import iflytop.app.service.base.WebSocketEndpointMgr; -import iflytop.app.utils.SpringBootBeanUtil; -import jakarta.websocket.*; -import jakarta.websocket.server.ServerEndpoint; -import lombok.extern.slf4j.Slf4j; -import org.springframework.stereotype.Component; - -import java.io.IOException; - -@ServerEndpoint(value = "/ws/event") -@Slf4j -@Component -public class AppEventWSEndpoint { - - private Session session; - - // 收到消息 - @OnMessage - public void onMessage(String message) throws IOException { - log.info("[websocket] 收到消息:id={},message={}", this.session.getId(), message); - } - - // 连接打开 - @OnOpen - public void onOpen(Session session, EndpointConfig endpointConfig) { - // 保存 session 到对象 - this.session = session; - SpringBootBeanUtil.getBean(WebSocketEndpointMgr.class).pushEventWebsocketSession(session); - log.info("[websocket] 新的连接:id={}", this.session.getId()); - } - - // 连接关闭 - @OnClose - public void onClose(CloseReason closeReason) { - SpringBootBeanUtil.getBean(WebSocketEndpointMgr.class).removeEventWebsocketSession(this.session); - log.info("[websocket] 连接断开:id={},reason={}", this.session.getId(), closeReason); - } - - // 连接异常 - @OnError - public void onError(Throwable throwable) throws IOException { - log.info("[websocket] 连接异常:id={},throwable={}", this.session.getId(), throwable.getMessage()); - // 关闭连接。状态码为 UNEXPECTED_CONDITION(意料之外的异常) - this.session.close(new CloseReason(CloseReason.CloseCodes.UNEXPECTED_CONDITION, throwable.getMessage())); - } -} diff --git a/src/main/java/iflytop/app/controler/ws/AppStateWSEndpoint.java b/src/main/java/iflytop/app/controler/ws/AppStateWSEndpoint.java deleted file mode 100644 index a5fbe99..0000000 --- a/src/main/java/iflytop/app/controler/ws/AppStateWSEndpoint.java +++ /dev/null @@ -1,47 +0,0 @@ -package iflytop.app.controler.ws; - -import iflytop.app.service.base.WebSocketEndpointMgr; -import iflytop.app.utils.SpringBootBeanUtil; -import jakarta.websocket.*; -import jakarta.websocket.server.ServerEndpoint; -import lombok.extern.slf4j.Slf4j; -import org.springframework.stereotype.Component; - -import java.io.IOException; - -@ServerEndpoint(value = "/ws/state") -@Slf4j -@Component -public class AppStateWSEndpoint { - private Session session; - - // 收到消息 - @OnMessage - public void onMessage(String message) throws IOException { - log.info("[websocket] 收到消息:id={},message={}", this.session.getId(), message); - } - - // 连接打开 - @OnOpen - public void onOpen(Session session, EndpointConfig endpointConfig) { - // 保存 session 到对象 - this.session = session; - SpringBootBeanUtil.getBean(WebSocketEndpointMgr.class).pushStateWebsocketSession(session); - log.info("{} [websocket] 新的连接:id={}", this,this.session.getId()); - } - - // 连接关闭 - @OnClose - public void onClose(CloseReason closeReason) { - SpringBootBeanUtil.getBean(WebSocketEndpointMgr.class).removeStateWebsocketSession(this.session); - log.info("[websocket] 连接断开:id={},reason={}", this.session.getId(), closeReason); - } - - // 连接异常 - @OnError - public void onError(Throwable throwable) throws IOException { - log.info("[websocket] 连接异常:id={},throwable={}", this.session.getId(), throwable.getMessage()); - // 关闭连接。状态码为 UNEXPECTED_CONDITION(意料之外的异常) - this.session.close(new CloseReason(CloseReason.CloseCodes.UNEXPECTED_CONDITION, throwable.getMessage())); - } -} diff --git a/src/main/java/iflytop/app/controler/ws/EventWSChannel.java b/src/main/java/iflytop/app/controler/ws/EventWSChannel.java new file mode 100644 index 0000000..67288ca --- /dev/null +++ b/src/main/java/iflytop/app/controler/ws/EventWSChannel.java @@ -0,0 +1,80 @@ +package iflytop.app.controler.ws; + +import jakarta.websocket.*; +import jakarta.websocket.server.ServerEndpoint; +import lombok.extern.slf4j.Slf4j; +import org.springframework.stereotype.Component; + +import java.io.IOException; +import java.util.ArrayList; +import java.util.List; + +@ServerEndpoint(value = "/ws/event") +@Slf4j +@Component +public class MeasurementTaskReportChannel { + + private Session session; + static List sessions = new ArrayList<>(); + + // + // ON MESSAGE + // + synchronized static public void report(String message) { + for (Session session : sessions) { + try { + session.getBasicRemote().sendText(message); + } catch (IOException ignored) { + + } + } + + } + + // + // CALLBACKS + // + + // 收到消息 + @OnMessage + public void onMessage(String message) throws IOException { + log.info("[websocket] 收到消息:id={},message={}", this.session.getId(), message); + } + + // 连接打开 + @OnOpen + public void onOpen(Session session, EndpointConfig endpointConfig) { + log.info("[websocket] 新的连接:id={}", session.getId()); + this.session = session; + addSession(session); + } + + // 连接关闭 + @OnClose + public void onClose(CloseReason closeReason) { + log.info("[websocket] 连接断开:id={},reason={}", this.session.getId(), closeReason); + removeSession(this.session); + this.session = null; + } + + // 连接异常 + @OnError + public void onError(Throwable throwable) throws IOException { + log.info("[websocket] 连接异常:id={},throwable={}", this.session.getId(), throwable.getMessage()); + // 关闭连接。状态码为 UNEXPECTED_CONDITION(意料之外的异常) + this.session.close(new CloseReason(CloseReason.CloseCodes.UNEXPECTED_CONDITION, throwable.getMessage())); + } + + // + // PRIVATE + // + + synchronized private static void addSession(Session session) { + sessions.add(session); + } + + synchronized private static void removeSession(Session session) { + sessions.remove(session); + } + +} diff --git a/src/main/java/iflytop/app/controler/ws/StateWSChannel.java b/src/main/java/iflytop/app/controler/ws/StateWSChannel.java new file mode 100644 index 0000000..501ac3e --- /dev/null +++ b/src/main/java/iflytop/app/controler/ws/StateWSChannel.java @@ -0,0 +1,80 @@ +package iflytop.app.controler.ws; + +import jakarta.websocket.*; +import jakarta.websocket.server.ServerEndpoint; +import lombok.extern.slf4j.Slf4j; +import org.springframework.stereotype.Component; + +import java.io.IOException; +import java.util.ArrayList; +import java.util.List; + +@ServerEndpoint(value = "/ws/event") +@Slf4j +@Component +public class EventWSChannel { + + private Session session; + static List sessions = new ArrayList<>(); + + // + // ON MESSAGE + // + synchronized static public void report(String message) { + for (Session session : sessions) { + try { + session.getBasicRemote().sendText(message); + } catch (IOException ignored) { + + } + } + + } + + // + // CALLBACKS + // + + // 收到消息 + @OnMessage + public void onMessage(String message) throws IOException { + log.info("[websocket] 收到消息:id={},message={}", this.session.getId(), message); + } + + // 连接打开 + @OnOpen + public void onOpen(Session session, EndpointConfig endpointConfig) { + log.info("[websocket] 新的连接:id={}", session.getId()); + this.session = session; + addSession(session); + } + + // 连接关闭 + @OnClose + public void onClose(CloseReason closeReason) { + log.info("[websocket] 连接断开:id={},reason={}", this.session.getId(), closeReason); + removeSession(this.session); + this.session = null; + } + + // 连接异常 + @OnError + public void onError(Throwable throwable) throws IOException { + log.info("[websocket] 连接异常:id={},throwable={}", this.session.getId(), throwable.getMessage()); + // 关闭连接。状态码为 UNEXPECTED_CONDITION(意料之外的异常) + this.session.close(new CloseReason(CloseReason.CloseCodes.UNEXPECTED_CONDITION, throwable.getMessage())); + } + + // + // PRIVATE + // + + synchronized private static void addSession(Session session) { + sessions.add(session); + } + + synchronized private static void removeSession(Session session) { + sessions.remove(session); + } + +} diff --git a/src/main/java/iflytop/app/service/backgroud/SensorReportPreAnalysis.java b/src/main/java/iflytop/app/service/backgroud/SensorReportPreAnalysis.java new file mode 100644 index 0000000..d510c22 --- /dev/null +++ b/src/main/java/iflytop/app/service/backgroud/SensorReportPreAnalysis.java @@ -0,0 +1,2 @@ +package iflytop.app.service.backgroud;public class SensorReportPreAnalysis { +} diff --git a/src/main/java/iflytop/app/type/XYPoint.java b/src/main/java/iflytop/app/type/XYPoint.java new file mode 100644 index 0000000..6a2cfd7 --- /dev/null +++ b/src/main/java/iflytop/app/type/XYPoint.java @@ -0,0 +1,2 @@ +package iflytop.app.type;public class XYPoint { +} diff --git a/src/main/java/iflytop/app/type/event/MeasurementTaskReportPosEvent.java b/src/main/java/iflytop/app/type/event/MeasurementTaskReportPosEvent.java new file mode 100644 index 0000000..7ad4905 --- /dev/null +++ b/src/main/java/iflytop/app/type/event/MeasurementTaskReportPosEvent.java @@ -0,0 +1,11 @@ +package iflytop.app.type.event; + +public class MeasurementTaskDataReportEvent extends AppEvent { + public Double x; + public Double y; + + public MeasurementTaskDataReportEvent(Double x, Double y) { + this.x = x; + this.y = y; + } +} diff --git a/src/main/java/iflytop/app/type/protocol/TPMISensorValReport.java b/src/main/java/iflytop/app/type/protocol/TPMISensorValReport.java new file mode 100644 index 0000000..0eb3070 --- /dev/null +++ b/src/main/java/iflytop/app/type/protocol/TPMISensorValReport.java @@ -0,0 +1,33 @@ +package iflytop.app.type.protocol; + +public class TPMISensorStateReport extends TPMIPacket { + + public TPMISensorStateReport(TPMIPacket packet) { + super(packet.rawpacket); + } + + //value:ARM0角度 + public Integer getArm0Angle() { + return this.getDataAsInt(0); + } + + //value:ARM1角度 + public Integer getArm1Angle() { + return this.getDataAsInt(1); + } + + //value:绝对值编码单圈最大值 + public Integer getMaxArmAngle() { + return this.getDataAsInt(2); + } + + //陀螺仪X角度 + public Integer getGyroscopeX() { + return this.getDataAsInt(3); + } + + //陀螺仪Y角度 + public Integer getGyroscopeY() { + return this.getDataAsInt(4); + } +} diff --git a/src/main/java/iflytop/app/type/ui/MessageBox.java b/src/main/java/iflytop/app/type/ui/MessageBox.java deleted file mode 100644 index 8b3ca27..0000000 --- a/src/main/java/iflytop/app/type/ui/MessageBox.java +++ /dev/null @@ -1,16 +0,0 @@ -package iflytop.app.type.ui; - -import java.util.Date; - -public class MessageBox { - public Date time; - public MessageLevel messageLevel; - public String message; - - public MessageBox(MessageLevel messageLevel, String message) { - this.time = new Date(); - this.messageLevel = messageLevel; - this.message = message; - } - -} diff --git a/src/main/java/iflytop/app/type/ui/MessageLevel.java b/src/main/java/iflytop/app/type/ui/MessageLevel.java deleted file mode 100644 index fee4996..0000000 --- a/src/main/java/iflytop/app/type/ui/MessageLevel.java +++ /dev/null @@ -1,8 +0,0 @@ -package iflytop.app.type.ui; - -public enum MessageLevel { - Info, //通知 - Warn, //警告 - Error, //错误 - Fatal, //致命错误 -} diff --git a/src/main/java/iflytop/app/type/ui/ZAppErrorStackInfo.java b/src/main/java/iflytop/app/type/ui/ZAppErrorStackInfo.java deleted file mode 100644 index 79806c1..0000000 --- a/src/main/java/iflytop/app/type/ui/ZAppErrorStackInfo.java +++ /dev/null @@ -1,5 +0,0 @@ -package iflytop.app.type.ui; - -public class ZAppErrorStackInfo { - public String[] stackTraceElements; -} diff --git a/src/main/java/iflytop/app/type/ui/ZAppPromopt.java b/src/main/java/iflytop/app/type/ui/ZAppPromopt.java deleted file mode 100644 index fd9f1d1..0000000 --- a/src/main/java/iflytop/app/type/ui/ZAppPromopt.java +++ /dev/null @@ -1,91 +0,0 @@ -package iflytop.app.type.ui; - -import io.swagger.v3.oas.annotations.media.Schema; - -import java.io.Serializable; -import java.util.List; - -public class ZAppPromopt implements Serializable { - - @Schema(description = "消息等级") - public MessageLevel messageLevel; - - public String title; - - @Schema(description = "主信息") - public String info; - - public ZAppPromoptDetailInfoType detailInfoType; - - @Schema(description = "详细信息") - public Object detailInfo; - - @Schema(description = "异常栈信息") - public ZAppErrorStackInfo stackInfo; - - void setDefaultTitle() { - if(messageLevel == MessageLevel.Error) { - this.title = "错误"; - } else if(messageLevel == MessageLevel.Warn) { - this.title = "警告"; - } else if(messageLevel == MessageLevel.Info) { - this.title = "信息"; - } - } - - - /** - * 构造FORMS - * @param type - * @param info - * @param stackInfo - * @param detailInfos - */ - public ZAppPromopt(MessageLevel type, String info, ZAppErrorStackInfo stackInfo, List detailInfos) { - this.messageLevel = type; - this.info = info; - this.stackInfo = stackInfo; - this.detailInfo = detailInfos; - this.detailInfoType = ZAppPromoptDetailInfoType.Forms; - - setDefaultTitle(); - } - - /** - * 构造TEXT - * @param type - * @param info - * @param stackInfo - * @param detailInfos - */ - public ZAppPromopt(MessageLevel type, String info, ZAppErrorStackInfo stackInfo, String detailInfos) { - this.messageLevel = type; - this.info = info; - this.stackInfo = stackInfo; - this.detailInfo = detailInfos; - this.detailInfoType = ZAppPromoptDetailInfoType.Text; - - setDefaultTitle(); - - } - - /** - * 构造TABLE - * @param type - * @param info - * @param stackInfo - * @param detailInfos - */ - public ZAppPromopt(MessageLevel type, String info, ZAppErrorStackInfo stackInfo, ZAppPromoptTable detailInfos) { - this.messageLevel = type; - this.info = info; - this.stackInfo = stackInfo; - this.detailInfo = detailInfos; - this.detailInfoType = ZAppPromoptDetailInfoType.Table; - setDefaultTitle(); - - } - - - -} diff --git a/src/main/java/iflytop/app/type/ui/ZAppPromoptDetailInfoType.java b/src/main/java/iflytop/app/type/ui/ZAppPromoptDetailInfoType.java deleted file mode 100644 index 0d391c7..0000000 --- a/src/main/java/iflytop/app/type/ui/ZAppPromoptDetailInfoType.java +++ /dev/null @@ -1,7 +0,0 @@ -package iflytop.app.type.ui; - -public enum ZAppPromoptDetailInfoType { - Text,//文本 - Forms, //表单 - Table, //表格 -} diff --git a/src/main/java/iflytop/app/type/ui/ZAppPromoptFormsItem.java b/src/main/java/iflytop/app/type/ui/ZAppPromoptFormsItem.java deleted file mode 100644 index 75983f7..0000000 --- a/src/main/java/iflytop/app/type/ui/ZAppPromoptFormsItem.java +++ /dev/null @@ -1,11 +0,0 @@ -package iflytop.app.type.ui; - -public class ZAppPromoptFormsItem { - public String name; - public String description; - - public ZAppPromoptFormsItem(String name, String description) { - this.name = name; - this.description = description; - } -} diff --git a/src/main/java/iflytop/app/type/ui/ZAppPromoptTable.java b/src/main/java/iflytop/app/type/ui/ZAppPromoptTable.java deleted file mode 100644 index c7276f2..0000000 --- a/src/main/java/iflytop/app/type/ui/ZAppPromoptTable.java +++ /dev/null @@ -1,39 +0,0 @@ -package iflytop.app.type.ui; - -import java.util.ArrayList; -import java.util.Arrays; -import java.util.List; - -public class ZAppPromoptTable { - - public static class Val { - public MessageLevel messageLevel;//Normal,Warning,Error - public String val; - - public Val(MessageLevel messageLevel, String val) { - this.val = val; - this.messageLevel = messageLevel; - } - - public Val(String val) { - this.messageLevel = MessageLevel.Info; - this.val = val; - } - } - - public List header = new ArrayList<>(); - public List types = new ArrayList<>(); - public List vars = new ArrayList<>(); - - public void addHeader(String... header) { - this.header.addAll(Arrays.asList(header)); - } - - public void addType(String... type) { - this.types.addAll(Arrays.asList(type)); - } - - public void addVar(Val... var) { - this.vars.add(var); - } -} diff --git a/src/main/java/iflytop/app/type/ui/message/ZAppMessage.java b/src/main/java/iflytop/app/type/ui/message/ZAppMessage.java new file mode 100644 index 0000000..fd9f1d1 --- /dev/null +++ b/src/main/java/iflytop/app/type/ui/message/ZAppMessage.java @@ -0,0 +1,91 @@ +package iflytop.app.type.ui; + +import io.swagger.v3.oas.annotations.media.Schema; + +import java.io.Serializable; +import java.util.List; + +public class ZAppPromopt implements Serializable { + + @Schema(description = "消息等级") + public MessageLevel messageLevel; + + public String title; + + @Schema(description = "主信息") + public String info; + + public ZAppPromoptDetailInfoType detailInfoType; + + @Schema(description = "详细信息") + public Object detailInfo; + + @Schema(description = "异常栈信息") + public ZAppErrorStackInfo stackInfo; + + void setDefaultTitle() { + if(messageLevel == MessageLevel.Error) { + this.title = "错误"; + } else if(messageLevel == MessageLevel.Warn) { + this.title = "警告"; + } else if(messageLevel == MessageLevel.Info) { + this.title = "信息"; + } + } + + + /** + * 构造FORMS + * @param type + * @param info + * @param stackInfo + * @param detailInfos + */ + public ZAppPromopt(MessageLevel type, String info, ZAppErrorStackInfo stackInfo, List detailInfos) { + this.messageLevel = type; + this.info = info; + this.stackInfo = stackInfo; + this.detailInfo = detailInfos; + this.detailInfoType = ZAppPromoptDetailInfoType.Forms; + + setDefaultTitle(); + } + + /** + * 构造TEXT + * @param type + * @param info + * @param stackInfo + * @param detailInfos + */ + public ZAppPromopt(MessageLevel type, String info, ZAppErrorStackInfo stackInfo, String detailInfos) { + this.messageLevel = type; + this.info = info; + this.stackInfo = stackInfo; + this.detailInfo = detailInfos; + this.detailInfoType = ZAppPromoptDetailInfoType.Text; + + setDefaultTitle(); + + } + + /** + * 构造TABLE + * @param type + * @param info + * @param stackInfo + * @param detailInfos + */ + public ZAppPromopt(MessageLevel type, String info, ZAppErrorStackInfo stackInfo, ZAppPromoptTable detailInfos) { + this.messageLevel = type; + this.info = info; + this.stackInfo = stackInfo; + this.detailInfo = detailInfos; + this.detailInfoType = ZAppPromoptDetailInfoType.Table; + setDefaultTitle(); + + } + + + +} diff --git a/src/main/java/iflytop/app/type/ui/message/basic/MessageLevel.java b/src/main/java/iflytop/app/type/ui/message/basic/MessageLevel.java new file mode 100644 index 0000000..fee4996 --- /dev/null +++ b/src/main/java/iflytop/app/type/ui/message/basic/MessageLevel.java @@ -0,0 +1,8 @@ +package iflytop.app.type.ui; + +public enum MessageLevel { + Info, //通知 + Warn, //警告 + Error, //错误 + Fatal, //致命错误 +} diff --git a/src/main/java/iflytop/app/type/ui/message/basic/ZAppErrorStackInfo.java b/src/main/java/iflytop/app/type/ui/message/basic/ZAppErrorStackInfo.java new file mode 100644 index 0000000..79806c1 --- /dev/null +++ b/src/main/java/iflytop/app/type/ui/message/basic/ZAppErrorStackInfo.java @@ -0,0 +1,5 @@ +package iflytop.app.type.ui; + +public class ZAppErrorStackInfo { + public String[] stackTraceElements; +} diff --git a/src/main/java/iflytop/app/type/ui/message/basic/ZAppPromoptDetailInfoType.java b/src/main/java/iflytop/app/type/ui/message/basic/ZAppPromoptDetailInfoType.java new file mode 100644 index 0000000..0d391c7 --- /dev/null +++ b/src/main/java/iflytop/app/type/ui/message/basic/ZAppPromoptDetailInfoType.java @@ -0,0 +1,7 @@ +package iflytop.app.type.ui; + +public enum ZAppPromoptDetailInfoType { + Text,//文本 + Forms, //表单 + Table, //表格 +} diff --git a/src/main/java/iflytop/app/type/ui/message/basic/ZAppPromoptFormsItem.java b/src/main/java/iflytop/app/type/ui/message/basic/ZAppPromoptFormsItem.java new file mode 100644 index 0000000..75983f7 --- /dev/null +++ b/src/main/java/iflytop/app/type/ui/message/basic/ZAppPromoptFormsItem.java @@ -0,0 +1,11 @@ +package iflytop.app.type.ui; + +public class ZAppPromoptFormsItem { + public String name; + public String description; + + public ZAppPromoptFormsItem(String name, String description) { + this.name = name; + this.description = description; + } +} diff --git a/src/main/java/iflytop/app/type/ui/message/basic/ZAppPromoptTable.java b/src/main/java/iflytop/app/type/ui/message/basic/ZAppPromoptTable.java new file mode 100644 index 0000000..c7276f2 --- /dev/null +++ b/src/main/java/iflytop/app/type/ui/message/basic/ZAppPromoptTable.java @@ -0,0 +1,39 @@ +package iflytop.app.type.ui; + +import java.util.ArrayList; +import java.util.Arrays; +import java.util.List; + +public class ZAppPromoptTable { + + public static class Val { + public MessageLevel messageLevel;//Normal,Warning,Error + public String val; + + public Val(MessageLevel messageLevel, String val) { + this.val = val; + this.messageLevel = messageLevel; + } + + public Val(String val) { + this.messageLevel = MessageLevel.Info; + this.val = val; + } + } + + public List header = new ArrayList<>(); + public List types = new ArrayList<>(); + public List vars = new ArrayList<>(); + + public void addHeader(String... header) { + this.header.addAll(Arrays.asList(header)); + } + + public void addType(String... type) { + this.types.addAll(Arrays.asList(type)); + } + + public void addVar(Val... var) { + this.vars.add(var); + } +} diff --git a/src/main/java/iflytop/app/utils/CoordinateCalculator.java b/src/main/java/iflytop/app/utils/CoordinateCalculator.java new file mode 100644 index 0000000..2337294 --- /dev/null +++ b/src/main/java/iflytop/app/utils/CoordinateCalculator.java @@ -0,0 +1,2 @@ +package iflytop.app.utils;public class CoordinateCalculator { +} diff --git a/src/main/java/iflytop/config/CorsConfig.java b/src/main/java/iflytop/config/CorsConfig.java deleted file mode 100644 index 443aa3a..0000000 --- a/src/main/java/iflytop/config/CorsConfig.java +++ /dev/null @@ -1,17 +0,0 @@ -package iflytop.config; -import org.springframework.context.annotation.Configuration; -import org.springframework.web.servlet.config.annotation.CorsRegistry; -import org.springframework.web.servlet.config.annotation.WebMvcConfigurer; - -@Configuration -public class CorsConfig implements WebMvcConfigurer { - - @Override - public void addCorsMappings(CorsRegistry registry) { - // 允许所有域名进行跨域访问,实际使用时应根据需要进行配置 - registry.addMapping("/**") - .allowedOrigins("*") - .allowedMethods("GET", "POST", "PUT", "DELETE") - .allowedHeaders("*"); - } -} \ No newline at end of file diff --git a/src/main/java/iflytop/config/SpringDocConfig.java b/src/main/java/iflytop/config/SpringDocConfig.java deleted file mode 100644 index 42a8619..0000000 --- a/src/main/java/iflytop/config/SpringDocConfig.java +++ /dev/null @@ -1,39 +0,0 @@ -package iflytop.config; - -import io.swagger.v3.oas.models.OpenAPI; -import io.swagger.v3.oas.models.info.Info; -import org.springdoc.core.models.GroupedOpenApi; -import org.springframework.context.annotation.Bean; -import org.springframework.context.annotation.Configuration; - -/** - * 接口文档配置类 - */ -@Configuration -public class SpringDocConfig { - @Bean - public OpenAPI myOpenAPI() { - return new OpenAPI() - .info(new Info() - .title("接口说明")); - } - - - @Bean - public GroupedOpenApi allApi() { - return GroupedOpenApi.builder() - .group("app") - .packagesToScan("iflytop.app.controler") - .build(); - } - - - @Bean - public GroupedOpenApi enginnerConfig() { - return GroupedOpenApi.builder() - .group("enginner") - .packagesToScan("iflytop.engineer.controler") - .build(); - } - -} \ No newline at end of file diff --git a/src/main/java/iflytop/config/WebSocketConfiguration.java b/src/main/java/iflytop/config/WebSocketConfiguration.java deleted file mode 100644 index adf7d41..0000000 --- a/src/main/java/iflytop/config/WebSocketConfiguration.java +++ /dev/null @@ -1,13 +0,0 @@ -package iflytop.config; - -import org.springframework.context.annotation.Bean; -import org.springframework.context.annotation.Configuration; -import org.springframework.web.socket.server.standard.ServerEndpointExporter; - -@Configuration -public class WebSocketConfiguration { - @Bean - public ServerEndpointExporter serverEndpointExporter() { - return new ServerEndpointExporter(); - } -} diff --git a/src/main/java/iflytop/engineer/controler/EngineerRootPageControler.java b/src/main/java/iflytop/engineer/controler/EngineerRootPageControler.java deleted file mode 100644 index 7619bea..0000000 --- a/src/main/java/iflytop/engineer/controler/EngineerRootPageControler.java +++ /dev/null @@ -1,30 +0,0 @@ -package iflytop.engineer.controler; - -import iflytop.app.type.exception.AppException; -import iflytop.engineer.service.RootMgrService; -import io.swagger.v3.oas.annotations.Operation; -import io.swagger.v3.oas.annotations.tags.Tag; -import jakarta.annotation.Resource; -import lombok.extern.slf4j.Slf4j; -import org.springframework.stereotype.Component; -import org.springframework.stereotype.Controller; -import org.springframework.web.bind.annotation.PostMapping; -import org.springframework.web.bind.annotation.RequestMapping; -import org.springframework.web.bind.annotation.ResponseBody; - -@Tag(name = "工程师页面根页面配置", description = "") -@Slf4j -@Controller -@RequestMapping(value = "/engineer/root/") -@ResponseBody -public class EngineerRootPageControler { - @Resource - RootMgrService rootMgrService; - - @Operation(summary = "获取AMIS-ROOT-CONFIG") - @PostMapping("getAmisRoot") - public Object getAmisRootConfig() throws AppException { - return rootMgrService.getRootPage("pageId"); - } - -} diff --git a/src/main/java/iflytop/engineer/service/RootMgrService.java b/src/main/java/iflytop/engineer/service/RootMgrService.java deleted file mode 100644 index e765068..0000000 --- a/src/main/java/iflytop/engineer/service/RootMgrService.java +++ /dev/null @@ -1,37 +0,0 @@ -package iflytop.engineer.service; - -import iflytop.engineer.type.EngineerPage; -import iflytop.zamis.type.features.Nav; -import iflytop.zamis.type.layout.Page; -import org.springframework.stereotype.Component; - -import java.util.ArrayList; -import java.util.List; -import java.util.Map; - -@Component -public class RootMgrService { - Map> pageMap; - - void regPage(EngineerPage page) {} - - public Object getRootPage(String pageId) { - /* - * PAGE - * NAV - * CONTENT - * STATUS - * FUNCTION(support) - */ - - Nav nav = new Nav(); - nav.links = new ArrayList<>(); - nav.links.add(new Nav.Link("页面1", "page1")); - nav.links.add(new Nav.Link("页面2", "page2")); - - Page page = new Page(); - page.aside = nav; - return page; - } - -} diff --git a/src/main/java/iflytop/engineer/type/EngineerPage.java b/src/main/java/iflytop/engineer/type/EngineerPage.java deleted file mode 100644 index 90b0f1f..0000000 --- a/src/main/java/iflytop/engineer/type/EngineerPage.java +++ /dev/null @@ -1,7 +0,0 @@ -package iflytop.engineer.type; - -public class EngineerPage { - public String groupName; - public String pageName; - -} diff --git a/src/main/java/iflytop/zamis/type/display/Icon.java b/src/main/java/iflytop/zamis/type/display/Icon.java deleted file mode 100644 index a1d6700..0000000 --- a/src/main/java/iflytop/zamis/type/display/Icon.java +++ /dev/null @@ -1,11 +0,0 @@ -package iflytop.zamis.type.display; - -import com.fasterxml.jackson.annotation.JsonInclude; - -@JsonInclude(JsonInclude.Include.NON_NULL) -public class Icon { - public String type = "icon"; // icon 指定组件类型 - public String className; // 外层 CSS 类名 - public Object icon; // 模板 icon 名称,支持 fontawesome v4 或 通过 registerIcon 注册的 icon、或使用 url - public String vendor; // icon 类型,默认为fa, 表示 fontawesome v4。也支持 iconfont, 如果是 fontawesome v5 以上版本或者其他框架可以设置为空字符串 -} diff --git a/src/main/java/iflytop/zamis/type/display/Remark.java b/src/main/java/iflytop/zamis/type/display/Remark.java deleted file mode 100644 index e717af0..0000000 --- a/src/main/java/iflytop/zamis/type/display/Remark.java +++ /dev/null @@ -1,17 +0,0 @@ -package iflytop.zamis.type.display; - -import com.fasterxml.jackson.annotation.JsonInclude; -import iflytop.zamis.type.options.Position; -import iflytop.zamis.type.options.Shape; -import iflytop.zamis.type.options.Trigger; - -@JsonInclude(JsonInclude.Include.NON_NULL) -public class Remark { - public String type = "remark"; // string remark - public String className; // string 外层 CSS 类名 - public String content; // string 提示文本 - public Position placement; // ['top', 'right', 'bottom', 'left'] 弹出位置 - public Trigger trigger; // ['hover', 'focus'] 触发条件 - public String icon; // string fa fa-question-circle 图标 - public Shape shape; // 'circle' | 'square' 图标形状 -} diff --git a/src/main/java/iflytop/zamis/type/features/ActionButton.java b/src/main/java/iflytop/zamis/type/features/ActionButton.java deleted file mode 100644 index 2f7d395..0000000 --- a/src/main/java/iflytop/zamis/type/features/ActionButton.java +++ /dev/null @@ -1,30 +0,0 @@ -package iflytop.zamis.type.features; - -import com.fasterxml.jackson.annotation.JsonInclude; - -import java.util.List; - -@JsonInclude(JsonInclude.Include.NON_NULL) -public class ActionButton { - public String type = "action";// string action 指定为 Page 渲染器。 - public String actionType;// string - 【必填】这是 action 最核心的配置,来指定该 action 的作用类型,支持:ajax、link、url、drawer、dialog、confirm、cancel、prev、next、copy、close。 - public String label;// string - 按钮文本。可用 ${xxx} 取值。 - public String level;// string default 按钮样式,支持:link、primary、secondary、info、success、warning、danger、light、dark、default。 - public String size;// string - 按钮大小,支持:xs、sm、md、lg。 - public String icon;// string - 设置图标,例如fa fa-plus。 - public String iconClassName;// string - 给图标上添加类名。 - public String rightIcon;// string - 在按钮文本右侧设置图标,例如fa fa-plus。 - public String rightIconClassName;// string - 给右侧图标上添加类名。 - public Boolean active;// boolean - 按钮是否高亮。 - public String activeLevel;// string - 按钮高亮时的样式,配置支持同level。 - public String activeClassName;// string is-active 给按钮高亮添加类名。 - public Boolean block;// boolean - 用display:"block"来显示按钮。 - public String confirmText;// 模板 - 当设置后,操作在开始前会询问用户。可用 ${xxx} 取值。 - public String confirmTitle;// 模板 - 确认框标题,前提是 confirmText 有内容,支持模版语法 - public String reload;// string - 指定此次操作完后,需要刷新的目标组件名字(组件的name值,自己配置的),多个请用 , 号隔开。 - public String tooltip;// string - 鼠标停留时弹出该段文字,也可以配置对象类型:字段为title和content。可用 ${xxx} 取值。 - public String disabledTip;// 'string' | 'TooltipObject' - 被禁用后鼠标停留时弹出该段文字,也可以配置对象类型:字段为title和content。可用 ${xxx} 取值。 - public String tooltipPlacement;// string top 如果配置了tooltip或者disabledTip,指定提示信息位置,可配置top、bottom、left、right。 - public Boolean close;// boolean or string - 当action配置在dialog或drawer的actions中时,配置为true指定此次操作完后关闭当前dialog或drawer。当值为字符串,并且是祖先层弹框的名字的时候,会把祖先弹框关闭掉。 - public List required;// Array - 配置字符串数组,指定在form中进行操作之前,需要指定的字段名的表单项通过验证 -} diff --git a/src/main/java/iflytop/zamis/type/features/DropDownButton.java b/src/main/java/iflytop/zamis/type/features/DropDownButton.java deleted file mode 100644 index 81abfb7..0000000 --- a/src/main/java/iflytop/zamis/type/features/DropDownButton.java +++ /dev/null @@ -1,25 +0,0 @@ -package iflytop.zamis.type.features; - -import com.fasterxml.jackson.annotation.JsonInclude; -import iflytop.zamis.type.options.Trigger; - -import java.util.List; - -@JsonInclude(JsonInclude.Include.NON_NULL) -public class DropDownButton { - public String type = "dropdown-button";// string dropdown-button 类型 - public String label;// string 按钮文本 - public String className;// string 外层 CSS 类名 - public String btnClassName;// string 按钮 CSS 类名 - public String menuClassName;// string 下拉菜单 CSS 类名 - public Boolean block;// boolean 块状样式 - public String size;// string 尺寸,支持'xs'、'sm'、'md' 、'lg' - public String align;// string 位置,可选'left'或'right' - public List buttons;// Array 配置下拉按钮 - public Boolean iconOnly;// boolean 只显示 icon - public Boolean defaultIsOpened;// boolean 默认是否打开 - public Boolean closeOnOutside;// boolean true 点击外侧区域是否收起 - public Boolean closeOnClick;// boolean false 点击按钮后自动关闭下拉菜单 - public Trigger trigger;// click 或 hover click 触发方式 - public Boolean hideCaret;// boolean false 隐藏下拉图标 -} diff --git a/src/main/java/iflytop/zamis/type/features/Nav.java b/src/main/java/iflytop/zamis/type/features/Nav.java deleted file mode 100644 index 6c6248d..0000000 --- a/src/main/java/iflytop/zamis/type/features/Nav.java +++ /dev/null @@ -1,71 +0,0 @@ -package iflytop.zamis.type.features; - -import com.fasterxml.jackson.annotation.JsonInclude; - -import java.util.List; - -@JsonInclude(JsonInclude.Include.NON_NULL) -public class Nav { - public static class Link { - public String label;// string 名称 - public String to;// 模板 链接地址 - public String target;// string 链接关系 - public String icon;// string 图标 - public List children;// Array 子链接 - public Boolean unfolded;// boolean 初始是否展开 - public Boolean active;// boolean 是否高亮 - public String activeOn;// 表达式 是否高亮的条件,留空将自动分析链接地址 - public Boolean defer;// boolean 标记是否为懒加载项 - public String deferApi;// API 可以不配置,如果配置优先级更高 - public Boolean disabled;// boolean 是否禁用 - public String disabledTip;// string 禁用提示信息 - public String className;// string 菜单项自定义样式 - public String mode;// string 菜菜单项模式,分组模式:"group"、分割线:"divider" - - public Link() { - } - - public Link(String label, String to) { - this.label = label; - this.to = to; - } - } - - public static class Overflow { - public Boolean enable;// boolean false 是否开启响应式收纳 - public String overflowLabel;// string | SchemaObject 菜单触发按钮的文字 - public Object overflowIndicator;// SchemaIcon "fa fa-ellipsis" 菜单触发按钮的图标 - public Number maxVisibleCount;// number 开启响应式收纳后导航最大可显示数量,超出此数量的导航将被收纳到下拉菜单中,默认为自动计算 - public String wrapperComponent;// string 包裹导航的外层标签名,可以使用其他标签渲染 - public String style;// React.CSSProperties 自定义样式 - public String overflowClassName;// string "" 菜单按钮 CSS 类名 - public String overflowPopoverClassName;// string "" Popover 浮层 CSS 类名 - } - - - public String type = "nav"; // string "nav" 指定为 Nav 渲染器 - public String mode; // string "inline" 导航模式,悬浮或者内联,默认内联模式 - public Boolean collapsed; // boolean 控制导航是否缩起 - public Number indentSize; // number 16 层级缩进值,仅内联模式下生效 - public Number level; // number 控制导航最大展示层级数 - public Number defaultOpenLevel; // number 控制导航最大默认展开层级 - public String className; // string 外层 Dom 的类名 - public String popupClassName; // string 当为悬浮模式时,可自定义悬浮层样式 - public String expandIcon; // string | SchemaObject 自定义展开按钮 - public String expandPosition; // string 展开按钮位置,"before"或者"after",不设置默认在前面 - public Boolean stacked; // boolean true 设置成 false 可以以 tabs 的形式展示 - public Boolean accordion; // boolean 是否开启手风琴模式 - public String source; // string 或 API 可以通过变量或 API 接口动态创建导航 - public String deferApi; // API 用来延时加载选项详情的接口,可以不配置,不配置公用 source 接口。 - public Object itemActions; // SchemaNode 更多操作相关配置 - public Boolean draggable; // boolean 是否支持拖拽排序 - public Boolean dragOnSameLevel; // boolean 仅允许同层级内拖拽 - public String saveOrderApi; // string 或 API 保存排序的 api - // public BadgeSchema itemBadge; // BadgeSchema 角标 - - - public Boolean searchable; // boolean false 是否开启搜索 3.5.0 - public Overflow overflow; - public List links; - -} diff --git a/src/main/java/iflytop/zamis/type/features/ServiceContainer.java b/src/main/java/iflytop/zamis/type/features/ServiceContainer.java deleted file mode 100644 index c763f27..0000000 --- a/src/main/java/iflytop/zamis/type/features/ServiceContainer.java +++ /dev/null @@ -1,27 +0,0 @@ -package iflytop.zamis.type.features; - - -import com.fasterxml.jackson.annotation.JsonInclude; - -@JsonInclude(JsonInclude.Include.NON_NULL) -public class ServiceContainer { - static public class Message { - public String fetchSuccess; // string 接口请求成功时的 toast 提示文字 - public String fetchFailed; // string "初始化失败" 接口请求失败时 toast 提示文字 - } - - public String type; // string "service" 指定为 service 渲染器 - public String className; // string 外层 Dom 的类名 - public Object body; // SchemaNode 内容容器 - public String api; // API 初始化数据域接口地址 - public String ws; // string WebScocket 地址 - public String dataProvider; // string | Record<"inited" | "onApiFetched" | "onSchemaApiFetched" | "onWsFetched", string> 数据获取函数 - public Boolean initFetch; // boolean 是否默认拉取 - public String schemaApi; // API 用来获取远程 Schema 接口地址 - public Boolean initFetchSchema; // boolean 是否默认拉取 Schema - public Message messages; // Object 消息提示覆写,默认消息读取的是接口返回的 toast 提示文字,但是在此可以覆写它。 - public Number interval; // number 轮询时间间隔,单位 ms(最低 1000) - public Boolean silentPolling; // boolean false 配置轮询时是否显示加载动画 - public String stopAutoRefreshWhen; // 表达式 配置停止轮询的条件 - public Boolean showErrorMsg; // boolean true 是否以 Alert 的形式显示 api 接口响应的错误信息,默认展示 2.8.1 -} diff --git a/src/main/java/iflytop/zamis/type/form/Form.java b/src/main/java/iflytop/zamis/type/form/Form.java deleted file mode 100644 index 1555509..0000000 --- a/src/main/java/iflytop/zamis/type/form/Form.java +++ /dev/null @@ -1,67 +0,0 @@ -package iflytop.zamis.type.form; - -import com.fasterxml.jackson.annotation.JsonInclude; -import iflytop.zamis.type.features.ServiceContainer; -import iflytop.zamis.type.options.Align; - -@JsonInclude(JsonInclude.Include.NON_NULL) -public class Form { - - static public class Message { - public String fetchSuccess; // string 接口请求成功时的 toast 提示文字 - public String fetchFailed; // string "初始化失败" 接口请求失败时 toast 提示文字 - public String saveSuccess; - public String SaveFailed; - } - - public String type;// string "form" 指定为 Form 渲染器 - public String name;// string 设置一个名字后,方便其他组件与其通信 - public String mode;// string normal 表单展示方式,可以是:normal、horizontal 或者 inline - public Object horizontal;// Object {"left":2, "right":10, "justify": false} 当 mode 为 horizontal 时有用,用来控制 label 的展示占比 - public Align labelAlign;// "right" | "left" "right" 表单项标签对齐方式,默认右对齐,仅在 mode为horizontal 时生效 - public Number labelWidth;// number | string 表单项标签自定义宽度 - public String title;// string "表单" Form 的标题 - public String submitText;// String "提交" 默认的提交按钮名称,如果设置成空,则可以把默认按钮去掉。 - public String className;// string 外层 Dom 的类名 - public Object body;// Array<表单项 or SchemaNode > Form 表单项集合 - public Object actions;// Array<行为按钮> Form 提交按钮,成员为 Action - public Message messages;//.fetchSuccess string 获取成功时提示 - - public Boolean wrapWithPanel;// boolean true 是否让 Form 用 panel 包起来,设置为 false 后,actions 将无效。 - public String panelClassName;// string 外层 panel 的类名 - public String api;// API Form 用来保存数据的 api。 - public String initApi;// API Form 用来获取初始数据的 api。 - public String rules;// Array<{rule:string;message:string;name?: string[]}> 表单组合校验规则 - public Number interval;// number 3000 刷新时间(最低 3000) - public Boolean silentPolling;// boolean false 配置刷新时是否显示加载动画 - public String stopAutoRefreshWhen;// string "" 通过表达式 来配置停止刷新的条件 - public String initAsyncApi;// API Form 用来获取初始数据的 api,与 initApi 不同的是,会一直轮询请求该接口,直到返回 finished 属性为 true 才 结束。 - public Boolean initFetch;// boolean true 设置了 initApi 或者 initAsyncApi 后,默认会开始就发请求,设置为 false 后就不会起始就请求接口 - public String initFetchOn;// string 用表达式来配置 - public String initFinishedField;// string finished 设置了 initAsyncApi 后,默认会从返回数据的 data.finished 来判断是否完成,也可以设置成其他的 xxx,就会从 data.xxx 中获取 - public Number initCheckInterval;// number 3000 设置了 initAsyncApi 以后,默认拉取的时间间隔 - public String asyncApi;// API 设置此属性后,表单提交发送保存接口后,还会继续轮询请求该接口,直到返回 finished 属性为 true 才 结束。 - public Number checkInterval;// number 3000 轮询请求的时间间隔,默认为 3 秒。设置 asyncApi 才有效 - public String finishedField;// string "finished" 如果决定结束的字段名不是 finished 请设置此属性,比如 is_success - public Boolean submitOnChange;// boolean false 表单修改即提交 - public Boolean submitOnInit;// boolean false 初始就提交一次 - public Boolean resetAfterSubmit;// boolean false 提交后是否重置表单 - public String primaryField;// string "id" 设置主键 id, 当设置后,检测表单是否完成时(asyncApi),只会携带此数据。 - public String target;// string 默认表单提交自己会通过发送 api 保存数据,但是也可以设定另外一个 form 的 name 值,或者另外一个 CRUD 模型的 name 值。 如果 target 目标是一个 Form ,则目标 Form 会重新触发 initApi,api 可以拿到当前 form 数据。如果目标是一个 CRUD 模型,则目标模型会重新触发搜索,参数为当前 Form 数据。当目标是 window 时,会把当前表单的数据附带到页面地址上。 - public String redirect;// string 设置此属性后,Form 保存成功后,自动跳转到指定页面。支持相对地址,和绝对地址(相对于组内的)。 - public String reload;// string 操作完后刷新目标对象。请填写目标组件设置的 name 值,如果填写为 window 则让当前页面整体刷新。 - public Boolean autoFocus;// boolean false 是否自动聚焦。 - public Boolean canAccessSuperData;// boolean true 指定是否可以自动获取上层的数据并映射到表单项上 - public String persistData;// string "" 指定一个唯一的 key,来配置当前表单是否开启本地缓存 - public String persistDataKeys;// string[] "" 指指定只有哪些 key 缓存 - public Boolean clearPersistDataAfterSubmit;// boolean true 指定表单提交成功后是否清除本地缓存 - public Boolean preventEnterSubmit;// boolean false 禁用回车提交表单 - public Boolean trimValues;// boolean false trim 当前表单项的每一个值 - public Boolean promptPageLeave;// boolean false form 还没保存,即将离开页面前是否弹框确认。 - public Number columnCount;// number 0 表单项显示为几列 - public Boolean inheritData;// boolean true 默认表单是采用数据链的形式创建个自己的数据域,表单提交的时候只会发送自己这个数据域的数据,如果希望共用上层数据域可以设置这个属性为 false,这样上层数据域的数据不需要在表单中用隐藏域或者显式映射才能发送了。 - - // public Boolean static;// boolean 2.4.0 整个表单静态方式展示,详情请查看示例页 - // public String staticClassName;// string 2.4.0 表单静态展示时使用的类名 - public Boolean closeDialogOnSubmit;// boolean 提交的时候是否关闭弹窗。当 form 里面有且只有一个弹窗的时候,本身提交会触发弹窗关闭,此属性可以关闭此行为 -} diff --git a/src/main/java/iflytop/zamis/type/form/FormItem.java b/src/main/java/iflytop/zamis/type/form/FormItem.java deleted file mode 100644 index 349613b..0000000 --- a/src/main/java/iflytop/zamis/type/form/FormItem.java +++ /dev/null @@ -1,48 +0,0 @@ -package iflytop.zamis.type.form; - -import com.fasterxml.jackson.annotation.JsonInclude; -import iflytop.zamis.type.options.Align; - -import java.util.List; - -@JsonInclude(JsonInclude.Include.NON_NULL) -public class FormItem { - static public class AutoFill { - public Boolean showSuggestion;//boolean true 为参照录入,false 自动填充 - public String api;//表达式 自动填充接口/参照录入筛选 CRUD 请求配置 - public Boolean silent;//boolean 是否展示数据格式错误提示,默认为 true - public Object fillMappinng;//SchemaNode 自动填充/参照录入数据映射配置,键值对形式,值支持变量获取及表达式 - public String trigger;//string showSuggestion 为 true 时,参照录入支持的触发方式,目前支持 change「值变化」| focus 「表单项聚焦」 - public String mode;//string showSuggestion 为 true 时,参照弹出方式 dialog, drawer, popOver - public String labelField;//string showSuggestion 为 true 时,设置弹出 dialog,drawer,popOver 中 picker 的 labelField - public String position;//string showSuggestion 为 true 时,参照录入 mode 为 popOver 时,可配置弹出位置 - public String size;//string showSuggestion 为 true 时,参照录入 mode 为 dialog 时,可设置大小 - public List columns;//Array showSuggestion 为 true 时,数据展示列配置 - public Object filter;//SchemaNode showSuggestion 为 true 时,数据查询过滤条件 - - } - - public String type; // string 指定表单项类型 - public String className; // string 表单最外层类名 - public String inputClassName; // string 表单控制器类名 - public String labelClassName; // string label 的类名 - public String name; // string 字段名,指定该表单项提交时的 key - public String value; // string 表单默认值 - public String label; // 模板 或 false 表单项标签 - public Align labelAlign; // "right" | "left" "right" 表单项标签对齐方式,默认右对齐,仅在 mode为horizontal 时生效 - public String labelRemark; // Remark 表单项标签描述 - public String description; // 模板 表单项描述 - public String placeholder; // string 表单项描述 - public Boolean inline; // boolean 是否为 内联 模式 - public Boolean strictMode; // boolean 通过配置 false 可以及时获取所有表单里面的数据,否则可能会有不同步 - public Boolean submitOnChange; // boolean 是否该表单项值发生变化时就提交当前表单。 - public Boolean disabled; // boolean 当前表单项是否是禁用状态 - public String disabledOn; // 表达式 当前表单项是否禁用的条件 - public String visible; // 表达式 当前表单项是否禁用的条件 - public String visibleOn; // 表达式 当前表单项是否禁用的条件 - public Boolean required; // boolean 是否为必填。 - public String requiredOn; // 表达式 通过表达式来配置当前表单项是否为必填。 - public String validations; // 表达式 表单项值格式验证,支持设置多个,多个规则用英文逗号隔开。 - public String validateApi; // 表达式 表单校验接口 - public Object autoFill; // SchemaNode 数据录入配置,自动填充或者参照录入 -} diff --git a/src/main/java/iflytop/zamis/type/form/InputNumber.java b/src/main/java/iflytop/zamis/type/form/InputNumber.java deleted file mode 100644 index acf594e..0000000 --- a/src/main/java/iflytop/zamis/type/form/InputNumber.java +++ /dev/null @@ -1,12 +0,0 @@ -package iflytop.zamis.type.form; - -import com.fasterxml.jackson.annotation.JsonInclude; - -@JsonInclude(JsonInclude.Include.NON_NULL) -public class InputNumber extends FormItem { - - public InputNumber() { - type = "input-number"; - } - -} diff --git a/src/main/java/iflytop/zamis/type/form/InputText.java b/src/main/java/iflytop/zamis/type/form/InputText.java deleted file mode 100644 index fe75e58..0000000 --- a/src/main/java/iflytop/zamis/type/form/InputText.java +++ /dev/null @@ -1,13 +0,0 @@ -package iflytop.zamis.type.form; - - -import com.fasterxml.jackson.annotation.JsonInclude; - -@JsonInclude(JsonInclude.Include.NON_NULL) -public class InputText extends FormItem { - - public InputText() { - type = "input-text"; - } - -} diff --git a/src/main/java/iflytop/zamis/type/form/Select.java b/src/main/java/iflytop/zamis/type/form/Select.java deleted file mode 100644 index 8594339..0000000 --- a/src/main/java/iflytop/zamis/type/form/Select.java +++ /dev/null @@ -1,19 +0,0 @@ -package iflytop.zamis.type.form; - -import com.fasterxml.jackson.annotation.JsonInclude; - -import java.util.List; - -@JsonInclude(JsonInclude.Include.NON_NULL) -public class Select extends FormItem { - static public class Option { - public String value; - public String label; - } - - Select() { - type = "select"; - } - - List