Skip to content

hajothelen/codeformuenster.github.io

 
 

Repository files navigation

The "Code for Münster" Homepage

See a live example at codeformuenster.org.

The cool thing about this is, the fancy project list on the frontpage can automatically be fetched from the GitHub API by reading all the repositories of an organisation.

We are generating a static html page that can be hosted on github pages.

How does it work?

  • It would generate too many requests to the GitHub API if we would call the GitHub API live on every user request,
  • That is why there is a php script in this repository that can be called from the command line.
  • It downloads all the repository meta data from GitHub and creates a summary json file that is then used by the static html frontpage.

Step 1: Install jekyll locally to simulate github pages

Install & run using Docker

(These instructions are for Linux. On OSX/Windows, Docker has to be installed differently.)

  • Install Docker and Fig.
  • Then run: sudo fig up

The website is now available at http://localhost:4000. Posts and stylesheets will automatically be recompiled on change.

Non-Docker Install

This site is build using jekyll.

sudo gem install jekyll
sudo gem install rdiscount
sudo gem install bundler

Install dependencies:

bundle install

Change Stylesheets

The stylesheets are written in SASS/SCSS and are found in folder _sass. After changing the code you must compile manually to CSS with:

compass compile

Or run compass watch to automatically recompile after saving a file. If you intend to run the webserver as well, you don't need to compile the SASS code by hand. It is then managed by bundler/jekyll.

Step 2: Generate the Homepage

The project list will be created by fetching all sub-repositories from an organisation at github.

Configuration

Create the file "_config.ini":

cp _config.ini.dist _config.ini

Enter your organisation name and github access keys into the file.

Github setup

  • Every project of the organisation needs the following things set up:
    • The fields "Description" and "Website" need to be filled out in Github (The "Description" will used as project description and the "Website" URL will be visited and a screenshot will be taken)
    • If the "Description" contains the string..
      • "obsolet" or "obsolete", then the repository will be excluded from the list.
      • "(neu)" then a work-in-progress icon will be shown.
      • "idee" then a this-is-just-an-idea icon will be shown.
      • "(down)" then a site-is-currently-down icon will be shown.
  • Project Issues
    • A progress bar for the project will be generated by counting the percentage of closed vs. open issues, so if you want to display a progress bar, then you need to have some open and closed tickets on the project.
  • README.md
    • Project preview image: If you want to show a different one than the auto-generated screenshot as preview image, then put an image into the README.md. The first image found in the README.md will be used as prview image for the project. IF no image is found, then a screenshot will be generated by visiting the Project Website.
    • You can put a variable block with a status value into the README, like this: https://raw.githubusercontent.com/codeformuenster/open-data/master/README.md If a status value of "ok" or "done" is found, then the project will be displayed as finished.

Update the project list on the homepage

First you need to install "shutter", so that it can automatically create the screenshots of your repositories:

sudo apt-get install shutter

Then you can generate the metadata json file that is used to render the repository list on the frontpage, by running:

php update-data.php

Step 3: Run it (for development)

Compiles the page after saving a code change:

bundle exec jekyll serve

Or use this command to run it in docker:

docker run -it --rm -v "$PWD":/usr/src/app -p "4000:4000" starefossen/github-pages

The website is now available at http://localhost:4000

Now you can make design changes, etc.

Step 4: deploy it to github

  • Commit the files json/*.json
  • Commit the file index.html
  • Push it to the gh-pages branch.
  • Done!

Other useful things

Update a single screenshot

Sometimes the screenshot generator generates ugly things, especially for javascript heavy pages. Then use your favorite screenshot tool to take screenshots and then issue the following commands to resize the screenshot to appropriate size:

convert screenshots-large/$repoName.png  -background white -resize 600x -crop 600x400+0+0 -strip -quality 80 $screenshot_file

convert screenshots-large/wo-ist-markt.github.io.png  -background white -resize 600x -crop 600x400+0+0 -strip -quality 80 screenshots/wo-ist-markt.github.io.jpg

About

Das Repository für unsere CodeForMünster-Webseite.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • HTML 46.4%
  • CSS 35.0%
  • JavaScript 9.2%
  • PHP 8.2%
  • CoffeeScript 1.1%
  • Ruby 0.1%