Skip to content

KeplerGO/KeplerScienceWebsite

Repository files navigation

Kepler/K2 Science Website DOI

The website for astronomers using NASA's Kepler/K2 space telescope.

Live URL: http://keplerscience.arc.nasa.gov

Test URL: http://keplergo.github.io/KeplerScienceWebsite/

Quickstart

To preview the Kepler/K2's Science Center Website on your local machine, simply clone this repository and run make devserver as follows:

$ git clone git@github.com:KeplerGO/KeplerScienceWebsite.git
$ cd KeplerScienceWebsite
$ make devserver
$ firefox http://localhost:8000

If you have write access to this repository, you can modify the website by editing the text files in the content sub-directory of this repository, preview them in your browser, and then commit the changes to this repository. For example

$ vim content/pages/helpdesk.md        # Edit the helpdesk page
$ http://localhost:8000                # Preview the change in your browser
$ git add content/pages/helpdesk.md    # Commit your change to this repo
$ git commit -m 'Explain your change'
$ git push

Finally, if you have access to the NASA webserver, you can make the changes live using the make upload command.

In what follows these steps are explained in more detail.

Detailed instructions for website editors

1. Cloning the website

The first step to start editing the website is to clone the website's main git repository onto your local machine, e.g. using:

git clone git@github.com:KeplerGO/KeplerScienceWebsite.git

If you are going to make changes to the website, you will need to ask the Kepler GO Office to give your GitHub account write permissions to this repository.

2. Installing the dependencies

Compiling the website requires a working environment of either Python 2 or 3 to be installed, e.g. using the Anaconda Python Distribution.

You will also need to ensure that the pelican, markdown, beautifulsoup4, and ghp-import Python packages are installed, e.g. using the pip package installer:

$ pip install pelican markdown pygments beautifulsoup4 ghp-import

Note that if markdown is not installed, you will only get a very cryptic warning message ("No valid files found in content.") when compiling the website below.

3. Editing the website

The website content is stored as a collection of text files in the content sub-directory of this repository, which is where all changes must be made.

Most of these content files are formatted using the MarkDown text format (see cheat sheet here), which will automatically be compiled into HTML code using a template (to be explained in step 4). You may also use HTML tags directly in the content files, but this should only be necessary in a small number of cases where very precise control over the layout is required.

Note that the website's template is based on the flatly bootstrap theme. This means that you can use all the html elements and classes which are demonstrated at https://bootswatch.com/flatly. In addition, you can also use all the standard bootstrap css classes.

4. Compiling and previewing the website

After editing the content, you will usually want to preview your changes by compiling the website into HTML format and viewing them in your browser.

The easiest way to do this is to type make devserver in the root of this repository, which will start a local server in the background that will serve the website at http://localhost:8000 (type this address in the url bar of your browser to preview the website). The server is fast and will auto-compile every time you change a content file, however note that it does not create a full version of the front page: you need to perform a full build using make html to preview the front page.

When you are done, you can kill the background server process using make stopserver.

5. Uploading the website

When you are happy with the changes made, you can make them live. This is a 3-step process.

First, make sure you update the repository to include changes others have made (and resolve any conflicts), e.g. using

$ git pull

Second, commit and push your own changes to the KeplerGO git repository so they are available to others. For example, if you changed the Helpdesk page, you would type:

$ git add content/pages/helpdesk.md`
$ git commit -m 'Changed the helpdesk e-mail address'
$ git push

Finally, you can now send the new HTML-compiled version of the website to the production webserver. This is done by typing make upload (note that this requires special access to the webserver and the configuration of shell variables).

If you are not quite ready to make your changes live, but would to make them available at a test URL, you can type make github which will deploy the website at the Test URL.

Makefile tasks

The Makefile provides the following useful commands:

  • make html to compile all pages and store them under output/.
  • make quick to compile only pages that have changed. This is faster than make html but will cause the front and news pages to be incomplete.
  • make devserver to start a development webserver on your local machine at http://localhost:8000, which will auto-compile a page when you make a change. This too causes the frontpage to be empty unless you call make html.
  • make upload to send the compiled HTML files to the production server.
  • make github to send the compiled HTML files to the development server.

Note: make quick and make devserver both use agressive caching which allows the website to be built quickly, but causes the listing of news items to be missing from the front page (output/index.html). You need to call make html if you care about a preview of the front page. Calling make github or make upload automatically triggers make html.

Authors

Created by Thomas Barclay, Geert Barentsen, and Knicole Colón for the Kepler/K2 Guest Observer Office at NASA Ames.

Created using the Pelican package and the pelican-bootstrap3 theme.

Citation

You can cite the Kepler/K2 Science Website in your publications using its DOI identifier or using the following BibTex code:

@misc{tom_barclay_2016_44393,
  author       = {Tom Barclay and
                  Geert Barentsen and
                  Knicole Colon},
  title        = {KeplerScienceWebsite: 20160106},
  month        = jan,
  year         = 2016,
  doi          = {10.5281/zenodo.44393},
  url          = {http://dx.doi.org/10.5281/zenodo.44393}
}