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/
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.
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.
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.
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.
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
.
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.
The Makefile provides the following useful commands:
make html
to compile all pages and store them underoutput/
.make quick
to compile only pages that have changed. This is faster thanmake html
but will cause the front and news pages to be incomplete.make devserver
to start a development webserver on your local machine athttp://localhost:8000
, which will auto-compile a page when you make a change. This too causes the frontpage to be empty unless you callmake 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
.
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.
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}
}