// Run on the command line to test colors.
// node userColorsTest.js > colorTest.html
console.log(`
`);
for (var i = 0; i < 20; i++) {
const element = generateElement(randomString(6));
console.log(element);
}
console.log(``);
function generateElement(string) {
const color = messageBubbleColorForString(string);
return `${string}
`
}
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})`;
}