Skip to content
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

(fix) O3-4299: Missing Label in Dropdown Menu of Service Queues #1425

Merged
merged 4 commits into from
Jan 14, 2025

Conversation

harshthakkr
Copy link
Contributor

@harshthakkr harshthakkr commented Jan 3, 2025

Requirements

  • This PR has a title that briefly describes the work done including the ticket number. If there is a ticket, make sure your PR title includes a conventional commit label. See existing PR titles for inspiration.
  • My work conforms to the OpenMRS 3.0 Styleguide and design documentation.
  • My work includes tests or is validated by existing tests.

Summary

This PR addresses an issue where the second clinic metric in Service Queues displayed an empty string instead of the label 'All' when defaulting to show data for all. The label has been updated to display 'All' by default, ensuring clarity and consistency in the UI.

Screenshots

Before:
Screenshot 2025-01-03 at 6 37 10 PM

After:
Screenshot 2025-01-03 at 6 55 23 PM

Related Issue

O3-4299

@Muppasanipraneeth
Copy link
Contributor

@harshthakkr update test also

@harshthakkr
Copy link
Contributor Author

@Muppasanipraneeth I am working on it.

@harshthakkr
Copy link
Contributor Author

One test is failing due to the new year (2025). @chibongho has created a PR to update the test. Their PR needs to be merged first to ensure all e2e tests pass.

@@ -67,7 +67,7 @@ function ClinicMetrics() {
itemToString={(item) =>
item ? `${item.display} ${item.location?.display ? `- ${item.location.display}` : ''}` : ''
}
label=""
label={t('all', 'All')}
onChange={handleServiceChange}
Copy link
Member

@denniskigen denniskigen Jan 6, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hardcoding All as the label for the default item in the dropdown is not the right approach. If the goal is to show a default value for the dropdown, we should use the initialSelectedItem prop. This allows us to display a default value in the dropdown.

To achieve, this we can modify the logic as follows:

const defaultServiceItem = {
  display: `${t('all', 'All')}`,
  uuid: '',
};

const serviceItems = [defaultServiceItem, ...(services ?? [])];

And then further down the line, we can use these values to set the initialSelectedItem prop and the items prop:

<Dropdown
  initialSelectedItem={defaultServiceItem}
  items={serviceItems}
  label=""
  // ... other props
/>

Copy link
Member

@denniskigen denniskigen Jan 6, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Two nice, optional extra touches would be:

  • Annotating serviceItems with the proper types.
  • Fixing the styling of the dropdown so it's vertical alignment matches that of the label.

Copy link
Contributor Author

@harshthakkr harshthakkr Jan 9, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

  • Fixing the styling of the dropdown so it's vertical alignment matches that of the label.

I am not able to implement the proper vertical alignment here since changing the value of margin-top can cause changes globally, and I couldn't find any other solution.

:global(.cds--dropdown__wrapper--inline) {
    gap: 0;
    margin-top: -(layout.$spacing-04);
  }

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Fixed in the latest commit @harshthakkr.

@harshthakkr harshthakkr force-pushed the fix/dropdown-menu-missing-label branch from 9f50776 to e45038d Compare January 9, 2025 18:54
@denniskigen denniskigen force-pushed the fix/dropdown-menu-missing-label branch from e45038d to b7b1b57 Compare January 13, 2025 21:59
Copy link
Member

@denniskigen denniskigen left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM. Thanks, @harshthakkr!

@denniskigen denniskigen merged commit bba0f2e into openmrs:main Jan 14, 2025
6 checks passed
@harshthakkr
Copy link
Contributor Author

Thank you @denniskigen!

@harshthakkr harshthakkr deleted the fix/dropdown-menu-missing-label branch January 14, 2025 14:41
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants