diff --git a/CHANGELOG.md b/CHANGELOG.md
index fd67240877..8ab035123e 100644
--- a/CHANGELOG.md
+++ b/CHANGELOG.md
@@ -1,3 +1,10 @@
+# [101.16.0](https://github.com/dhis2/capture-app/compare/v101.15.0...v101.16.0) (2024-11-13)
+
+
+### Features
+
+* [DHIS2-18250] Breadcrumb for event & enrollment pages ([#3849](https://github.com/dhis2/capture-app/issues/3849)) ([d65882e](https://github.com/dhis2/capture-app/commit/d65882eacb711865d9f6a860c65d56a0f4d68157))
+
# [101.15.0](https://github.com/dhis2/capture-app/compare/v101.14.9...v101.15.0) (2024-11-12)
diff --git a/cypress/e2e/EnrollmentAddEventPage/EnrollmentAddEventPageForm/EnrollmentAddEventPageForm.feature b/cypress/e2e/EnrollmentAddEventPage/EnrollmentAddEventPageForm/EnrollmentAddEventPageForm.feature
index 869b837615..e74ed7c4f8 100644
--- a/cypress/e2e/EnrollmentAddEventPage/EnrollmentAddEventPageForm/EnrollmentAddEventPageForm.feature
+++ b/cypress/e2e/EnrollmentAddEventPage/EnrollmentAddEventPageForm/EnrollmentAddEventPageForm.feature
@@ -50,7 +50,7 @@ Feature: User interacts with the Enrollment New Event Workspace
Scenario: User should be asked to create new event after completing a stage and choose to cancel
Given you land on the enrollment new event page by having typed #/enrollmentEventNew?enrollmentId=zRfAPUpjoG3&orgUnitId=DiszpKrYNg8&programId=M3xtLkYBlKI&stageId=CWaAcQYKVpq&teiId=S3JjTA4QMNe
- Then you see the following Enrollment: New Event
+ Then you see the new event form
And you see the widget header Foci investigation & classification
And you type 2022-01-01 in the input number 0
And you type x in the input number 20
@@ -62,7 +62,7 @@ Feature: User interacts with the Enrollment New Event Workspace
Scenario: User should be asked to create new event after completing a stage and choose to continue
Given you land on the enrollment new event page by having typed #/enrollmentEventNew?enrollmentId=zRfAPUpjoG3&orgUnitId=DiszpKrYNg8&programId=M3xtLkYBlKI&stageId=CWaAcQYKVpq&teiId=S3JjTA4QMNe
- Then you see the following Enrollment: New Event
+ Then you see the new event form
And you see the widget header Foci investigation & classification
And you type 2022-01-01 in the input number 0
And you type x in the input number 20
@@ -74,7 +74,7 @@ Feature: User interacts with the Enrollment New Event Workspace
Scenario: User is able to schedule an event with a note
Given you land on the enrollment new event page by having typed /#/enrollmentEventNew?enrollmentId=qcFFRp7DpcX&orgUnitId=DiszpKrYNg8&programId=WSGAb5XwJ3Y&stageId=edqlbukwRfQ&teiId=erqa3phUfpI
- And you see the following Enrollment: New Event
+ And you see the new event form
And you select the schedule tab
When you add a note to the event
And the events saves successfully
diff --git a/cypress/e2e/EnrollmentAddEventPage/EnrollmentAddEventPageNavigation/EnrollmentAddEventPageNavigation.feature b/cypress/e2e/EnrollmentAddEventPage/EnrollmentAddEventPageNavigation/EnrollmentAddEventPageNavigation.feature
index 5364d08ec0..de83e45d76 100644
--- a/cypress/e2e/EnrollmentAddEventPage/EnrollmentAddEventPageNavigation/EnrollmentAddEventPageNavigation.feature
+++ b/cypress/e2e/EnrollmentAddEventPage/EnrollmentAddEventPageNavigation/EnrollmentAddEventPageNavigation.feature
@@ -1,7 +1,7 @@
Feature: User interacts with Enrollment Add event page
Scenario: The user can land on the enrollment add event page.
Given you land on the enrollment add event page by having typed /#/enrollmentEventNew?programId=IpHINAT79UW&orgUnitId=DiszpKrYNg8&teiId=tIJu6iqQxNV&enrollmentId=CCBLMntFuzb&stageId=A03MvHHogjR
- Then you see the following Enrollment: New Event
+ Then you see the new event form
And you see the widget header Birth
And you see the following Report date
And you see the add event form details
diff --git a/cypress/e2e/EnrollmentAddEventPage/sharedSteps.js b/cypress/e2e/EnrollmentAddEventPage/sharedSteps.js
index 9be509e28c..354b982afa 100644
--- a/cypress/e2e/EnrollmentAddEventPage/sharedSteps.js
+++ b/cypress/e2e/EnrollmentAddEventPage/sharedSteps.js
@@ -1,4 +1,4 @@
-import { Then, defineStep as And } from '@badeball/cypress-cucumber-preprocessor';
+import { defineStep as And, Then, When } from '@badeball/cypress-cucumber-preprocessor';
Then(/^you see the following (.*)$/, (message) => {
cy.contains(message);
@@ -12,3 +12,7 @@ And(/^you see the widget header (.*)$/, (name) => {
cy.contains(name).should('exist');
});
});
+
+When('you see the new event form', () => {
+ cy.get('[data-test="new-enrollment-event-form"]').should('exist');
+});
diff --git a/cypress/e2e/EnrollmentEditEventPage/EnrollmentEditEventPageForm/EnrollmentEditEventPageForm.feature b/cypress/e2e/EnrollmentEditEventPage/EnrollmentEditEventPageForm/EnrollmentEditEventPageForm.feature
index 594b821007..31ab0f99c8 100644
--- a/cypress/e2e/EnrollmentEditEventPage/EnrollmentEditEventPageForm/EnrollmentEditEventPageForm.feature
+++ b/cypress/e2e/EnrollmentEditEventPage/EnrollmentEditEventPageForm/EnrollmentEditEventPageForm.feature
@@ -25,12 +25,12 @@ And the user see the following text: Yes
Scenario: The user can enter and exit the edit mode.
Given you land on the enrollment event page with selected Person by having typed /#/enrollmentEventEdit?orgUnitId=DiszpKrYNg8&eventId=V1CerIi3sdL
-And the user see the following text: Enrollment: View Event
+And the view enrollment event form is in view mode
And the user see the following text: Apgar Score
When the user clicks on the edit button
-Then the user see the following text: Enrollment: Edit Event
+Then the view enrollment event form is in edit mode
When the user clicks on the cancel button
-And the user see the following text: Enrollment: View Event
+And the view enrollment event form is in view mode
Scenario: The tracker program rules are triggered correctly for the Child Program.
Given you land on the enrollment event page with selected Person by having typed /#/enrollmentEventEdit?orgUnitId=DiszpKrYNg8&eventId=V1CerIi3sdL
@@ -53,58 +53,58 @@ Then the user don't see the following text: Low-dose acetylsalicylic acid given
Scenario: User can modify and save the data in the form
Given you land on the enrollment event page with selected Person by having typed /#/enrollmentEventEdit?orgUnitId=DiszpKrYNg8&eventId=V1CerIi3sdL
-Then the user see the following text: Enrollment: View Event
+Then the view enrollment event form is in view mode
And the apgar score is 11
When the user clicks on the edit button
And the user set the apgar score to 5
And the user clicks on the save button
Then you are redirected to the enrollment dashboard
And you open the Birth stage event
-Then the user see the following text: Enrollment: View Event
+Then the view enrollment event form is in view mode
And the user see the following text: 5
When the user clicks on the edit button
And the user set the apgar score to 11
And the user clicks on the save button
Then you are redirected to the enrollment dashboard
And you open the Birth stage event
-Then the user see the following text: Enrollment: View Event
+Then the view enrollment event form is in view mode
And the user see the following text: 11
Scenario: User goes directly to Edit mode for scheduled events
Given you land on the enrollment event page with selected Person by having typed /#/enrollmentEventEdit?eventId=RIrfCcEP8Uu&orgUnitId=DiszpKrYNg8
- Then the user see the following text: Enrollment: Edit Event
+ Then the view enrollment event form is in edit mode
And the user see the following text: Infant Feeding
When the user clicks on the cancel button
- Then the user see the following text: Enrollment Dashboard
+ Then the user is navigated to the enrollment dashboard
-Scenario: User can update schedule date for a scheduled event
+Scenario: User can update schedule date for a scheduled event
Given you land on the enrollment event page with selected Person by having typed /#/enrollmentEventEdit?eventId=RIrfCcEP8Uu&orgUnitId=DiszpKrYNg8
- Then the user see the following text: Enrollment: Edit Event
+ Then the view enrollment event form is in edit mode
And the user see the following text: Infant Feeding
When the user clicks switch tab to Schedule
And the user selects another schedule date
And the user clicks on the schedule button on widget-enrollment-event
- Then the user see the following text: Enrollment Dashboard
+ Then the user is navigated to the enrollment dashboard
Scenario: User can update schedule date if Hide due date is enabled
Given you land on the enrollment event page with selected Focus area by having typed /#/enrollmentEventNew?enrollmentId=V8uPJuhvlL7&orgUnitId=DiszpKrYNg8&programId=M3xtLkYBlKI&stageId=uvMKOn1oWvd&tab=SCHEDULE&teiId=dNpxRu1mWG5
- Then the user see the following text: Enrollment: New Event
+ Then the add event form is displayed
And the user see the following text: Foci response
And the user see the schedule date and info box
And the user clicks on the schedule button on add-event-enrollment-page-content
- Then the user see the following text: Enrollment Dashboard
+ Then the user is navigated to the enrollment dashboard
Scenario: User can see disabled scheduled date for active event
Given you land on the enrollment event page with selected Person by having typed /#/enrollmentEventEdit?eventId=FV4JCI73wO2&orgUnitId=DiszpKrYNg8
- Then the user see the following text: Enrollment: View Event
+ Then the view enrollment event form is in view mode
When the user clicks on the edit button
- Then the user see the following text: Enrollment: Edit Event
+ Then the view enrollment event form is in edit mode
Then the user see the schedule date field with tooltip: Scheduled date cannot be changed for Active events
-
+
@user:trackerAutoTestRestricted
Scenario: The user cannot enter edit mode for completed events
Given you land on the enrollment event page with selected Person by having typed /#/enrollmentEventEdit?eventId=nUVwTLuQ6FT&orgUnitId=DiszpKrYNg8
- And the user see the following text: Enrollment: View Event
+ And the view enrollment event form is in view mode
Then the edit button should be disabled
Scenario: User can edit the event and complete the enrollment
@@ -113,4 +113,4 @@ Scenario: User can edit the event and complete the enrollment
And the user clicks on the edit button
And the user completes the event
And the user completes the enrollment
- Then the user sees the enrollment status and recently edited event in Case outcome event status is completed
\ No newline at end of file
+ Then the user sees the enrollment status and recently edited event in Case outcome event status is completed
diff --git a/cypress/e2e/EnrollmentEditEventPage/EnrollmentEditEventPageForm/EnrollmentEditEventPageForm.js b/cypress/e2e/EnrollmentEditEventPage/EnrollmentEditEventPageForm/EnrollmentEditEventPageForm.js
index 70468a3a93..3d94481898 100644
--- a/cypress/e2e/EnrollmentEditEventPage/EnrollmentEditEventPageForm/EnrollmentEditEventPageForm.js
+++ b/cypress/e2e/EnrollmentEditEventPage/EnrollmentEditEventPageForm/EnrollmentEditEventPageForm.js
@@ -1,4 +1,4 @@
-import { Given, When, Then, defineStep as And } from '@badeball/cypress-cucumber-preprocessor';
+import { defineStep as And, Given, Then, When } from '@badeball/cypress-cucumber-preprocessor';
import { getCurrentYear } from '../../../support/date';
const changeEnrollmentAndEventsStatus = () => (
@@ -212,3 +212,15 @@ Then('the edit button should be disabled', () => {
.eq(1)
.should('be.disabled');
});
+
+And('the add event form is displayed', () => {
+ cy.get('[data-test="add-event-enrollment-page-content"]').should('exist');
+});
+
+And('the user is navigated to the enrollment dashboard', () => {
+ cy.get('[data-test="enrollment-overview-page"]').should('exist');
+});
+
+And(/^the view enrollment event form is in (.*) mode$/, (mode) => {
+ cy.get(`[data-test="widget-enrollment-event-${mode}"]`).should('exist');
+});
diff --git a/cypress/e2e/EnrollmentEditEventPage/EnrollmentEditEventPageNavigation/EnrollmentEditEventPageNavigation.feature b/cypress/e2e/EnrollmentEditEventPage/EnrollmentEditEventPageNavigation/EnrollmentEditEventPageNavigation.feature
index 118c8e4c14..663543760e 100644
--- a/cypress/e2e/EnrollmentEditEventPage/EnrollmentEditEventPageNavigation/EnrollmentEditEventPageNavigation.feature
+++ b/cypress/e2e/EnrollmentEditEventPage/EnrollmentEditEventPageNavigation/EnrollmentEditEventPageNavigation.feature
@@ -2,18 +2,18 @@ Feature: User interacts with Enrollment event page
Scenario: The user can land on the enrollment event page.
Given you land on the enrollment event page by having typed #/enrollmentEventEdit?orgUnitId=DiszpKrYNg8&eventId=O7IACPx40nQ
- Then you see the following Enrollment: View Event
+ Then the view enrollment event form is in view mode
And you see the following Baby Postnatal
- Scenario: User can navigate back and forward between the enrollment event edit page and the enrollment page
+ Scenario: User can navigate back and forward between the enrollment event edit page and the enrollment page
Given you open the enrollment page which has multiple events and stages
- Then you see the following Enrollment Dashboard
+ Then the user is navigated to the enrollment dashboard
And the widgets are done rendering
And the program stages should be displayed
When the user clicks the first second antenatal care visit event
- Then you see the following Enrollment: View Event
+ Then the view enrollment event form is in view mode
And you see the following antenatal care visit
And you see the following No ARV medication plan
When the user clicks the "Back to all stages and events" button
- Then you see the following Enrollment Dashboard
- And the program stages should be displayed
\ No newline at end of file
+ Then the user is navigated to the enrollment dashboard
+ And the program stages should be displayed
diff --git a/cypress/e2e/EnrollmentEditEventPage/EnrollmentEditEventPageNavigation/EnrollmentEditEventPageNavigation.js b/cypress/e2e/EnrollmentEditEventPage/EnrollmentEditEventPageNavigation/EnrollmentEditEventPageNavigation.js
index 76fbb1915c..3664b4c338 100644
--- a/cypress/e2e/EnrollmentEditEventPage/EnrollmentEditEventPageNavigation/EnrollmentEditEventPageNavigation.js
+++ b/cypress/e2e/EnrollmentEditEventPage/EnrollmentEditEventPageNavigation/EnrollmentEditEventPageNavigation.js
@@ -1,4 +1,4 @@
-import { Given, When, Then, defineStep as And } from '@badeball/cypress-cucumber-preprocessor';
+import { defineStep as And, Given, Then, When } from '@badeball/cypress-cucumber-preprocessor';
Given(/^you land on the enrollment event page by having typed (.*)$/, (url) => {
cy.visit(url);
@@ -39,3 +39,11 @@ Then('the program stages should be displayed', () => {
cy.contains('Care at birth').should('exist');
});
});
+
+And('the user is navigated to the enrollment dashboard', () => {
+ cy.get('[data-test="enrollment-overview-page"]').should('exist');
+});
+
+And(/^the view enrollment event form is in (.*) mode$/, (mode) => {
+ cy.get(`[data-test="widget-enrollment-event-${mode}"]`).should('exist');
+});
diff --git a/cypress/e2e/EnrollmentPage/EnrollmentPageNavigation/EnrollmentPageNavigation.js b/cypress/e2e/EnrollmentPage/EnrollmentPageNavigation/EnrollmentPageNavigation.js
index 4d331734b9..46fe376da8 100644
--- a/cypress/e2e/EnrollmentPage/EnrollmentPageNavigation/EnrollmentPageNavigation.js
+++ b/cypress/e2e/EnrollmentPage/EnrollmentPageNavigation/EnrollmentPageNavigation.js
@@ -1,9 +1,8 @@
-import { Given, When, Then, defineStep as And } from '@badeball/cypress-cucumber-preprocessor';
+import { defineStep as And, Given, Then, When } from '@badeball/cypress-cucumber-preprocessor';
Given('you are on an enrollment page', () => {
cy.visit('/#/enrollment?programId=IpHINAT79UW&orgUnitId=UgYg0YW7ZIh&teiId=fhFQhO0xILJ&enrollmentId=gPDueU02tn8');
- cy.get('[data-test="enrollment-page-content"]')
- .contains('Enrollment Dashboard');
+ cy.get('[data-test="enrollment-overview-page"]');
});
And('you select the Inpatient morbidity program', () => {
@@ -90,8 +89,7 @@ Then(/^you should be redirect to (.*)$/, (expectedUrl) => {
Given('you land on the enrollment page by having typed only the enrollmentId in the url', () => {
cy.visit('/#/enrollment?enrollmentId=gPDueU02tn8');
- cy.get('[data-test="enrollment-page-content"]')
- .contains('Enrollment Dashboard');
+ cy.get('[data-test="enrollment-overview-page"]');
cy.contains('[data-test="scope-selector"]', 'Carlos Cruz');
cy.contains('[data-test="scope-selector"]', 'Taninahun (Malen) CHP');
cy.contains('1 event');
@@ -119,8 +117,7 @@ When('you reset the org unit selection', () => {
Then('you see the enrollment page but there is no org unit id in the url', () => {
cy.url().should('not.include', 'orgUnitId');
- cy.get('[data-test="enrollment-page-content"]')
- .contains('Enrollment Dashboard');
+ cy.get('[data-test="enrollment-overview-page"]');
});
When('you reset the enrollment selection', () => {
diff --git a/cypress/e2e/EnrollmentPage/EnrollmentQuickActions/EnrollmentQuickActions.js b/cypress/e2e/EnrollmentPage/EnrollmentQuickActions/EnrollmentQuickActions.js
index a450af97d9..ff2c76281f 100644
--- a/cypress/e2e/EnrollmentPage/EnrollmentQuickActions/EnrollmentQuickActions.js
+++ b/cypress/e2e/EnrollmentPage/EnrollmentQuickActions/EnrollmentQuickActions.js
@@ -1,4 +1,4 @@
-import { Given, When, Then } from '@badeball/cypress-cucumber-preprocessor';
+import { Given, Then, When } from '@badeball/cypress-cucumber-preprocessor';
Given(/^you open the enrollment page by typing (.*)$/, url =>
cy.visit(url),
@@ -6,14 +6,12 @@ Given(/^you open the enrollment page by typing (.*)$/, url =>
Given('you are on an enrollment page with stage available', () => {
cy.visit('/#/enrollment?programId=ur1Edk5Oe2n&orgUnitId=UgYg0YW7ZIh&teiId=zmgVvEZ91Kg&enrollmentId=xRnBV5aJDeF');
- cy.get('[data-test="enrollment-page-content"]')
- .contains('Enrollment Dashboard');
+ cy.get('[data-test="enrollment-overview-page"]');
});
Given('you are on an enrollment page with no stage available', () => {
cy.visit('/#/enrollment?programId=IpHINAT79UW&orgUnitId=UgYg0YW7ZIh&teiId=fhFQhO0xILJ&enrollmentId=gPDueU02tn8');
- cy.get('[data-test="enrollment-page-content"]')
- .contains('Enrollment Dashboard');
+ cy.get('[data-test="enrollment-overview-page"]');
});
When(/^you click the (.*) event-button/, (mode) => {
diff --git a/cypress/e2e/EnrollmentPage/sharedSteps.js b/cypress/e2e/EnrollmentPage/sharedSteps.js
index 8f8e2992ca..b21b9ec516 100644
--- a/cypress/e2e/EnrollmentPage/sharedSteps.js
+++ b/cypress/e2e/EnrollmentPage/sharedSteps.js
@@ -7,3 +7,7 @@ Given('you open the enrollment page', () => {
Given('you open the enrollment page which has multiples events and stages', () => {
cy.visit('#/enrollment?enrollmentId=ek4WWAgXX5i');
});
+
+Given('you are on the enrollment dashboard', () => {
+ cy.url().should('include', '/#/enrollment?');
+});
diff --git a/cypress/e2e/ScopeSelector/ScopeSelector.feature b/cypress/e2e/ScopeSelector/ScopeSelector.feature
index ec80a5d2b0..5a06714422 100644
--- a/cypress/e2e/ScopeSelector/ScopeSelector.feature
+++ b/cypress/e2e/ScopeSelector/ScopeSelector.feature
@@ -144,14 +144,14 @@ Feature: User uses the ScopeSelector to navigate
Examples:
| url | state | message |
- | /#/enrollment?enrollmentId=gPDueU02tn8 | all | Enrollment Dashboard |
- | /#/enrollment?teiId=fhFQhO0xILJ&enrollmentId=gPDueU02tn8 | all | Enrollment Dashboard |
- | /#/enrollment?orgUnitId=UgYg0YW7ZIh&enrollmentId=gPDueU02tn8 | all | Enrollment Dashboard |
- | /#/enrollment?orgUnitId=UgYg0YW7ZIh&teiId=fhFQhO0xILJ&enrollmentId=gPDueU02tn8 | all | Enrollment Dashboard |
- | /#/enrollment?programId=IpHINAT79UW&enrollmentId=gPDueU02tn8 | all | Enrollment Dashboard |
- | /#/enrollment?programId=IpHINAT79UW&teiId=fhFQhO0xILJ&enrollmentId=gPDueU02tn8 | all | Enrollment Dashboard |
- | /#/enrollment?programId=IpHINAT79UW&orgUnitId=UgYg0YW7ZIh&enrollmentId=gPDueU02tn8 | all | Enrollment Dashboard |
- | /#/enrollment?programId=IpHINAT79UW&orgUnitId=UgYg0YW7ZIh&teiId=fhFQhO0xILJ&enrollmentId=gPDueU02tn8 | all | Enrollment Dashboard |
+ | /#/enrollment?enrollmentId=gPDueU02tn8 | all | Enrollment dashboard |
+ | /#/enrollment?teiId=fhFQhO0xILJ&enrollmentId=gPDueU02tn8 | all | Enrollment dashboard |
+ | /#/enrollment?orgUnitId=UgYg0YW7ZIh&enrollmentId=gPDueU02tn8 | all | Enrollment dashboard |
+ | /#/enrollment?orgUnitId=UgYg0YW7ZIh&teiId=fhFQhO0xILJ&enrollmentId=gPDueU02tn8 | all | Enrollment dashboard |
+ | /#/enrollment?programId=IpHINAT79UW&enrollmentId=gPDueU02tn8 | all | Enrollment dashboard |
+ | /#/enrollment?programId=IpHINAT79UW&teiId=fhFQhO0xILJ&enrollmentId=gPDueU02tn8 | all | Enrollment dashboard |
+ | /#/enrollment?programId=IpHINAT79UW&orgUnitId=UgYg0YW7ZIh&enrollmentId=gPDueU02tn8 | all | Enrollment dashboard |
+ | /#/enrollment?programId=IpHINAT79UW&orgUnitId=UgYg0YW7ZIh&teiId=fhFQhO0xILJ&enrollmentId=gPDueU02tn8 | all | Enrollment dashboard |
| /#/enrollment?orgUnitId=UgYg0YW7ZIh&teiId=fhFQhO0xILJ | teiAndOrgUnit | Choose a program to add new or see existing enrollments for Carlos Cruz |
| /#/enrollment?programId=IpHINAT79UW&teiId=fhFQhO0xILJ | teiAndChildProgram | Choose an enrollment to view the dashboard. |
| /#/enrollment?programId=qDkgAbB5Jlk&teiId=fhFQhO0xILJ | teiAndMalariaProgram | Carlos Cruz is a person and cannot be enrolled in the Malaria case diagnosis, treatment and investigation. Choose another program that allows person enrollment. Enroll a new malaria entity in this program.|
@@ -184,6 +184,8 @@ Feature: User uses the ScopeSelector to navigate
When you reset the program selection
Then you see message explaining you need to select a program
+ # DHIS2-18326
+ @skip
Scenario: Enrollment event edit page > resetting the org unit
Given you land on a enrollment page domain by having typed /#/enrollmentEventEdit?orgUnitId=UgYg0YW7ZIh&eventId=lQQyjR73hHk
When you reset the org unit selection
diff --git a/cypress/e2e/ScopeSelector/ScopeSelector.js b/cypress/e2e/ScopeSelector/ScopeSelector.js
index 00b119713f..c870644462 100644
--- a/cypress/e2e/ScopeSelector/ScopeSelector.js
+++ b/cypress/e2e/ScopeSelector/ScopeSelector.js
@@ -1,4 +1,4 @@
-import { Given, When, Then, defineStep as And } from '@badeball/cypress-cucumber-preprocessor';
+import { defineStep as And, Given, Then, When } from '@badeball/cypress-cucumber-preprocessor';
import { getCurrentYear } from '../../support/date';
Given(/^you land on a enrollment page domain by having typed (.*)$/, (url) => {
@@ -263,8 +263,7 @@ Then(/^you see the following (.*)$/, (message) => {
And('you land on the enrollment page by having typed only the enrollmentId on the url', () => {
cy.visit('/#/enrollment?enrollmentId=gPDueU02tn8');
- cy.get('[data-test="enrollment-page-content"]')
- .contains('Enrollment Dashboard');
+ cy.get('[data-test="enrollment-overview-page"]');
});
And('you reset the tei selection', () => {
@@ -288,7 +287,7 @@ And('you reset the org unit selection', () => {
And('you see the enrollment event Edit page but there is no org unit id in the url', () => {
cy.url().should('eq', `${Cypress.config().baseUrl}/#/enrollmentEventEdit?eventId=lQQyjR73hHk`);
- cy.contains('Enrollment: View Event');
+ cy.get('[data-test="widget-enrollment-event-view"]').should('exist');
});
And('you see the enrollment event New page but there is no org unit id in the url', () => {
@@ -298,13 +297,12 @@ And('you see the enrollment event New page but there is no org unit id in the ur
And('you see the enrollment event New page but there is no stage id in the url', () => {
cy.url().should('eq', `${Cypress.config().baseUrl}/#/enrollmentEventNew?enrollmentId=gPDueU02tn8&orgUnitId=UgYg0YW7ZIh&programId=IpHINAT79UW&teiId=fhFQhO0xILJ`);
- cy.contains('Enrollment: New Event');
+ cy.contains('Choose a stage for a new event');
});
And('you see the enrollment page', () => {
cy.url().should('eq', `${Cypress.config().baseUrl}/#/enrollment?enrollmentId=gPDueU02tn8&orgUnitId=UgYg0YW7ZIh&programId=IpHINAT79UW&teiId=fhFQhO0xILJ`);
- cy.get('[data-test="enrollment-page-content"]')
- .contains('Enrollment Dashboard');
+ cy.get('[data-test="enrollment-overview-page"]');
});
And('you reset the enrollment selection', () => {
diff --git a/cypress/e2e/TopBarActions/TopBarActions.feature b/cypress/e2e/TopBarActions/TopBarActions.feature
index 20f8aa8f74..25135c9328 100644
--- a/cypress/e2e/TopBarActions/TopBarActions.feature
+++ b/cypress/e2e/TopBarActions/TopBarActions.feature
@@ -61,7 +61,7 @@ Feature: User uses the TopBarActions to navigate
Given you land on a enrollment page domain by having typed /#/enrollmentEventEdit?orgUnitId=DwpbWkiqjMy&eventId=KNbStF7YTon
And the user see the following text: Gestational age at visit
When the user clicks on the edit button
- And the user see the following text: Enrollment: Edit Event
+ And the view enrollment event form is in edit mode
When the user clicks the element containing the text: Clear selections
Then the user sees the warning popup
@@ -88,7 +88,7 @@ Feature: User uses the TopBarActions to navigate
Given you land on a enrollment page domain by having typed #/enrollmentEventNew?programId=WSGAb5XwJ3Y&orgUnitId=DwpbWkiqjMy&teiId=yFcOhsM1Yoa&enrollmentId=ek4WWAgXX5i&stageId=edqlbukwRfQ
And the user see the following text: Clear selections
When the user clicks the arrow button to see the dropdown
- And the user clicks the element containing the text: Create new in another program...
+ And the user clicks the element containing the text: Create new in another program...
Then the current url is /#/new?orgUnitId=DwpbWkiqjMy
Scenario: Enrollment Event New page > You go to the new page inside the same program
diff --git a/cypress/e2e/TopBarActions/TopBarActions.js b/cypress/e2e/TopBarActions/TopBarActions.js
index 81d8cc996e..6fb563ed38 100644
--- a/cypress/e2e/TopBarActions/TopBarActions.js
+++ b/cypress/e2e/TopBarActions/TopBarActions.js
@@ -1,4 +1,4 @@
-import { Given, When, Then } from '@badeball/cypress-cucumber-preprocessor';
+import { defineStep as And, Given, Then, When } from '@badeball/cypress-cucumber-preprocessor';
Given(/^you land on a enrollment page domain by having typed (.*)$/, (url) => {
cy.visit(url);
@@ -24,3 +24,7 @@ When(/^the user set the WHOMCH Diastolic blood pressure to (.*)/, score =>
.type(score)
.blur(),
);
+
+And(/^the view enrollment event form is in (.*) mode$/, (mode) => {
+ cy.get(`[data-test="widget-enrollment-event-${mode}"]`).should('exist');
+});
diff --git a/cypress/e2e/WidgetsForEnrollmentPages/WidgetEventNote/index.js b/cypress/e2e/WidgetsForEnrollmentPages/WidgetEventNote/index.js
index 2a1c5200ef..8b0ae0e38e 100644
--- a/cypress/e2e/WidgetsForEnrollmentPages/WidgetEventNote/index.js
+++ b/cypress/e2e/WidgetsForEnrollmentPages/WidgetEventNote/index.js
@@ -1,4 +1,4 @@
-import { When, Then } from '@badeball/cypress-cucumber-preprocessor';
+import { Then, When } from '@badeball/cypress-cucumber-preprocessor';
Then('the enrollment widget should be loaded', () => {
cy.contains('The enrollment event data could not be found').should('not.exist');
@@ -7,7 +7,7 @@ Then('the enrollment widget should be loaded', () => {
When('you click edit mode', () => {
cy.contains('[data-test="dhis2-uicore-button"]', 'Edit event')
.click();
- cy.contains('Enrollment: Edit Event').should('exist');
+ cy.get('[data-test="widget-enrollment-event-edit"]').should('exist');
});
When(/^you fill in the note: (.*)$/, (note) => {
diff --git a/i18n/en.pot b/i18n/en.pot
index 3679a47b6b..11c24b0478 100644
--- a/i18n/en.pot
+++ b/i18n/en.pot
@@ -35,6 +35,39 @@ msgstr ""
"(in the same domain). Please refresh this page if you would like to use "
"this version again, but be aware that this will close other versions."
+msgid "Enrollment dashboard"
+msgstr "Enrollment dashboard"
+
+msgid "View event"
+msgstr "View event"
+
+msgid "Edit event"
+msgstr "Edit event"
+
+msgid "New event"
+msgstr "New event"
+
+msgid "Active enrollments"
+msgstr "Active enrollments"
+
+msgid "Completed enrollments"
+msgstr "Completed enrollments"
+
+msgid "Cancelled enrollments"
+msgstr "Cancelled enrollments"
+
+msgid "{{trackedEntityName}} list"
+msgstr "{{trackedEntityName}} list"
+
+msgid "Search"
+msgstr "Search"
+
+msgid "Working List"
+msgstr "Working List"
+
+msgid "Event list"
+msgstr "Event list"
+
msgid "More"
msgstr "More"
@@ -293,9 +326,6 @@ msgstr "Yes, discard changes"
msgid "No, cancel"
msgstr "No, cancel"
-msgid "New event"
-msgstr "New event"
-
msgid "You don't have access to create an event in the current selections"
msgstr "You don't have access to create an event in the current selections"
@@ -514,9 +544,6 @@ msgstr "Type to filter options"
msgid "No match found"
msgstr "No match found"
-msgid "Search"
-msgstr "Search"
-
msgid "Clear"
msgstr "Clear"
@@ -858,9 +885,6 @@ msgstr "event"
msgid "You don't have access to edit this event"
msgstr "You don't have access to edit this event"
-msgid "Edit event"
-msgstr "Edit event"
-
msgid "View changelog"
msgstr "View changelog"
@@ -898,15 +922,6 @@ msgstr "Event could not be loaded"
msgid "Organisation unit could not be loaded"
msgstr "Organisation unit could not be loaded"
-msgid "Dashboard"
-msgstr "Dashboard"
-
-msgid "Edit Event"
-msgstr "Edit Event"
-
-msgid "View Event"
-msgstr "View Event"
-
msgid "Selected program"
msgstr "Selected program"
diff --git a/package.json b/package.json
index 4c79240393..07eb53096a 100644
--- a/package.json
+++ b/package.json
@@ -1,7 +1,7 @@
{
"name": "capture-app",
"homepage": ".",
- "version": "101.15.0",
+ "version": "101.16.0",
"cacheVersion": "7",
"serverVersion": "38",
"license": "BSD-3-Clause",
@@ -10,7 +10,7 @@
"packages/rules-engine"
],
"dependencies": {
- "@dhis2/rules-engine-javascript": "101.15.0",
+ "@dhis2/rules-engine-javascript": "101.16.0",
"@dhis2/app-runtime": "^3.9.3",
"@dhis2/d2-i18n": "^1.1.0",
"@dhis2/d2-icons": "^1.0.1",
diff --git a/packages/rules-engine/package.json b/packages/rules-engine/package.json
index e8bf339ad9..d0b7bd5ae9 100644
--- a/packages/rules-engine/package.json
+++ b/packages/rules-engine/package.json
@@ -1,6 +1,6 @@
{
"name": "@dhis2/rules-engine-javascript",
- "version": "101.15.0",
+ "version": "101.16.0",
"license": "BSD-3-Clause",
"main": "./build/cjs/index.js",
"scripts": {
diff --git a/src/core_modules/capture-core/components/Breadcrumbs/EnrollmentBreadcrumb/EnrollmentBreadcrumb.js b/src/core_modules/capture-core/components/Breadcrumbs/EnrollmentBreadcrumb/EnrollmentBreadcrumb.js
new file mode 100644
index 0000000000..1387ce9209
--- /dev/null
+++ b/src/core_modules/capture-core/components/Breadcrumbs/EnrollmentBreadcrumb/EnrollmentBreadcrumb.js
@@ -0,0 +1,171 @@
+// @flow
+import type { ComponentType } from 'react';
+import React, { useCallback, useMemo, useState } from 'react';
+import i18n from '@dhis2/d2-i18n';
+import { withStyles } from '@material-ui/core/styles';
+import { colors, IconChevronRight16 } from '@dhis2/ui';
+import { useWorkingListLabel } from './hooks/useWorkingListLabel';
+import { BreadcrumbItem } from '../common/BreadcrumbItem';
+import { defaultDialogProps } from '../../Dialogs/DiscardDialog.constants';
+import { DiscardDialog } from '../../Dialogs/DiscardDialog.component';
+import {
+ EnrollmentPageKeys,
+} from '../../Pages/common/EnrollmentOverviewDomain/EnrollmentPageLayout/DefaultEnrollmentLayout.constants';
+
+type Props = {
+ onBackToMainPage: () => void,
+ onBackToDashboard?: () => void,
+ onBackToViewEvent?: () => void,
+ displayFrontPageList: boolean,
+ programId: string,
+ userInteractionInProgress?: boolean,
+ trackedEntityName?: string,
+};
+
+export const EventStatuses = {
+ ACTIVE: 'ACTIVE',
+ COMPLETED: 'COMPLETED',
+ SKIPPED: 'SKIPPED',
+ SCHEDULE: 'SCHEDULE',
+ OVERDUE: 'OVERDUE',
+};
+
+const styles = {
+ container: {
+ display: 'flex',
+ alignItems: 'center',
+ },
+};
+
+const pageKeys = Object.freeze({
+ MAIN_PAGE: 'mainPage',
+ ...EnrollmentPageKeys,
+});
+
+const eventIsScheduled = eventStatus => [EventStatuses.SCHEDULE, EventStatuses.OVERDUE, EventStatuses.SKIPPED]
+ .includes(eventStatus);
+
+const BreadcrumbsPlain = ({
+ onBackToMainPage,
+ onBackToDashboard,
+ onBackToViewEvent,
+ eventStatus,
+ programId,
+ trackedEntityName,
+ displayFrontPageList,
+ userInteractionInProgress = false,
+ page,
+ classes,
+}) => {
+ const [openWarning, setOpenWarning] = useState(null);
+
+ const { label } = useWorkingListLabel({
+ trackedEntityName,
+ programId,
+ displayFrontPageList,
+ });
+
+ const handleNavigation = useCallback((callback, warningType) => {
+ if (userInteractionInProgress) {
+ setOpenWarning(warningType);
+ } else {
+ callback && callback();
+ }
+ }, [userInteractionInProgress]);
+
+ const breadcrumbItems = useMemo(() => ([
+ {
+ key: pageKeys.MAIN_PAGE,
+ onClick: () => handleNavigation(onBackToMainPage, pageKeys.MAIN_PAGE),
+ label,
+ selected: false,
+ condition: true,
+ },
+ {
+ key: pageKeys.OVERVIEW,
+ onClick: () => handleNavigation(onBackToDashboard, pageKeys.OVERVIEW),
+ label: i18n.t('Enrollment dashboard'),
+ selected: page === pageKeys.OVERVIEW,
+ condition: true,
+ },
+ {
+ key: pageKeys.VIEW_EVENT,
+ onClick: () => handleNavigation(onBackToViewEvent, pageKeys.VIEW_EVENT),
+ label: i18n.t('View event'),
+ selected: page === pageKeys.VIEW_EVENT,
+ condition: page === pageKeys.VIEW_EVENT ||
+ (page === pageKeys.EDIT_EVENT && !eventIsScheduled(eventStatus)),
+ },
+ {
+ key: pageKeys.EDIT_EVENT,
+ onClick: () => {},
+ label: i18n.t('Edit event'),
+ selected: page === pageKeys.EDIT_EVENT,
+ condition: page === pageKeys.EDIT_EVENT,
+ },
+ {
+ key: pageKeys.NEW_EVENT,
+ onClick: () => {},
+ label: i18n.t('New event'),
+ selected: page === pageKeys.NEW_EVENT,
+ condition: page === pageKeys.NEW_EVENT,
+ },
+ ].filter(item => item.condition)), [
+ label,
+ page,
+ eventStatus,
+ handleNavigation,
+ onBackToMainPage,
+ onBackToDashboard,
+ onBackToViewEvent,
+ ]);
+
+ return (
+