UNPKG

ng2-charts

Version:

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

499 lines 53.6 kB
/** * @fileoverview added by tsickle * Generated from: lib/monkey-patch-chart-js-legend.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 monkeyPatchChartJsLegend() { 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; } /** @type {?} */ const plugins = Chart.plugins.getAll(); /** @type {?} */ const legend = plugins.filter((/** * @param {?} p * @return {?} */ p => p.id === 'legend'))[0]; legend._element.prototype.fit = fit; legend._element.prototype.draw = draw; /** @type {?} */ const helpers = Chart.helpers; /** @type {?} */ const defaults = Chart.defaults; /** @type {?} */ const valueOrDefault = helpers.valueOrDefault; /** * @param {?} labelOpts * @param {?} fontSize * @return {?} */ function getBoxWidth(labelOpts, fontSize) { return labelOpts.usePointStyle && labelOpts.boxWidth > fontSize ? fontSize : labelOpts.boxWidth; } /** * @return {?} */ function fit() { /** @type {?} */ var me = this; /** @type {?} */ var opts = me.options; /** @type {?} */ var labelOpts = opts.labels; /** @type {?} */ var display = opts.display; /** @type {?} */ var ctx = me.ctx; /** @type {?} */ var labelFont = helpers.options._parseFont(labelOpts); /** @type {?} */ var fontSize = labelFont.size; // Reset hit boxes /** @type {?} */ var hitboxes = me.legendHitBoxes = []; /** @type {?} */ var minSize = me.minSize; /** @type {?} */ var isHorizontal = me.isHorizontal(); if (isHorizontal) { minSize.width = me.maxWidth; // fill all the width minSize.height = display ? 10 : 0; } else { minSize.width = display ? 10 : 0; minSize.height = me.maxHeight; // fill all the height } /** @type {?} */ var getMaxLineWidth = (/** * @param {?} textLines * @return {?} */ function (textLines) { return textLines.map((/** * @param {?} textLine * @return {?} */ function (textLine) { return ctx.measureText(textLine).width; })).reduce((/** * @param {?} acc * @param {?} v * @return {?} */ function (acc, v) { return v > acc ? v : acc; }), 0); }); // Increase sizes here if (display) { ctx.font = labelFont.string; if (isHorizontal) { // Labels // Width of each line of legend boxes. Labels wrap onto multiple lines when there are too many to fit on one /** @type {?} */ var lineWidths = me.lineWidths = [0]; /** @type {?} */ var lineHeights = me.lineHeights = []; /** @type {?} */ var currentLineHeight = 0; /** @type {?} */ var lineIndex = 0; ctx.textAlign = 'left'; ctx.textBaseline = 'top'; helpers.each(me.legendItems, (/** * @param {?} legendItem * @param {?} i * @return {?} */ function (legendItem, i) { /** @type {?} */ var width; /** @type {?} */ var height; if (helpers.isArray(legendItem.text)) { width = getMaxLineWidth(legendItem.text); height = fontSize * legendItem.text.length + labelOpts.padding; } else { width = ctx.measureText(legendItem.text).width; height = fontSize + labelOpts.padding; } width += getBoxWidth(labelOpts, fontSize) + (fontSize / 2); if (lineWidths[lineWidths.length - 1] + width + 2 * labelOpts.padding > minSize.width) { lineHeights.push(currentLineHeight); currentLineHeight = 0; lineWidths[lineWidths.length - (i > 0 ? 0 : 1)] = 0; lineIndex++; } legendItem.lineOrColumnIndex = lineIndex; if (height > currentLineHeight) { currentLineHeight = height; } // Store the hitbox width and height here. Final position will be updated in `draw` hitboxes[i] = { left: 0, top: 0, width: width, height: height, }; lineWidths[lineWidths.length - 1] += width + labelOpts.padding; })); lineHeights.push(currentLineHeight); minSize.height += lineHeights.reduce((/** * @param {?} acc * @param {?} v * @return {?} */ function (acc, v) { return acc + v; }), 0); } else { /** @type {?} */ var vPadding = labelOpts.padding; /** @type {?} */ var columnWidths = me.columnWidths = []; /** @type {?} */ var columnHeights = me.columnHeights = []; /** @type {?} */ var totalWidth = labelOpts.padding; /** @type {?} */ var currentColWidth = 0; /** @type {?} */ var currentColHeight = 0; /** @type {?} */ var columnIndex = 0; helpers.each(me.legendItems, (/** * @param {?} legendItem * @param {?} i * @return {?} */ function (legendItem, i) { /** @type {?} */ var itemWidth; /** @type {?} */ var height; if (helpers.isArray(legendItem.text)) { itemWidth = getMaxLineWidth(legendItem.text); height = fontSize * legendItem.text.length; } else { itemWidth = ctx.measureText(legendItem.text).width; height = fontSize; } itemWidth += getBoxWidth(labelOpts, fontSize) + (fontSize / 2); // If too tall, go to new column if (currentColHeight + fontSize + 2 * vPadding > minSize.height) { totalWidth += currentColWidth + labelOpts.padding; columnWidths.push(currentColWidth); // previous column width columnHeights.push(currentColHeight); currentColWidth = 0; currentColHeight = 0; columnIndex++; } legendItem.lineOrColumnIndex = columnIndex; // Get max width currentColWidth = Math.max(currentColWidth, itemWidth); currentColHeight += height + vPadding; // Store the hitbox width and height here. Final position will be updated in `draw` hitboxes[i] = { left: 0, top: 0, width: itemWidth, height: height }; })); totalWidth += currentColWidth; columnWidths.push(currentColWidth); columnHeights.push(currentColHeight); minSize.width += totalWidth; } } me.width = minSize.width; me.height = minSize.height; } /** * @return {?} */ function draw() { /** @type {?} */ var me = this; /** @type {?} */ var opts = me.options; /** @type {?} */ var labelOpts = opts.labels; /** @type {?} */ var globalDefaults = defaults.global; /** @type {?} */ var defaultColor = globalDefaults.defaultColor; /** @type {?} */ var lineDefault = globalDefaults.elements.line; /** @type {?} */ var legendHeight = me.height; /** @type {?} */ var columnHeights = me.columnHeights; /** @type {?} */ var columnWidths = me.columnWidths; /** @type {?} */ var legendWidth = me.width; /** @type {?} */ var lineWidths = me.lineWidths; /** @type {?} */ var lineHeights = me.lineHeights; if (opts.display) { /** @type {?} */ var ctx = me.ctx; /** @type {?} */ var fontColor = valueOrDefault(labelOpts.fontColor, globalDefaults.defaultFontColor); /** @type {?} */ var labelFont = helpers.options._parseFont(labelOpts); /** @type {?} */ var fontSize = labelFont.size; /** @type {?} */ var cursor; // Canvas setup ctx.textAlign = 'left'; ctx.textBaseline = 'middle'; ctx.lineWidth = 0.5; ctx.strokeStyle = fontColor; // for strikethrough effect ctx.fillStyle = fontColor; // render in correct colour ctx.font = labelFont.string; /** @type {?} */ var boxWidth = getBoxWidth(labelOpts, fontSize); /** @type {?} */ var hitboxes = me.legendHitBoxes; // current position /** @type {?} */ var drawLegendBox = (/** * @param {?} x * @param {?} y * @param {?} legendItem * @return {?} */ function (x, y, legendItem) { if (isNaN(boxWidth) || boxWidth <= 0) { return; } // Set the ctx for the box ctx.save(); /** @type {?} */ var lineWidth = valueOrDefault(legendItem.lineWidth, lineDefault.borderWidth); ctx.fillStyle = valueOrDefault(legendItem.fillStyle, defaultColor); ctx.lineCap = valueOrDefault(legendItem.lineCap, lineDefault.borderCapStyle); ctx.lineDashOffset = valueOrDefault(legendItem.lineDashOffset, lineDefault.borderDashOffset); ctx.lineJoin = valueOrDefault(legendItem.lineJoin, lineDefault.borderJoinStyle); ctx.lineWidth = lineWidth; ctx.strokeStyle = valueOrDefault(legendItem.strokeStyle, defaultColor); if (ctx.setLineDash) { // IE 9 and 10 do not support line dash ctx.setLineDash(valueOrDefault(legendItem.lineDash, lineDefault.borderDash)); } if (opts.labels && opts.labels.usePointStyle) { // Recalculate x and y for drawPoint() because its expecting // x and y to be center of figure (instead of top left) /** @type {?} */ var radius = boxWidth * Math.SQRT2 / 2; /** @type {?} */ var centerX = x + boxWidth / 2; /** @type {?} */ var centerY = y + fontSize / 2; // Draw pointStyle as legend symbol helpers.canvas.drawPoint(ctx, legendItem.pointStyle, radius, centerX, centerY); } else { // Draw box as legend symbol if (lineWidth !== 0) { ctx.strokeRect(x, y, boxWidth, fontSize); } ctx.fillRect(x, y, boxWidth, fontSize); } ctx.restore(); }); /** @type {?} */ var drawStrikeThrough = (/** * @param {?} x * @param {?} y * @param {?} w * @return {?} */ function (x, y, w) { ctx.beginPath(); ctx.lineWidth = 2; ctx.moveTo(x, y); ctx.lineTo(x + w, y); ctx.stroke(); }); /** @type {?} */ var drawCrossOver = (/** * @param {?} x * @param {?} y * @param {?} w * @param {?} h * @return {?} */ function (x, y, w, h) { ctx.beginPath(); ctx.lineWidth = 2; ctx.moveTo(x, y); ctx.lineTo(x + w, y + h); ctx.moveTo(x, y + h); ctx.lineTo(x + w, y); ctx.stroke(); }); /** @type {?} */ var fillText = (/** * @param {?} x * @param {?} y * @param {?} legendItem * @param {?} textWidth * @return {?} */ function (x, y, legendItem, textWidth) { /** @type {?} */ var halfFontSize = fontSize / 2; /** @type {?} */ var xLeft = boxWidth + halfFontSize + x; /** @type {?} */ var yMiddle = y + halfFontSize; if (helpers.isArray(legendItem.text)) { helpers.each(legendItem.text, (/** * @param {?} textLine * @param {?} index * @return {?} */ function (textLine, index) { /** @type {?} */ var lineOffset = index * fontSize; ctx.fillText(textLine, xLeft, yMiddle + lineOffset); })); } else { ctx.fillText(legendItem.text, xLeft, yMiddle); } if (legendItem.hidden) { if (helpers.isArray(legendItem.text)) { drawCrossOver(xLeft, yMiddle, textWidth, (legendItem.text.length - 1) * (fontSize - 1)); } else { drawStrikeThrough(xLeft, yMiddle, textWidth); } } }); /** @type {?} */ var alignmentOffset = (/** * @param {?} dimension * @param {?} blockSize * @return {?} */ function (dimension, blockSize) { switch (opts.align) { case 'start': return labelOpts.padding; case 'end': return dimension - blockSize; default: // center return (dimension - blockSize + labelOpts.padding) / 2; } }); // Horizontal /** @type {?} */ var isHorizontal = me.isHorizontal(); if (isHorizontal) { cursor = { x: me.left + alignmentOffset(legendWidth, lineWidths[0]), y: me.top + labelOpts.padding, line: 0 }; } else { cursor = { x: me.left + labelOpts.padding, y: me.top + alignmentOffset(legendHeight, columnHeights[0]), line: 0 }; } helpers.each(me.legendItems, (/** * @param {?} legendItem * @param {?} i * @return {?} */ function (legendItem, i) { /** @type {?} */ var textWidth; /** @type {?} */ var height; /** @type {?} */ var boxTopOffset; if (legendItem.lineOrColumnIndex > cursor.line) { if (isHorizontal) { cursor.y += lineHeights[cursor.line]; cursor.line = legendItem.lineOrColumnIndex; cursor.x = me.left + alignmentOffset(legendWidth, lineWidths[cursor.line]); } else { cursor.x += columnWidths[cursor.line] + labelOpts.padding; cursor.line = legendItem.lineOrColumnIndex; cursor.y = me.top + alignmentOffset(legendHeight, columnHeights[cursor.line]); } } if (helpers.isArray(legendItem.text)) { textWidth = legendItem.text.map((/** * @param {?} textLine * @return {?} */ function (textLine) { return ctx.measureText(textLine).width; })).reduce((/** * @param {?} acc * @param {?} v * @return {?} */ function (acc, v) { return v > acc ? v : acc; }), 0); boxTopOffset = fontSize / 2 * (legendItem.text.length - 1); height = fontSize * legendItem.text.length; } else { textWidth = ctx.measureText(legendItem.text).width; boxTopOffset = 0; height = fontSize; } /** @type {?} */ var width = boxWidth + (fontSize / 2) + textWidth; /** @type {?} */ var x = cursor.x; /** @type {?} */ var y = cursor.y; /** @type {?} */ var topOffset = isHorizontal ? Math.trunc((lineHeights[cursor.line] - hitboxes[i].height) / 2) : 0; drawLegendBox(x, y + boxTopOffset + topOffset, legendItem); hitboxes[i].left = x; hitboxes[i].top = y; // Fill the actual label fillText(x, y + topOffset, legendItem, textWidth); if (isHorizontal) { cursor.x += width + labelOpts.padding; } else { cursor.y += height + labelOpts.padding; } })); } } } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"monkey-patch-chart-js-legend.js","sourceRoot":"","sources":["../../../../projects/ng2-charts/src/lib/monkey-patch-chart-js-legend.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 monkeyPatchChartJsLegend() {\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  const plugins = Chart.plugins.getAll();\r\n  const legend = plugins.filter(p => p.id === 'legend')[0];\r\n  legend._element.prototype.fit = fit;\r\n  legend._element.prototype.draw = draw;\r\n\r\n  const helpers = Chart.helpers;\r\n  const defaults = Chart.defaults;\r\n  const valueOrDefault = helpers.valueOrDefault;\r\n\r\n  function getBoxWidth(labelOpts, fontSize) {\r\n    return labelOpts.usePointStyle && labelOpts.boxWidth > fontSize ?\r\n      fontSize :\r\n      labelOpts.boxWidth;\r\n  }\r\n\r\n  function fit() {\r\n    var me = this;\r\n    var opts = me.options;\r\n    var labelOpts = opts.labels;\r\n    var display = opts.display;\r\n\r\n    var ctx = me.ctx;\r\n\r\n    var labelFont = helpers.options._parseFont(labelOpts);\r\n    var fontSize = labelFont.size;\r\n\r\n    // Reset hit boxes\r\n    var hitboxes = me.legendHitBoxes = [];\r\n\r\n    var minSize = me.minSize;\r\n    var isHorizontal = me.isHorizontal();\r\n\r\n    if (isHorizontal) {\r\n      minSize.width = me.maxWidth; // fill all the width\r\n      minSize.height = display ? 10 : 0;\r\n    } else {\r\n      minSize.width = display ? 10 : 0;\r\n      minSize.height = me.maxHeight; // fill all the height\r\n    }\r\n\r\n    var getMaxLineWidth = function (textLines) {\r\n      return textLines.map(function (textLine) {\r\n        return ctx.measureText(textLine).width;\r\n      }).reduce(function (acc, v) {\r\n        return v > acc ? v : acc;\r\n      }, 0);\r\n    };\r\n\r\n    // Increase sizes here\r\n    if (display) {\r\n      ctx.font = labelFont.string;\r\n\r\n      if (isHorizontal) {\r\n\r\n        // Labels\r\n\r\n        // Width of each line of legend boxes. Labels wrap onto multiple lines when there are too many to fit on one\r\n        var lineWidths = me.lineWidths = [0];\r\n        var lineHeights = me.lineHeights = [];\r\n        var currentLineHeight = 0;\r\n        var lineIndex = 0;\r\n\r\n        ctx.textAlign = 'left';\r\n        ctx.textBaseline = 'top';\r\n\r\n        helpers.each(me.legendItems, function (legendItem, i) {\r\n          var width, height;\r\n\r\n          if (helpers.isArray(legendItem.text)) {\r\n            width = getMaxLineWidth(legendItem.text);\r\n            height = fontSize * legendItem.text.length + labelOpts.padding;\r\n          } else {\r\n            width = ctx.measureText(legendItem.text).width;\r\n            height = fontSize + labelOpts.padding;\r\n          }\r\n          width += getBoxWidth(labelOpts, fontSize) + (fontSize / 2);\r\n\r\n          if (lineWidths[lineWidths.length - 1] + width + 2 * labelOpts.padding > minSize.width) {\r\n            lineHeights.push(currentLineHeight);\r\n            currentLineHeight = 0;\r\n            lineWidths[lineWidths.length - (i > 0 ? 0 : 1)] = 0;\r\n            lineIndex++;\r\n          }\r\n\r\n          legendItem.lineOrColumnIndex = lineIndex;\r\n\r\n          if (height > currentLineHeight) {\r\n            currentLineHeight = height;\r\n          }\r\n\r\n          // Store the hitbox width and height here. Final position will be updated in `draw`\r\n          hitboxes[i] = {\r\n            left: 0,\r\n            top: 0,\r\n            width: width,\r\n            height: height,\r\n          };\r\n\r\n          lineWidths[lineWidths.length - 1] += width + labelOpts.padding;\r\n        });\r\n\r\n        lineHeights.push(currentLineHeight);\r\n        minSize.height += lineHeights.reduce(function (acc, v) {\r\n          return acc + v;\r\n        }, 0);\r\n\r\n      } else {\r\n        var vPadding = labelOpts.padding;\r\n        var columnWidths = me.columnWidths = [];\r\n        var columnHeights = me.columnHeights = [];\r\n        var totalWidth = labelOpts.padding;\r\n        var currentColWidth = 0;\r\n        var currentColHeight = 0;\r\n        var columnIndex = 0;\r\n\r\n        helpers.each(me.legendItems, function (legendItem, i) {\r\n          var itemWidth;\r\n          var height;\r\n\r\n          if (helpers.isArray(legendItem.text)) {\r\n            itemWidth = getMaxLineWidth(legendItem.text);\r\n            height = fontSize * legendItem.text.length;\r\n          } else {\r\n            itemWidth = ctx.measureText(legendItem.text).width;\r\n            height = fontSize;\r\n          }\r\n          itemWidth += getBoxWidth(labelOpts, fontSize) + (fontSize / 2);\r\n\r\n          // If too tall, go to new column\r\n          if (currentColHeight + fontSize + 2 * vPadding > minSize.height) {\r\n            totalWidth += currentColWidth + labelOpts.padding;\r\n            columnWidths.push(currentColWidth); // previous column width\r\n            columnHeights.push(currentColHeight);\r\n            currentColWidth = 0;\r\n            currentColHeight = 0;\r\n            columnIndex++;\r\n          }\r\n\r\n          legendItem.lineOrColumnIndex = columnIndex;\r\n\r\n          // Get max width\r\n          currentColWidth = Math.max(currentColWidth, itemWidth);\r\n          currentColHeight += height + vPadding;\r\n\r\n          // Store the hitbox width and height here. Final position will be updated in `draw`\r\n          hitboxes[i] = {\r\n            left: 0,\r\n            top: 0,\r\n            width: itemWidth,\r\n            height: height\r\n          };\r\n        });\r\n\r\n        totalWidth += currentColWidth;\r\n        columnWidths.push(currentColWidth);\r\n        columnHeights.push(currentColHeight);\r\n        minSize.width += totalWidth;\r\n      }\r\n    }\r\n\r\n    me.width = minSize.width;\r\n    me.height = minSize.height;\r\n  }\r\n\r\n  function draw() {\r\n    var me = this;\r\n    var opts = me.options;\r\n    var labelOpts = opts.labels;\r\n    var globalDefaults = defaults.global;\r\n    var defaultColor = globalDefaults.defaultColor;\r\n    var lineDefault = globalDefaults.elements.line;\r\n    var legendHeight = me.height;\r\n    var columnHeights = me.columnHeights;\r\n    var columnWidths = me.columnWidths;\r\n    var legendWidth = me.width;\r\n    var lineWidths = me.lineWidths;\r\n    var lineHeights = me.lineHeights;\r\n\r\n    if (opts.display) {\r\n      var ctx = me.ctx;\r\n      var fontColor = valueOrDefault(labelOpts.fontColor, globalDefaults.defaultFontColor);\r\n      var labelFont = helpers.options._parseFont(labelOpts);\r\n      var fontSize = labelFont.size;\r\n      var cursor;\r\n\r\n      // Canvas setup\r\n      ctx.textAlign = 'left';\r\n      ctx.textBaseline = 'middle';\r\n      ctx.lineWidth = 0.5;\r\n      ctx.strokeStyle = fontColor; // for strikethrough effect\r\n      ctx.fillStyle = fontColor; // render in correct colour\r\n      ctx.font = labelFont.string;\r\n\r\n      var boxWidth = getBoxWidth(labelOpts, fontSize);\r\n      var hitboxes = me.legendHitBoxes;\r\n\r\n      // current position\r\n      var drawLegendBox = function (x, y, legendItem) {\r\n        if (isNaN(boxWidth) || boxWidth <= 0) {\r\n          return;\r\n        }\r\n\r\n        // Set the ctx for the box\r\n        ctx.save();\r\n\r\n        var lineWidth = valueOrDefault(legendItem.lineWidth, lineDefault.borderWidth);\r\n        ctx.fillStyle = valueOrDefault(legendItem.fillStyle, defaultColor);\r\n        ctx.lineCap = valueOrDefault(legendItem.lineCap, lineDefault.borderCapStyle);\r\n        ctx.lineDashOffset = valueOrDefault(legendItem.lineDashOffset, lineDefault.borderDashOffset);\r\n        ctx.lineJoin = valueOrDefault(legendItem.lineJoin, lineDefault.borderJoinStyle);\r\n        ctx.lineWidth = lineWidth;\r\n        ctx.strokeStyle = valueOrDefault(legendItem.strokeStyle, defaultColor);\r\n\r\n        if (ctx.setLineDash) {\r\n          // IE 9 and 10 do not support line dash\r\n          ctx.setLineDash(valueOrDefault(legendItem.lineDash, lineDefault.borderDash));\r\n        }\r\n\r\n        if (opts.labels && opts.labels.usePointStyle) {\r\n          // Recalculate x and y for drawPoint() because its expecting\r\n          // x and y to be center of figure (instead of top left)\r\n          var radius = boxWidth * Math.SQRT2 / 2;\r\n          var centerX = x + boxWidth / 2;\r\n          var centerY = y + fontSize / 2;\r\n\r\n          // Draw pointStyle as legend symbol\r\n          helpers.canvas.drawPoint(ctx, legendItem.pointStyle, radius, centerX, centerY);\r\n        } else {\r\n          // Draw box as legend symbol\r\n          if (lineWidth !== 0) {\r\n            ctx.strokeRect(x, y, boxWidth, fontSize);\r\n          }\r\n          ctx.fillRect(x, y, boxWidth, fontSize);\r\n        }\r\n\r\n        ctx.restore();\r\n      };\r\n\r\n      var drawStrikeThrough = function (x, y, w) {\r\n        ctx.beginPath();\r\n        ctx.lineWidth = 2;\r\n        ctx.moveTo(x, y);\r\n        ctx.lineTo(x + w, y);\r\n        ctx.stroke();\r\n      };\r\n\r\n      var drawCrossOver = function (x, y, w, h) {\r\n        ctx.beginPath();\r\n        ctx.lineWidth = 2;\r\n        ctx.moveTo(x, y);\r\n        ctx.lineTo(x + w, y + h);\r\n        ctx.moveTo(x, y + h);\r\n        ctx.lineTo(x + w, y);\r\n        ctx.stroke();\r\n      };\r\n\r\n      var fillText = function (x, y, legendItem, textWidth) {\r\n        var halfFontSize = fontSize / 2;\r\n        var xLeft = boxWidth + halfFontSize + x;\r\n        var yMiddle = y + halfFontSize;\r\n\r\n        if (helpers.isArray(legendItem.text)) {\r\n          helpers.each(legendItem.text, function (textLine, index) {\r\n            var lineOffset = index * fontSize;\r\n            ctx.fillText(textLine, xLeft, yMiddle + lineOffset);\r\n          });\r\n        } else {\r\n          ctx.fillText(legendItem.text, xLeft, yMiddle);\r\n        }\r\n\r\n        if (legendItem.hidden) {\r\n          if (helpers.isArray(legendItem.text)) {\r\n            drawCrossOver(xLeft, yMiddle, textWidth, (legendItem.text.length - 1) * (fontSize - 1));\r\n          } else {\r\n            drawStrikeThrough(xLeft, yMiddle, textWidth);\r\n          }\r\n        }\r\n      };\r\n\r\n      var alignmentOffset = function (dimension, blockSize) {\r\n        switch (