From f0589e67cf9c26293fd8cd9da09e78f4f4134d66 Mon Sep 17 00:00:00 2001
From: JavidSumra <112365664+JavidSumra@users.noreply.github.com>
Date: Thu, 9 Jan 2025 20:31:52 +0530
Subject: [PATCH] Fix Online Status Indicator in Organization Tab (#9728)
---
public/locale/en.json | 20 ++++-
src/components/Users/UserListAndCard.tsx | 83 +++++++------------
.../ui/sidebar/facility-switcher.tsx | 8 +-
.../FacilityOrganizationUsers.tsx | 30 +++----
.../components/EditFacilityUserRoleSheet.tsx | 58 +++++++------
src/pages/Organization/OrganizationUsers.tsx | 25 ++----
.../components/EditUserRoleSheet.tsx | 57 +++++++------
7 files changed, 139 insertions(+), 142 deletions(-)
diff --git a/public/locale/en.json b/public/locale/en.json
index 67ac2188bd8..ab0afc7ca3c 100644
--- a/public/locale/en.json
+++ b/public/locale/en.json
@@ -28,7 +28,6 @@
"CONSCIOUSNESS_LEVEL__RESPONDS_TO_PAIN": "Responds to Pain",
"CONSCIOUSNESS_LEVEL__RESPONDS_TO_VOICE": "Responds to Voice",
"CONSCIOUSNESS_LEVEL__UNRESPONSIVE": "Unresponsive",
- "Cancel": "Cancel",
"DAYS_OF_WEEK_SHORT__0": "Mon",
"DAYS_OF_WEEK_SHORT__1": "Tue",
"DAYS_OF_WEEK_SHORT__2": "Wed",
@@ -355,6 +354,7 @@
"age_input_warning_bold": "Recommended only when the patient's date of birth is unknown",
"age_less_than_0": "Age cannot be less than 0",
"age_notice": "Only year of birth will be stored for age.",
+ "ago": "ago",
"all": "All",
"all_changes_have_been_saved": "All changes have been saved",
"all_details": "All Details",
@@ -486,6 +486,7 @@
"cancelled": "Cancelled",
"capture": "Capture",
"capture_cover_photo": "Capture Cover Photo",
+ "card": "Card",
"care": "CARE",
"category": "Category",
"caution": "Caution",
@@ -658,6 +659,7 @@
"csv_file_in_the_specified_format": "Select a CSV file in the specified format",
"current_address": "Current Address",
"current_password": "Current Password",
+ "current_role": "Current Role",
"current_status": "Current Status",
"customer_support_email": "Customer Support Email",
"customer_support_name": "Customer Support Name",
@@ -678,7 +680,6 @@
"date_of_return": "Date of Return",
"date_of_test": "Date of sample collection for Covid testing",
"day": "Day",
- "days": "Days",
"death_report": "Death Report",
"delete": "Delete",
"delete_account": "Delete account",
@@ -767,7 +768,9 @@
"edit_policy_description": "Add or edit patient's insurance details",
"edit_prescriptions": "Edit Prescriptions",
"edit_profile": "Edit Profile",
+ "edit_role": "Edit Role",
"edit_user_profile": "Edit Profile",
+ "edit_user_role": "Edit User Role",
"edited_by": "Edited by",
"edited_on": "Edited on",
"education": "Education",
@@ -1033,7 +1036,6 @@
"home_facility_cleared_success": "Home Facility cleared successfully",
"home_facility_updated_error": "Error while updating Home Facility",
"home_facility_updated_success": "Home Facility updated successfully",
- "hours": "hours",
"hubs": "Hub Facilities",
"i_declare": "I hereby declare that:",
"icd11_as_recommended": "As per ICD-11 recommended by WHO",
@@ -1117,6 +1119,7 @@
"last_administered": "Last administered",
"last_discharge_reason": "Last Discharge Reason",
"last_edited": "Last Edited",
+ "last_login": "Last Login",
"last_modified": "Last Modified",
"last_modified_by": "Last Modified By",
"last_name": "Last Name",
@@ -1230,6 +1233,7 @@
"nationality": "Nationality",
"nearby_facilities": "Nearby Facilities",
"never": "never",
+ "never_logged_in": "Never Logged In",
"new_password": "New Password",
"new_password_confirmation": "Confirm New Password",
"new_password_same_as_old": "New password is same as old password, please enter a different new password.",
@@ -1546,6 +1550,8 @@
"reload": "Reload",
"remove": "Remove",
"remove_user": "Remove User",
+ "remove_user_organization": "Remove User from Organization",
+ "remove_user_warn": "Are you sure you want to remove {{firstName}} {{lastName}} from this organization? This action cannot be undone.",
"rename": "Rename",
"replace_home_facility": "Replace Home Facility",
"replace_home_facility_confirm": "Are you sure you want to replace",
@@ -1643,7 +1649,9 @@
"select_all": "Select All",
"select_date": "Select date",
"select_department": "Select Department",
+ "select_diff_role": "Please select a different role",
"select_eligible_policy": "Select an Eligible Insurance Policy",
+ "select_facility": "Select Facility",
"select_facility_for_discharged_patients_warning": "Facility needs to be selected to view discharged patients.",
"select_for_administration": "Select for Administration",
"select_groups": "Select Groups",
@@ -1651,6 +1659,7 @@
"select_investigation_groups": "Select Investigation Groups",
"select_investigations": "Select Investigations",
"select_local_body": "Select Local Body",
+ "select_new_role": "Select New Role",
"select_patient": "Select Patient",
"select_policy": "Select an Insurance Policy",
"select_policy_to_add_items": "Select a Policy to Add Items",
@@ -1837,9 +1846,11 @@
"update_preset_position_to_current": "Update preset's position to camera's current position",
"update_record": "Update Record",
"update_record_for_asset": "Update record for asset",
+ "update_role": "Update Role",
"update_shift_request": "Update Shift Request",
"update_status": "Update Status",
"update_status_details": "Update Status/Details",
+ "update_user_role_organization": "Update the role for this user in the organization",
"update_volunteer": "Reassign Volunteer",
"updated": "Updated",
"updated_on": "Updated On",
@@ -1869,6 +1880,8 @@
"user_not_available_for_appointments": "This user is not available for appointments",
"user_qualifications": "Qualifications",
"user_qualifications_note": "Enter appropriate qualifications for this user",
+ "user_removed_success": "User removed from organization successfully",
+ "user_role_update_success": "User role updated successfully",
"user_type": "User Type",
"username": "Username",
"username_already_exists": "This username already exists",
@@ -1909,6 +1922,7 @@
"view_cns": "View CNS",
"view_consultation": "View Latest Encounter",
"view_consultation_and_log_updates": "View Consultation / Log Updates",
+ "view_dashboard": "View Dashboard",
"view_details": "View Details",
"view_facility": "View Facility",
"view_files": "View Files",
diff --git a/src/components/Users/UserListAndCard.tsx b/src/components/Users/UserListAndCard.tsx
index e436afe6e15..6422f096f2f 100644
--- a/src/components/Users/UserListAndCard.tsx
+++ b/src/components/Users/UserListAndCard.tsx
@@ -4,6 +4,8 @@ import { useTranslation } from "react-i18next";
import Card from "@/CAREUI/display/Card";
import CareIcon from "@/CAREUI/icons/CareIcon";
+import { Badge } from "@/components/ui/badge";
+
import { Avatar } from "@/components/Common/Avatar";
import Tabs from "@/components/Common/Tabs";
import SearchInput from "@/components/Form/SearchInput";
@@ -14,12 +16,7 @@ import useWindowDimensions from "@/hooks/useWindowDimensions";
import { USER_TYPE_OPTIONS } from "@/common/constants";
-import {
- classNames,
- formatName,
- isUserOnline,
- relativeTime,
-} from "@/Utils/utils";
+import { formatName, isUserOnline, relativeTime } from "@/Utils/utils";
import { UserBase } from "@/types/user/user";
export const GetUserTypes = () => {
@@ -65,11 +62,7 @@ const GetDetailsButton = (username: string) => {
);
};
-const getNameAndStatusCard = (
- user: UserBase,
- cur_online: boolean,
- showDetailsButton = false,
-) => {
+const getNameAndStatusCard = (user: UserBase, showDetailsButton = false) => {
return (
@@ -78,14 +71,7 @@ const getNameAndStatusCard = (
{formatName(user)}
-
-
-
+
{
const authUser = useAuthUser();
const isAuthUser = user.id === authUser.external_id;
- const isOnline = isUserOnline(user) || isAuthUser;
const { t } = useTranslation();
return (
-
-
-
- {isOnline
- ? t("online")
- : user.last_login
- ? relativeTime(user.last_login)
- : t("never")}
-
-
+ {isUserOnline(user) || isAuthUser ? (
+
+
+ {t("online")}
+
+ ) : user.last_login ? (
+
+
+
+ {relativeTime(user.last_login)}
+
+
+ ) : (
+
+
+ {t("never_logged_in")}
+
+ )}
+
);
};
const UserCard = ({ user }: { user: UserBase }) => {
@@ -173,7 +154,7 @@ const UserCard = ({ user }: { user: UserBase }) => {
{!isMediumScreen &&
- getNameAndStatusCard(user, userOnline, !isLessThanXLargeScreen)}
+ getNameAndStatusCard(user, !isLessThanXLargeScreen)}
{t("role")}
@@ -312,7 +293,7 @@ export default function UserListView({
text: (
- Card
+ {t("card")}
),
value: 0,
@@ -322,7 +303,7 @@ export default function UserListView({
text: (
- List
+ {t("list")}
),
value: 1,
@@ -345,7 +326,7 @@ export default function UserListView({
) : (
- No Users Found
+ {t("no_users_found")}
)}
diff --git a/src/components/ui/sidebar/facility-switcher.tsx b/src/components/ui/sidebar/facility-switcher.tsx
index 59715e4e02c..0769f2a825f 100644
--- a/src/components/ui/sidebar/facility-switcher.tsx
+++ b/src/components/ui/sidebar/facility-switcher.tsx
@@ -1,6 +1,7 @@
import { CaretSortIcon, DashboardIcon } from "@radix-ui/react-icons";
import { Hospital } from "lucide-react";
import { navigate } from "raviger";
+import { useTranslation } from "react-i18next";
import {
DropdownMenu,
@@ -27,6 +28,7 @@ export function FacilitySwitcher({
selectedFacility: UserFacilityModel | null;
}) {
const { isMobile, setOpenMobile } = useSidebar();
+ const { t } = useTranslation();
return (
@@ -42,7 +44,7 @@ export function FacilitySwitcher({
- {selectedFacility?.name || "Select Facility"}
+ {selectedFacility?.name || t("select_facility")}
@@ -56,10 +58,10 @@ export function FacilitySwitcher({
>
navigate("/")}>
- View Dashboard
+ {t("view_dashboard")}
-
Facilities
+
{t("facilities")}
{facilities.map((facility, index) => (
();
+ const { t } = useTranslation();
const openAddUserSheet = qParams.sheet === "add";
const openLinkUserSheet = qParams.sheet === "link";
@@ -70,7 +72,7 @@ export default function FacilityOrganizationUsers({ id, facilityId }: Props) {
-
Users
+
{t("users")}
- No users found.
+ {t("no_users_found")}
) : (
@@ -117,33 +119,25 @@ export default function FacilityOrganizationUsers({ id, facilityId }: Props) {
{userRole.user.first_name} {userRole.user.last_name}
-
-
+
+
{userRole.user.username}
-
-
-
- online
-
-
-
+
+
-
Role
+
{t("role")}
{userRole.role.name}
-
Phone Number
+
{t("phone_number")}
{userRole.user.phone_number}
@@ -165,7 +159,7 @@ export default function FacilityOrganizationUsers({ id, facilityId }: Props) {
icon="l-arrow-up-right"
className="h-4 w-4"
/>
-
More details
+
{t("more_details")}
}
/>
diff --git a/src/pages/FacilityOrganization/components/EditFacilityUserRoleSheet.tsx b/src/pages/FacilityOrganization/components/EditFacilityUserRoleSheet.tsx
index 39fb57115d2..3d96f2210a7 100644
--- a/src/pages/FacilityOrganization/components/EditFacilityUserRoleSheet.tsx
+++ b/src/pages/FacilityOrganization/components/EditFacilityUserRoleSheet.tsx
@@ -1,5 +1,6 @@
import { useMutation, useQuery, useQueryClient } from "@tanstack/react-query";
import { useState } from "react";
+import { useTranslation } from "react-i18next";
import { toast } from "sonner";
import {
@@ -14,6 +15,7 @@ import {
AlertDialogTrigger,
} from "@/components/ui/alert-dialog";
import { Button } from "@/components/ui/button";
+import { Label } from "@/components/ui/label";
import {
Select,
SelectContent,
@@ -31,6 +33,7 @@ import {
} from "@/components/ui/sheet";
import { Avatar } from "@/components/Common/Avatar";
+import { UserStatusIndicator } from "@/components/Users/UserListAndCard";
import routes from "@/Utils/request/api";
import mutate from "@/Utils/request/mutate";
@@ -53,6 +56,7 @@ export default function EditUserRoleSheet({
const queryClient = useQueryClient();
const [open, setOpen] = useState(false);
const [selectedRole, setSelectedRole] = useState
(userRole.role.id);
+ const { t } = useTranslation();
const { data: roles } = useQuery({
queryKey: ["roles"],
@@ -74,7 +78,7 @@ export default function EditUserRoleSheet({
queryClient.invalidateQueries({
queryKey: ["facilityOrganizationUsers", facilityId, organizationId],
});
- toast.success("User role updated successfully");
+ toast.success(t("user_role_update_success"));
setOpen(false);
},
onError: (error) => {
@@ -98,7 +102,7 @@ export default function EditUserRoleSheet({
queryClient.invalidateQueries({
queryKey: ["facilityOrganizationUsers", facilityId, organizationId],
});
- toast.success("User removed from organization successfully");
+ toast.success(t("user_removed_success"));
setOpen(false);
},
onError: (error) => {
@@ -111,7 +115,7 @@ export default function EditUserRoleSheet({
const handleUpdateRole = () => {
if (selectedRole === userRole.role.id) {
- toast.error("Please select a different role");
+ toast.error(t("select_diff_role"));
return;
}
@@ -124,13 +128,13 @@ export default function EditUserRoleSheet({
return (
- {trigger || }
+ {trigger || }
- Edit User Role
+ {t("edit_user_role")}
- Update the role for this user in the organization.
+ {t("update_user_role_organization")}
@@ -153,29 +157,30 @@ export default function EditUserRoleSheet({
-
Username
+
{t("username")}
{userRole.user.username}
-
Current Role
+
+ {t("current_role")}
+
{userRole.role.name}
-
-
Last Login
-
- {userRole.user.last_login
- ? new Date(userRole.user.last_login).toLocaleDateString()
- : "Never"}
-
+
+
+ {t("last_login")}{" "}
+
+
-
-
+