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>
This commit is contained in:
@@ -2,7 +2,7 @@ import { chromium } from 'playwright';
|
||||
|
||||
(async () => {
|
||||
const browser = await chromium.launch({
|
||||
headless: false // 有头模式,方便观察
|
||||
headless: false, // 有头模式,方便观察
|
||||
});
|
||||
const context = await browser.newContext();
|
||||
const page = await context.newPage();
|
||||
@@ -14,9 +14,9 @@ import { chromium } from 'playwright';
|
||||
console.log('1. 访问系统...');
|
||||
await page.goto('http://localhost:5666/', {
|
||||
waitUntil: 'networkidle',
|
||||
timeout: 30000
|
||||
timeout: 30_000,
|
||||
});
|
||||
|
||||
|
||||
// 如果在登录页,执行登录
|
||||
if (page.url().includes('/auth/login')) {
|
||||
console.log(' - 需要登录,执行登录...');
|
||||
@@ -26,42 +26,44 @@ import { chromium } from 'playwright';
|
||||
await page.keyboard.press('Enter');
|
||||
await page.waitForTimeout(2000);
|
||||
}
|
||||
|
||||
|
||||
// 访问交易管理页面
|
||||
console.log(' - 访问交易管理页面...');
|
||||
await page.goto('http://localhost:5666/finance/transaction', {
|
||||
waitUntil: 'networkidle',
|
||||
timeout: 30000
|
||||
timeout: 30_000,
|
||||
});
|
||||
|
||||
|
||||
await page.waitForTimeout(2000);
|
||||
|
||||
|
||||
// 点击新建按钮
|
||||
console.log('2. 点击新建交易按钮...');
|
||||
const createButton = page.locator('button', { hasText: '新建交易' });
|
||||
await createButton.waitFor({ state: 'visible', timeout: 5000 });
|
||||
await createButton.click();
|
||||
await page.waitForTimeout(1000);
|
||||
|
||||
|
||||
// 检查弹窗是否打开
|
||||
const modalVisible = await page.locator('.ant-modal').isVisible();
|
||||
console.log(` - 弹窗已打开: ${modalVisible ? '是' : '否'}`);
|
||||
|
||||
|
||||
// 检查金额输入框是否聚焦
|
||||
const amountInput = page.locator('.transaction-amount-input input');
|
||||
const isFocused = await amountInput.evaluate(el => el === document.activeElement);
|
||||
const isFocused = await amountInput.evaluate(
|
||||
(el) => el === document.activeElement,
|
||||
);
|
||||
console.log(` - 金额输入框自动聚焦: ${isFocused ? '是' : '否'}`);
|
||||
|
||||
|
||||
// 测试快速创建分类
|
||||
console.log('\n3. 测试快速创建分类功能...');
|
||||
const plusButton = page.locator('button[title="快速创建分类"]');
|
||||
await plusButton.click();
|
||||
await page.waitForTimeout(500);
|
||||
|
||||
|
||||
const quickInput = page.locator('input[placeholder="输入新分类名称"]');
|
||||
const quickInputVisible = await quickInput.isVisible();
|
||||
console.log(` - 快速创建输入框显示: ${quickInputVisible ? '是' : '否'}`);
|
||||
|
||||
|
||||
// 测试金额格式化
|
||||
console.log('\n4. 测试金额输入格式化...');
|
||||
await amountInput.fill('12345.67');
|
||||
@@ -69,32 +71,32 @@ import { chromium } from 'playwright';
|
||||
const formattedValue = await amountInput.inputValue();
|
||||
console.log(` - 输入: 12345.67`);
|
||||
console.log(` - 显示: ${formattedValue}`);
|
||||
|
||||
|
||||
// 测试表单布局
|
||||
console.log('\n5. 检查表单布局优化...');
|
||||
const formItems = await page.locator('.ant-form-item').count();
|
||||
console.log(` - 表单项数量: ${formItems}`);
|
||||
|
||||
|
||||
const rowsCount = await page.locator('.ant-row').count();
|
||||
console.log(` - 使用行布局数量: ${rowsCount} (优化后应该更多)`);
|
||||
|
||||
|
||||
// 测试快捷键
|
||||
console.log('\n6. 测试快捷键功能...');
|
||||
await page.keyboard.press('Escape');
|
||||
await page.waitForTimeout(500);
|
||||
|
||||
|
||||
const modalClosed = !(await page.locator('.ant-modal').isVisible());
|
||||
console.log(` - ESC关闭弹窗: ${modalClosed ? '成功' : '失败'}`);
|
||||
|
||||
|
||||
// 测试 Ctrl+N 快捷键
|
||||
await page.keyboard.press('Control+N');
|
||||
await page.waitForTimeout(500);
|
||||
|
||||
|
||||
const modalReopened = await page.locator('.ant-modal').isVisible();
|
||||
console.log(` - Ctrl+N 打开新建: ${modalReopened ? '成功' : '失败'}`);
|
||||
|
||||
|
||||
console.log('\n测试完成!新建交易功能已优化。');
|
||||
|
||||
|
||||
console.log('\n主要改进:');
|
||||
console.log(' ✓ 自动聚焦到金额输入框');
|
||||
console.log(' ✓ 快速创建分类功能');
|
||||
@@ -102,13 +104,12 @@ import { chromium } from 'playwright';
|
||||
console.log(' ✓ 优化的表单布局');
|
||||
console.log(' ✓ 快捷键支持');
|
||||
console.log(' ✓ 最近使用记录自动完成');
|
||||
|
||||
} catch (error) {
|
||||
console.error('测试失败:', error);
|
||||
}
|
||||
|
||||
|
||||
// 保持浏览器打开15秒供查看
|
||||
console.log('\n浏览器将在15秒后关闭...');
|
||||
await page.waitForTimeout(15000);
|
||||
await page.waitForTimeout(15_000);
|
||||
await browser.close();
|
||||
})();
|
||||
})();
|
||||
|
||||
Reference in New Issue
Block a user