@namelessmedia/tisc_nuxt
Version:
TISC NUXT Component Library
114 lines (96 loc) • 5.59 kB
JavaScript
const generateRootCss = require('./lib/index')
const hexConvert = (num) => {
if (num > 255) num = 255;
else if (num < 0) num = '00';
if (num > 16)
return num.toString(16)
else if (num != '00') {
return `0${num.toString(16)}`
} else {
return '00'
}
}
const colourNameToHex = (colour) => {
let colours = {"aliceblue":"#f0f8ff","antiquewhite":"#faebd7","aqua":"#00ffff","aquamarine":"#7fffd4","azure":"#f0ffff",
"beige":"#f5f5dc","bisque":"#ffe4c4","black":"#000000","blanchedalmond":"#ffebcd","blue":"#0000ff","blueviolet":"#8a2be2","brown":"#a52a2a","burlywood":"#deb887",
"cadetblue":"#5f9ea0","chartreuse":"#7fff00","chocolate":"#d2691e","coral":"#ff7f50","cornflowerblue":"#6495ed","cornsilk":"#fff8dc","crimson":"#dc143c","cyan":"#00ffff",
"darkblue":"#00008b","darkcyan":"#008b8b","darkgoldenrod":"#b8860b","darkgray":"#a9a9a9","darkgreen":"#006400","darkkhaki":"#bdb76b","darkmagenta":"#8b008b","darkolivegreen":"#556b2f",
"darkorange":"#ff8c00","darkorchid":"#9932cc","darkred":"#8b0000","darksalmon":"#e9967a","darkseagreen":"#8fbc8f","darkslateblue":"#483d8b","darkslategray":"#2f4f4f","darkturquoise":"#00ced1",
"darkviolet":"#9400d3","deeppink":"#ff1493","deepskyblue":"#00bfff","dimgray":"#696969","dodgerblue":"#1e90ff",
"firebrick":"#b22222","floralwhite":"#fffaf0","forestgreen":"#228b22","fuchsia":"#ff00ff",
"gainsboro":"#dcdcdc","ghostwhite":"#f8f8ff","gold":"#ffd700","goldenrod":"#daa520","gray":"#808080","green":"#008000","greenyellow":"#adff2f",
"honeydew":"#f0fff0","hotpink":"#ff69b4",
"indianred ":"#cd5c5c","indigo":"#4b0082","ivory":"#fffff0","khaki":"#f0e68c",
"lavender":"#e6e6fa","lavenderblush":"#fff0f5","lawngreen":"#7cfc00","lemonchiffon":"#fffacd","lightblue":"#add8e6","lightcoral":"#f08080","lightcyan":"#e0ffff","lightgoldenrodyellow":"#fafad2",
"lightgrey":"#d3d3d3","lightgreen":"#90ee90","lightpink":"#ffb6c1","lightsalmon":"#ffa07a","lightseagreen":"#20b2aa","lightskyblue":"#87cefa","lightslategray":"#778899","lightsteelblue":"#b0c4de",
"lightyellow":"#ffffe0","lime":"#00ff00","limegreen":"#32cd32","linen":"#faf0e6",
"magenta":"#ff00ff","maroon":"#800000","mediumaquamarine":"#66cdaa","mediumblue":"#0000cd","mediumorchid":"#ba55d3","mediumpurple":"#9370d8","mediumseagreen":"#3cb371","mediumslateblue":"#7b68ee",
"mediumspringgreen":"#00fa9a","mediumturquoise":"#48d1cc","mediumvioletred":"#c71585","midnightblue":"#191970","mintcream":"#f5fffa","mistyrose":"#ffe4e1","moccasin":"#ffe4b5",
"navajowhite":"#ffdead","navy":"#000080",
"oldlace":"#fdf5e6","olive":"#808000","olivedrab":"#6b8e23","orange":"#ffa500","orangered":"#ff4500","orchid":"#da70d6",
"palegoldenrod":"#eee8aa","palegreen":"#98fb98","paleturquoise":"#afeeee","palevioletred":"#d87093","papayawhip":"#ffefd5","peachpuff":"#ffdab9","peru":"#cd853f","pink":"#ffc0cb","plum":"#dda0dd","powderblue":"#b0e0e6","purple":"#800080",
"rebeccapurple":"#663399","red":"#ff0000","rosybrown":"#bc8f8f","royalblue":"#4169e1",
"saddlebrown":"#8b4513","salmon":"#fa8072","sandybrown":"#f4a460","seagreen":"#2e8b57","seashell":"#fff5ee","sienna":"#a0522d","silver":"#c0c0c0","skyblue":"#87ceeb","slateblue":"#6a5acd","slategray":"#708090","snow":"#fffafa","springgreen":"#00ff7f","steelblue":"#4682b4",
"tan":"#d2b48c","teal":"#008080","thistle":"#d8bfd8","tomato":"#ff6347","turquoise":"#40e0d0",
"violet":"#ee82ee",
"wheat":"#f5deb3","white":"#ffffff","whitesmoke":"#f5f5f5",
"yellow":"#ffff00","yellowgreen":"#9acd32"};
if (typeof colours[colour.toLowerCase()] != 'undefined')
return colours[colour.toLowerCase()];
return false;
}
const LightenDarkenColor = (col, amt) => {
var usePound = false;
if (col[0] == "#") {
col = col.slice(1);
usePound = true;
}
if(colourNameToHex(col)) {
col = colourNameToHex(col)
col = col.slice(1);
usePound = true;
}
var num = parseInt(col, 16);
var r = (num >> 16) + amt;
var b = ((num >> 8) & 0x00FF) + amt;
var g = (num & 0x0000FF) + amt;
g = hexConvert(g)
r = hexConvert(r)
b = hexConvert(b)
return ("#") + `${r}${b}${g}`;
}
const theme = (theme) => {``
const results = {
vars: {},
main: {},
light: {},
dark: {}
}
if (theme.main) {
Object.entries(theme.main).forEach((values) => {
if (values[0] == 'primary') {
results.vars[`$primary`] = values[1]
results.vars[`$primary-light`] = LightenDarkenColor(values[1], 50);
results.vars[`$primary-dark`] = LightenDarkenColor(values[1], -70);
results.main[`--tisc-${values[0]}`] = values[1]
results.main[`--tisc-${values[0]}-light`] = LightenDarkenColor(values[1], 50);
results.main[`--tisc-${values[0]}-dark`] = LightenDarkenColor(values[1], -70);
}
})
results.light[`--tisc-overlay`] = LightenDarkenColor(theme.main.primary, -70)
results.dark[`--tisc-overlay`] = LightenDarkenColor(theme.main.primary, 40)
results.light[`--tisc-text-third`] = theme.main.primary
results.dark[`--tisc-text-third`] = LightenDarkenColor(theme.main.primary, 20)
Object.entries(theme.light).forEach((values) => {
results.light[`--tisc-${values[0]}`] = values[1]
})
Object.entries(theme.dark).forEach((values) => {
results.dark[`--tisc-${values[0]}`] = values[1]
})
}
return results
}
module.exports = (colors, output) => {
let variables = theme(colors)
generateRootCss(variables, output)
}