Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Feature/53585 Migrate cookie message #187

Open
wants to merge 30 commits into
base: develop
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
30 commits
Select commit Hold shift + click to select a range
f768d2a
#53585 - Move component to the molecules
May 20, 2019
e72ddc6
#53585 - Add 'a' prefix in class
May 20, 2019
99e9126
#53585 - Add 'a' prefix in class
May 20, 2019
936d231
#53585 - Add slots
May 20, 2019
088e701
#53585 - Add description for slots and props
May 20, 2019
9c29255
#53585 - Add test for cookie message
May 20, 2019
8931516
#53585 - Change text color to increase contrast for a11y
May 20, 2019
eef1c1d
#53585 - Use color variable
May 20, 2019
a89787d
Merge branch 'develop' into feature/53585
Aekal May 21, 2019
05cb64e
Merge branch 'develop' into feature/53585
Aekal May 21, 2019
38314bb
#53585 - Move arialabels to story
May 21, 2019
5aef2df
#53585 - Remove closeIcon props
May 21, 2019
e7106f9
#53585 - Move dataType to data
May 21, 2019
011dae8
#53585 - Add knobs for custom button
May 21, 2019
3dd67c7
#53585 - Add knobs for default button
May 21, 2019
a3873df
#53585 - Remove unnecessary brackets
May 21, 2019
c0acf88
#53585 - Add knobs,default value for storageName
May 22, 2019
a95531c
#53585 - Fix styles
May 22, 2019
ad12cfb
Merge branch 'develop' into feature/53585
May 28, 2019
b2a0f6a
#53585 - Revert style changes
May 28, 2019
219c752
#53585 - Move transitions
May 28, 2019
0b70126
Merge branch 'develop' into feature/53585
May 30, 2019
8a4c4a8
Merge branch 'develop' into feature/53585
May 31, 2019
d0e26d3
#53585 - Fix line-height
May 31, 2019
af79012
#53585 - Remove connect with localStorage
Jun 4, 2019
a86980e
#53585 - Change this.$root.$el on this.$el
Jun 4, 2019
8faab0b
#53585 - Fix styles
Jun 4, 2019
3dc1b08
Merge branch 'develop' into feature/53585
Jun 4, 2019
a995b3b
#53585 - Remove unnecessary test, after changes in component
Jun 4, 2019
a763b31
Merge remote-tracking branch 'origin/feature/53585' into feature/53585
Jun 4, 2019
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
24 changes: 0 additions & 24 deletions components/src/02-elements/cookie-message/CookieMessage.html

This file was deleted.

17 changes: 0 additions & 17 deletions components/src/02-elements/cookie-message/CookieMessage.stories.js

This file was deleted.

2 changes: 1 addition & 1 deletion components/src/03-modules/footer/Footer.js
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ import ALink from '../../atoms/link/Link.vue'
import AButton from '../../atoms/button/Button.vue'
import AList from '../../atoms/list/List.vue'
import AListItem from '../../atoms/list-item/ListItem.vue'
import ACookieMessage from '../../02-elements/cookie-message/CookieMessage.vue'
import ACookieMessage from '../../molecules/cookie-message/CookieMessage.vue'
import ADropdownList from '../../molecules/collapse/Collapse.vue'
import ANewsletter from '../../03-modules/newsletter/Newsletter.vue'

Expand Down
29 changes: 29 additions & 0 deletions components/src/molecules/cookie-message/CookieMessage.html
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
<div
class="a-cookie-message"
:aria-label="ariaLabel"
tabindex="0"
>
<div class="a-cookie-message__container">
<div class="a-cookie-message__text">
<!-- @slot Content slot -->
<slot />
</div>
<!-- @slot Close button (Scoped slot) -->
<slot
name="button"
:close-bar="closeBar"
>
<a-button
:aria-label="closeAriaLabel"
class="a-cookie-message__close"
@click.native="closeBar"
>
{{ closeButton }}
<a-icon
icon="close"
class="a-cookie-message__close-icon"
/>
</a-button>
</slot>
</div>
</div>
Original file line number Diff line number Diff line change
Expand Up @@ -8,52 +8,43 @@ export default {
AButton
},
props: {
text: {
type: String,
required: true
},
dataType: {
type: String,
required: true
},
closeIcon: {
type: String,
default: null
},
/**
* Text for close button
*/
closeButton: {
type: String,
default: null
},
/**
* Aria label for container
*/
ariaLabel: {
type: String,
default: 'Cookie policy message'
default: null
},
/**
* Aria label for close button
*/
closeAriaLabel: {
type: String,
default: 'Close cookie message'
}
},
data: () => {
return {
isOpen: false
}
},
mounted () {
if (localStorage.getItem(this.dataType) !== 'closed') {
this.isOpen = true
default: null
}
},
methods: {
closeBar () {
const focusable = document.querySelectorAll('button:not([disabled]), a[href], area[href] input:not([disabled]), select:not([disabled]), textarea:not([disabled]), *[tabindex]:not([tabindex="-1"]), object, embed, *[contenteditable]')
const focusable = this.$el.querySelectorAll('button:not([disabled]), a[href], area[href] input:not([disabled]), select:not([disabled]), textarea:not([disabled]), *[tabindex]:not([tabindex="-1"]), object, embed, *[contenteditable]')

this.isOpen = false
localStorage.setItem(this.dataType, 'closed')
// after closing message box move focus on first focusable element on the page
if (focusable.length) {
let firstFocusable = [...focusable].find(el => el.offsetParent !== null)
firstFocusable.focus()
}

/**
* Triggered close button
* @type {Event}
*/
this.$emit('close')
}
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -4,23 +4,27 @@ $cookie-message__width : 100% !default;
$cookie-message__background-color : $gray-lightest !default;
$cookie-message__font-size : $font-size-small !default;
$cookie-message__font-family : $font-family-base !default;
$cookie-message__text-color : $gray !default;
$cookie-message__container-min-width : 100% !default;
$cookie-message__text-color : $gray-dark !default;
$cookie-message__text-padding : $spacer--medium $spacer--medium 0 $spacer--medium !default;
$cookie-message__text-padding--small : $spacer--medium $spacer $spacer--medium $spacer--medium !default;
$cookie-message__text-line-height : 1.5 !default;
$cookie-message__text-line-height : 1.5 !default;
$cookie-message__link-color : $blue !default;
$cookie-message__close-color : $cookie-message__text-color !default;
$cookie-message__close-size : 48px !default;
$cookie-message__close-color : $cookie-message__text-color !default;
$cookie-message__close-background : none !default;
$cookie-message__close-border : none !default;
$cookie-message__close-font-weight : $font-weight-bold !default;
$cookie-message__close-padding : 0 $spacer--medium 0 0 !default;
$cookie-message__close-padding--small : 0 $spacer--medium 0 $spacer !default;
$cookie-message__text-padding--small : $spacer--medium $spacer $spacer--medium $spacer--medium !default;
$cookie-message__close-icon-size : 14px !default;
$cookie-message__close-icon-margin-left: $spacer !default;
$cookie-message__close-icon-fill : $color-primary !default;
$cookie-message__close-icon-transition : $transition-base !default;


.cookie-message {
display: none;
.a-cookie-message {
align-items: stretch;
box-sizing: border-box;
width: $cookie-message__width;
Expand All @@ -33,8 +37,7 @@ $cookie-message__close-icon-transition : $transition-base !default;
flex-wrap: wrap;
align-items: center;
justify-content: flex-end;
min-width: 100%;
text-align: center;
min-width: $cookie-message__container-min-width;

@include mq($screen-s) {
flex-wrap: nowrap;
Expand All @@ -46,19 +49,18 @@ $cookie-message__close-icon-transition : $transition-base !default;
flex-basis: 100%;
padding: $cookie-message__text-padding;
color: $cookie-message__text-color;
font-size: inherit;
font-family: inherit;
line-height: $cookie-message__text-line-height;
text-align: justify;

@include mq($screen-s) {
flex-basis: auto;
padding: $cookie-message__text-padding--small;
text-align: left;
}
}

&__link {
color: $cookie-message__link-color;
& > a {
color: $cookie-message__link-color;
}
}

&__close {
Expand All @@ -71,16 +73,19 @@ $cookie-message__close-icon-transition : $transition-base !default;
padding: $cookie-message__close-padding;
color: $cookie-message__close-color;
font-weight: $cookie-message__close-font-weight;
font-size: inherit;
font-family: inherit;
background: none;
border: none;
background: $cookie-message__close-background;
border: $cookie-message__close-border;
cursor: pointer;

&:active,
&:hover {
&:hover,
&:focus {
color: $cookie-message__close-color;
background: none;
background: $cookie-message__close-background;

.a-cookie-message__close-icon {
fill: $cookie-message__close-icon-fill;
}
}

@include mq($screen-s) {
Expand All @@ -92,20 +97,12 @@ $cookie-message__close-icon-transition : $transition-base !default;
width: $cookie-message__close-icon-size;
height: $cookie-message__close-icon-size;
margin-left: $cookie-message__close-icon-margin-left;
transition: $cookie-message__close-icon-transition;
fill: $cookie-message__close-color;

&:hover,
&:focus {
transition: $cookie-message__close-icon-transition;
fill: $color-primary;
fill: $cookie-message__close-icon-fill;
}
}

&--open {
display: flex;
}
}

.cookie-message__text > a {
@extend .cookie-message__link;
}
24 changes: 24 additions & 0 deletions components/src/molecules/cookie-message/CookieMessage.spec.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
import { mount } from '@vue/test-utils'
import ACookieMessage from './CookieMessage.vue'

describe('Cookie message', () => {
it('has default structure', () => {
const wrapper = mount(ACookieMessage)
expect(wrapper.is('div')).toBe(true)
expect(wrapper.classes()).toContain('a-cookie-message')
})

it('renders slots content when passed', () => {
const wrapper = mount(ACookieMessage, {
slots: {
default: `<span>Sample content</span>`,
button: `<button>Sample button</button>`
}
})

const span = wrapper.find('.a-cookie-message span')
expect(span.exists()).toBe(true)
expect(span.text()).toEqual('Sample content')
expect(wrapper.find('button').text()).toBe('Sample button')
})
})
68 changes: 68 additions & 0 deletions components/src/molecules/cookie-message/CookieMessage.stories.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,68 @@
import { storiesOf } from '@storybook/vue'
import { text } from '@storybook/addon-knobs'

import ALink from '../../atoms/link/Link.vue'
import ACookieMessage from './CookieMessage.vue'

const data = {
props: {
textKnobs: {
default: text('Button text', 'Button text')
},
linkText: {
default: text('Link text', 'Example link')
},
infoText: {
default: text('Info text', 'Find out more about their purpose and settings in your browser. By browsing the site you are agreeing to use cookies according to your browser settings.')
}
},
data: () => ({
isOpen: true
}),
methods: {
close () {
this.isOpen = false
}
}
}
storiesOf('Molecules/CookieMessage', module)
.addParameters({ info: true })
.add('Default', () => ({
components: { ACookieMessage, ALink },
...data,
template: `
<a-cookie-message
v-if="isOpen"
:close-button="textKnobs"
aria-label="Cookie policy message"
close-aria-label="Close cookie message"
@close="close"
>
<a-link href='#'>
{{ linkText }}
</a-link>
{{ infoText }}
</a-cookie-message>
`
}))
.add('With slots', () => ({
components: { ACookieMessage, ALink },
...data,
template: `
<a-cookie-message
v-if="isOpen"
aria-label="Cookie policy message"
close-aria-label="Close cookie message"
>
<a-link href='#'>
{{ linkText }}
</a-link>
{{ infoText }}
<template #button="{ closeBar }">
<button @click="() => { closeBar(); close(); }">
{{ textKnobs }}
</button>
</template>
</a-cookie-message>
`
}))
2 changes: 2 additions & 0 deletions cookbook/src/app/App.vue
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
<template src="./App.html" />

<script src="./App.js" />

<style lang="scss" src="./App.scss" />