feat: refactor monolithic App.vue into modular Vue component architecture
- Extract 711-line App.vue into 15+ focused files across 5 directories
- Add data layer (icons, metrics, policies, auditTrail, requests)
- Add composables (useNavigation, useRequests, useChat, useToast)
- Add layout components (SidebarRail, TopBar, FilterBar)
- Add shared components (PanelHead, InfoRow, ToastNotification)
- Add business component (RequestTable) and 5 view components
- Extract global CSS to assets/styles/global.css
- Add start.sh with WSL/Windows cross-platform support
- Add .gitignore for node_modules, dist, and IDE dirs
2026-04-28 17:20:52 +08:00
|
|
|
<template>
|
2026-05-12 15:15:43 +00:00
|
|
|
<div class="app-desktop-shell" :style="desktopScaleStyle">
|
|
|
|
|
<div class="app-desktop-stage">
|
2026-05-29 14:11:06 +08:00
|
|
|
<ElConfigProvider :locale="zhCn">
|
|
|
|
|
<RouterView />
|
|
|
|
|
<ToastNotification :toast-text="toastText" />
|
|
|
|
|
</ElConfigProvider>
|
2026-05-12 15:15:43 +00:00
|
|
|
</div>
|
|
|
|
|
</div>
|
feat: refactor monolithic App.vue into modular Vue component architecture
- Extract 711-line App.vue into 15+ focused files across 5 directories
- Add data layer (icons, metrics, policies, auditTrail, requests)
- Add composables (useNavigation, useRequests, useChat, useToast)
- Add layout components (SidebarRail, TopBar, FilterBar)
- Add shared components (PanelHead, InfoRow, ToastNotification)
- Add business component (RequestTable) and 5 view components
- Extract global CSS to assets/styles/global.css
- Add start.sh with WSL/Windows cross-platform support
- Add .gitignore for node_modules, dist, and IDE dirs
2026-04-28 17:20:52 +08:00
|
|
|
</template>
|
|
|
|
|
|
|
|
|
|
<script setup>
|
2026-05-12 15:39:00 +00:00
|
|
|
import { computed, onBeforeUnmount, onMounted, ref, watch } from 'vue'
|
2026-05-06 22:23:42 +08:00
|
|
|
import { RouterView } from 'vue-router'
|
2026-05-29 14:11:06 +08:00
|
|
|
import { ElConfigProvider } from 'element-plus/es/components/config-provider/index.mjs'
|
|
|
|
|
import zhCn from 'element-plus/es/locale/lang/zh-cn'
|
2026-05-06 22:23:42 +08:00
|
|
|
|
feat: refactor monolithic App.vue into modular Vue component architecture
- Extract 711-line App.vue into 15+ focused files across 5 directories
- Add data layer (icons, metrics, policies, auditTrail, requests)
- Add composables (useNavigation, useRequests, useChat, useToast)
- Add layout components (SidebarRail, TopBar, FilterBar)
- Add shared components (PanelHead, InfoRow, ToastNotification)
- Add business component (RequestTable) and 5 view components
- Extract global CSS to assets/styles/global.css
- Add start.sh with WSL/Windows cross-platform support
- Add .gitignore for node_modules, dist, and IDE dirs
2026-04-28 17:20:52 +08:00
|
|
|
import './assets/styles/global.css'
|
|
|
|
|
|
|
|
|
|
import ToastNotification from './components/shared/ToastNotification.vue'
|
2026-05-06 22:23:42 +08:00
|
|
|
import { useToast } from './composables/useToast.js'
|
2026-05-06 11:00:38 +08:00
|
|
|
|
2026-05-06 22:23:42 +08:00
|
|
|
const { toastText } = useToast()
|
2026-05-12 15:15:43 +00:00
|
|
|
|
|
|
|
|
const DESKTOP_BASE_WIDTH = 1600
|
|
|
|
|
const DESKTOP_BASE_HEIGHT = 920
|
|
|
|
|
const DESKTOP_MIN_SCALE = 0.82
|
|
|
|
|
|
|
|
|
|
const viewportWidth = ref(typeof window === 'undefined' ? DESKTOP_BASE_WIDTH : window.innerWidth)
|
|
|
|
|
const viewportHeight = ref(typeof window === 'undefined' ? DESKTOP_BASE_HEIGHT : window.innerHeight)
|
|
|
|
|
|
|
|
|
|
const desktopScaleStyle = computed(() => {
|
2026-05-12 15:39:00 +00:00
|
|
|
const metrics = resolveDesktopMetrics(viewportWidth.value, viewportHeight.value)
|
2026-05-12 15:15:43 +00:00
|
|
|
|
|
|
|
|
return {
|
2026-05-12 15:39:00 +00:00
|
|
|
'--desktop-ui-scale': metrics.scale.toFixed(4),
|
|
|
|
|
'--desktop-ui-inverse-scale': metrics.inverseScale.toFixed(4),
|
|
|
|
|
'--desktop-stage-width': `${metrics.stageWidth}px`,
|
|
|
|
|
'--desktop-stage-height': `${metrics.stageHeight}px`
|
2026-05-12 15:15:43 +00:00
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
|
2026-05-12 15:39:00 +00:00
|
|
|
const desktopMetrics = computed(() => resolveDesktopMetrics(viewportWidth.value, viewportHeight.value))
|
|
|
|
|
|
|
|
|
|
function resolveDesktopMetrics(width, height) {
|
2026-05-12 15:15:43 +00:00
|
|
|
if (width < 960) {
|
2026-05-12 15:39:00 +00:00
|
|
|
return {
|
|
|
|
|
scale: 1,
|
|
|
|
|
inverseScale: 1,
|
|
|
|
|
stageWidth: width,
|
|
|
|
|
stageHeight: height,
|
|
|
|
|
viewportWidth: width,
|
|
|
|
|
viewportHeight: height
|
|
|
|
|
}
|
2026-05-12 15:15:43 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const scaleByWidth = width / DESKTOP_BASE_WIDTH
|
|
|
|
|
const scaleByHeight = height / DESKTOP_BASE_HEIGHT
|
2026-05-12 15:39:00 +00:00
|
|
|
const scale = Number(Math.min(1, Math.max(DESKTOP_MIN_SCALE, Math.min(scaleByWidth, scaleByHeight))).toFixed(4))
|
|
|
|
|
const inverseScale = Number((1 / scale).toFixed(4))
|
|
|
|
|
|
|
|
|
|
return {
|
|
|
|
|
scale,
|
|
|
|
|
inverseScale,
|
|
|
|
|
stageWidth: Math.round(width * inverseScale),
|
|
|
|
|
stageHeight: Math.round(height * inverseScale),
|
|
|
|
|
viewportWidth: width,
|
|
|
|
|
viewportHeight: height
|
|
|
|
|
}
|
|
|
|
|
}
|
2026-05-12 15:15:43 +00:00
|
|
|
|
2026-05-12 15:39:00 +00:00
|
|
|
function syncRootDesktopVars(metrics) {
|
|
|
|
|
if (typeof document === 'undefined') {
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const rootStyle = document.documentElement.style
|
|
|
|
|
rootStyle.setProperty('--desktop-ui-scale', metrics.scale.toFixed(4))
|
|
|
|
|
rootStyle.setProperty('--desktop-ui-inverse-scale', metrics.inverseScale.toFixed(4))
|
|
|
|
|
rootStyle.setProperty('--desktop-stage-width', `${metrics.stageWidth}px`)
|
|
|
|
|
rootStyle.setProperty('--desktop-stage-height', `${metrics.stageHeight}px`)
|
|
|
|
|
rootStyle.setProperty('--desktop-viewport-width', String(metrics.viewportWidth))
|
|
|
|
|
rootStyle.setProperty('--desktop-viewport-height', String(metrics.viewportHeight))
|
2026-05-12 15:15:43 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function updateViewport() {
|
|
|
|
|
viewportWidth.value = window.innerWidth
|
|
|
|
|
viewportHeight.value = window.innerHeight
|
|
|
|
|
}
|
|
|
|
|
|
2026-05-12 15:39:00 +00:00
|
|
|
watch(
|
|
|
|
|
desktopMetrics,
|
|
|
|
|
(metrics) => {
|
|
|
|
|
syncRootDesktopVars(metrics)
|
|
|
|
|
},
|
|
|
|
|
{ immediate: true }
|
|
|
|
|
)
|
|
|
|
|
|
2026-05-12 15:15:43 +00:00
|
|
|
onMounted(() => {
|
|
|
|
|
updateViewport()
|
|
|
|
|
window.addEventListener('resize', updateViewport, { passive: true })
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
onBeforeUnmount(() => {
|
|
|
|
|
window.removeEventListener('resize', updateViewport)
|
|
|
|
|
})
|
feat: refactor monolithic App.vue into modular Vue component architecture
- Extract 711-line App.vue into 15+ focused files across 5 directories
- Add data layer (icons, metrics, policies, auditTrail, requests)
- Add composables (useNavigation, useRequests, useChat, useToast)
- Add layout components (SidebarRail, TopBar, FilterBar)
- Add shared components (PanelHead, InfoRow, ToastNotification)
- Add business component (RequestTable) and 5 view components
- Extract global CSS to assets/styles/global.css
- Add start.sh with WSL/Windows cross-platform support
- Add .gitignore for node_modules, dist, and IDE dirs
2026-04-28 17:20:52 +08:00
|
|
|
</script>
|
|
|
|
|
|
2026-05-06 22:23:42 +08:00
|
|
|
<style src="./assets/styles/app.css"></style>
|