@rivet-health/design-system 13.1.0 → 13.1.1

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.
@@ -43,7 +43,11 @@ export var Chart;
43
43
  const { data, visibleIndices } = hide(allData);
44
44
  const xScale = scaleUtc(timeseriesDomain(data), xRange(dimensions));
45
45
  const format = (date) => formatedDate(config.dateFormat || 'day', date);
46
- const xTicks = xScale.ticks(Math.min(5, data.x.length)).map(tick => ({
46
+ //Dont use auto magic when dealing with 1,2,3,4 data points
47
+ const xTickDates = data.x.length < 5
48
+ ? data.x.map(x => new Date(x))
49
+ : xScale.ticks(Math.min(5, data.x.length));
50
+ const xTicks = xTickDates.map(tick => ({
47
51
  x: xScale(tick),
48
52
  label: format(tick),
49
53
  }));
@@ -360,4 +364,4 @@ export var Chart;
360
364
  }
361
365
  Chart.getTimeIntervalFormat = getTimeIntervalFormat;
362
366
  })(Chart || (Chart = {}));
363
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chart.js","sourceRoot":"","sources":["../../../../../../projects/riv/src/lib/visualization/chart/chart.ts"],"names":[],"mappings":"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","sourcesContent":["import { CurrencyPipe } from '@angular/common';\nimport { scaleLinear, scaleUtc } from 'd3-scale';\nimport { area, line } from 'd3-shape';\nimport { utcFormat } from 'd3-time-format';\nimport { DaysPipe } from '../../format/pipes/days.pipe';\nimport { NumberPipe } from '../../format/pipes/number.pipe';\nimport { PercentagePipe } from '../../format/pipes/percentage.pipe';\nimport { SmallCurrencyPipe } from '../../format/pipes/small-currency.pipe';\n\nexport namespace Chart {\n  export const defaultColorPalette = [\n    //Base colors\n    '--baja-blast-50',\n    '--teal-diamond-50',\n    '--fyre-50',\n    '--tang-50',\n    '--purp-60',\n    '--rosi-70',\n    //Shift lighter from base by -20\n    '--baja-blast-30',\n    '--teal-diamond-30',\n    '--fyre-30',\n    '--tang-30',\n    '--purp-40',\n    '--rosi-50',\n    //Shift darker from base by +20\n    '--baja-blast-70',\n    '--teal-diamond-70',\n    '--fyre-70',\n    '--tang-70',\n    '--purp-80',\n    '--rosi-90',\n  ];\n\n  export function chart(config: Config, data: Data, dimensions: Dimensions) {\n    return config.type == 'line'\n      ? lines(config, data, dimensions)\n      : config.type == 'area'\n      ? areas(config, data, dimensions)\n      : bars(config, data, dimensions);\n  }\n  export function lines(\n    config: Config,\n    allData: Data,\n    dimensions: Dimensions,\n  ): RenderedChart {\n    const { data, visibleIndices } = hide(allData);\n    const xScale = scaleUtc(timeseriesDomain(data), xRange(dimensions));\n    const format = (date: Date) =>\n      formatedDate(config.dateFormat || 'day', date);\n\n    const xTicks = xScale.ticks(Math.min(5, data.x.length)).map(tick => ({\n      x: xScale(tick),\n      label: format(tick),\n    }));\n\n    const { pipe, fullPipe } = getPipes(config.valueType);\n    const yScale = scaleLinear(yDomain(data), yRange(dimensions));\n    const yTicks = yScale.ticks(5).map(tick => ({\n      y: yScale(tick),\n      label: pipe.transform(tick),\n    }));\n\n    const colors = visibleIndices.map(\n      i => config.colors[i % config.colors.length],\n    );\n    const indices = data.x.map((_, i) => i);\n    const lines =\n      data.x.length > 1\n        ? data.ys.map(y =>\n            line<number>(\n              i => xScale(data.x[i]),\n              i => yScale(y.values[i]),\n            )(indices),\n          )\n        : [];\n    const circles =\n      data.x.length === 1\n        ? data.ys.map(ySeries => ({\n            cx: xScale(data.x[0]),\n            cy: yScale(ySeries.values[0]),\n          }))\n        : [];\n\n    function hover(pos: { rect: DOMRect; x: number; y: number }) {\n      const xIndex = findNearestIndex(data.x, xScale.invert(pos.x).getTime());\n      const x = xScale(data.x[xIndex]);\n      const visibleYIndex = findNearestIndex(\n        data.ys.map(y => y.values[xIndex]),\n        yScale.invert(pos.y),\n      );\n      const yIndex = visibleIndices[visibleYIndex];\n      const ys = data.ys.map(y => yScale(y.values[xIndex]));\n\n      const format = (date: Date) =>\n        formatedDate(config.dateFormat || 'day', date);\n\n      const anchor = new DOMRect(\n        pos.rect.x + x,\n        pos.rect.y + ys[visibleYIndex],\n        8,\n        0,\n      );\n      return {\n        x,\n        xIndex,\n        ys,\n        yIndex,\n        visibleYIndex,\n        tooltip: {\n          anchor,\n          date: format(new Date(data.x[xIndex])),\n          metrics: data.ys\n            .map((y, index) => ({\n              color: colors[index % colors.length],\n              label: y.label,\n              value: fullPipe.transform(y.values[xIndex]) ?? '-',\n            }))\n            .filter((_, i) => config.groupedTooltip || i == visibleYIndex),\n        },\n      };\n    }\n\n    return {\n      xTicks,\n      yTicks,\n      colors,\n      lines,\n      circles,\n      hover,\n      bars: [],\n      areas: [],\n    };\n  }\n\n  export function areas(\n    config: Config,\n    allData: Data,\n    dimensions: Dimensions,\n  ): RenderedChart {\n    const { data: unstackedData, visibleIndices } = hide(allData);\n    const data = stack(unstackedData);\n    const xScale = scaleUtc(timeseriesDomain(data), xRange(dimensions));\n    const format = (date: Date) =>\n      formatedDate(config.dateFormat || 'day', date);\n    const xTicks = xScale.ticks(Math.min(5, data.x.length)).map(tick => ({\n      x: xScale(tick),\n      label: format(tick),\n    }));\n\n    const { pipe, fullPipe } = getPipes(config.valueType);\n    const yScale = scaleLinear(yDomain(data), yRange(dimensions));\n    const yTicks = yScale.ticks(5).map(tick => ({\n      y: yScale(tick),\n      label: pipe.transform(tick),\n    }));\n\n    const indices = data.x.map((_, i) => i);\n    const colors = visibleIndices.map(\n      i => config.colors[i % config.colors.length],\n    );\n    const areas = data.ys.map((y, yIndex) =>\n      area<number>(\n        i => xScale(data.x[i]),\n        i => yScale(yIndex == 0 ? 0 : data.ys[yIndex - 1].values[i]),\n        i => yScale(y.values[i]),\n      )(indices),\n    );\n\n    function hover(pos: { rect: DOMRect; x: number; y: number }) {\n      const xIndex = findNearestIndex(data.x, xScale.invert(pos.x).getTime());\n      const x = xScale(data.x[xIndex]);\n      const yValue = yScale.invert(pos.y);\n      let visibleYIndex = data.ys\n        .map(y => y.values[xIndex])\n        .findIndex(y => y > yValue);\n      if (visibleYIndex == -1) {\n        visibleYIndex = data.ys.length - 1;\n      }\n      const yIndex = visibleIndices[visibleYIndex];\n      const ys = data.ys.map(y => yScale(y.values[xIndex]));\n      const padding = 8;\n      const anchor = new DOMRect(\n        pos.rect.x + x,\n        pos.rect.y + ys[visibleYIndex],\n        padding,\n        0,\n      );\n      return {\n        x,\n        xIndex,\n        ys,\n        yIndex,\n        visibleYIndex,\n        tooltip: {\n          anchor,\n          date: utcFormat('%B %d, %Y')(new Date(unstackedData.x[xIndex])),\n          metrics: unstackedData.ys\n            .map((y, index) => ({\n              color: colors[index % colors.length],\n              label: y.label,\n              value: fullPipe.transform(y.values[xIndex]) ?? '-',\n            }))\n            .filter((_, i) => config.groupedTooltip || i == visibleYIndex),\n        },\n      };\n    }\n\n    return {\n      xTicks,\n      yTicks,\n      colors,\n      areas,\n      lines: [],\n      circles: [],\n      hover,\n      bars: [],\n    };\n  }\n\n  export function bars(\n    config: Config,\n    allData: Data,\n    dimensions: Dimensions,\n  ): RenderedChart {\n    const { data: unstackedData, visibleIndices } = hide(allData);\n    const data = stack(unstackedData);\n    const { range: xRange, binSize } = barXRange(dimensions, data);\n    const halfBinSize = binSize / 2;\n    const xScale = scaleUtc(timeseriesDomain(data), xRange);\n    const format = (date: Date) =>\n      formatedDate(config.dateFormat || 'day', date);\n    const xTicks = xScale.ticks(Math.min(5, data.x.length)).map(tick => ({\n      x: xScale(tick),\n      label: format(tick),\n    }));\n\n    const { pipe, fullPipe } = getPipes(config.valueType);\n    const yScale = scaleLinear(yDomain(data), yRange(dimensions));\n    const yTicks = yScale.ticks(5).map(tick => ({\n      y: yScale(tick),\n      label: pipe.transform(tick),\n    }));\n    const colors = visibleIndices.map(\n      i => config.colors[i % config.colors.length],\n    );\n    const bars = data.ys.map((y, yIndex) =>\n      y.values.map((value, index) => {\n        const yValue = yScale(value);\n        return {\n          x: xScale(data.x[index]) - halfBinSize,\n          y: yValue,\n          width: binSize,\n          height:\n            (yIndex == 0\n              ? yScale(0)\n              : yScale(data.ys[yIndex - 1].values[index])) - yValue,\n        };\n      }),\n    );\n\n    function hover(pos: { rect: DOMRect; x: number; y: number }) {\n      const xIndex = findNearestIndex(data.x, xScale.invert(pos.x).getTime());\n      const x = xScale(data.x[xIndex]);\n      const yValue = yScale.invert(pos.y);\n      let visibleYIndex = data.ys\n        .map(y => y.values[xIndex])\n        .findIndex(y => y > yValue);\n      if (visibleYIndex == -1) {\n        visibleYIndex = data.ys.length - 1;\n      }\n      const yIndex = visibleIndices[visibleYIndex];\n      const ys = data.ys.map(y => yScale(y.values[xIndex]));\n      const padding = 8;\n      const anchor = new DOMRect(\n        pos.rect.x + bars[visibleYIndex][xIndex].x - padding,\n        pos.rect.y + ys[visibleYIndex],\n        bars[visibleYIndex][xIndex].width + padding * 2,\n        (visibleYIndex == 0 ? yScale(0) : ys[visibleYIndex - 1]) -\n          ys[visibleYIndex],\n      );\n      return {\n        x,\n        xIndex,\n        ys,\n        yIndex,\n        visibleYIndex,\n        tooltip: {\n          anchor,\n          date: utcFormat('%B %d, %Y')(new Date(unstackedData.x[xIndex])),\n          metrics: unstackedData.ys\n            .map((y, index) => ({\n              color: colors[index % colors.length],\n              label: y.label,\n              value: fullPipe.transform(y.values[xIndex]) ?? '-',\n            }))\n            .filter((_, i) => config.groupedTooltip || i == visibleYIndex),\n        },\n      };\n    }\n\n    return {\n      xTicks,\n      yTicks,\n      colors,\n      bars,\n      lines: [],\n      circles: [],\n      areas: [],\n      hover,\n    };\n  }\n\n  const LEFT_PADDING = 48;\n  const RIGHT_PADDING = 24;\n  const TOP_PADDING = 16;\n  const BOTTOM_PADDING = 24;\n\n  export type Data = {\n    ys: {\n      label: string;\n      hidden?: boolean;\n      values: number[];\n    }[];\n    x: number[];\n  };\n\n  export type Dimensions = {\n    width: number;\n    height: number;\n  };\n\n  export type Config = {\n    type: 'line' | 'area' | 'bar';\n    groupedTooltip: boolean;\n    colors: string[];\n    allowLegendToggle: boolean;\n    zeroStateMessage: string;\n    valueType: ValueType;\n    truncateLegend: boolean;\n    dateFormat?: Interval;\n  };\n\n  export const defaultConfig: Config = {\n    type: 'line',\n    groupedTooltip: true,\n    colors: defaultColorPalette,\n    allowLegendToggle: false,\n    zeroStateMessage: 'No data to display.',\n    valueType: 'currency',\n    truncateLegend: true,\n    dateFormat: 'day',\n  };\n\n  export type Area = {\n    path: string | null;\n    fill: string;\n  };\n\n  export type XTick = {\n    x: number;\n    label: string;\n  };\n\n  export type YTick = {\n    y: number;\n    label: string;\n  };\n\n  type Rect = {\n    x: number;\n    y: number;\n    width: number;\n    height: number;\n  };\n\n  export type BarSeries = {\n    fill: string;\n    rects: Rect[];\n  };\n\n  type Circle = {\n    cx: number;\n    cy: number;\n  };\n\n  // Hover is a function that takes a viewport x and y and returns a rich\n  // set of information about what values are being hovered and what the tooltip\n  // should look like\n  export type Hover = (pos: { rect: DOMRect; x: number; y: number }) => {\n    // the indices into the data of the closest point\n    xIndex: number;\n    // we want to know which visible y index is hovered\n    // and which actual y index is hovered\n    yIndex: number;\n    visibleYIndex: number;\n\n    // the viewport x and ys of the hovered items\n    x: number;\n    ys: number[];\n\n    tooltip: {\n      anchor: DOMRect;\n      date: string;\n      metrics: {\n        color: string;\n        label: string;\n        value: string;\n      }[];\n    };\n  };\n\n  // RenderedChart represents all of the parts of a chart\n  // that end up on screen. Every chart has x and y ticks\n  // and hover functionality, even though they might be\n  // different from chart to chart.\n  type RenderedChart = {\n    xTicks: XTick[];\n    yTicks: YTick[];\n    hover: Hover;\n    colors: string[];\n    lines: (string | null)[];\n    circles: Circle[]; //Line fallback for a single point\n    areas: (string | null)[];\n    bars: Rect[][];\n  };\n\n  function timeseriesDomain(data: Data) {\n    return [Math.min(...data.x), Math.max(...data.x)];\n  }\n\n  function yDomain(data: Data) {\n    const max = Math.max(...data.ys.map(y => Math.max(...y.values)));\n    return [0, max == 0 ? 1 : max];\n  }\n\n  function xRange(dimensions: Dimensions) {\n    return [LEFT_PADDING, dimensions.width - RIGHT_PADDING];\n  }\n\n  function barXRange(dimensions: Dimensions, data: Data) {\n    const left = LEFT_PADDING;\n    const right = dimensions.width - RIGHT_PADDING;\n    const width = right - left;\n    const binSize = width / (data.x.length || 1);\n    const halfBinSize = binSize / 2;\n    const range = [left + halfBinSize, right - halfBinSize];\n    return { binSize: Math.min(binSize * 0.7, 80), range };\n  }\n\n  function yRange(dimensions: Dimensions) {\n    return [dimensions.height - BOTTOM_PADDING, TOP_PADDING];\n  }\n\n  function findNearestIndex(values: number[], input: number) {\n    return values.reduce((nearestIndex, value, index) => {\n      return Math.abs(value - input) < Math.abs(values[nearestIndex] - input)\n        ? index\n        : nearestIndex;\n    }, 0);\n  }\n\n  // stack returns a new data where each set of yValues is stacked\n  // on top of the previous.\n  function stack(data: Data): Data {\n    const stacked: Data = {\n      ...data,\n      ys: data.ys.map(y => ({ label: y.label, values: [] })),\n    };\n    for (let i = 0; i < data.x.length; i++) {\n      let from = 0;\n      for (let j = 0; j < data.ys.length; j++) {\n        const to = from + data.ys[j].values[i];\n        stacked.ys[j].values.push(to);\n        from = to;\n      }\n    }\n    return stacked;\n  }\n\n  // hide strips out hidden y values while retaining the original indices\n  // for the remaining visible values\n  function hide(data: Data): { data: Data; visibleIndices: number[] } {\n    const visibleIndices = data.ys\n      .map((y, i) => ({ y, i }))\n      .filter(({ y }) => !y.hidden)\n      .map(({ i }) => i);\n    return {\n      data: { ...data, ys: visibleIndices.map(i => data.ys[i]) },\n      visibleIndices,\n    };\n  }\n\n  type ValueType = 'count' | 'currency' | 'percentage' | 'days';\n\n  export function getPipes(valueType: ValueType) {\n    switch (valueType) {\n      case 'count': {\n        const pipe = new NumberPipe();\n        return { pipe, fullPipe: pipe };\n      }\n      case 'currency':\n        return {\n          pipe: new SmallCurrencyPipe(),\n          fullPipe: new CurrencyPipe('en-us'),\n        };\n      case 'percentage': {\n        const pipe = new PercentagePipe();\n        return { pipe, fullPipe: pipe };\n      }\n      case 'days': {\n        const pipe = new DaysPipe();\n        return { pipe, fullPipe: pipe };\n      }\n    }\n  }\n\n  export const intervals = ['year', 'quarter', 'month', 'week', 'day'] as const;\n  export type Interval = (typeof intervals)[number];\n\n  export function formatedDate(dateFormat: Interval, date: Date) {\n    if (dateFormat == 'quarter') {\n      const quarter = Math.ceil((date.getUTCMonth() + 1) / 3);\n      const year = utcFormat(getTimeIntervalFormat('year'))(date);\n      return `Q${quarter} ${year}`;\n    }\n    const format = getTimeIntervalFormat(dateFormat);\n    return utcFormat(format)(date);\n  }\n\n  export function getTimeIntervalFormat(interval: Interval): string {\n    switch (interval) {\n      case 'day':\n      case 'week':\n        return '%m/%d/%Y';\n      case 'month':\n      case 'quarter':\n        return '%b %Y';\n      case 'year':\n        return '%Y';\n    }\n  }\n}\n"]}
367
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chart.js","sourceRoot":"","sources":["../../../../../../projects/riv/src/lib/visualization/chart/chart.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,WAAW,EAAE,QAAQ,EAAE,MAAM,UAAU,CAAC;AACjD,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,UAAU,CAAC;AACtC,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC3C,OAAO,EAAE,QAAQ,EAAE,MAAM,8BAA8B,CAAC;AACxD,OAAO,EAAE,UAAU,EAAE,MAAM,gCAAgC,CAAC;AAC5D,OAAO,EAAE,cAAc,EAAE,MAAM,oCAAoC,CAAC;AACpE,OAAO,EAAE,iBAAiB,EAAE,MAAM,wCAAwC,CAAC;AAE3E,MAAM,KAAW,KAAK,CA2hBrB;AA3hBD,WAAiB,KAAK;IACP,yBAAmB,GAAG;QACjC,aAAa;QACb,iBAAiB;QACjB,mBAAmB;QACnB,WAAW;QACX,WAAW;QACX,WAAW;QACX,WAAW;QACX,gCAAgC;QAChC,iBAAiB;QACjB,mBAAmB;QACnB,WAAW;QACX,WAAW;QACX,WAAW;QACX,WAAW;QACX,+BAA+B;QAC/B,iBAAiB;QACjB,mBAAmB;QACnB,WAAW;QACX,WAAW;QACX,WAAW;QACX,WAAW;KACZ,CAAC;IAEF,SAAgB,KAAK,CAAC,MAAc,EAAE,IAAU,EAAE,UAAsB;QACtE,OAAO,MAAM,CAAC,IAAI,IAAI,MAAM;YAC1B,CAAC,CAAC,KAAK,CAAC,MAAM,EAAE,IAAI,EAAE,UAAU,CAAC;YACjC,CAAC,CAAC,MAAM,CAAC,IAAI,IAAI,MAAM;gBACvB,CAAC,CAAC,KAAK,CAAC,MAAM,EAAE,IAAI,EAAE,UAAU,CAAC;gBACjC,CAAC,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,EAAE,UAAU,CAAC,CAAC;IACrC,CAAC;IANe,WAAK,QAMpB,CAAA;IACD,SAAgB,KAAK,CACnB,MAAc,EACd,OAAa,EACb,UAAsB;QAEtB,MAAM,EAAE,IAAI,EAAE,cAAc,EAAE,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC;QAC/C,MAAM,MAAM,GAAG,QAAQ,CAAC,gBAAgB,CAAC,IAAI,CAAC,EAAE,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC;QACpE,MAAM,MAAM,GAAG,CAAC,IAAU,EAAE,EAAE,CAC5B,YAAY,CAAC,MAAM,CAAC,UAAU,IAAI,KAAK,EAAE,IAAI,CAAC,CAAC;QAEjD,2DAA2D;QAC3D,MAAM,UAAU,GACd,IAAI,CAAC,CAAC,CAAC,MAAM,GAAG,CAAC;YACf,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC;YAC9B,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC;QAE/C,MAAM,MAAM,GAAG,UAAU,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;YACrC,CAAC,EAAE,MAAM,CAAC,IAAI,CAAC;YACf,KAAK,EAAE,MAAM,CAAC,IAAI,CAAC;SACpB,CAAC,CAAC,CAAC;QAEJ,MAAM,EAAE,IAAI,EAAE,QAAQ,EAAE,GAAG,QAAQ,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;QACtD,MAAM,MAAM,GAAG,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC;QAC9D,MAAM,MAAM,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;YAC1C,CAAC,EAAE,MAAM,CAAC,IAAI,CAAC;YACf,KAAK,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC;SAC5B,CAAC,CAAC,CAAC;QAEJ,MAAM,MAAM,GAAG,cAAc,CAAC,GAAG,CAC/B,CAAC,CAAC,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,GAAG,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAC7C,CAAC;QACF,MAAM,OAAO,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC;QACxC,MAAM,KAAK,GACT,IAAI,CAAC,CAAC,CAAC,MAAM,GAAG,CAAC;YACf,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CACd,IAAI,CACF,CAAC,CAAC,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EACtB,CAAC,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CACzB,CAAC,OAAO,CAAC,CACX;YACH,CAAC,CAAC,EAAE,CAAC;QACT,MAAM,OAAO,GACX,IAAI,CAAC,CAAC,CAAC,MAAM,KAAK,CAAC;YACjB,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;gBACtB,EAAE,EAAE,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;gBACrB,EAAE,EAAE,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;aAC9B,CAAC,CAAC;YACL,CAAC,CAAC,EAAE,CAAC;QAET,SAAS,KAAK,CAAC,GAA4C;YACzD,MAAM,MAAM,GAAG,gBAAgB,CAAC,IAAI,CAAC,CAAC,EAAE,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC;YACxE,MAAM,CAAC,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC;YACjC,MAAM,aAAa,GAAG,gBAAgB,CACpC,IAAI,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,EAClC,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CACrB,CAAC;YACF,MAAM,MAAM,GAAG,cAAc,CAAC,aAAa,CAAC,CAAC;YAC7C,MAAM,EAAE,GAAG,IAAI,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;YAEtD,MAAM,MAAM,GAAG,CAAC,IAAU,EAAE,EAAE,CAC5B,YAAY,CAAC,MAAM,CAAC,UAAU,IAAI,KAAK,EAAE,IAAI,CAAC,CAAC;YAEjD,MAAM,MAAM,GAAG,IAAI,OAAO,CACxB,GAAG,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,EACd,GAAG,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,CAAC,aAAa,CAAC,EAC9B,CAAC,EACD,CAAC,CACF,CAAC;YACF,OAAO;gBACL,CAAC;gBACD,MAAM;gBACN,EAAE;gBACF,MAAM;gBACN,aAAa;gBACb,OAAO,EAAE;oBACP,MAAM;oBACN,IAAI,EAAE,MAAM,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC;oBACtC,OAAO,EAAE,IAAI,CAAC,EAAE;yBACb,GAAG,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC;wBAClB,KAAK,EAAE,MAAM,CAAC,KAAK,GAAG,MAAM,CAAC,MAAM,CAAC;wBACpC,KAAK,EAAE,CAAC,CAAC,KAAK;wBACd,KAAK,EAAE,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,IAAI,GAAG;qBACnD,CAAC,CAAC;yBACF,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,MAAM,CAAC,cAAc,IAAI,CAAC,IAAI,aAAa,CAAC;iBACjE;aACF,CAAC;QACJ,CAAC;QAED,OAAO;YACL,MAAM;YACN,MAAM;YACN,MAAM;YACN,KAAK;YACL,OAAO;YACP,KAAK;YACL,IAAI,EAAE,EAAE;YACR,KAAK,EAAE,EAAE;SACV,CAAC;IACJ,CAAC;IAlGe,WAAK,QAkGpB,CAAA;IAED,SAAgB,KAAK,CACnB,MAAc,EACd,OAAa,EACb,UAAsB;QAEtB,MAAM,EAAE,IAAI,EAAE,aAAa,EAAE,cAAc,EAAE,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC;QAC9D,MAAM,IAAI,GAAG,KAAK,CAAC,aAAa,CAAC,CAAC;QAClC,MAAM,MAAM,GAAG,QAAQ,CAAC,gBAAgB,CAAC,IAAI,CAAC,EAAE,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC;QACpE,MAAM,MAAM,GAAG,CAAC,IAAU,EAAE,EAAE,CAC5B,YAAY,CAAC,MAAM,CAAC,UAAU,IAAI,KAAK,EAAE,IAAI,CAAC,CAAC;QACjD,MAAM,MAAM,GAAG,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;YACnE,CAAC,EAAE,MAAM,CAAC,IAAI,CAAC;YACf,KAAK,EAAE,MAAM,CAAC,IAAI,CAAC;SACpB,CAAC,CAAC,CAAC;QAEJ,MAAM,EAAE,IAAI,EAAE,QAAQ,EAAE,GAAG,QAAQ,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;QACtD,MAAM,MAAM,GAAG,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC;QAC9D,MAAM,MAAM,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;YAC1C,CAAC,EAAE,MAAM,CAAC,IAAI,CAAC;YACf,KAAK,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC;SAC5B,CAAC,CAAC,CAAC;QAEJ,MAAM,OAAO,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC;QACxC,MAAM,MAAM,GAAG,cAAc,CAAC,GAAG,CAC/B,CAAC,CAAC,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,GAAG,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAC7C,CAAC;QACF,MAAM,KAAK,GAAG,IAAI,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,MAAM,EAAE,EAAE,CACtC,IAAI,CACF,CAAC,CAAC,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EACtB,CAAC,CAAC,EAAE,CAAC,MAAM,CAAC,MAAM,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,EAC5D,CAAC,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CACzB,CAAC,OAAO,CAAC,CACX,CAAC;QAEF,SAAS,KAAK,CAAC,GAA4C;YACzD,MAAM,MAAM,GAAG,gBAAgB,CAAC,IAAI,CAAC,CAAC,EAAE,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC;YACxE,MAAM,CAAC,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC;YACjC,MAAM,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YACpC,IAAI,aAAa,GAAG,IAAI,CAAC,EAAE;iBACxB,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;iBAC1B,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC;YAC9B,IAAI,aAAa,IAAI,CAAC,CAAC,EAAE;gBACvB,aAAa,GAAG,IAAI,CAAC,EAAE,CAAC,MAAM,GAAG,CAAC,CAAC;aACpC;YACD,MAAM,MAAM,GAAG,cAAc,CAAC,aAAa,CAAC,CAAC;YAC7C,MAAM,EAAE,GAAG,IAAI,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;YACtD,MAAM,OAAO,GAAG,CAAC,CAAC;YAClB,MAAM,MAAM,GAAG,IAAI,OAAO,CACxB,GAAG,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,EACd,GAAG,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,CAAC,aAAa,CAAC,EAC9B,OAAO,EACP,CAAC,CACF,CAAC;YACF,OAAO;gBACL,CAAC;gBACD,MAAM;gBACN,EAAE;gBACF,MAAM;gBACN,aAAa;gBACb,OAAO,EAAE;oBACP,MAAM;oBACN,IAAI,EAAE,SAAS,CAAC,WAAW,CAAC,CAAC,IAAI,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC;oBAC/D,OAAO,EAAE,aAAa,CAAC,EAAE;yBACtB,GAAG,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC;wBAClB,KAAK,EAAE,MAAM,CAAC,KAAK,GAAG,MAAM,CAAC,MAAM,CAAC;wBACpC,KAAK,EAAE,CAAC,CAAC,KAAK;wBACd,KAAK,EAAE,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,IAAI,GAAG;qBACnD,CAAC,CAAC;yBACF,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,MAAM,CAAC,cAAc,IAAI,CAAC,IAAI,aAAa,CAAC;iBACjE;aACF,CAAC;QACJ,CAAC;QAED,OAAO;YACL,MAAM;YACN,MAAM;YACN,MAAM;YACN,KAAK;YACL,KAAK,EAAE,EAAE;YACT,OAAO,EAAE,EAAE;YACX,KAAK;YACL,IAAI,EAAE,EAAE;SACT,CAAC;IACJ,CAAC;IAnFe,WAAK,QAmFpB,CAAA;IAED,SAAgB,IAAI,CAClB,MAAc,EACd,OAAa,EACb,UAAsB;QAEtB,MAAM,EAAE,IAAI,EAAE,aAAa,EAAE,cAAc,EAAE,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC;QAC9D,MAAM,IAAI,GAAG,KAAK,CAAC,aAAa,CAAC,CAAC;QAClC,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,GAAG,SAAS,CAAC,UAAU,EAAE,IAAI,CAAC,CAAC;QAC/D,MAAM,WAAW,GAAG,OAAO,GAAG,CAAC,CAAC;QAChC,MAAM,MAAM,GAAG,QAAQ,CAAC,gBAAgB,CAAC,IAAI,CAAC,EAAE,MAAM,CAAC,CAAC;QACxD,MAAM,MAAM,GAAG,CAAC,IAAU,EAAE,EAAE,CAC5B,YAAY,CAAC,MAAM,CAAC,UAAU,IAAI,KAAK,EAAE,IAAI,CAAC,CAAC;QACjD,MAAM,MAAM,GAAG,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;YACnE,CAAC,EAAE,MAAM,CAAC,IAAI,CAAC;YACf,KAAK,EAAE,MAAM,CAAC,IAAI,CAAC;SACpB,CAAC,CAAC,CAAC;QAEJ,MAAM,EAAE,IAAI,EAAE,QAAQ,EAAE,GAAG,QAAQ,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;QACtD,MAAM,MAAM,GAAG,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC;QAC9D,MAAM,MAAM,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;YAC1C,CAAC,EAAE,MAAM,CAAC,IAAI,CAAC;YACf,KAAK,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC;SAC5B,CAAC,CAAC,CAAC;QACJ,MAAM,MAAM,GAAG,cAAc,CAAC,GAAG,CAC/B,CAAC,CAAC,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,GAAG,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAC7C,CAAC;QACF,MAAM,IAAI,GAAG,IAAI,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,MAAM,EAAE,EAAE,CACrC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,KAAK,EAAE,EAAE;YAC5B,MAAM,MAAM,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;YAC7B,OAAO;gBACL,CAAC,EAAE,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,GAAG,WAAW;gBACtC,CAAC,EAAE,MAAM;gBACT,KAAK,EAAE,OAAO;gBACd,MAAM,EACJ,CAAC,MAAM,IAAI,CAAC;oBACV,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC;oBACX,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,MAAM;aAC1D,CAAC;QACJ,CAAC,CAAC,CACH,CAAC;QAEF,SAAS,KAAK,CAAC,GAA4C;YACzD,MAAM,MAAM,GAAG,gBAAgB,CAAC,IAAI,CAAC,CAAC,EAAE,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC;YACxE,MAAM,CAAC,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC;YACjC,MAAM,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YACpC,IAAI,aAAa,GAAG,IAAI,CAAC,EAAE;iBACxB,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;iBAC1B,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC;YAC9B,IAAI,aAAa,IAAI,CAAC,CAAC,EAAE;gBACvB,aAAa,GAAG,IAAI,CAAC,EAAE,CAAC,MAAM,GAAG,CAAC,CAAC;aACpC;YACD,MAAM,MAAM,GAAG,cAAc,CAAC,aAAa,CAAC,CAAC;YAC7C,MAAM,EAAE,GAAG,IAAI,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;YACtD,MAAM,OAAO,GAAG,CAAC,CAAC;YAClB,MAAM,MAAM,GAAG,IAAI,OAAO,CACxB,GAAG,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,OAAO,EACpD,GAAG,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,CAAC,aAAa,CAAC,EAC9B,IAAI,CAAC,aAAa,CAAC,CAAC,MAAM,CAAC,CAAC,KAAK,GAAG,OAAO,GAAG,CAAC,EAC/C,CAAC,aAAa,IAAI,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,aAAa,GAAG,CAAC,CAAC,CAAC;gBACtD,EAAE,CAAC,aAAa,CAAC,CACpB,CAAC;YACF,OAAO;gBACL,CAAC;gBACD,MAAM;gBACN,EAAE;gBACF,MAAM;gBACN,aAAa;gBACb,OAAO,EAAE;oBACP,MAAM;oBACN,IAAI,EAAE,SAAS,CAAC,WAAW,CAAC,CAAC,IAAI,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC;oBAC/D,OAAO,EAAE,aAAa,CAAC,EAAE;yBACtB,GAAG,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC;wBAClB,KAAK,EAAE,MAAM,CAAC,KAAK,GAAG,MAAM,CAAC,MAAM,CAAC;wBACpC,KAAK,EAAE,CAAC,CAAC,KAAK;wBACd,KAAK,EAAE,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,IAAI,GAAG;qBACnD,CAAC,CAAC;yBACF,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,MAAM,CAAC,cAAc,IAAI,CAAC,IAAI,aAAa,CAAC;iBACjE;aACF,CAAC;QACJ,CAAC;QAED,OAAO;YACL,MAAM;YACN,MAAM;YACN,MAAM;YACN,IAAI;YACJ,KAAK,EAAE,EAAE;YACT,OAAO,EAAE,EAAE;YACX,KAAK,EAAE,EAAE;YACT,KAAK;SACN,CAAC;IACJ,CAAC;IA3Fe,UAAI,OA2FnB,CAAA;IAED,MAAM,YAAY,GAAG,EAAE,CAAC;IACxB,MAAM,aAAa,GAAG,EAAE,CAAC;IACzB,MAAM,WAAW,GAAG,EAAE,CAAC;IACvB,MAAM,cAAc,GAAG,EAAE,CAAC;IA2Bb,mBAAa,GAAW;QACnC,IAAI,EAAE,MAAM;QACZ,cAAc,EAAE,IAAI;QACpB,MAAM,EAAE,MAAA,mBAAmB;QAC3B,iBAAiB,EAAE,KAAK;QACxB,gBAAgB,EAAE,qBAAqB;QACvC,SAAS,EAAE,UAAU;QACrB,cAAc,EAAE,IAAI;QACpB,UAAU,EAAE,KAAK;KAClB,CAAC;IA2EF,SAAS,gBAAgB,CAAC,IAAU;QAClC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;IACpD,CAAC;IAED,SAAS,OAAO,CAAC,IAAU;QACzB,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QACjE,OAAO,CAAC,CAAC,EAAE,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;IACjC,CAAC;IAED,SAAS,MAAM,CAAC,UAAsB;QACpC,OAAO,CAAC,YAAY,EAAE,UAAU,CAAC,KAAK,GAAG,aAAa,CAAC,CAAC;IAC1D,CAAC;IAED,SAAS,SAAS,CAAC,UAAsB,EAAE,IAAU;QACnD,MAAM,IAAI,GAAG,YAAY,CAAC;QAC1B,MAAM,KAAK,GAAG,UAAU,CAAC,KAAK,GAAG,aAAa,CAAC;QAC/C,MAAM,KAAK,GAAG,KAAK,GAAG,IAAI,CAAC;QAC3B,MAAM,OAAO,GAAG,KAAK,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,IAAI,CAAC,CAAC,CAAC;QAC7C,MAAM,WAAW,GAAG,OAAO,GAAG,CAAC,CAAC;QAChC,MAAM,KAAK,GAAG,CAAC,IAAI,GAAG,WAAW,EAAE,KAAK,GAAG,WAAW,CAAC,CAAC;QACxD,OAAO,EAAE,OAAO,EAAE,IAAI,CAAC,GAAG,CAAC,OAAO,GAAG,GAAG,EAAE,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC;IACzD,CAAC;IAED,SAAS,MAAM,CAAC,UAAsB;QACpC,OAAO,CAAC,UAAU,CAAC,MAAM,GAAG,cAAc,EAAE,WAAW,CAAC,CAAC;IAC3D,CAAC;IAED,SAAS,gBAAgB,CAAC,MAAgB,EAAE,KAAa;QACvD,OAAO,MAAM,CAAC,MAAM,CAAC,CAAC,YAAY,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE;YAClD,OAAO,IAAI,CAAC,GAAG,CAAC,KAAK,GAAG,KAAK,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,YAAY,CAAC,GAAG,KAAK,CAAC;gBACrE,CAAC,CAAC,KAAK;gBACP,CAAC,CAAC,YAAY,CAAC;QACnB,CAAC,EAAE,CAAC,CAAC,CAAC;IACR,CAAC;IAED,gEAAgE;IAChE,0BAA0B;IAC1B,SAAS,KAAK,CAAC,IAAU;QACvB,MAAM,OAAO,GAAS;YACpB,GAAG,IAAI;YACP,EAAE,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC,KAAK,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC,CAAC;SACvD,CAAC;QACF,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YACtC,IAAI,IAAI,GAAG,CAAC,CAAC;YACb,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBACvC,MAAM,EAAE,GAAG,IAAI,GAAG,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;gBACvC,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;gBAC9B,IAAI,GAAG,EAAE,CAAC;aACX;SACF;QACD,OAAO,OAAO,CAAC;IACjB,CAAC;IAED,uEAAuE;IACvE,mCAAmC;IACnC,SAAS,IAAI,CAAC,IAAU;QACtB,MAAM,cAAc,GAAG,IAAI,CAAC,EAAE;aAC3B,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;aACzB,MAAM,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;aAC5B,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC;QACrB,OAAO;YACL,IAAI,EAAE,EAAE,GAAG,IAAI,EAAE,EAAE,EAAE,cAAc,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE;YAC1D,cAAc;SACf,CAAC;IACJ,CAAC;IAID,SAAgB,QAAQ,CAAC,SAAoB;QAC3C,QAAQ,SAAS,EAAE;YACjB,KAAK,OAAO,CAAC,CAAC;gBACZ,MAAM,IAAI,GAAG,IAAI,UAAU,EAAE,CAAC;gBAC9B,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;aACjC;YACD,KAAK,UAAU;gBACb,OAAO;oBACL,IAAI,EAAE,IAAI,iBAAiB,EAAE;oBAC7B,QAAQ,EAAE,IAAI,YAAY,CAAC,OAAO,CAAC;iBACpC,CAAC;YACJ,KAAK,YAAY,CAAC,CAAC;gBACjB,MAAM,IAAI,GAAG,IAAI,cAAc,EAAE,CAAC;gBAClC,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;aACjC;YACD,KAAK,MAAM,CAAC,CAAC;gBACX,MAAM,IAAI,GAAG,IAAI,QAAQ,EAAE,CAAC;gBAC5B,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;aACjC;SACF;IACH,CAAC;IApBe,cAAQ,WAoBvB,CAAA;IAEY,eAAS,GAAG,CAAC,MAAM,EAAE,SAAS,EAAE,OAAO,EAAE,MAAM,EAAE,KAAK,CAAU,CAAC;IAG9E,SAAgB,YAAY,CAAC,UAAoB,EAAE,IAAU;QAC3D,IAAI,UAAU,IAAI,SAAS,EAAE;YAC3B,MAAM,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;YACxD,MAAM,IAAI,GAAG,SAAS,CAAC,qBAAqB,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;YAC5D,OAAO,IAAI,OAAO,IAAI,IAAI,EAAE,CAAC;SAC9B;QACD,MAAM,MAAM,GAAG,qBAAqB,CAAC,UAAU,CAAC,CAAC;QACjD,OAAO,SAAS,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC;IACjC,CAAC;IARe,kBAAY,eAQ3B,CAAA;IAED,SAAgB,qBAAqB,CAAC,QAAkB;QACtD,QAAQ,QAAQ,EAAE;YAChB,KAAK,KAAK,CAAC;YACX,KAAK,MAAM;gBACT,OAAO,UAAU,CAAC;YACpB,KAAK,OAAO,CAAC;YACb,KAAK,SAAS;gBACZ,OAAO,OAAO,CAAC;YACjB,KAAK,MAAM;gBACT,OAAO,IAAI,CAAC;SACf;IACH,CAAC;IAXe,2BAAqB,wBAWpC,CAAA;AACH,CAAC,EA3hBgB,KAAK,KAAL,KAAK,QA2hBrB","sourcesContent":["import { CurrencyPipe } from '@angular/common';\nimport { scaleLinear, scaleUtc } from 'd3-scale';\nimport { area, line } from 'd3-shape';\nimport { utcFormat } from 'd3-time-format';\nimport { DaysPipe } from '../../format/pipes/days.pipe';\nimport { NumberPipe } from '../../format/pipes/number.pipe';\nimport { PercentagePipe } from '../../format/pipes/percentage.pipe';\nimport { SmallCurrencyPipe } from '../../format/pipes/small-currency.pipe';\n\nexport namespace Chart {\n  export const defaultColorPalette = [\n    //Base colors\n    '--baja-blast-50',\n    '--teal-diamond-50',\n    '--fyre-50',\n    '--tang-50',\n    '--purp-60',\n    '--rosi-70',\n    //Shift lighter from base by -20\n    '--baja-blast-30',\n    '--teal-diamond-30',\n    '--fyre-30',\n    '--tang-30',\n    '--purp-40',\n    '--rosi-50',\n    //Shift darker from base by +20\n    '--baja-blast-70',\n    '--teal-diamond-70',\n    '--fyre-70',\n    '--tang-70',\n    '--purp-80',\n    '--rosi-90',\n  ];\n\n  export function chart(config: Config, data: Data, dimensions: Dimensions) {\n    return config.type == 'line'\n      ? lines(config, data, dimensions)\n      : config.type == 'area'\n      ? areas(config, data, dimensions)\n      : bars(config, data, dimensions);\n  }\n  export function lines(\n    config: Config,\n    allData: Data,\n    dimensions: Dimensions,\n  ): RenderedChart {\n    const { data, visibleIndices } = hide(allData);\n    const xScale = scaleUtc(timeseriesDomain(data), xRange(dimensions));\n    const format = (date: Date) =>\n      formatedDate(config.dateFormat || 'day', date);\n\n    //Dont use auto magic when dealing with 1,2,3,4 data points\n    const xTickDates =\n      data.x.length < 5\n        ? data.x.map(x => new Date(x))\n        : xScale.ticks(Math.min(5, data.x.length));\n\n    const xTicks = xTickDates.map(tick => ({\n      x: xScale(tick),\n      label: format(tick),\n    }));\n\n    const { pipe, fullPipe } = getPipes(config.valueType);\n    const yScale = scaleLinear(yDomain(data), yRange(dimensions));\n    const yTicks = yScale.ticks(5).map(tick => ({\n      y: yScale(tick),\n      label: pipe.transform(tick),\n    }));\n\n    const colors = visibleIndices.map(\n      i => config.colors[i % config.colors.length],\n    );\n    const indices = data.x.map((_, i) => i);\n    const lines =\n      data.x.length > 1\n        ? data.ys.map(y =>\n            line<number>(\n              i => xScale(data.x[i]),\n              i => yScale(y.values[i]),\n            )(indices),\n          )\n        : [];\n    const circles =\n      data.x.length === 1\n        ? data.ys.map(ySeries => ({\n            cx: xScale(data.x[0]),\n            cy: yScale(ySeries.values[0]),\n          }))\n        : [];\n\n    function hover(pos: { rect: DOMRect; x: number; y: number }) {\n      const xIndex = findNearestIndex(data.x, xScale.invert(pos.x).getTime());\n      const x = xScale(data.x[xIndex]);\n      const visibleYIndex = findNearestIndex(\n        data.ys.map(y => y.values[xIndex]),\n        yScale.invert(pos.y),\n      );\n      const yIndex = visibleIndices[visibleYIndex];\n      const ys = data.ys.map(y => yScale(y.values[xIndex]));\n\n      const format = (date: Date) =>\n        formatedDate(config.dateFormat || 'day', date);\n\n      const anchor = new DOMRect(\n        pos.rect.x + x,\n        pos.rect.y + ys[visibleYIndex],\n        8,\n        0,\n      );\n      return {\n        x,\n        xIndex,\n        ys,\n        yIndex,\n        visibleYIndex,\n        tooltip: {\n          anchor,\n          date: format(new Date(data.x[xIndex])),\n          metrics: data.ys\n            .map((y, index) => ({\n              color: colors[index % colors.length],\n              label: y.label,\n              value: fullPipe.transform(y.values[xIndex]) ?? '-',\n            }))\n            .filter((_, i) => config.groupedTooltip || i == visibleYIndex),\n        },\n      };\n    }\n\n    return {\n      xTicks,\n      yTicks,\n      colors,\n      lines,\n      circles,\n      hover,\n      bars: [],\n      areas: [],\n    };\n  }\n\n  export function areas(\n    config: Config,\n    allData: Data,\n    dimensions: Dimensions,\n  ): RenderedChart {\n    const { data: unstackedData, visibleIndices } = hide(allData);\n    const data = stack(unstackedData);\n    const xScale = scaleUtc(timeseriesDomain(data), xRange(dimensions));\n    const format = (date: Date) =>\n      formatedDate(config.dateFormat || 'day', date);\n    const xTicks = xScale.ticks(Math.min(5, data.x.length)).map(tick => ({\n      x: xScale(tick),\n      label: format(tick),\n    }));\n\n    const { pipe, fullPipe } = getPipes(config.valueType);\n    const yScale = scaleLinear(yDomain(data), yRange(dimensions));\n    const yTicks = yScale.ticks(5).map(tick => ({\n      y: yScale(tick),\n      label: pipe.transform(tick),\n    }));\n\n    const indices = data.x.map((_, i) => i);\n    const colors = visibleIndices.map(\n      i => config.colors[i % config.colors.length],\n    );\n    const areas = data.ys.map((y, yIndex) =>\n      area<number>(\n        i => xScale(data.x[i]),\n        i => yScale(yIndex == 0 ? 0 : data.ys[yIndex - 1].values[i]),\n        i => yScale(y.values[i]),\n      )(indices),\n    );\n\n    function hover(pos: { rect: DOMRect; x: number; y: number }) {\n      const xIndex = findNearestIndex(data.x, xScale.invert(pos.x).getTime());\n      const x = xScale(data.x[xIndex]);\n      const yValue = yScale.invert(pos.y);\n      let visibleYIndex = data.ys\n        .map(y => y.values[xIndex])\n        .findIndex(y => y > yValue);\n      if (visibleYIndex == -1) {\n        visibleYIndex = data.ys.length - 1;\n      }\n      const yIndex = visibleIndices[visibleYIndex];\n      const ys = data.ys.map(y => yScale(y.values[xIndex]));\n      const padding = 8;\n      const anchor = new DOMRect(\n        pos.rect.x + x,\n        pos.rect.y + ys[visibleYIndex],\n        padding,\n        0,\n      );\n      return {\n        x,\n        xIndex,\n        ys,\n        yIndex,\n        visibleYIndex,\n        tooltip: {\n          anchor,\n          date: utcFormat('%B %d, %Y')(new Date(unstackedData.x[xIndex])),\n          metrics: unstackedData.ys\n            .map((y, index) => ({\n              color: colors[index % colors.length],\n              label: y.label,\n              value: fullPipe.transform(y.values[xIndex]) ?? '-',\n            }))\n            .filter((_, i) => config.groupedTooltip || i == visibleYIndex),\n        },\n      };\n    }\n\n    return {\n      xTicks,\n      yTicks,\n      colors,\n      areas,\n      lines: [],\n      circles: [],\n      hover,\n      bars: [],\n    };\n  }\n\n  export function bars(\n    config: Config,\n    allData: Data,\n    dimensions: Dimensions,\n  ): RenderedChart {\n    const { data: unstackedData, visibleIndices } = hide(allData);\n    const data = stack(unstackedData);\n    const { range: xRange, binSize } = barXRange(dimensions, data);\n    const halfBinSize = binSize / 2;\n    const xScale = scaleUtc(timeseriesDomain(data), xRange);\n    const format = (date: Date) =>\n      formatedDate(config.dateFormat || 'day', date);\n    const xTicks = xScale.ticks(Math.min(5, data.x.length)).map(tick => ({\n      x: xScale(tick),\n      label: format(tick),\n    }));\n\n    const { pipe, fullPipe } = getPipes(config.valueType);\n    const yScale = scaleLinear(yDomain(data), yRange(dimensions));\n    const yTicks = yScale.ticks(5).map(tick => ({\n      y: yScale(tick),\n      label: pipe.transform(tick),\n    }));\n    const colors = visibleIndices.map(\n      i => config.colors[i % config.colors.length],\n    );\n    const bars = data.ys.map((y, yIndex) =>\n      y.values.map((value, index) => {\n        const yValue = yScale(value);\n        return {\n          x: xScale(data.x[index]) - halfBinSize,\n          y: yValue,\n          width: binSize,\n          height:\n            (yIndex == 0\n              ? yScale(0)\n              : yScale(data.ys[yIndex - 1].values[index])) - yValue,\n        };\n      }),\n    );\n\n    function hover(pos: { rect: DOMRect; x: number; y: number }) {\n      const xIndex = findNearestIndex(data.x, xScale.invert(pos.x).getTime());\n      const x = xScale(data.x[xIndex]);\n      const yValue = yScale.invert(pos.y);\n      let visibleYIndex = data.ys\n        .map(y => y.values[xIndex])\n        .findIndex(y => y > yValue);\n      if (visibleYIndex == -1) {\n        visibleYIndex = data.ys.length - 1;\n      }\n      const yIndex = visibleIndices[visibleYIndex];\n      const ys = data.ys.map(y => yScale(y.values[xIndex]));\n      const padding = 8;\n      const anchor = new DOMRect(\n        pos.rect.x + bars[visibleYIndex][xIndex].x - padding,\n        pos.rect.y + ys[visibleYIndex],\n        bars[visibleYIndex][xIndex].width + padding * 2,\n        (visibleYIndex == 0 ? yScale(0) : ys[visibleYIndex - 1]) -\n          ys[visibleYIndex],\n      );\n      return {\n        x,\n        xIndex,\n        ys,\n        yIndex,\n        visibleYIndex,\n        tooltip: {\n          anchor,\n          date: utcFormat('%B %d, %Y')(new Date(unstackedData.x[xIndex])),\n          metrics: unstackedData.ys\n            .map((y, index) => ({\n              color: colors[index % colors.length],\n              label: y.label,\n              value: fullPipe.transform(y.values[xIndex]) ?? '-',\n            }))\n            .filter((_, i) => config.groupedTooltip || i == visibleYIndex),\n        },\n      };\n    }\n\n    return {\n      xTicks,\n      yTicks,\n      colors,\n      bars,\n      lines: [],\n      circles: [],\n      areas: [],\n      hover,\n    };\n  }\n\n  const LEFT_PADDING = 48;\n  const RIGHT_PADDING = 24;\n  const TOP_PADDING = 16;\n  const BOTTOM_PADDING = 24;\n\n  export type Data = {\n    ys: {\n      label: string;\n      hidden?: boolean;\n      values: number[];\n    }[];\n    x: number[];\n  };\n\n  export type Dimensions = {\n    width: number;\n    height: number;\n  };\n\n  export type Config = {\n    type: 'line' | 'area' | 'bar';\n    groupedTooltip: boolean;\n    colors: string[];\n    allowLegendToggle: boolean;\n    zeroStateMessage: string;\n    valueType: ValueType;\n    truncateLegend: boolean;\n    dateFormat?: Interval;\n  };\n\n  export const defaultConfig: Config = {\n    type: 'line',\n    groupedTooltip: true,\n    colors: defaultColorPalette,\n    allowLegendToggle: false,\n    zeroStateMessage: 'No data to display.',\n    valueType: 'currency',\n    truncateLegend: true,\n    dateFormat: 'day',\n  };\n\n  export type Area = {\n    path: string | null;\n    fill: string;\n  };\n\n  export type XTick = {\n    x: number;\n    label: string;\n  };\n\n  export type YTick = {\n    y: number;\n    label: string;\n  };\n\n  type Rect = {\n    x: number;\n    y: number;\n    width: number;\n    height: number;\n  };\n\n  export type BarSeries = {\n    fill: string;\n    rects: Rect[];\n  };\n\n  type Circle = {\n    cx: number;\n    cy: number;\n  };\n\n  // Hover is a function that takes a viewport x and y and returns a rich\n  // set of information about what values are being hovered and what the tooltip\n  // should look like\n  export type Hover = (pos: { rect: DOMRect; x: number; y: number }) => {\n    // the indices into the data of the closest point\n    xIndex: number;\n    // we want to know which visible y index is hovered\n    // and which actual y index is hovered\n    yIndex: number;\n    visibleYIndex: number;\n\n    // the viewport x and ys of the hovered items\n    x: number;\n    ys: number[];\n\n    tooltip: {\n      anchor: DOMRect;\n      date: string;\n      metrics: {\n        color: string;\n        label: string;\n        value: string;\n      }[];\n    };\n  };\n\n  // RenderedChart represents all of the parts of a chart\n  // that end up on screen. Every chart has x and y ticks\n  // and hover functionality, even though they might be\n  // different from chart to chart.\n  type RenderedChart = {\n    xTicks: XTick[];\n    yTicks: YTick[];\n    hover: Hover;\n    colors: string[];\n    lines: (string | null)[];\n    circles: Circle[]; //Line fallback for a single point\n    areas: (string | null)[];\n    bars: Rect[][];\n  };\n\n  function timeseriesDomain(data: Data) {\n    return [Math.min(...data.x), Math.max(...data.x)];\n  }\n\n  function yDomain(data: Data) {\n    const max = Math.max(...data.ys.map(y => Math.max(...y.values)));\n    return [0, max == 0 ? 1 : max];\n  }\n\n  function xRange(dimensions: Dimensions) {\n    return [LEFT_PADDING, dimensions.width - RIGHT_PADDING];\n  }\n\n  function barXRange(dimensions: Dimensions, data: Data) {\n    const left = LEFT_PADDING;\n    const right = dimensions.width - RIGHT_PADDING;\n    const width = right - left;\n    const binSize = width / (data.x.length || 1);\n    const halfBinSize = binSize / 2;\n    const range = [left + halfBinSize, right - halfBinSize];\n    return { binSize: Math.min(binSize * 0.7, 80), range };\n  }\n\n  function yRange(dimensions: Dimensions) {\n    return [dimensions.height - BOTTOM_PADDING, TOP_PADDING];\n  }\n\n  function findNearestIndex(values: number[], input: number) {\n    return values.reduce((nearestIndex, value, index) => {\n      return Math.abs(value - input) < Math.abs(values[nearestIndex] - input)\n        ? index\n        : nearestIndex;\n    }, 0);\n  }\n\n  // stack returns a new data where each set of yValues is stacked\n  // on top of the previous.\n  function stack(data: Data): Data {\n    const stacked: Data = {\n      ...data,\n      ys: data.ys.map(y => ({ label: y.label, values: [] })),\n    };\n    for (let i = 0; i < data.x.length; i++) {\n      let from = 0;\n      for (let j = 0; j < data.ys.length; j++) {\n        const to = from + data.ys[j].values[i];\n        stacked.ys[j].values.push(to);\n        from = to;\n      }\n    }\n    return stacked;\n  }\n\n  // hide strips out hidden y values while retaining the original indices\n  // for the remaining visible values\n  function hide(data: Data): { data: Data; visibleIndices: number[] } {\n    const visibleIndices = data.ys\n      .map((y, i) => ({ y, i }))\n      .filter(({ y }) => !y.hidden)\n      .map(({ i }) => i);\n    return {\n      data: { ...data, ys: visibleIndices.map(i => data.ys[i]) },\n      visibleIndices,\n    };\n  }\n\n  type ValueType = 'count' | 'currency' | 'percentage' | 'days';\n\n  export function getPipes(valueType: ValueType) {\n    switch (valueType) {\n      case 'count': {\n        const pipe = new NumberPipe();\n        return { pipe, fullPipe: pipe };\n      }\n      case 'currency':\n        return {\n          pipe: new SmallCurrencyPipe(),\n          fullPipe: new CurrencyPipe('en-us'),\n        };\n      case 'percentage': {\n        const pipe = new PercentagePipe();\n        return { pipe, fullPipe: pipe };\n      }\n      case 'days': {\n        const pipe = new DaysPipe();\n        return { pipe, fullPipe: pipe };\n      }\n    }\n  }\n\n  export const intervals = ['year', 'quarter', 'month', 'week', 'day'] as const;\n  export type Interval = (typeof intervals)[number];\n\n  export function formatedDate(dateFormat: Interval, date: Date) {\n    if (dateFormat == 'quarter') {\n      const quarter = Math.ceil((date.getUTCMonth() + 1) / 3);\n      const year = utcFormat(getTimeIntervalFormat('year'))(date);\n      return `Q${quarter} ${year}`;\n    }\n    const format = getTimeIntervalFormat(dateFormat);\n    return utcFormat(format)(date);\n  }\n\n  export function getTimeIntervalFormat(interval: Interval): string {\n    switch (interval) {\n      case 'day':\n      case 'week':\n        return '%m/%d/%Y';\n      case 'month':\n      case 'quarter':\n        return '%b %Y';\n      case 'year':\n        return '%Y';\n    }\n  }\n}\n"]}
@@ -3731,7 +3731,11 @@ var Chart;
3731
3731
  const { data, visibleIndices } = hide(allData);
3732
3732
  const xScale = scaleUtc(timeseriesDomain(data), xRange(dimensions));
3733
3733
  const format = (date) => formatedDate(config.dateFormat || 'day', date);
3734
- const xTicks = xScale.ticks(Math.min(5, data.x.length)).map(tick => ({
3734
+ //Dont use auto magic when dealing with 1,2,3,4 data points
3735
+ const xTickDates = data.x.length < 5
3736
+ ? data.x.map(x => new Date(x))
3737
+ : xScale.ticks(Math.min(5, data.x.length));
3738
+ const xTicks = xTickDates.map(tick => ({
3735
3739
  x: xScale(tick),
3736
3740
  label: format(tick),
3737
3741
  }));