Skip to content

Hamakor/pycon-il-2024

Repository files navigation

Website for PyCon Israel 2024

Website built with Pelican, using a PyCon-Israel-Flex theme based on Flex. This is a static website (this is what Pelican does), but it relies on a Pretalx system that manages and presents the schedule, talks and speakers.

Tools and building

The Python side is managed by Poetry. Use poetry install to get the dependencies.

The theme styling is built with gulp and other npm tools. If you want to change anything in the CSS,

  • Preparation: Go to the folder website_2024/themes/PyCon-Israel-Flex, and there run the command npm install
  • "Compilation" (mostly of the Less sources): Run the command npm run build

When you want to build the site itself, there's two things you need to do:

First, to create the speakers page, you need to run the speakers.py script (found in the repo's root folder) from inside the virtualenv like this (assuming the site is generated from website_2024 folder):

python ./speakers.py <event-slug> -t <api-token> -o ./website_2024/content/pages/speakers.md

In this command, <event-slug> is the slug for the event in Pretalx, and <api-token> is an authentication token you can get from your Pretalx profile page. For PyCon Israel 2024, event-slug is pycon-2024, and your profile page is https://cfp.pycon.org.il/pycon-2024/me/ .

Then, use make html from the website_2024 folder. It puts the built site in output. You can use make clean to remove everything if you want to rebuild from scratch; but it doesn't clean the theme files.

You can also use make devserver for the HTML, and npm run watch for the styling -- these create watchers which update the output as you change the source files.

Content

Pages are in website_2024/content/pages, and are written in Markdown. At the top of each page there is a block of metadata. Of these, the Title field is very visible, but also critical are the Slug and Lang fields which define the page identity (the Hebrew and English versions of a page should have the same Slug; otherwise, different pages should have different Slugs). The page_number field determines the order of the page in the list of pages in the sidebar.

The home page content is defined like other pages, using files homepage.md and homepage-he.md in content/pages; these contain mostly HTML, since the homepage is not an "article" like other pages. The metadata in these files has some unique fields, to choose the different templates and to save the page as index.html.

The home page buttons and top is defined in the templates website_2024/themes/PyCon-Israel-Flex/templates/homepage.html and .../homepage-he.html. In the original template that came with the Flex theme, this page lists articles (blog posts), but we don't want that. The original template was kept for reference as index.html.orig.

Other interesting files to look at:

  • The settings are defined in website_2024/pelicanconf.py (for development) and publishconf.py (for "production").
  • The sidebar is defined in website_2024/themes/PyCon-Israel-Flex/templates/partial/sidebar.html
  • The footer is in website_2024/themes/PyCon-Israel-Flex/templates/partial/footer.html
  • All (non-partial) templates extend website_2024/themes/PyCon-Israel-Flex/templates/base.html -- that means that template defines structure for everything.

References of software used