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-04-29 23:35:56 +08:00
|
|
|
<!-- Login Page -->
|
2026-04-30 17:11:24 +08:00
|
|
|
<LoginView
|
|
|
|
|
v-if="!loggedIn"
|
|
|
|
|
@login="handleLogin"
|
|
|
|
|
@recover-password="handleRecoverPassword"
|
|
|
|
|
@sso-login="handleSsoLogin"
|
|
|
|
|
/>
|
2026-04-29 23:35:56 +08:00
|
|
|
|
|
|
|
|
<!-- Main App -->
|
|
|
|
|
<div v-else class="app">
|
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
|
|
|
<SidebarRail
|
|
|
|
|
:nav-items="navItems"
|
|
|
|
|
:active-view="activeView"
|
2026-04-30 17:11:24 +08:00
|
|
|
@navigate="handleNavigate"
|
|
|
|
|
@open-chat="handleOpenChat"
|
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
|
|
|
/>
|
|
|
|
|
|
2026-04-30 17:11:24 +08:00
|
|
|
<main
|
|
|
|
|
class="main"
|
|
|
|
|
:class="{
|
|
|
|
|
'chat-main': activeView === 'chat',
|
|
|
|
|
'overview-main': activeView === 'overview',
|
2026-05-05 18:22:47 +08:00
|
|
|
'workbench-main': activeView === 'workbench',
|
2026-05-01 00:39:24 +08:00
|
|
|
'requests-main': activeView === 'requests',
|
|
|
|
|
'approval-main': activeView === 'approval',
|
2026-05-05 22:35:38 +08:00
|
|
|
'policies-main': activeView === 'policies',
|
2026-05-06 11:00:38 +08:00
|
|
|
'audit-main': activeView === 'audit',
|
|
|
|
|
'employees-main': activeView === 'employees'
|
2026-04-30 17:11:24 +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
|
|
|
<TopBar
|
2026-04-30 17:11:24 +08:00
|
|
|
:current-view="topBarView"
|
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
|
|
|
:search="search"
|
2026-04-29 23:35:56 +08:00
|
|
|
:active-view="activeView"
|
2026-04-30 17:11:24 +08:00
|
|
|
:ranges="ranges"
|
|
|
|
|
:active-range="activeRange"
|
|
|
|
|
:custom-range="customRange"
|
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
|
|
|
@update:search="search = $event"
|
2026-04-30 17:11:24 +08:00
|
|
|
@update:active-range="activeRange = $event"
|
|
|
|
|
@update:custom-range="customRange = $event"
|
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
|
|
|
@batch-approve="toast('已筛出 23 个低风险单据,可进入批量通过确认。')"
|
2026-04-30 17:11:24 +08:00
|
|
|
@open-chat="handleOpenChat"
|
|
|
|
|
@new-application="openTravelCreate"
|
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
|
|
|
/>
|
|
|
|
|
|
|
|
|
|
<FilterBar
|
2026-05-06 11:00:38 +08:00
|
|
|
v-if="activeView !== 'chat' && activeView !== 'overview' && activeView !== 'workbench' && activeView !== 'requests' && activeView !== 'approval' && activeView !== 'policies' && activeView !== 'audit' && activeView !== 'employees'"
|
2026-04-29 23:35:56 +08:00
|
|
|
:compact="activeView === 'overview'"
|
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
|
|
|
:filters="filters"
|
|
|
|
|
:ranges="ranges"
|
|
|
|
|
:active-range="activeRange"
|
|
|
|
|
@update:active-range="activeRange = $event"
|
|
|
|
|
/>
|
|
|
|
|
|
2026-04-30 17:11:24 +08:00
|
|
|
<section
|
|
|
|
|
class="workarea"
|
|
|
|
|
:class="{
|
|
|
|
|
'chat-workarea': activeView === 'chat',
|
2026-05-01 00:39:24 +08:00
|
|
|
'requests-workarea': activeView === 'requests',
|
|
|
|
|
'approval-workarea': activeView === 'approval',
|
2026-05-05 22:35:38 +08:00
|
|
|
'policies-workarea': activeView === 'policies',
|
2026-05-06 11:00:38 +08:00
|
|
|
'audit-workarea': activeView === 'audit',
|
|
|
|
|
'employees-workarea': activeView === 'employees'
|
2026-04-30 17:11:24 +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
|
|
|
<OverviewView
|
|
|
|
|
v-if="activeView === 'overview'"
|
|
|
|
|
:filtered-requests="filteredRequests"
|
2026-04-30 17:11:24 +08:00
|
|
|
@ask="handleOpenChat"
|
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
|
|
|
@approve="handleApprove"
|
|
|
|
|
@reject="handleReject"
|
|
|
|
|
/>
|
|
|
|
|
|
2026-05-05 18:22:47 +08:00
|
|
|
<PersonalWorkbenchView
|
|
|
|
|
v-else-if="activeView === 'workbench'"
|
2026-05-05 23:47:20 +08:00
|
|
|
@open-assistant="openSmartEntry"
|
2026-04-30 17:11:24 +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
|
|
|
<ChatView
|
|
|
|
|
v-else-if="activeView === 'chat'"
|
2026-04-29 23:35:56 +08:00
|
|
|
:documents="filteredDocuments"
|
|
|
|
|
:doc-search="docSearch"
|
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
|
|
|
:messages="messages"
|
|
|
|
|
:uploaded-files="uploadedFiles"
|
|
|
|
|
:active-case="activeCase"
|
2026-04-29 23:35:56 +08:00
|
|
|
:quick-prompts="travelPrompts"
|
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
|
|
|
:draft="draft"
|
|
|
|
|
:message-list="messageList"
|
|
|
|
|
@send="sendMessage"
|
|
|
|
|
@upload="handleUpload"
|
|
|
|
|
@draft="draft = $event"
|
2026-04-30 17:11:24 +08:00
|
|
|
@select-case="handleOpenChat"
|
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
|
|
|
@approve-case="toast(`${activeCase?.id} 已生成通过意见。`)"
|
|
|
|
|
@reject-case="toast(`${activeCase?.id} 已转人工复核。`)"
|
|
|
|
|
/>
|
|
|
|
|
|
2026-05-05 22:35:38 +08:00
|
|
|
<TravelRequestDetailView
|
2026-05-02 11:30:25 +08:00
|
|
|
v-else-if="activeView === 'requests' && detailMode"
|
2026-05-05 22:35:38 +08:00
|
|
|
:request="selectedTravelRequest"
|
|
|
|
|
@back-to-requests="closeRequestDetail"
|
2026-05-05 23:47:20 +08:00
|
|
|
@open-assistant="openSmartEntry"
|
2026-05-02 11:30:25 +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
|
|
|
<RequestsView
|
|
|
|
|
v-else-if="activeView === 'requests'"
|
|
|
|
|
:filtered-requests="filteredRequests"
|
2026-05-05 22:35:38 +08:00
|
|
|
@ask="openRequestDetail"
|
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
|
|
|
@approve="handleApprove"
|
|
|
|
|
@reject="handleReject"
|
2026-04-30 17:11:24 +08:00
|
|
|
@create-request="openTravelCreate"
|
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
|
|
|
/>
|
|
|
|
|
|
2026-05-01 00:39:24 +08:00
|
|
|
<ApprovalCenterView v-else-if="activeView === 'approval'" />
|
|
|
|
|
|
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
|
|
|
<PoliciesView v-else-if="activeView === 'policies'" />
|
|
|
|
|
|
2026-05-06 11:00:38 +08:00
|
|
|
<AuditView v-else-if="activeView === 'audit'" />
|
|
|
|
|
|
|
|
|
|
<EmployeeManagementView v-else />
|
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
|
|
|
</section>
|
|
|
|
|
</main>
|
|
|
|
|
|
2026-05-05 23:47:20 +08:00
|
|
|
<TravelReimbursementCreateView
|
|
|
|
|
v-if="smartEntryOpen"
|
|
|
|
|
:key="smartEntrySessionId"
|
|
|
|
|
:initial-prompt="smartEntryContext.prompt"
|
|
|
|
|
:entry-source="smartEntryContext.source"
|
|
|
|
|
:request-context="smartEntryContext.request"
|
|
|
|
|
@close="closeSmartEntry"
|
|
|
|
|
/>
|
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
|
|
|
</div>
|
2026-04-30 17:11:24 +08:00
|
|
|
|
|
|
|
|
<ToastNotification :toast-text="toastText" />
|
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>
|
|
|
|
|
import './assets/styles/global.css'
|
|
|
|
|
|
|
|
|
|
import SidebarRail from './components/layout/SidebarRail.vue'
|
|
|
|
|
import TopBar from './components/layout/TopBar.vue'
|
|
|
|
|
import FilterBar from './components/layout/FilterBar.vue'
|
|
|
|
|
import ToastNotification from './components/shared/ToastNotification.vue'
|
2026-04-29 23:35:56 +08:00
|
|
|
import LoginView from './views/LoginView.vue'
|
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 OverviewView from './views/OverviewView.vue'
|
2026-05-05 18:22:47 +08:00
|
|
|
import PersonalWorkbenchView from './views/PersonalWorkbenchView.vue'
|
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 ChatView from './views/ChatView.vue'
|
2026-04-30 17:11:24 +08:00
|
|
|
import TravelReimbursementCreateView from './views/TravelReimbursementCreateView.vue'
|
2026-05-05 22:35:38 +08:00
|
|
|
import TravelRequestDetailView from './views/TravelRequestDetailView.vue'
|
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 RequestsView from './views/RequestsView.vue'
|
2026-05-01 00:39:24 +08:00
|
|
|
import ApprovalCenterView from './views/ApprovalCenterView.vue'
|
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 PoliciesView from './views/PoliciesView.vue'
|
|
|
|
|
import AuditView from './views/AuditView.vue'
|
2026-05-06 11:00:38 +08:00
|
|
|
import EmployeeManagementView from './views/EmployeeManagementView.vue'
|
|
|
|
|
|
|
|
|
|
import { useAppShell } from './composables/useAppShell.js'
|
|
|
|
|
|
|
|
|
|
const {
|
|
|
|
|
activeCase,
|
|
|
|
|
activeRange,
|
|
|
|
|
activeView,
|
|
|
|
|
closeRequestDetail,
|
|
|
|
|
closeSmartEntry,
|
|
|
|
|
customRange,
|
|
|
|
|
detailMode,
|
|
|
|
|
docSearch,
|
|
|
|
|
draft,
|
|
|
|
|
filteredDocuments,
|
|
|
|
|
filteredRequests,
|
|
|
|
|
filters,
|
|
|
|
|
handleApprove,
|
|
|
|
|
handleLogin,
|
|
|
|
|
handleNavigate,
|
|
|
|
|
handleOpenChat,
|
|
|
|
|
handleRecoverPassword,
|
|
|
|
|
handleReject,
|
|
|
|
|
handleSsoLogin,
|
|
|
|
|
handleUpload,
|
|
|
|
|
loggedIn,
|
|
|
|
|
messageList,
|
|
|
|
|
messages,
|
|
|
|
|
navItems,
|
|
|
|
|
openRequestDetail,
|
|
|
|
|
openSmartEntry,
|
|
|
|
|
openTravelCreate,
|
|
|
|
|
ranges,
|
|
|
|
|
search,
|
|
|
|
|
selectedTravelRequest,
|
|
|
|
|
sendMessage,
|
|
|
|
|
smartEntryContext,
|
|
|
|
|
smartEntryOpen,
|
|
|
|
|
smartEntrySessionId,
|
|
|
|
|
toast,
|
|
|
|
|
toastText,
|
|
|
|
|
topBarView,
|
|
|
|
|
travelPrompts,
|
|
|
|
|
uploadedFiles
|
|
|
|
|
} = useAppShell()
|
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 11:00:38 +08:00
|
|
|
<style scoped src="./assets/styles/app.css"></style>
|