Files
kt-financial-system/test-expand-menu.js
你的用户名 675fe0a1a8 feat: 增强财务管理系统功能与分析能力
主要更新:
- 🎯 新增综合分析仪表板,包含关键指标卡片、预算对比、智能洞察等组件
- 📊 增强数据可视化能力,新增标签云分析、时间维度分析等图表
- 📱 优化移动端响应式设计,改进触控交互体验
- 🔧 新增多个API模块(base、budget、tag),完善数据管理
- 🗂️ 重构路由结构,新增贷款、快速添加、设置、统计等独立模块
- 🔄 优化数据导入导出功能,增强数据迁移能力
- 🐛 修复多个已知问题,提升系统稳定性

技术改进:
- 使用IndexedDB提升本地存储性能
- 实现模拟API服务,支持离线开发
- 增加自动化测试脚本,确保功能稳定
- 优化打包配置,提升构建效率

文件变更:
- 新增42个文件
- 修改55个文件
- 包含测试脚本、配置文件、组件和API模块

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-08-24 16:41:58 +08:00

103 lines
3.5 KiB
JavaScript

import { chromium } from 'playwright';
(async () => {
const browser = await chromium.launch({ headless: false });
const page = await browser.newPage();
try {
console.log('1. 访问系统...');
await page.goto('http://localhost:5670');
await page.waitForTimeout(3000);
// 如果需要登录
if (page.url().includes('login')) {
console.log('2. 登录...');
const usernameInput = await page.locator('input[type="text"]').first();
const passwordInput = await page.locator('input[type="password"]').first();
const loginButton = await page.locator('button[type="submit"]').first();
await usernameInput.fill('admin');
await passwordInput.fill('111111');
await loginButton.click();
await page.waitForTimeout(5000);
}
console.log('3. 展开侧边栏...');
// 点击汉堡菜单图标展开侧边栏
const menuToggle = await page.locator('[class*="menu-toggle"], [class*="sider-trigger"], .ant-layout-sider-trigger, [aria-label*="menu"]').first();
if (await menuToggle.count() > 0) {
await menuToggle.click();
console.log(' 已点击展开按钮');
await page.waitForTimeout(2000);
}
// 再次尝试其他可能的展开按钮
const possibleTriggers = [
'button:has-text("☰")',
'button[class*="hamburger"]',
'[class*="collapsed"] button',
'.ant-layout-sider-collapsed + .ant-layout-sider-trigger',
'.vben-layout-header__menu-toggle'
];
for (const selector of possibleTriggers) {
const trigger = await page.locator(selector).first();
if (await trigger.count() > 0 && await trigger.isVisible()) {
console.log(` 找到展开按钮: ${selector}`);
await trigger.click();
await page.waitForTimeout(2000);
break;
}
}
console.log('4. 获取展开后的菜单...');
// 获取所有菜单项文本
const menuTexts = await page.locator('.ant-menu-title-content, [class*="menu-item"] span').allTextContents();
console.log('\n当前菜单项:');
console.log('===========');
menuTexts.forEach((text, i) => {
if (text.trim()) {
console.log(`${i+1}. ${text}`);
}
});
// 尝试获取带图标的菜单项
const menuItems = await page.locator('.ant-menu-item, .ant-menu-submenu').evaluateAll(items => {
return items.map(item => {
const text = item.textContent?.trim() || '';
const icon = item.querySelector('[class*="icon"]');
const hasIcon = !!icon;
return { text, hasIcon };
}).filter(item => item.text);
});
console.log('\n菜单详情:');
console.log('=========');
menuItems.forEach((item, i) => {
console.log(`${i+1}. ${item.text} ${item.hasIcon ? '[有图标]' : ''}`);
});
// 检查特定菜单
const targetMenus = ['记一笔', '交易记录', '统计分析', '设置', '贷款管理', '系统工具'];
console.log('\n目标菜单检查:');
console.log('============');
for (const menu of targetMenus) {
const found = menuTexts.some(text => text.includes(menu)) ||
menuItems.some(item => item.text.includes(menu));
console.log(`${found ? '✅' : '❌'} ${menu}`);
}
// 截图
await page.screenshot({ path: 'expanded-menu.png', fullPage: true });
console.log('\n截图保存: expanded-menu.png');
} catch (error) {
console.error('错误:', error.message);
} finally {
await page.waitForTimeout(3000);
await browser.close();
}
})();