Skip to content

Commit

Permalink
add backward compatibility documentation
Browse files Browse the repository at this point in the history
  • Loading branch information
joelanman committed Jul 24, 2018
1 parent 8d0e7a3 commit 79980eb
Show file tree
Hide file tree
Showing 4 changed files with 76 additions and 4 deletions.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
6 changes: 5 additions & 1 deletion docs/assets/sass/docs.scss
Original file line number Diff line number Diff line change
@@ -1,5 +1,9 @@
@import "node_modules/govuk-frontend/all";

img{
max-width: 100%;
}

// adjust code block font-size to 19px
.hljs {
font-size: 19px;
Expand Down Expand Up @@ -87,7 +91,7 @@
pre {
@extend .app-code;
}

p code {
border: 1px solid $govuk-border-colour;
background-color: govuk-colour("grey-4");
Expand Down
68 changes: 68 additions & 0 deletions docs/documentation/backwards-compatibility.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,68 @@
# Using backwards compatibility

Version 7 of the Prototype Kit uses the new GOV.UK Design System. It is not compatible with prototypes built with older versions by default.

Backwards compatibility lets you import a large old prototype into version 7, without having to rewrite it. You can update old pages one by one as you need to, and add new pages.

You will end up with 2 'apps' in your prototype:

**/app** using version 7

**/app/v6** using version 6

If any pages or routes exist in both apps, the one in version 7 will win.

## Instructions

1. Make a note of your Prototype Kit version in **VERSION.txt** in your prototype folder.

1. Download the latest Prototype Kit and unzip it.

1. Make sure you have a backup of your prototype folder, for example by copying it to another folder or by uploading to GitHub.

1. Delete everything in your prototype folder except for the **app** and **.git** folders. (.git may be hidden).

1. Rename your **app** folder to **v6**

1. Find and replace all instances of **/public/** to **/public/v6/** in your code.
In Atom, press **cmd shift F**. It looks like this:
![Screenshot of Atom find and replace](/public/images/docs/backwards-compatibility-atom.png)

1. Copy everything from the new Prototype Kit folder into your prototype folder.

1. Move your **v6** folder into the new **app** folder.

1. Update **app/config.js** to your settings, in particular the **serviceName**. You can then safely remove **app/v6/config.js**.

1. On the command line, in your prototype folder, run **npm install**, then **npm start**.

1. To see your old homepage, comment out lines 5-7 in **app/routes.js**, like this:
```
// router.get('/', function (req, res) {
// res.render('index')
// })
```

1. If your previous Prototype Kit version was older than 6.3.0, follow the guidance below about updating from older versions.

## Updating pages to use version 7

You can now create new pages using version 7 by working in the app/views folder.

You can update old pages by moving them from app/v6/views to app/views. You will then need to update the code on these pages to work with version 7. See the [updating your code guide in the GOV.UK Design System](https://design-system.service.gov.uk/get-started/updating-your-code/).

## Updating from versions older than 6.3.0

The instructions above are for updating from version 6.3.0 of the Prototype Kit. If you had an older version, follow the normal instructions then run the commands below:

### 6.2.0

```
npm install govuk-elements-sass@3.0.1 govuk_frontend_toolkit@5.1.2 govuk_template_jinja@0.22.1
```

### 6.1.0 or 6.0.0

```
npm install govuk-elements-sass@3.0.1 govuk_frontend_toolkit@5.1.2 govuk_template_jinja@0.19.2
```
6 changes: 3 additions & 3 deletions docs/documentation/updating-the-kit.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,11 +4,11 @@

If you have made any changes outside the `app` folder, this process will destroy those changes. We will try and improve the update process to avoid this, but in the meantime you will need to make a note of your changes outside `app`, and add them back after updating.

## Version 7
## Updating from version 6 to version 7

Version 7 of the GOV.UK Prototype Kit is a large change from previous versions. Updating an old prototype will mean re-writing most of the code.
Version 7 of the GOV.UK Prototype Kit is a large change from previous versions.

We are working on ways to make updating easier, so if you have a large prototype it may be worth waiting for that.
If you have a large old prototype, follow this [guide to backward compatibility](/docs/backwards-compatibility) which lets you update the Prototype Kit without having to rewrite all your pages at once.

There is a [guide to updating your code](https://design-system.service.gov.uk/get-started/updating-your-code/) on the GOV.UK Design System.

Expand Down

0 comments on commit 79980eb

Please sign in to comment.