87 lines
2.1 KiB
Vue
87 lines
2.1 KiB
Vue
<template>
|
|
<span
|
|
v-if="contrast"
|
|
class="contrast-ratio"
|
|
>
|
|
<span
|
|
:title="hint"
|
|
class="rating"
|
|
>
|
|
<span v-if="contrast.aaa">
|
|
<i class="icon-thumbs-up-alt" />
|
|
</span>
|
|
<span v-if="!contrast.aaa && contrast.aa">
|
|
<i class="icon-adjust" />
|
|
</span>
|
|
<span v-if="!contrast.aaa && !contrast.aa">
|
|
<i class="icon-attention" />
|
|
</span>
|
|
</span>
|
|
<span
|
|
v-if="contrast && large"
|
|
class="rating"
|
|
:title="hint_18pt"
|
|
>
|
|
<span v-if="contrast.laaa">
|
|
<i class="icon-thumbs-up-alt" />
|
|
</span>
|
|
<span v-if="!contrast.laaa && contrast.laa">
|
|
<i class="icon-adjust" />
|
|
</span>
|
|
<span v-if="!contrast.laaa && !contrast.laa">
|
|
<i class="icon-attention" />
|
|
</span>
|
|
</span>
|
|
</span>
|
|
</template>
|
|
|
|
<script>
|
|
export default {
|
|
props: {
|
|
large: {
|
|
required: false
|
|
},
|
|
// TODO: Make theme switcher compute theme initially so that contrast
|
|
// component won't be called without contrast data
|
|
contrast: {
|
|
required: false,
|
|
type: Object
|
|
}
|
|
},
|
|
computed: {
|
|
hint () {
|
|
const levelVal = this.contrast.aaa ? 'aaa' : (this.contrast.aa ? 'aa' : 'bad')
|
|
const level = this.$t(`settings.style.common.contrast.level.${levelVal}`)
|
|
const context = this.$t('settings.style.common.contrast.context.text')
|
|
const ratio = this.contrast.text
|
|
return this.$t('settings.style.common.contrast.hint', { level, context, ratio })
|
|
},
|
|
hint_18pt () {
|
|
const levelVal = this.contrast.laaa ? 'aaa' : (this.contrast.laa ? 'aa' : 'bad')
|
|
const level = this.$t(`settings.style.common.contrast.level.${levelVal}`)
|
|
const context = this.$t('settings.style.common.contrast.context.18pt')
|
|
const ratio = this.contrast.text
|
|
return this.$t('settings.style.common.contrast.hint', { level, context, ratio })
|
|
}
|
|
}
|
|
}
|
|
</script>
|
|
|
|
<style lang="scss">
|
|
.contrast-ratio {
|
|
display: flex;
|
|
justify-content: flex-end;
|
|
|
|
margin-top: -4px;
|
|
margin-bottom: 5px;
|
|
|
|
.label {
|
|
margin-right: 1em;
|
|
}
|
|
|
|
.rating {
|
|
display: inline-block;
|
|
text-align: center;
|
|
}
|
|
}
|
|
</style>
|