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

EOmaps #138

Closed
14 of 30 tasks
raphaelquast opened this issue Sep 26, 2023 · 46 comments
Closed
14 of 30 tasks

EOmaps #138

raphaelquast opened this issue Sep 26, 2023 · 46 comments
Assignees

Comments

@raphaelquast
Copy link

raphaelquast commented Sep 26, 2023

Submitting Author: Raphael Quast (@raphaelquast)
All current maintainers: @raphaelquast
Package Name: EOmaps
One-Line Description of Package: EOmaps is a python package to visualize, analyze and compare geographical datasets.
Repository Link: https://github.com/raphaelquast/EOmaps
Version submitted: 7.3
Editor: @banesullivan
Reviewer 1: @yeelauren
Reviewer 2: @jhkennedy
Archive: DOI
Version accepted: 8.0.2
Date accepted (month/day/year): 03/14/2024


Code of Conduct & Commitment to Maintain Package

Description

EOmaps is a python package to visualize, analyze and compare geographical datasets.

It is intended to simplify the process of geospatial data visualization and to provide a straight forward way to turn the maps into interactive widgets for data analysis.

EOmaps is based on matplotlib and cartopy and extends cartopy's capabilities with the following features

  • Multi-layer capabilities (compare/combine/overlay multiple layers)
  • North-arrows, scalebars, gridlines on arbitrary projections, ...
  • A PyQt5 GUI widget that can be used to quickly fetch webmaps, switch layers, check data-values etc.
  • Capabilities to visualize datasets as ellipses, rectangles, geodesic circles, voronoi diagrams, contour plots ...
  • Integration with datashader to visualize extremely large datasets
  • A flexible API to quickly turn the maps into fully customizable interactive data-analysis widgets
  • ...and many more features...

It is extensively documented, unit-tested, citable via a zenodo and installable via conda or pip.
(However using pip is discouraged since dependencies like GDAL and PYPROJ can be difficult to install, especially on windows)

Scope

  • Please indicate which category or categories.
    Check out our package scope page to learn more about our
    scope. (If you are unsure of which category you fit, we suggest you make a pre-submission inquiry):

    • Data retrieval
    • Data extraction
    • Data processing/munging
    • Data deposition
    • Data validation and testing
    • Data visualization1
    • Workflow automation
    • Citation management and bibliometrics
    • Scientific software wrappers
    • Database interoperability

Domain Specific & Community Partnerships

- [x] Geospatial
- [ ] Education
- [ ] Pangeo

Community Partnerships

If your package is associated with an
existing community please check below:

  • For all submissions, explain how the and why the package falls under the categories you indicated above. In your explanation, please address the following points (briefly, 1-2 sentences for each):

    • Who is the target audience and what are scientific applications of this package?

      The target audience for EOmaps are scientists and researchers working with geospatial datasets.
      EOmaps can be used to quilkly visualize structured (or unstructured) geo-spatial datasets, compare multiple datasets with each other or compare maps to an extensive list of open access webmap services. Since EOmaps is based on matplotlib, the created maps can also be connected to ordinary matplotlib axes to analyze multi-dimensional (e.g. timeseries) data.

      In addition to the interactive capabilities, maps created with EOmaps can be exported as high-resolution images or vector-graphics to create publication-ready plots.

      Finally, I believe that EOmaps also has great potential to be used in education to teach about projections, distortions, spatial resolution, rasterization of data, the subtleties of big-data visualization etc.

    • Are there other Python packages that accomplish the same thing? If so, how does yours differ?

      EOmaps is based on cartopy. While cartopy provides similar functionalities in terms of data
      visualization, EOmaps greatly extends these capabilities (especially for large datasets),
      adds multi-layer support, a basic GUI, easy-access to webmaps, and many more features.

      There exist other packages that focus on interactive geo-data visualization, but to my knowledge
      none that focusses on local use in pure python.

      • folium (wrapper for javascript-library leaflet)
      • geemap (wrapper for google-earth-engine)
      • geoviews (provides an api for matplotlib, but it is a much more high-level plotting library than EOmaps)
    • If you made a pre-submission enquiry, please paste the link to the corresponding issue, forum post, or other discussion, or @tag the editor you contacted:

      EOmaps #137

Technical checks

For details about the pyOpenSci packaging requirements, see our packaging guide. Confirm each of the following by checking the box. This package:

  • does not violate the Terms of Service of any service it interacts with.
  • uses an OSI approved license.
  • contains a README with instructions for installing the development version.
  • includes documentation with examples for all functions.
  • contains a tutorial with examples of its essential functions and uses.
  • has a test suite.
  • has continuous integration setup, such as GitHub Actions CircleCI, and/or others.

Publication Options

JOSS Checks
  • The package has an obvious research application according to JOSS's definition in their submission requirements. Be aware that completing the pyOpenSci review process does not guarantee acceptance to JOSS. Be sure to read their submission requirements (linked above) if you are interested in submitting to JOSS.
  • The package is not a "minor utility" as defined by JOSS's submission requirements: "Minor ‘utility’ packages, including ‘thin’ API clients, are not acceptable." pyOpenSci welcomes these packages under "Data Retrieval", but JOSS has slightly different criteria.
  • The package contains a paper.md matching JOSS's requirements with a high-level description in the package root or in inst/.
  • The package is deposited in a long-term repository with the DOI:

Note: JOSS accepts our review as theirs. You will NOT need to go through another full review. JOSS will only review your paper.md file. Be sure to link to this pyOpenSci issue when a JOSS issue is opened for your package. Also be sure to tell the JOSS editor that this is a pyOpenSci reviewed package once you reach this step.

Are you OK with Reviewers Submitting Issues and/or pull requests to your Repo Directly?

This option will allow reviewers to open smaller issues that can then be linked to PR's rather than submitting a more dense text based review. It will also allow you to demonstrate addressing the issue via PR links.

  • Yes I am OK with reviewers submitting requested changes as issues to my repo. Reviewers will then link to the issues in their submitted review.

Confirm each of the following by checking the box.

  • I have read the author guide.
  • I expect to maintain this package for at least 2 years and can help find a replacement for the maintainer (team) if needed.

Please fill out our survey

P.S. Have feedback/comments about our review process? Leave a comment here

Editor and Review Templates

The editor template can be found here.

The review template can be found here.

Footnotes

  1. Please fill out a pre-submission inquiry before submitting a data visualization package.

@arianesasso
Copy link

Dear @raphaelquast, thank you for submitting to pyOpenSci! I saw that @NickleDave already looked into your pre-submission and it went well 🎉. I am performing the EIC (editor in chief) checks for EOmaps and will update you by tomorrow!

@raphaelquast
Copy link
Author

Hey @arianesasso. Just checking in to see if there are any updates on the EOmaps submission yet?

In the meantime I've pushed to EOmaps v7.2 to address some reported issues and since the formal review process did not yet start, I've also updated the "submitted version" above to v7.2 (please let me know in case this is not OK). Thanks!

@arianesasso
Copy link

Hello @raphaelquast, I am really sorry for the delay, there were some unforeseen tasks this week on my side. Thank you for letting me know about the update, I will check it with the other editors but should be okay! Would it also be fine for you to wait till the end of this week for us to start the review formally? Thank you again for your patience 🙏🏼

@raphaelquast
Copy link
Author

@arianesasso thanks for the quick response! I fully understand that editor/reviewer activities sometimes have to be put on the waiting list for a few days. Take your time!

@NickleDave
Copy link
Contributor

NickleDave commented Oct 11, 2023

Hi @raphaelquast thank you for your continued patience.
We are still looking for an editor with spatial expertise for this review.

In the meantime, here are the initial editor checks. As expected, EOmaps passes with flying colors.

Editor in Chief checks

Please check our Python packaging guide for more information on the elements
below.

  • Installation The package can be installed from a community repository such as PyPI (preferred), and/or a community channel on conda (e.g. conda-forge, bioconda).
    • More difficult to install with pip because of native dependencies (e.g. GDAL) but conda works fine
    • The package imports properly into a standard Python environment import package.
  • Fit The package meets criteria for fit and overlap.
  • Documentation The package has sufficient online documentation to allow us to evaluate package function and scope without installing the package. This includes:
  • Core GitHub repository Files
    • README The package has a README.md file with clear explanation of what the package does, instructions on how to install it, and a link to development instructions.
    • Contributing File The package has a CONTRIBUTING.md file that details how to install and contribute to the package.
    • Code of Conduct The package has a Code_of_Conduct.md file.
    • License The package has an OSI approved license.
      NOTE: We prefer that you have development instructions in your documentation too.
  • Issue Submission Documentation All of the information is filled out in the YAML header of the issue (located at the top of the issue template).
  • Automated tests Package has a testing suite and is tested via a Continuous Integration service.
  • Repository The repository link resolves correctly.
  • Package overlap The package doesn't entirely overlap with the functionality of other packages that have already been submitted to pyOpenSci.
  • Archive (JOSS only, may be post-review): The repository DOI resolves correctly.
  • Version (JOSS only, may be post-review): Does the release version given match the GitHub release (v1.0.0)?

  • Initial onboarding survey was filled out
    We appreciate each maintainer of the package filling out this survey individually. 🙌
    Thank you authors in advance for setting aside five to ten minutes to do this. It truly helps our organization. 🙌


Editor comments

None except nice work 🙂

@raphaelquast
Copy link
Author

@NickleDave
Thanks! Great to hear that initial checks turned out fine!

Two quick points from my side:

  • There is actually a code-of-conduct implemented: CODE_OF_CONDUCT.md
  • Since there's no review activity yet, I'd like to push the submitted version up to v7.2.1 to incorporate latest fixes.

@NickleDave
Copy link
Contributor

NickleDave commented Oct 19, 2023

Ah, whoops, sorry I failed to mark the code-of-conduct box, I saw it but missed the checkbox. Fixed now.

Since there's no review activity yet, I'd like to push the submitted version up to v7.2.1 to incorporate latest fixes.

No worries. We will make sure that's clear here. You can feel free to change the metadata in your initial comment above, or I can.

We are getting close to finding an editor. Thanks again for your continued patience, and expect us to reply back early next week.

@raphaelquast
Copy link
Author

OK, thanks! Metadata is updated.

We are getting close to finding an editor. Thanks again for your continued patience, and expect us to reply back early next week.

Awesome! looking forward to getting this started!

@NickleDave
Copy link
Contributor

Hi @raphaelquast happy to report that @banesullivan will be the editor for this review, and that he has already started looking for reviewers

@raphaelquast
Copy link
Author

Hey @NickleDave, that's great news! Thanks for the update!

@banesullivan
Copy link
Collaborator

I thought I'd chime in with a quick update so you don't think I've gone dark: I have found one reviewer and I'm still trying to confirm a second reviewer. Hopefully, I'll have an update in the coming days!

@raphaelquast
Copy link
Author

@banesullivan Hey, thanks for the info! I fully understand that it can be tough to find reviewers and I'm grateful for the time you invest here!

@NickleDave NickleDave moved this to under-review in peer-review-status Nov 15, 2023
@banesullivan
Copy link
Collaborator

banesullivan commented Nov 16, 2023

👋 Hi @yeelauren and @jhkennedy! Thank you for volunteering to review for pyOpenSci!

Please fill out our pre-review survey

Before beginning your review, please fill out our pre-review survey. This helps us improve all aspects of our review and better understand our community. No personal data will be shared from this survey - it will only be used in an aggregated format by our Executive Director to improve our processes and programs.

The following resources will help you complete your review:

  1. Here is the reviewers guide. This guide contains all of the steps and information needed to complete your review.
  2. Here is the review template that you will need to fill out and submit here as a comment, once your review is complete.

Please get in touch with any questions or concerns! Your review is due ~6th of December 2023

Reviewers: @yeelauren @jhkennedy
Due date: 2023-12-06

@yeelauren
Copy link

yeelauren commented Dec 4, 2023

Hi 👋 @raphaelquast ! Great work this far and happy to e-meet you!

Package Review

Please check off boxes as applicable, and elaborate in comments below. Your review is not limited to these topics, as described in the reviewer guide

  • As the reviewer I confirm that there are no conflicts of interest for me to review this work (If you are unsure whether you are in conflict, please speak to your editor before starting your review).

Documentation

The package includes all the following forms of documentation:

  • A statement of need clearly stating problems the software is designed to solve and its target audience in README.
  • Installation instructions: for the development version of the package and any non-standard dependencies in README.
  • Vignette(s) demonstrating major functionality that runs successfully locally.
  • Function Documentation: for all user-facing functions.
  • Examples for all user-facing functions.
  • Community guidelines including contribution guidelines in the README or CONTRIBUTING.
  • Metadata including author(s), author e-mail(s), a url, and any other relevant metadata e.g., in a pyproject.toml file or elsewhere.

Readme file requirements
The package meets the readme requirements below:

  • Package has a README.md file in the root directory.

The README should include, from top to bottom:

  • The package name
  • Badges for:
    • Continuous integration and test coverage,
    • Docs building (if you have a documentation website),
    • A repostatus.org badge,
    • Python versions supported,
    • Current package version (on PyPI / Conda).

NOTE: If the README has many more badges, you might want to consider using a table for badges: see this example. Such a table should be more wide than high. (Note that the a badge for pyOpenSci peer-review will be provided upon acceptance.)

  • Short description of package goals.
  • Package installation instructions
  • Any additional setup required to use the package (authentication tokens, etc.)
  • Descriptive links to all vignettes. If the package is small, there may only be a need for one vignette which could be placed in the README.md file.
    • Brief demonstration of package usage (as it makes sense - links to vignettes could also suffice here if package description is clear)
  • Link to your documentation website.
  • If applicable, how the package compares to other similar packages and/or how it relates to other packages in the scientific ecosystem.
  • Citation information

Usability

Reviewers are encouraged to submit suggestions (or pull requests) that will improve the usability of the package as a whole.
Package structure should follow general community best-practices. In general please consider whether:

  • Package documentation is clear and easy to find and use.
  • The need for the package is clear
  • All functions have documentation and associated examples for use
  • The package is easy to install

Functionality

  • Installation: Installation succeeds as documented.
  • Functionality: Any functional claims of the software been confirmed.
  • Performance: Any performance claims of the software been confirmed.
  • Automated tests:
    • All tests pass on the reviewer's local machine for the package version submitted by the author. Ideally this should be a tagged version making it easy for reviewers to install.
    • Tests cover essential functions of the package and a reasonable range of inputs and conditions.
  • Continuous Integration: Has continuous integration setup (We suggest using Github actions but any CI platform is acceptable for review)
  • Packaging guidelines: The package conforms to the pyOpenSci packaging guidelines.
    A few notable highlights to look at:
    • Package supports modern versions of Python and not End of life versions.
    • Code format is standard throughout package and follows PEP 8 guidelines (CI tests for linting pass)

For packages also submitting to JOSS

Note: Be sure to check this carefully, as JOSS's submission requirements and scope differ from pyOpenSci's in terms of what types of packages are accepted.

The package contains a paper.md matching JOSS's requirements with:

  • A short summary describing the high-level functionality of the software
  • Authors: A list of authors with their affiliations
  • A statement of need clearly stating problems the software is designed to solve and its target audience.
  • References: With DOIs for all those that have one (e.g. papers, datasets, software).

Final approval (post-review)

  • The author has responded to my review and made changes to my satisfaction. I recommend approving this package.

Estimated hours spent reviewing: ~2:45 onboarding, 6 hr reviewing


Review Comments

I really like the number of examples, blog articles and documentation provided. The docstrings within the package are very well done as well! I'll definitely be excited to use this package for future work :)

I have a few questions and some suggestions below, happy to provide them as separate issues to discuss as well:

Questions

While I can definitely see the use-case for eomaps, in terms of this review, I think the README and documentation could use a line or two about what the package is and why you might want to use it stated more explicitly.

Since this package is building on cartopy, what were the motivations for creating a separate package versus adding a PR/additional functionality to cartopy directly?

Suggestions/Troubleshooting

  • The inclusion of specific instructions in the setup for various IDES makes me wonder if I missed some steps for my initial set-up using VSCode. I'd argue that a lot of Developers and Data Scientists are users of VSCode so instructions should be included.
    • Add instructions for VSCode
  • Provide instructions on notebook setup with examples? e.g. use jupyter, quarto, etc. to implement some of the notebook cell tricks in https://eomaps.readthedocs.io/en/latest/FAQ.html#from-0-to-eomaps-a-quickstart-guide

Tests

  • When trying to run tests on my machine (ubuntu) I received this:
    qt.qpa.plugin: Could not find the Qt platform plugin "wayland" in ""
    • Is this an error I can ignore? It seems to be related to matplotlib and how ubuntu is rendering the graphics?
  • Some errors and deprecation warnings come up while running the test(s) that may need to be addressed in a future version
  • Happy to approve package once I can confirm or troubleshoot the error above

@jhkennedy
Copy link

Since the review is due today, I just wanted to check in and say I'm working on it and will try and get it done by Friday, or next week at the worst. Sorry for the delay!

@raphaelquast
Copy link
Author

raphaelquast commented Dec 7, 2023

Hey @yeelauren,
Thank you very much for your review!
Below you can find a detailed response to your comments (associated adjustments in the package will follow as soon as possible).


I really like the number of examples, blog articles and documentation provided. The docstrings within the package are very well done as well! I'll definitely be excited to use this package for future work :)

Thanks for the kind words! I put a lot of effort in extensively documenting the package since I think it is extremely important (especially for beginners) to get as much information and examples as possible.


While I can definitely see the use-case for eomaps, in terms of this review, I think the README and documentation could use a line or two about what the package is and why you might want to use it stated more explicitly.

Glad to hear that you feel that the package is useful! I agree that the README can be improved... I'll try to come up with some improvements and report back here as soon as they are implemented!


Since this package is building on cartopy, what were the motivations for creating a separate package versus adding a PR/additional functionality to cartopy directly?

Cartopy is closely tied to the matplotlib syntax. Since my intention was to provide a package that goes beyond static maps and provides functionalities specifically tuned for interactive geo-data analysis, supercharging Figure or Axes objects with additional methods didn't seem like a good approach.
To be a bit more specific:

  • multi-layer capabilities require extensive adaptions on the way how draw-events are handled in matplotlib
    I am unsure if such modifications are in scope for cartopy
  • to simplify interacting with datasets, EOmaps keeps track of the datasets that were used to create the map and provides means to quickly identify nearest-neighbors etc.. (e.g. "pick callbacks" m.cb.pick...). For pure cartopy plots there is no need for this additional complexity.
  • With EOmaps I wanted to also provide a more hands-on approach by providing a PyQt5 GUI widget... again I'm not sure something like this would be in scope for cartopy
  • ...

In general, I try my best to port relevant fixes to cartopy, and it might even be good to one day have a unified package that does it all (or simply a more clear split between what goes into cartopy and what goes into EOmaps), but this would require a lot of time and effort. Right now, with 0 financial support (and ~0.01 contributors) this is out of scope for me.
I am open to participating in discussions on the future of the packages. At the moment my personal focus is to find maintainers and contributors (and ideally financial support) for EOmaps, to clean-up the codebase and to make the API stable and easy-to-use.


The inclusion of specific instructions in the setup for various IDES makes me wonder if I missed some steps for my initial set-up using VSCode. I'd argue that a lot of Developers and Data Scientists are users of VSCode so instructions should be included.

Yes, I agree. I will get myself a copy of VSCode and see what steps are required to get EOmaps running properly and include it in the docs!

✓ Implemented! (see here)


Provide instructions on notebook setup with examples? e.g. use jupyter, quarto, etc. to implement some of the notebook cell tricks in https://eomaps.readthedocs.io/en/latest/FAQ.html#from-0-to-eomaps-a-quickstart-guide

The main reason why Jupyter Notebooks are a bit under-represented in the docs at the moment is that the interactivity is affected by a bug in the interactive jupyter-matplotlib backend ipympl. I tried my best to help leveraging a solution by investigating problems of the python-side of ipympl (see raphaelquast/EOmaps#62) and the associated webagg backend (see matplotlib/matplotlib#27160) , but so far there is little progress concerning Jupyter notebooks since the problem requires adaptions in the javascript code (and my experience with js is limited).

Nonetheless, static maps now work just fine (and even interactivity is OK if update triggers are not too fast) so I agree that it might be time to better highlight the usability of EOmaps with Jupyter Notebooks in the docs.

My current idea is to actually completely refactor the Examples section. I gained some experience using myst_nb recently and I was thinking about using it to re-write all examples directly as Jupyter Notebooks and render them to the docs.

This will also help introducing a better structure for the examples (e.g. simple - advanced / static - interactive / ...).
I will try to start this process as soon as possible, but it might take some time until I created a decent number of examples.


When trying to run tests on my machine (ubuntu) I received this: qt.qpa.plugin: Could not find the Qt platform plugin "wayland" in ""

So far I have never encountered this error and unfortunately I cannot reproduce it locally (tested on Linux Mint 21.2 Cinnamon) and also GitHub actions currently run on Ubuntu 22.04.3 and do not seem to be affected by this.

After doing some research, it seems to be a more general issue with Qt that affects multiple other packages as well. I'm not sure what I can do to solve this except for pointing you to some associated discussions I found that might provide some (OS-specific) workarounds:

If you feel that there is something that I can do in EOmaps to resolve this, please open an Issue and I'll do my best to help in finding a solution!


Some errors and deprecation warnings come up while running the test(s) that may need to be addressed in a future version

I had a close look at the warnings reported in the latest test-run (from here):

  • cartopy DownloadWarning can savely be ignored. They just indicate that the associated NaturalEarth dataset has never been accessed before and needs to be downloaded (and cached for future use).

  • geopandas UserWarning: Geometry is in a geographic CRS. ... can savely be ignored. it just indicates that geometry.buffer(..) was used in a geographic crs and therefore the size of the buffer might vary depending on the location of the data.

  • numpy RuntimeWarning: numpy.ndarray size changed, may indicate binary incompatibility.:
    This indicates that the uploaded NetCDF file was created with an earlier numpy version... I'll update the associated test-dataset!
    (see EOmaps #138 (comment))

  • numpy UserWarning: Warning: 'partition' will ignore the 'mask' of the MaskedArray.: I have to investigate this.

  • geopandas FutureWarning: In a future version, "df.iloc[:, i] = newvals" will attempt to set the values inplace instead of always setting a new array. To retain the old behavior, use either "df[df.columns[i]] = newvals" or, if columns are non-unique, "df.isetitem(i, newvals)": I have to investigate this

  • DeprecationWarning: invalid escape sequence '\*' This is from a docstring.
    It originates from trying to document what happens with additional keyword-arguments, e.g. **kwargs
    The problem here is that in re-structured text and markdown, ** is also used for bold-text which is why I had to escape \*. It seems that this is now Deprecated and I have to find a better solution.
    I'm happy about any suggestions for a clean way how to do this!

    To clarify, I'd need a "re-structured-text and markdown save" version of a docstring like this that can be parsed with sphinx-autodoc:

     def func(**kwargs):
     	"""
     	A nice function.
     	
     	Parameters
     	----------
     	**kwargs: 
     		Keyword-arguments passed to print.
     	"""
     	print(kwargs)
    

@raphaelquast
Copy link
Author

@yeelauren Basic info on how to use VSCode/VSCodium is now added to the docs!
(currently still in dev-branch for next release since there are also changes in the way how the docs are built).
You can have a look at the updated content here.

@raphaelquast
Copy link
Author

raphaelquast commented Dec 13, 2023

@yeelauren I had a closer look at the numpy RuntimeWarning that appears in the tests...

numpy RuntimeWarning: numpy.ndarray size changed, may indicate binary incompatibility.: This indicates that the uploaded NetCDF file was created with an earlier numpy version... I'll update the associated test-dataset!

This is apparently caused by some unresolved issue regarding the import-order of numpy and netCDF4.
Here is the associated (open) issue from xarray: pydata/xarray#7259

My solution for now is to try to import netCDF4 on init to ensure it is imported prior to numpy to address this warning.
(see raphaelquast/EOmaps@da5de8d and the associated test-run)

@jhkennedy
Copy link

jhkennedy commented Dec 15, 2023

Overall fantastic work @raphaelquast!

Package Review

Please check off boxes as applicable, and elaborate in comments below. Your review is not limited to these topics, as described in the reviewer guide

  • As the reviewer I confirm that there are no conflicts of interest for me to review this work (If you are unsure whether you are in conflict, please speak to your editor before starting your review).

Documentation

The package includes all the following forms of documentation:

  • A statement of need clearly stating problems the software is designed to solve and its target audience in README.
  • Installation instructions: for the development version of the package and any non-standard dependencies in README.
  • Vignette(s) demonstrating major functionality that runs successfully locally.
  • Function Documentation: for all user-facing functions.
  • Examples for all user-facing functions.
  • Community guidelines including contribution guidelines in the README or CONTRIBUTING.
  • Metadata including author(s), author e-mail(s), a url, and any other relevant metadata e.g., in a pyproject.toml file or elsewhere.

Readme file requirements
The package meets the readme requirements below:

  • Package has a README.md file in the root directory.

The README should include, from top to bottom:

  • The package name
  • Badges for:
    • Continuous integration and test coverage,
    • Docs building (if you have a documentation website),
    • A repostatus.org badge,
    • Python versions supported,
    • Current package version (on PyPI / Conda).

NOTE: If the README has many more badges, you might want to consider using a table for badges: see this example. Such a table should be more wide than high. (Note that a badge for pyOpenSci peer-review will be provided upon acceptance.)*

  • Short description of package goals.
  • Package installation instructions
  • Any additional setup required to use the package (authentication tokens, etc.)
  • Descriptive links to all vignettes. If the package is small, there may only be a need for one vignette which could be placed in the README.md file.
    • Brief demonstration of package usage (as it makes sense - links to vignettes could also suffice here if package description is clear)
  • Link to your documentation website.
  • If applicable, how the package compares to other similar packages and/or how it relates to other packages in the scientific ecosystem.
  • Citation information

Usability

Reviewers are encouraged to submit suggestions (or pull requests) that will improve the usability of the package as a whole.
Package structure should follow general community best-practices. In general please consider whether:

  • Package documentation is clear and easy to find and use.
  • The need for the package is clear
  • All functions have documentation and associated examples for use
  • The package is easy to install

Functionality

  • Installation: Installation succeeds as documented.
  • Functionality: Any functional claims of the software been confirmed.
  • Performance: Any performance claims of the software been confirmed.
  • Automated tests:
    • All tests pass on the reviewer's local machine for the package version submitted by the author. Ideally this should be a tagged version making it easy for reviewers to install.
    • Tests cover essential functions of the package and a reasonable range of inputs and conditions.
  • Continuous Integration: Has continuous integration setup (We suggest using Github actions but any CI platform is acceptable for review)
  • Packaging guidelines: The package conforms to the pyOpenSci packaging guidelines.
    A few notable highlights to look at:
    • Package supports modern versions of Python and not End of life versions.
    • Code format is standard throughout package and follows PEP 8 guidelines (CI tests for linting pass)

For packages also submitting to JOSS

Note: Be sure to check this carefully, as JOSS's submission requirements and scope differ from pyOpenSci's in terms of what types of packages are accepted.

The package contains a paper.md matching JOSS's requirements with:

  • A short summary describing the high-level functionality of the software
  • Authors: A list of authors with their affiliations
  • A statement of need clearly stating problems the software is designed to solve and its target audience.
  • References: With DOIs for all those that have one (e.g. papers, datasets, software).

Final approval (post-review)

  • The author has responded to my review and made changes to my satisfaction. I recommend approving this package.

Estimated hours spent reviewing: 2 on-boarding; 4-6 playing/using.


Review Comments

Overall

Overall, I'm really excited about this package, and it significantly reduces some of the boilerplate for the CartoPy maps I've produced in the past. Coming to the GitHub, I was impressed with the README, releases, and release notes immediately, and I could see many of the "community standards" (e.g., code of conduct, contributing, license, etc.) right up front.

The documentation is fantastic, as well as the examples, and it was overall pretty easy to jump in as a user.

I find myself wishing you were submitting to JOSS so you could expand on the why -- why create the package, why you designed it the way you did, etc., which @yeelauren also hit on. I think JOSS is likely a better place for that than in the README or docs.

Detailed Comments

Note: I'm reviewing specifically v7.3.2, as that was latest v7.3 release when I started in seriously.

A) First impressions
  1. Using a copy-left license like GPL means, for me, I will happily use and contribute to EOMaps, but I will be unable to build upon it as I'm obligated to use a permissive use license in my work. This is fine for EOMaps for the most part, I think, as it's more of an end-user package than a library.

  2. On the repository main page on GitHub, in the "About" (upper-left) there's a documentation link pointing to github.io but the README and rest of the docs links point to readthedocs.io -- I'd change the about to also point to ReadTheDocs

  3. It's time to move from setup.py to pyproject.toml

  4. It's not clear what python versions EOMaps supports:

    1. There's no badge on the README, or in the PyPI metadata about supported versions
    2. python_requires is not set in setup.py
    3. classifiers in the setup.py only list Python 3.7, but I see that EOMaps is only tested on Python 3.8-3.10
    4. The conda-forge recipe supports Python >=3.6, so users can install into Python 3.11 and 3.12, but it's not being tested on those versions

    I'd really like to see this cleaned up, with the supported python versions clearly listed, and all supported versions tested.

    *Note: I also have some additional comments related to this when setting up a development environment.

B) Setting up a development environment
  1. This proved a bit more challenging as there was no top-level environment.yml or requirements.txt that'd set up a development environment. So I had to go: README -> installation docs -> scroll to bottom to find a small link to where the dev environment was described in the contributing docs. I didn't naturally jump to the contributing guide initially, and the section in the contributing guide also didn't work because:

    1. it instructs you to create a conda environment from eomaps.yml, which does not exist at the top level and the guide doesn't tell you where it exists in the repository. I ended up running find . -iname '*.yml' which then informed me that it doesn't exist at all and I likely wanted docs/contribute_env.yml.
    2. docs/contribute_env.yml at least matches the content of eomaps.yml as listed in the contributing guide (in the docs) and had I looked at contributing.rst I would have seen that is the environment file being used in the docs:
    Content of ``eomaps.yml``:
    
    .. literalinclude:: ../docs/contribute_env.yml
  2. At this point, I was unsure if the Docs were in-sync with the latest released version, but the docs don't list a version number explicitly anywhere. I'd like to at least see that on the front page of the docs and explicitly as a version listed on ReadTheDocs (even if you don't keep old versions around).

  3. When reading through the contributing guide:

    1. Overall I found it very well done! 👍
    2. Consider switching to git switch over get checkout which is more confusing and does both switching branches and restoring specific revisions.
    3. You point people to the miniconda installer but then have users install mamba. I'd just point people to miniforge which includes conda and mamba from the get go.
    4. There's nothing on how to run tests. I want to set up my environment and immediately run tests before starting in on changes. I had to go look at .github/workflows/testMaps.yml to see how tests should be run.
C) Running tests
  1. WHOAH soo many figure windows get created and deleted! I was not prepared for that. The tests took just long enough I switched away and started on something else when my desktop started exploding with figure windows being created/deleted. Do you need this to happen? If so, you should definitely document how to run tests and warn about this.
  2. I had 1 test failure from checkout of version 7.3.2 (I'll post the full traceback in a subsequent comment)
    FAILED tests/test_plot_shapes.py::TestPlotShapes::test_contour - AttributeError: 'NoneType' object has no attribute 'dpi'
    
  3. tests/test_doc_codeblocks.py hangs between the third and fourth codeblock until you close a figure window, but I couldn't easily tell which codeblock this corresponds to easily, and it looks like there's no logging of which code block is being run that I could make visible with the -s pytest option.
D) Conda environment files

I am not really a fan how the conda environment files are set up here. Recommendations:

  1. Provide a single environment.yml at the repository root, and:
    1. use this for both testing and development. This can be accomplished by setting the python requirement to python>=3.6 or whatever your minimum supported version is. If you want a preferred development version that's not whatever's the latest conda/mamba resolve, add setting the version restriction to the dev docs.
    2. rtree is in test_env.yml in the runtime dependencies but not in contribute_env.yml. It should be moved to the appropriate section or removed if not needed.
    3. I would really prefer git not be installed in the environment -- it's much more common to use the system install of git and this could lead to very unexpected things with miss-match system and environment versions.
    4. Related to ☝️ I would encourage pre-commit, but not install it into the environment, especially since you also have a pre-commit workflow: .github/workflows/pre-commit.yml
  2. docs_env.yml is fine where it is, but I'd just include sphinx-autobuild since you highlight it in the docs
E) Reading the FAQs

I hopped over to the FAQs after messing around with the tests to see if anything was addressed there.

  1. In the "From 0 to EOmaps - a quickstart guide" section
    1. After installing miniconda, you ask users to open a Anaconda Prompt terminal, but that is windows specific.
    2. matplotlib is unnecessarily included in the 2nd 3rd TODO
    3. Really, the TODO blocks are subsections -- It'd be nice to at least number them.
  2. In the "Configuing the editor (IDE)" setcion:
    1. I did not have any hanging with interactive plots like mentioned in the PyCharm section so setting Gt5Agg may be unnecessary now (fine to still recommend though)
    2. It's Pycharm Professional not commercial.
    3. The latest Pycharm Version don't have "Python Scientific" anymore; disabling plots into the tool window is located at "Setting -> Tools -> Python Plots -> [] show plots in tool window"
  3. I really like the Important Changes between major versions but
    1. It'd be good to include that in an UPGRADING.rst at the top level of the repo or at list mention it right up front in the README
    2. It'd also be good to reverse the order so the changes between the latest version and the last major version are at the top
F) Finally taking it for a spin with examples and data
  1. in the Basics the layer management figure needs to be bigger or zoomable. If that doesn't happen as an overlay, I'd set it top open in a new tab/window (target="_blank")
  2. In the data visualization section:
    1. in your note on data-reprojection about 1D coordinate vectors, you should also mention that these will be broadcast using matrix indexing, not cartesian indexing, as this could lead to the data being transposed in the plot.
    2. The speed and performance notes might also be worth linking to or putting in the FAQ
    3. Optional dependencies should be discussed on the installation page
  3. In the examples section:
    1. It would be nice to number the example's content to match the example figure numbers and code files
    2. They also appear out of order in places, e.g., ? -> 3 -> 2.
    3. The actual examples code being located in the tests directory was unexpected -- I initially looked for it in the docs directory
  4. The API reference is hard to navigate
    1. it's not in alphabetical order, or is at least missing headings, and the add_feature and add_wms methods were hard to find
    2. add_feature.preset isn't documented and seems to be a NaturalEarth_features class. In fact, the add_feature reference doesn't seem to match at all
    3. IDE tab completion also doesn't discover NE categories; hard to know what I'm able to access
    4. I ended up just opening NE_features.json, reformatting it so it's not on a single line, and looking at what's available there.

@jhkennedy
Copy link

Here's the full traceback of the test failure I had on v7.3.2:

FAILED tests/test_plot_shapes.py::TestPlotShapes::test_contour - AttributeError: 'NoneType' object has no attribute 'dpi'

full traceback:

______________________________________________________________ TestPlotShapes.test_contour _______________________________________________________________

self = <test_plot_shapes.TestPlotShapes testMethod=test_contour>

    def test_contour(self):
        for data in (self.data_pandas, self.data_1d, self.data_2d):
            m = Maps(ax=221, figsize=(10, 6))
            m.subplots_adjust(left=0.01, right=0.99)
            m.set_data(**data)
            m.set_shape.contour(filled=True)
            m.plot_map()
            cb = m.add_colorbar()
    
            m1 = m.new_map(ax=222, inherit_data=True)
            m1.set_shape.contour(filled=False)
            m1.plot_map()
            cb1 = m1.add_colorbar()
    
            m2 = m.new_map(ax=223, inherit_data=True)
            m2.add_feature.preset("ocean", "land")
            m2.set_shape.contour(filled=True)
            m2.plot_map(
                colors=["none", "r", (0, 1, 0, 0.25), "r"],
                hatches=["", "xxxx", "///", "xxxx"],
            )
    
            m3 = m.new_map(ax=224, inherit_data=True)
            m3.set_shape.ellipses()
            m3.plot_map(alpha=0.25)
            cb3 = m3.add_colorbar()
    
            m3_1 = m3.new_layer("contours", inherit_data=True)
            m3_1.set_shape.contour(filled=False)
            m3_1.plot_map(linestyles=["--", "-", ":", "-."])
    
            cb3.indicate_contours(
                contour_map=m3_1,
                add_labels="top",
                exclude_levels=[0, -1],
                label_kwargs=dict(color="r", rotation=90, xytext=(-5, -10)),
            )
    
            cb3.indicate_contours(
                contour_map=m3_1,
                add_labels="top",
                use_levels=[1],
                label_names=["This one!"],
                label_kwargs=dict(
                    xytext=(-40, 20), zorder=-1, arrowprops={"arrowstyle": "fancy"}
                ),
            )
    
            arts = m3_1.ax.clabel(m3_1.coll.contour_set)
            for a in arts:
                m3_1.BM.add_bg_artist(a, layer=m3_1.layer)
    
>           m.show_layer("base", "contours")

tests/test_plot_shapes.py:83: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _  
eomaps/eomaps.py:3357: in show_layer
    self.BM.update()
eomaps/helpers.py:2692: in update
    self.fetch_bg(show_layer)
eomaps/helpers.py:2154: in fetch_bg
    self._do_fetch_bg(layer, bbox)
eomaps/helpers.py:2078: in _do_fetch_bg
    self._combine_bgs(layer)
eomaps/helpers.py:2017: in _combine_bgs
    self.fetch_bg(l)
eomaps/helpers.py:2154: in fetch_bg
    self._do_fetch_bg(layer, bbox)
eomaps/helpers.py:2124: in _do_fetch_bg
    art.draw(renderer)
eomaps/shapes.py:73: in cb
    returns.append(getattr(c, name)(*args, **kwargs))
../../../../mambaforge/envs/eomaps/lib/python3.10/site-packages/matplotlib/artist.py:72: in draw_wrapper
    return draw(artist, renderer)
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _  

self = <matplotlib.collections.PathCollection object at 0x7f87019c8190>, renderer = <matplotlib.backends.backend_agg.RendererAgg object at 0x7f87029afa90>

    @artist.allow_rasterization
    def draw(self, renderer):
>       self.set_sizes(self._sizes, self.figure.dpi)
E       AttributeError: 'NoneType' object has no attribute 'dpi'

../../../../mambaforge/envs/eomaps/lib/python3.10/site-packages/matplotlib/collections.py:1004: AttributeError

@raphaelquast
Copy link
Author

Response to comment form @jhkennedy

The API reference is hard to navigate

  • it's not in alphabetical order, or is at least missing headings, and the add_feature and add_wms methods were hard to find
  • add_feature.preset isn't documented and seems to be a NaturalEarth_features class. In fact, the add_feature reference doesn't seem to match at all
  • IDE tab completion also doesn't discover NE categories; hard to know what I'm able to access
  • I ended up just opening NE_features.json, reformatting it so it's not on a single line, and looking at what's available there.

I implemented major changes to the API docs to reflect the actual public API and not the (internal) module-structure...
I hope you'll find them easier to navigate now!
You can have a look at the current state here: https://eomaps.readthedocs.io/en/dev/api/reference.html
I'm happy about any additional comments how to improve the docs!

@raphaelquast
Copy link
Author

raphaelquast commented Jan 20, 2024

@banesullivan @jhkennedy @yeelauren
Once again, thank you very much for all your helpful and productive comments! They really helped to pinpoint aspects of the package that required improvements (which are sometimes hard to spot if you know almost any line of code by heart).

I have now collected all major changes into a pending PR for EOmaps v8.0 EOmaps#205 which should address the majority of comments mentioned here.

Here's an overview of the most relevant changes/fixes relevant for this review:

  • EOmaps license will change from GPL to BSD-3-clause
  • All links in readme and github now point to the start-page of the docs (instead of github.io).
  • There is now a top-level environment.yml containing all relevant dependencies
    • pre-commit and git are no longer included explicitly but mentioned in the contribution-guide
    • tests/test_env.yml is kept for now, since the test-runs do not require packages relevant to build the docs
    • docs/docs_env.yml now pinns docs-build dependencies and installs only minimal EOmaps requirements
  • Installation instructions are now provided via pyproject.toml
    • Minimal python support is now clearly stated and >=3.8
    • Obsolete dependencies have been removed
    • Optional dependency groups are now available for pip install
      (pip install eomaps now installs only bare minimum requirements)
  • Major updates for the Docs:
    • Docs now build without any warnings and explicitly indicate the associated eomaps-version
    • Contribution guide has been re-worked to include info on testing, docs-build etc.
    • API docs have been completely re-worked to better represent the public API actually relevant for users
      (including access to available feature-names, pre-defined callbacks etc. )
    • Quickstart-guides now recommend miniforge as starting point for python+conda/mamba setup
    • Info on how to setup VSCode/VSCodium has been added to the docs
    • Example files are now located under "docs/examples" using a descriptive naming-convention (aligning with the associated figures and images)
    • A more responsive design is used to make the docs look nice also on small screens (phones etc.)
  • In addition, there are a lot of fixes as well as internal changes and re-structuring to cleanup old code etc.

Since my personal todos tagged for EOmaps v8.0 are more or less implemented, I wanted to ask how we proceed with the review-process since it would be nice if the release of v8.0 can be aligned with the outcomes of the PyOpenSci review.

  • All pending changes are summarized in EOmaps#205
  • ...and the associated docs can be viewed here

@banesullivan In addition, I also wanted to ask if it is feasible to still append a JOSS paper at this stage of the review or if you prefer that this is done post-review to avoid stretching the time for this review.

@banesullivan
Copy link
Collaborator

Hey, @raphaelquast, I want to leave a quick note that I haven't forgotten about this! Again fantastic work addressing all of the feedback!

In the coming days, I will sit down and review all of this to take inventory of anything that may remain and answer you questions about JOSS

I appreciate your patience!

@raphaelquast
Copy link
Author

@banesullivan Thanks, take your time!

@banesullivan
Copy link
Collaborator

@raphaelquast, this has truly come together fantastically! Thank you for diligently working to address all of the feedback our excellent reviewers brought up!

I've read this review thread up and down a few times now... (lots of amazing work happening here!!) and I believe you have addressed all of the feedback raised. That said, I'd like to give @yeelauren and @jhkennedy time to double check and sign off on the review.

@yeelauren and @jhkennedy, to make this process a little easier for you both I've tried to sift through your open review request/comments to track down the state of things. The following are my findings:

@yeelauren's comments:

  • Explicitly calling out the statement of need and why users may turn to EOmaps: I'm not sure if this has been fully addressed. @raphaelquast, is there a line you can point us to that you feel captures the statement of need? If so, perhaps this could come right after the "EOmaps is a python package to visualize and analyze geographical datasets" line in the README?
  • @yeelauren raised a great question on the why EOmaps is a separate package versus adding a PR/additional functionality to cartopy directly. I think @raphaelquast reponded well to this in this comment. I'm wondering if this explanation should be added in a new section to the CONTRIBUTING guide of EOmaps?
  • Set up and testing: I think @raphaelquast has addressed on these and my latest run of the tests under the dev branch show everything passing.
  • Testing warnings: @yeelauren raised some concerns about specific testing warnings that seemed of high importance and I think some of these have been addressed. In my latest run of the test suite from the dev branch, there are still a high number of warnings thrown, however they do not greatly concern me for the sake of this review at this time. I've raised a new issue in EOmap Testing warnings raphaelquast/EOmaps#227 to track these and feel comfortable not having those block this review.

@jhkennedy's comments:

  • Supported python versions: I believe this has been cleaned up and now EOmaps is supporting python>=3.8
  • Setting up a development environment and contributing guide: @raphaelquast has included a new contributing guide that I think address your concerns.
  • Documentation versioning: I think this is handled well now via RTD's versioning mechanisms
  • Testing failures and hangs: On the latest dev branch, I'm having no issues about tests
  • Testing figure windows: there is a note now in the contributing guid about this
  • Metadata in pyproject.toml: I think all of this has been added!

@raphaelquast, on your question about the JOSS review: I'm leaning towards following up with the JOSS paper post-review at this stage, but I will talk with some other's in PyOpenSci to fully assess this.... stand by.

@raphaelquast
Copy link
Author

raphaelquast commented Feb 6, 2024

@banesullivan Thank you very much for your thorough review and the kind words!
I've already started investigating the extensive number of warnings (in raphaelquast/EOmaps#227) and I agree that the README can still be improved... I'll try to come up with an updated README as soon as possible!

@raphaelquast
Copy link
Author

raphaelquast commented Feb 16, 2024

I finally found the time to draft an updated README to tackle the last open point from the review (PR: raphaelquast/EOmaps#230).

If any of you find the time, feedback would be highly appreciated! (You can look at it here)

@raphaelquast
Copy link
Author

@banesullivan @jhkennedy @yeelauren

Dear all, I wanted to ask if it is possible to get a quick update on the time-schedule for this review.

The reason I'm asking is because I am currently postponing the release for EOmaps v8.0 in hope that it might be aligned with the outcome of this review. However, since time is flying, I am now facing several upcoming activities (most importantly EGU General Assembly in 14-19 April and GeoPython 2024 conference on May 27) where I plan to participate with all the improvements introduced with EOmaps v8.0.

I would highly appreciate your opinion if it is feasible to arrive at a conclusion for this review by end of March.
If you think this is out of scope, I would release EOmaps v8.0 in the upcoming weeks irrespective of the status of the PyOpenSci review (and we can continue here without a time-constraint).

@jhkennedy
Copy link

@banesullivan @raphaelquast Sorry I got slammed the last couple of weeks.

As far as I'm concerned, EOMaps is in fantastic shape, @raphaelquast did an amazing job responding to feedback and updating EOMaps, and I definitely would recommend accepting EOmaps v8.0.

@raphaelquast
Copy link
Author

@jhkennedy thank you very much for your kind words and the prompt response!

@yeelauren
Copy link

@raphaelquast I haven't forgotten! I think end of March is doable.
I'll review ASAP this weekend :) apologies for the delay !

@yeelauren
Copy link

@raphaelquast amazing work - and happy with your response to the review and the significant work put into v.8.0! I like the added blurb to the read me. Same with @jhkennedy I'd recommend accepting 😊

@raphaelquast
Copy link
Author

@yeelauren Thank you very much for your support! Glad you like the improvements!

@raphaelquast
Copy link
Author

@banesullivan Could you provide an update on how we proceed with this review?

Test-warnings (raphaelquast/EOmaps#227) are now down to 17 of which I only 1 requires attention.

Aside of that, I believe all comments have been addressed as requested.


In addition, there are a few nice features that now made it into the v8.0 branch!

  • EOmaps now provides a set of pre-configured Jupyter Widgets to get nice control-elements in Jupyter Notebooks
  • xarray.Dataset is now accepted as input for m.set_data() (see info here)

The latest release-candidate can be installed with pip install eomaps[all]==8.0rc2

@banesullivan
Copy link
Collaborator

@raphaelquast, thank your for your patience! The last few weeks got the best of me between moving and some sickness.

Aside of that, I believe all comments have been addressed as requested.

I believe you're right! I think we're ready to proceed with the acceptance of EOmaps given @jhkennedy and @yeelauren have both recommended accepting! 🎉 🎉

I'm going to change the status of this review and will handle the next steps from here.


I want to close the loop on an earlier conversation about submitting to JOSS: We highly recommend you submit EOmaps to JOSS, but are going to encourage you to go through the standard JOSS submission process as opposed to starting it here. Given acceptance here, I believe there is precedent for fast-tracking the JOSS submission or using this review to augment the JOSS software review. I will happily chime in to help in any way I can during the JOSS submission if you chose to do so, please @ mention me as needed.


Amazing work here, @raphaelquast!!

@banesullivan
Copy link
Collaborator

@raphaelquast, I'd like to tie this review with version 8.0, would you let me know when that has been fully released?

@raphaelquast
Copy link
Author

@banesullivan Thank you very much for all your time and efforts!
I fully understand that sometimes things get in the way... I hope you're feeling well again and that you had a successful move!

@yeelauren @jhkennedy The same also counts for you of course! Your reviews have been highly valuable and helped me to improve many parts of EOmaps!


🚀 This is amazing news! I'm thrilled that this review has reached a positive outcome and I'm very happy that EOmaps will become a part of PyOpenSci!

I'd like to tie this review with version 8.0, would you let me know when that has been fully released?

EOmaps v8.0 is already waiting in the starting blocks! I'll do a final checkup and try to release it as soon as possible!

I'm going to change the status of this review and will handle the next steps from here.

@banesullivan Please keep me informed on any actions required from my side!


I want to close the loop on an earlier conversation about submitting to JOSS: We highly recommend you submit EOmaps to JOSS, but are going to encourage you to go through the standard JOSS submission process as opposed to starting it here. Given acceptance here, I believe there is precedent for fast-tracking the JOSS submission or using this review to augment the JOSS software review. I will happily chime in to help in any way I can during the JOSS submission if you chose to do so, please @ mention me as needed.

Thank you for following up on this. I agree that this is the best way forward. I'll try to compose a JOSS submission later this year once all the conference contributions etc. are done. I highly appreciate your support on this and I will reach out to you when the time comes!

@raphaelquast
Copy link
Author

I'd like to tie this review with version 8.0, would you let me know when that has been fully released?

@banesullivan EOmaps v8 is now released!

@banesullivan
Copy link
Collaborator

banesullivan commented Mar 18, 2024

🎉 Fantastic! With that, EOmaps v8 has been approved by pyOpenSci! Thank you @raphaelquast for submitting EOmaps and many thanks to @yeelauren and @jhkennedy for reviewing this package! 😸

Author Wrap Up Tasks

There are a few things left to do to wrap up this submission. I think you've already activated Zendo and created a DOI (which I have updated in the meta of the original post at the top of this issue), so I've marked those, but would you please let me know after you completed the following:

  • Activate Zenodo watching the repo if you haven't already done so.
  • Tag and create a release to create a Zenodo version and DOI.
  • Add the badge for pyOpenSci peer-review to the README.md of EOmaps. The badge should be [![pyOpenSci](https://tinyurl.com/y22nb8up)](https://github.com/pyOpenSci/software-review/issues/issue-number).
  • Please fill out the post-review survey. All maintainers and reviewers should fill this out.

Editor Final Checks

These are for me:

  • Make sure that the maintainers filled out the post-review survey
  • Invite the maintainers to submit a blog post highlighting their package. Feel free to use / adapt language found in this comment to help guide the author.
  • Change the status tag of the issue to 6/pyOS-approved6 🚀🚀🚀.
  • Invite the package maintainer(s) and both reviewers to slack if they wish to join.
  • If the author submits to JOSS, please continue to update the labels for JOSS on this issue until the author is accepted (do not remove the 6/pyOS-approved label). Once accepted add the label 9/joss-approved to the issue. Skip this check if the package is not submitted to JOSS.
  • If the package is JOSS-accepted please add the JOSS doi to the YAML at the top of the issue.
  • Post on Discourse

If you have any feedback for us about the review process please feel free to share it here. We are always looking to improve our process and documentation in the peer-review-guide.

@raphaelquast
Copy link
Author

raphaelquast commented Mar 18, 2024

PyOpenSci review badge has been added to the README

@raphaelquast
Copy link
Author

I now completed the post-review servery as well!

@lwasser lwasser moved this from under-review to pyos-accepted in peer-review-status Mar 20, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
Status: pyos-accepted
Development

No branches or pull requests

6 participants