| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180 |
- /**
- * 项目列表数据测试脚本
- *
- * 用途:在浏览器控制台中运行,测试Parse Server项目数据查询
- *
- * 使用方法:
- * 1. 打开浏览器开发者工具(F12)
- * 2. 切换到Console标签
- * 3. 复制并粘贴此脚本
- * 4. 按回车运行
- */
- (async function testProjectListData() {
- console.log('🔍 开始测试项目列表数据加载...\n');
-
- // 1. 检查localStorage中的公司ID
- const companyId = localStorage.getItem('company');
- console.log('📊 步骤1: 检查公司ID');
- console.log(' 公司ID:', companyId || '❌ 未找到');
-
- if (!companyId) {
- console.error('❌ 错误: localStorage中没有company字段');
- console.log('💡 解决方法: 请先登录或手动设置公司ID');
- console.log(' 示例: localStorage.setItem("company", "your-company-id")');
- return;
- }
-
- // 2. 检查Parse是否可用
- console.log('\n📊 步骤2: 检查Parse SDK');
- if (typeof Parse === 'undefined') {
- console.error('❌ 错误: Parse SDK未加载');
- console.log('💡 解决方法: 请确保在项目页面中运行此脚本');
- return;
- }
- console.log(' ✅ Parse SDK已加载');
-
- // 3. 查询项目数据
- console.log('\n📊 步骤3: 查询项目数据');
- try {
- const ProjectQuery = new Parse.Query('Project');
-
- // 设置查询条件
- ProjectQuery.equalTo('company', {
- __type: 'Pointer',
- className: 'Company',
- objectId: companyId
- });
- ProjectQuery.notEqualTo('isDeleted', true);
- ProjectQuery.include('contact', 'assignee', 'owner');
- ProjectQuery.descending('updatedAt');
- ProjectQuery.limit(100);
-
- console.log(' 查询条件:');
- console.log(' - company:', companyId);
- console.log(' - isDeleted: != true');
- console.log(' - include: contact, assignee, owner');
- console.log(' - limit: 100');
- console.log(' 正在查询...');
-
- const projects = await ProjectQuery.find();
-
- console.log(`\n✅ 查询成功! 找到 ${projects.length} 个项目\n`);
-
- if (projects.length === 0) {
- console.warn('⚠️ 数据库中没有符合条件的项目');
- console.log('💡 可能的原因:');
- console.log(' 1. Project表中没有数据');
- console.log(' 2. 项目的company字段不匹配当前公司ID');
- console.log(' 3. 所有项目的isDeleted字段都为true');
- return;
- }
-
- // 4. 分析项目数据
- console.log('📊 步骤4: 分析项目数据\n');
-
- const statusCount = {};
- const stageCount = {};
- const assignedCount = { assigned: 0, unassigned: 0 };
-
- projects.forEach(project => {
- // 统计状态
- const status = project.get('status') || '未知';
- statusCount[status] = (statusCount[status] || 0) + 1;
-
- // 统计阶段
- const stage = project.get('currentStage') || '未知';
- stageCount[stage] = (stageCount[stage] || 0) + 1;
-
- // 统计分配情况
- const assignee = project.get('assignee');
- if (assignee && assignee.id) {
- assignedCount.assigned++;
- } else {
- assignedCount.unassigned++;
- }
- });
-
- console.log('📈 项目状态分布:');
- Object.entries(statusCount).forEach(([status, count]) => {
- console.log(` ${status}: ${count}个`);
- });
-
- console.log('\n📈 项目阶段分布:');
- Object.entries(stageCount).forEach(([stage, count]) => {
- console.log(` ${stage}: ${count}个`);
- });
-
- console.log('\n📈 分配情况:');
- console.log(` 已分配: ${assignedCount.assigned}个`);
- console.log(` 未分配: ${assignedCount.unassigned}个`);
-
- // 5. 显示前3个项目的详细信息
- console.log('\n📋 前3个项目详情:\n');
- projects.slice(0, 3).forEach((project, index) => {
- const contact = project.get('contact');
- const assignee = project.get('assignee');
-
- console.log(`${index + 1}. ${project.get('title') || '未命名项目'}`);
- console.log(` ID: ${project.id}`);
- console.log(` 客户: ${contact?.get('name') || '未知'}`);
- console.log(` 负责人: ${assignee?.get('name') || '未分配'}`);
- console.log(` 状态: ${project.get('status') || '未知'}`);
- console.log(` 阶段: ${project.get('currentStage') || '未知'}`);
- console.log(` 更新时间: ${project.get('updatedAt')?.toLocaleString() || '未知'}`);
- console.log('');
- });
-
- // 6. 看板分组预览
- console.log('📊 看板分组预览:\n');
-
- const orderAssignment = projects.filter(p => {
- const assignee = p.get('assignee');
- return !assignee || !assignee.id || p.get('currentStage') === '订单分配';
- });
-
- const requirements = projects.filter(p => {
- const stage = p.get('currentStage');
- const status = p.get('status');
- const assignee = p.get('assignee');
- const isAftercare = status === '已完成' || ['投诉处理', '客户评价'].includes(stage);
- const isOrder = !assignee || !assignee.id || stage === '订单分配';
- return !isAftercare && !isOrder && ['需求沟通', '方案确认'].includes(stage);
- });
-
- const delivery = projects.filter(p => {
- const stage = p.get('currentStage');
- const status = p.get('status');
- const assignee = p.get('assignee');
- const isAftercare = status === '已完成' || ['投诉处理', '客户评价'].includes(stage);
- const isOrder = !assignee || !assignee.id || stage === '订单分配';
- return !isAftercare && !isOrder && ['建模', '软装', '渲染', '后期', '尾款结算'].includes(stage);
- });
-
- const aftercare = projects.filter(p => {
- const stage = p.get('currentStage');
- const status = p.get('status');
- return status === '已完成' || ['投诉处理', '客户评价'].includes(stage);
- });
-
- console.log(` 订单分配: ${orderAssignment.length}个项目`);
- console.log(` 确认需求: ${requirements.length}个项目`);
- console.log(` 交付执行: ${delivery.length}个项目`);
- console.log(` 售后: ${aftercare.length}个项目`);
-
- console.log('\n✅ 测试完成! 数据加载正常\n');
- console.log('💡 提示: 如果页面上没有显示数据,请检查:');
- console.log(' 1. 浏览器控制台是否有错误信息');
- console.log(' 2. 网络请求是否成功(Network标签)');
- console.log(' 3. 页面是否正确初始化(刷新页面试试)');
-
- } catch (error) {
- console.error('❌ 查询失败:', error);
- console.log('\n💡 可能的原因:');
- console.log(' 1. Parse Server连接失败');
- console.log(' 2. 权限不足');
- console.log(' 3. 查询语法错误');
- console.log('\n详细错误信息:', error.message);
- }
- })();
|