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

FEAT: Catalog Search plugin to support import catalog from Table/QTable object #3425

Merged
merged 3 commits into from
Feb 5, 2025

Conversation

pllim
Copy link
Contributor

@pllim pllim commented Feb 1, 2025

Description

This pull request is to add support for Catalog Search plugin to import table directly from existing Table/QTable object. To do this, we expose a new public API called import_catalog.

Change log entry

  • Is a change log needed? If yes, is it added to CHANGES.rst? If you want to avoid merge conflicts,
    list the proposed change log here for review and add to CHANGES.rst before merge. If no, maintainer
    should add a no-changelog-entry-needed label.

Checklist for package maintainer(s)

This checklist is meant to remind the package maintainer(s) who will review this pull request of some common things to look for. This list is not exhaustive.

  • Are two approvals required? Branch protection rule does not check for the second approval. If a second approval is not necessary, please apply the trivial label.
  • Do the proposed changes actually accomplish desired goals? Also manually run the affected example notebooks, if necessary.
  • Do the proposed changes follow the STScI Style Guides?
  • Are tests added/updated as required? If so, do they follow the STScI Style Guides?
  • Are docs added/updated as required? If so, do they follow the STScI Style Guides?
  • Did the CI pass? If not, are the failures related?
  • Is a milestone set? Set this to bugfix milestone if this is a bug fix and needs to be released ASAP; otherwise, set this to the next major release milestone. Bugfix milestone also needs an accompanying backport label.
  • After merge, any internal documentations need updating (e.g., JIRA, Innerspace)? 🐱

@pllim pllim added this to the 4.2 milestone Feb 1, 2025
@github-actions github-actions bot added documentation Explanation of code and concepts imviz plugin Label for plugins common to multiple configurations labels Feb 1, 2025
Copy link

codecov bot commented Feb 1, 2025

Codecov Report

All modified and coverable lines are covered by tests ✅

Project coverage is 87.53%. Comparing base (aedb793) to head (ace010e).
Report is 4 commits behind head on main.

Additional details and impacted files
@@           Coverage Diff           @@
##             main    #3425   +/-   ##
=======================================
  Coverage   87.53%   87.53%           
=======================================
  Files         128      128           
  Lines       19957    19962    +5     
=======================================
+ Hits        17469    17474    +5     
  Misses       2488     2488           

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

@pllim pllim marked this pull request as ready for review February 1, 2025 01:43
@camipacifici
Copy link
Contributor

Would it be in scope to add the API equivalent to clicking "search"?

@pllim
Copy link
Contributor Author

pllim commented Feb 3, 2025

API equivalent to clicking "search"

Well, the method is there, just not exposed... Gotta ask @kecnry or @javerbukh why not though.

def search(self, error_on_fail=False):

@kecnry
Copy link
Member

kecnry commented Feb 3, 2025

I suspect just because catalogs was/is still a work in progress and the API methods have not yet been exposed (except for recent work for zoom_to_selected it seems). That said, search probably is pretty safe to expose if we want.

@pllim
Copy link
Contributor Author

pllim commented Feb 3, 2025

Perhaps exposing search should be a separate ticket and it seems pretty unrelated to loading from table object. This is because we should double check if the existing signature and return value are satisfactory. Once exposed, those are hard to change without issuing notice or deprecation.

@camipacifici
Copy link
Contributor

Gotcha, thanks

@camipacifici
Copy link
Contributor

In any case, this worked with the example I had in hand. 👍

Copy link
Contributor

@gibsongreen gibsongreen left a comment

Choose a reason for hiding this comment

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

Test clean up looks great and the table code looks is clean, love the simplicity. Works as expected when testing, great job!

assert len(out_tbl) == n_entries
assert catalogs_plugin.number_of_results == n_entries
assert catalogs_plugin._obj.number_of_results == n_entries
Copy link
Contributor

Choose a reason for hiding this comment

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

why the ._obj added here (and below)?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Because I changed catalogs_plugin = imviz_helper.plugins['Catalog Search']._obj to catalogs_plugin = imviz_helper.plugins['Catalog Search'] (old: L223, new: L221) so I can accessed the public API publicly, which means I need to throw in a ._obj for all others. Hope this clarifies the matter.

Copy link
Contributor

Choose a reason for hiding this comment

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

oh i missed that, sorry! thanks for clarifying

Copy link
Contributor

@cshanahan1 cshanahan1 left a comment

Choose a reason for hiding this comment

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

looks good, just left one comment for clarification on something

@pllim pllim merged commit aa6438b into spacetelescope:main Feb 5, 2025
26 of 27 checks passed
@pllim pllim deleted the cat-load-from-table branch February 5, 2025 20:53
@pllim
Copy link
Contributor Author

pllim commented Feb 5, 2025

Thanks for the reviews!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
documentation Explanation of code and concepts imviz plugin Label for plugins common to multiple configurations Ready for final review
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants