
Material Color Helper
Description
This is a simple material color helper css generator that can be used to generate css for material colors.
visit material.io for color palette.
Usage
<div class="red-50">background red and foreground will be contrast color</div>
<div class="red-50-bg">only background red</div>
<div class="red-50-fg">only foreground red</div>
All Shades are supported
- 50
- 100
- 200
- 300
- 400
- 500
- 600
- 700
- 800
- 900
- A100
- A200
- A400
- A700
All Colors are supported
- red
- pink
- purple
- deep-purple
- indigo
- blue
- light-blue
- cyan
- teal
- green
- light-green
- lime
- yellow
- amber
- orange
- deep-orange
- brown
- grey
- blue-grey
- nk-dark
Code For Generating CSS stylesheet
// helper-stylesheet.service.ts
import { MaterialColors, shades } from './mat-colors';
const generate = () => {
return Object.entries(MaterialColors)
.map(([key, value]) => {
return shades
.map(
(shade, shadeIx) =>
`.${key}-${shade}-bg {background-color: ${value[0][shadeIx]}!important;}` +
`.${key}-${shade}-fg {color: ${value[0][shadeIx]}!important;}` +
`.${key}-${shade} {color: ${value[1][shadeIx]}!important;background-color: ${value[0][shadeIx]}!important}`
)
.join('');
})
.join('');
};
const injectStyleSheetInHead = (css: string, desc = 'helpers') => {
const head = document.head || document.getElementsByTagName('head')[0];
const style = document.createElement('style');
style.setAttribute('desc', desc);
head.appendChild(style);
if ((style as any).styleSheet) {
// This is required for IE8 and below.
(style as any).styleSheet.cssText = css;
} else {
style.appendChild(document.createTextNode(css));
}
};
export const LoadHelperStyleSheet = () => {
injectStyleSheetInHead(generate(), 'color-helpers');
};
call LoadHelperStyleSheet() to load the helper stylesheet in app component’s constructor.
Material Colors
// mat-colors.ts
const black87 = 'rgba(0, 0, 0, 0.87)';
const white87 = 'rgba(255, 255, 255, 0.87)';
export const shades = ['50', '100', '200', '300', '400', '500', '600', '700', '800', '900', 'A100', 'A200', 'A400', 'A700'];
export const MaterialColors = {
red: [
['#ffebee', '#ffcdd2', '#ef9a9a', '#e57373', '#ef5350', '#f44336', '#e53935', '#d32f2f', '#c62828', '#b71c1c', '#ff8a80', '#ff5252', '#ff1744', '#d50000'],
[black87, black87, black87, black87, black87, 'white', 'white', 'white', white87, white87, black87, 'white', 'white', 'white'],
],
pink: [
['#fce4ec', '#f8bbd0', '#f48fb1', '#f06292', '#ec407a', '#e91e63', '#d81b60', '#c2185b', '#ad1457', '#880e4f', '#ff80ab', '#ff4081', '#f50057', '#c51162'],
[black87, black87, black87, black87, black87, 'white', 'white', white87, white87, white87, black87, 'white', 'white', 'white'],
],
purple: [
['#f3e5f5', '#e1bee7', '#ce93d8', '#ba68c8', '#ab47bc', '#9c27b0', '#8e24aa', '#7b1fa2', '#6a1b9a', '#4a148c', '#ea80fc', '#e040fb', '#d500f9', '#aa00ff'],
[black87, black87, black87, 'white', 'white', white87, white87, white87, white87, white87, black87, 'white', 'white', 'white'],
],
'deep-purple': [
['#ede7f6', '#d1c4e9', '#b39ddb', '#9575cd', '#7e57c2', '#673ab7', '#5e35b1', '#512da8', '#4527a0', '#311b92', '#b388ff', '#7c4dff', '#651fff', '#6200ea'],
[black87, black87, black87, 'white', 'white', white87, white87, white87, white87, white87, black87, 'white', white87, white87],
],
indigo: [
['#e8eaf6', '#c5cae9', '#9fa8da', '#7986cb', '#5c6bc0', '#3f51b5', '#3949ab', '#303f9f', '#283593', '#1a237e', '#8c9eff', '#536dfe', '#3d5afe', '#304ffe'],
[black87, black87, black87, 'white', 'white', white87, white87, white87, white87, white87, black87, 'white', 'white', white87],
],
blue: [
['#e3f2fd', '#bbdefb', '#90caf9', '#64b5f6', '#42a5f5', '#2196f3', '#1e88e5', '#1976d2', '#1565c0', '#0d47a1', '#82b1ff', '#448aff', '#2979ff', '#2962ff'],
[black87, black87, black87, black87, black87, 'white', 'white', 'white', white87, white87, black87, 'white', 'white', 'white'],
],
'light-blue': [
['#e1f5fe', '#b3e5fc', '#81d4fa', '#4fc3f7', '#29b6f6', '#03a9f4', '#039be5', '#0288d1', '#0277bd', '#01579b', '#80d8ff', '#40c4ff', '#00b0ff', '#0091ea'],
[black87, black87, black87, black87, black87, 'white', 'white', 'white', 'white', white87, black87, black87, black87, 'white'],
],
cyan: [
['#e0f7fa', '#b2ebf2', '#80deea', '#4dd0e1', '#26c6da', '#00bcd4', '#00acc1', '#0097a7', '#00838f', '#006064', '#84ffff', '#18ffff', '#00e5ff', '#00b8d4'],
[black87, black87, black87, black87, black87, 'white', 'white', 'white', 'white', white87, black87, black87, black87, black87],
],
teal: [
['#e0f2f1', '#b2dfdb', '#80cbc4', '#4db6ac', '#26a69a', '#009688', '#00897b', '#00796b', '#00695c', '#004d40', '#a7ffeb', '#64ffda', '#1de9b6', '#00bfa5'],
[black87, black87, black87, black87, black87, 'white', 'white', 'white', white87, white87, black87, black87, black87, black87],
],
green: [
['#e8f5e9', '#c8e6c9', '#a5d6a7', '#81c784', '#66bb6a', '#4caf50', '#43a047', '#388e3c', '#2e7d32', '#1b5e20', '#b9f6ca', '#69f0ae', '#00e676', '#00c853'],
[black87, black87, black87, black87, black87, 'white', 'white', 'white', white87, white87, black87, black87, black87, black87],
],
'light-green': [
['#f1f8e9', '#dcedc8', '#c5e1a5', '#aed581', '#9ccc65', '#8bc34a', '#7cb342', '#689f38', '#558b2f', '#33691e', '#ccff90', '#b2ff59', '#76ff03', '#64dd17'],
[black87, black87, black87, black87, black87, black87, black87, black87, 'white', 'white', black87, black87, black87, black87],
],
lime: [
['#f9fbe7', '#f0f4c3', '#e6ee9c', '#dce775', '#d4e157', '#cddc39', '#c0ca33', '#afb42b', '#9e9d24', '#827717', '#f4ff81', '#eeff41', '#c6ff00', '#aeea00'],
[black87, black87, black87, black87, black87, black87, black87, black87, black87, 'white', black87, black87, black87, black87],
],
yellow: [
['#fffde7', '#fff9c4', '#fff59d', '#fff176', '#ffee58', '#ffeb3b', '#fdd835', '#fbc02d', '#f9a825', '#f57f17', '#ffff8d', '#ffff00', '#ffea00', '#ffd600'],
[black87, black87, black87, black87, black87, black87, black87, black87, black87, black87, black87, black87, black87, black87],
],
amber: [
['#fff8e1', '#ffecb3', '#ffe082', '#ffd54f', '#ffca28', '#ffc107', '#ffb300', '#ffa000', '#ff8f00', '#ff6f00', '#ffe57f', '#ffd740', '#ffc400', '#ffab00'],
[black87, black87, black87, black87, black87, black87, black87, black87, black87, black87, black87, black87, black87, black87],
],
orange: [
['#fff3e0', '#ffe0b2', '#ffcc80', '#ffb74d', '#ffa726', '#ff9800', '#fb8c00', '#f57c00', '#ef6c00', '#e65100', '#ffd180', '#ffab40', '#ff9100', '#ff6d00'],
[black87, black87, black87, black87, black87, black87, black87, black87, 'white', 'white', black87, black87, black87, 'black'],
],
'deep-orange': [
['#fbe9e7', '#ffccbc', '#ffab91', '#ff8a65', '#ff7043', '#ff5722', '#f4511e', '#e64a19', '#d84315', '#bf360c', '#ff9e80', '#ff6e40', '#ff3d00', '#dd2c00'],
[black87, black87, black87, black87, black87, 'white', 'white', 'white', 'white', 'white', black87, black87, 'white', 'white'],
],
brown: [
['#efebe9', '#d7ccc8', '#bcaaa4', '#a1887f', '#8d6e63', '#795548', '#6d4c41', '#5d4037', '#4e342e', '#3e2723', '#d7ccc8', '#bcaaa4', '#8d6e63', '#5d4037'],
[black87, black87, black87, 'white', 'white', white87, white87, white87, white87, white87, black87, black87, 'white', white87],
],
grey: [
['#fafafa', '#f5f5f5', '#eeeeee', '#e0e0e0', '#bdbdbd', '#9e9e9e', '#757575', '#616161', '#424242', '#212121', '#ffffff', '#eeeeee', '#bdbdbd', '#616161'],
[black87, black87, black87, black87, black87, black87, white87, white87, white87, white87, black87, black87, black87, white87],
],
'blue-grey': [
['#eceff1', '#cfd8dc', '#b0bec5', '#90a4ae', '#78909c', '#607d8b', '#546e7a', '#455a64', '#37474f', '#263238', '#cfd8dc', '#b0bec5', '#78909c', '#455a64'],
[black87, black87, black87, black87, 'white', 'white', white87, white87, white87, white87, black87, black87, 'white', white87],
],
'nk-dark': [
['#ECECEE', '#C5C6CB', '#9EA1A9', '#7D818C', '#5C616F', '#3C4252', '#353A48', '#2D323E', '#262933', '#1E2129', '#C5C6CB', '#9EA1A9', '#5C616F', '#2D323E'],
[black87, black87, black87, 'white', 'white', white87, white87, white87, white87, white87, black87, white87, white87, white87],
],
};