UNPKG

ng2-charts

Version:

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

115 lines 12.7 kB
/** * @fileoverview added by tsickle * Generated from: lib/monkey-patch-chart-js-tooltip.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ // tslint:disable:variable-name // tslint:disable:no-var-keyword // tslint:disable:prefer-const // tslint:disable:only-arrow-functions // tslint:disable:one-variable-per-declaration // tslint:disable:object-literal-shorthand // tslint:disable:space-before-function-paren /** * @return {?} */ export function monkeyPatchChartJsTooltip() { if (typeof Chart === 'undefined') { console.log('Chart not defined (guessing this is a universal build, and I don\'t know why this happens -- Aviad)'); return; } Chart.Tooltip.prototype.drawBody = drawBody; /** @type {?} */ const helpers = Chart.helpers; /** * @param {?} vm * @param {?} align * @return {?} */ function getAlignedX(vm, align) { return align === 'center' ? vm.x + vm.width / 2 : align === 'right' ? vm.x + vm.width - vm.xPadding : vm.x + vm.xPadding; } /** * @param {?} pt * @param {?} vm * @param {?} ctx * @return {?} */ function drawBody(pt, vm, ctx) { /** @type {?} */ var bodyFontSize = vm.bodyFontSize; /** @type {?} */ var bodySpacing = vm.bodySpacing; /** @type {?} */ var bodyAlign = vm._bodyAlign; /** @type {?} */ var body = vm.body; /** @type {?} */ var drawColorBoxes = vm.displayColors; /** @type {?} */ var labelColors = vm.labelColors; /** @type {?} */ var xLinePadding = 0; /** @type {?} */ var colorX = drawColorBoxes ? getAlignedX(vm, 'left') : 0; /** @type {?} */ var textColor; ctx.textAlign = bodyAlign; ctx.textBaseline = 'top'; ctx.font = helpers.fontString(bodyFontSize, vm._bodyFontStyle, vm._bodyFontFamily); pt.x = getAlignedX(vm, bodyAlign); // Before Body /** @type {?} */ var fillLineOfText = (/** * @param {?} line * @return {?} */ function (line) { ctx.fillText(line, pt.x + xLinePadding, pt.y); pt.y += bodyFontSize + bodySpacing; }); // Before body lines ctx.fillStyle = vm.bodyFontColor; helpers.each(vm.beforeBody, fillLineOfText); xLinePadding = drawColorBoxes && bodyAlign !== 'right' ? bodyAlign === 'center' ? (bodyFontSize / 2 + 1) : (bodyFontSize + 2) : 0; // Draw body lines now helpers.each(body, (/** * @param {?} bodyItem * @param {?} i * @return {?} */ function (bodyItem, i) { textColor = vm.labelTextColors[i]; ctx.fillStyle = textColor; helpers.each(bodyItem.before, fillLineOfText); // Draw Legend-like boxes if needed if (drawColorBoxes) { // Fill a white rect so that colours merge nicely if the opacity is < 1 ctx.fillStyle = vm.legendColorBackground; ctx.fillRect(colorX, pt.y, bodyFontSize, bodyFontSize); // Border ctx.lineWidth = 1; ctx.strokeStyle = labelColors[i].borderColor; ctx.strokeRect(colorX, pt.y, bodyFontSize, bodyFontSize); // Inner square ctx.fillStyle = labelColors[i].backgroundColor; ctx.fillRect(colorX + 1, pt.y + 1, bodyFontSize - 2, bodyFontSize - 2); ctx.fillStyle = textColor; } helpers.each(bodyItem.lines, fillLineOfText); helpers.each(bodyItem.after, fillLineOfText); })); // Reset back to 0 for after body xLinePadding = 0; // After body lines helpers.each(vm.afterBody, fillLineOfText); pt.y -= bodySpacing; // Remove last body spacing } } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"monkey-patch-chart-js-tooltip.js","sourceRoot":"","sources":["../../../../projects/ng2-charts/src/lib/monkey-patch-chart-js-tooltip.ts"],"names":[],"mappings":"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","sourcesContent":["// tslint:disable:variable-name\r\n// tslint:disable:no-var-keyword\r\n// tslint:disable:prefer-const\r\n// tslint:disable:only-arrow-functions\r\n// tslint:disable:one-variable-per-declaration\r\n// tslint:disable:object-literal-shorthand\r\n// tslint:disable:space-before-function-paren\r\n\r\ndeclare class Chart {\r\n  static readonly Chart: typeof Chart;\r\n  static readonly Tooltip: any;\r\n  static readonly helpers: any;\r\n  static readonly defaults: any;\r\n  static readonly plugins: any;\r\n}\r\n\r\nexport function monkeyPatchChartJsTooltip() {\r\n  if (typeof Chart === 'undefined') {\r\n    console.log('Chart not defined (guessing this is a universal build, and I don\\'t know why this happens -- Aviad)');\r\n    return;\r\n  }\r\n  Chart.Tooltip.prototype.drawBody = drawBody;\r\n  const helpers = Chart.helpers;\r\n\r\n  function getAlignedX(vm, align) {\r\n    return align === 'center'\r\n      ? vm.x + vm.width / 2\r\n      : align === 'right'\r\n        ? vm.x + vm.width - vm.xPadding\r\n        : vm.x + vm.xPadding;\r\n  }\r\n\r\n  function drawBody(pt, vm, ctx) {\r\n    var bodyFontSize = vm.bodyFontSize;\r\n    var bodySpacing = vm.bodySpacing;\r\n    var bodyAlign = vm._bodyAlign;\r\n    var body = vm.body;\r\n    var drawColorBoxes = vm.displayColors;\r\n    var labelColors = vm.labelColors;\r\n    var xLinePadding = 0;\r\n    var colorX = drawColorBoxes ? getAlignedX(vm, 'left') : 0;\r\n    var textColor;\r\n\r\n    ctx.textAlign = bodyAlign;\r\n    ctx.textBaseline = 'top';\r\n    ctx.font = helpers.fontString(bodyFontSize, vm._bodyFontStyle, vm._bodyFontFamily);\r\n\r\n    pt.x = getAlignedX(vm, bodyAlign);\r\n\r\n    // Before Body\r\n    var fillLineOfText = function (line) {\r\n      ctx.fillText(line, pt.x + xLinePadding, pt.y);\r\n      pt.y += bodyFontSize + bodySpacing;\r\n    };\r\n\r\n    // Before body lines\r\n    ctx.fillStyle = vm.bodyFontColor;\r\n    helpers.each(vm.beforeBody, fillLineOfText);\r\n\r\n    xLinePadding = drawColorBoxes && bodyAlign !== 'right'\r\n      ? bodyAlign === 'center' ? (bodyFontSize / 2 + 1) : (bodyFontSize + 2)\r\n      : 0;\r\n\r\n    // Draw body lines now\r\n    helpers.each(body, function (bodyItem, i) {\r\n      textColor = vm.labelTextColors[i];\r\n      ctx.fillStyle = textColor;\r\n      helpers.each(bodyItem.before, fillLineOfText);\r\n\r\n      // Draw Legend-like boxes if needed\r\n      if (drawColorBoxes) {\r\n        // Fill a white rect so that colours merge nicely if the opacity is < 1\r\n        ctx.fillStyle = vm.legendColorBackground;\r\n        ctx.fillRect(colorX, pt.y, bodyFontSize, bodyFontSize);\r\n\r\n        // Border\r\n        ctx.lineWidth = 1;\r\n        ctx.strokeStyle = labelColors[i].borderColor;\r\n        ctx.strokeRect(colorX, pt.y, bodyFontSize, bodyFontSize);\r\n\r\n        // Inner square\r\n        ctx.fillStyle = labelColors[i].backgroundColor;\r\n        ctx.fillRect(colorX + 1, pt.y + 1, bodyFontSize - 2, bodyFontSize - 2);\r\n        ctx.fillStyle = textColor;\r\n      }\r\n\r\n      helpers.each(bodyItem.lines, fillLineOfText);\r\n\r\n      helpers.each(bodyItem.after, fillLineOfText);\r\n    });\r\n\r\n    // Reset back to 0 for after body\r\n    xLinePadding = 0;\r\n\r\n    // After body lines\r\n    helpers.each(vm.afterBody, fillLineOfText);\r\n    pt.y -= bodySpacing; // Remove last body spacing\r\n  }\r\n}\r\n"]}