Skip to content
This repository has been archived by the owner on Dec 6, 2022. It is now read-only.

Latest commit

 

History

History
308 lines (184 loc) · 12.9 KB

README.md

File metadata and controls

308 lines (184 loc) · 12.9 KB

Website redesign for the minor Web Development

During this project we redesigned the website for the minor 'web development' at the University of Applied sciences in Amsterdam. We have done our best to make a very experimental yet pleasurable web site.

A big theme in this project was 'accessibility'. The site should be pleasurable for everyone, not just for the 'general public'.

Homepage

Demo here!

1. Requirements

  • NPM (node package manager)
  • NodeJS
  • GULP (task-runner)
  • Browserify

2. Installing and building

Clone this repository

git clone [email protected]:baskager/redesign-minor-web-dev.git

Navigate to the /app directory and run NPM install

This will install all the NPM packages that are used throughout the project.

cd app
npm install

3. Deploying on development

Set the node environment variable to 'development'

This ensures that the docker scripts will use the right build for development

export NODE_ENV=development

Checkout to the develop branch

git checkout develop

Run the 'start-servers' script

This starts a 'postgres' container and an 'adminer' container. More info on these containers can be find in the /docs folder.

./start-servers.sh

Run the 'import database' script

This imports the database file contained in /sql/dumps/minorwebdev.sql

./import-database.sh

Go to the /app/ directory

cd app

Run gulp watch

This will check for changes in the assets and run the gulp task runner when needed.

gulp watch

Start the server

We recommend using Nodemon for development. This will restart the server when the code is changed. The will also run the server on http://localhost:3000.

npm install -g nodemon
nodemon server.js

4. Deploying on production

Set the node environment variable to 'production'

This ensures that the docker scripts will use the right build for production

export NODE_ENV=production

Run the 'start-servers' script

This can take a while as it correctly installs and builds the webserver container

./start-servers.sh

Run the 'import database' script

This imports the database file contained in /sql/dumps/minorwebdev.sql

./import-database.sh

Your server should now run on the production server on port 3000, you could use a proxy through Apache or NGINX to serve the site on a domain or on another port.

5. Experiments

'Hector Salamanca' input method by Rick

Rick made a very experimental version of a keyboard that ( according to his research ) shoud be very accessible for Marijn. Check out his progress Blog for the full research and results of the test with Marijn.

Video element with captions and split screen

For deaf people it is hard to follow lectures. They have to focus on the speaker, the interpreter and the slides at the same time. As we are making a website for a minor lectures are part of it. To make it easier for deaf people to follow the lectures I made a video player focused on improving this experience. We tested the video player with Marie, a deaf graphic designer. She gave us a lot of interesting feedback. With this feedback we improved the video player to it's current form.

The video player contains the following features:

  • Synced split screen view of the lecture and the slides
  • Subtitles (loaded as SRT format).
  • The subtitles can switch side using the mouse or arrow keys.
  • Slide overview to quickly navigate trough the lecture
  • The possibility to slowdown or speed up the lecture.
  • The video player can be controlled using the keyboard.

Screenshot of the videoplayer

Spatial navigation on the program page

The spatial navigation functionality is deeply inspired by the original Opera function and by multiple large screen navigation systems. Users can easily navigate through elements using their arrow keys. Unlike the forward jumping tab key, users can navigate in any direction. The enter key will emulate the mouse's on click event. More information can be found on James personal progress blog.

Focus following the scroll position

Marijn once told me that the biggest disadvantage of the tab key was the fact that it always starts at the top of the website. If the user chooses to scroll down the page and wants to interact with an element, he will need to spam the tab key until he get's there. With this functionality James wrote, the focus key will always follow the user's window location. The focus state will change its current element depending on what is currently displayed on the screen. More information can be found on James personal progress blog.

Navigation through hotkeys

In our interviews/test with Marijn, he told us that he really liked interfaces dat can be used through hotkeys. Now, all the pages in the main menu are available when you use the keys with a number on it. Look at the number in de main navigation to know which number you have to press. This feature can be toggled on or off when you press alt + ctrl simultaniously. Every user should be able to navigate quickly through the website without too much effort. Especially in combination with the spacial navigation and focus on scroll position.

How to use the hotkeys

  • If the indicator on the bottom right is transparent, press control + alt to toggle the hotkeys.
  • With [1, 2, 3, 4, 5, 6] you can navigate through the different pages on the website.

hotkeys

Spatial navigation slider element

I made this prototype because I heard that marijn hated carousel elements in websites because they never seem to work with spacebar or tabs and are often very fidgety.

For this reason, I tried to make a carousel element that would be more pleasurable for Marijn to use and ended up with two prototypes:

  • A carousel element with navigation using 'tab' keys and 'arrow' keys. spatial navigation slider element
  • A carousel element with navigation using 'tab' keys, 'arrow' keys and clickable buttons on the side spatial navigation slider element with buttons

After the third usability/accessibility testing with Marijn, it became clear that he prefers the second option, but, was confused about not being able to use the 'spacebar' key to navigate through the carousel items. With this feedback, I decided to create another prototype with the 'spacebar' navigation added. This last version of the prototype made it to the website.

6. Insights

The experiments were eye-opening for us as a team. Every member of the team represents the 'general public'. We use a computer and websites like most of society. Not often do we as developers realise our privileges and that leads to designing and developing things that might not be ideal for users that need/use additional accessibility features.

Testing and conversing with Marijn and Marie made us realise that the web/software is used in so many different ways and what for some is pleasurable can be an obstacle for others.

We found out that it is extremely difficult to make something pleasurable and accessible at the same time. It takes experiments, testing and a lot of iterations to get something right. It, however, is extremely useful and after a while it just makes sense.

When designing pleasurably accessible website elements you will find out that some designs are actually more pleasurable for the general public as well. There are some things we just get wrong in general and continuously testing helps us to realize this.

We highly recommend making websites/software more accessible if the time and money is available. You'll find out a lot of things that you can implement in future projects. Your finished work will have far more value because there are far more people that can use your product pleasurably. This isn't just financial value, it's also social value.

It really means something to the people who use it and we think that is powerful.

7. Conclusions

  • Don't assume things are pleasurable for everyone. Test it with a diverse group of people, including people who need accessibility software like screen readers.
  • Take your time to experiment and build prototypes, it's actually really fun and useful.
  • We all have something to learn, even when we think we don't.

8. Roadmap

Write this when we sign off on the project

9. Versioning

We use semantic versioning. More information can be found on http://semver.org

10. License

We use the "MIT License"

A short and simple permissive license with conditions only requiring preservation of copyright and license notices. Licensed works, modifications and larger works may be distributed under different terms and without source code.

You can find our license here: https://github.com/baskager/redesign-minor-web-dev/blob/master/LICENSE

11. Authors

James Jefferies

Profile photo

Ex-Graphical Design student that refound himself as a Frontend Developer at the University of Applied Science Amsterdam.

Github repo

Progress Blog

Jelle Overbeek

Profile photo

Designer that also likes to code.

Github repo

Progress Blog

Rick Buter

Profile photo

Doesn't really know what he's doing, but he's doing just fine.

Github repo

Progress Blog

Jamal van Rooijen

Profile photo

A designer who just recently discovered his love for code.s

Github repo

Jamal his progress blog.

Bas Kager

Profile photo

Software Engineer studying at The University of Applied Sciences Leiden. Really likes databases, performance, security and clean code.

Github repo

Progress Blog

12. Acknowledgements

A very special thank you to Marijn and Marie for helping us with accessibility testing and the design process. This project would not have been possible without them.

We would also like the thank all the teachers for the guidance in this project but also in the entire minor. They really went out of their way to push us and teach us something new.

13. Individual goals for this project

James Peter Perrone Jefferies:

  1. Learn how to build and manage complex project structures, for example, components splitting, folder structure, and name conventions.
  2. Don't be afraid to try new stuff out, be creative, and build awesome stuff where users can say: WoW!
  3. Don't write "quick fixes" or "prototype code". Try to write good code from the startup. Because I know that I won't refactor it later.

Jamal van Rooijen:

  1. Learning how to plan properly in this project. Especially since we are with a team of five people. Dividing tasks and completing our personal goals can only be achieved by planning properly.
  2. Learning more Javascript by developing interactive elements on the website, without being afraid to try new and innovative things if it seems too 'hard' on first glance.
  3. Combining style and functionality, which should result in something that is pleasurable to use and has a 'Wow factor'.

Rick:

  1. Animations and Transitions that increase the user experience
  2. Clean code so that it is readable for everyone
  3. A bit design to improve my skills

Bas Kager:

  1. Learn how to build proper CSS layouts with flexbox, grid and best practices.
  2. Get up to speed with tasks runners.
  3. Learn more about web design (best) practices

Jelle Overbeek:

  1. Performance matters - Setting up a Node server including performance optimisations
  2. Web Design - Out of the box design, include more creativity than usual and try to deliver a wow experience.
  3. WAFS - General JavaScript knowledge, make efficient JavaScript functions.

14. Roadmap

  1. Add masters project to program page.
  2. Fix bug where hotkeys are captured when in input field
  3. Improve video player on mobile.
  4. Fix mobile menu bug
  5. Fix mobile headers
  6. Improve animation speed
  7. Add filter functionality to student work.
  8. Add Github API
  9. Make whole website dynamic from database
  10. Add Instagram and/or Twitter feed to give a feeling about the minor.