| 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);
 
-   }
 
- })();
 
 
  |