Setting up a MetacatUI development environment

The first task is to get a development environment set up on your machine, which means:

  1. Get familiar with MetacatUI
  2. Fork the MetacatUI GitHub repository
  3. Install a local instance of MetacatUI

Get familiar with MetacatUI

Read about the MetacatUI software on the MetacatUI Github (https://github.com/NCEAS/metacatui) and documentation website (https://nceas.github.io/metacatui/)

Fork the MetacatUI repository

Fork the MetacatUI Git repository by going to https://github.com/NCEAS/metacatui and clicking on the “Fork” button.

Clone your fork to your local machine:

git clone https://github.com/your-username/metacatui.git

Open the forked repository (the metacatui folder) in your preferred code editor (e.g. Atom)

Test that your fork is ready to work with by making a small change to a file (e.g. add a space character) and committing and pushing the commit to your fork.

Install a local instance of MetacatUI

Follow the installation instructions for using MetacatUI locally with a remote Metacat data repository.

When you have MetacatUI running locally, you should be able to navigate in your web browser to the localhost path that you have your server running at, and you’ll see MetacatUI running like this:

Next: Contributing to MetacatUI

Review our Contributing guidelines.

Plug into the MetacatUI development pipeline

It is probably helpful to look over the MetacatUI issue tracker to get an idea of what we are currently working on in MetacatUI. We track all of our issues in Zenhub, here: https://app.zenhub.com/workspaces/data-portal-infrastructure-5d057ceca88c9959aefd0159/board

There are 7 different pipelines: New Issues - Newly-created issues that have yet to be reviewed and assigned to a pipeline Icebox - Issues that are not planned for a release anytime soon, but we still want to complete someday. Next - Issues that are planned for the next release. They are not being actively worked on yet, but will be once the issues in the Current pipeline are closed. Current - Issues that are planned for the current release and will be worked on after all the In Progress issues are closed. In Progress - Issues currently being actively worked on by a developer. Once a developer begins coding for an issue, the issue is moved to this pipeline. Review/QA - Issues that have pushed commits which resolve the feature or bug described, but the commits need to be reviewed by another developer (e.g. Lauren). Closed - These issues have code that is already merged into the develop branch and are completely reviewed and resolved.

We would suggest looking at the issues in this Zenhub board and getting a basic familiarity with the new features we’d like to add to MetacatUI. We’re always looking for enhancements to :

Submit a Pull Request

When you’re ready to contribute the changes made on your fork to the main MetacatUI code base, follow the steps outlined in the Contributing guidelines for submitting a pull request to MetacatUI.