-
Notifications
You must be signed in to change notification settings - Fork 502
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Patient header UI update in Patient details page #9377
Patient header UI update in Patient details page #9377
Conversation
WalkthroughThis pull request encompasses updates to localization, UI components, and patient-related interfaces. The changes include modifying the English localization file with spelling corrections and new keys, updating the Changes
Assessment against linked issues
Possibly related PRs
Suggested labels
Suggested reviewers
Poem
📜 Recent review detailsConfiguration used: CodeRabbit UI 📒 Files selected for processing (1)
🚧 Files skipped from review as they are similar to previous changes (1)
Thank you for using CodeRabbit. We offer it for free to the OSS community and would appreciate your support in helping us grow. If you find it useful, would you consider giving us a shout-out on your favorite social media? 🪧 TipsChatThere are 3 ways to chat with CodeRabbit:
Note: Be mindful of the bot's finite context window. It's strongly recommended to break down tasks such as reading entire modules into smaller chunks. For a focused discussion, use review comments to chat about specific files and their changes, instead of using the PR comments. CodeRabbit Commands (Invoked using PR comments)
Other keywords and placeholders
CodeRabbit Configuration File (
|
✅ Deploy Preview for care-ohc ready!
To edit notification comments on pull requests, go to your Netlify site configuration. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actionable comments posted: 1
🧹 Outside diff range and nitpick comments (1)
src/components/Patient/PatientHome.tsx (1)
279-309
: Consider memoizing the skills formatting logicThe skills formatting and tooltip rendering logic could benefit from memoization to prevent unnecessary re-renders, especially for large skill sets.
+ const formattedSkills = useMemo(() => formatSkills(skillsQuery.data?.results), + [skillsQuery.data?.results]); - {!!skillsQuery.data?.results?.length && - formatSkills(skillsQuery.data?.results)} + {!!skillsQuery.data?.results?.length && formattedSkills}
📜 Review details
Configuration used: CodeRabbit UI
Review profile: CHILL
📒 Files selected for processing (3)
public/locale/en.json
(1 hunks)src/components/Patient/PatientDetailsTab/Demography.tsx
(1 hunks)src/components/Patient/PatientHome.tsx
(1 hunks)
🔇 Additional comments (4)
src/components/Patient/PatientDetailsTab/Demography.tsx (1)
229-229
: LGTM: Safe state value access implementation
The change to use state_object?.name
with optional chaining is a safer way to access the state value and fixes the incorrect state value issue mentioned in the PR objectives.
src/components/Patient/PatientHome.tsx (2)
268-269
: LGTM: Clean layout structure
The flex layout with proper gap spacing provides a responsive and well-organized structure for the patient header.
350-432
: LGTM: Comprehensive status indicators
The status chips section effectively displays all relevant patient statuses with appropriate visual indicators and conditions.
public/locale/en.json (1)
1119-1119
: LGTM: Improved text clarity
The text change from "Patient Details" to "Details of Patient" provides better clarity in the UI.
👋 Hi, @Mahendar0701, This message is automatically generated by prince-chrismc/label-merge-conflicts-action so don't hesitate to report issues/improvements there. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actionable comments posted: 0
🧹 Outside diff range and nitpick comments (2)
src/components/ui/badge.tsx (1)
37-59
: Consider adding aria-label for icon-only scenarios.The implementation looks good! For better accessibility, consider adding aria-label when the badge contains only icons without text.
- {startIcon && <CareIcon icon={startIcon} className="mr-1" />} + {startIcon && <CareIcon icon={startIcon} className="mr-1" aria-label={startIcon} />} <span>{props.children}</span> - {endIcon && <CareIcon icon={endIcon} className="ml-1" />} + {endIcon && <CareIcon icon={endIcon} className="ml-1" aria-label={endIcon} />}src/components/Patient/PatientHome.tsx (1)
568-577
: Consider consolidating transfer status logic.The transfer status badge could be simplified using a single conditional render.
- {patientData.allow_transfer ? ( - <Badge variant="success" startIcon="l-unlock"> - {t("transfer_allowed")} - </Badge> - ) : ( - <Badge variant="warning" startIcon="l-lock"> - {t("transfer_blocked")} - </Badge> - )} + <Badge + variant={patientData.allow_transfer ? "success" : "warning"} + startIcon={patientData.allow_transfer ? "l-unlock" : "l-lock"} + > + {t(patientData.allow_transfer ? "transfer_allowed" : "transfer_blocked")} + </Badge>
📜 Review details
Configuration used: CodeRabbit UI
Review profile: CHILL
Plan: Pro
📒 Files selected for processing (2)
src/components/Patient/PatientHome.tsx
(5 hunks)src/components/ui/badge.tsx
(3 hunks)
🔇 Additional comments (3)
src/components/ui/badge.tsx (1)
19-26
: LGTM! Well-structured variant definitions.
The new variants (alert, danger, success) are properly defined with appropriate color schemes and hover states.
src/components/Patient/PatientHome.tsx (2)
291-434
: LGTM! Well-structured patient header layout.
The new layout effectively organizes patient information with clear sections for:
- Facility details
- Treating doctor with skills tooltip
- Assigned doctor with WhatsApp integration
- Assigned volunteer
- Status badges with appropriate visual indicators
347-355
:
Security: Enhance WhatsApp link sanitization.
The current phone number sanitization can be improved for better security.
This was previously flagged in an earlier review. Please implement the suggested phone number sanitization function.
@Jacobjeevan i replaced chip with badge . can you once look into it |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actionable comments posted: 0
🧹 Nitpick comments (1)
src/components/Common/AuthorizedButton.tsx (1)
13-17
: Consider enhancing prop validationWhile the authorizeFor validation is good, consider adding type checking to ensure the prop is of the correct type when provided.
if (!authorizeFor) { throw new Error( "The 'authorizeFor' prop is required for AuthorizedButton.", ); } +if (typeof authorizeFor !== 'string' && !Array.isArray(authorizeFor)) { + throw new Error( + "The 'authorizeFor' prop must be a string or an array of strings.", + ); +}
📜 Review details
Configuration used: CodeRabbit UI
Review profile: CHILL
Plan: Pro
📒 Files selected for processing (1)
src/components/Common/AuthorizedButton.tsx
(2 hunks)
🔇 Additional comments (4)
src/components/Common/AuthorizedButton.tsx (4)
9-12
: LGTM! Clean component declaration with proper type definitions
The component declaration properly combines both ButtonProps and AuthorizedElementProps types, ensuring proper type checking for all props.
Line range hint 18-27
: LGTM! Clean implementation with proper prop handling
The component correctly handles authorization logic and properly combines the disabled state with authorization status.
29-29
: LGTM! Clean default export
The default export aligns with modern React practices and provides flexibility in importing.
5-5
: Verify the Button component styling compatibility
The Button component import has been changed from headlessui to a local UI component. Please ensure that this change maintains consistent styling and behavior across all usage locations.
✅ Verification successful
Let me gather more information about the Button component usage to better understand the impact.
Let me check one more thing to understand the Button component's implementation and its compatibility.
Button component change is compatible and safe
The change from headlessui to the local UI Button component is safe and maintains consistent styling and behavior because:
- The local Button component is a well-structured component with proper styling variants and size options
- The AuthorizedButton correctly forwards all ButtonProps and handles the disabled state appropriately
- The Button component is widely used across the codebase (20+ files) as the standard button implementation
🏁 Scripts executed
The following scripts were executed for the analysis:
Script:
#!/bin/bash
# Find all files that use AuthorizedButton to verify visual consistency
rg -l "AuthorizedButton" | xargs rg -l "Button.*disabled.*isAuthorized"
Length of output: 114
Script:
#!/bin/bash
# Check the implementation of the local Button component
ast-grep --pattern 'export function Button($$$) { $$$ }' src/components/ui/button.tsx
# Find all usages of AuthorizedButton to understand its implementation
ast-grep --pattern 'const AuthorizedButton = $$$' src/components/Common/AuthorizedButton.tsx
# Find other Button usages in the codebase for consistency
rg "from.*components/ui/button" -A 2
Length of output: 5135
Script:
#!/bin/bash
# Check the Button component's implementation
cat src/components/ui/button.tsx
# Check the AuthorizedButton implementation to see how it uses the Button component
cat src/components/Common/AuthorizedButton.tsx
Length of output: 3398
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actionable comments posted: 0
🧹 Nitpick comments (2)
src/components/Common/AuthorizedButton.tsx (2)
Line range hint
13-23
: Consider extracting button-specific propsWhile the implementation is clean, spreading all props to the Button component might pass unnecessary props. Consider extracting only ButtonProps:
-const AuthorizedButton: React.FC<AuthorizedButtonProps> = (props) => { +const AuthorizedButton: React.FC<AuthorizedButtonProps> = ({ authorizeFor, children, ...buttonProps }) => { return ( - <AuthorizedChild authorizeFor={props.authorizeFor}> + <AuthorizedChild authorizeFor={authorizeFor}> {({ isAuthorized }) => ( - <Button {...props} disabled={props.disabled || !isAuthorized}> - {props.children} + <Button {...buttonProps} disabled={buttonProps.disabled || !isAuthorized}> + {children} </Button> )} </AuthorizedChild> ); };
25-25
: Consider using named exportWhile default exports work, named exports are generally preferred for better maintainability and refactoring support. However, if this follows your project's conventions, feel free to keep it as is.
-export default AuthorizedButton; +export { AuthorizedButton };
📜 Review details
Configuration used: CodeRabbit UI
Review profile: CHILL
Plan: Pro
📒 Files selected for processing (1)
src/components/Common/AuthorizedButton.tsx
(2 hunks)
🔇 Additional comments (2)
src/components/Common/AuthorizedButton.tsx (2)
1-7
: LGTM! Clean import organization
The imports are well-structured using absolute paths and properly organized by separating external (React) from internal dependencies.
9-11
: LGTM! Well-structured type definition
The AuthorizedButtonProps
type effectively combines the necessary props while making authorizeFor
mandatory, addressing the previous review feedback.
@rithviknishad can you please update review and let me know if any changes are required. |
👋 Hi, @Mahendar0701, This message is automatically generated by prince-chrismc/label-merge-conflicts-action so don't hesitate to report issues/improvements there. |
Proposed Changes
Fixes Update Patient Header and state value in Patient details page #9376
Updated patient Header
Updated state value in demography tab
Updated tranfer labels to relevant colours
@ohcnetwork/care-fe-code-reviewers
Merge Checklist
Summary by CodeRabbit
New Features
Bug Fixes
Refactor
Style