28 lines
1.0 KiB
JavaScript
28 lines
1.0 KiB
JavaScript
|
import findContrastedTextColour from './findContrastedTextColour'
|
||
|
|
||
|
export default forcedThemeColour => {
|
||
|
let
|
||
|
scriptColour = () => {
|
||
|
let script = document.currentScript || [ ...document.getElementsByTagName('script') ].pop()
|
||
|
return script && script.getAttribute('couleur')
|
||
|
},
|
||
|
// Use the default theme colour if the host page hasn't made a choice
|
||
|
defaultColour = '#4A89DC',
|
||
|
colour = forcedThemeColour || scriptColour() || defaultColour,
|
||
|
textColour = findContrastedTextColour(colour, true), // the 'simple' version feels better...
|
||
|
inverseTextColour = textColour === '#ffffff' ? '#000' : '#fff',
|
||
|
lightenTextColour = textColour => textColour === '#ffffff' ? 'rgba(255, 255, 255, .85)' : '#333',
|
||
|
lighterTextColour = lightenTextColour(textColour),
|
||
|
lighterInverseTextColour = lightenTextColour(inverseTextColour),
|
||
|
textColourOnWhite = textColour === '#ffffff' ? colour : '#333'
|
||
|
|
||
|
return {
|
||
|
colour,
|
||
|
textColour,
|
||
|
inverseTextColour,
|
||
|
lighterTextColour,
|
||
|
lighterInverseTextColour,
|
||
|
textColourOnWhite
|
||
|
}
|
||
|
}
|