@rfprodz/client-d3-charts 1.3.0 → 1.3.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/bar-chart/bar-chart.component.mjs +3 -3
- package/esm2022/lib/components/chart-examples/chart-examples.component.mjs +4 -4
- package/esm2022/lib/components/force-directed-chart/force-directed-chart.component.mjs +3 -3
- package/esm2022/lib/components/line-chart/line-chart.component.mjs +3 -3
- package/esm2022/lib/components/pie-chart/pie-chart.component.mjs +3 -3
- package/esm2022/lib/components/radar-chart/radar-chart.component.mjs +3 -3
- package/esm2022/lib/d3-charts.module.mjs +4 -4
- package/esm2022/lib/util/line-chart.util.mjs +10 -3
- package/esm2022/lib/util/pie-chart.util.mjs +10 -10
- package/esm2022/lib/util/radar-chart.util.mjs +15 -5
- package/fesm2022/rfprodz-client-d3-charts.mjs +55 -38
- package/fesm2022/rfprodz-client-d3-charts.mjs.map +1 -1
- package/package.json +3 -3
|
@@ -237,8 +237,6 @@ const drawRadarChartBlobs = (radiusScale, angleSlice, g, data, config) => {
|
|
|
237
237
|
const appendInvisibleTooltipCircles = (g, data, radiusScale, angleSlice, config) => {
|
|
238
238
|
// wrapper for the invisible circles on top
|
|
239
239
|
const blobCircleWrapper = g.selectAll('.radar-circle-wrapper').data(data).enter().append('g').attr('class', 'radar-circle-wrapper');
|
|
240
|
-
// set up the small tooltip for when you hover over a circle
|
|
241
|
-
const tooltip = g.append('text').attr('class', 'chart-tooltip').style('opacity', 0);
|
|
242
240
|
// append a set of invisible circles on top for the mouseover pop-up
|
|
243
241
|
const blobCircleWrapperRadiusMultiplier = 1.5;
|
|
244
242
|
blobCircleWrapper
|
|
@@ -258,10 +256,22 @@ const appendInvisibleTooltipCircles = (g, data, radiusScale, angleSlice, config)
|
|
|
258
256
|
const newY = parseFloat(d3.select(this).attr('cy')) - modifier;
|
|
259
257
|
const nodeData = event.target['__data__'];
|
|
260
258
|
const tooltipText = `${nodeData.value} ${nodeData.unit}`;
|
|
261
|
-
|
|
259
|
+
g.append('text')
|
|
260
|
+
.attr('class', 'chart-tooltip')
|
|
261
|
+
.style('opacity', 0)
|
|
262
|
+
.attr('x', newX)
|
|
263
|
+
.attr('y', newY)
|
|
264
|
+
.text(tooltipText)
|
|
265
|
+
.transition()
|
|
266
|
+
.duration(config.transitionDuration)
|
|
267
|
+
.style('opacity', 1);
|
|
262
268
|
})
|
|
263
269
|
.on('mouseout', () => {
|
|
264
|
-
|
|
270
|
+
d3.selectAll('.chart-tooltip')
|
|
271
|
+
.transition()
|
|
272
|
+
.duration(config.transitionDuration / 2)
|
|
273
|
+
.style('opacity', 0)
|
|
274
|
+
.remove();
|
|
265
275
|
});
|
|
266
276
|
};
|
|
267
277
|
/**
|
|
@@ -294,4 +304,4 @@ export const drawRadarChart = (container, data, options) => {
|
|
|
294
304
|
appendInvisibleTooltipCircles(g, data, radiusScale, angleSlice, config);
|
|
295
305
|
return config;
|
|
296
306
|
};
|
|
297
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radar-chart.util.js","sourceRoot":"","sources":["../../../../../../libs/client-d3-charts/src/lib/util/radar-chart.util.ts"],"names":[],"mappings":"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","sourcesContent":["import { ElementRef } from '@angular/core';\nimport * as d3 from 'd3';\n\nimport { IRadarChartDataNode, IRadarChartOptions, TRadarChartData } from '../interfaces/radar-chart.interface';\nimport { generateConfiguration } from './configuration.util';\n\n/**\n * The radar chart default configuration.\n */\nexport const defaultRadarChartConfig: IRadarChartOptions = Object.freeze(<IRadarChartOptions>{\n  chartTitle: '',\n  width: 350,\n  height: 350,\n  margin: {\n    top: 50,\n    right: 50,\n    bottom: 50,\n    left: 50,\n  },\n  levels: 3, // how many levels or inner circles should there be drawn\n  maxValue: 0, // what is the value that the biggest circle will represent\n  lineFactor: 1.1, // how much farther than the radius of the outer circle should the lines be stretched\n  labelFactor: 1.15, // how much farther than the radius of the outer circle should the labels be placed\n  labelTextWrapWidth: 60, // the number of pixels after which a label needs to be given a new line\n  opacityArea: 0.35, // the opacity of the area of the blob\n  dotRadius: 4, // the size of the colored circles of each blog\n  opacityCircles: 0.1, // the opacity of the circles of each blob\n  strokeWidth: 2, // the width of the stroke around each blob\n  roundStrokes: false, // if true the area and stroke will follow a round path (cardinal-closed)\n  transitionDuration: 200,\n  color: d3.scaleOrdinal(d3.schemeCategory10),\n});\n\n/**\n * Creates a container for the radar chart.\n * @param container the chart container\n * @param config the chart configuration\n * @returns the object with the svg element and the g element\n */\nconst createContainer = (container: ElementRef<HTMLDivElement>, config: IRadarChartOptions) => {\n  const id = container.nativeElement.id ?? 'radar-0';\n\n  d3.select(`#${id}`).select('svg').remove();\n  const svg = d3\n    .select(`#${id}`)\n    .append('svg')\n    .attr('width', config.width + config.margin.left + config.margin.right)\n    .attr('height', config.height + config.margin.top + config.margin.bottom)\n    .attr('class', id);\n  const g = svg\n    .append('g')\n    .attr('transform', `translate(${config.width / 2 + config.margin.left},${config.height / 2 + config.margin.top})`);\n\n  return { svg, g };\n};\n\n/**\n * Draws the radar chart circular grid.\n * @param axisGrid the chart axis grid\n * @param radius the chart radius value\n * @param maxValue the maximum value of the chart axis\n * @param config the chart configuration\n */\nconst drawCircularGrid = (\n  axisGrid: d3.Selection<SVGGElement, unknown, HTMLElement, unknown>,\n  radius: number,\n  maxValue: number,\n  config: IRadarChartOptions,\n) => {\n  // background circles\n  axisGrid\n    .selectAll('.levels')\n    .data(d3.range(1, config.levels + 1).reverse())\n    .enter()\n    .append('circle')\n    .attr('class', 'grid-circle')\n    .attr('r', (d, i) => (radius / config.levels) * d)\n    .style('fill', '#CDCDCD')\n    .style('stroke', '#CDCDCD')\n    .style('fill-opacity', config.opacityCircles)\n    .style('filter', 'url(#glow)');\n  // text indicating at what % each level is\n  const axisGridX = 4;\n  axisGrid\n    .selectAll('.axis-label')\n    .data(d3.range(1, config.levels + 1).reverse())\n    .enter()\n    .append('text')\n    .attr('class', 'axis-label')\n    .attr('x', axisGridX)\n    .attr('y', d => (-d * radius) / config.levels)\n    .attr('dy', '0.4em')\n    .style('font-size', '10px')\n    .attr('fill', '#737373')\n    .text((d, i) => (maxValue * d) / config.levels);\n};\n\n/**\n * Wraps the chart axis labels text.\n * @param svgText the svg text elements\n * @param width the chart axis label width\n */\nconst wrapSvgText = (svgText: d3.Selection<SVGTextElement, string, SVGGElement, unknown>, width: number) => {\n  svgText.each(function (this: SVGTextElement) {\n    const text = d3.select<SVGElement, string>(this);\n    const words = text.text().split(/\\s+/).reverse();\n    if (words.length > 1) {\n      let line: string[] = [];\n      let lineNumber = 0;\n      const lineHeight = 1.4;\n      const y = text.attr('y');\n      const x = text.attr('x');\n      const dy = parseFloat(text.attr('dy') ?? 0);\n      let tspan = text.text(null).append('tspan').attr('x', x).attr('y', y).attr('dy', `${dy}em`);\n\n      let word = words.pop();\n\n      while (typeof word !== 'undefined') {\n        line.push(word ?? '');\n        tspan.text(line.join(' '));\n        if ((tspan.node()?.getComputedTextLength() ?? 0) > width) {\n          line.pop();\n          tspan.text(line.join(' '));\n          line = [word ?? ''];\n          lineNumber += 1;\n          tspan = text\n            .append('tspan')\n            .attr('x', x)\n            .attr('y', y)\n            .attr('dy', `${lineNumber * lineHeight + dy}em`)\n            .text(word ?? '');\n        }\n        word = words.pop();\n      }\n    }\n  });\n};\n\n/**\n * Creates the legend.\n * @param g the svg g element\n * @param config the chart configuration\n */\nconst createLegend = (g: d3.Selection<SVGGElement, unknown, HTMLElement, unknown>, config: IRadarChartOptions) => {\n  if (config.chartTitle !== '') {\n    g.append('g')\n      .attr('transform', `translate(-${config.width / 2 + config.margin.left / 2}, -${config.height / 2 + config.margin.top / 2})`)\n      .append('text')\n      .style('font-size', '12px')\n      .attr('class', 'legend')\n      .text(config.chartTitle);\n  }\n};\n\n/**\n * Draws the radar chart axis.\n * @param axisGrid the chart axis grid\n * @param axisNames the chart axis names\n * @param radiusScale the chart radius scale\n * @param maxValue the maximum value of the chart axis\n * @param angleSlice the chart angle slice value\n * @param config the chart configuration\n */\nconst drawAxis = (\n  axisGrid: d3.Selection<SVGGElement, unknown, HTMLElement, unknown>,\n  axisNames: string[],\n  radiusScale: d3.ScaleLinear<number, number>,\n  maxValue: number,\n  angleSlice: number,\n  config: IRadarChartOptions,\n) => {\n  // create the straight lines radiating outward from the center\n  const axis = axisGrid.selectAll('.axis').data(axisNames).enter().append('g').attr('class', 'axis');\n  // append the lines\n  axis\n    .append('line')\n    .attr('x1', 0)\n    .attr('y1', 0)\n    .attr('x2', (d, i) => radiusScale(maxValue * config.lineFactor) * Math.cos(angleSlice * i - Math.PI / 2))\n    .attr('y2', (d, i) => radiusScale(maxValue * config.lineFactor) * Math.sin(angleSlice * i - Math.PI / 2))\n    .attr('class', 'line')\n    .style('stroke', 'white')\n    .style('stroke-width', '2px');\n  // append the labels at each axis\n  axis\n    .append('text')\n    .attr('class', 'legend')\n    .style('font-size', '11px')\n    .attr('text-anchor', 'middle')\n    .attr('dy', '0.35em')\n    .attr('x', (d, i) => radiusScale(maxValue * config.labelFactor) * Math.cos(angleSlice * i - Math.PI / 2))\n    .attr('y', (d, i) => radiusScale(maxValue * config.labelFactor) * Math.sin(angleSlice * i - Math.PI / 2))\n    .text(d => d)\n    .call(wrapSvgText, config.labelTextWrapWidth);\n};\n\n/**\n * Draws the radar chart blobs.\n * @param radiusScale the chart radius scale\n * @param angleSlice the chart angle slice value\n * @param g the svg g element\n * @param data the chart data\n * @param config the chart configuration\n */\nconst drawRadarChartBlobs = (\n  radiusScale: d3.ScaleLinear<number, number>,\n  angleSlice: number,\n  g: d3.Selection<SVGGElement, unknown, HTMLElement, unknown>,\n  data: TRadarChartData,\n  config: IRadarChartOptions,\n) => {\n  // the radial line function\n  const radarLine = d3\n    .lineRadial<IRadarChartDataNode>()\n    .radius(d => radiusScale(d.value))\n    .angle((d, i) => i * angleSlice);\n  // create a wrapper for the blobs\n  const blobWrapper = g.selectAll('.radar-wrapper').data(data).enter().append('g').attr('class', 'radar-wrapper');\n  // append the backgrounds\n  blobWrapper\n    .append('path')\n    .attr('class', 'radar-area')\n    .attr('d', (d, i) => radarLine(d))\n    .style('fill', (d, i) => config.color(i.toString()))\n    .style('fill-opacity', config.opacityArea)\n    .on('mouseover', function (d, i) {\n      // dim all blobs\n      const radarAreaFillOpacity = 0.1;\n      d3.selectAll('.radar-area').transition().duration(config.transitionDuration).style('fill-opacity', radarAreaFillOpacity);\n      // bring back the hovered over blob\n      const fillOpacity = 0.7;\n      d3.select(this).transition().duration(config.transitionDuration).style('fill-opacity', fillOpacity);\n    })\n    .on('mouseout', () => {\n      // bring back all blobs\n      d3.selectAll('.radar-area').transition().duration(config.transitionDuration).style('fill-opacity', config.opacityArea);\n    });\n  // create the outlines\n  blobWrapper\n    .append('path')\n    .attr('class', 'radar-stroke')\n    .attr('d', (d, i) => radarLine(d))\n    .style('stroke-width', `${config.strokeWidth}px`)\n    .style('stroke', (d, i) => config.color(i.toString()))\n    .style('fill', 'none')\n    .style('filter', 'url(#glow)');\n  // append the circles\n  const blobWrapperFillOpacity = 0.8;\n  blobWrapper\n    .selectAll('.radar-circle')\n    .data((d, i) => d)\n    .enter()\n    .append('circle')\n    .attr('class', 'radar-circle')\n    .attr('r', config.dotRadius)\n    .attr('cx', (d, i) => radiusScale(d.value) * Math.cos(angleSlice * i - Math.PI / 2))\n    .attr('cy', (d, i) => radiusScale(d.value) * Math.sin(angleSlice * i - Math.PI / 2))\n    .style('fill', (d, i, j) => config.color(j.toString()))\n    .style('fill-opacity', blobWrapperFillOpacity);\n};\n\n/**\n * Appends the invisible tooltip circles.\n * @param g the svg g element\n * @param data the chart data\n * @param radiusScale the chart radius scale\n * @param angleSlice the chart angle slice value\n * @param config the chart configuration\n */\nconst appendInvisibleTooltipCircles = (\n  g: d3.Selection<SVGGElement, unknown, HTMLElement, unknown>,\n  data: TRadarChartData,\n  radiusScale: d3.ScaleLinear<number, number>,\n  angleSlice: number,\n  config: IRadarChartOptions,\n) => {\n  // wrapper for the invisible circles on top\n  const blobCircleWrapper = g.selectAll('.radar-circle-wrapper').data(data).enter().append('g').attr('class', 'radar-circle-wrapper');\n  // set up the small tooltip for when you hover over a circle\n  const tooltip = g.append('text').attr('class', 'chart-tooltip').style('opacity', 0);\n  // append a set of invisible circles on top for the mouseover pop-up\n  const blobCircleWrapperRadiusMultiplier = 1.5;\n  blobCircleWrapper\n    .selectAll<SVGElement, IRadarChartDataNode>('.radar-invisible-circle')\n    .data((d, i) => d)\n    .enter()\n    .append('circle')\n    .attr('class', 'radar-invisible-circle')\n    .attr('r', config.dotRadius * blobCircleWrapperRadiusMultiplier)\n    .attr('cx', (d, i) => radiusScale(d.value) * Math.cos(angleSlice * i - Math.PI / 2))\n    .attr('cy', (d, i) => radiusScale(d.value) * Math.sin(angleSlice * i - Math.PI / 2))\n    .style('fill', 'none')\n    .style('pointer-events', 'all')\n    .on('mouseover', function (event: MouseEvent, i) {\n      const modifier = 10;\n      const newX = parseFloat(d3.select(this).attr('cx')) - modifier;\n      const newY = parseFloat(d3.select(this).attr('cy')) - modifier;\n\n      const nodeData = (event.target as unknown as Record<string, IRadarChartDataNode>)['__data__'];\n      const tooltipText = `${nodeData.value} ${nodeData.unit}`;\n      tooltip.attr('x', newX).attr('y', newY).text(tooltipText).transition().duration(config.transitionDuration).style('opacity', 1);\n    })\n    .on('mouseout', () => {\n      tooltip.transition().duration(config.transitionDuration).style('opacity', 0);\n    });\n};\n\n/**\n * Draws the radar chart.\n * @param container the chart container\n * @param data the chart data\n * @param options the chart options\n * @returns the hart configuration\n */\nexport const drawRadarChart = (container: ElementRef<HTMLDivElement>, data: TRadarChartData, options?: Partial<IRadarChartOptions>) => {\n  const config: IRadarChartOptions = generateConfiguration<IRadarChartOptions>(defaultRadarChartConfig, options, {});\n\n  const maxValue = Math.max(config.maxValue, d3.max(data, i => d3.max(i.map(o => o.value))) ?? 0);\n  const axisNames = data[0].map((i, j) => i.axis);\n  const totalAxis = axisNames.length;\n  const radius = Math.min(config.width / 2 - config.margin.left / 2, config.height / 2 - config.margin.top / 2);\n  const angleSlice = (Math.PI * 2) / totalAxis;\n  const radiusScale = d3.scaleLinear([0, radius]).domain([0, maxValue]);\n\n  const { g } = createContainer(container, config);\n\n  // filter for the outside glow\n  const filter = g.append('defs').append('filter').attr('id', 'glow');\n  filter.append('feGaussianBlur').attr('stdDeviation', '2.5').attr('result', 'coloredBlur');\n  const feMerge = filter.append('feMerge');\n  feMerge.append('feMergeNode').attr('in', 'coloredBlur');\n  feMerge.append('feMergeNode').attr('in', 'SourceGraphic');\n\n  const axisGrid = g.append('g').attr('class', 'axis-wrapper');\n\n  drawCircularGrid(axisGrid, radius, maxValue, config);\n\n  drawAxis(axisGrid, axisNames, radiusScale, maxValue, angleSlice, config);\n\n  createLegend(g, config);\n\n  drawRadarChartBlobs(radiusScale, angleSlice, g, data, config);\n\n  appendInvisibleTooltipCircles(g, data, radiusScale, angleSlice, config);\n\n  return config;\n};\n"]}
|
|
307
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radar-chart.util.js","sourceRoot":"","sources":["../../../../../../libs/client-d3-charts/src/lib/util/radar-chart.util.ts"],"names":[],"mappings":"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","sourcesContent":["import { ElementRef } from '@angular/core';\nimport * as d3 from 'd3';\n\nimport { IRadarChartDataNode, IRadarChartOptions, TRadarChartData } from '../interfaces/radar-chart.interface';\nimport { generateConfiguration } from './configuration.util';\n\n/**\n * The radar chart default configuration.\n */\nexport const defaultRadarChartConfig: IRadarChartOptions = Object.freeze(<IRadarChartOptions>{\n  chartTitle: '',\n  width: 350,\n  height: 350,\n  margin: {\n    top: 50,\n    right: 50,\n    bottom: 50,\n    left: 50,\n  },\n  levels: 3, // how many levels or inner circles should there be drawn\n  maxValue: 0, // what is the value that the biggest circle will represent\n  lineFactor: 1.1, // how much farther than the radius of the outer circle should the lines be stretched\n  labelFactor: 1.15, // how much farther than the radius of the outer circle should the labels be placed\n  labelTextWrapWidth: 60, // the number of pixels after which a label needs to be given a new line\n  opacityArea: 0.35, // the opacity of the area of the blob\n  dotRadius: 4, // the size of the colored circles of each blog\n  opacityCircles: 0.1, // the opacity of the circles of each blob\n  strokeWidth: 2, // the width of the stroke around each blob\n  roundStrokes: false, // if true the area and stroke will follow a round path (cardinal-closed)\n  transitionDuration: 200,\n  color: d3.scaleOrdinal(d3.schemeCategory10),\n});\n\n/**\n * Creates a container for the radar chart.\n * @param container the chart container\n * @param config the chart configuration\n * @returns the object with the svg element and the g element\n */\nconst createContainer = (container: ElementRef<HTMLDivElement>, config: IRadarChartOptions) => {\n  const id = container.nativeElement.id ?? 'radar-0';\n\n  d3.select(`#${id}`).select('svg').remove();\n  const svg = d3\n    .select(`#${id}`)\n    .append('svg')\n    .attr('width', config.width + config.margin.left + config.margin.right)\n    .attr('height', config.height + config.margin.top + config.margin.bottom)\n    .attr('class', id);\n  const g = svg\n    .append('g')\n    .attr('transform', `translate(${config.width / 2 + config.margin.left},${config.height / 2 + config.margin.top})`);\n\n  return { svg, g };\n};\n\n/**\n * Draws the radar chart circular grid.\n * @param axisGrid the chart axis grid\n * @param radius the chart radius value\n * @param maxValue the maximum value of the chart axis\n * @param config the chart configuration\n */\nconst drawCircularGrid = (\n  axisGrid: d3.Selection<SVGGElement, unknown, HTMLElement, unknown>,\n  radius: number,\n  maxValue: number,\n  config: IRadarChartOptions,\n) => {\n  // background circles\n  axisGrid\n    .selectAll('.levels')\n    .data(d3.range(1, config.levels + 1).reverse())\n    .enter()\n    .append('circle')\n    .attr('class', 'grid-circle')\n    .attr('r', (d, i) => (radius / config.levels) * d)\n    .style('fill', '#CDCDCD')\n    .style('stroke', '#CDCDCD')\n    .style('fill-opacity', config.opacityCircles)\n    .style('filter', 'url(#glow)');\n  // text indicating at what % each level is\n  const axisGridX = 4;\n  axisGrid\n    .selectAll('.axis-label')\n    .data(d3.range(1, config.levels + 1).reverse())\n    .enter()\n    .append('text')\n    .attr('class', 'axis-label')\n    .attr('x', axisGridX)\n    .attr('y', d => (-d * radius) / config.levels)\n    .attr('dy', '0.4em')\n    .style('font-size', '10px')\n    .attr('fill', '#737373')\n    .text((d, i) => (maxValue * d) / config.levels);\n};\n\n/**\n * Wraps the chart axis labels text.\n * @param svgText the svg text elements\n * @param width the chart axis label width\n */\nconst wrapSvgText = (svgText: d3.Selection<SVGTextElement, string, SVGGElement, unknown>, width: number) => {\n  svgText.each(function (this: SVGTextElement) {\n    const text = d3.select<SVGElement, string>(this);\n    const words = text.text().split(/\\s+/).reverse();\n    if (words.length > 1) {\n      let line: string[] = [];\n      let lineNumber = 0;\n      const lineHeight = 1.4;\n      const y = text.attr('y');\n      const x = text.attr('x');\n      const dy = parseFloat(text.attr('dy') ?? 0);\n      let tspan = text.text(null).append('tspan').attr('x', x).attr('y', y).attr('dy', `${dy}em`);\n\n      let word = words.pop();\n\n      while (typeof word !== 'undefined') {\n        line.push(word ?? '');\n        tspan.text(line.join(' '));\n        if ((tspan.node()?.getComputedTextLength() ?? 0) > width) {\n          line.pop();\n          tspan.text(line.join(' '));\n          line = [word ?? ''];\n          lineNumber += 1;\n          tspan = text\n            .append('tspan')\n            .attr('x', x)\n            .attr('y', y)\n            .attr('dy', `${lineNumber * lineHeight + dy}em`)\n            .text(word ?? '');\n        }\n        word = words.pop();\n      }\n    }\n  });\n};\n\n/**\n * Creates the legend.\n * @param g the svg g element\n * @param config the chart configuration\n */\nconst createLegend = (g: d3.Selection<SVGGElement, unknown, HTMLElement, unknown>, config: IRadarChartOptions) => {\n  if (config.chartTitle !== '') {\n    g.append('g')\n      .attr('transform', `translate(-${config.width / 2 + config.margin.left / 2}, -${config.height / 2 + config.margin.top / 2})`)\n      .append('text')\n      .style('font-size', '12px')\n      .attr('class', 'legend')\n      .text(config.chartTitle);\n  }\n};\n\n/**\n * Draws the radar chart axis.\n * @param axisGrid the chart axis grid\n * @param axisNames the chart axis names\n * @param radiusScale the chart radius scale\n * @param maxValue the maximum value of the chart axis\n * @param angleSlice the chart angle slice value\n * @param config the chart configuration\n */\nconst drawAxis = (\n  axisGrid: d3.Selection<SVGGElement, unknown, HTMLElement, unknown>,\n  axisNames: string[],\n  radiusScale: d3.ScaleLinear<number, number>,\n  maxValue: number,\n  angleSlice: number,\n  config: IRadarChartOptions,\n) => {\n  // create the straight lines radiating outward from the center\n  const axis = axisGrid.selectAll('.axis').data(axisNames).enter().append('g').attr('class', 'axis');\n  // append the lines\n  axis\n    .append('line')\n    .attr('x1', 0)\n    .attr('y1', 0)\n    .attr('x2', (d, i) => radiusScale(maxValue * config.lineFactor) * Math.cos(angleSlice * i - Math.PI / 2))\n    .attr('y2', (d, i) => radiusScale(maxValue * config.lineFactor) * Math.sin(angleSlice * i - Math.PI / 2))\n    .attr('class', 'line')\n    .style('stroke', 'white')\n    .style('stroke-width', '2px');\n  // append the labels at each axis\n  axis\n    .append('text')\n    .attr('class', 'legend')\n    .style('font-size', '11px')\n    .attr('text-anchor', 'middle')\n    .attr('dy', '0.35em')\n    .attr('x', (d, i) => radiusScale(maxValue * config.labelFactor) * Math.cos(angleSlice * i - Math.PI / 2))\n    .attr('y', (d, i) => radiusScale(maxValue * config.labelFactor) * Math.sin(angleSlice * i - Math.PI / 2))\n    .text(d => d)\n    .call(wrapSvgText, config.labelTextWrapWidth);\n};\n\n/**\n * Draws the radar chart blobs.\n * @param radiusScale the chart radius scale\n * @param angleSlice the chart angle slice value\n * @param g the svg g element\n * @param data the chart data\n * @param config the chart configuration\n */\nconst drawRadarChartBlobs = (\n  radiusScale: d3.ScaleLinear<number, number>,\n  angleSlice: number,\n  g: d3.Selection<SVGGElement, unknown, HTMLElement, unknown>,\n  data: TRadarChartData,\n  config: IRadarChartOptions,\n) => {\n  // the radial line function\n  const radarLine = d3\n    .lineRadial<IRadarChartDataNode>()\n    .radius(d => radiusScale(d.value))\n    .angle((d, i) => i * angleSlice);\n  // create a wrapper for the blobs\n  const blobWrapper = g.selectAll('.radar-wrapper').data(data).enter().append('g').attr('class', 'radar-wrapper');\n  // append the backgrounds\n  blobWrapper\n    .append('path')\n    .attr('class', 'radar-area')\n    .attr('d', (d, i) => radarLine(d))\n    .style('fill', (d, i) => config.color(i.toString()))\n    .style('fill-opacity', config.opacityArea)\n    .on('mouseover', function (d, i) {\n      // dim all blobs\n      const radarAreaFillOpacity = 0.1;\n      d3.selectAll('.radar-area').transition().duration(config.transitionDuration).style('fill-opacity', radarAreaFillOpacity);\n      // bring back the hovered over blob\n      const fillOpacity = 0.7;\n      d3.select(this).transition().duration(config.transitionDuration).style('fill-opacity', fillOpacity);\n    })\n    .on('mouseout', () => {\n      // bring back all blobs\n      d3.selectAll('.radar-area').transition().duration(config.transitionDuration).style('fill-opacity', config.opacityArea);\n    });\n  // create the outlines\n  blobWrapper\n    .append('path')\n    .attr('class', 'radar-stroke')\n    .attr('d', (d, i) => radarLine(d))\n    .style('stroke-width', `${config.strokeWidth}px`)\n    .style('stroke', (d, i) => config.color(i.toString()))\n    .style('fill', 'none')\n    .style('filter', 'url(#glow)');\n  // append the circles\n  const blobWrapperFillOpacity = 0.8;\n  blobWrapper\n    .selectAll('.radar-circle')\n    .data((d, i) => d)\n    .enter()\n    .append('circle')\n    .attr('class', 'radar-circle')\n    .attr('r', config.dotRadius)\n    .attr('cx', (d, i) => radiusScale(d.value) * Math.cos(angleSlice * i - Math.PI / 2))\n    .attr('cy', (d, i) => radiusScale(d.value) * Math.sin(angleSlice * i - Math.PI / 2))\n    .style('fill', (d, i, j) => config.color(j.toString()))\n    .style('fill-opacity', blobWrapperFillOpacity);\n};\n\n/**\n * Appends the invisible tooltip circles.\n * @param g the svg g element\n * @param data the chart data\n * @param radiusScale the chart radius scale\n * @param angleSlice the chart angle slice value\n * @param config the chart configuration\n */\nconst appendInvisibleTooltipCircles = (\n  g: d3.Selection<SVGGElement, unknown, HTMLElement, unknown>,\n  data: TRadarChartData,\n  radiusScale: d3.ScaleLinear<number, number>,\n  angleSlice: number,\n  config: IRadarChartOptions,\n) => {\n  // wrapper for the invisible circles on top\n  const blobCircleWrapper = g.selectAll('.radar-circle-wrapper').data(data).enter().append('g').attr('class', 'radar-circle-wrapper');\n  // append a set of invisible circles on top for the mouseover pop-up\n  const blobCircleWrapperRadiusMultiplier = 1.5;\n  blobCircleWrapper\n    .selectAll<SVGElement, IRadarChartDataNode>('.radar-invisible-circle')\n    .data((d, i) => d)\n    .enter()\n    .append('circle')\n    .attr('class', 'radar-invisible-circle')\n    .attr('r', config.dotRadius * blobCircleWrapperRadiusMultiplier)\n    .attr('cx', (d, i) => radiusScale(d.value) * Math.cos(angleSlice * i - Math.PI / 2))\n    .attr('cy', (d, i) => radiusScale(d.value) * Math.sin(angleSlice * i - Math.PI / 2))\n    .style('fill', 'none')\n    .style('pointer-events', 'all')\n    .on('mouseover', function (event: MouseEvent, i) {\n      const modifier = 10;\n      const newX = parseFloat(d3.select(this).attr('cx')) - modifier;\n      const newY = parseFloat(d3.select(this).attr('cy')) - modifier;\n\n      const nodeData = (event.target as unknown as Record<string, IRadarChartDataNode>)['__data__'];\n      const tooltipText = `${nodeData.value} ${nodeData.unit}`;\n      g.append('text')\n        .attr('class', 'chart-tooltip')\n        .style('opacity', 0)\n        .attr('x', newX)\n        .attr('y', newY)\n        .text(tooltipText)\n        .transition()\n        .duration(config.transitionDuration)\n        .style('opacity', 1);\n    })\n    .on('mouseout', () => {\n      d3.selectAll('.chart-tooltip')\n        .transition()\n        .duration(config.transitionDuration / 2)\n        .style('opacity', 0)\n        .remove();\n    });\n};\n\n/**\n * Draws the radar chart.\n * @param container the chart container\n * @param data the chart data\n * @param options the chart options\n * @returns the hart configuration\n */\nexport const drawRadarChart = (container: ElementRef<HTMLDivElement>, data: TRadarChartData, options?: Partial<IRadarChartOptions>) => {\n  const config: IRadarChartOptions = generateConfiguration<IRadarChartOptions>(defaultRadarChartConfig, options, {});\n\n  const maxValue = Math.max(config.maxValue, d3.max(data, i => d3.max(i.map(o => o.value))) ?? 0);\n  const axisNames = data[0].map((i, j) => i.axis);\n  const totalAxis = axisNames.length;\n  const radius = Math.min(config.width / 2 - config.margin.left / 2, config.height / 2 - config.margin.top / 2);\n  const angleSlice = (Math.PI * 2) / totalAxis;\n  const radiusScale = d3.scaleLinear([0, radius]).domain([0, maxValue]);\n\n  const { g } = createContainer(container, config);\n\n  // filter for the outside glow\n  const filter = g.append('defs').append('filter').attr('id', 'glow');\n  filter.append('feGaussianBlur').attr('stdDeviation', '2.5').attr('result', 'coloredBlur');\n  const feMerge = filter.append('feMerge');\n  feMerge.append('feMergeNode').attr('in', 'coloredBlur');\n  feMerge.append('feMergeNode').attr('in', 'SourceGraphic');\n\n  const axisGrid = g.append('g').attr('class', 'axis-wrapper');\n\n  drawCircularGrid(axisGrid, radius, maxValue, config);\n\n  drawAxis(axisGrid, axisNames, radiusScale, maxValue, angleSlice, config);\n\n  createLegend(g, config);\n\n  drawRadarChartBlobs(radiusScale, angleSlice, g, data, config);\n\n  appendInvisibleTooltipCircles(g, data, radiusScale, angleSlice, config);\n\n  return config;\n};\n"]}
|
|
@@ -754,7 +754,10 @@ const onMouseOver = (self, d, g, config) => {
|
|
|
754
754
|
.style('font-size', '11px')
|
|
755
755
|
.attr('dx', () => (config.width - config.margin.left - config.margin.right) / tooltipShift)
|
|
756
756
|
.attr('dy', () => tooltipDy)
|
|
757
|
-
.text(() => `${d.value} (${new Date(d.timestamp).toUTCString()})`)
|
|
757
|
+
.text(() => `${d.value} (${new Date(d.timestamp).toUTCString()})`)
|
|
758
|
+
.transition()
|
|
759
|
+
.duration(config.transitionDuration)
|
|
760
|
+
.style('opacity', 1);
|
|
758
761
|
};
|
|
759
762
|
/**
|
|
760
763
|
* The mouse out event handler.
|
|
@@ -765,7 +768,11 @@ const onMouseOut = (self, config) => {
|
|
|
765
768
|
const duration = 400;
|
|
766
769
|
d3.select(self).attr('class', 'dot');
|
|
767
770
|
d3.select(self).transition().duration(duration).attr('r', config.dotRadius);
|
|
768
|
-
d3.selectAll('.chart-tooltip')
|
|
771
|
+
d3.selectAll('.chart-tooltip')
|
|
772
|
+
.transition()
|
|
773
|
+
.duration(config.transitionDuration / 2)
|
|
774
|
+
.style('opacity', 0)
|
|
775
|
+
.remove();
|
|
769
776
|
};
|
|
770
777
|
/**
|
|
771
778
|
* Draws the chart lines, dots, and sets the mouse pointer events.
|
|
@@ -903,7 +910,6 @@ const drawPieChart = (container, data, options) => {
|
|
|
903
910
|
const pie = d3.pie().value(datum => datum.y);
|
|
904
911
|
const radius = Math.min(config.width, config.height) / 2;
|
|
905
912
|
const arc = d3.arc().innerRadius(config.innerRadius).outerRadius(radius);
|
|
906
|
-
const tooltip = g.append('text').attr('class', 'chart-tooltip').style('opacity', 0);
|
|
907
913
|
const arcs = g
|
|
908
914
|
.selectAll('arc')
|
|
909
915
|
.data(pie(data))
|
|
@@ -912,16 +918,12 @@ const drawPieChart = (container, data, options) => {
|
|
|
912
918
|
.attr('class', 'arc')
|
|
913
919
|
.on('mouseover', function (event, d) {
|
|
914
920
|
this.style.opacity = '0.8';
|
|
915
|
-
const modifier = 10;
|
|
916
|
-
const x = parseFloat(d3.select(this).attr('cx')) - modifier;
|
|
917
|
-
const y = parseFloat(d3.select(this).attr('cy')) - modifier;
|
|
918
921
|
const tooltipText = `${d.data.key}: ${d.data.y}`;
|
|
919
|
-
|
|
922
|
+
g.append('text')
|
|
920
923
|
.attr('class', 'chart-tooltip')
|
|
921
|
-
.
|
|
922
|
-
.attr('y', y)
|
|
924
|
+
.style('opacity', 0)
|
|
923
925
|
.attr('dx', -config.width / (2 * 2 * 2))
|
|
924
|
-
.attr('dy',
|
|
926
|
+
.attr('dy', config.height / 2 + config.margin.top)
|
|
925
927
|
.text(tooltipText)
|
|
926
928
|
.transition()
|
|
927
929
|
.duration(config.transitionDuration)
|
|
@@ -929,7 +931,11 @@ const drawPieChart = (container, data, options) => {
|
|
|
929
931
|
})
|
|
930
932
|
.on('mouseout', function (event, d) {
|
|
931
933
|
this.style.opacity = 'unset';
|
|
932
|
-
|
|
934
|
+
d3.selectAll('.chart-tooltip')
|
|
935
|
+
.transition()
|
|
936
|
+
.duration(config.transitionDuration / 2)
|
|
937
|
+
.style('opacity', 0)
|
|
938
|
+
.remove();
|
|
933
939
|
});
|
|
934
940
|
arcs
|
|
935
941
|
.append('path')
|
|
@@ -947,6 +953,7 @@ const drawPieChart = (container, data, options) => {
|
|
|
947
953
|
.attr('text-anchor', 'middle')
|
|
948
954
|
.attr('dy', textDy)
|
|
949
955
|
.attr('transform', d => `translate(${label.centroid(d)})`)
|
|
956
|
+
.style('font-size', '12px')
|
|
950
957
|
.text(d => d.data.y);
|
|
951
958
|
}
|
|
952
959
|
return config;
|
|
@@ -1189,8 +1196,6 @@ const drawRadarChartBlobs = (radiusScale, angleSlice, g, data, config) => {
|
|
|
1189
1196
|
const appendInvisibleTooltipCircles = (g, data, radiusScale, angleSlice, config) => {
|
|
1190
1197
|
// wrapper for the invisible circles on top
|
|
1191
1198
|
const blobCircleWrapper = g.selectAll('.radar-circle-wrapper').data(data).enter().append('g').attr('class', 'radar-circle-wrapper');
|
|
1192
|
-
// set up the small tooltip for when you hover over a circle
|
|
1193
|
-
const tooltip = g.append('text').attr('class', 'chart-tooltip').style('opacity', 0);
|
|
1194
1199
|
// append a set of invisible circles on top for the mouseover pop-up
|
|
1195
1200
|
const blobCircleWrapperRadiusMultiplier = 1.5;
|
|
1196
1201
|
blobCircleWrapper
|
|
@@ -1210,10 +1215,22 @@ const appendInvisibleTooltipCircles = (g, data, radiusScale, angleSlice, config)
|
|
|
1210
1215
|
const newY = parseFloat(d3.select(this).attr('cy')) - modifier;
|
|
1211
1216
|
const nodeData = event.target['__data__'];
|
|
1212
1217
|
const tooltipText = `${nodeData.value} ${nodeData.unit}`;
|
|
1213
|
-
|
|
1218
|
+
g.append('text')
|
|
1219
|
+
.attr('class', 'chart-tooltip')
|
|
1220
|
+
.style('opacity', 0)
|
|
1221
|
+
.attr('x', newX)
|
|
1222
|
+
.attr('y', newY)
|
|
1223
|
+
.text(tooltipText)
|
|
1224
|
+
.transition()
|
|
1225
|
+
.duration(config.transitionDuration)
|
|
1226
|
+
.style('opacity', 1);
|
|
1214
1227
|
})
|
|
1215
1228
|
.on('mouseout', () => {
|
|
1216
|
-
|
|
1229
|
+
d3.selectAll('.chart-tooltip')
|
|
1230
|
+
.transition()
|
|
1231
|
+
.duration(config.transitionDuration / 2)
|
|
1232
|
+
.style('opacity', 0)
|
|
1233
|
+
.remove();
|
|
1217
1234
|
});
|
|
1218
1235
|
};
|
|
1219
1236
|
/**
|
|
@@ -1318,10 +1335,10 @@ class AppBarChartComponent {
|
|
|
1318
1335
|
this.drawChart();
|
|
1319
1336
|
}
|
|
1320
1337
|
}
|
|
1321
|
-
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.
|
|
1322
|
-
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.
|
|
1338
|
+
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: AppBarChartComponent, deps: [{ token: DOCUMENT }, { token: D3_CHART_FACTORY }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
1339
|
+
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.1", type: AppBarChartComponent, selector: "app-bar-chart", inputs: { chartId: "chartId", data: "data", options: "options" }, viewQueries: [{ propertyName: "container", first: true, predicate: ["container"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"container\" id=\"{{ chartId }}\" #container></div>\n", styles: [":host{display:flex;flex-direction:row;flex-wrap:nowrap;justify-content:center}:host .container{flex:0 1 auto}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
1323
1340
|
}
|
|
1324
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.
|
|
1341
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: AppBarChartComponent, decorators: [{
|
|
1325
1342
|
type: Component,
|
|
1326
1343
|
args: [{ selector: 'app-bar-chart', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"container\" id=\"{{ chartId }}\" #container></div>\n", styles: [":host{display:flex;flex-direction:row;flex-wrap:nowrap;justify-content:center}:host .container{flex:0 1 auto}\n"] }]
|
|
1327
1344
|
}], ctorParameters: function () { return [{ type: Document, decorators: [{
|
|
@@ -1404,10 +1421,10 @@ class AppPieChartComponent {
|
|
|
1404
1421
|
this.drawChart();
|
|
1405
1422
|
}
|
|
1406
1423
|
}
|
|
1407
|
-
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.
|
|
1408
|
-
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.
|
|
1424
|
+
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: AppPieChartComponent, deps: [{ token: DOCUMENT }, { token: D3_CHART_FACTORY }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
1425
|
+
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.1", type: AppPieChartComponent, selector: "app-pie-chart", inputs: { chartId: "chartId", data: "data", options: "options" }, viewQueries: [{ propertyName: "container", first: true, predicate: ["container"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"container\">\n <div id=\"{{ chartId }}\" #container></div>\n\n <small class=\"container--chart-title\">{{ options.chartTitle }}</small>\n</div>\n", styles: [":host{display:flex;flex-direction:row;flex-wrap:nowrap;justify-content:center}:host canvas{width:auto!important;height:150px}:host .container{flex:0 1 auto}:host .container--chart-title{display:block;text-align:center}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
1409
1426
|
}
|
|
1410
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.
|
|
1427
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: AppPieChartComponent, decorators: [{
|
|
1411
1428
|
type: Component,
|
|
1412
1429
|
args: [{ selector: 'app-pie-chart', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"container\">\n <div id=\"{{ chartId }}\" #container></div>\n\n <small class=\"container--chart-title\">{{ options.chartTitle }}</small>\n</div>\n", styles: [":host{display:flex;flex-direction:row;flex-wrap:nowrap;justify-content:center}:host canvas{width:auto!important;height:150px}:host .container{flex:0 1 auto}:host .container--chart-title{display:block;text-align:center}\n"] }]
|
|
1413
1430
|
}], ctorParameters: function () { return [{ type: Document, decorators: [{
|
|
@@ -1501,10 +1518,10 @@ class AppRadarChartComponent {
|
|
|
1501
1518
|
this.drawChart();
|
|
1502
1519
|
}
|
|
1503
1520
|
}
|
|
1504
|
-
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.
|
|
1505
|
-
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.
|
|
1521
|
+
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: AppRadarChartComponent, deps: [{ token: DOCUMENT }, { token: D3_CHART_FACTORY }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
1522
|
+
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.1", type: AppRadarChartComponent, selector: "app-radar-chart", inputs: { chartId: "chartId", data: "data", options: "options" }, viewQueries: [{ propertyName: "container", first: true, predicate: ["container"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"container\" id=\"{{ chartId }}\" #container></div>\n", styles: [":host{display:flex;flex-direction:row;flex-wrap:nowrap;justify-content:center}:host .container{flex:0 1 auto}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
1506
1523
|
}
|
|
1507
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.
|
|
1524
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: AppRadarChartComponent, decorators: [{
|
|
1508
1525
|
type: Component,
|
|
1509
1526
|
args: [{ selector: 'app-radar-chart', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"container\" id=\"{{ chartId }}\" #container></div>\n", styles: [":host{display:flex;flex-direction:row;flex-wrap:nowrap;justify-content:center}:host .container{flex:0 1 auto}\n"] }]
|
|
1510
1527
|
}], ctorParameters: function () { return [{ type: Document, decorators: [{
|
|
@@ -1589,10 +1606,10 @@ class AppForceDirectedChartComponent {
|
|
|
1589
1606
|
this.drawChart();
|
|
1590
1607
|
}
|
|
1591
1608
|
}
|
|
1592
|
-
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.
|
|
1593
|
-
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.
|
|
1609
|
+
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: AppForceDirectedChartComponent, deps: [{ token: DOCUMENT }, { token: D3_CHART_FACTORY }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
1610
|
+
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.1", type: AppForceDirectedChartComponent, selector: "app-force-directed-chart", inputs: { chartId: "chartId", data: "data", options: "options" }, viewQueries: [{ propertyName: "container", first: true, predicate: ["container"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"container\">\n <div id=\"{{ chartId }}\" #container></div>\n\n <small class=\"container--chart-title\">{{ options.chartTitle }}</small>\n</div>\n", styles: [":host{display:flex;flex-direction:row;flex-wrap:nowrap;justify-content:center}:host .container{flex:0 1 auto}:host .container--chart-title{display:block;text-align:center}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
1594
1611
|
}
|
|
1595
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.
|
|
1612
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: AppForceDirectedChartComponent, decorators: [{
|
|
1596
1613
|
type: Component,
|
|
1597
1614
|
args: [{ selector: 'app-force-directed-chart', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"container\">\n <div id=\"{{ chartId }}\" #container></div>\n\n <small class=\"container--chart-title\">{{ options.chartTitle }}</small>\n</div>\n", styles: [":host{display:flex;flex-direction:row;flex-wrap:nowrap;justify-content:center}:host .container{flex:0 1 auto}:host .container--chart-title{display:block;text-align:center}\n"] }]
|
|
1598
1615
|
}], ctorParameters: function () { return [{ type: Document, decorators: [{
|
|
@@ -1676,10 +1693,10 @@ class AppLineChartComponent {
|
|
|
1676
1693
|
this.drawChart();
|
|
1677
1694
|
}
|
|
1678
1695
|
}
|
|
1679
|
-
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.
|
|
1680
|
-
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.
|
|
1696
|
+
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: AppLineChartComponent, deps: [{ token: DOCUMENT }, { token: D3_CHART_FACTORY }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
1697
|
+
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.1", type: AppLineChartComponent, selector: "app-line-chart", inputs: { chartId: "chartId", data: "data", options: "options" }, viewQueries: [{ propertyName: "container", first: true, predicate: ["container"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"container\" id=\"{{ chartId }}\" #container></div>\n", styles: [":host{display:flex;flex-direction:row;flex-wrap:nowrap;justify-content:center}:host .container{flex:0 1 auto}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
1681
1698
|
}
|
|
1682
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.
|
|
1699
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: AppLineChartComponent, decorators: [{
|
|
1683
1700
|
type: Component,
|
|
1684
1701
|
args: [{ selector: 'app-line-chart', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"container\" id=\"{{ chartId }}\" #container></div>\n", styles: [":host{display:flex;flex-direction:row;flex-wrap:nowrap;justify-content:center}:host .container{flex:0 1 auto}\n"] }]
|
|
1685
1702
|
}], ctorParameters: function () { return [{ type: Document, decorators: [{
|
|
@@ -1907,17 +1924,17 @@ class AppChartExamplesComponent {
|
|
|
1907
1924
|
chartTitle: 'Example force directed chart',
|
|
1908
1925
|
};
|
|
1909
1926
|
}
|
|
1910
|
-
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.
|
|
1911
|
-
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.
|
|
1927
|
+
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: AppChartExamplesComponent, deps: [{ token: i1.BreakpointObserver }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
1928
|
+
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.1", type: AppChartExamplesComponent, selector: "app-chart-examples", ngImport: i0, template: "<div class=\"container\" *ngIf=\"barChartConfig$ | async as config\">\n <app-bar-chart [chartId]=\"'bar-example-1'\" [data]=\"config.data\" [options]=\"config.options\"></app-bar-chart>\n</div>\n\n<hr [ngStyle]=\"{ width: '100%' }\" />\n\n<div class=\"container\" *ngIf=\"lineChartConfig$ | async as config\">\n <app-line-chart [chartId]=\"'line-example-1'\" [data]=\"[config.data[0]]\" [options]=\"config.options\"></app-line-chart>\n\n <app-line-chart [chartId]=\"'line-example-2'\" [data]=\"[config.data[1]]\" [options]=\"config.optionsDateDdMmYy\"></app-line-chart>\n\n <app-line-chart\n [chartId]=\"'line-example-3'\"\n [data]=\"[config.data[1], config.data[2]]\"\n [options]=\"config.optionsDateDdMmYyyy\"\n ></app-line-chart>\n\n <app-line-chart [chartId]=\"'line-example-4'\" [data]=\"config.data\" [options]=\"config.optionsDateMmYyyy\"></app-line-chart>\n</div>\n\n<hr [ngStyle]=\"{ width: '100%' }\" />\n\n<div class=\"container\" *ngIf=\"radarChartConfig$ | async as config\">\n <app-radar-chart [chartId]=\"'radar-example-1'\" [data]=\"config.data\" [options]=\"config.options\"></app-radar-chart>\n</div>\n\n<hr [ngStyle]=\"{ width: '100%' }\" />\n\n<div class=\"container\" *ngIf=\"pieChartConfig$ | async as config\">\n <app-pie-chart [chartId]=\"'pie-example-1'\" [data]=\"config.data\" [options]=\"config.options\"></app-pie-chart>\n</div>\n\n<hr [ngStyle]=\"{ width: '100%' }\" />\n\n<div class=\"container\" *ngIf=\"forceDirectedChartConfig$ | async as config\">\n <app-force-directed-chart\n [chartId]=\"'force-directed-example-1'\"\n [data]=\"config.data\"\n [options]=\"config.options\"\n ></app-force-directed-chart>\n</div>\n", styles: [":host{display:flex;flex-direction:row;flex-wrap:wrap;justify-content:center}:host .container{display:flex;flex:1 1 auto;flex-wrap:wrap;width:100%}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: AppPieChartComponent, selector: "app-pie-chart", inputs: ["chartId", "data", "options"] }, { kind: "component", type: AppRadarChartComponent, selector: "app-radar-chart", inputs: ["chartId", "data", "options"] }, { kind: "component", type: AppForceDirectedChartComponent, selector: "app-force-directed-chart", inputs: ["chartId", "data", "options"] }, { kind: "component", type: AppBarChartComponent, selector: "app-bar-chart", inputs: ["chartId", "data", "options"] }, { kind: "component", type: AppLineChartComponent, selector: "app-line-chart", inputs: ["chartId", "data", "options"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
1912
1929
|
}
|
|
1913
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.
|
|
1930
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: AppChartExamplesComponent, decorators: [{
|
|
1914
1931
|
type: Component,
|
|
1915
|
-
args: [{ selector: 'app-chart-examples', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"container\" *ngIf=\"barChartConfig$ | async as config\">\n <app-bar-chart [chartId]=\"'bar-example-1'\" [data]=\"config.data\" [options]=\"config.options\"></app-bar-chart>\n</div>\n\n<hr [ngStyle]=\"{ width: '100%' }\" />\n\n<div class=\"container\" *ngIf=\"lineChartConfig$ | async as config\">\n <app-line-chart [chartId]=\"'line-example-1'\" [data]=\"[config.data[0]]\" [options]=\"config.options\"></app-line-chart>\n\n <app-line-chart [chartId]=\"'line-example-2'\" [data]=\"[config.data[1]]\" [options]=\"config.optionsDateDdMmYy\"></app-line-chart>\n\n <app-line-chart\n [chartId]=\"'line-example-3'\"\n [data]=\"[config.data[1], config.data[2]]\"\n [options]=\"config.optionsDateDdMmYyyy\"\n ></app-line-chart>\n\n <app-line-chart [chartId]=\"'line-example-4'\" [data]=\"config.data\" [options]=\"config.optionsDateMmYyyy\"></app-line-chart>\n</div>\n\n<hr [ngStyle]=\"{ width: '100%' }\" />\n\n<div class=\"container\" *ngIf=\"radarChartConfig$ | async as config\">\n <app-radar-chart [chartId]=\"'radar-example-1'\" [data]=\"config.data\" [options]=\"config.options\"></app-radar-chart>\n</div>\n\n<hr [ngStyle]=\"{ width: '100%' }\" />\n\n<div class=\"container\" *ngIf=\"pieChartConfig$ | async as config\">\n <app-pie-chart [chartId]=\"'pie-example-1'\" [data]=\"config.data\" [options]=\"config.options\"></app-pie-chart>\n</div>\n\n<hr [ngStyle]=\"{ width: '100%' }\" />\n\n<div class=\"container\" *ngIf=\"forceDirectedChartConfig$ | async as config\">\n <app-force-directed-chart\n [chartId]=\"'force-directed-example-1'\"\n [data]=\"config.data\"\n [options]=\"config.options\"\n ></app-force-directed-chart>\n</div>\n", styles: [":host{display:flex;flex-direction:row;flex-wrap:wrap;justify-content:center}:host .container{display:flex;flex:1 1 auto;width:100%}\n"] }]
|
|
1932
|
+
args: [{ selector: 'app-chart-examples', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"container\" *ngIf=\"barChartConfig$ | async as config\">\n <app-bar-chart [chartId]=\"'bar-example-1'\" [data]=\"config.data\" [options]=\"config.options\"></app-bar-chart>\n</div>\n\n<hr [ngStyle]=\"{ width: '100%' }\" />\n\n<div class=\"container\" *ngIf=\"lineChartConfig$ | async as config\">\n <app-line-chart [chartId]=\"'line-example-1'\" [data]=\"[config.data[0]]\" [options]=\"config.options\"></app-line-chart>\n\n <app-line-chart [chartId]=\"'line-example-2'\" [data]=\"[config.data[1]]\" [options]=\"config.optionsDateDdMmYy\"></app-line-chart>\n\n <app-line-chart\n [chartId]=\"'line-example-3'\"\n [data]=\"[config.data[1], config.data[2]]\"\n [options]=\"config.optionsDateDdMmYyyy\"\n ></app-line-chart>\n\n <app-line-chart [chartId]=\"'line-example-4'\" [data]=\"config.data\" [options]=\"config.optionsDateMmYyyy\"></app-line-chart>\n</div>\n\n<hr [ngStyle]=\"{ width: '100%' }\" />\n\n<div class=\"container\" *ngIf=\"radarChartConfig$ | async as config\">\n <app-radar-chart [chartId]=\"'radar-example-1'\" [data]=\"config.data\" [options]=\"config.options\"></app-radar-chart>\n</div>\n\n<hr [ngStyle]=\"{ width: '100%' }\" />\n\n<div class=\"container\" *ngIf=\"pieChartConfig$ | async as config\">\n <app-pie-chart [chartId]=\"'pie-example-1'\" [data]=\"config.data\" [options]=\"config.options\"></app-pie-chart>\n</div>\n\n<hr [ngStyle]=\"{ width: '100%' }\" />\n\n<div class=\"container\" *ngIf=\"forceDirectedChartConfig$ | async as config\">\n <app-force-directed-chart\n [chartId]=\"'force-directed-example-1'\"\n [data]=\"config.data\"\n [options]=\"config.options\"\n ></app-force-directed-chart>\n</div>\n", styles: [":host{display:flex;flex-direction:row;flex-wrap:wrap;justify-content:center}:host .container{display:flex;flex:1 1 auto;flex-wrap:wrap;width:100%}\n"] }]
|
|
1916
1933
|
}], ctorParameters: function () { return [{ type: i1.BreakpointObserver }]; } });
|
|
1917
1934
|
|
|
1918
1935
|
class AppD3ChartsModule {
|
|
1919
|
-
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.
|
|
1920
|
-
/** @nocollapse */ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.0.
|
|
1936
|
+
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: AppD3ChartsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
1937
|
+
/** @nocollapse */ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.0.1", ngImport: i0, type: AppD3ChartsModule, declarations: [AppPieChartComponent,
|
|
1921
1938
|
AppRadarChartComponent,
|
|
1922
1939
|
AppForceDirectedChartComponent,
|
|
1923
1940
|
AppBarChartComponent,
|
|
@@ -1928,9 +1945,9 @@ class AppD3ChartsModule {
|
|
|
1928
1945
|
AppBarChartComponent,
|
|
1929
1946
|
AppLineChartComponent,
|
|
1930
1947
|
AppChartExamplesComponent] }); }
|
|
1931
|
-
/** @nocollapse */ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.0.
|
|
1948
|
+
/** @nocollapse */ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: AppD3ChartsModule, imports: [CommonModule] }); }
|
|
1932
1949
|
}
|
|
1933
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.
|
|
1950
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: AppD3ChartsModule, decorators: [{
|
|
1934
1951
|
type: NgModule,
|
|
1935
1952
|
args: [{
|
|
1936
1953
|
imports: [CommonModule],
|