diff --git a/web-vue/packages/core/layouts/screen/index.vue b/web-vue/packages/core/layouts/screen/index.vue
new file mode 100644
index 0000000..02409e3
--- /dev/null
+++ b/web-vue/packages/core/layouts/screen/index.vue
@@ -0,0 +1,8 @@
+
+
+
+
+
+
\ No newline at end of file
diff --git a/web-vue/packages/core/layouts/views/screen/analysis/index.vue b/web-vue/packages/core/layouts/views/screen/analysis/index.vue
new file mode 100644
index 0000000..02409e3
--- /dev/null
+++ b/web-vue/packages/core/layouts/views/screen/analysis/index.vue
@@ -0,0 +1,8 @@
+
+
+
+
+
+
\ No newline at end of file
diff --git a/web-vue/packages/core/router/constant.ts b/web-vue/packages/core/router/constant.ts
index 8e17765..9663539 100644
--- a/web-vue/packages/core/router/constant.ts
+++ b/web-vue/packages/core/router/constant.ts
@@ -6,6 +6,7 @@ export const PAGE_NOT_FOUND_NAME = 'PageNotFound';
* @description: default layout
*/
export const LAYOUT = () => import('@jeesite/core/layouts/default/index.vue');
+export const SCREEN_LAYOUT = () => import('@jeesite/core/layouts/screen/index.vue');
export const IFRAME_BLANK = () => import('@jeesite/core/layouts/iframe/FrameBlank.vue');
export const IFRAME_SIMPLE = () => import('@jeesite/core/layouts/iframe/FrameSimple.vue');
export const EXCEPTION_COMPONENT = () => import('@jeesite/core/layouts/views/exception/Exception.vue');
diff --git a/web-vue/packages/core/router/routes/modules/screen.ts b/web-vue/packages/core/router/routes/modules/screen.ts
new file mode 100644
index 0000000..da584e5
--- /dev/null
+++ b/web-vue/packages/core/router/routes/modules/screen.ts
@@ -0,0 +1,31 @@
+import type { AppRouteModule } from '@jeesite/core/router/types';
+
+import { SCREEN_LAYOUT } from '@jeesite/core/router/constant';
+import { t } from '@jeesite/core/hooks/web/useI18n';
+
+const screen: AppRouteModule = {
+ path: '/screen',
+ name: 'Screen',
+ component: SCREEN_LAYOUT,
+ redirect: '/screen/analysis',
+ meta: {
+ orderNo: 10,
+ icon: 'i-ant-design:home-outlined',
+ title: t('routes.dashboard.dashboard'),
+ },
+ children: [
+ {
+ path: 'analysis',
+ name: 'Analysis',
+ component: () => import('@jeesite/core/layouts/views/screen/analysis/index.vue'),
+ meta: {
+ // affix: true,
+ icon: 'i-ant-design:home-outlined',
+ tabIcon: 'i-ant-design:home-outlined',
+ title: t('routes.dashboard.analysis'),
+ },
+ },
+ ],
+};
+
+export default screen;