Menu

Column.svelte component

Generates an SVG column chart.

Param Default Required Description
fill String '#00e047'
no
The shape's fill color.
stroke String '#000'
no
The shape's stroke color.
strokeWidth Number 0
no
The shape's stroke width.
false Boolean None
no
Show the numbers for each column

Used in these examples:

SSR Examples:

<!--
  @component
  Generates an SVG column chart.
 -->
<script>
  import { getContext } from 'svelte';

  const { data, xGet, yGet, x, yRange, xScale, y, height, zGet, zScale, z } = getContext('LayerCake');

  /** @type {String} [fill='#00e047'] - The shape's fill color. */
  export let fill = '#00e047';

  /** @type {String} [stroke='#000'] - The shape's stroke color. */
  export let stroke = '#000';

  /** @type {Number} [strokeWidth=0] - The shape's stroke width. */
  export let strokeWidth = 0;

  /** @type {Boolean} [false] - Show the numbers for each column */
  export let showLabels = false;

  $: columnWidth = d => {
    const vals = $xGet(d);
    return Math.abs(vals[1] - vals[0]);
  };

  $: columnHeight = d => {
    return $yRange[0] - $yGet(d);
  };
</script>

<g class="column-group">
  {#each $data as d, i}
    {@const colHeight = columnHeight(d)}
    {@const xGot = $xGet(d)}
    {@const xPos = Array.isArray(xGot) ? xGot[0] : xGot}
    {@const colWidth = $xScale.bandwidth ? $xScale.bandwidth() : columnWidth(d)}
    {@const yValue = $y(d)}
    <rect
      class='group-rect'
      data-id="{i}"
      data-range="{$x(d)}"
      data-count="{yValue}"
      x="{xPos}"
      y="{$yGet(d)}"
      width="{colWidth}"
      height="{colHeight}"
      {fill}
      {stroke}
      stroke-width="{strokeWidth}"
    />
    {#if showLabels && yValue}
      <text x="{xPos + colWidth / 2}" y="{$height - colHeight - 5}" text-anchor="middle">{yValue}</text>
    {/if}
  {/each}
</g>

<style>
  text {
    font-size: 12px;
  }
</style>