You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
36 lines
942 B
36 lines
942 B
// Run on the command line to test colors. |
|
// node userColorsTest.js > colorTest.html |
|
|
|
console.log(`<body style="background: #2d3748">`); |
|
|
|
for (var i = 0; i < 20; i++) { |
|
const element = generateElement(randomString(6)); |
|
console.log(element); |
|
} |
|
|
|
console.log(`</body>`); |
|
|
|
function generateElement(string) { |
|
const color = messageBubbleColorForString(string); |
|
return `<div style="color: ${color}">${string}</div>` |
|
} |
|
|
|
function randomString(length) { |
|
return Math.random().toString(36).substring(length); |
|
} |
|
|
|
function messageBubbleColorForString(str) { |
|
let hash = 0; |
|
for (let i = 0; i < str.length; i++) { |
|
// eslint-disable-next-line |
|
hash = str.charCodeAt(i) + ((hash << 5) - hash); |
|
} |
|
|
|
// Tweak these to adjust the result of the color |
|
const saturation = 75; |
|
const lightness = 65; |
|
const alpha = 1.0; |
|
const hue = parseInt(Math.abs(hash), 16) % 360; |
|
|
|
return `hsla(${hue}, ${saturation}%, ${lightness}%, ${alpha})`; |
|
}
|
|
|