Skip to content

The Computer Science Society at the University of Birmingham.

Notifications You must be signed in to change notification settings

randomRooster/cssuob.github.io

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

cssbham.com

This is the source code to cssbham.com.

Documentation

See in-depth documentation and maintainance guides at the wiki.

Installation

Docker setup

Ensure that you have docker and docker-compose installed.

Then:

docker-compose build
docker-compose up

The website should now be available at http://127.0.0.1:4000.

Manual setup (not recommended)

First, ensure that gem is installed.

Install bundle:

gem install bundle

Install required dependencies:

bundle install

Run jekyll server:

bundle exec jekyll serve

The website should now be available at http://127.0.0.1:4000.

Development

Adding new redirects

To manage a new redirect, then add it to _data/redirects.yaml, following the format of the entries that are already there.

This avoids needing to add files and folders everywhere, keeping the site cleaner.

Writing a new post

To create a new post, create a markdown file in _collections/news with the post content. You can see a template post already there to borrow from.

The filename should follow a precise format - to create this file from a shell:

touch \_collections/news/"$(date +%Y-%m-%d)-<title>.md"

You can add a thumbnail to a post; simply link the thumbnail in the front matter in the markdown file for the post. The thumbnail should be a 150px square for best results.

Calendar Events

The calendar events are accessed from the public CSS Google calendar also available here. They are accessed from the calendar using FullCalendar and an API key managed from the Google Cloud Console.

To add a new calendar event, a member of the CSS committee with access to the calendar must add a new event, and it will automatically appear on the website.

Event formatting

The event data displayed on the webiste is taken directly from the Google Calendar event. Some properties are extracted using XML-like tags from the event description - note that this does not imply that other XML tags are implemented, so no other tags aside from the ones specified here should be used.

Content Source
title the name of it appears on the calendar
date the date and time as it appears on the calendar
location the location as it appears on the calendar
description <desc></desc> tags in the event description, otherwise, the full event description, which may include other tags if used
facebook link <fb></fb> tags in the event description

Note that for the facebook event link, all matching <a></a> tags are then removed from the event description.

The time and date format used is chosen automagically depending on the times and dates given in the calendar event. The below table details the process:

Date Format Used when
DD MMM YYYY - DD MMM YYYY all day when the year changes
DD MMM YYYY HH:MM - DD MMM YYYY HH:MM time specified when year changes
DD MMM - DD MMM all day when month changes
DD MMM HH:MM - DD MMM HH:MM time specified when month changes
DD - DD MMM all day on different days in same month
DD MMM HH:MM - DD MMM HH:MM time specified on different days in same month
DD MM HH:MM - HH:MM same day

Updating the committee

To update the committee:

  1. Add the new committee's photos into assets/committee/full
    • Each image should have a 1:1 ratio.
    • Add the highest quality images you can (they'll be scaled down later).
    • Most common image formats are supported.
  2. Create all the additional files by running _scripts/committee.sh _scripts/assets/committee/2019-20 (it's a bash shell script).
  3. Create a new yaml file in _data/committee/ with these tags:
    • academic_year: The academic year of the committee, e.g. 2019/20
    • prefix: Prefix to the role of each member, e.g. "Outgoing Publicity Rep"
    • postfix: Postfix to the role of each member, e.g. "Publicity Rep Elect"
    • current: Display the committee on the main list page, true or false. All committees will always be listed in the archive
    • people: : A list of committee members:
      • name: Name
      • role: Committee Role
      • bio: >: Multiline Bio
      • picture: Picture

About

The Computer Science Society at the University of Birmingham.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • HTML 44.8%
  • SCSS 27.4%
  • JavaScript 15.7%
  • CSS 11.1%
  • Shell 0.5%
  • Dockerfile 0.4%
  • Ruby 0.1%