This article is aimed at people who would like to try using the Prototype kit but are unsure how to do that. You might need a bit of help if you have never used a command window or if you are new to HTML or CSS. You can bookmark this link to W3Schools in that case for HTML and CSS or this link for basic commands.
If you work for the government, there are trainings available. If you don’t, there is a lot of help online and you will probably want to customise the kit, so this is why I’ve written this blog post. You can also check this online help.
At the end, you will have a live clickable prototype, responsive (= working on both mobile and bigger screens), accessible (unless you modified the components or didn’t used them well).
Edit 19/12/22: Since I wrote this, the prototype kit has evolved quite a lot. Advice in this blog post won’t be as useful as it was at the time of writing. The folder structure is different for example.
The work described here was to create a website for East Renfrewshire Council to support classes to improve digital skills. This needed some customisation. I’ve recently updated it so you could look at the code on Github to see how it’s done with the most recent version of the prototype kit. You can see the website even on a mobile device. You will be prompted for a password which is erc-tool.
Note: This installation is not my first one, and I’m using a Mac. You should only use this for prototypes, not for production code.
In this post:
- installation of the kit
- start a new repository on Github
- customise the prototype
- deploy to Heroku
- some examples
Installation of the kit
If you are ok with using Git then follow the bullet points below. If not, check the instructions from GOV.UK Design System starting at the begin.
- download the prototype kit here.
- Unzip and rename to whatever suits you. Open a command window for that folder.
- the latest kit at the time of writing (25/02/20) requires Node.js 12
If you have Node version problems or if you are unsure about having NodeJs at all
This page will help you. If you have nvm installed on your machine, you can check what version you have:
nvm current
to see version used with nvm (nvm deals with multiple node versions on one machine).nvm ls
to see the various versions you have on the machine.nvm install v12
to have the latest version of node installed.
then you can decide which one you want to use on the computer as the default:nvm use v12.16.1
(for me).
data:image/s3,"s3://crabby-images/09353/0935384a08e0c987c2a15b1a47996d7793ec5f2f" alt="screenshot of the git instructions to get the correct node.js version"
Then npm install
and npm start
data:image/s3,"s3://crabby-images/d4c84/d4c84452d8a7b91ad1a83e12f5053899c38166aa" alt="screenshot showing the lines of code and messages in the Git window after running npm install and npm start"
Do you give permission for the kit to send anonymous usage data? (y/n)
It’s up to you. I answered yes.
data:image/s3,"s3://crabby-images/fb869/fb869d85d3c5b262a467e2c92deae1c380dc3719" alt="screenshot of what appears on screen once you answer yes to the question"
Go to localhost:3000 in your browser, and That’s it …. it’s that easy.
data:image/s3,"s3://crabby-images/96baa/96baa972e6d67ce17ea287b22396bc63ed924fc2" alt="screenshot of the window on localhost:3000 showing the home page of the GOV.UK Protoype Kit"
Now start a new repository on Github
If you are not familiar with Github, try this guide first: Hello World
In Github create a new repository
I chose to leave it public, no licence, no gitignore (there is one already), no readme yet.
data:image/s3,"s3://crabby-images/7269d/7269d7cea6c1eef550116e3f7fcbe0b2aa1ee802" alt="screenshot of Github settings when you create a new repository showing my settings"
You will then see the quick setup help from Github:
data:image/s3,"s3://crabby-images/3cb40/3cb40c8cef6fd744f803b96cf73b14ccdb9c3f2a" alt="page from Github showing different options to do your set up."
In a Command line window, navigate to your folder
and add the instructions from Github in the picture above (I used ..or create a new repository on the command line, but then also did: git add .
then git commit -m "first commit"
and finally git push
)
Once you’re done, your repository in Github should look like that:
data:image/s3,"s3://crabby-images/2ed1b/2ed1bd549bca1b4a17bdef052feedf610d62f11f" alt="screenshot of the repository, showing all the files and folders"
That’s your code ready for version control in Github
Customise the prototype
Create your own layout file
You are going to create your own layout. The kit has an unbranded one. Make a copy of it and change its name. I’ve called mine layout_erc.html
It’s in app>views>layout_unbranded.html
data:image/s3,"s3://crabby-images/81153/811533e9257f52acf81feb94c37981a9b87301ff" alt="screenshot to show the path to the file"
Create your own CSS
Just the same way, you are going to create your own CSS. The kit has an unbranded file. Make a copy of it and change its name. I’ve called mine erc.scss
It’s in app>assets>sass>unbranded.scss
data:image/s3,"s3://crabby-images/52fae/52fae73f838eb522bc9f346496da82edfce1c349" alt="screenshot to show the path to the file"
You might want to check that link for advice on changing colours and fonts. (thanks to Joe Lanman for the link)
Add your favicon
If you plan to change the favicon, add yours to app>assets>images (this is the little image in the corner of your tab in a desktop browser)
data:image/s3,"s3://crabby-images/5c59d/5c59dfe2245bcf1b843359e390734527a720aee7" alt="showing the path to the favicon and the picture itself - this is the logo of the East Renfrewshire Council"
This is where you would put any images you might need as well.
Now add these changes to your own layout
In your layout file, mention your new favicon and your own css file:
data:image/s3,"s3://crabby-images/2279b/2279b33e6f15bf9c608cf59bcf0f85ddfa5c2931" alt="screenshot of the code showing code lines to make the changes"
This is also where you will change the footer and header, which at the moment are just emply. But we’ll come back to this later.
Change your index file to see the changes
In the index.html file (in app>views>index.html) change line 2 by writing your own layout file name and the page title line 5.
data:image/s3,"s3://crabby-images/cf87d/cf87d1016bb9118b3066640ec1d653531ffdfba7" alt="screenshot showing the line code changes"
As soon as you save your changes you should see the tab for localhost:3000 updating with your new title and favicon:
data:image/s3,"s3://crabby-images/d50d9/d50d976909ba2a777df3d7d43687a2185cd099b4" alt="this is the page in localhost:3000 as it looked before"
data:image/s3,"s3://crabby-images/987a9/987a95d71fd5714020b0c5c5055bb5ffcc4be9aa" alt="the GOV UK header is gone and you can see the new favicon and the new title in the tab of the browser"
Now you can also make the rest of this page your own by changing the HTML in the block Content (from line 8)
You can add pages in the Views folder. Here is an example of a simple page:
data:image/s3,"s3://crabby-images/14b77/14b771d940f077f6daa01b97c4404ddba20fd9c6" alt="showing the line of code for the example in a code editor"
data:image/s3,"s3://crabby-images/0125a/0125a6491974487926c5e979c8ed5eebc6669b8d" alt="screenshot of the page rendered in localhost:3000"
If you use that same code, but changing the layout on line 2 to: layout.html, then your page will have the same text but have the GOVUK branding instead:
data:image/s3,"s3://crabby-images/0b1dd/0b1dd77ab5224d16ada5d46b8c35c903964de60c" alt="same content but with the GOVUK layout, the header with the crown is back and the branded footer is back too"
Get help if you are not familiar with the GOV.UK Design System
You’ll find the classes names and more in under ‘Styles’
data:image/s3,"s3://crabby-images/8588c/8588ce47973412bc696c4c055023d460b71788ff" alt=""
The menu Components and Patterns will also show you what is available.
To build the code of your page, you can simply look for the components you need and then copy the code from there. You can use the Nunjucks version (it’s a templating language which should be easier for non coder as it’s closer to natural language. Or you can use the HTML version for it which will probably suits you best if you know how to code as you can modify things more easily.
data:image/s3,"s3://crabby-images/c9f17/c9f173b00436add892c68be0aead1e078e9a076e" alt="showing the GDS design system component for the breadcrumbs and the code displayed on that page"
You can link one page to the next by a simple ‘Continue’ button component and adding an ‘href’ link to your next page.
If you want to pass some input values or do some validation / logic with them, then you will need to add form tags <form class="form" method="post"> ... your inputs ... </form>
and add some code to a key file: route.js
data:image/s3,"s3://crabby-images/082eb/082ebf65b8b791a79fbea97215c0c2cd64aefaa1" alt="showing the path to the route.js file, it's in the app folder"
Changing the Header
You will need to add some code in your layout file
data:image/s3,"s3://crabby-images/f08ac/f08acd0451f32f17f27bb1ef39183773a85cd40d" alt="screenshot from the code editor for the HTML"
And some CSS for it in your customised SASS file:
Just start under the code that is already in that file. I’ve added a list of my own colour variables, and a bit of style for the header
data:image/s3,"s3://crabby-images/33bef/33bef252a8d6ff7c54e18dcef8d992f6c5da4a3f" alt="Screenshot in the code editor for the CSS"
data:image/s3,"s3://crabby-images/1b09b/1b09be67ad1febcb76bb30609e260ea5b4eaf807" alt="screenshot of how it looks in the localhost:3000, we now have a logo of the council displayed at the top and a tag saying "This is a training website""
Changing the Footer
You can add some code in the footer block of your customised layout:
data:image/s3,"s3://crabby-images/e6fc9/e6fc9231cae4e0b30aa910722adb15e0b6677649" alt="screenshot of the lines of code in a code editor"
Some CSS in your customised Sass file:
data:image/s3,"s3://crabby-images/2908e/2908eaecb7593c843ff4f48880dc617cae2204b6" alt="screenshot of the lines of code in a code editor"
Here is how my example page looks now:
data:image/s3,"s3://crabby-images/7053b/7053b5f2e9b72eb91d99e75439553d06371b44a6" alt="The page now have a blue footer with some white text and links"
Deploy to Heroku
Edit 01/12/22: Heroku is not longer free, check the recommendations from the GDS (Government Digital Service).
Once you have created an account, you need to create a new app:
data:image/s3,"s3://crabby-images/dbb0e/dbb0e2487f90e740221127aca1046f28c41c0417" alt="screenshot of Heroku screen showing the dropdown to create a new app"
You will then select a name for it, and select the zone for hosting (US or Europe)
data:image/s3,"s3://crabby-images/562cd/562cd2bac3d666d76f3e97e31a202077dc1c8cd9" alt="screenshot of the next screen when you create an app on Heroku"
For the deployment method, select Github.
data:image/s3,"s3://crabby-images/caaf7/caaf750aa727d4447413be530b0e757710b6bf74" alt="screenshot of Heroku showing the deployment method"
Find your repository by typing its name and then hit Connect.
data:image/s3,"s3://crabby-images/5d502/5d50210899bd7e7c4d944569d1e890766849dc34" alt="screenshot of the Heroku window once you have found your repository"
This is you all set, and every time you will push to master it will automatically deploy to your website if you select: Enable Automatic Deploys
(Note: ‘master’ is now called ‘main’ on Github so this is what you’re likely to see when you do it)
data:image/s3,"s3://crabby-images/b2a88/b2a88ae9d980b3cf3948eef9c9d23c08de23816d" alt="screenshot showing the page to set automatic deployments"
You need to do a manual deployment first though.
data:image/s3,"s3://crabby-images/782c9/782c9281f3212b0647fba0392922f55ff5ee2716" alt="screenshot showing a successful deployment"
But when you view it, you’ll see there is an error. This is because prototypes made with the kit require a username and password when published online. This stops members of the public coming across your prototype by accident thinking it’s a ‘real’ government website.
data:image/s3,"s3://crabby-images/f74dd/f74dd2d4569db1db530d959f2a449dce93c4a815" alt="screenshot showing the message: Error: Username or password not set"
To do that, in a command line window type:
heroku config:set USERNAME=the-username-you-chose --app name-of-your-heroku-app
heroku config:set PASSWORD=the-password-you-chose --app name-of-your-heroku-app
Now when you try to view your app (no need to deploy again) you’ll be prompted to type the user name and password.
data:image/s3,"s3://crabby-images/35820/358205f0a48c751a524d3361eec17e7a5d8dbedc" alt="screenshot of the window where you need to enter your username and password"
That’s it … you should now be able to see your website.
Whenever you push to your master branch in Github, it might take up to 5 minutes to see the changes deployed. Be patient.
If you run into problems with Heroku
It wasn’t the first time I used Heroku, and it took me less than 5 min to create the app, connect to Github and deploy successfully (mostly because I was taking screenshots and taking notes here!)
Previously I had various problems, so writing some useful commands for the command line here:
- to install Heroku
brew install heroku/brew/heroku
- my Ruby version wasn’t up to date
brew install ruby
heroku login
- to see the logs
heroku logs --tail --app name-of-your-heroku-app