diff --git a/cypress/e2e/facility_spec/facility_homepage.cy.ts b/cypress/e2e/facility_spec/facility_homepage.cy.ts
index 3d916b4ba47..7269c3a2581 100644
--- a/cypress/e2e/facility_spec/facility_homepage.cy.ts
+++ b/cypress/e2e/facility_spec/facility_homepage.cy.ts
@@ -5,6 +5,7 @@ import FacilityHome from "../../pageobject/Facility/FacilityHome";
import ManageUserPage from "../../pageobject/Users/ManageUserPage";
import FacilityPage from "../../pageobject/Facility/FacilityCreation";
import { UserPage } from "../../pageobject/Users/UserSearch";
+import { AssetPagination } from "../../pageobject/Asset/AssetPagination";
describe("Facility Homepage Function", () => {
const loginPage = new LoginPage();
@@ -12,6 +13,7 @@ describe("Facility Homepage Function", () => {
const facilityPage = new FacilityPage();
const manageUserPage = new ManageUserPage();
const userPage = new UserPage();
+ const assetPagination = new AssetPagination();
const facilitiesAlias = "downloadFacilitiesCSV";
const capacitiesAlias = "downloadCapacitiesCSV";
const doctorsAlias = "downloadDoctorsCSV";
@@ -19,6 +21,7 @@ describe("Facility Homepage Function", () => {
const facilityname = "Dummy Facility 1";
const statename = "Kerala";
const district = "Ernakulam";
+ const localbody = "Aikaranad";
const facilitytype = "Private Hospital";
before(() => {
@@ -31,24 +34,52 @@ describe("Facility Homepage Function", () => {
cy.awaitUrl("/facility");
});
+ it("Verify the Facility card button redirection", () => {
+ // view cns button
+ facilityHome.clickViewCnsButton();
+ facilityHome.verifyCnsUrl();
+ facilityHome.navigateBack();
+ // view notify button
+ facilityHome.clickFacilityNotifyButton();
+ facilityHome.verifyAndCloseNotifyModal();
+ // view facility button
+ facilityHome.clickViewFacilityDetails();
+ facilityPage.getFacilityName().should("be.visible");
+ facilityHome.verifyFacilityDetailsUrl();
+ facilityHome.navigateBack();
+ // view patient button
+ manageUserPage.clickFacilityPatients();
+ facilityHome.verifyPatientListVisibility();
+ facilityHome.verifyPatientListUrl();
+ facilityHome.navigateBack();
+ // occupancy badge
+ facilityHome.verifyOccupancyBadgeVisibility();
+ });
+
it("Verify the functionality of advance filter", () => {
userPage.clickAdvancedFilters();
facilityPage.selectState(statename);
facilityPage.selectDistrict(district);
- // facilityPage.selectLocalBody("Anthikad Grama"); current dummy data have issue in local body
+ facilityPage.selectLocalBody(localbody);
facilityPage.clickUpdateFacilityType(facilitytype);
userPage.applyFilter();
facilityPage.verifyStateBadgeContent(statename);
facilityPage.verifyDistrictBadgeContent(district);
+ facilityPage.verifyLocalBodyBadgeContent(localbody);
facilityPage.verifyFacilityTypeBadgeContent(facilitytype);
manageUserPage.assertFacilityInCard(facilityname);
userPage.clearFilters();
userPage.verifyDataTestIdNotVisible("State");
userPage.verifyDataTestIdNotVisible("District");
userPage.verifyDataTestIdNotVisible("Facility type");
+ userPage.verifyDataTestIdNotVisible("Local Body");
});
- it("Search a facility in homepage", () => {
+ it("Search a facility in homepage and pagination", () => {
+ // pagination of the facility page
+ assetPagination.navigateToNextPage();
+ assetPagination.navigateToPreviousPage();
+ // search for a facility
manageUserPage.typeFacilitySearch(facilityname);
facilityPage.verifyFacilityBadgeContent(facilityname);
manageUserPage.assertFacilityInCard(facilityname);
diff --git a/cypress/e2e/facility_spec/locations.cy.ts b/cypress/e2e/facility_spec/locations.cy.ts
index 26364048ca2..d6377ba97c3 100644
--- a/cypress/e2e/facility_spec/locations.cy.ts
+++ b/cypress/e2e/facility_spec/locations.cy.ts
@@ -3,14 +3,18 @@ import { AssetPage } from "../../pageobject/Asset/AssetCreation";
import { UserCreationPage } from "../../pageobject/Users/UserCreation";
import FacilityPage from "../../pageobject/Facility/FacilityCreation";
import FacilityLocation from "../../pageobject/Facility/FacilityLocation";
-// import { AssetPagination } from "../../pageobject/Asset/AssetPagination";
+import { AssetPagination } from "../../pageobject/Asset/AssetPagination";
+import FacilityHome from "../../pageobject/Facility/FacilityHome";
+
describe("Location Management Section", () => {
const assetPage = new AssetPage();
const userCreationPage = new UserCreationPage();
const facilityPage = new FacilityPage();
const facilityLocation = new FacilityLocation();
- // const assetPagination = new AssetPagination();
+ const assetPagination = new AssetPagination();
+ const facilityHome = new FacilityHome();
+
const EXPECTED_LOCATION_ERROR_MESSAGES = [
"Name is required",
"Location Type is required",
@@ -27,7 +31,7 @@ describe("Location Management Section", () => {
const locationModifiedDescription = "Test Modified Description";
const locationModifiedType = "ICU";
const locationModifiedMiddleware = "dev-middleware.coronasafe.live";
- const bedName = "Test Bed";
+ const bedName = "Test-Bed";
const bedDescrption = "test description";
const bedType = "ICU";
const bedStatus = "Vacant";
@@ -35,7 +39,7 @@ describe("Location Management Section", () => {
const bedModifiedDescrption = "test modified description";
const bedModifiedType = "Isolation";
const numberOfBeds = 10;
- // const numberOfModifiedBeds = 25;
+ const numberOfModifiedBeds = 25;
before(() => {
cy.loginByApi("devdistrictadmin", "Coronasafe@123");
@@ -56,6 +60,42 @@ describe("Location Management Section", () => {
cy.get("[id=location-management]").click();
});
+ it("Add a Bed to facility location along with duplication and deleting a bed", () => {
+ // mandatory field verification in bed creation
+ facilityLocation.clickManageBedButton();
+ facilityLocation.clickAddBedButton();
+ assetPage.clickassetupdatebutton();
+ userCreationPage.verifyErrorMessages(EXPECTED_BED_ERROR_MESSAGES);
+ // create a new single bed and verify
+ facilityLocation.enterBedName(bedName);
+ facilityLocation.enterBedDescription(bedDescrption);
+ facilityLocation.selectBedType(bedType);
+ assetPage.clickassetupdatebutton();
+ // Verify the bed creation
+ facilityLocation.verifyBedNameBadge(bedName);
+ facilityLocation.verifyBedBadge(bedType);
+ facilityLocation.verifyBedBadge(bedStatus);
+ // Try to create duplication bed and verify the error
+ facilityLocation.clickAddBedButton();
+ facilityLocation.enterBedName(bedName);
+ facilityLocation.selectBedType(bedType);
+ assetPage.clickassetupdatebutton();
+ facilityLocation.verifyNotification(
+ "Name - Bed with same name already exists in location"
+ );
+ facilityHome.verifyAndCloseNotifyModal();
+ // edit the created bed
+ facilityLocation.clickEditBedButton();
+ facilityLocation.enterBedName(bedModifiedName);
+ facilityLocation.enterBedDescription(bedModifiedDescrption);
+ facilityLocation.selectBedType(bedModifiedType);
+ assetPage.clickassetupdatebutton();
+ // verify the modification
+ facilityLocation.verifyBedNameBadge(bedModifiedName);
+ facilityLocation.verifyBedBadge(bedModifiedType);
+ facilityLocation.verifyBedBadge(bedStatus);
+ });
+
it("Adds Location to a facility and modify it", () => {
// add a new location form mandatory error
facilityLocation.clickAddNewLocationButton();
@@ -86,7 +126,7 @@ describe("Location Management Section", () => {
facilityLocation.verifyLocationMiddleware(locationModifiedMiddleware);
});
- it("Add Multiple Bed to a facility location and delete a bed", () => {
+ it("Multiple Bed to a facility location and delete a bed", () => {
// create multiple bed and verify
facilityLocation.clickManageBedButton();
facilityLocation.clickAddBedButton();
@@ -106,45 +146,18 @@ describe("Location Management Section", () => {
facilityLocation.deleteBedRequest();
});
- // it("Add Multiple Bed to a facility location and verify pagination", () => {
- // // bed creation
- // facilityLocation.clickManageBedButton();
- // facilityLocation.clickAddBedButton();
- // facilityLocation.enterBedName(bedModifiedName);
- // facilityLocation.enterBedDescription(bedModifiedDescrption);
- // facilityLocation.selectBedType(bedModifiedType);
- // facilityLocation.setMultipleBeds(numberOfModifiedBeds);
- // assetPage.clickassetupdatebutton();
- // // pagination
- // assetPagination.navigateToNextPage();
- // assetPagination.navigateToPreviousPage();
- // }); need to be unblocked upon issue #6906 is solved
-
- it("Add Single Bed to a facility location and modify it", () => {
- // mandatory field verification in bed creation
+ it("Add Multiple Bed to a facility location and verify pagination", () => {
+ // bed creation
facilityLocation.clickManageBedButton();
facilityLocation.clickAddBedButton();
- assetPage.clickassetupdatebutton();
- userCreationPage.verifyErrorMessages(EXPECTED_BED_ERROR_MESSAGES);
- // create a new single bed and verify
- facilityLocation.enterBedName(bedName);
- facilityLocation.enterBedDescription(bedDescrption);
- facilityLocation.selectBedType(bedType);
- assetPage.clickassetupdatebutton();
- // Verify the bed creation
- facilityLocation.verifyBedNameBadge(bedName);
- facilityLocation.verifyBedBadge(bedType);
- facilityLocation.verifyBedBadge(bedStatus);
- // edit the created bed
- facilityLocation.clickEditBedButton();
facilityLocation.enterBedName(bedModifiedName);
facilityLocation.enterBedDescription(bedModifiedDescrption);
facilityLocation.selectBedType(bedModifiedType);
+ facilityLocation.setMultipleBeds(numberOfModifiedBeds);
assetPage.clickassetupdatebutton();
- // verify the modification
- facilityLocation.verifyBedNameBadge(bedModifiedName);
- facilityLocation.verifyBedBadge(bedModifiedType);
- facilityLocation.verifyBedBadge(bedStatus);
+ // pagination
+ assetPagination.navigateToNextPage();
+ assetPagination.navigateToPreviousPage();
});
afterEach(() => {
diff --git a/cypress/pageobject/Facility/FacilityCreation.ts b/cypress/pageobject/Facility/FacilityCreation.ts
index 608dd9c357b..2d6aa9ff375 100644
--- a/cypress/pageobject/Facility/FacilityCreation.ts
+++ b/cypress/pageobject/Facility/FacilityCreation.ts
@@ -299,6 +299,7 @@ class FacilityPage {
cy.intercept("https://maps.googleapis.com/maps/api/mapsjs/*").as("mapApi");
cy.wait("@mapApi").its("response.statusCode").should("eq", 200);
cy.get("input#pac-input").type(location).type("{enter}");
+ cy.wait(2000);
cy.get("div#map-close").click();
}
@@ -337,6 +338,10 @@ class FacilityPage {
cy.get("[data-testid='District']").should("contain", expectedText);
}
+ verifyLocalBodyBadgeContent(expectedText: string) {
+ cy.get("[data-testid='Local Body']").should("contain", expectedText);
+ }
+
verifyFacilityTypeBadgeContent(expectedText: string) {
cy.get("[data-testid='Facility type']").should("contain", expectedText);
}
@@ -414,6 +419,7 @@ class FacilityPage {
selectStateOnPincode(stateName) {
this.getStateElement()
.scrollIntoView()
+ .wait(2000)
.should("be.visible")
.then(($element) => {
const text = $element.text();
@@ -427,6 +433,7 @@ class FacilityPage {
selectDistrictOnPincode(districtName) {
this.getDistrictElement()
.scrollIntoView()
+ .wait(2000)
.should("be.visible")
.then(($element) => {
const text = $element.text();
diff --git a/cypress/pageobject/Facility/FacilityHome.ts b/cypress/pageobject/Facility/FacilityHome.ts
index 04dfe94d002..03f2be9b19b 100644
--- a/cypress/pageobject/Facility/FacilityHome.ts
+++ b/cypress/pageobject/Facility/FacilityHome.ts
@@ -23,6 +23,49 @@ class FacilityHome {
cy.intercept("GET", `**/api/v1/facility/?csv${queryParam}`).as(alias);
}
+ clickViewCnsButton() {
+ cy.get("#view-cns-button").first().click();
+ }
+
+ verifyCnsUrl() {
+ cy.url().should("include", "/cns");
+ }
+
+ clickFacilityNotifyButton() {
+ cy.get("#facility-notify").first().click();
+ }
+
+ verifyFacilityDetailsUrl() {
+ cy.url().should("match", /\/facility\/[\w-]+/);
+ }
+
+ verifyPatientListVisibility() {
+ cy.get("#patient-name-list").scrollIntoView();
+ cy.get("#patient-name-list").should("be.visible");
+ }
+
+ verifyPatientListUrl() {
+ cy.url().should("match", /\/patients\?facility=.+/);
+ }
+
+ verifyOccupancyBadgeVisibility() {
+ cy.get("#occupany-badge").should("be.visible");
+ }
+
+ verifyAndCloseNotifyModal() {
+ cy.get("#cancel").should("be.visible");
+ cy.get("#cancel").click();
+ }
+
+ navigateBack() {
+ cy.go(-1);
+ }
+
+ clickViewFacilityDetails() {
+ cy.get("#facility-details").should("be.visible");
+ cy.get("#facility-details").first().click();
+ }
+
verifyDownload(alias: string) {
cy.wait(`@${alias}`).its("response.statusCode").should("eq", 200);
}
diff --git a/cypress/pageobject/Facility/FacilityLocation.ts b/cypress/pageobject/Facility/FacilityLocation.ts
index d3eebdaf4ff..8924119510f 100644
--- a/cypress/pageobject/Facility/FacilityLocation.ts
+++ b/cypress/pageobject/Facility/FacilityLocation.ts
@@ -32,6 +32,10 @@ class FacilityLocation {
cy.get("#location-type").contains(type);
}
+ verifyNotification(message: string) {
+ cy.get(".pnotify-container").should("contain", message).and("be.visible");
+ }
+
verifyLocationDescription(description: string) {
cy.get("#view-location-description").contains(description);
}
@@ -49,7 +53,7 @@ class FacilityLocation {
}
enterBedName(name: string) {
- cy.get("#bed-name").clear().click().type(name);
+ cy.get("#bed-name").click().clear().click().type(name);
}
enterBedDescription(description: string) {
diff --git a/cypress/pageobject/Users/ManageUserPage.ts b/cypress/pageobject/Users/ManageUserPage.ts
index d3f7e17e7d5..2d1ebbc14f0 100644
--- a/cypress/pageobject/Users/ManageUserPage.ts
+++ b/cypress/pageobject/Users/ManageUserPage.ts
@@ -103,6 +103,7 @@ export class ManageUserPage {
}
clickFacilityPatients() {
+ cy.get("#facility-patients").should("be.visible");
cy.get("#facility-patients").click();
}
diff --git a/src/CAREUI/display/RecordMeta.tsx b/src/CAREUI/display/RecordMeta.tsx
index 818553d9207..5e1e117f9d6 100644
--- a/src/CAREUI/display/RecordMeta.tsx
+++ b/src/CAREUI/display/RecordMeta.tsx
@@ -1,7 +1,8 @@
import CareIcon from "../icons/CareIcon";
import {
- formatDateTime,
+ formatDate,
formatName,
+ formatTime,
isUserOnline,
relativeTime,
} from "../../Utils/utils";
@@ -38,7 +39,8 @@ const RecordMeta = ({
{relativeTime(time)}
- {formatDateTime(time)}
+ {formatTime(time)}
+ {formatDate(time)}
{user && !inlineUser && (
by
diff --git a/src/CAREUI/display/Timeline.tsx b/src/CAREUI/display/Timeline.tsx
index 7549fbfd69f..276c437056c 100644
--- a/src/CAREUI/display/Timeline.tsx
+++ b/src/CAREUI/display/Timeline.tsx
@@ -76,23 +76,29 @@ export const TimelineNode = (props: TimelineNodeProps) => {
>
{props.title || (
-
- {props.event.by && (
-
- {formatName(props.event.by)}{" "}
-
- )}
- {props.titleSuffix
- ? props.titleSuffix
- : `${props.event.type} the ${props.name || name}.`}
-
- {props.actions && (
- {props.actions}
- )}
-
+
+
+ {props.event.by && (
+
+ {formatName(props.event.by)}{" "}
+ {props.event.by.user_type &&
+ `(${props.event.by.user_type}) `}
+
+ )}
+ {props.titleSuffix
+ ? props.titleSuffix
+ : `${props.event.type} the ${props.name || name}.`}
+
+
+ {props.actions && (
+ {props.actions}
+ )}
+
+
+
)}
diff --git a/src/CAREUI/misc/PaginatedList.tsx b/src/CAREUI/misc/PaginatedList.tsx
index 02ee0e3d90e..1487d69e4fa 100644
--- a/src/CAREUI/misc/PaginatedList.tsx
+++ b/src/CAREUI/misc/PaginatedList.tsx
@@ -7,6 +7,7 @@ import ButtonV2, {
import CareIcon from "../icons/CareIcon";
import { classNames } from "../../Utils/utils";
import Pagination from "../../Components/Common/Pagination";
+import Timeline from "../display/Timeline";
const DEFAULT_PER_PAGE_LIMIT = 14;
@@ -129,20 +130,26 @@ interface ItemsProps {
const Items = (props: ItemsProps) => {
const { loading, items } = useContextualized();
+ if (loading || items.length === 0) {
+ return null;
+ }
+
return (
-
- {loading && props.shimmer
- ? Array.from({ length: props.shimmerCount ?? 8 }).map((_, i) => (
- -
- {props.shimmer}
-
- ))
- : items.map((item, index, items) => (
- -
- {props.children(item, items)}
-
- ))}
-
+
+
+ {loading && props.shimmer
+ ? Array.from({ length: props.shimmerCount ?? 8 }).map((_, i) => (
+ -
+ {props.shimmer}
+
+ ))
+ : items.map((item, index, items) => (
+ -
+ {props.children(item, items)}
+
+ ))}
+
+
);
};
@@ -153,8 +160,16 @@ interface PaginatorProps {
hideIfSinglePage?: boolean;
}
-const Paginator = ({ className, hideIfSinglePage }: PaginatorProps) => {
+const Paginator = ({
+ className,
+ hideIfSinglePage,
+}: PaginatorProps) => {
const { data, perPage, currentPage, setPage } = useContextualized