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

[Multiple Datasource] Refactor data source menu and interface to allow cleaner selection of component and related configurations #6256

Merged
merged 8 commits into from
Mar 26, 2024

Conversation

BionIT
Copy link
Collaborator

@BionIT BionIT commented Mar 24, 2024

Description

This change refactors data source menu and its interface to allow cleaner selection of respective data source component and related configurations

Issues Resolved

Fixes #6239

Screenshot

refactor2.mp4

Testing the changes

The following were performed in the recording:

  1. enable data source plugin
  2. change the code of search relevance to use the interface to mount data source selectable component, and it renders successfully
  3. change the code of search relevance to use the interface to mount data source aggregated view component, and it renders successfully
  4. change the code of search relevance to use the interface to mount data source view component, and it renders successfully

Check List

  • All tests pass
    • yarn test:jest
    • yarn test:jest_integration
  • New functionality includes testing.
  • New functionality has been documented.
  • Update CHANGELOG.md
  • Commits are signed per the DCO using --signoff

BionIT added 2 commits March 22, 2024 23:45
Signed-off-by: Lu Yu <[email protected]>
Copy link

codecov bot commented Mar 24, 2024

Codecov Report

Attention: Patch coverage is 78.94737% with 4 lines in your changes are missing coverage. Please review.

Project coverage is 67.35%. Comparing base (6c25f2d) to head (291f19e).

Files Patch % Lines
...c/components/data_source_menu/data_source_menu.tsx 84.61% 0 Missing and 2 partials ⚠️
...onents/data_source_menu/data_source_selectable.tsx 0.00% 1 Missing ⚠️
...rc/plugins/data_source_management/public/plugin.ts 0.00% 1 Missing ⚠️
Additional details and impacted files
@@            Coverage Diff             @@
##             main    #6256      +/-   ##
==========================================
+ Coverage   67.34%   67.35%   +0.01%     
==========================================
  Files        3352     3353       +1     
  Lines       65082    65083       +1     
  Branches    10486    10483       -3     
==========================================
+ Hits        43831    43839       +8     
+ Misses      18699    18694       -5     
+ Partials     2552     2550       -2     
Flag Coverage Δ
Linux_1 31.82% <ø> (ø)
Linux_2 55.57% <ø> (ø)
Linux_3 44.83% <78.94%> (+0.09%) ⬆️
Linux_4 35.03% <5.26%> (-0.01%) ⬇️
Windows_1 31.84% <ø> (ø)
Windows_2 55.53% <ø> (ø)
Windows_3 44.84% <78.94%> (+0.09%) ⬆️
Windows_4 35.03% <5.26%> (-0.01%) ⬇️

Flags with carried forward coverage won't be shown. Click here to find out more.

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

return null;
}
export function DataSourceMenu<T>(props: DataSourceMenuProps<T>): ReactElement | null {
const { componentType, componentConfig } = props;
Copy link
Collaborator

Choose a reason for hiding this comment

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

Any reason why we cannot simply made the type prop be type?
Also, is there a reason to have a bunch of props clubbed into config? To me, it feels natural not club them.

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

@AMoo-Miki , this was based on discussion with @ashwin-pc @Flyingliuhub @ZilongX @yujin-emma last week to group the configs specific to a component and use generic type for better readability which I think makes a lot of sense here. If we don't do that, all the configs to all components will need to the the prop for Data Source Menu. Also, this is similar to how TopNavMenu accepts the config https://github.com/opensearch-project/OpenSearch-Dashboards/blob/main/src/plugins/navigation/public/top_nav_menu/top_nav_menu.tsx#L47

bandinib-amzn
bandinib-amzn previously approved these changes Mar 25, 2024
Comment on lines 25 to 26
setMenuMountPoint?: (menuMount: MountPoint | undefined) => void;
componentConfig: T;
Copy link
Member

Choose a reason for hiding this comment

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

same as above. Just for a sake of readability I guess

xinruiba
xinruiba previously approved these changes Mar 25, 2024
@@ -63,6 +63,7 @@ Inspired from [Keep a Changelog](https://keepachangelog.com/en/1.0.0/)
- [Workspace] Register a workspace dropdown menu at the top of left nav bar ([#6150](https://github.com/opensearch-project/OpenSearch-Dashboards/pull/6150))
- [Multiple Datasource] Add icon in datasource table page to show the default datasource ([#6231](https://github.com/opensearch-project/OpenSearch-Dashboards/pull/6231))
- [Multiple Datasource] Add TLS configuration for multiple data sources ([#6171](https://github.com/opensearch-project/OpenSearch-Dashboards/pull/6171))
- [Multiple Datasource] Refactor data source menu and interface to allow cleaner selection of component and related configurations ([#6256](https://github.com/opensearch-project/OpenSearch-Dashboards/pull/6256))
Copy link
Collaborator

Choose a reason for hiding this comment

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

Just a small trick to avoid potential changelog conflicts (since there are a lot..), instead of attaching the changelog entry as last line (L66 in this case), simply stuff it into the middle (say L64) would save the efforts to resolve changelog conflicts

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

Good to know, thanks!


interface DataSourceSelectableProps {
savedObjectsClient: SavedObjectsClientContract;
notifications: ToastsStart;
onSelectedDataSource: (dataSource: DataSourceOption) => void;
onSelectedDataSources: (dataSources: DataSourceOption[]) => void;
Copy link
Collaborator

Choose a reason for hiding this comment

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

any context of the renaming from onSelectedDataSource to onSelectedDataSources ? MDS drop down doesn't support multiple selected right ? (aka we can only select one data source at a time)

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

We are supporting multi select which is in another PR, thus changing it to selected data sources

@ZilongX ZilongX self-requested a review March 25, 2024 20:57
ZilongX
ZilongX previously approved these changes Mar 25, 2024
@BionIT BionIT dismissed stale reviews from ZilongX, xinruiba, and bandinib-amzn via 5a9206f March 25, 2024 22:40
@ZilongX ZilongX self-requested a review March 25, 2024 23:02
@BionIT BionIT merged commit 4f1884b into opensearch-project:main Mar 26, 2024
70 checks passed
opensearch-trigger-bot bot pushed a commit that referenced this pull request Mar 26, 2024
…w cleaner selection of component and related configurations (#6256)

* refactor

Signed-off-by: Lu Yu <[email protected]>

* refactor data source menu

Signed-off-by: Lu Yu <[email protected]>

* add change log

Signed-off-by: Lu Yu <[email protected]>

* move configs based on if it is required

Signed-off-by: Lu Yu <[email protected]>

* move optional params below required

Signed-off-by: Lu Yu <[email protected]>

---------

Signed-off-by: Lu Yu <[email protected]>
Co-authored-by: ZilongX <[email protected]>
(cherry picked from commit 4f1884b)
Signed-off-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>

# Conflicts:
#	CHANGELOG.md
BionIT added a commit that referenced this pull request Mar 26, 2024
…w cleaner selection of component and related configurations (#6256) (#6267)

* refactor

Signed-off-by: Lu Yu <[email protected]>

* refactor data source menu

Signed-off-by: Lu Yu <[email protected]>

* add change log

Signed-off-by: Lu Yu <[email protected]>

* move configs based on if it is required

Signed-off-by: Lu Yu <[email protected]>

* move optional params below required

Signed-off-by: Lu Yu <[email protected]>

---------

Signed-off-by: Lu Yu <[email protected]>
Co-authored-by: ZilongX <[email protected]>
(cherry picked from commit 4f1884b)
Signed-off-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>

# Conflicts:
#	CHANGELOG.md

Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>
Co-authored-by: Lu Yu <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

[Multiple Datasource] Refactor data source menu and clean up data source component configurations
5 participants