This example showcases a simple data catalog that get its data from a list of GitHub repos that serve as datasets.
A datasets.json
file is used to specify which datasets are going to be part of the data catalog.
The application contains an index page, which lists all the datasets specified in the datasets.json
file, and users can see more information about each dataset, such as the list of data files in it and the README, by clicking the "info" button on the list.
You can read more about it on the Data catalog with data on GitHub blog post.
By clicking on this button, you will be redirected to a page which will allow you to clone the content into your own GitHub/GitLab/Bitbucket account and automatically deploy everything.
Execute create-next-app
to bootstrap the example:
npx create-next-app <app-name> --example https://github.com/datopian/portaljs/tree/main/examples/github-backed-catalog
cd <app-name>
This project uses the GitHub API, which for anonymous users will cap at 50 requests per hour, so you might want to get a Personal Access Token and add it to a .env
file inside the folder like so
GITHUB_PAT=<github token>
You can change the datasets that will be displayed in the data catalog by editing the file datasets.json
. Some examples can be found inside this repo.
Run the app using:
npm run dev
Open http://localhost:3000 from your browser. You should see something similar to this:
If click on the info
button for a dataset you will see a page similar to this:
The datasets.json
file is simply a list of datasets, below you can see a minimal example of a dataset:
{
"owner": "fivethirtyeight",
"repo": "data",
"branch": "master",
"files": ["nba-raptor/historical_RAPTOR_by_player.csv", "nba-raptor/historical_RAPTOR_by_team.csv"],
"readme": "nba-raptor/README.md"
}
It has:
- A
owner
which is going to be the github repo owner - A
repo
which is going to be the github repo name - A
branch
which is going to be the branch to which we need to get the files and the readme - A list of
files
which is going to be a list of paths with files that you want to show to the world - A
readme
which is going to be the path to your data description, it can also be a subpath eg:example/README.md
You can also add:
- A
description
which is useful if you have more than one dataset for each repo, if not provided we are just going to use the repo description - A
Name
which is useful if you want to give your dataset a nice name, if not provided we are going to use the junction of theowner
therepo
+ the path of the README, in the exaple above it will befivethirtyeight/data/nba-raptor
You can also build the project for production with:
npm run build
And run the production build with:
npm run start