Skip to content

Technical accomplishments

Barry Pollard edited this page Jul 31, 2020 · 13 revisions

The Web Almanac Development team does more than just build a simple website to host the Almanac, and in fact they have built some pretty amazing things.

We aim to use the best of technology available to lead by example to showcase what is possible on the web. We want the Web Almanac to illustrate many of the suggestions and recommendations discussed in the chapters and with the code fully open sourced and available on our GitHub repository, it can serve as a good example for implementing many exciting new features available to the web platform.

The purpose of this page is to highlight some of the team's best work as an example of the kinds of challenges that there are to work on.

Accessibility, translations and other best practices

An important principal we as a project team follow is to ensure the content is as accessible to anyone who wants access to it. That means paying special attention to accessibility, translating the content to as many languages as possible, and using progressive enhancement to give the best experience to those users on modern browsers, while ensuring the site is still usable on those on older browsers. Additionally we are obsessive about performance and adhering to other best practices in web development. This takes real effort from the development team, but we feel it is well worth it!

Accessibility

More details of this is in our Accessibility Statement but we spend a lot of time ensuring the site is built to the best accessibility standards we can with the appropriate use (but not overuse!) of ARIA atributes where necessary. We use various tools to achieve this including AXE, WAVE, Lighthouse and the Firefox Accessibility tester and attempt to address all issues which are not false positives.

Accessibility Tools screenshot showing high pass rates for the web almanac website

We're not claiming we're perfect, but we make a genuine effort to address all Accessibility issues that we are aware of.

Translations

The site was built form the beginning as a multi-lingual site and we have separate Translation Teams continually working on back porting old content to various languages. That brings a number of technical changes on how to implement it, how to avoid duplicating code as much as possible to make maintenance easier and to ensure we handle SEO appropriately.

It also brings UX and testing challenges as the different languages will have different content available at different times and, in many cases, will not have pages available in each language.

Progressive Enhancements

In line with our ethos, we do not assume that all our readers will be running the latest browsers and have access to all the most recently released features that we use on this site. This means that, although we encourage use of new features in JavaScript and CSS, we ensure the site is useable and content is readable even on browsers and devices that do not support these.

At the end of the day, the content is what is most important about this website and that should be easily rendered by even the most basic browser. Any nice features, for either out users, or to make development easier for ourselves on top of that, is secondary to that. So we encourage latest features,

At present the site works well on any of the currently commonly used browsers, right back to Internet Explorer 11 - though those browsers may miss out on some of the nicer features like our Fonts, our fancy index sidebars, or our contributor filters. Some of these would be possible to add even in older browsers, but we feel are not essential and this increases complexity and risk of errors. The important point is the main site and content is available.

This also means the Web Almanac is also available to any device capable of rendering HTML, is fully readable in reader modes of browsers and also can be used in smaller devices if you really desire 😀:

Css chapter display on iWatch Css chapter display on iWatch Css chapter display on iWatch Css chapter display on iWatch Css chapter display on iWatch

Performance

Many of us involved in the Web Almanac are web performance advocates and so of course we ensure the website is a performant as possible despite the wealth of rich data available.

We are pleased to have developed a highly performant and responsive website – despite the time pressures associated with the project and the fact it is developed by volunteers:

Lighthouse scores for Web Almanac with 99% for Performance, 100% for Accessibility, 100% for Best Practices and 100% for SEO

The web development team carefully considers all new enhancements and ensure they are implemented as efficiently as possible, including ensuring images are of the appropriate sized and format depending on the devices capabilities, serving assets like fonts locally, measuring our site performance using Web Vitals

Other best practices

As well as all of the above, we ensure we use good semantic HTML, that our websites pass HTML and CSS validators, and that changes are peer reviewed. We also ensure we are developing using good SEO practices to ensure our content is easy to find. Having access to a wealth of web experts allows us to reach out to them on various issues where the answer is not obvious!

And despite being a static site, we still follow best security practices, including using Content-Security-Policy and privacy protecting features like Feature-Policy:

A+ rating on securityheaders.com

Ebook

The Web Almanac is available as both as an online website but is also available to download as an Ebook: 2019 English Ebook. Or course it is also available in any other completed translations too: 2019 Japanese Ebook.

The Ebook is generated via the website using the CSS Paged Media Module. This is not yet well supported in standard browsers, but specialist tools exist which allow you to generate a PDF from the HTML, CSS and JavaScript we all know and love.

As discussed in our Accessibility Statement we also ensure this is an accessible Tagged PDF which meets the PDF/UA-1 standard. Again this [accessible PDF is generated directly from our website)[https://medium.com/@bruce_39084/making-accessible-tagged-pdfs-with-prince-ad7fd7a48711].

The Ebook is also available in print-ready format:

Printed Book cover TOC Performance Chapter Colour Figures

Latest browser features

These are just some of the newer APIs, or more advanced techniques that we use on this website (in no particular order):

GitHub Actions

We make a lot of use of GitHub Actions to help with developing, testing, build and releasing the website.

Chapter tracker

We created a GitHub Action to automatically track chapter progress which helps project manage such a large project with so many contributors based all across the world.

Linting and Testing

Our actions automatically lint all our code to keep it bug free and enforce a consistency of style. We also perform test code changes, which again helps with the spread of the team and new team members joining all the time.

Helping other projects

Using such a variety of technologies and having such high standards occasionally means we spot issues with some of the tools, and dependencies we use. Many of these are open source and we have committed improvements to the Github Super linter, the Calibre Image compressor, and the Flask Talisman security library to name but a few. These changes make our site and development practices better, and hopefully allow others to benefit as well.