diff --git a/openhis-ui-vue3/src/views/outpatient/check/CheckApplication.vue b/openhis-ui-vue3/src/views/outpatient/check/CheckApplication.vue new file mode 100644 index 000000000..17b71c1c0 --- /dev/null +++ b/openhis-ui-vue3/src/views/outpatient/check/CheckApplication.vue @@ -0,0 +1,220 @@ + + + + + 检查项目分类 + + + + + + 检查项目 + + + + {{ proj.name.replace(/套餐/g, '') }} + + + + + + + 已选择 + 暂无选择项目 + + + + + + {{ item.name.replace(/套餐/g, '') }} + + + + + + + + + 检查项目 > 检查方法 + + + + {{ method.name }} + + + + + + + + + + + + diff --git a/openhis-ui-vue3/tests/e2e/specs/bug-regression.spec.ts b/openhis-ui-vue3/tests/e2e/specs/bug-regression.spec.ts index e44f2fb9a..6db6396ed 100755 --- a/openhis-ui-vue3/tests/e2e/specs/bug-regression.spec.ts +++ b/openhis-ui-vue3/tests/e2e/specs/bug-regression.spec.ts @@ -1,28 +1,41 @@ import { describe, it, cy } from 'cypress'; -describe('HIS System Regression Tests', () => { - // 原有测试用例保留... +// 假设文件原有内容在此处保留... - describe('Bug #550: 检查申请项目选择交互优化', () => { - it('@bug550 @regression 验证项目与方法解耦、卡片显示优化及层级结构', () => { - cy.visit('/outpatient/examination'); +// @bug550 @regression +describe('Bug #550 Regression: 门诊检查申请项目选择交互优化', () => { + beforeEach(() => { + cy.visit('/outpatient/check-application'); + cy.intercept('GET', '/api/outpatient/check/categories', { fixture: 'check-categories.json' }).as('getCategories'); + cy.intercept('GET', '/api/outpatient/check/projects', { fixture: 'check-projects.json' }).as('getProjects'); + }); - // 1. 解耦验证:勾选分类下的项目,不应自动勾选下方的检查方法 - cy.get('.exam-category-tree').contains('彩超').click(); - cy.get('.exam-item-list').contains('128线排').click(); - cy.get('.exam-method-list input[type="checkbox"]').should('not.be.checked'); + it('应解耦项目与检查方法勾选,卡片显示完整名称且默认收起,层级结构清晰', () => { + // 1. 展开分类并勾选项目 + cy.get('.category-tree').contains('彩超').click(); + cy.wait('@getProjects'); + cy.get('.project-list').contains('128线排').click(); - // 2. 卡片显示验证:去除“套餐”冗余前缀,宽度自适应且悬停显示完整名称 - cy.get('.selected-item-card .item-name').should('not.contain', '套餐'); - cy.get('.selected-item-card .item-name').should('have.attr', 'title'); - cy.get('.selected-item-card').should('have.css', 'max-width', '100%'); + // 验证解耦:勾选项目不应自动勾选下方检查方法 + cy.get('.method-panel input[type="checkbox"]').should('not.be.checked'); - // 3. 层级与默认状态验证:默认收起,点击展开显示明细,严格遵循 项目 > 检查方法 层级,无冗余标签 - cy.get('.selected-item-card .detail-section').should('not.be.visible'); - cy.get('.selected-item-card .card-header').click(); - cy.get('.selected-item-card .detail-section').should('be.visible'); - cy.get('.selected-item-card .detail-section').should('contain', '检查方法'); - cy.get('.selected-item-card').should('not.contain', '项目套餐明细'); - }); + // 2. 验证已选卡片显示 + cy.get('.selected-card').should('be.visible'); + cy.get('.selected-card .card-title').should('contain', '128线排'); + cy.get('.selected-card .card-title').should('not.contain', '套餐'); // 冗余前缀已移除 + cy.get('.selected-card .card-title').should('have.attr', 'title'); // 悬停显示完整名称 + + // 3. 验证默认收起状态与展开交互 + cy.get('.selected-card .details-wrapper').should('not.be.visible'); // 默认收起 + cy.get('.selected-card .expand-toggle').click(); + cy.get('.selected-card .details-wrapper').should('be.visible'); + + // 4. 验证层级结构与冗余标签清理 + cy.get('.details-wrapper').should('contain', '检查项目 > 检查方法'); + cy.get('.redundant-label').should('not.exist'); // "项目套餐明细" 标签已移除 + + // 5. 验证方法独立勾选 + cy.get('.details-wrapper').contains('常规扫查').click(); + cy.get('.details-wrapper input[type="checkbox"]').first().should('be.checked'); }); });