From b82c6794dc30ac1dcea706cdf27324ed23167500 Mon Sep 17 00:00:00 2001
From: Shane Edwards
Date: Thu, 9 Aug 2018 14:27:18 +0100
Subject: [PATCH 01/11] LMS prototype version added
---
.../your-household-lms/assets/household.js | 120 +++
.../assets/numbers-to-words.js | 146 +++
.../assets/personal-details.js | 185 ++++
.../assets/prototype-tools.js | 139 +++
.../assets/relationships.js | 581 +++++++++++
.../your-household-lms/assets/utils.js | 39 +
_prototypes/your-household-lms/bundle.js | 384 +++++++
.../your-household-lms/confirm-address.html | 95 ++
.../your-household-lms/do-you-live-here.html | 132 +++
.../does-anyone-else-live-here.html | 141 +++
_prototypes/your-household-lms/hub.html | 247 +++++
.../your-household-lms/i-dont-live-here.html | 116 +++
_prototypes/your-household-lms/index.html | 122 +++
.../individual-decision-other-pin.html | 126 +++
.../individual-decision-other-secure.html | 140 +++
.../individual-decision-pin.html | 112 ++
.../individual-decision-secure.html | 148 +++
.../individual-decision.html | 122 +++
.../individual-details-country.html | 191 ++++
.../individual-details-dob.html | 167 +++
.../individual-details-orientation.html | 186 ++++
.../individual-details-relationship.html | 243 +++++
.../individual-details-salary.html | 134 +++
.../individual-details-summary.html | 246 +++++
.../your-household-lms/individual-intro.html | 83 ++
.../individual-pin-security.html | 121 +++
.../lms/do-they-share-cooking-facilities.html | 88 ++
.../lms/do-they-share-dining-living-room.html | 88 ++
.../lms/do-you-live-here.html | 136 +++
.../lms/does-anyone-else-live-here.html | 110 ++
.../lms/does-anyone-live-student-halls.html | 127 +++
.../lms/i-dont-live-here.html | 176 ++++
_prototypes/your-household-lms/lms/index.html | 125 +++
...-there-does-anyone-else-student-halls.html | 103 ++
.../lms/what-is-your-name.html | 118 +++
.../lms/who-else-to-add.html | 158 +++
.../relationships-person-select.html | 283 +++++
.../relationships-summary.html | 985 ++++++++++++++++++
.../your-household-lms/relationships.html | 462 ++++++++
.../your-household-lms/section-intro.html | 74 ++
_prototypes/your-household-lms/style.css | 32 +
_prototypes/your-household-lms/summary.html | 293 ++++++
.../temp-away-from-home.html | 101 ++
.../temp-living-here-feedback.html | 97 ++
.../your-household-lms/temp-living-here.html | 111 ++
.../temp-types-feedback.html | 115 ++
.../temp-types-living-away.html | 150 +++
.../temp-types-question.html | 134 +++
.../your-household-lms/test-address.html | 227 ++++
_prototypes/your-household-lms/test-data.html | 42 +
_prototypes/your-household-lms/visitors.html | 148 +++
.../your-household-lms/what-is-your-name.html | 118 +++
.../your-household-lms/who-else-to-add.html | 177 ++++
53 files changed, 9244 insertions(+)
create mode 100644 _prototypes/your-household-lms/assets/household.js
create mode 100644 _prototypes/your-household-lms/assets/numbers-to-words.js
create mode 100644 _prototypes/your-household-lms/assets/personal-details.js
create mode 100644 _prototypes/your-household-lms/assets/prototype-tools.js
create mode 100644 _prototypes/your-household-lms/assets/relationships.js
create mode 100644 _prototypes/your-household-lms/assets/utils.js
create mode 100644 _prototypes/your-household-lms/bundle.js
create mode 100644 _prototypes/your-household-lms/confirm-address.html
create mode 100644 _prototypes/your-household-lms/do-you-live-here.html
create mode 100644 _prototypes/your-household-lms/does-anyone-else-live-here.html
create mode 100644 _prototypes/your-household-lms/hub.html
create mode 100644 _prototypes/your-household-lms/i-dont-live-here.html
create mode 100644 _prototypes/your-household-lms/index.html
create mode 100644 _prototypes/your-household-lms/individual-decision-other-pin.html
create mode 100644 _prototypes/your-household-lms/individual-decision-other-secure.html
create mode 100644 _prototypes/your-household-lms/individual-decision-pin.html
create mode 100644 _prototypes/your-household-lms/individual-decision-secure.html
create mode 100644 _prototypes/your-household-lms/individual-decision.html
create mode 100644 _prototypes/your-household-lms/individual-details-country.html
create mode 100644 _prototypes/your-household-lms/individual-details-dob.html
create mode 100644 _prototypes/your-household-lms/individual-details-orientation.html
create mode 100644 _prototypes/your-household-lms/individual-details-relationship.html
create mode 100644 _prototypes/your-household-lms/individual-details-salary.html
create mode 100644 _prototypes/your-household-lms/individual-details-summary.html
create mode 100644 _prototypes/your-household-lms/individual-intro.html
create mode 100644 _prototypes/your-household-lms/individual-pin-security.html
create mode 100644 _prototypes/your-household-lms/lms/do-they-share-cooking-facilities.html
create mode 100644 _prototypes/your-household-lms/lms/do-they-share-dining-living-room.html
create mode 100644 _prototypes/your-household-lms/lms/do-you-live-here.html
create mode 100644 _prototypes/your-household-lms/lms/does-anyone-else-live-here.html
create mode 100644 _prototypes/your-household-lms/lms/does-anyone-live-student-halls.html
create mode 100644 _prototypes/your-household-lms/lms/i-dont-live-here.html
create mode 100644 _prototypes/your-household-lms/lms/index.html
create mode 100644 _prototypes/your-household-lms/lms/is-there-does-anyone-else-student-halls.html
create mode 100644 _prototypes/your-household-lms/lms/what-is-your-name.html
create mode 100644 _prototypes/your-household-lms/lms/who-else-to-add.html
create mode 100644 _prototypes/your-household-lms/relationships-person-select.html
create mode 100644 _prototypes/your-household-lms/relationships-summary.html
create mode 100644 _prototypes/your-household-lms/relationships.html
create mode 100644 _prototypes/your-household-lms/section-intro.html
create mode 100644 _prototypes/your-household-lms/style.css
create mode 100644 _prototypes/your-household-lms/summary.html
create mode 100644 _prototypes/your-household-lms/temp-away-from-home.html
create mode 100644 _prototypes/your-household-lms/temp-living-here-feedback.html
create mode 100644 _prototypes/your-household-lms/temp-living-here.html
create mode 100644 _prototypes/your-household-lms/temp-types-feedback.html
create mode 100644 _prototypes/your-household-lms/temp-types-living-away.html
create mode 100644 _prototypes/your-household-lms/temp-types-question.html
create mode 100644 _prototypes/your-household-lms/test-address.html
create mode 100644 _prototypes/your-household-lms/test-data.html
create mode 100644 _prototypes/your-household-lms/visitors.html
create mode 100644 _prototypes/your-household-lms/what-is-your-name.html
create mode 100644 _prototypes/your-household-lms/who-else-to-add.html
diff --git a/_prototypes/your-household-lms/assets/household.js b/_prototypes/your-household-lms/assets/household.js
new file mode 100644
index 0000000000..01e78e53c7
--- /dev/null
+++ b/_prototypes/your-household-lms/assets/household.js
@@ -0,0 +1,120 @@
+import {autoIncrementId} from './utils';
+
+export const HOUSEHOLD_MEMBERS_STORAGE_KEY = 'household-members';
+export const USER_HOUSEHOLD_MEMBER_ID = 'person_me';
+export const HOUSEHOLD_MEMBER_TYPE = 'household-member';
+export const VISITOR_TYPE = 'visitor';
+
+/**
+ * Types
+ */
+export function person(opts) {
+ if (opts.firstName === '' || opts.lastName === '') {
+ console.log('Unable to create person with data: ',
+ opts.firstName,
+ !opts.middleName,
+ !opts.lastName);
+ }
+
+ let middleName = opts.middleName || '';
+
+ return {
+ fullName: opts.firstName + ' ' + middleName + ' ' + opts.lastName,
+ firstName: opts.firstName,
+ middleName,
+ lastName: opts.lastName
+ };
+}
+
+/**
+ * Storage
+ */
+export function getUserAsHouseholdMember() {
+ return getAllHouseholdMembers().find((member) => {
+ return member['@person'].id === USER_HOUSEHOLD_MEMBER_ID;
+ });
+}
+
+export function deleteUserAsHouseholdMember() {
+ deleteHouseholdMember(USER_HOUSEHOLD_MEMBER_ID);
+}
+
+export function deleteHouseholdMember(personId) {
+ let members = getAllHouseholdMembers().filter((member) => {
+ return member['@person'].id !== personId;
+ });
+
+ sessionStorage.setItem(HOUSEHOLD_MEMBERS_STORAGE_KEY,
+ JSON.stringify(members));
+}
+
+export function updateUserAsHouseholdMember(person, memberData) {
+ let userAsHouseholdMember = getUserAsHouseholdMember();
+
+ userAsHouseholdMember
+ ? updateHouseholdMember(userAsHouseholdMember['@person'], memberData)
+ : addHouseholdMember(person, memberData, USER_HOUSEHOLD_MEMBER_ID);
+}
+
+export function updateHouseholdMember(person, memberData) {
+ let membersUpdated = getAllHouseholdMembers().map((member) => {
+ return member['@person'].id === person.id
+ ? {...member, ...memberData, '@person': {...member['@person'], ...person}}
+ : member;
+ });
+
+ sessionStorage.setItem(HOUSEHOLD_MEMBERS_STORAGE_KEY,
+ JSON.stringify(membersUpdated));
+}
+
+export function addHouseholdMember(person, memberData, id) {
+ let people = getAllHouseholdMembers() || [];
+ memberData = memberData || {};
+
+ people.push({
+ ...memberData,
+ type: memberData.type || HOUSEHOLD_MEMBER_TYPE,
+ '@person': {
+ ...person,
+ id: id || 'person' + autoIncrementId('household-members')
+ }
+ });
+
+ sessionStorage.setItem(HOUSEHOLD_MEMBERS_STORAGE_KEY, JSON.stringify(people));
+}
+
+export function getAllHouseholdMembers() {
+ return JSON.parse(sessionStorage.getItem(HOUSEHOLD_MEMBERS_STORAGE_KEY)) || [];
+}
+
+export function getHouseholdMemberByPersonId(id) {
+ return getAllHouseholdMembers().find(function(member) {
+ return member['@person'].id === id;
+ });
+}
+
+export function getMemberPersonId(member) {
+ return member['@person'].id;
+}
+
+/**
+ * Comparators
+ */
+export function isVisitor(member) {
+ return member.type === window.ONS.storage.KEYS.VISITOR_TYPE;
+}
+
+export function isHouseholdMember(member) {
+ return member.type === window.ONS.storage.KEYS.HOUSEHOLD_MEMBER_TYPE;
+}
+
+export function isOtherHouseholdMember(member) {
+ return member.type === window.ONS.storage.KEYS.HOUSEHOLD_MEMBER_TYPE &&
+ member['@person'].id !== window.ONS.storage.IDS.USER_HOUSEHOLD_MEMBER_ID;
+}
+
+export const tempAwayQuestionSentenceMap = {
+ 'studying-away': 'who is working or studying away from home',
+ 'armed-forces': 'who is a member of the armed forces',
+ 'outside-uk': 'who is staying outside the UK for 12 months'
+};
diff --git a/_prototypes/your-household-lms/assets/numbers-to-words.js b/_prototypes/your-household-lms/assets/numbers-to-words.js
new file mode 100644
index 0000000000..f59219fca8
--- /dev/null
+++ b/_prototypes/your-household-lms/assets/numbers-to-words.js
@@ -0,0 +1,146 @@
+/**
+ * Copied from:
+ * https://codereview.stackexchange.com/questions/90349/changing-number-to-words-in-javascript
+ * ===============
+ */
+var ONE_TO_NINETEEN = [
+ 'one', 'two', 'three', 'four', 'five',
+ 'six', 'seven', 'eight', 'nine', 'ten',
+ 'eleven', 'twelve', 'thirteen', 'fourteen', 'fifteen',
+ 'sixteen', 'seventeen', 'eighteen', 'nineteen'
+];
+
+var TENS = [
+ 'ten', 'twenty', 'thirty', 'forty', 'fifty',
+ 'sixty', 'seventy', 'eighty', 'ninety'
+];
+
+var SCALES = ['thousand', 'million', 'billion', 'trillion'];
+
+// helper function for use with Array.filter
+function isTruthy(item) {
+ return !!item;
+}
+
+// convert a number into 'chunks' of 0-999
+function chunk(number) {
+ var thousands = [];
+
+ while(number > 0) {
+ thousands.push(number % 1000);
+ number = Math.floor(number / 1000);
+ }
+
+ return thousands;
+}
+
+// translate a number from 1-999 into English
+function inEnglish(number) {
+ var thousands, hundreds, tens, ones, words = [];
+
+ if(number < 20) {
+ return ONE_TO_NINETEEN[number - 1]; // may be undefined
+ }
+
+ if(number < 100) {
+ ones = number % 10;
+ tens = number / 10 | 0; // equivalent to Math.floor(number / 10)
+
+ words.push(TENS[tens - 1]);
+ words.push(inEnglish(ones));
+
+ return words.filter(isTruthy).join('-');
+ }
+
+ hundreds = number / 100 | 0;
+ words.push(inEnglish(hundreds));
+ words.push('hundred');
+ words.push(inEnglish(number % 100));
+
+ return words.filter(isTruthy).join(' ');
+}
+
+// append the word for a scale. Made for use with Array.map
+function appendScale(chunk, exp) {
+ var scale;
+ if (!chunk) {
+ return null;
+ }
+ scale = SCALES[exp - 1];
+ return [chunk, scale].filter(isTruthy).join(' ');
+}
+
+/**
+ * ===============
+ * End copy
+ */
+
+/**
+ * Modification - decorator
+ */
+var NUMBER_TO_POSITION_TEXT_MAP = {
+ 'one': 'first',
+ 'two': 'second',
+ 'three': 'third',
+ 'four': 'fourth',
+ 'five': 'fifth',
+ 'six': 'sixth',
+ 'seven': 'seventh',
+ 'eight': 'eighth',
+ 'nine': 'nineth',
+ 'ten': 'tenth',
+ 'eleven': 'eleventh',
+ 'twelve': 'twelveth',
+ 'thirteen': 'thirteenth',
+ 'fourteen': 'fourteenth',
+ 'fifteen': 'fifteenth',
+ 'sixteen': 'sixteenth',
+ 'seventeen': 'seventeenth',
+ 'eighteen': 'eighteenth',
+ 'nineteen': 'nineteenth',
+
+ 'twenty': 'twentieth',
+ 'thirty': 'thirtieth',
+ 'forty': 'fortieth',
+ 'fifty': 'fiftieth',
+ 'sixty': 'sixtieth',
+ 'seventy': 'seventieth',
+ 'eighty': 'eightieth',
+ 'ninety': 'ninetieth',
+ 'hundred': 'hundredth',
+
+ 'thousand': 'thousandth',
+ 'million': 'millionth',
+ 'billion': 'billionth',
+ 'trillion': 'trillionth'
+};
+
+export function numberToPositionWord(num) {
+ const str = chunk(num)
+ .map(inEnglish)
+ .map(appendScale)
+ .filter(isTruthy)
+ .reverse()
+ .join(' ');
+
+ const sub = str.split(' '),
+ lastWordDashSplitArr = sub[sub.length - 1].split('-'),
+ lastWord = lastWordDashSplitArr[lastWordDashSplitArr.length - 1],
+
+ newLastWord = (lastWordDashSplitArr.length > 1? lastWordDashSplitArr[0] + '-' : '') +
+ NUMBER_TO_POSITION_TEXT_MAP[lastWord];
+
+ /*console.log('str:', str);
+ console.log('sub:', sub);
+ console.log('lastWordDashSplitArr:', lastWordDashSplitArr);
+ console.log('lastWord:', lastWord);
+ console.log('newLastWord:', newLastWord);*/
+
+ const subCopy = [].concat(sub);
+ subCopy.pop();
+ const prefix = subCopy.join(' ');
+ const result = (prefix ? prefix + ' ' : '') + newLastWord;
+
+ // console.log('result', (prefix ? prefix + ' ' : '') + newLastWord);
+ return result;
+}
diff --git a/_prototypes/your-household-lms/assets/personal-details.js b/_prototypes/your-household-lms/assets/personal-details.js
new file mode 100644
index 0000000000..d9c9f4f5a4
--- /dev/null
+++ b/_prototypes/your-household-lms/assets/personal-details.js
@@ -0,0 +1,185 @@
+export const PERSONAL_DETAILS_KEY = 'individual-details';
+export const PERSONAL_PINS_KEY = 'individual-pins';
+
+export const personalDetailsMaritalStatusMap = {
+ 'never': {
+ description: 'Never married and never registered a same-sex civil' +
+ ' partnership'
+ },
+ 'married': {
+ description: 'Married'
+ },
+ 'registered': {
+ description: 'In a registered same-sex civil partnership'
+ },
+ 'separated-married': {
+ description: 'Separated, but still legally married'
+ },
+ 'divorced': {
+ description: 'Divorced'
+ },
+ 'former-partnership': {
+ description: 'Formerly in a same-sex civil partnership which is now' +
+ ' legally dissolved'
+ },
+ 'widowed': {
+ description: 'Widowed'
+ },
+ 'surviving-partner': {
+ description: 'Surviving partner from a same-sex civil partnership'
+ },
+ 'separated-partnership': {
+ description: 'Separated, but still legally in a same-sex civil partnership'
+ }
+};
+
+export const personalDetailsCountryMap = {
+ 'england': {
+ description: 'England'
+ },
+ 'wales': {
+ description: 'Wales'
+ },
+ 'scotland': {
+ description: 'Scotland'
+ },
+ 'northern-ireland': {
+ description: 'Northern Ireland'
+ },
+ 'republic-ireland': {
+ description: 'Republic of Ireland'
+ },
+ 'elsewhere': {
+ description: 'Elsewhere'
+ }
+};
+
+export const personalDetailsOrientationMap = {
+ 'straight': {
+ description: 'Straight or Heterosexual'
+ },
+ 'gay': {
+ description: 'Gay or Lesbian'
+ },
+ 'bisexual': {
+ description: 'Bisexual'
+ },
+ 'other': {
+ description: 'Other'
+ },
+ 'no-say': {
+ description: 'Prefer not to say'
+ }
+};
+
+export function addUpdatePersonalDetailsDOB(personId, day, month, year) {
+ let allDetails = getAllPersonalDetails(),
+ details = allDetails[personId] || {};
+
+ details['dob'] = {
+ day,
+ month,
+ year
+ };
+
+ updatePersonalDetails(personId, details);
+
+ return details;
+}
+
+export function addUpdateMaritalStatus(personId, val) {
+ let allDetails = getAllPersonalDetails(),
+ details = allDetails[personId] || {};
+
+ details['maritalStatus'] = val;
+
+ updatePersonalDetails(personId, details);
+
+ return details;
+}
+
+export function addUpdateCountry(personId, val) {
+ let allDetails = getAllPersonalDetails(),
+ details = allDetails[personId] || {};
+
+ details['country'] = val;
+
+ updatePersonalDetails(personId, details);
+
+ return details;
+}
+
+export function addUpdateOrientation(personId, val) {
+ let allDetails = getAllPersonalDetails(),
+ details = allDetails[personId] || {};
+
+ details['orientation'] = val;
+
+ updatePersonalDetails(personId, details);
+
+ return details;
+}
+
+export function addUpdateSalary(personId, val) {
+ let allDetails = getAllPersonalDetails(),
+ details = allDetails[personId] || {};
+
+ details['salary'] = val;
+
+ updatePersonalDetails(personId, details);
+
+ return details;
+}
+
+export function getPins() {
+ return JSON.parse(sessionStorage.getItem(PERSONAL_PINS_KEY)) || {};
+}
+
+export function createPinFor(personId, opts = {}) {
+ let pins = getPins();
+
+ pins[personId] = {
+ pin: _.random(10000, 99999),
+ exported: !!opts.exported
+ };
+
+ sessionStorage.setItem(PERSONAL_PINS_KEY, JSON.stringify(pins));
+
+ return pins[personId];
+}
+
+export function getPinFor(personId) {
+ return getPins()[personId];
+}
+
+export function unsetPinFor(personId) {
+ let pins = getPins();
+
+ delete pins[personId];
+
+ sessionStorage.setItem(PERSONAL_PINS_KEY, JSON.stringify(pins));
+}
+
+export function updatePersonalDetails(personId, details) {
+ sessionStorage.setItem(PERSONAL_DETAILS_KEY, JSON.stringify({
+ ...getAllPersonalDetails(),
+ [personId]: details
+ }));
+
+ return details;
+}
+
+export function getAllPersonalDetails() {
+ return JSON.parse(sessionStorage.getItem(PERSONAL_DETAILS_KEY)) || {};
+}
+
+export function getPersonalDetailsFor(personId) {
+ const storageObj = JSON.parse(sessionStorage.getItem(PERSONAL_DETAILS_KEY)) || {},
+ personObj = storageObj[personId];
+
+ if (!personObj) {
+ console.log('Personal details for ' + personId + ' not found');
+ }
+
+ return personObj;
+}
diff --git a/_prototypes/your-household-lms/assets/prototype-tools.js b/_prototypes/your-household-lms/assets/prototype-tools.js
new file mode 100644
index 0000000000..2e8bbdd646
--- /dev/null
+++ b/_prototypes/your-household-lms/assets/prototype-tools.js
@@ -0,0 +1,139 @@
+export function tools () {
+
+ const $listLinks = $('.test-data-links'),
+
+ $createFamilyHousehold = $('' +
+ 'Create family household '),
+
+ $createFamilyRelationships = $('' +
+ 'Create family relationships '),
+
+ familyHouseholdMembersData = [{
+ 'type': 'household-member',
+ '@person': {
+ 'fullName': 'Dave Jones',
+ 'firstName': 'Dave',
+ 'middleName': '',
+ 'lastName': 'Jones',
+ 'id': 'person_me'
+ }
+ }, {
+ 'type':
+ 'household-member',
+ '@person': {
+ 'fullName': 'Sally Jones',
+ 'firstName': 'Sally',
+ 'middleName': '',
+ 'lastName': 'Jones',
+ 'id': 'person1'
+ }
+ }, {
+ 'type': 'household-member',
+ '@person': {
+ 'fullName': 'Rebecca Jones',
+ 'firstName': 'Rebecca',
+ 'middleName': '',
+ 'lastName': 'Jones',
+ 'id': 'person2'
+ }
+ }, {
+ 'type': 'household-member',
+ '@person': {
+ 'fullName': 'Amy Jones',
+ 'firstName': 'Amy',
+ 'middleName': '',
+ 'lastName': 'Jones',
+ 'id': 'person3'
+ }
+ }],
+
+ familyHouseholdRelationshipsData = [{
+ 'personIsDescription': 'husband-wife',
+ 'personIsId': 'person1',
+ 'personToId': 'person_me',
+ 'inferred': false,
+ 'id': 1
+ }, {
+ 'personIsDescription': 'son-daughter',
+ 'personIsId': 'person2',
+ 'personToId': 'person_me',
+ 'inferred': false,
+ 'id': 2
+ }, {
+ 'personIsDescription': 'mother-father',
+ 'personIsId': 'person_me',
+ 'personToId': 'person3',
+ 'inferred': false,
+ 'id': 3
+ }, {
+ 'personIsDescription': 'son-daughter',
+ 'personIsId': 'person2',
+ 'personToId': 'person1',
+ 'inferred': false,
+ 'id': 4
+ }, {
+ 'personIsDescription': 'mother-father',
+ 'personIsId': 'person1',
+ 'personToId': 'person3',
+ 'inferred': false,
+ 'id': 5
+ }, {
+ 'personIsDescription': 'brother-sister',
+ 'personIsId': 'person3',
+ 'personToId': 'person2',
+ 'inferred': true,
+ 'id': 6
+ }],
+
+ userData = {
+ 'fullName': 'Dave Jones',
+ 'firstName': 'Dave',
+ 'middleName': '',
+ 'lastName': 'Jones'
+ };
+
+ $createFamilyHousehold.on('click', function(e) {
+ e.preventDefault();
+ clearStorage();
+ createFamilyHousehold();
+ });
+
+ $createFamilyRelationships.on('click', function(e) {
+ e.preventDefault();
+ clearStorage();
+ createFamilyHousehold();
+ createFamilyRelationships();
+ });
+
+ function prerequisites() {
+ sessionStorage.setItem('address', '12 Somewhere Close, Newport, CF12 3AB');
+ sessionStorage.setItem('address-line-1', '12');
+ sessionStorage.setItem('address-line-2', 'Somewhere close');
+ sessionStorage.setItem('county', 'Newport');
+ sessionStorage.setItem('lives-here', 'yes');
+ sessionStorage.setItem('postcode', 'CF12 3AB');
+ sessionStorage.setItem('town-city', 'Newport');
+ }
+
+ function createFamilyHousehold() {
+ prerequisites();
+ sessionStorage.setItem('user-details', JSON.stringify(userData));
+ sessionStorage.setItem(window.ONS.storage.KEYS.HOUSEHOLD_MEMBERS_STORAGE_KEY, JSON.stringify(familyHouseholdMembersData));
+ sessionStorage.setItem('household-members-increment', JSON.stringify(4));
+ window.location.href = '../summary';
+ }
+
+ function createFamilyRelationships() {
+ sessionStorage.setItem(window.ONS.storage.KEYS.RELATIONSHIPS_STORAGE_KEY, JSON.stringify(familyHouseholdRelationshipsData));
+ sessionStorage.setItem('relationships-increment', JSON.stringify(6));
+ window.location.href = '../relationships-summary';
+ }
+
+ function clearStorage() {
+ sessionStorage.clear();
+ }
+
+ $listLinks.append($createFamilyHousehold);
+ $listLinks.append($createFamilyRelationships);
+}
diff --git a/_prototypes/your-household-lms/assets/relationships.js b/_prototypes/your-household-lms/assets/relationships.js
new file mode 100644
index 0000000000..cb56a3060b
--- /dev/null
+++ b/_prototypes/your-household-lms/assets/relationships.js
@@ -0,0 +1,581 @@
+import {autoIncrementId, removeFromList, trailingNameS} from './utils';
+import {
+ isHouseholdMember,
+ getAllHouseholdMembers,
+ getHouseholdMemberByPersonId
+} from './household';
+
+/**
+ * Augment Underscore library
+ */
+const _ = window._ || {};
+
+export const RELATIONSHIPS_STORAGE_KEY = 'relationships';
+
+export const relationshipTypes = {
+ 'spouse': {id: 'spouse'},
+ 'child-parent': {id: 'child-parent'},
+ 'step-child-parent': {id: 'step-child-parent'},
+ 'grandchild-grandparent': {id: 'grandchild-grandparent'},
+ 'half-sibling': {id: 'half-sibling'},
+ 'sibling': {id: 'sibling'},
+ 'step-brother-sister': {id: 'step-brother-sister'},
+ 'partner': {id: 'partner'},
+ 'unrelated': {id: 'unrelated'},
+ 'other-relation': {id: 'other-relation'}
+};
+
+export const relationshipDescriptionMap = {
+ // covered
+ 'husband-wife': {
+ sentanceLabel: 'husband or wife',
+ summaryAdjective: 'husband or wife',
+ type: relationshipTypes['spouse']
+ },
+ // covered
+ 'mother-father': {
+ sentanceLabel: 'mother or father',
+ summaryAdjective: 'mother or father',
+ type: relationshipTypes['child-parent']
+ },
+ // covered
+ 'step-mother-father': {
+ sentanceLabel: 'stepmother or stepfather',
+ summaryAdjective: 'stepmother or stepfather',
+ type: relationshipTypes['step-child-parent']
+ },
+ // covered
+ 'son-daughter': {
+ sentanceLabel: 'son or daughter',
+ summaryAdjective: 'son or daughter',
+ type: relationshipTypes['child-parent']
+ },
+ // covered
+ 'half-brother-sister': {
+ sentanceLabel: 'half-brother or half-sister',
+ summaryAdjective: 'half-brother or half-sister',
+ type: relationshipTypes['half-sibling']
+ },
+ // covered
+ 'step-child': {
+ sentanceLabel: 'stepchild',
+ summaryAdjective: 'stepchild',
+ type: relationshipTypes['step-child-parent']
+ },
+ // covered
+ 'grandparent': {
+ sentanceLabel: 'grandparent',
+ summaryAdjective: 'grandparent',
+ type: relationshipTypes['grandchild-grandparent']
+ },
+ // covered
+ 'grandchild': {
+ sentanceLabel: 'grandchild',
+ summaryAdjective: 'grandchild',
+ type: relationshipTypes['grandchild-grandparent']
+ },
+ // covered
+ 'brother-sister': {
+ sentanceLabel: 'brother or sister',
+ summaryAdjective: 'brother or sister',
+ type: relationshipTypes['sibling']
+ },
+ // covered
+ 'step-brother-sister': {
+ sentanceLabel: 'stepbrother or stepsister',
+ summaryAdjective: 'stepbrother or stepsister',
+ type: relationshipTypes['step-brother-sister']
+ },
+ // covered
+ 'other-relation': {
+ sentanceLabel: 'other relation',
+ summaryAdjective: 'related',
+ type: relationshipTypes['other-relation']
+ },
+ // covered
+ 'partner': {
+ sentanceLabel: 'partner',
+ summaryAdjective: 'partner',
+ type: relationshipTypes['partner']
+ },
+ 'same-sex-partner': {
+ sentanceLabel: 'legally registered civil partner',
+ summaryAdjective: 'legally registered civil partner',
+ type: relationshipTypes['partner']
+ },
+ // covered
+ 'unrelated': {
+ sentanceLabel: 'unrelated',
+ summaryAdjective: 'unrelated',
+ type: relationshipTypes['unrelated']
+ }
+};
+
+function nameElement(name) {
+ return '' + name + ' ';
+}
+
+function personListStr(peopleArr) {
+ if (peopleArr.length < 1) {
+ console.log(peopleArr, 'not enough people to create a list string');
+ return;
+ }
+
+ if (peopleArr.length === 1) {
+ return nameElement(peopleArr[0]);
+ }
+
+ let peopleCopy = [...peopleArr],
+ lastPerson = peopleCopy.pop();
+
+ return peopleCopy
+ .map(nameElement).join(', ') + ' and ' + nameElement(lastPerson)
+}
+
+export const relationshipSummaryTemplates = {
+ 'partnership': (person1, person2, description) => {
+ return `${nameElement(person1)} is ${nameElement(person2 + trailingNameS(person2))} ${description}`;
+ },
+ 'twoFamilyMembersToMany': (parent1, parent2, childrenArr, description) => {
+ return `${nameElement(parent1)} and ${nameElement(parent2)} are ${personListStr(childrenArr.map(name => name + trailingNameS(name)))} ${description}`;
+ },
+ 'oneFamilyMemberToMany': (parent, childrenArr, description) => {
+ return `${nameElement(parent)} is ${personListStr(childrenArr.map(name => name + trailingNameS(name)))} ${description}`;
+ },
+ 'manyToMany': (peopleArr1, peopleArr2, description) => {
+ return `${personListStr(peopleArr1)} ${peopleArr1.length > 1 ? 'are' : 'is'} ${description} to ${personListStr(peopleArr2)}`;
+ },
+ 'allMutual': (peopleArr, description) => {
+ return `${personListStr(peopleArr)} are ${description}`;
+ }
+};
+
+/**
+ * Types
+ */
+export function relationship(description, personIsId, personToId, opts = {}) {
+ return {
+ personIsDescription: description,
+ personIsId: personIsId,
+ personToId: personToId,
+ inferred: !!opts.inferred
+ };
+}
+
+/**
+ * Storage
+ */
+export function addRelationship(relationshipObj) {
+ let householdRelationships = getAllRelationships() || [],
+ item = {
+ ...relationshipObj,
+ id: autoIncrementId(RELATIONSHIPS_STORAGE_KEY)
+ };
+
+ householdRelationships.push(item);
+
+ sessionStorage.setItem(RELATIONSHIPS_STORAGE_KEY,
+ JSON.stringify(householdRelationships));
+
+ return item;
+}
+
+export function editRelationship(relationshipId, valueObject) {
+ let householdRelationships = (getAllRelationships() || []).map(function(relationship) {
+ return (relationship.id + '') === (relationshipId + '') ? {
+ ...valueObject,
+ id: relationshipId
+ } : relationship;
+ });
+
+ sessionStorage.setItem(RELATIONSHIPS_STORAGE_KEY,
+ JSON.stringify(householdRelationships));
+}
+
+export function getAllRelationships() {
+ return JSON.parse(sessionStorage.getItem(RELATIONSHIPS_STORAGE_KEY)) || [];
+}
+
+export function getAllManualRelationships() {
+ return getAllRelationships().filter((relationship) => {
+ return !relationship.inferred;
+ });
+}
+
+export function deleteAllRelationshipsForMember(personId) {
+ const householdRelationships = getAllRelationships()
+ .filter((relationship) => {
+ return !(personId === relationship.personIsId || personId === relationship.personToId);
+ });
+
+ sessionStorage.setItem(RELATIONSHIPS_STORAGE_KEY,
+ JSON.stringify(householdRelationships));
+}
+
+/**
+ * Comparators
+ */
+export function isInRelationship(personId, relationship) {
+ return relationship.personToId === personId || relationship.personIsId === personId;
+}
+
+export function isAChildInRelationship(personId, relationship) {
+ /**
+ * Guard
+ */
+ if (!isInRelationship(personId, relationship)) {
+ return false;
+ }
+
+ return (
+ relationship.personIsDescription === 'mother-father' &&
+ relationship.personToId === personId
+ ) || (
+ relationship.personIsDescription === 'son-daughter' &&
+ relationship.personIsId === personId
+ );
+}
+
+export function isASiblingInRelationship(personId, relationship) {
+ return isInRelationship(personId, relationship) &&
+ relationshipDescriptionMap[relationship.personIsDescription].type.id === 'sibling';
+}
+
+export function isAParentInRelationship(personId, relationship) {
+ /**
+ * Guard
+ */
+ if (!isInRelationship(personId, relationship)) {
+ return false;
+ }
+
+ return (
+ relationship.personIsDescription === 'mother-father' &&
+ relationship.personIsId === personId
+ ) || (
+ relationship.personIsDescription === 'son-daughter' &&
+ relationship.personToId === personId
+ );
+}
+
+export function areAnyChildrenInRelationshipNotParent(childrenIds, notParentId, relationship) {
+ /**
+ * Guard
+ * If relationship type is not child-parent
+ */
+ if (relationshipDescriptionMap[relationship.personIsDescription]
+ .type.id !== 'child-parent') {
+
+ return false;
+ }
+
+ let childIndexAsPersonIs = childrenIds.indexOf(relationship.personIsId),
+ childIndexAsPersonTo = childrenIds.indexOf(relationship.personToId);
+
+ /**
+ * Find parents with the same children
+ *
+ * If a personIs-child is not in relationship
+ * or 2 children are found in relationship
+ */
+ if (
+ (childIndexAsPersonIs === -1 && childIndexAsPersonTo === -1) ||
+ (childIndexAsPersonIs !== -1 && childIndexAsPersonTo !== -1)
+ ) {
+ return false;
+ }
+
+ /**
+ * Child must be in relationship, get child index
+ */
+ let childIndex = childIndexAsPersonIs !== -1
+ ? childIndexAsPersonIs
+ : childIndexAsPersonTo;
+
+ /**
+ * If personIs is not in relationship
+ * and child from previous relationship is a child in this relationship
+ */
+ return !isInRelationship(notParentId, relationship) &&
+ isAChildInRelationship(childrenIds[childIndex], relationship);
+}
+
+export function isRelationshipType(relationshipType, relationship) {
+ const typeOfRelationship = relationshipDescriptionMap[relationship.personIsDescription]
+ .type.id;
+
+ /**
+ * relationshipType can be an array of types
+ */
+ return _.isArray(relationshipType)
+ ? !!_.find(relationshipType, function(rType) {
+ return rType === typeOfRelationship;
+ })
+ : typeOfRelationship === relationshipType;
+}
+
+/**
+ * Retrieve people by role in relationships
+ */
+export function getParentIdFromRelationship(relationship) {
+ let parentId;
+
+ if (relationship.personIsDescription === 'mother-father') {
+ parentId = relationship.personIsId;
+ }
+
+ if (relationship.personIsDescription === 'son-daughter') {
+ parentId = relationship.personToId;
+ }
+
+ if (!parentId) {
+ console.log('Parent not found in relationship: ', relationship);
+ return false;
+ }
+
+ return parentId;
+}
+
+export function getChildIdFromRelationship(relationship) {
+ let childId;
+
+ if (relationship.personIsDescription === 'mother-father') {
+ childId = relationship.personToId;
+ }
+
+ if (relationship.personIsDescription === 'son-daughter') {
+ childId = relationship.personIsId;
+ }
+
+ if (!childId) {
+ console.log('Child not found in relationship: ', relationship);
+ return false;
+ }
+
+ return childId;
+}
+
+export function getSiblingIdFromRelationship(personId, relationship) {
+ if (!isInRelationship(personId, relationship)) {
+ console.log('Person ' + personId + ' not found in relationship: ', relationship);
+ return false;
+ }
+
+ return relationship[relationship.personIsId === personId ? 'personToId' : 'personIsId'];
+}
+
+export function getOtherPersonIdFromRelationship(personId, relationship) {
+ return relationship.personIsId === personId
+ ? relationship.personToId : relationship.personIsId;
+}
+
+export function getAllParentsOf(personId) {
+ return getAllRelationships()
+ .filter(isAChildInRelationship.bind(null, personId))
+ .map(relationship => getPersonFromMember(getHouseholdMemberByPersonId(getParentIdFromRelationship(relationship))));
+}
+
+export function getAllChildrenOf(personId) {
+ return getAllRelationships()
+ .filter(isAParentInRelationship.bind(null, personId))
+ .map(relationship => getHouseholdMemberByPersonId(getChildIdFromRelationship(relationship))['@person']);
+}
+
+export function getPersonIdFromPerson(person) {
+ return person.id;
+}
+
+export function getPersonFromMember(member) {
+ return member['@person'];
+}
+
+/**
+ * Missing relationship inference
+ */
+export const missingRelationshipInference = {
+ siblingsOf(subjectMember) {
+
+ const missingRelationships = [],
+ allRelationships = getAllRelationships(),
+ person = getPersonFromMember(subjectMember),
+ personId = person.id,
+
+ parents = getAllParentsOf(personId),
+
+ siblingIds = allRelationships
+ .filter(isASiblingInRelationship.bind(null, personId))
+ .map(getSiblingIdFromRelationship.bind(null, personId));
+
+ /**
+ * If 2 parent relationships of 'person' are found we can attempt to infer
+ * sibling relationships
+ */
+ if (parents.length === 2) {
+
+ getAllHouseholdMembers()
+ .filter(isHouseholdMember)
+ .forEach((member) => {
+
+ const memberPersonId = member['@person'].id;
+
+ /**
+ * Guard
+ * If member is the subject member
+ * or member is a parent
+ * or member already has a sibling relationship with 'person'
+ * skip member
+ */
+ if (memberPersonId === personId ||
+ memberPersonId === parents[0].id || memberPersonId === parents[1].id ||
+ siblingIds.indexOf(memberPersonId) > -1) {
+ return;
+ }
+
+ const memberParents = getAllParentsOf(memberPersonId);
+
+ /**
+ * If 2 parents of 'member' are found
+ * and they are the same parents of 'person'
+ * we have identified a missing inferred relationship
+ */
+ if (memberParents.length === 2 &&
+ _.difference(
+ parents.map(getPersonIdFromPerson),
+ memberParents.map(getPersonIdFromPerson)
+ ).length === 0) {
+
+ /**
+ * Add to missingRelationships
+ */
+ missingRelationships.push(relationship(
+ 'brother-sister',
+ person.id,
+ memberPersonId,
+ {inferred: true}
+ ));
+ }
+ });
+ }
+
+ return missingRelationships;
+ }
+};
+
+export function inferRelationships(relationship, personIs, personTo) {
+ var missingRelationships = [];
+
+ if (relationship.personIsDescription === 'mother-father') {
+ missingRelationships = missingRelationships.concat(
+ missingRelationshipInference.siblingsOf(personTo)
+ );
+ }
+
+ if (relationship.personIsDescription === 'son-daughter') {
+ missingRelationships = missingRelationships.concat(
+ missingRelationshipInference.siblingsOf(personIs)
+ );
+ }
+
+ $.each(missingRelationships, function(i, relationship) {
+ addRelationship(relationship);
+ });
+}
+
+export function findNextMissingRelationship() {
+ let householdMembers = getAllHouseholdMembers().filter(isHouseholdMember),
+ relationships = getAllRelationships(),
+ missingRelationshipMembers = [],
+ personIs = null;
+
+ /**
+ * Find the next missing relationship
+ */
+ $.each(householdMembers, function(i, member) {
+ const personId = member['@person'].id;
+
+ /**
+ * Get all relationships for this member
+ */
+ const memberRelationships = relationships.filter(function(relationship) {
+ return relationship.personIsId === personId || relationship.personToId === personId;
+ }),
+
+ memberRelationshipToIds = memberRelationships.map(function(relationship) {
+ return relationship.personIsId === personId ? relationship.personToId : relationship.personIsId;
+ }) || [];
+
+ /**
+ * If total relationships related to this member isn't equal to
+ * total household members -1, indicates missing relationship
+ */
+ if (memberRelationships.length < householdMembers.length - 1) {
+
+ /**
+ * All missing relationship members
+ */
+ missingRelationshipMembers = householdMembers.filter(function(m) {
+ return memberRelationshipToIds.indexOf(m['@person'].id) === -1 &&
+ m['@person'].id !== personId;
+ });
+
+ personIs = member;
+
+ return false;
+ }
+ });
+
+ return personIs ? {
+ personIs: personIs,
+ personTo: missingRelationshipMembers[0]
+ } : null;
+}
+
+export function getPeopleIdsMissingRelationshipsWithPerson(personId) {
+ const remainingPersonIds = getAllHouseholdMembers()
+ .filter(isHouseholdMember)
+ .map(function(member) {
+ return member['@person'].id;
+ });
+
+ /**
+ * Remove this person from the list
+ */
+ removeFromList(remainingPersonIds, personId);
+
+ $.each(getAllRelationships(), function(i, relationship) {
+ if (!isInRelationship(personId, relationship)) {
+ return;
+ }
+
+ /**
+ * Remove the other person from the remainingPersonIds list
+ */
+ removeFromList(
+ remainingPersonIds,
+ getOtherPersonIdFromRelationship(personId, relationship)
+ );
+ });
+
+ return remainingPersonIds;
+}
+
+export function getRelationshipType(relationship) {
+ return relationshipDescriptionMap[relationship.personIsDescription].type;
+}
+
+/**
+ * Retrieve from relationship group
+ */
+export function getRelationshipsWithPersonIds(relationships, idArr) {
+ return relationships.filter(function(childRelationship) {
+ return idArr.indexOf(childRelationship.personIsId) !== -1 ||
+ idArr.indexOf(childRelationship.personToId) !== -1;
+ });
+}
+
+export function getRelationshipOf(person1, person2) {
+ return getAllRelationships().find(function(relationship) {
+ return isInRelationship(person1, relationship) &&
+ isInRelationship(person2, relationship);
+ });
+}
diff --git a/_prototypes/your-household-lms/assets/utils.js b/_prototypes/your-household-lms/assets/utils.js
new file mode 100644
index 0000000000..c0898a3d80
--- /dev/null
+++ b/_prototypes/your-household-lms/assets/utils.js
@@ -0,0 +1,39 @@
+export function autoIncrementId(collection) {
+ let k = collection + '-increment',
+ id = parseInt(sessionStorage.getItem(k)) || 0;
+
+ id++;
+
+ sessionStorage.setItem(k, JSON.stringify(id));
+
+ return id;
+}
+
+export function removeFromList(list, val) {
+
+ function doRemove(item) {
+ var foundId = list.indexOf(item);
+
+ /**
+ * Guard
+ */
+ if (foundId === -1) {
+ console.log('Attempt to remove from list failed: ', list, val);
+ return;
+ }
+
+ list.splice(foundId, 1);
+ }
+
+ if (_.isArray(val)) {
+ $.each(val, function(i, item) {
+ doRemove(item);
+ });
+ } else {
+ doRemove(val);
+ }
+}
+
+export function trailingNameS(name) {
+ return name[name.length - 1] === 's' ? '\’' : '\’s';
+}
diff --git a/_prototypes/your-household-lms/bundle.js b/_prototypes/your-household-lms/bundle.js
new file mode 100644
index 0000000000..e6723392ee
--- /dev/null
+++ b/_prototypes/your-household-lms/bundle.js
@@ -0,0 +1,384 @@
+import {
+ RELATIONSHIPS_STORAGE_KEY,
+ relationshipDescriptionMap,
+ addRelationship,
+ editRelationship,
+ getAllRelationships,
+ getAllManualRelationships,
+ deleteAllRelationshipsForMember,
+ relationshipSummaryTemplates,
+ missingRelationshipInference,
+ inferRelationships,
+ getAllParentsOf,
+ getAllChildrenOf,
+ getParentIdFromRelationship,
+ getChildIdFromRelationship,
+ getOtherPersonIdFromRelationship,
+ isAChildInRelationship,
+ isAParentInRelationship,
+ isInRelationship,
+ areAnyChildrenInRelationshipNotParent,
+ isRelationshipType,
+ getRelationshipOf,
+ getRelationshipsWithPersonIds,
+ getPeopleIdsMissingRelationshipsWithPerson,
+ getRelationshipType,
+ findNextMissingRelationship,
+ relationship
+} from './assets/relationships';
+import {
+ HOUSEHOLD_MEMBER_TYPE,
+ VISITOR_TYPE,
+ USER_HOUSEHOLD_MEMBER_ID,
+ HOUSEHOLD_MEMBERS_STORAGE_KEY,
+ addHouseholdMember,
+ updateHouseholdMember,
+ deleteHouseholdMember,
+ getAllHouseholdMembers,
+ getUserAsHouseholdMember,
+ getHouseholdMemberByPersonId,
+ getMemberPersonId,
+ updateUserAsHouseholdMember,
+ deleteUserAsHouseholdMember,
+ isVisitor,
+ isOtherHouseholdMember,
+ isHouseholdMember,
+ person,
+ tempAwayQuestionSentenceMap
+} from './assets/household';
+import {
+ addUpdatePersonalDetailsDOB,
+ getPersonalDetailsFor,
+ addUpdateMaritalStatus,
+ addUpdateCountry,
+ addUpdateOrientation,
+ addUpdateSalary,
+
+ personalDetailsMaritalStatusMap,
+ personalDetailsCountryMap,
+ personalDetailsOrientationMap,
+
+ createPinFor,
+ getPinFor,
+ unsetPinFor
+} from './assets/personal-details';
+import {removeFromList, trailingNameS} from './assets/utils';
+
+import { numberToPositionWord } from './assets/numbers-to-words';
+
+import { tools } from './assets/prototype-tools';
+
+export const USER_STORAGE_KEY = 'user-details';
+export const INDIVIDUAL_PROXY_STORAGE_KEY = 'proxy-person';
+
+export function getAddress() {
+ let addressLines = sessionStorage.getItem('address').split(',');
+
+ return {
+ addressLine1: addressLines[0],
+ addressLine2: addressLines[1],
+ addressLine3: addressLines[2],
+ addressCounty: addressLines[4],
+ addressTownCity: addressLines[3],
+ addressPostcode: addressLines[5]
+ }
+}
+
+/**
+ * User
+ */
+export function addUserPerson(person) {
+ sessionStorage.setItem(USER_STORAGE_KEY, JSON.stringify(person));
+}
+
+export function getUserPerson() {
+ return JSON.parse(sessionStorage.getItem(USER_STORAGE_KEY));
+}
+
+/**
+ * Helpers
+ */
+function createNavItem(member) {
+ let $nodeEl = $('' +
+ ' ' +
+ ' '),
+ $linkEl = $nodeEl.find('.js-template-nav-item-label');
+
+ $linkEl.html(member['@person'].fullName);
+
+ if (member['@person'].id === USER_HOUSEHOLD_MEMBER_ID) {
+ $linkEl.attr('href', '../what-is-your-name');
+ } else {
+ $linkEl.attr('href', '../who-else-to-add?edit=' + member['@person'].id);
+ }
+
+ return $nodeEl;
+}
+
+function updateHouseholdVisitorsNavigationItems() {
+ let allHouseholdMembers = window.ONS.storage.getAllHouseholdMembers(),
+ householdMembers = allHouseholdMembers.filter(window.ONS.storage.isHouseholdMember),
+ visitors = allHouseholdMembers.filter(window.ONS.storage.isVisitor);
+
+ const $navigationHouseholdMembersEl = $('#navigation-household-members'),
+ $navigationVisitorsEl = $('#navigation-visitors');
+
+ if (householdMembers.length) {
+ $.each(householdMembers, function(i, member) {
+ $navigationHouseholdMembersEl.append(createNavItem(member));
+ });
+ } else {
+ $navigationHouseholdMembersEl.parent().hide();
+ }
+
+ if (visitors.length) {
+ $.each(visitors, function(i, member) {
+ $navigationVisitorsEl.append(createNavItem(member));
+ });
+ } else {
+ $navigationVisitorsEl.parent().hide();
+ }
+}
+
+function createListItemPerson(member) {
+ return $('').addClass('mars').html(
+ '' + member['@person'].fullName + ' '
+ );
+}
+
+function populateList($el, memberType) {
+ if (!$el.length) {
+ return;
+ }
+
+ let members = getAllHouseholdMembers() || [];
+
+ $el.empty().append(members.filter((member) => {
+ return member.type === memberType;
+ }).map(createListItemPerson));
+
+ $el.addClass('list list--people-plain');
+}
+
+function populateHouseholdList() {
+ populateList($('#household-members'), HOUSEHOLD_MEMBER_TYPE);
+}
+
+function populateVisitorList() {
+ populateList($('#visitors-list'), VISITOR_TYPE);
+}
+
+function updateAddresses() {
+ let addressLines = (sessionStorage.getItem('address') || '').split(','),
+ addressLine1 = addressLines[0],
+ addressLine2 = addressLines[1];
+
+ $('#section-address').html(addressLine1 || 'Address not' +
+ ' found ');
+ $('.address-text').html(
+ addressLine1 && addressLine2
+ ? (
+ addressLine1 + (addressLine2 ? ', ' + addressLine2 : '')
+ )
+ : 'Address not found '
+ );
+
+ $('.address-text-line1').html(addressLine1);
+
+ let personId = new URLSearchParams(window.location.search).get('person'),
+ person;
+
+ if (personId) {
+ person = getHouseholdMemberByPersonId(personId)['@person'];
+ $('#section-individual').html(person.fullName);
+
+ $('.js-person-fullname-from-url-id').html(person.fullName);
+ }
+}
+
+const secureLinkTextMap = {
+ 'question-you': {
+ description: 'Want to keep your answers secure from other people at this' +
+ ' address?',
+ linkText: 'Get a separate access code to submit an individual response',
+ link: '../individual-decision-secure'
+ },
+ 'pin-you': {
+ description: 'You\'ve chosen to keep your answers secure',
+ linkText: 'Cancel this and make answers available to the rest of the' +
+ ' household',
+ link: '../individual-decision-secure'
+ },
+ 'question-proxy': {
+ description: 'Not happy to continue answering for $[NAME]?',
+ linkText: 'Request an individual access code to be sent to them',
+ link: '../individual-decision-other-secure'
+ }
+};
+
+function updateAllPreviousLinks() {
+ $('.js-previous-link').attr('href', document.referrer);
+}
+
+function updatePersonLink() {
+ const personId = new URLSearchParams(window.location.search).get('person');
+
+ if (personId) {
+ let urlParam = new URLSearchParams(window.location.search),
+ person = getHouseholdMemberByPersonId(personId)['@person'],
+ pinObj = getPinFor(personId),
+ secureLinkTextConfig = secureLinkTextMap[
+ (getAnsweringIndividualByProxy() ? 'question-proxy' : (pinObj && pinObj.pin ? 'pin-you' : 'question-you'))
+ ],
+ linkHref = secureLinkTextConfig.link + '?person=' + personId +
+ '&returnurl=' + window.location.pathname,
+ surveyType = urlParam.get('survey');
+
+ linkHref += (surveyType ? '&survey=' + surveyType : '');
+
+ let $secureLink = $('.js-link-secure');
+ $secureLink.attr('href', linkHref);
+
+ $secureLink.html(secureLinkTextConfig.linkText);
+ $('.js-link-secure-label').html(secureLinkTextConfig.description.replace('$[NAME]', person.fullName));
+
+ let personLink = $('.js-link-person');
+ personLink.attr('href', personLink.attr('href') + '?person=' + personId +
+ (surveyType ? '&survey=' + surveyType : ''));
+ }
+}
+
+function updateBySurveyType() {
+ const urlParams = new URLSearchParams(window.location.search),
+ surveyType = urlParams.get('survey');
+
+ if (surveyType) {
+ $('.js-header-title').html(surveyTypeConfig[surveyType].title);
+ $('#people-living-here').html(surveyTypeConfig[surveyType].householdSectionTitle);
+ $('#people-living-here').attr('href', surveyTypeConfig[surveyType].householdSectionLink);
+ $('#relationships-section').attr('href', surveyTypeConfig[surveyType].relationshipsSection);
+ $('title').html(surveyTypeConfig[surveyType].title);
+ }
+}
+
+function setAnsweringIndividualByProxy(bool) {
+ sessionStorage.setItem(INDIVIDUAL_PROXY_STORAGE_KEY, JSON.stringify(bool));
+}
+
+function getAnsweringIndividualByProxy() {
+ return JSON.parse(sessionStorage.getItem(INDIVIDUAL_PROXY_STORAGE_KEY));
+}
+
+const surveyTypeConfig = {
+ lms: {
+ title: 'Online Household Study',
+ householdSectionTitle: 'About your household',
+ householdSectionLink: '../summary/?survey=lms',
+ relationshipsSection: '../relationships/?survey=lms'
+ }
+};
+
+window.ONS = window.ONS || {};
+window.ONS.storage = {
+ getAddress,
+ addHouseholdMember,
+ updateHouseholdMember,
+ deleteHouseholdMember,
+ getAllHouseholdMembers,
+ addUserPerson,
+ getUserPerson,
+ getUserAsHouseholdMember,
+ getHouseholdMemberByPersonId,
+ getMemberPersonId,
+ updateUserAsHouseholdMember,
+ deleteUserAsHouseholdMember,
+ tempAwayQuestionSentenceMap,
+
+ isVisitor,
+ isOtherHouseholdMember,
+ isHouseholdMember,
+
+ addRelationship,
+ editRelationship,
+ getAllRelationships,
+ getAllManualRelationships,
+ deleteAllRelationshipsForMember,
+
+ getAllParentsOf,
+ getAllChildrenOf,
+ getParentIdFromRelationship,
+ getChildIdFromRelationship,
+ getOtherPersonIdFromRelationship,
+ isAParentInRelationship,
+ isAChildInRelationship,
+ isInRelationship,
+ areAnyChildrenInRelationshipNotParent,
+ isRelationshipType,
+ getRelationshipOf,
+
+ relationshipDescriptionMap,
+ relationshipSummaryTemplates,
+ missingRelationshipInference,
+ inferRelationships,
+ getRelationshipsWithPersonIds,
+ getPeopleIdsMissingRelationshipsWithPerson,
+ getRelationshipType,
+ findNextMissingRelationship,
+
+ addUpdatePersonalDetailsDOB,
+ getPersonalDetailsFor,
+ addUpdateMaritalStatus,
+ addUpdateCountry,
+ addUpdateOrientation,
+ addUpdateSalary,
+
+ personalDetailsMaritalStatusMap,
+ personalDetailsCountryMap,
+ personalDetailsOrientationMap,
+
+ createPinFor,
+ getPinFor,
+ unsetPinFor,
+
+ setAnsweringIndividualByProxy,
+ getAnsweringIndividualByProxy,
+
+ KEYS: {
+ HOUSEHOLD_MEMBERS_STORAGE_KEY,
+ USER_STORAGE_KEY,
+ INDIVIDUAL_PROXY_STORAGE_KEY,
+ HOUSEHOLD_MEMBER_TYPE,
+ VISITOR_TYPE,
+ RELATIONSHIPS_STORAGE_KEY
+ },
+
+ IDS: {
+ USER_HOUSEHOLD_MEMBER_ID
+ },
+
+ TYPES: {
+ person,
+ relationship
+ }
+};
+
+window.ONS.helpers = {
+ populateHouseholdList,
+ populateVisitorList
+};
+
+window.ONS.utils = {
+ removeFromList,
+ trailingNameS,
+ numberToPositionWord
+};
+
+$(populateHouseholdList);
+$(populateVisitorList);
+$(updateHouseholdVisitorsNavigationItems);
+$(updateAddresses);
+$(updatePersonLink);
+$(tools);
+$(updateAllPreviousLinks);
+$(updateBySurveyType);
diff --git a/_prototypes/your-household-lms/confirm-address.html b/_prototypes/your-household-lms/confirm-address.html
new file mode 100644
index 0000000000..8877f3574e
--- /dev/null
+++ b/_prototypes/your-household-lms/confirm-address.html
@@ -0,0 +1,95 @@
+---
+title: Household prototype v4
+project: your-household
+globalcss: false
+layout: eq-default-extras
+cdn: v1.5.0
+---
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/_prototypes/your-household-lms/do-you-live-here.html b/_prototypes/your-household-lms/do-you-live-here.html
new file mode 100644
index 0000000000..4d60f6fdca
--- /dev/null
+++ b/_prototypes/your-household-lms/do-you-live-here.html
@@ -0,0 +1,132 @@
+---
+title: Household prototype v4
+project: your-household
+globalcss: false
+layout: eq-default-extras
+cdn: v1.5.0
+---
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/_prototypes/your-household-lms/does-anyone-else-live-here.html b/_prototypes/your-household-lms/does-anyone-else-live-here.html
new file mode 100644
index 0000000000..9a98d24a9a
--- /dev/null
+++ b/_prototypes/your-household-lms/does-anyone-else-live-here.html
@@ -0,0 +1,141 @@
+---
+title: Household prototype v4
+project: your-household
+globalcss: false
+layout: eq-default-extras
+cdn: v1.5.0
+---
+
+
+
+
+
+
+
+
+
diff --git a/_prototypes/your-household-lms/hub.html b/_prototypes/your-household-lms/hub.html
new file mode 100644
index 0000000000..cc13a5ad9c
--- /dev/null
+++ b/_prototypes/your-household-lms/hub.html
@@ -0,0 +1,247 @@
+---
+title: Household prototype v4
+project: your-household
+globalcss: false
+layout: eq-default-extras
+cdn: v1.5.0
+---
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/_prototypes/your-household-lms/i-dont-live-here.html b/_prototypes/your-household-lms/i-dont-live-here.html
new file mode 100644
index 0000000000..0ba1a5f35b
--- /dev/null
+++ b/_prototypes/your-household-lms/i-dont-live-here.html
@@ -0,0 +1,116 @@
+---
+title: Household prototype v4
+project: your-household
+globalcss: false
+layout: eq-default-extras
+cdn: v1.5.0
+---
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/_prototypes/your-household-lms/index.html b/_prototypes/your-household-lms/index.html
new file mode 100644
index 0000000000..d23be0bfba
--- /dev/null
+++ b/_prototypes/your-household-lms/index.html
@@ -0,0 +1,122 @@
+---
+title: Household prototype v4
+project: your-household
+globalcss: false
+layout: eq-default-extras
+cdn: v1.5.0
+---
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Welcome to the household prototype
+
+
+
+
+
+
+
+ Enter the unique access code
+
+
+
+
+
+
+
The unique access code
+ is printed on your invitation
+ letter or form
+
+
+
+
Your personal information is protected by law and will be kept confidential
+
+
+
+
+
+ Submit code
+
+
+
+
+
+
+
+
+
+
diff --git a/_prototypes/your-household-lms/individual-decision-other-pin.html b/_prototypes/your-household-lms/individual-decision-other-pin.html
new file mode 100644
index 0000000000..d956b79aee
--- /dev/null
+++ b/_prototypes/your-household-lms/individual-decision-other-pin.html
@@ -0,0 +1,126 @@
+---
+title: Household prototype v4
+project: your-household
+globalcss: false
+layout: eq-default-extras
+cdn: v1.5.0
+---
+
+
+
+
+
+
+
+ {% include navigation.html
+ items=site.data.your-household-v4.yourHouseholdV4_navigationItemsPersonalDetails
+ nav-title-id="section-individual" %}
+
+
+
+
+
+
+
+
diff --git a/_prototypes/your-household-lms/individual-decision-other-secure.html b/_prototypes/your-household-lms/individual-decision-other-secure.html
new file mode 100644
index 0000000000..8a6eb03bfb
--- /dev/null
+++ b/_prototypes/your-household-lms/individual-decision-other-secure.html
@@ -0,0 +1,140 @@
+---
+title: Household prototype v4
+project: your-household
+globalcss: false
+layout: eq-default-extras
+cdn: v1.5.0
+---
+
+
+
+
+
+
+
+ {% include navigation.html
+ items=site.data.your-household-v4.yourHouseholdV4_navigationItemsPersonalDetails
+ nav-title-id="section-individual" %}
+
+
+
+
+
+
+
+
diff --git a/_prototypes/your-household-lms/individual-decision-pin.html b/_prototypes/your-household-lms/individual-decision-pin.html
new file mode 100644
index 0000000000..ebd9524ded
--- /dev/null
+++ b/_prototypes/your-household-lms/individual-decision-pin.html
@@ -0,0 +1,112 @@
+---
+title: Household prototype v4
+project: your-household
+globalcss: false
+layout: eq-default-extras
+cdn: v1.5.0
+---
+
+
+
+
+
+
+
+
+
+
+
diff --git a/_prototypes/your-household-lms/individual-decision-secure.html b/_prototypes/your-household-lms/individual-decision-secure.html
new file mode 100644
index 0000000000..07fd37f160
--- /dev/null
+++ b/_prototypes/your-household-lms/individual-decision-secure.html
@@ -0,0 +1,148 @@
+---
+title: Household prototype v4
+project: your-household
+globalcss: false
+layout: eq-default-extras
+cdn: v1.5.0
+---
+
+
+
+
+
+
+
+ {% include navigation.html
+ items=site.data.your-household-v4.yourHouseholdV4_navigationItemsPersonalDetails
+ nav-title-id="section-individual" %}
+
+
+
+
+
+
+
+
diff --git a/_prototypes/your-household-lms/individual-decision.html b/_prototypes/your-household-lms/individual-decision.html
new file mode 100644
index 0000000000..213d4cdb4f
--- /dev/null
+++ b/_prototypes/your-household-lms/individual-decision.html
@@ -0,0 +1,122 @@
+---
+title: Household prototype v4
+project: your-household
+globalcss: false
+layout: eq-default-extras
+cdn: v1.5.0
+---
+
+
+
+
+
+
+
+ {% include navigation.html
+ items=site.data.your-household-v4.yourHouseholdV4_navigationItemsPersonalDetails
+ nav-title-id="section-individual" %}
+
+
+
+
+
+
+
+
diff --git a/_prototypes/your-household-lms/individual-details-country.html b/_prototypes/your-household-lms/individual-details-country.html
new file mode 100644
index 0000000000..74926454d2
--- /dev/null
+++ b/_prototypes/your-household-lms/individual-details-country.html
@@ -0,0 +1,191 @@
+---
+title: Household prototype v4
+project: your-household
+globalcss: false
+layout: eq-default-extras
+cdn: v1.5.0
+---
+
+
+
+
+
+
+
+ {% include navigation.html
+ items=site.data.your-household-v4.yourHouseholdV4_navigationItemsPersonalDetails
+ nav-title-id="section-individual" %}
+
+
+
+
+
+
+
+
diff --git a/_prototypes/your-household-lms/individual-details-dob.html b/_prototypes/your-household-lms/individual-details-dob.html
new file mode 100644
index 0000000000..97e785b28d
--- /dev/null
+++ b/_prototypes/your-household-lms/individual-details-dob.html
@@ -0,0 +1,167 @@
+---
+title: Household prototype v4
+project: your-household
+globalcss: false
+layout: eq-default-extras
+cdn: v1.5.0
+---
+
+
+
+
+
+
+
+ {% include navigation.html
+ items=site.data.your-household-v4.yourHouseholdV4_navigationItemsPersonalDetails
+ nav-title-id="section-individual" %}
+
+
+
+
+
+
+
+
diff --git a/_prototypes/your-household-lms/individual-details-orientation.html b/_prototypes/your-household-lms/individual-details-orientation.html
new file mode 100644
index 0000000000..1ff3260c03
--- /dev/null
+++ b/_prototypes/your-household-lms/individual-details-orientation.html
@@ -0,0 +1,186 @@
+---
+title: Household prototype v4
+project: your-household
+globalcss: false
+layout: eq-default-extras
+cdn: v1.5.0
+---
+
+
+
+
+
+
+
+ {% include navigation.html
+ items=site.data.your-household-v4.yourHouseholdV4_navigationItemsPersonalDetails
+ nav-title-id="section-individual" %}
+
+
+
+
+
+
+
+
diff --git a/_prototypes/your-household-lms/individual-details-relationship.html b/_prototypes/your-household-lms/individual-details-relationship.html
new file mode 100644
index 0000000000..852da1de9a
--- /dev/null
+++ b/_prototypes/your-household-lms/individual-details-relationship.html
@@ -0,0 +1,243 @@
+---
+title: Household prototype v4
+project: your-household
+globalcss: false
+layout: eq-default-extras
+cdn: v1.5.0
+---
+
+
+
+
+
+
+
+ {% include navigation.html
+ items=site.data.your-household-v4.yourHouseholdV4_navigationItemsPersonalDetails
+ nav-title-id="section-individual" %}
+
+
+
+
+
+
+
+
diff --git a/_prototypes/your-household-lms/individual-details-salary.html b/_prototypes/your-household-lms/individual-details-salary.html
new file mode 100644
index 0000000000..901ed09029
--- /dev/null
+++ b/_prototypes/your-household-lms/individual-details-salary.html
@@ -0,0 +1,134 @@
+---
+title: Household prototype v4
+project: your-household
+globalcss: false
+layout: eq-default-extras
+cdn: v1.5.0
+---
+
+
+
+
+
+
+
+ {% include navigation.html
+ items=site.data.your-household-v4.yourHouseholdV4_navigationItemsPersonalDetails
+ nav-title-id="section-individual" %}
+
+
+
+
+
+
+
+
diff --git a/_prototypes/your-household-lms/individual-details-summary.html b/_prototypes/your-household-lms/individual-details-summary.html
new file mode 100644
index 0000000000..308c676e46
--- /dev/null
+++ b/_prototypes/your-household-lms/individual-details-summary.html
@@ -0,0 +1,246 @@
+---
+title: Household prototype v4
+project: your-household
+globalcss: false
+layout: eq-default-extras
+cdn: v1.5.0
+---
+
+
+
+
+
+
+
+
+
+ {% include navigation.html
+ items=site.data.your-household-v4.yourHouseholdV4_navigationItemsPersonalDetails
+ nav-title-id="section-individual" %}
+
+
+
+
+
+
+
+
+
diff --git a/_prototypes/your-household-lms/individual-intro.html b/_prototypes/your-household-lms/individual-intro.html
new file mode 100644
index 0000000000..1ad2d8ab23
--- /dev/null
+++ b/_prototypes/your-household-lms/individual-intro.html
@@ -0,0 +1,83 @@
+---
+title: Household prototype v4
+project: your-household
+globalcss: false
+layout: eq-default-extras
+cdn: v1.5.0
+---
+
+
+
+
+
+
+
+ {% include navigation.html
+ items=site.data.your-household-v4.yourHouseholdV4_navigationItemsPersonalDetails
+ nav-title-id="section-individual" %}
+
+
+
+
+
+
+
+
+ In this sub section, we’re going to
+ ask you questions about .
+
+
+ Information you will need:
+
+ Personal details such as date of birth, country of birth, sexual orientation and religion etc.
+ Education and qualifications
+ Employment, income and travel to work
+ Second or holiday homes
+ Unpaid care, health and well-being
+
+
+ Submitting an individual response
+ When completing this section, we will ask you if you would like to submit an
+ individual response. Choose this option if you don't want other people at this address to view
+ your answers
+
+
+
+
+ Continue
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/_prototypes/your-household-lms/individual-pin-security.html b/_prototypes/your-household-lms/individual-pin-security.html
new file mode 100644
index 0000000000..b565761510
--- /dev/null
+++ b/_prototypes/your-household-lms/individual-pin-security.html
@@ -0,0 +1,121 @@
+---
+title: Household prototype v4
+project: your-household
+globalcss: false
+layout: eq-default-extras
+cdn: v1.5.0
+---
+
+
+
+
+
+
+
+
+
diff --git a/_prototypes/your-household-lms/lms/do-they-share-cooking-facilities.html b/_prototypes/your-household-lms/lms/do-they-share-cooking-facilities.html
new file mode 100644
index 0000000000..7d68ab9909
--- /dev/null
+++ b/_prototypes/your-household-lms/lms/do-they-share-cooking-facilities.html
@@ -0,0 +1,88 @@
+---
+title: Online Household Study
+project: your-household
+globalcss: false
+layout: eq-default-extras
+cdn: v1.5.0
+---
+
+
+
+
+
+
+
+
+
diff --git a/_prototypes/your-household-lms/lms/do-they-share-dining-living-room.html b/_prototypes/your-household-lms/lms/do-they-share-dining-living-room.html
new file mode 100644
index 0000000000..693dc6695b
--- /dev/null
+++ b/_prototypes/your-household-lms/lms/do-they-share-dining-living-room.html
@@ -0,0 +1,88 @@
+---
+title: Online Household Study
+project: your-household
+globalcss: false
+layout: eq-default-extras
+cdn: v1.5.0
+---
+
+
+
+
+
+
+
+
+
diff --git a/_prototypes/your-household-lms/lms/do-you-live-here.html b/_prototypes/your-household-lms/lms/do-you-live-here.html
new file mode 100644
index 0000000000..351b0c1188
--- /dev/null
+++ b/_prototypes/your-household-lms/lms/do-you-live-here.html
@@ -0,0 +1,136 @@
+---
+title: Online Household Study
+project: your-household
+globalcss: false
+layout: eq-default-extras
+cdn: v1.5.0
+---
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/_prototypes/your-household-lms/lms/does-anyone-else-live-here.html b/_prototypes/your-household-lms/lms/does-anyone-else-live-here.html
new file mode 100644
index 0000000000..42e0765e0c
--- /dev/null
+++ b/_prototypes/your-household-lms/lms/does-anyone-else-live-here.html
@@ -0,0 +1,110 @@
+---
+title: Online Household Study
+project: your-household
+globalcss: false
+layout: eq-default-extras
+cdn: v1.5.0
+---
+
+
+
+
+
+
+
+
+
diff --git a/_prototypes/your-household-lms/lms/does-anyone-live-student-halls.html b/_prototypes/your-household-lms/lms/does-anyone-live-student-halls.html
new file mode 100644
index 0000000000..48e346dd63
--- /dev/null
+++ b/_prototypes/your-household-lms/lms/does-anyone-live-student-halls.html
@@ -0,0 +1,127 @@
+---
+title: Online Household Study
+project: your-household
+globalcss: false
+layout: eq-default-extras
+cdn: v1.5.0
+---
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/_prototypes/your-household-lms/lms/i-dont-live-here.html b/_prototypes/your-household-lms/lms/i-dont-live-here.html
new file mode 100644
index 0000000000..a28bba6983
--- /dev/null
+++ b/_prototypes/your-household-lms/lms/i-dont-live-here.html
@@ -0,0 +1,176 @@
+---
+title: Online Household Study
+project: your-household
+globalcss: false
+layout: eq-default-extras
+cdn: v1.5.0
+---
+
+
+
+
+
+
+
+
+
+
+
diff --git a/_prototypes/your-household-lms/lms/index.html b/_prototypes/your-household-lms/lms/index.html
new file mode 100644
index 0000000000..6aa7ce3d0a
--- /dev/null
+++ b/_prototypes/your-household-lms/lms/index.html
@@ -0,0 +1,125 @@
+---
+title: Online Household Study
+project: your-household
+globalcss: false
+layout: eq-default-extras
+cdn: v1.5.0
+---
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Welcome to the Online Household Study
+
+
+
+
+
+
+
+ Enter the unique access code
+
+
+
+
+
+
+
The unique access code
+ is printed on your invitation
+ letter or form
+
+
+
+
Your personal
+ information is protected by law and will be
+ kept confidential. Responses are saved at
+ the end of each age and may be used even if
+ you have not fully completed the study.
+
+
+
+
+ Submit code
+
+
+
+
+
+
+
+
+
+
diff --git a/_prototypes/your-household-lms/lms/is-there-does-anyone-else-student-halls.html b/_prototypes/your-household-lms/lms/is-there-does-anyone-else-student-halls.html
new file mode 100644
index 0000000000..4b6ccb747c
--- /dev/null
+++ b/_prototypes/your-household-lms/lms/is-there-does-anyone-else-student-halls.html
@@ -0,0 +1,103 @@
+---
+title: Online Household Study
+project: your-household
+globalcss: false
+layout: eq-default-extras
+cdn: v1.5.0
+---
+
+
+
+
+
+
+
+
+
diff --git a/_prototypes/your-household-lms/lms/what-is-your-name.html b/_prototypes/your-household-lms/lms/what-is-your-name.html
new file mode 100644
index 0000000000..1703a9df75
--- /dev/null
+++ b/_prototypes/your-household-lms/lms/what-is-your-name.html
@@ -0,0 +1,118 @@
+---
+title: Online Household Study
+project: your-household
+globalcss: false
+layout: eq-default-extras
+cdn: v1.5.0
+---
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ What is your name?
+
+
+
+ What is your name?
+
+
+
+
+
+
+
+
+ Save and continue
+
+
+
+
+
+
+
+
+
+
diff --git a/_prototypes/your-household-lms/lms/who-else-to-add.html b/_prototypes/your-household-lms/lms/who-else-to-add.html
new file mode 100644
index 0000000000..7ed597b40f
--- /dev/null
+++ b/_prototypes/your-household-lms/lms/who-else-to-add.html
@@ -0,0 +1,158 @@
+---
+title: Online Household Study
+project: your-household
+globalcss: false
+layout: eq-default-extras
+cdn: v1.5.0
+---
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Who do you need to add to
+
+
+
+
Include all
+ adults, children and babies who class this
+ as their main residence, even if they
+ are currently away for a continuous
+ period of up to 6 months
+
+
+
+
+
+ What is your name?
+
+
+
+
+
+
+
+
+ Save and continue
+
+
+
+
+
+
+
+
+
+
diff --git a/_prototypes/your-household-lms/relationships-person-select.html b/_prototypes/your-household-lms/relationships-person-select.html
new file mode 100644
index 0000000000..4ab57e47ac
--- /dev/null
+++ b/_prototypes/your-household-lms/relationships-person-select.html
@@ -0,0 +1,283 @@
+---
+title: Household prototype v4
+project: your-household
+globalcss: false
+householdMembers:
+visitors:
+layout: eq-default-extras
+cdn: v1.5.0
+---
+
+
+
+
+
+
+
+ {% include navigation.html
+ items=site.data.your-household-v4.navigationItemsRelationships
+ nav-title-id="section-address" %}
+
+
+
+
+
+
+
+
+
+
diff --git a/_prototypes/your-household-lms/relationships-summary.html b/_prototypes/your-household-lms/relationships-summary.html
new file mode 100644
index 0000000000..b61f7c904e
--- /dev/null
+++ b/_prototypes/your-household-lms/relationships-summary.html
@@ -0,0 +1,985 @@
+---
+title: Household prototype v4
+project: your-household
+globalcss: false
+householdMembers:
+visitors:
+layout: eq-default-extras
+cdn: v1.5.0
+---
+
+
+
+
+
+
+
+ {% include navigation.html
+ items=site.data.your-household-v4.navigationItemsRelationships
+ nav-title-id="section-address" %}
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/_prototypes/your-household-lms/relationships.html b/_prototypes/your-household-lms/relationships.html
new file mode 100644
index 0000000000..ab4853d6bb
--- /dev/null
+++ b/_prototypes/your-household-lms/relationships.html
@@ -0,0 +1,462 @@
+---
+title: Household prototype v4
+project: your-household
+globalcss: false
+householdMembers:
+visitors:
+layout: eq-default-extras
+cdn: v1.5.0
+---
+
+
+
+
+
+
+
+ {% include navigation.html
+ items=site.data.your-household-v4.navigationItemsRelationships
+ nav-title-id="section-address" %}
+
+
+
+
+
+
+
+
+
+
diff --git a/_prototypes/your-household-lms/section-intro.html b/_prototypes/your-household-lms/section-intro.html
new file mode 100644
index 0000000000..38a3687531
--- /dev/null
+++ b/_prototypes/your-household-lms/section-intro.html
@@ -0,0 +1,74 @@
+---
+title: Household prototype v4
+project: your-household
+globalcss: false
+layout: eq-default-extras
+cdn: v1.5.0
+---
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ People who live here
+
+ In this sub section, we’re going to
+ ask you about all the people that live at or
+ are visiting .
+
+
+ Information you will need:
+
+ Names of the people living at this
+ address
+ Names of the visitors staying in the
+ household on 20 July 2018
+
+
+
+
+
+
+ Continue
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/_prototypes/your-household-lms/style.css b/_prototypes/your-household-lms/style.css
new file mode 100644
index 0000000000..63b67ce2bd
--- /dev/null
+++ b/_prototypes/your-household-lms/style.css
@@ -0,0 +1,32 @@
+.list.list--people-plain {
+ margin-bottom : 1rem;
+ list-style-type : none;
+}
+
+.list.list--people-plain .list__item {
+ background: url(/img/icons/person.svg) 0 .2rem no-repeat;
+}
+
+.list.list--people-plain .list__item-name {
+ padding-left: 1.5rem;
+}
+
+.list.list--people-plain .list__item-actions {
+ margin-top: -4px;
+}
+
+.list.list--people-plain .list__item-action + .list__item-action {
+ margin-left : .5rem;
+}
+
+/**
+ * Pattern library fix
+ */
+.header {
+ margin-bottom : 0;
+}
+
+.lock {
+ padding-left : 1.5rem;
+ background : url('../img/icons/lockicon.svg') no-repeat left top;
+}
diff --git a/_prototypes/your-household-lms/summary.html b/_prototypes/your-household-lms/summary.html
new file mode 100644
index 0000000000..18f46f74e4
--- /dev/null
+++ b/_prototypes/your-household-lms/summary.html
@@ -0,0 +1,293 @@
+---
+title: Household prototype v4
+project: your-household
+globalcss: false
+layout: eq-default-extras
+cdn: v1.5.0
+---
+
+
+
+
+
+
+
+ {% include navigation.html
+ items=site.data.your-household-v4.navigationItemsHousehold
+ nav-title-id="section-address" %}
+
+
+
+
+
+
+
+
Are you sure you want to remove ?
+
All of the data associated with this person will be
+ deleted
+
+
+ Cancel
+
+
+ Confirm
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/_prototypes/your-household-lms/temp-away-from-home.html b/_prototypes/your-household-lms/temp-away-from-home.html
new file mode 100644
index 0000000000..afe6863fde
--- /dev/null
+++ b/_prototypes/your-household-lms/temp-away-from-home.html
@@ -0,0 +1,101 @@
+---
+title: Household prototype v4
+project: your-household
+globalcss: false
+layout: eq-default-extras
+cdn: v1.5.0
+---
+
+
+
+
+
+
+
+
+
diff --git a/_prototypes/your-household-lms/temp-living-here-feedback.html b/_prototypes/your-household-lms/temp-living-here-feedback.html
new file mode 100644
index 0000000000..f3886199cf
--- /dev/null
+++ b/_prototypes/your-household-lms/temp-living-here-feedback.html
@@ -0,0 +1,97 @@
+---
+title: Household prototype v4
+project: your-household
+globalcss: false
+layout: eq-default-extras
+cdn: v1.5.0
+---
+
+
+
+
+
+
+
+
+
diff --git a/_prototypes/your-household-lms/temp-living-here.html b/_prototypes/your-household-lms/temp-living-here.html
new file mode 100644
index 0000000000..524a276ced
--- /dev/null
+++ b/_prototypes/your-household-lms/temp-living-here.html
@@ -0,0 +1,111 @@
+---
+title: Household prototype v4
+project: your-household
+globalcss: false
+layout: eq-default-extras
+cdn: v1.5.0
+---
+
+
+
+
+
+
+
+
+
diff --git a/_prototypes/your-household-lms/temp-types-feedback.html b/_prototypes/your-household-lms/temp-types-feedback.html
new file mode 100644
index 0000000000..7eb06b933a
--- /dev/null
+++ b/_prototypes/your-household-lms/temp-types-feedback.html
@@ -0,0 +1,115 @@
+---
+title: Household prototype v4
+project: your-household
+globalcss: false
+layout: eq-default-extras
+cdn: v1.5.0
+---
+
+
+
+
+
+
+
+
+
diff --git a/_prototypes/your-household-lms/temp-types-living-away.html b/_prototypes/your-household-lms/temp-types-living-away.html
new file mode 100644
index 0000000000..120df0d5f4
--- /dev/null
+++ b/_prototypes/your-household-lms/temp-types-living-away.html
@@ -0,0 +1,150 @@
+---
+title: Household prototype v4
+project: your-household
+globalcss: false
+layout: eq-default-extras
+cdn: v1.5.0
+---
+
+
+
+
+
+
+
+
+
diff --git a/_prototypes/your-household-lms/temp-types-question.html b/_prototypes/your-household-lms/temp-types-question.html
new file mode 100644
index 0000000000..0f3120e6b6
--- /dev/null
+++ b/_prototypes/your-household-lms/temp-types-question.html
@@ -0,0 +1,134 @@
+---
+title: Household prototype v4
+project: your-household
+globalcss: false
+layout: eq-default-extras
+cdn: v1.5.0
+---
+
+
+
+
+
+
+
+
+
diff --git a/_prototypes/your-household-lms/test-address.html b/_prototypes/your-household-lms/test-address.html
new file mode 100644
index 0000000000..fe469e5223
--- /dev/null
+++ b/_prototypes/your-household-lms/test-address.html
@@ -0,0 +1,227 @@
+---
+title: Household prototype v4
+project: your-household
+globalcss: false
+layout: eq-default-extras
+cdn: v1.5.0
+---
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ What is your address?
+
+
+
+
+ What is your address?
+
+
+
+
+
+
+
+
+
+
+
+ Town or City
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ County (optional)
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Postcode
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Continue
+
+
+
+
+
+
+
+
+
+
diff --git a/_prototypes/your-household-lms/test-data.html b/_prototypes/your-household-lms/test-data.html
new file mode 100644
index 0000000000..76b680dfda
--- /dev/null
+++ b/_prototypes/your-household-lms/test-data.html
@@ -0,0 +1,42 @@
+---
+title: Household prototype v4
+project: your-household
+globalcss: false
+layout: eq-default-extras
+cdn: v1.5.0
+---
+
+
+
+
+
+
+
+
+
diff --git a/_prototypes/your-household-lms/visitors.html b/_prototypes/your-household-lms/visitors.html
new file mode 100644
index 0000000000..e29a77a97d
--- /dev/null
+++ b/_prototypes/your-household-lms/visitors.html
@@ -0,0 +1,148 @@
+---
+title: Household prototype v4
+project: your-household
+globalcss: false
+layout: eq-default-extras
+cdn: v1.5.0
+---
+
+
+
+
+
+
+
+
+
diff --git a/_prototypes/your-household-lms/what-is-your-name.html b/_prototypes/your-household-lms/what-is-your-name.html
new file mode 100644
index 0000000000..674021dbbe
--- /dev/null
+++ b/_prototypes/your-household-lms/what-is-your-name.html
@@ -0,0 +1,118 @@
+---
+title: Household prototype v4
+project: your-household
+globalcss: false
+layout: eq-default-extras
+cdn: v1.5.0
+---
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ What is your name?
+
+
+
+ What is your name?
+
+
+
+
+
+
+
+
+ Save and continue
+
+
+
+
+
+
+
+
+
+
diff --git a/_prototypes/your-household-lms/who-else-to-add.html b/_prototypes/your-household-lms/who-else-to-add.html
new file mode 100644
index 0000000000..3c31b341a4
--- /dev/null
+++ b/_prototypes/your-household-lms/who-else-to-add.html
@@ -0,0 +1,177 @@
+---
+title: Household prototype v4
+project: your-household
+globalcss: false
+layout: eq-default-extras
+cdn: v1.5.0
+---
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Who do you need to add to
+
+
+
+
+
+ What is your name?
+
+
+
+
+
+
+
+
+ Save and continue
+
+
+
+
+
+
+
+
+
+
From bd8e9ab1bc83fc3e826871af91d9d209e55c1665 Mon Sep 17 00:00:00 2001
From: Shane Edwards
Date: Thu, 9 Aug 2018 16:40:56 +0100
Subject: [PATCH 02/11] LMS v2 - Updated pages, routing and content
---
.../your-household-lms/assets/household.js | 3 +-
_prototypes/your-household-lms/bundle.js | 2 +-
.../your-household-lms/do-you-live-here.html | 2 +-
.../does-anyone-else-live-here.html | 2 +-
_prototypes/your-household-lms/hub.html | 2 +-
.../your-household-lms/i-dont-live-here.html | 2 +-
.../individual-decision-other-pin.html | 2 +-
.../individual-decision-other-secure.html | 2 +-
.../individual-decision-pin.html | 2 +-
.../individual-decision-secure.html | 2 +-
.../individual-decision.html | 2 +-
.../individual-details-country.html | 2 +-
.../individual-details-dob.html | 2 +-
.../individual-details-orientation.html | 2 +-
.../individual-details-relationship.html | 2 +-
.../individual-details-salary.html | 2 +-
.../individual-details-summary.html | 2 +-
.../your-household-lms/individual-intro.html | 2 +-
.../individual-pin-security.html | 2 +-
.../lms/do-they-share-cooking-facilities.html | 8 +-
.../lms/do-they-share-dining-living-room.html | 10 +-
.../lms/do-you-live-here.html | 4 +-
.../lms/does-anyone-else-live-here.html | 4 +-
.../lms/does-anyone-live-student-halls.html | 4 +-
.../lms/i-dont-live-here.html | 4 +-
_prototypes/your-household-lms/lms/index.html | 2 +-
...-there-does-anyone-else-student-halls.html | 4 +-
.../lms/what-is-your-name.html | 35 ++++-
.../lms/who-else-to-add.html | 47 +++++--
.../lms/who-owns-rents-accommodation.html | 120 ++++++++++++++++++
.../relationships-person-select.html | 2 +-
.../relationships-summary.html | 2 +-
.../your-household-lms/relationships.html | 2 +-
.../your-household-lms/section-intro.html | 2 +-
_prototypes/your-household-lms/summary.html | 2 +-
.../temp-away-from-home.html | 2 +-
.../temp-living-here-feedback.html | 2 +-
.../your-household-lms/temp-living-here.html | 2 +-
.../temp-types-feedback.html | 2 +-
.../temp-types-living-away.html | 2 +-
.../temp-types-question.html | 2 +-
_prototypes/your-household-lms/test-data.html | 2 +-
_prototypes/your-household-lms/visitors.html | 2 +-
.../your-household-lms/what-is-your-name.html | 2 +-
.../your-household-lms/who-else-to-add.html | 2 +-
45 files changed, 241 insertions(+), 70 deletions(-)
create mode 100644 _prototypes/your-household-lms/lms/who-owns-rents-accommodation.html
diff --git a/_prototypes/your-household-lms/assets/household.js b/_prototypes/your-household-lms/assets/household.js
index 01e78e53c7..9e8a5935b8 100644
--- a/_prototypes/your-household-lms/assets/household.js
+++ b/_prototypes/your-household-lms/assets/household.js
@@ -22,7 +22,8 @@ export function person(opts) {
fullName: opts.firstName + ' ' + middleName + ' ' + opts.lastName,
firstName: opts.firstName,
middleName,
- lastName: opts.lastName
+ lastName: opts.lastName,
+ gender: opts.gender
};
}
diff --git a/_prototypes/your-household-lms/bundle.js b/_prototypes/your-household-lms/bundle.js
index e6723392ee..00d6bb3ca8 100644
--- a/_prototypes/your-household-lms/bundle.js
+++ b/_prototypes/your-household-lms/bundle.js
@@ -272,7 +272,7 @@ function getAnsweringIndividualByProxy() {
const surveyTypeConfig = {
lms: {
- title: 'Online Household Study',
+ title: 'Online Household Study v2',
householdSectionTitle: 'About your household',
householdSectionLink: '../summary/?survey=lms',
relationshipsSection: '../relationships/?survey=lms'
diff --git a/_prototypes/your-household-lms/do-you-live-here.html b/_prototypes/your-household-lms/do-you-live-here.html
index 4d60f6fdca..4b74988c2f 100644
--- a/_prototypes/your-household-lms/do-you-live-here.html
+++ b/_prototypes/your-household-lms/do-you-live-here.html
@@ -84,7 +84,7 @@
-
+
+
+
-
+
+
+
+
+
+
+
+
+
+
+
-
+
+
+
+
+
diff --git a/_prototypes/your-household-lms/lms/do-you-live-here.html b/_prototypes/your-household-lms/lms/do-you-live-here.html
index 351b0c1188..fe3aaf1615 100644
--- a/_prototypes/your-household-lms/lms/do-you-live-here.html
+++ b/_prototypes/your-household-lms/lms/do-you-live-here.html
@@ -1,5 +1,5 @@
---
-title: Online Household Study
+title: Online Household Study v2
project: your-household
globalcss: false
layout: eq-default-extras
@@ -83,7 +83,7 @@
-
+
+
-
+
-
+
+
+
diff --git a/_prototypes/your-household-lms/lms/who-else-to-add.html b/_prototypes/your-household-lms/lms/who-else-to-add.html
index 7ed597b40f..b31bedf4cf 100644
--- a/_prototypes/your-household-lms/lms/who-else-to-add.html
+++ b/_prototypes/your-household-lms/lms/who-else-to-add.html
@@ -1,5 +1,5 @@
---
-title: Online Household Study
+title: Online Household Study v2
project: your-household
globalcss: false
layout: eq-default-extras
@@ -35,7 +35,8 @@
- Who do you need to add to
@@ -47,6 +48,8 @@
period of up to 6 months
+
+
- First name
+ First or given name
- Last name
+ Surname or family name
+
+
@@ -92,14 +115,16 @@
-
+
diff --git a/_prototypes/your-household-lms/lms/who-owns-rents-accommodation.html b/_prototypes/your-household-lms/lms/who-owns-rents-accommodation.html
new file mode 100644
index 0000000000..5897135a3a
--- /dev/null
+++ b/_prototypes/your-household-lms/lms/who-owns-rents-accommodation.html
@@ -0,0 +1,120 @@
+---
+title: Online Household Study v2
+project: your-household
+globalcss: false
+layout: eq-default-extras
+cdn: v1.5.0
+---
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/_prototypes/your-household-lms/relationships-person-select.html b/_prototypes/your-household-lms/relationships-person-select.html
index 4ab57e47ac..114bd6eb82 100644
--- a/_prototypes/your-household-lms/relationships-person-select.html
+++ b/_prototypes/your-household-lms/relationships-person-select.html
@@ -89,7 +89,7 @@
-
+
+
-
+
+
+