UNPKG

ng2-charts

Version:

Reactive, responsive, beautiful charts for Angular2 based on Chart.js

168 lines 13.5 kB
/** * @fileoverview added by tsickle * Generated from: lib/get-colors.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { defaultColors } from './default-colors'; /** * Generate colors by chart type * @param {?} chartType * @param {?} index * @param {?} count * @return {?} */ export function getColors(chartType, index, count) { if (chartType === 'pie' || chartType === 'doughnut') { return formatPieColors(generateColors(count)); } if (chartType === 'polarArea') { return formatPolarAreaColors(generateColors(count)); } if (chartType === 'line' || chartType === 'radar') { return formatLineColor(generateColor(index)); } if (chartType === 'bar' || chartType === 'horizontalBar') { return formatBarColor(generateColor(index)); } if (chartType === 'bubble') { return formatPieColors(generateColors(count)); } if (chartType === 'scatter') { return formatPieColors(generateColors(count)); } throw new Error(`getColors - Unsupported chart type ${chartType}`); } /** * @param {?} colour * @param {?} alpha * @return {?} */ function rgba(colour, alpha) { return 'rgba(' + colour.concat(alpha).join(',') + ')'; } /** * @param {?} min * @param {?} max * @return {?} */ function getRandomInt(min, max) { return Math.floor(Math.random() * (max - min + 1)) + min; } /** * @param {?} colors * @return {?} */ function formatLineColor(colors) { return { backgroundColor: rgba(colors, 0.4), borderColor: rgba(colors, 1), pointBackgroundColor: rgba(colors, 1), pointBorderColor: '#fff', pointHoverBackgroundColor: '#fff', pointHoverBorderColor: rgba(colors, 0.8) }; } /** * @param {?} colors * @return {?} */ function formatBarColor(colors) { return { backgroundColor: rgba(colors, 0.6), borderColor: rgba(colors, 1), hoverBackgroundColor: rgba(colors, 0.8), hoverBorderColor: rgba(colors, 1) }; } /** * @param {?} colors * @return {?} */ function formatPieColors(colors) { return { backgroundColor: colors.map((/** * @param {?} color * @return {?} */ (color) => rgba(color, 0.6))), borderColor: colors.map((/** * @return {?} */ () => '#fff')), pointBackgroundColor: colors.map((/** * @param {?} color * @return {?} */ (color) => rgba(color, 1))), pointBorderColor: colors.map((/** * @return {?} */ () => '#fff')), pointHoverBackgroundColor: colors.map((/** * @param {?} color * @return {?} */ (color) => rgba(color, 1))), pointHoverBorderColor: colors.map((/** * @param {?} color * @return {?} */ (color) => rgba(color, 1))) }; } /** * @param {?} colors * @return {?} */ function formatPolarAreaColors(colors) { return { backgroundColor: colors.map((/** * @param {?} color * @return {?} */ (color) => rgba(color, 0.6))), borderColor: colors.map((/** * @param {?} color * @return {?} */ (color) => rgba(color, 1))), hoverBackgroundColor: colors.map((/** * @param {?} color * @return {?} */ (color) => rgba(color, 0.8))), hoverBorderColor: colors.map((/** * @param {?} color * @return {?} */ (color) => rgba(color, 1))) }; } /** * @return {?} */ function getRandomColor() { return [getRandomInt(0, 255), getRandomInt(0, 255), getRandomInt(0, 255)]; } /** * Generate colors for line|bar charts * @param {?} index * @return {?} */ function generateColor(index) { return defaultColors[index] || getRandomColor(); } /** * Generate colors for pie|doughnut charts * @param {?} count * @return {?} */ function generateColors(count) { /** @type {?} */ const colorsArr = new Array(count); for (let i = 0; i < count; i++) { colorsArr[i] = defaultColors[i] || getRandomColor(); } return colorsArr; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"get-colors.js","sourceRoot":"","sources":["../../../../projects/ng2-charts/src/lib/get-colors.ts"],"names":[],"mappings":";;;;;AAEA,OAAO,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAC;;;;;;;;AAKjD,MAAM,UAAU,SAAS,CAAC,SAAiB,EAAE,KAAa,EAAE,KAAa;IACvE,IAAI,SAAS,KAAK,KAAK,IAAI,SAAS,KAAK,UAAU,EAAE;QACnD,OAAO,eAAe,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,CAAC;KAC/C;IAED,IAAI,SAAS,KAAK,WAAW,EAAE;QAC7B,OAAO,qBAAqB,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,CAAC;KACrD;IAED,IAAI,SAAS,KAAK,MAAM,IAAI,SAAS,KAAK,OAAO,EAAE;QACjD,OAAO,eAAe,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC,CAAC;KAC9C;IAED,IAAI,SAAS,KAAK,KAAK,IAAI,SAAS,KAAK,eAAe,EAAE;QACxD,OAAO,cAAc,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC,CAAC;KAC7C;IAED,IAAI,SAAS,KAAK,QAAQ,EAAE;QAC1B,OAAO,eAAe,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,CAAC;KAC/C;IAED,IAAI,SAAS,KAAK,SAAS,EAAE;QAC3B,OAAO,eAAe,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,CAAC;KAC/C;IAED,MAAM,IAAI,KAAK,CAAC,sCAAsC,SAAS,EAAE,CAAC,CAAC;AACrE,CAAC;;;;;;AAED,SAAS,IAAI,CAAC,MAAqB,EAAE,KAAa;IAChD,OAAO,OAAO,GAAG,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC;AACxD,CAAC;;;;;;AAED,SAAS,YAAY,CAAC,GAAW,EAAE,GAAW;IAC5C,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,GAAG,GAAG,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;AAC3D,CAAC;;;;;AAED,SAAS,eAAe,CAAC,MAAqB;IAC5C,OAAO;QACL,eAAe,EAAE,IAAI,CAAC,MAAM,EAAE,GAAG,CAAC;QAClC,WAAW,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;QAC5B,oBAAoB,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;QACrC,gBAAgB,EAAE,MAAM;QACxB,yBAAyB,EAAE,MAAM;QACjC,qBAAqB,EAAE,IAAI,CAAC,MAAM,EAAE,GAAG,CAAC;KACzC,CAAC;AACJ,CAAC;;;;;AAED,SAAS,cAAc,CAAC,MAAqB;IAC3C,OAAO;QACL,eAAe,EAAE,IAAI,CAAC,MAAM,EAAE,GAAG,CAAC;QAClC,WAAW,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;QAC5B,oBAAoB,EAAE,IAAI,CAAC,MAAM,EAAE,GAAG,CAAC;QACvC,gBAAgB,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;KAClC,CAAC;AACJ,CAAC;;;;;AAED,SAAS,eAAe,CAAC,MAAuB;IAC9C,OAAO;QACL,eAAe,EAAE,MAAM,CAAC,GAAG;;;;QAAC,CAAC,KAAe,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE,GAAG,CAAC,EAAC;QAClE,WAAW,EAAE,MAAM,CAAC,GAAG;;;QAAC,GAAG,EAAE,CAAC,MAAM,EAAC;QACrC,oBAAoB,EAAE,MAAM,CAAC,GAAG;;;;QAAC,CAAC,KAAe,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC,EAAC;QACrE,gBAAgB,EAAE,MAAM,CAAC,GAAG;;;QAAC,GAAG,EAAE,CAAC,MAAM,EAAC;QAC1C,yBAAyB,EAAE,MAAM,CAAC,GAAG;;;;QAAC,CAAC,KAAe,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC,EAAC;QAC1E,qBAAqB,EAAE,MAAM,CAAC,GAAG;;;;QAAC,CAAC,KAAe,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC,EAAC;KACvE,CAAC;AACJ,CAAC;;;;;AAED,SAAS,qBAAqB,CAAC,MAAuB;IACpD,OAAO;QACL,eAAe,EAAE,MAAM,CAAC,GAAG;;;;QAAC,CAAC,KAAe,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE,GAAG,CAAC,EAAC;QAClE,WAAW,EAAE,MAAM,CAAC,GAAG;;;;QAAC,CAAC,KAAe,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC,EAAC;QAC5D,oBAAoB,EAAE,MAAM,CAAC,GAAG;;;;QAAC,CAAC,KAAe,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE,GAAG,CAAC,EAAC;QACvE,gBAAgB,EAAE,MAAM,CAAC,GAAG;;;;QAAC,CAAC,KAAe,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC,EAAC;KAClE,CAAC;AACJ,CAAC;;;;AAED,SAAS,cAAc;IACrB,OAAO,CAAC,YAAY,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,YAAY,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,YAAY,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC;AAC5E,CAAC;;;;;;AAKD,SAAS,aAAa,CAAC,KAAa;IAClC,OAAO,aAAa,CAAC,KAAK,CAAC,IAAI,cAAc,EAAE,CAAC;AAClD,CAAC;;;;;;AAKD,SAAS,cAAc,CAAC,KAAa;;UAC7B,SAAS,GAAoB,IAAI,KAAK,CAAC,KAAK,CAAC;IACnD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,EAAE,CAAC,EAAE,EAAE;QAC9B,SAAS,CAAC,CAAC,CAAC,GAAG,aAAa,CAAC,CAAC,CAAC,IAAI,cAAc,EAAE,CAAC;KACrD;IACD,OAAO,SAAS,CAAC;AACnB,CAAC","sourcesContent":["import { Color } from './color';\r\nimport { Colors } from './colors';\r\nimport { defaultColors } from './default-colors';\r\n\r\n/**\r\n * Generate colors by chart type\r\n */\r\nexport function getColors(chartType: string, index: number, count: number): Color {\r\n  if (chartType === 'pie' || chartType === 'doughnut') {\r\n    return formatPieColors(generateColors(count));\r\n  }\r\n\r\n  if (chartType === 'polarArea') {\r\n    return formatPolarAreaColors(generateColors(count));\r\n  }\r\n\r\n  if (chartType === 'line' || chartType === 'radar') {\r\n    return formatLineColor(generateColor(index));\r\n  }\r\n\r\n  if (chartType === 'bar' || chartType === 'horizontalBar') {\r\n    return formatBarColor(generateColor(index));\r\n  }\r\n\r\n  if (chartType === 'bubble') {\r\n    return formatPieColors(generateColors(count));\r\n  }\r\n\r\n  if (chartType === 'scatter') {\r\n    return formatPieColors(generateColors(count));\r\n  }\r\n\r\n  throw new Error(`getColors - Unsupported chart type ${chartType}`);\r\n}\r\n\r\nfunction rgba(colour: Array<number>, alpha: number): string {\r\n  return 'rgba(' + colour.concat(alpha).join(',') + ')';\r\n}\r\n\r\nfunction getRandomInt(min: number, max: number): number {\r\n  return Math.floor(Math.random() * (max - min + 1)) + min;\r\n}\r\n\r\nfunction formatLineColor(colors: Array<number>): Color {\r\n  return {\r\n    backgroundColor: rgba(colors, 0.4),\r\n    borderColor: rgba(colors, 1),\r\n    pointBackgroundColor: rgba(colors, 1),\r\n    pointBorderColor: '#fff',\r\n    pointHoverBackgroundColor: '#fff',\r\n    pointHoverBorderColor: rgba(colors, 0.8)\r\n  };\r\n}\r\n\r\nfunction formatBarColor(colors: Array<number>): Color {\r\n  return {\r\n    backgroundColor: rgba(colors, 0.6),\r\n    borderColor: rgba(colors, 1),\r\n    hoverBackgroundColor: rgba(colors, 0.8),\r\n    hoverBorderColor: rgba(colors, 1)\r\n  };\r\n}\r\n\r\nfunction formatPieColors(colors: Array<number[]>): Colors {\r\n  return {\r\n    backgroundColor: colors.map((color: number[]) => rgba(color, 0.6)),\r\n    borderColor: colors.map(() => '#fff'),\r\n    pointBackgroundColor: colors.map((color: number[]) => rgba(color, 1)),\r\n    pointBorderColor: colors.map(() => '#fff'),\r\n    pointHoverBackgroundColor: colors.map((color: number[]) => rgba(color, 1)),\r\n    pointHoverBorderColor: colors.map((color: number[]) => rgba(color, 1))\r\n  };\r\n}\r\n\r\nfunction formatPolarAreaColors(colors: Array<number[]>): Color {\r\n  return {\r\n    backgroundColor: colors.map((color: number[]) => rgba(color, 0.6)),\r\n    borderColor: colors.map((color: number[]) => rgba(color, 1)),\r\n    hoverBackgroundColor: colors.map((color: number[]) => rgba(color, 0.8)),\r\n    hoverBorderColor: colors.map((color: number[]) => rgba(color, 1))\r\n  };\r\n}\r\n\r\nfunction getRandomColor(): number[] {\r\n  return [getRandomInt(0, 255), getRandomInt(0, 255), getRandomInt(0, 255)];\r\n}\r\n\r\n/**\r\n * Generate colors for line|bar charts\r\n */\r\nfunction generateColor(index: number): number[] {\r\n  return defaultColors[index] || getRandomColor();\r\n}\r\n\r\n/**\r\n * Generate colors for pie|doughnut charts\r\n */\r\nfunction generateColors(count: number): Array<number[]> {\r\n  const colorsArr: Array<number[]> = new Array(count);\r\n  for (let i = 0; i < count; i++) {\r\n    colorsArr[i] = defaultColors[i] || getRandomColor();\r\n  }\r\n  return colorsArr;\r\n}\r\n"]}