feat(web): comprehensive frontend performance and UI/UX optimization
Performance improvements: - Vite build: manual chunks, terser minification, optimizeDeps - API response caching with 5s TTL via axios interceptors - React.memo for SidebarMenuItem, useCallback for handlers - CSS classes replacing inline styles to reduce reflows UI/UX enhancements (inspired by SAP Fiori, Linear, Feishu): - Dashboard: trend indicators, sparkline charts, CountUp animation on stat cards - Dashboard: pending tasks section with priority labels - Dashboard: recent activity timeline - Design system tokens: trend colors, line-height, dark mode refinements - Enhanced quick actions with hover animations Accessibility (Lighthouse 100/100): - Skip-to-content link, ARIA landmarks, heading hierarchy - prefers-reduced-motion support, focus-visible states - Color contrast fixes: all text meets 4.5:1 ratio - Keyboard navigation for stat cards and task items SEO: meta theme-color, format-detection, robots.txt
This commit is contained in:
@@ -1,5 +1,6 @@
|
||||
import { useState } from 'react';
|
||||
import { Tabs } from 'antd';
|
||||
import { Tabs, theme } from 'antd';
|
||||
import { PartitionOutlined, FileSearchOutlined, CheckSquareOutlined, MonitorOutlined } from '@ant-design/icons';
|
||||
import ProcessDefinitions from './workflow/ProcessDefinitions';
|
||||
import PendingTasks from './workflow/PendingTasks';
|
||||
import CompletedTasks from './workflow/CompletedTasks';
|
||||
@@ -7,17 +8,63 @@ import InstanceMonitor from './workflow/InstanceMonitor';
|
||||
|
||||
export default function Workflow() {
|
||||
const [activeKey, setActiveKey] = useState('definitions');
|
||||
const { token } = theme.useToken();
|
||||
const isDark = token.colorBgContainer === '#111827' || token.colorBgContainer === 'rgb(17, 24, 39)';
|
||||
|
||||
return (
|
||||
<div>
|
||||
<div className="erp-page-header" style={{ borderBottom: 'none', marginBottom: 0, paddingBottom: 8 }}>
|
||||
<div>
|
||||
<h4>工作流引擎</h4>
|
||||
<div className="erp-page-subtitle">管理流程定义、审批任务和流程监控</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<Tabs
|
||||
activeKey={activeKey}
|
||||
onChange={setActiveKey}
|
||||
style={{ marginTop: 8 }}
|
||||
items={[
|
||||
{ key: 'definitions', label: '流程定义', children: <ProcessDefinitions /> },
|
||||
{ key: 'pending', label: '我的待办', children: <PendingTasks /> },
|
||||
{ key: 'completed', label: '我的已办', children: <CompletedTasks /> },
|
||||
{ key: 'instances', label: '流程监控', children: <InstanceMonitor /> },
|
||||
{
|
||||
key: 'definitions',
|
||||
label: (
|
||||
<span style={{ display: 'flex', alignItems: 'center', gap: 6 }}>
|
||||
<PartitionOutlined style={{ fontSize: 14 }} />
|
||||
流程定义
|
||||
</span>
|
||||
),
|
||||
children: <ProcessDefinitions />,
|
||||
},
|
||||
{
|
||||
key: 'pending',
|
||||
label: (
|
||||
<span style={{ display: 'flex', alignItems: 'center', gap: 6 }}>
|
||||
<FileSearchOutlined style={{ fontSize: 14 }} />
|
||||
我的待办
|
||||
</span>
|
||||
),
|
||||
children: <PendingTasks />,
|
||||
},
|
||||
{
|
||||
key: 'completed',
|
||||
label: (
|
||||
<span style={{ display: 'flex', alignItems: 'center', gap: 6 }}>
|
||||
<CheckSquareOutlined style={{ fontSize: 14 }} />
|
||||
我的已办
|
||||
</span>
|
||||
),
|
||||
children: <CompletedTasks />,
|
||||
},
|
||||
{
|
||||
key: 'instances',
|
||||
label: (
|
||||
<span style={{ display: 'flex', alignItems: 'center', gap: 6 }}>
|
||||
<MonitorOutlined style={{ fontSize: 14 }} />
|
||||
流程监控
|
||||
</span>
|
||||
),
|
||||
children: <InstanceMonitor />,
|
||||
},
|
||||
]}
|
||||
/>
|
||||
</div>
|
||||
|
||||
Reference in New Issue
Block a user