.stepper-chart.svelte-r5ds0j{--max-width-outer:85vw}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"StepperChart-2021-10.svelte","sources":["StepperChart-2021-10.svelte"],"sourcesContent":["<script>\n  import { isoParse, utcFormat } from 'd3-time-format';\n  import { utcDay } from 'd3-time';\n  import { format } from 'd3-format';\n  import { color as d3Color } from 'd3-color';\n  import { scaleUtc } from 'd3-scale';\n  import { greatest, least, rollup, group } from 'd3-array';\n  import borschtColors from 'borscht/src/js/helpers/colors.js';\n  import * as formatters from 'src/js/modules/formatters.js';\n  import { selectedPlaces as selectedPlacesStores } from '../../js/modules/stores';\n  import * as Chart from '../Chart/index.js';\n  import FetchCached from '../FetchCached.svelte';\n  import Select from './Select.svelte';\n  import TooltipTemplate from './TooltipTemplate.svelte';\n\n  export let id;\n  export let region;\n\n  let chartProps = {};\n  let historicalData = {};\n  let places = [];\n\n  $: ({\n    selectItems = [],\n    selectText,\n    selectedID,\n    boldPlaceID,\n    tooltipConfig,\n    showLabels = [],\n    showTopPlace = false,\n    showBottomPlace = false,\n    yAxisLabel = undefined,\n  } = chartProps);\n\n  $: ({\n    columns = [],\n    places: historicalCompact = {},\n    extents = {},\n  } = historicalData);\n\n  $: [dateMin, dateMax] = extents?.dateString?.map((d) => isoParse(d)) || [];\n\n  $: parsedDatesArray = dateMax\n    ? utcDay.range(dateMin, utcDay.offset(dateMax))\n    : [];\n\n  $: parsedDates = new Map(\n    parsedDatesArray.map((dateObject) => [\n      utcFormat(`%Y-%m-%d`)(dateObject),\n      dateObject,\n    ])\n  );\n\n  $: placesWithData_ = places\n    .map((d) => {\n      const data_ = historicalCompact?.[d.placeID] || [];\n      const placeData = data_\n        .map((arr) =>\n          Object.fromEntries(columns.map((key, index) => [key, arr[index]]))\n        )\n        .map((d) => ({ ...d, dateObject: isoParse(d.dateString) }));\n      return {\n        ...d,\n        placeData,\n      };\n    })\n    .filter((d) => d.placeData.length > 0);\n\n  // Add date objects, get latest\n  $: placesWithDataArray = placesWithData_.map((place) => {\n    const placeData = place.placeData.map((d) => ({\n      ...d,\n      dateObject: parsedDates.get(d.dateString),\n    }));\n    return {\n      ...place,\n      latestData: greatest(placeData, (d) => d.dateObject),\n      placeData,\n    };\n  });\n\n  $: placesWithDataMap = new Map(\n    placesWithDataArray.map((d) => [d.placeID, d])\n  );\n\n  // Flatten\n  $: flat = placesWithDataArray\n    .map((place) => {\n      const { placeData, ...rest } = place;\n      return placeData.map((d) => ({ ...d, ...rest }));\n    })\n    .flat(1);\n\n  $: numYTicks = 5;\n\n  $: ({ xScale, yScale, xGet, yGet, xAccessor, yAccessor } = Chart.getScales({\n    x: {\n      key: `dateObject`,\n      scaleFunction: scaleUtc,\n      domain: extents?.dateString?.map((d) => isoParse(d)) || [],\n      nice: false,\n      clamp: true,\n    },\n    y: {\n      key: `noDosesTotalPer100`,\n      domain: extents?.noDosesTotalPer100 || [],\n      nice: numYTicks,\n    },\n  }));\n\n  $: mappedPoints = flat.map((d) => {\n    return {\n      ...d,\n      x: xGet(d),\n      y: yGet(d),\n    };\n  });\n\n  $: delaunayPoints = mappedPoints.filter((d) =>\n    selectedID ? d.placeID === selectedID : true\n  );\n\n  $: selectedPlacesStore = selectedPlacesStores[region];\n\n  let firstStoreValue = true;\n  let selectedPlaceHasChanged = false;\n\n  $: if (selectedPlacesStore) {\n    (() => {\n      const selectedStoreValue = $selectedPlacesStore;\n      if (selectItems.map((d) => d.value).includes(selectedStoreValue)) {\n        // Don't set the selectedID to boldPlaceID, unless\n        if (!selectedPlaceHasChanged) {\n          if (\n            typeof selectedStoreValue === 'undefined' ||\n            selectedStoreValue === boldPlaceID\n          ) {\n            return;\n          } else {\n            selectedPlaceHasChanged = true;\n          }\n        }\n        selectedID = selectedStoreValue;\n      }\n    })();\n  }\n\n  let hoverData;\n  let hoverX;\n  let hoverY;\n\n  $: hoverID = hoverData?.placeID || null;\n\n  $: baseLineOpacity = region === `usa` ? 0.5 : 0.5;\n  $: baseLineColor = d3Color(borschtColors[`mint-darker-1`]).copy({\n    opacity: baseLineOpacity,\n  });\n  $: baseLineWidth = 1;\n\n  $: boldLineColor = `black`;\n  $: boldLineWidth = 2;\n\n  $: selectedLineColor = borschtColors[`mint-darker-3`];\n  $: selectedLineWidth = 2;\n\n  $: selectedValue =\n    typeof selectedID === 'string' && selectedID !== 'BBG'\n      ? { value: selectedID }\n      : null;\n\n  $: topPlace = greatest(placesWithDataArray, (d) => yAccessor(d.latestData));\n\n  $: bottomPlace = least(placesWithDataArray, (d) => yAccessor(d.latestData));\n\n  $: alwaysShowIDs = [\n    ...showLabels,\n    boldPlaceID,\n    showTopPlace && topPlace?.placeID,\n    showBottomPlace && bottomPlace?.placeID,\n  ].filter((d) => d);\n\n  $: labelIDs = [...alwaysShowIDs, selectedID || hoverID].filter((d) => d);\n\n  $: labelProps = labelIDs\n    .map((placeID) => {\n      const place = placesWithDataMap.get(placeID);\n      if (!place) return null;\n      const { latestData, nameShort } = place;\n      return {\n        placeID,\n        left: 100,\n        top: yGet(latestData),\n        text: nameShort,\n      };\n    })\n    .filter((d) => d);\n\n  let euNudge = 0;\n  let usNudge = 0;\n\n  // Nudge labels :(\n  $: {\n    const euPosition = labelProps.find((d) => d.placeID === `BBG-EU`)?.top;\n    const usPosition = labelProps.find((d) => d.placeID === `USA`)?.top;\n    if (euPosition && usPosition) {\n      const distance = Math.abs(euPosition - usPosition);\n      const targetDistance = 4;\n      if (distance < targetDistance) {\n        const nudgeAmount = (targetDistance - distance) / 2;\n        if (euPosition > usPosition) {\n          euNudge = +nudgeAmount;\n          usNudge = -nudgeAmount;\n        } else {\n          euNudge = -nudgeAmount;\n          usNudge = +nudgeAmount;\n        }\n      }\n    }\n  }\n\n  $: getNudge = (placeID, top) => {\n    if (placeID === `BBG-EU`) return top + euNudge + 0.1;\n    if (placeID === `USA`) return top + usNudge + 0.1;\n    return top;\n  };\n\n  const drawPlaceData = ({ context, placeData, width, height }) => {\n    for (const [index, d] of placeData.entries()) {\n      // const { dateString } = d;\n      const x = (xGet(d) / 100) * width;\n      const y = (yGet(d) / 100) * height;\n      if (index === 0) {\n        context.moveTo(x, y);\n      } else {\n        context.lineTo(x, y);\n      }\n    }\n  };\n</script>\n\n<FetchCached path=\"data/charts/{id}.json\" bind:data={chartProps} />\n<FetchCached\n  path=\"data/charts/{region}-historical-doses-total.json\"\n  bind:data={historicalData}\n/>\n<FetchCached path=\"data/charts/{region}-places.json\" bind:data={places} />\n<div class=\"stepper-chart\">\n  <Select\n    items={selectItems}\n    placeholder={selectText}\n    value={selectedValue}\n    on:select={(event) => {\n      selectedID = event.detail.value;\n      if (selectedPlacesStore) $selectedPlacesStore = selectedID;\n    }}\n    on:clear={() => {\n      selectedID = null;\n      if (selectedPlacesStore) $selectedPlacesStore = null;\n    }}\n  />\n  <div style=\"height: 3rem;\" />\n  <Chart.Container --height=\"400px\" --max-width=\"var(--max-width-outer)\">\n    <Chart.Container --height=\"100%\" --width=\"84%\" --margin=\"0\">\n      <!-- Canvas for all the lines -->\n      <Chart.Canvas\n        render={({ context, width, height }) => {\n          context.clearRect(0, 0, width, height);\n          // Draw all the lines\n          for (const { placeData } of placesWithDataArray) {\n            context.beginPath();\n            drawPlaceData({ placeData, context, width, height });\n            context.strokeStyle = baseLineColor;\n            context.lineWidth = baseLineWidth;\n            context.stroke();\n          }\n\n          // Draw the bold line\n          if (boldPlaceID) {\n            const found = placesWithDataMap.get(boldPlaceID);\n            if (found) {\n              context.beginPath();\n              drawPlaceData({\n                placeData: found.placeData,\n                context,\n                width,\n                height,\n              });\n              context.strokeStyle = boldLineColor;\n              context.lineWidth = boldLineWidth;\n              context.stroke();\n            }\n          }\n        }}\n      />\n      <!-- Draw lines for places in alwaysShowIDs -->\n      <Chart.Canvas\n        render={({ context, width, height }) => {\n          context.clearRect(0, 0, width, height);\n          if (!selectedID && !hoverID) {\n            context.beginPath();\n            for (const placeID of alwaysShowIDs) {\n              const found = placesWithDataMap.get(placeID);\n              if (found) {\n                drawPlaceData({\n                  placeData: found.placeData,\n                  context,\n                  width,\n                  height,\n                });\n              }\n            }\n            context.strokeStyle = selectedLineColor;\n            context.lineWidth = selectedLineWidth;\n            context.stroke();\n          }\n        }}\n      />\n      <!-- Canvas for current selected lines -->\n      <Chart.Canvas\n        render={({ context, width, height }) => {\n          context.clearRect(0, 0, width, height);\n          // This is important: prioritize selectedID over hoverID\n          const found = placesWithDataMap.get(selectedID || hoverID);\n          if (found) {\n            context.beginPath();\n            drawPlaceData({\n              placeData: found.placeData,\n              context,\n              width,\n              height,\n            });\n            context.strokeStyle = selectedLineColor;\n            context.lineWidth = selectedLineWidth;\n            context.stroke();\n          }\n        }}\n      />\n      <Chart.TooltipScreen\n        {delaunayPoints}\n        bind:data={hoverData}\n        bind:x={hoverX}\n        bind:y={hoverY}\n        on:click={() => {\n          selectedID = hoverID;\n        }}\n      />\n      {#if hoverData}\n        <Chart.Tooltip left=\"{hoverX}%\" top=\"{hoverY}%\">\n          <TooltipTemplate data={hoverData} {tooltipConfig} />\n        </Chart.Tooltip>\n      {/if}\n\n      <!-- LABELS -->\n      <div class=\"labels\">\n        {#each labelProps as { left, top, text, placeID }}\n          <Chart.Text\n            shadow\n            --left=\"{left}%\"\n            --top=\"{getNudge(placeID, top)}%\"\n            --transform=\"translateY(-50%) translateX(5px)\"\n          >\n            {text}\n          </Chart.Text>\n        {/each}\n      </div>\n      <Chart.XAxis scale={xScale} format={utcFormat('%b')} />\n    </Chart.Container>\n    <Chart.HorizontalLine --top=\"{yScale(0)}%\" --width=\"calc(100% + 7px)\" />\n    <Chart.YAxis\n      scale={yScale}\n      numTicks={numYTicks}\n      format={(d) => (d === 0 ? `0` : d)}\n      tickWidth={50}\n      prefix={`${yAxisLabel}:&ensp;`}\n      autoTickWidth\n    />\n  </Chart.Container>\n  <div style=\"height: 3rem;\" />\n</div>\n\n<style>\n  .stepper-chart {\n    --max-width-outer: 85vw;\n  }</style>\n"],"names":[],"mappings":"AA6XE,cAAc,cAAC,CAAC,AACd,iBAAiB,CAAE,IAAI,AACzB,CAAC"} */.charts.svelte-1vqlrvv{display:grid;row-gap:5rem}.listItem span.value,.selectedItem span.value{font-size:.875rem}.listItem span.bold{font-weight:700}.listItem span.value span.suffix{display:none}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"CasesVsDoses-2021-10.svelte","sources":["CasesVsDoses-2021-10.svelte"],"sourcesContent":["<script>\n  // @ts-check\n  import { writable } from 'svelte/store';\n  import borschtColors from 'borscht/src/js/helpers/colors.js';\n  import { line as d3Line, curveStepAfter } from 'd3-shape';\n  import { scaleUtc, scaleBand } from 'd3-scale';\n  import { format } from 'd3-format';\n  import { utcDay } from 'd3-time';\n  import { isoParse, utcFormat } from 'd3-time-format';\n  import { greatest, least, rollup, group, extent, max } from 'd3-array';\n  import { apnumber } from 'journalize';\n  import { selectedPlaces as selectedPlacesStores } from '../../js/modules/stores';\n  import * as formatters from '../../js/modules/formatters.js';\n  import { getDataFormatter } from '../../js/modules/formatters';\n  import * as Chart from '../Chart/index.js';\n  import FetchCached from '../FetchCached.svelte';\n  import Select from './Select.svelte';\n  import TooltipTemplate from './TooltipTemplate.svelte';\n\n  export let id;\n  export let region;\n  export let covidCases;\n\n  let chartProps = {};\n  let historicalData = {};\n  let places = [];\n  let container;\n\n  $: ({\n    selectItems: selectItems_ = [],\n    selectText,\n    defaultID,\n    selectedID = defaultID,\n    casesChartConfig = {},\n    vaccinesChartConfig = {},\n    thresholdValue = 0,\n    noPeopleTotalPerCapita = {},\n  } = chartProps);\n\n  $: ({\n    columns = [],\n    places: historicalCompact = {},\n    extents = {},\n  } = historicalData);\n\n  $: [dateMin, dateMax] = extents?.dateString?.map((d) => isoParse(d)) || [];\n\n  $: parsedDatesArray = dateMax\n    ? utcDay.range(dateMin, utcDay.offset(dateMax))\n    : [];\n\n  $: parsedDates = new Map(\n    parsedDatesArray.map((dateObject) => [\n      utcFormat(`%Y-%m-%d`)(dateObject),\n      dateObject,\n    ])\n  );\n\n  $: dateStrings = [...parsedDates.keys()];\n\n  $: placesWithData_ = places\n    .map((d) => {\n      const placeData =\n        historicalCompact?.[d.placeID]?.map((arr) => {\n          return Object.fromEntries(\n            columns.map((key, index) => [key, arr[index]])\n          );\n        }) || [];\n      return {\n        ...d,\n        placeData,\n      };\n    })\n    .filter((d) => d.placeData.length);\n\n  // Add date objects, get latest\n  $: placesWithDataArray = placesWithData_.map((place) => {\n    const placeData = place.placeData.map((d) => ({\n      ...d,\n      dateObject: parsedDates.get(d.dateString),\n    }));\n    return {\n      ...place,\n      latestData: greatest(placeData, (d) => d.dateObject),\n      placeData,\n    };\n  });\n\n  $: placesWithDataMap = new Map(\n    placesWithDataArray.map((d) => [d.placeID, d])\n  );\n\n  $: covidCasesData = covidCases[region];\n\n  $: if (region === `usa`) {\n    // To find u.s. covid cases in global, and merge into state-level data\n    // The date range for the global feed may not match the U.S.\n    const usaCovidCases = covidCases.global.data.USA;\n    const globalDateColumns = covidCases.global.dateColumns;\n    const usaCovidCasesAlignedDates = covidCasesData.dateColumns.map(\n      (dateString) => {\n        const globalDateIndex = globalDateColumns.indexOf(dateString);\n        if (globalDateIndex >= 0) return usaCovidCases[globalDateIndex];\n        return null;\n      }\n    );\n    covidCasesData.data.USA = usaCovidCasesAlignedDates;\n  }\n\n  $: selectItems = selectItems_.filter((d) => {\n    return covidCasesData?.data?.[d.placeID];\n  });\n\n  $: selectedPlacesStore = selectedPlacesStores[region];\n\n  $: if (selectedPlacesStore) {\n    const selectedStoreValue = $selectedPlacesStore;\n    if (selectItems.map((d) => d.value).includes(selectedStoreValue)) {\n      selectedID = selectedStoreValue;\n    }\n  }\n\n  $: ({ scale: xScale, get: xGet } = Chart.getScale({\n    key: `dateObject`,\n    scaleFunction: scaleUtc,\n    domain: [dateMin, dateMax],\n    nice: false,\n    clamp: true,\n  }));\n\n  $: ({ scale: xBandScale, get: xBandGet } = Chart.getScale({\n    key: `dateString`,\n    scaleFunction: scaleBand,\n    domain: dateStrings,\n    padding: 0,\n  }));\n\n  $: population = placesWithDataMap.get(selectedID)?.population;\n\n  $: dosesDataForPlace = placesWithDataMap?.get(selectedID) || {};\n\n  $: covidCasesDataForPlace = covidCasesData?.data?.[selectedID]?.map(\n    ([dateString, newCases, movingAverage]) => {\n      return {\n        dateString,\n        dateObject: isoParse(dateString),\n        newCases,\n        movingAverage,\n      };\n    }\n  );\n\n  let mungedCasesData = [];\n  $: {\n    // Calculate cases per capita\n    if (population && covidCasesDataForPlace) {\n      mungedCasesData = covidCasesDataForPlace.map((d) => {\n        const { newCases, movingAverage } = d;\n        const newCasesPerCapita = newCases / population;\n        const movingAveragePerCapita = movingAverage / population;\n        const newCasesPerMillion = newCasesPerCapita * 1e6;\n        const movingAveragePerMillion = movingAveragePerCapita * 1e6;\n        return {\n          ...d,\n          newCasesPerMillion,\n          movingAveragePerMillion,\n        };\n      });\n    }\n  }\n\n  const tooltipDateStringStore = writable();\n\n  $: {\n    if (!selectedID) {\n      selectedID = defaultID;\n    }\n  }\n\n  $: chartConfigs = [\n    // VACCINES CHART CONFIG\n    (() => {\n      const { placeData = [] } = dosesDataForPlace;\n\n      const { scale: yScale, get: yGet } = Chart.getScale({\n        data: placeData,\n        key: `noDosesTotalPerCapita`,\n        range: [100, 0],\n        min: 0,\n        nice: 3,\n      });\n\n      const pathData = placeData.map((d) => {\n        const x = xGet(d);\n        const y = yGet(d);\n        const defined = Number.isFinite(x) && Number.isFinite(y);\n        return {\n          ...d,\n          defined,\n          x,\n          y,\n        };\n      });\n\n      const render = ({\n        context,\n        width: canvasWidth,\n        height: canvasHeight,\n      }) => {\n        context.clearRect(0, 0, canvasWidth, canvasHeight);\n\n        const pathFunc = /** @type {import('d3-shape').Line<any>} */ (d3Line())\n          .defined((d) => d.defined)\n          .x((d) => d.x)\n          .y((d) => d.y)\n          .context(context)\n          .curve(curveStepAfter);\n\n        const pathDataFinal = pathData.map((d) => {\n          const x = (d.x / 100) * canvasWidth;\n          const y = (d.y / 100) * canvasHeight;\n          return {\n            ...d,\n            x,\n            y,\n          };\n        });\n\n        context.beginPath();\n        pathFunc(pathDataFinal);\n        context.lineWidth = 2;\n        context.strokeStyle = borschtColors[`mint`];\n        context.stroke();\n      };\n\n      const tooltipConfig = vaccinesChartConfig?.tooltip?.map((obj) => {\n        if (obj.formatter in formatters) {\n          return {\n            ...obj,\n            formatFunc: formatters[obj.formatter],\n          };\n        }\n        return obj;\n      });\n\n      const delaunayPoints = pathData.filter((d) => d.defined);\n\n      return {\n        yScale,\n        numYTicks: 3,\n        yAxisFormat: getDataFormatter(vaccinesChartConfig.dataFormat), // (d) => (d === 0 ? `0` : format(`.1f`)(d)),\n        yAxisPrefix: `${vaccinesChartConfig.yAxisLabel}:&ensp;`,\n        render,\n        delaunayPoints,\n        tooltipConfig,\n      };\n    })(),\n    // COVID CASES CHART CONFIG\n    (() => {\n      const numYTicks = 3;\n\n      let yMax = +max(mungedCasesData, (d) => d.newCasesPerMillion);\n\n      if (yMax < 1e3) yMax = 1e3;\n\n      const { scale: yScale } = Chart.getScale({\n        domain: [0, yMax],\n        range: [100, 0],\n        nice: numYTicks,\n      });\n\n      const pathData = mungedCasesData.map((d) => {\n        const x = xScale(d.dateObject);\n        const y = yScale(d.movingAveragePerMillion);\n        const defined = d.movingAveragePerMillion > 0;\n        return {\n          ...d,\n          defined,\n          x,\n          y,\n        };\n      });\n\n      const render = ({\n        context,\n        width: canvasWidth,\n        height: canvasHeight,\n      }) => {\n        context.clearRect(0, 0, canvasWidth, canvasHeight);\n        for (const d of mungedCasesData) {\n          const x = xBandScale(d.dateString);\n          const y = yScale(d.newCasesPerMillion);\n          const height = Math.abs(yScale(0) - y);\n          if (!x) continue;\n          const rectX = (x / 100) * canvasWidth;\n          const rectY = (y / 100) * canvasHeight;\n          const rectHeight = (height / 100) * canvasHeight;\n          const rectWidth = (xBandScale.bandwidth() / 100) * canvasWidth;\n          context.fillStyle = borschtColors.gray1;\n          context.fillRect(rectX, rectY, rectWidth, rectHeight);\n        }\n\n        const pathDataFinal = pathData.map((d) => {\n          const x = (d.x / 100) * canvasWidth;\n          const y = (d.y / 100) * canvasHeight;\n          return {\n            ...d,\n            x,\n            y,\n          };\n        });\n\n        const pathFunc = /** @type {import('d3-shape').Line<any>} */ (d3Line())\n          .defined((d) => d.defined)\n          .x((d) => d.x)\n          .y((d) => d.y)\n          .context(context);\n\n        context.beginPath();\n        pathFunc(pathDataFinal);\n        context.lineWidth = 2;\n        context.strokeStyle = `black`;\n        context.stroke();\n      };\n\n      const tooltipConfig = [\n        {\n          ...casesChartConfig?.tooltip?.[0],\n          formatFunc: (d) => {\n            if (d === 0) return 0;\n            if (d < 0.05) return `<0.1`;\n            if (d < 1.95) return format(`.1f`)(d);\n            return format(`,.0f`)(d);\n          },\n        },\n      ];\n\n      const delaunayPoints = pathData.filter((d) => d.defined);\n\n      return {\n        yScale,\n        numYTicks,\n        yAxisFormat: (d) => (d === 0 ? `0` : format(`,.0f`)(d)),\n        yAxisPrefix: `${casesChartConfig.yAxisLabel}:&ensp;`,\n        render,\n        delaunayPoints,\n        tooltipConfig,\n      };\n    })(),\n  ];\n\n  /**\n   * We need to put the tooltip data in a separate dynamic block to prevent\n   * the chart from re-rendering every time the tooltip data changes\n   */\n  $: tooltipDatas = chartConfigs.map((d) => {\n    return d.delaunayPoints.find(\n      (d) => d.dateString === $tooltipDateStringStore\n    );\n  });\n\n  $: {\n    if (container) {\n      // Sets the dek of this component (outside the svelte), when possible\n      const figure = container.closest('figure');\n      const spanNbThreshold = figure.querySelector('span.places-threshold');\n      if (spanNbThreshold && selectItems.length) {\n        // const validValues = selectItems\n        //   .map((d) => d.sortValue)\n        //   .filter((d) => typeof d === 'number' && d >= thresholdValue);\n        const validValues = selectItems\n          .map((d) => {\n            return noPeopleTotalPerCapita[d.placeID];\n          })\n          .filter((d) => Number.isFinite(d) && d >= thresholdValue);\n        spanNbThreshold.innerText = validValues.length\n          ? apnumber(validValues.length)\n          : '';\n      }\n      const spanThreshold = figure.querySelector(`span.threshold`);\n      if (\n        spanThreshold &&\n        !Number.isNaN(thresholdValue) &&\n        thresholdValue > 0\n      ) {\n        // Dynamically set threshold in dek, if it exists\n        spanThreshold.innerText = getDataFormatter('percent')(thresholdValue);\n      }\n    }\n  }\n</script>\n\n<FetchCached path=\"data/charts/{id}.json\" bind:data={chartProps} />\n<FetchCached\n  path=\"data/charts/{region}-historical-doses-total.json\"\n  bind:data={historicalData}\n/>\n<FetchCached path=\"data/charts/{region}-places.json\" bind:data={places} />\n\n<div class=\"cases-vs-vaccines\" bind:this={container}>\n  <div class=\"copy-width\">\n    <Select\n      skipFirst\n      items={selectItems}\n      placeholder={selectText}\n      value={{ value: selectedID }}\n      on:select={(event) => {\n        selectedID = event.detail.value;\n        if (selectedPlacesStore) $selectedPlacesStore = selectedID;\n      }}\n      on:clear={() => {\n        selectedID = null;\n        if (selectedPlacesStore) $selectedPlacesStore = null;\n      }}\n    />\n    <div style=\"height: 5rem;\" />\n    <div class=\"charts\">\n      {#each chartConfigs as config, index}\n        <Chart.Container --height=\"200px\" --width=\"calc(100% - 30px)\">\n          <Chart.Canvas render={config.render || (() => {})} />\n          <Chart.HorizontalLine\n            --top=\"{config.yScale(0)}%\"\n            --width=\"calc(100% + 7px)\"\n          />\n          <Chart.XAxis scale={xScale} format={utcFormat('%b')} />\n          <Chart.YAxis\n            scale={config.yScale}\n            numTicks={config.numYTicks}\n            format={config.yAxisFormat}\n            tickWidth={50}\n            prefix={config.yAxisPrefix}\n            autoTickWidth\n          />\n          <Chart.TooltipScreen\n            delaunayPoints={config.delaunayPoints || []}\n            horizontalOnly={true}\n            on:data={(event) => {\n              if (event) {\n                $tooltipDateStringStore = event?.detail?.dateString;\n              } else {\n                $tooltipDateStringStore = null;\n              }\n            }}\n          />\n          {#if tooltipDatas[index]}\n            <Chart.Tooltip\n              left=\"{tooltipDatas[index].x}%\"\n              top=\"{tooltipDatas[index].y}%\"\n            >\n              <TooltipTemplate\n                data={tooltipDatas[index]}\n                tooltipConfig={config.tooltipConfig}\n                hideTooltipName\n              />\n            </Chart.Tooltip>\n          {/if}\n        </Chart.Container>\n      {/each}\n    </div>\n    <div style=\"height: 5rem;\" />\n  </div>\n</div>\n\n<style lang=\"scss\">.charts{display:grid;row-gap:5rem}:global(.listItem span.value),:global(.selectedItem span.value){font-size:.875rem}:global(.listItem span.bold){font-weight:700}:global(.listItem span.value span.suffix){display:none}</style>\n"],"names":[],"mappings":"AA+cmB,sBAAO,CAAC,QAAQ,IAAI,CAAC,QAAQ,IAAI,CAAC,AAAQ,oBAAoB,AAAC,CAAC,AAAQ,wBAAwB,AAAC,CAAC,UAAU,OAAO,CAAC,AAAQ,mBAAmB,AAAC,CAAC,YAAY,GAAG,CAAC,AAAQ,gCAAgC,AAAC,CAAC,QAAQ,IAAI,CAAC"} */.rates-chart.svelte-9pvome{--container-max-width:85vw}.summary.svelte-9pvome{min-height:67px}@media(min-width: 600px){.summary.svelte-9pvome{min-height:84px}}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"RatesChart-2021-10.svelte","sources":["RatesChart-2021-10.svelte"],"sourcesContent":["<script>\n  // @ts-check\n  import borschtColors from 'borscht/src/js/helpers/colors.js';\n  import { scaleUtc, scaleBand } from 'd3-scale';\n  import { isoParse, utcFormat } from 'd3-time-format';\n  import { greatest, least, rollup, group, extent, max } from 'd3-array';\n  import { selectedPlaces as selectedPlacesStores } from 'src/js/modules/stores';\n  import FetchCached from '../FetchCached.svelte';\n  import Select from './Select.svelte';\n  import * as Chart from '../Chart/index.js';\n  import TooltipTemplate from './TooltipTemplate.svelte';\n\n  export let id;\n  export let region;\n\n  let chartProps = {};\n  let vaccinationRates = {};\n\n  $: ({\n    yAxisLabel = ``,\n    tooltipConfig = [],\n    mungedSummaryTextObject = {},\n    selectItems = [],\n    selectText,\n    selectedID,\n    defaultID,\n  } = chartProps);\n\n  $: selectedPlacesStore = selectedPlacesStores[region];\n\n  let firstStoreValue = true;\n\n  $: if (selectedPlacesStore) {\n    const selectedStoreValue = $selectedPlacesStore;\n    if (selectItems.map((d) => d.value).includes(selectedStoreValue)) {\n      if (firstStoreValue) {\n        firstStoreValue = false;\n      } else {\n        selectedID = selectedStoreValue;\n      }\n    }\n  }\n\n  let summaryText = null;\n\n  $: {\n    const found = mungedSummaryTextObject[selectedID];\n    if (found) {\n      summaryText = found;\n    }\n  }\n\n  $: dataForPlace = vaccinationRates?.[selectedID] || [];\n\n  $: munged = dataForPlace.map(([dateString, deltaPrevious, average]) => ({\n    dateString,\n    dateObject: isoParse(dateString),\n    deltaPrevious,\n    average,\n  }));\n\n  $: dateStrings = munged.map((d) => d.dateString);\n\n  $: ({ xScale, yScale, xGet, yGet } = Chart.getScales({\n    data: munged,\n    x: {\n      key: `dateObject`,\n      scaleFunction: scaleUtc,\n      nice: false,\n    },\n    y: {\n      key: `deltaPrevious`,\n      min: 0,\n      maxFunc: (data, accessor) => max(data, accessor) || 100,\n      nice: 3,\n    },\n  }));\n\n  $: ({ scale: xScaleBand, get: xGetBand } = Chart.getScale({\n    key: `dateString`,\n    scaleFunction: scaleBand,\n    domain: dateStrings,\n    padding: 0,\n  }));\n\n  // $: console.log('DATA FOR PLACE', yScale.domain(), yScale.range());\n\n  $: yMax = yScale.domain()[1];\n\n  const roundYTick = (d) => {\n    return yMax >= 1e9\n      ? d / 1e9\n      : yMax >= 1e6\n      ? d / 1e6\n      : yMax >= 1e3\n      ? d / 1e3\n      : d;\n  };\n\n  const yTickFormat = (d, index, arr) => {\n    const rounded = roundYTick(d);\n    const maybe = rounded.toFixed(yMax >= 1e3 ? 1 : 0);\n    const hasDecimal = arr.some((dd) => {\n      const rounded = roundYTick(dd);\n      return rounded.toFixed(1).match(/\\.[1-9]/);\n    });\n    const out = hasDecimal ? maybe : rounded.toFixed(0);\n    return out === `0.0` ? `0` : out;\n  };\n\n  $: yTickSuffix =\n    yMax > 1e9 ? 'B' : yMax > 1e6 ? 'M' : yMax > 1e3 ? 'K' : null;\n\n  $: pathData = munged.map((d) => {\n    const x = xGet(d);\n    const y = yScale(d.average);\n    const defined = Number.isFinite(x) && Number.isFinite(y);\n    return {\n      ...d,\n      defined,\n      x,\n      y,\n    };\n  });\n\n  $: delaunayPoints = pathData.filter((d) => d.defined);\n\n  $: render = ({ context, width: canvasWidth, height: canvasHeight }) => {\n    context.clearRect(0, 0, canvasWidth, canvasHeight);\n\n    for (const d of munged) {\n      const x = xGetBand(d);\n      const y = yGet(d);\n      const height = Math.abs(yScale(0) - y);\n      if (!x) continue;\n      const rectX = (x / 100) * canvasWidth;\n      const rectY = (y / 100) * canvasHeight;\n      const rectHeight = (height / 100) * canvasHeight;\n      const rectWidth = (xScaleBand.bandwidth() / 100) * canvasWidth;\n      context.fillStyle = borschtColors[`mint-lighter-2`];\n      context.fillRect(rectX, rectY, rectWidth, rectHeight);\n    }\n  };\n</script>\n\n<FetchCached path=\"data/charts/{id}.json\" bind:data={chartProps} />\n<FetchCached\n  path=\"data/charts/{region}-historical-doses-total-rates.json\"\n  bind:data={vaccinationRates}\n/>\n\n<div class=\"rates-chart\">\n  <div style=\"height: 10px\" />\n  <div class=\"haas-text summary\">\n    {#if summaryText}{@html summaryText}{/if}\n  </div>\n  <div style=\"height: 20px\" />\n  <Select\n    skipFirst\n    value={{ value: selectedID }}\n    items={selectItems}\n    placeholder={selectText}\n    on:select={(event) => {\n      selectedID = event.detail.value;\n      if (selectedPlacesStore) $selectedPlacesStore = selectedID;\n    }}\n    on:clear={() => {\n      selectedID = defaultID;\n      if (selectedPlacesStore) $selectedPlacesStore = null;\n    }}\n  />\n  <div style=\"height: 30px\" />\n\n  <Chart.Container --height=\"200px\" --max-width=\"var(--container-max-width)\">\n    <!-- <Chart.XAxis scale={xScale} format={utcFormat('%b')} /> -->\n    <Chart.Canvas {render} />\n    <Chart.Path\n      data={pathData}\n      defined={(d) => d.defined}\n      --stroke-width=\"2px\"\n    />\n    <Chart.XAxis scale={xScale} format={utcFormat('%b')} />\n    <Chart.YAxis\n      scale={yScale}\n      format={yTickFormat}\n      prefix={`${yAxisLabel}:&ensp;`}\n      suffix={yTickSuffix}\n      autoTickWidth\n    />\n    <Chart.TooltipScreen\n      delaunayPoints={delaunayPoints || []}\n      horizontalOnly={true}\n      let:data\n    >\n      <Chart.Tooltip left=\"{data.x}%\" top=\"{data.y}%\">\n        <TooltipTemplate {data} {tooltipConfig} hideTooltipName />\n      </Chart.Tooltip>\n    </Chart.TooltipScreen>\n  </Chart.Container>\n  <div style=\"height: 3rem;\" />\n</div>\n\n<!-- <TimeSeriesRatesChart\n  {...amlData}\n  data={ratesData || {}}\n  places={places || []}\n  placeIDs={[selectedID]}\n/> -->\n<style>\n  .rates-chart {\n    --container-max-width: 85vw;\n  }\n  .summary {\n    min-height: 67px;\n  }\n  @media (min-width: 600px) {\n    .summary {\n      min-height: 84px;\n    }\n  }</style>\n"],"names":[],"mappings":"AAiNE,YAAY,cAAC,CAAC,AACZ,qBAAqB,CAAE,IAAI,AAC7B,CAAC,AACD,QAAQ,cAAC,CAAC,AACR,UAAU,CAAE,IAAI,AAClB,CAAC,AACD,MAAM,AAAC,YAAY,KAAK,CAAC,AAAC,CAAC,AACzB,QAAQ,cAAC,CAAC,AACR,UAAU,CAAE,IAAI,AAClB,CAAC,AACH,CAAC"} */.graphic.svelte-bda6i4{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;margin-top:var(--margin-top-bottom);margin-bottom:var(--margin-top-bottom)}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU3RhY2tlZEJhcnMuc3ZlbHRlIiwic291cmNlcyI6WyJTdGFja2VkQmFycy5zdmVsdGUiXSwic291cmNlc0NvbnRlbnQiOlsiPHNjcmlwdD5cbiAgaW1wb3J0IHsgc2V0Q29udGV4dCB9IGZyb20gJ3N2ZWx0ZSc7XG4gIGltcG9ydCB7IHdyaXRhYmxlIH0gZnJvbSAnc3ZlbHRlL3N0b3JlJztcbiAgaW1wb3J0IHsgc3VtIH0gZnJvbSAnZDMtYXJyYXknO1xuICBpbXBvcnQgQmFyIGZyb20gJy4vQmFyLnN2ZWx0ZSc7XG4gIGltcG9ydCBKb2luZXIgZnJvbSAnLi9Kb2luZXIuc3ZlbHRlJztcbiAgaW1wb3J0IExpbmVyIGZyb20gJy4vTGluZXIuc3ZlbHRlJztcbiAgaW1wb3J0IHsgY29sb3JzIGFzIGJvcnNjaHRDb2xvcnMgfSBmcm9tICdib3JzY2h0JztcbiAgaW1wb3J0IENoYXJ0S2V5IGZyb20gJy4uL0NoYXJ0Q29tcG9uZW50cy9DaGFydEtleV92Mi5zdmVsdGUnO1xuICBleHBvcnQgbGV0IGRhdGE7XG4gIGV4cG9ydCBsZXQgaWRGaWVsZCA9ICdpc28nXG4gIGV4cG9ydCBsZXQgdmFjY2luZXNDaGFydENvbmZpZztcbiAgZXhwb3J0IGxldCBwb3B1bGF0aW9uQ2hhcnRDb25maWc7XG4gIGV4cG9ydCBsZXQgY29sb3JzO1xuICBleHBvcnQgbGV0IGNvdW50cnlDdXRvZmY7XG5cbiAgY29uc3QgTU9CSUxFX1dJRFRIID0gNDIwO1xuICBsZXQgY2hhcnRDb250YWluZXJXaWR0aDtcblxuICBsZXQgaG92ZXJJRENvdW50cnkgPSBudWxsO1xuICBsZXQgaG92ZXJJREdyb3VwID0gbnVsbDtcbiAgbGV0IHNob3dMaW5lcyA9IGZhbHNlO1xuICBjb25zdCBzb3J0S2V5ID0gJ2dkcF9wcHAnO1xuICBjb25zdCBsYWJlbFdpZHRoID0gODA7XG5cbiAgJDogaXNNb2JpbGUgPSBjaGFydENvbnRhaW5lcldpZHRoIC0gbGFiZWxXaWR0aCA8PSBNT0JJTEVfV0lEVEg7XG5cbiAgJDogY2hhcnRQcm9wcyA9IHtcbiAgICAuLi4kJHByb3BzLFxuICB9O1xuXG4gICQ6IGRhdGFGaWx0ZXJlZCA9IGRhdGFcbiAgICAuZmlsdGVyKChkKSA9PiB0eXBlb2YgZFtzb3J0S2V5XSA9PT0gJ251bWJlcicgJiYgZFtzb3J0S2V5XSA+IDApXG4gICAgLmZpbHRlcigoZCkgPT4gZC5ub0Rvc2VzVG90YWwpXG4gICAgLmZpbHRlcigoZCkgPT4gZC5wb3B1bGF0aW9uKVxuICAgIC5maWx0ZXIoKGQpID0+IGQucGFyZW50SXNvID09PSBudWxsKTtcblxuICAkOiB7XG4gICAgZGF0YUZpbHRlcmVkLnNvcnQoKGEsIGIpID0+IGFbc29ydEtleV0gLSBiW3NvcnRLZXldKTtcbiAgfVxuXG4gICQ6IGNoYXJ0S2V5SXRlbXMgPSBjb2xvcnMubWFwKChkKSA9PiB7XG4gICAgcmV0dXJuIHtcbiAgICAgIGNvbG9yOiBib3JzY2h0Q29sb3JzW2RdIHx8IGQsXG4gICAgICB0eXBlOiAnc3F1YXJlJyxcbiAgICAgIHdpZHRoOiAxNixcbiAgICB9XG4gIH0pO1xuXG4gICQ6IGNvdW50cnlDdXRvZmZJbmRleCA9IHR5cGVvZiBjb3VudHJ5Q3V0b2ZmID09PSAnc3RyaW5nJyAmJiBjb3VudHJ5Q3V0b2ZmLmxlbmd0aCAmJiBkYXRhRmlsdGVyZWQubGVuZ3RoID8gZGF0YUZpbHRlcmVkLm1hcCgoZCkgPT4gZFtpZEZpZWxkXSkuaW5kZXhPZihjb3VudHJ5Q3V0b2ZmKSA6IG51bGw7XG4gICQ6IGNvbG9yc0N1dG9mZiA9IE1hdGguZmxvb3IoZGF0YUZpbHRlcmVkLmxlbmd0aCAqIChNYXRoLmZsb29yKGNvbG9ycy5sZW5ndGggLyAyKSkgLyBjb2xvcnMubGVuZ3RoKTsgLy8gMTMwLWlzaCB4IDMgLyA3O1xuICAkOiBjdXRvZmZJbmRleCA9IGNvdW50cnlDdXRvZmZJbmRleCA/IGNvdW50cnlDdXRvZmZJbmRleCA6IGNvbG9yc0N1dG9mZjtcbiAgJDogaG92ZXJGb3VuZCA9IGhvdmVySURHcm91cCA/IGRhdGFGaWx0ZXJlZC5tYXAoKGQpID0+IGRbaWRGaWVsZF0pLmluZGV4T2YoaG92ZXJJREdyb3VwKSA6IC0xO1xuICAkOiBob3ZlclJhbmsgPSBob3ZlckZvdW5kID09PSAtMSA/IGN1dG9mZkluZGV4IDogaG92ZXJGb3VuZDtcbiAgJDogbG9va2luZ1VwID0gaG92ZXJSYW5rID49IGNvbG9yc0N1dG9mZjtcbiAgJDogbmJDb3VudHJpZXNUb3BCb3R0b20gPSBsb29raW5nVXAgPyBkYXRhRmlsdGVyZWQubGVuZ3RoIC0gaG92ZXJSYW5rIDogaG92ZXJSYW5rICsgMTtcbiAgJDogY291bnRyaWVzVG9wQm90dG9tID0gbG9va2luZ1VwID8gZGF0YUZpbHRlcmVkLnNsaWNlKGhvdmVyUmFuaykgOiBkYXRhRmlsdGVyZWQuc2xpY2UoMCwgaG92ZXJSYW5rICsgMSk7XG4gICQ6IHZhY2NpbmVzQWxsQ291bnRyaWVzID0gc3VtKGRhdGFGaWx0ZXJlZCwgKGQpID0+IGRbdmFjY2luZXNDaGFydENvbmZpZy52YWx1ZUZpZWxkXSk7XG4gICQ6IHZhY2NpbmVzQ291bnRyaWVzVG9wQm90dG9tID0gc3VtKGNvdW50cmllc1RvcEJvdHRvbSwgKGQpID0+IGRbdmFjY2luZXNDaGFydENvbmZpZy52YWx1ZUZpZWxkXSk7XG4gICQ6IHZhY2NpbmVzQ291bnRyaWVzVG9wQm90dG9tUHJvcG9ydGlvbiA9IHZhY2NpbmVzQ291bnRyaWVzVG9wQm90dG9tIC8gdmFjY2luZXNBbGxDb3VudHJpZXM7XG4gICQ6IHBvcHVsYXRpb25BbGxDb3VudHJpZXMgPSBzdW0oZGF0YUZpbHRlcmVkLCAoZCkgPT4gZFtwb3B1bGF0aW9uQ2hhcnRDb25maWcudmFsdWVGaWVsZF0pO1xuICAkOiBwb3B1bGF0aW9uQ291bnRyaWVzVG9wQm90dG9tID0gc3VtKGNvdW50cmllc1RvcEJvdHRvbSwgKGQpID0+IGRbcG9wdWxhdGlvbkNoYXJ0Q29uZmlnLnZhbHVlRmllbGRdKTtcbiAgJDogcG9wdWxhdGlvbkNvdW50cmllc1RvcEJvdHRvbVByb3BvcnRpb24gPSBwb3B1bGF0aW9uQ291bnRyaWVzVG9wQm90dG9tIC8gcG9wdWxhdGlvbkFsbENvdW50cmllcztcblxuICBjb25zdCB0b29sdGlwU3RvcmUgPSB3cml0YWJsZSgpO1xuICBzZXRDb250ZXh0KGB0b29sdGlwLXN0b3JlYCwgdG9vbHRpcFN0b3JlKTtcbjwvc2NyaXB0PlxuXG48c3R5bGUgbGFuZz1cInNjc3NcIj5oNXtkaXNwbGF5Om5vbmU7Zm9udC1mYW1pbHk6XCJCV0hhYXNEaW5nYmF0XCIsXCJCV0hhYXNUZXh0XCIsXCJIZWx2ZXRpY2EgTmV1ZVwiLEhlbHZldGljYSxBcmlhbCxzYW5zLXNlcmlmfS5hdXRvLXRleHR7ZGlzcGxheTpub25lO21hcmdpbi1ib3R0b206MTRweH0uYXV0by10ZXh0IHB7Zm9udC1mYW1pbHk6XCJCV0hhYXNEaW5nYmF0XCIsXCJCV0hhYXNUZXh0XCIsXCJIZWx2ZXRpY2EgTmV1ZVwiLEhlbHZldGljYSxBcmlhbCxzYW5zLXNlcmlmfS5ncmFwaGljey13ZWJraXQtdXNlci1zZWxlY3Q6bm9uZTstbW96LXVzZXItc2VsZWN0Om5vbmU7LW1zLXVzZXItc2VsZWN0Om5vbmU7dXNlci1zZWxlY3Q6bm9uZTttYXJnaW4tdG9wOnZhcigtLW1hcmdpbi10b3AtYm90dG9tKTttYXJnaW4tYm90dG9tOnZhcigtLW1hcmdpbi10b3AtYm90dG9tKX08L3N0eWxlPlxuXG48Q2hhcnRLZXkgey4uLmNoYXJ0UHJvcHN9IGl0ZW1zPXtjaGFydEtleUl0ZW1zfS8+XG5cbjxkaXYgY2xhc3M9XCJncmFwaGljXCIgc3R5bGU9XCItLW1hcmdpbi10b3AtYm90dG9tOiB7aXNNb2JpbGUgPyA1NiA6IDI4fXB4O1wiIGJpbmQ6Y2xpZW50V2lkdGg9e2NoYXJ0Q29udGFpbmVyV2lkdGh9PlxuICA8TGluZXJcbiAgICB7Li4uY2hhcnRQcm9wc31cbiAgICB7Li4udmFjY2luZXNDaGFydENvbmZpZ31cbiAgICB7bGFiZWxXaWR0aH1cbiAgICBhbGlnblJpZ2h0PXtsb29raW5nVXB9XG4gICAgdmFsdWU9e3ZhY2NpbmVzQ291bnRyaWVzVG9wQm90dG9tUHJvcG9ydGlvbn1cbiAgICBjb3VudD17Y291bnRyaWVzVG9wQm90dG9tLmxlbmd0aH1cbiAgLz5cbiAgPEJhclxuICAgIHsuLi5jaGFydFByb3BzfVxuICAgIHsuLi52YWNjaW5lc0NoYXJ0Q29uZmlnfVxuICAgIHtsYWJlbFdpZHRofVxuICAgIGRhdGE9e2RhdGFGaWx0ZXJlZH1cbiAgICBzaG93VG9vbHRpcFRpdGxlPXt0cnVlfVxuICAgIGJpbmQ6aG92ZXJJRD17aG92ZXJJRENvdW50cnl9XG4gICAgYmluZDpzaG93TGluZXM9e3Nob3dMaW5lc31cbiAgLz5cbiAgPEpvaW5lclxuICAgIHsuLi5jaGFydFByb3BzfVxuICAgIHtsYWJlbFdpZHRofVxuICAgIGRhdGE9e2RhdGFGaWx0ZXJlZH1cbiAgICB2YWx1ZUZpZWxkcz17W3ZhY2NpbmVzQ2hhcnRDb25maWcudmFsdWVGaWVsZCwgcG9wdWxhdGlvbkNoYXJ0Q29uZmlnLnZhbHVlRmllbGRdfVxuICAgIGJpbmQ6aG92ZXJJRD17aG92ZXJJREdyb3VwfVxuICAgIHtob3ZlcklEQ291bnRyeX1cbiAgICBiaW5kOnNob3dMaW5lcz17c2hvd0xpbmVzfVxuICAvPlxuICA8QmFyXG4gICAgey4uLmNoYXJ0UHJvcHN9XG4gICAgey4uLnBvcHVsYXRpb25DaGFydENvbmZpZ31cbiAgICB7bGFiZWxXaWR0aH1cbiAgICBkYXRhPXtkYXRhRmlsdGVyZWR9XG4gICAgYmluZDpob3ZlcklEPXtob3ZlcklEQ291bnRyeX1cbiAgICBiaW5kOnNob3dMaW5lcz17c2hvd0xpbmVzfVxuICAgIG9yaWVudD1cImJvdHRvbVwiXG4gIC8+XG4gIDxMaW5lclxuICAgIHsuLi5jaGFydFByb3BzfVxuICAgIHsuLi5wb3B1bGF0aW9uQ2hhcnRDb25maWd9XG4gICAge2xhYmVsV2lkdGh9XG4gICAgYWxpZ25SaWdodD17bG9va2luZ1VwfVxuICAgIHZhbHVlPXtwb3B1bGF0aW9uQ291bnRyaWVzVG9wQm90dG9tUHJvcG9ydGlvbn1cbiAgICBvcmllbnQ9XCJib3R0b21cIlxuICAgIGNvdW50PXtjb3VudHJpZXNUb3BCb3R0b20ubGVuZ3RofVxuICAvPlxuPC9kaXY+XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBb0VxUSxzQkFBUSxDQUFDLG9CQUFvQixJQUFJLENBQUMsaUJBQWlCLElBQUksQ0FBQyxnQkFBZ0IsSUFBSSxDQUFDLFlBQVksSUFBSSxDQUFDLFdBQVcsSUFBSSxtQkFBbUIsQ0FBQyxDQUFDLGNBQWMsSUFBSSxtQkFBbUIsQ0FBQyxDQUFDIn0= */button.svelte-nfpvoh{touch-action:manipulation}.select.svelte-nfpvoh{--inputFontSize:16px;grid-template-columns:1fr 50px 50px}.selectedItem{overflow-y:hidden}.selectContainer input{width:90% !important}@media(max-width: 420px){.select.svelte-nfpvoh{--inputFontSize:14px;grid-template-columns:70% 13% 13%}.selectContainer input{width:70% !important}}@media(max-width: 340px){.select.svelte-nfpvoh{--inputFontSize:12px;grid-template-columns:60% 18% 18%}.selectContainer input{width:60% !important}}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU2VsZWN0LnN2ZWx0ZSIsInNvdXJjZXMiOlsiU2VsZWN0LnN2ZWx0ZSJdLCJzb3VyY2VzQ29udGVudCI6WyI8c2NyaXB0PlxuICAvLyBAdHMtY2hlY2tcbiAgaW1wb3J0IFNlbGVjdCBmcm9tICdzdmVsdGUtc2VsZWN0JztcblxuICBleHBvcnQgbGV0IGl0ZW1zID0gW107XG4gIGV4cG9ydCBsZXQgc2tpcEZpcnN0ID0gZmFsc2U7XG4gIGV4cG9ydCBsZXQgdmFsdWUgPSB1bmRlZmluZWQ7XG4gIGV4cG9ydCBsZXQgZGVidWcgPSBmYWxzZTtcblxuICAkOiBvbkNsaWNrID0gKGRpcmVjdGlvbikgPT4ge1xuICAgIGNvbnN0IG51bUl0ZW1zID0gaXRlbXMubGVuZ3RoO1xuICAgIGlmIChkZWJ1ZykgY29uc29sZS5sb2coYFNlbGVjdDogb25DbGljazpgLCB7IHZhbHVlLCBza2lwRmlyc3QsIG51bUl0ZW1zIH0pO1xuICAgIGxldCBuZXh0SW5kZXg7XG4gICAgaWYgKHZhbHVlICE9PSBudWxsKSB7XG4gICAgICBjb25zdCBpbmRleCA9IGl0ZW1zXG4gICAgICAgIC5tYXAoKGQpID0+IGQudmFsdWUpXG4gICAgICAgIC5pbmRleE9mKHR5cGVvZiB2YWx1ZSA9PT0gJ29iamVjdCcgPyB2YWx1ZS52YWx1ZSA6IHZhbHVlKTtcbiAgICAgIGlmIChkZWJ1ZykgY29uc29sZS5sb2coYFNlbGVjdDogY3VycmVudCBpbmRleDpgLCBpbmRleCk7XG4gICAgICBpZiAoZGlyZWN0aW9uID09PSAncHJldicpIHtcbiAgICAgICAgbmV4dEluZGV4ID0gaW5kZXggLSAxO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgbmV4dEluZGV4ID0gaW5kZXggKyAxO1xuICAgICAgfVxuICAgICAgaWYgKG5leHRJbmRleCA8IDApIHtcbiAgICAgICAgbmV4dEluZGV4ID0gbnVtSXRlbXMgLSAxO1xuICAgICAgfVxuICAgICAgaWYgKG5leHRJbmRleCA+IG51bUl0ZW1zIC0gMSkge1xuICAgICAgICBuZXh0SW5kZXggPSAwO1xuICAgICAgfVxuICAgICAgaWYgKCF2YWx1ZSAmJiBza2lwRmlyc3QgJiYgZGlyZWN0aW9uID09PSAnbmV4dCcpIHtcbiAgICAgICAgbmV4dEluZGV4ID0gMTtcbiAgICAgIH1cbiAgICB9IGVsc2Uge1xuICAgICAgaWYgKGRpcmVjdGlvbiA9PT0gJ3ByZXYnKSB7XG4gICAgICAgIG5leHRJbmRleCA9IG51bUl0ZW1zIC0gMTtcbiAgICAgIH0gZWxzZSBpZiAoc2tpcEZpcnN0KSB7XG4gICAgICAgIG5leHRJbmRleCA9IDE7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICBuZXh0SW5kZXggPSAwO1xuICAgICAgfVxuICAgIH1cbiAgICBjb25zdCBuZXh0SXRlbSA9IGl0ZW1zW25leHRJbmRleF07XG4gICAgdmFsdWUgPSBuZXh0SXRlbTtcbiAgICBpZiAoZGVidWcpXG4gICAgICBjb25zb2xlLmxvZyhgU2VsZWN0OmAsIHsgdmFsdWUsIHNraXBGaXJzdCwgbmV4dEluZGV4LCBuZXh0SXRlbSB9KTtcbiAgfTtcblxuICBjb25zdCBidXR0b25DbGFzcyA9XG4gICAgJ2gtZnVsbCBiZy13aGl0ZSBib3JkZXItc29saWQgYm9yZGVyIGJvcmRlci1ncmF5IHJvdW5kZWQgY3Vyc29yLXBvaW50ZXIgdGV4dC1sZyBjdXJzb3I6cG9pbnRlcic7XG5cbiAgY29uc3QgdXAgPSAnJiN4MjE5MTsnO1xuICBjb25zdCBkb3duID0gJyYjeDIxOTM7Jztcbjwvc2NyaXB0PlxuXG48ZGl2IGNsYXNzPVwic2VsZWN0IGhhYXMtdGV4dCBncmlkIGdhcC14LTEgY3Vyc29yOnBvaW50ZXJcIj5cbiAgPFNlbGVjdFxuICAgIGJpbmQ6dmFsdWVcbiAgICBpdGVtcz17JCRwcm9wcy5pdGVtc31cbiAgICBwbGFjZWhvbGRlcj17JCRwcm9wcy5wbGFjZWhvbGRlcn1cbiAgICBvbjpzZWxlY3RcbiAgICBvbjpjbGVhclxuICAgIGxpc3RBdXRvV2lkdGg9e2ZhbHNlfVxuICAgIGlucHV0QXR0cmlidXRlcz17e1xuICAgICAgYXV0b2NvbXBsZXRlOiAneHh4eHgnLFxuICAgIH19XG4gIC8+XG4gIDxidXR0b24gY2xhc3M9e2J1dHRvbkNsYXNzfSBvbjpjbGljaz17KCkgPT4gb25DbGljaygncHJldicpfVxuICAgID57QGh0bWwgdXB9PC9idXR0b25cbiAgPlxuICA8YnV0dG9uIGNsYXNzPXtidXR0b25DbGFzc30gb246Y2xpY2s9eygpID0+IG9uQ2xpY2soJ25leHQnKX1cbiAgICA+e0BodG1sIGRvd259PC9idXR0b25cbiAgPlxuPC9kaXY+XG5cbjxzdHlsZSBsYW5nPVwic2Nzc1wiPmJ1dHRvbnt0b3VjaC1hY3Rpb246bWFuaXB1bGF0aW9ufS5zZWxlY3R7LS1pbnB1dEZvbnRTaXplOiAxNnB4O2dyaWQtdGVtcGxhdGUtY29sdW1uczoxZnIgNTBweCA1MHB4fTpnbG9iYWwoLnNlbGVjdGVkSXRlbSl7b3ZlcmZsb3cteTpoaWRkZW59Omdsb2JhbCguc2VsZWN0Q29udGFpbmVyIGlucHV0KXt3aWR0aDo5MCUgIWltcG9ydGFudH1AbWVkaWEobWF4LXdpZHRoOiA0MjBweCl7LnNlbGVjdHstLWlucHV0Rm9udFNpemU6IDE0cHg7Z3JpZC10ZW1wbGF0ZS1jb2x1bW5zOjcwJSAxMyUgMTMlfTpnbG9iYWwoLnNlbGVjdENvbnRhaW5lciBpbnB1dCl7d2lkdGg6NzAlICFpbXBvcnRhbnR9fUBtZWRpYShtYXgtd2lkdGg6IDM0MHB4KXsuc2VsZWN0ey0taW5wdXRGb250U2l6ZTogMTJweDtncmlkLXRlbXBsYXRlLWNvbHVtbnM6NjAlIDE4JSAxOCV9Omdsb2JhbCguc2VsZWN0Q29udGFpbmVyIGlucHV0KXt3aWR0aDo2MCUgIWltcG9ydGFudH19PC9zdHlsZT5cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEwRW1CLG9CQUFNLENBQUMsYUFBYSxZQUFZLENBQUMscUJBQU8sQ0FBQyxlQUFlLENBQUUsSUFBSSxDQUFDLHNCQUFzQixHQUFHLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxBQUFRLGFBQWEsQUFBQyxDQUFDLFdBQVcsTUFBTSxDQUFDLEFBQVEsc0JBQXNCLEFBQUMsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxVQUFVLENBQUMsTUFBTSxZQUFZLEtBQUssQ0FBQyxDQUFDLHFCQUFPLENBQUMsZUFBZSxDQUFFLElBQUksQ0FBQyxzQkFBc0IsR0FBRyxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsQUFBUSxzQkFBc0IsQUFBQyxDQUFDLE1BQU0sR0FBRyxDQUFDLFVBQVUsQ0FBQyxDQUFDLE1BQU0sWUFBWSxLQUFLLENBQUMsQ0FBQyxxQkFBTyxDQUFDLGVBQWUsQ0FBRSxJQUFJLENBQUMsc0JBQXNCLEdBQUcsQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLEFBQVEsc0JBQXNCLEFBQUMsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxVQUFVLENBQUMsQ0FBQyJ9 */.num.svelte-1szsx1f{font-size:1.375rem;line-height:1.375rem}.max-content.svelte-1szsx1f{width:-webkit-max-content;width:-moz-max-content;width:max-content}.nowrap.svelte-1szsx1f{white-space:nowrap}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVG9vbHRpcFRlbXBsYXRlLnN2ZWx0ZSIsInNvdXJjZXMiOlsiVG9vbHRpcFRlbXBsYXRlLnN2ZWx0ZSJdLCJzb3VyY2VzQ29udGVudCI6WyI8c2NyaXB0PlxuICBpbXBvcnQgeyBmb3JtYXQgfSBmcm9tICdkMy1mb3JtYXQnO1xuICBpbXBvcnQgKiBhcyBmb3JtYXR0ZXJzIGZyb20gJy4uLy4uL2pzL21vZHVsZXMvZm9ybWF0dGVycy5qcyc7XG4gIGltcG9ydCB7IGdldERhdGFGb3JtYXR0ZXIgfSBmcm9tICcuLi8uLi9qcy9tb2R1bGVzL2Zvcm1hdHRlcnMuanMnO1xuICBpbXBvcnQgeyBibG9vbWJlcmdVdGNGb3JtYXQgfSBmcm9tICcuLi8uLi9qcy9tb2R1bGVzL2Zvcm1hdHRlcnMuanMnO1xuXG4gIGV4cG9ydCBsZXQgZGF0YTtcbiAgZXhwb3J0IGxldCBkZWJ1ZyA9IGZhbHNlO1xuICBleHBvcnQgbGV0IHRvb2x0aXBDb25maWcgPSBbXTtcbiAgZXhwb3J0IGxldCBoaWRlVG9vbHRpcE5hbWUgPSBmYWxzZTtcblxuICAkOiBpZiAoZGVidWcpIGNvbnNvbGUubG9nKGB0b29sdGlwYCwgeyBkYXRhLCB0b29sdGlwQ29uZmlnIH0pO1xuXG4gICQ6IGZpbmFsVG9vbHRpcENvbmZpZyA9IHRvb2x0aXBDb25maWcubWFwKChvYmopID0+IHtcbiAgICBjb25zdCB7IGZvcm1hdHRlcjogZm9ybWF0dGVyS2V5LCBkM0Zvcm1hdCwgZm9ybWF0RnVuYywgdmFyaWFibGUgfSA9IG9iajtcbiAgICAvLyBDcmVhdGUgYSBmdW5jdGlvbiB0byBnZXQgdGhlIHZhbHVlXG4gICAgY29uc3QgZ2V0VmFsdWUgPSAoZGF0YSkgPT4ge1xuICAgICAgLy8gaWYgKGRlYnVnKSBjb25zb2xlLmxvZyhgdG9vbHRpcCBkYXRhOmAsIGRhdGEpO1xuICAgICAgY29uc3QgYWNjZXNzb3IgPSAoZCkgPT4gZFt2YXJpYWJsZV07XG4gICAgICBjb25zdCB2YWx1ZSA9IGFjY2Vzc29yKGRhdGEpO1xuICAgICAgaWYgKCFOdW1iZXIuaXNGaW5pdGUodmFsdWUpKSByZXR1cm4gJ+KAkyc7XG4gICAgICBpZiAoZm9ybWF0RnVuYykgcmV0dXJuIGZvcm1hdEZ1bmModmFsdWUpO1xuICAgICAgaWYgKGQzRm9ybWF0KSByZXR1cm4gZm9ybWF0KGQzRm9ybWF0KSh2YWx1ZSk7XG4gICAgICBpZiAoIWZvcm1hdHRlcktleSkgcmV0dXJuIHZhbHVlO1xuICAgICAgaWYgKGZvcm1hdHRlcktleSBpbiBmb3JtYXR0ZXJzKSB7XG4gICAgICAgIHJldHVybiBmb3JtYXR0ZXJzW2Zvcm1hdHRlcktleV0odmFsdWUpO1xuICAgICAgfVxuICAgICAgY29uc3QgZm9ybWF0dGVyID0gZ2V0RGF0YUZvcm1hdHRlcihmb3JtYXR0ZXJLZXkpOyAvL3Nob3VsZCBub3QgYWNjZXNzIGZvcm1hdCBmdW5jdGlvbiBkaXJlY3RseSAodXNlIHRoZSBzdHJpbmcgZGVjaW1hbDIgd2l0aCBhY2Nlc3NvciByYXRoZXIgdGhhbiBmdW5jdGlvbiBkZWNpbWFsMkZvcm1hdClcbiAgICAgIGlmICghZm9ybWF0dGVyKSB7XG4gICAgICAgIHJldHVybiB2YWx1ZTtcbiAgICAgIH1cbiAgICAgIHJldHVybiBmb3JtYXR0ZXIodmFsdWUpO1xuICAgIH07XG4gICAgcmV0dXJuIHsgLi4ub2JqLCBnZXRWYWx1ZSB9O1xuICB9KTtcbjwvc2NyaXB0PlxuXG57I2lmIGhpZGVUb29sdGlwTmFtZSA9PT0gZmFsc2V9XG4gIDxoNCBjbGFzcz1cIm1heC1jb250ZW50IHBsYWNlLW5hbWUgbm93cmFwXCI+XG4gICAge2RhdGEuZnVsbE5hbWUgfHwgZGF0YS5uYW1lTG9uZ31cbiAgPC9oND5cbiAgPGRpdiBzdHlsZT1cImhlaWdodDogNXB4O1wiIC8+XG57L2lmfVxuPGRpdiBjbGFzcz1cImRhdGVcIj57Ymxvb21iZXJnVXRjRm9ybWF0KGRhdGEuZGF0ZU9iamVjdCl9PC9kaXY+XG57I2VhY2ggZmluYWxUb29sdGlwQ29uZmlnIGFzIHsgbGFiZWwsIGdldFZhbHVlIH19XG4gIDxkaXYgc3R5bGU9XCJoZWlnaHQ6IDdweDtcIiAvPlxuICA8ZGl2IGNsYXNzPVwibnVtXCI+e2dldFZhbHVlKGRhdGEpfTwvZGl2PlxuICA8ZGl2IGNsYXNzPVwidGV4dC1zbWFsbCBsYWJlbCBub3dyYXBcIj57QGh0bWwgbGFiZWx9PC9kaXY+XG57L2VhY2h9XG5cbjxzdHlsZSBsYW5nPVwic2Nzc1wiPi5udW17Zm9udC1zaXplOjEuMzc1cmVtO2xpbmUtaGVpZ2h0OjEuMzc1cmVtfS5tYXgtY29udGVudHt3aWR0aDotd2Via2l0LW1heC1jb250ZW50O3dpZHRoOi1tb3otbWF4LWNvbnRlbnQ7d2lkdGg6bWF4LWNvbnRlbnR9Lm5vd3JhcHt3aGl0ZS1zcGFjZTpub3dyYXB9PC9zdHlsZT5cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrRG1CLG1CQUFJLENBQUMsVUFBVSxRQUFRLENBQUMsWUFBWSxRQUFRLENBQUMsMkJBQVksQ0FBQyxNQUFNLG1CQUFtQixDQUFDLE1BQU0sZ0JBQWdCLENBQUMsTUFBTSxXQUFXLENBQUMsc0JBQU8sQ0FBQyxZQUFZLE1BQU0sQ0FBQyJ9 */.svelte-1lb03e5.svelte-1lb03e5{font-family:"BWHaasDingbat","BWHaasText","Helvetica Neue",Helvetica,Arial,sans-serif}.container.svelte-1lb03e5.svelte-1lb03e5{display:-webkit-flex;display:flex;-webkit-justify-content:center;justify-content:center}.chart-container.svelte-1lb03e5.svelte-1lb03e5{width:100%}div.label.svelte-1lb03e5.svelte-1lb03e5{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;display:-webkit-flex;display:flex;-webkit-align-self:center;align-self:center;-webkit-justify-content:flex-end;justify-content:flex-end;text-align:right;font-size:.875rem;font-weight:700;width:100%;max-width:var(--label-width);min-width:var(--label-width);margin-right:var(--label-margin);line-height:1}svg.svelte-1lb03e5.svelte-1lb03e5{width:100%;height:100%;overflow:visible}svg.svelte-1lb03e5 *{vector-effect:non-scaling-stroke}.relative.svelte-1lb03e5.svelte-1lb03e5{position:relative}.absolute.svelte-1lb03e5.svelte-1lb03e5{position:absolute}.non-scaling-stroke.svelte-1lb03e5 *{vector-effect:non-scaling-stroke}.w-full.svelte-1lb03e5.svelte-1lb03e5{width:100%}.h-full.svelte-1lb03e5.svelte-1lb03e5{height:100%}.max-height-custom.svelte-1lb03e5.svelte-1lb03e5{max-height:35px}.h-custom.svelte-1lb03e5.svelte-1lb03e5{height:35px}.h-50.svelte-1lb03e5.svelte-1lb03e5{height:50px}.h-100.svelte-1lb03e5.svelte-1lb03e5{height:100px}.h-150.svelte-1lb03e5.svelte-1lb03e5{height:150px}.h-200.svelte-1lb03e5.svelte-1lb03e5{height:200px}.h-300.svelte-1lb03e5.svelte-1lb03e5{height:300px}.h-400.svelte-1lb03e5.svelte-1lb03e5{height:400px}.h-500.svelte-1lb03e5.svelte-1lb03e5{height:500px}.no-fill.svelte-1lb03e5.svelte-1lb03e5{fill:none}.no-stroke.svelte-1lb03e5.svelte-1lb03e5{stroke:none}.stroke-1.svelte-1lb03e5.svelte-1lb03e5{stroke-width:1}.stroke-2.svelte-1lb03e5.svelte-1lb03e5{stroke-width:2}.stroke-3.svelte-1lb03e5.svelte-1lb03e5{stroke-width:3}.stroke-4.svelte-1lb03e5.svelte-1lb03e5{stroke-width:4}.fill-white.svelte-1lb03e5.svelte-1lb03e5{fill:#fff}.fill-highlight.svelte-1lb03e5.svelte-1lb03e5{fill:var(--highlight-color)}.stroke-black.svelte-1lb03e5.svelte-1lb03e5{stroke:#000}.opacity-over.svelte-1lb03e5.svelte-1lb03e5{opacity:var(--over-opacity)}.over.svelte-1lb03e5 rect.svelte-1lb03e5{pointer-events:none}.color-black.svelte-1lb03e5.svelte-1lb03e5{color:#000}.color-white.svelte-1lb03e5.svelte-1lb03e5{color:#fff}.chart-container.svelte-1lb03e5.svelte-1lb03e5{cursor:crosshair}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"Bar.svelte","sources":["Bar.svelte"],"sourcesContent":["<script>\n  import { onMount } from 'svelte';\n  import { scaleLinear } from 'd3-scale';\n  import { stack } from 'd3-shape';\n  import { sum } from 'd3-array';\n  import { colors as borschtColors } from 'borscht';\n  import { hasEnoughContrast } from '../../js/modules/colors';\n  // import Voronoi from '../ChartComponents/Voronoi.svelte';\n  import Tooltip from '../ChartComponents/Tooltip_v2.svelte';\n  import TooltipTemplate from './TooltipTemplate.svelte';\n  import AnnotationText from '../ChartComponents/AnnotationText.svelte';\n  export let tooltipConfig = [];\n  export let showTooltipTitle = false;\n  export let tooltipSubtitle;\n  export let tooltipFooter;\n  export let idField = 'iso';\n  export let data;\n  export let label; // Label of the data type\n  export let valueField = 'value';\n  export let colors = ['mint'];\n  export let orient = 'top';\n  export let hoverID = null;\n  export let showLines = false; // Lines for the middle section (see Joiner.svelte)\n  export let labelWidth;\n\n  const dim = 100;\n  const pxPerChar = 6;\n  const paddingEachSideNeeded = 2;\n  const labelMargin = 7;\n\n  let chartContainerWidth;\n  let chartContainer;\n\n  $: viewBox = `0 0 ${dim} ${dim}`;\n  $: idAccessor = (d) => d[idField];\n  $: valueAccessor = (d) => d[valueField];\n  $: valueDomain = [0, sum(data, valueAccessor)];\n  $: valueRange = [0, dim];\n  $: xScale = scaleLinear().domain(valueDomain).range(valueRange);\n  $: orderedKeys = data.map(idAccessor);\n  $: flatData = data.reduce((a, b) => {\n    const key = idAccessor(b);\n    const out = {...a};\n    out[key] = b;\n    return out;\n  }, {});\n  $: stackGenerator = stack().keys(orderedKeys).value((d, key) => valueAccessor(d[key]));\n  $: stackedData = flatData ? stackGenerator([flatData]) : [];\n  $: formattedData = stackedData.map((d, i, arr) => {\n    const colorName = colors[Math.floor(i / arr.length * colors.length)];\n    const color = borschtColors[colorName] || colorName;\n    return {\n      x1: d[0][0],\n      x2: d[0][1],\n      key: d.key,\n      d: d[0].data[d.key],\n      color,\n    }\n  });\n  $: dimMultiplier = chartContainerWidth / dim;\n\n  const onInteractEnd = () => {\n    /* eslint-disable no-unused-vars */\n    hoverID = null;\n    showLines = false;\n    /* eslint-enable no-unused-vars */\n  }\n\n  // This controls voronoi hovering.\n  function interactAction(element, data_) {\n    let currentData = data_;\n    const onHover = () => {\n      if (currentData.key !== hoverID) hoverID = currentData.key;\n      if (showLines !== true) showLines = true;\n    };\n    const onClick = () => {\n      if (currentData.key !== hoverID) hoverID = currentData.key;\n      if (showLines !== true) showLines = true;\n    };\n    const onTouchMove = (event) => {\n      if (event.touches) {\n        const xPos = event.touches[0].pageX;\n        const yPos = event.touches[0].pageY;\n        const element = document.elementFromPoint(\n          xPos - window.pageXOffset,\n          yPos - window.pageYOffset\n        );\n        if (element && element.dataset) {\n          currentData = { ...element.dataset };\n          if (currentData.key) {\n            if (currentData.key !== hoverID) hoverID = currentData.key;\n            if (showLines !== true) showLines = true;\n          } else {\n            onInteractEnd();\n          }\n        } else {\n          onInteractEnd();\n        }\n      }\n    };\n    element.addEventListener('click', onClick);\n    element.addEventListener('mousemove', onHover);\n    element.addEventListener('mousedown', onHover);\n    element.addEventListener('touchstart', onTouchMove, {passive: true});\n    element.addEventListener('touchmove', onTouchMove, {passive: true});\n    return {\n      update(d) {\n        currentData = d;\n      },\n      destroy() {\n        element.removeEventListener('click', onClick);\n        element.removeEventListener('mousemove', onHover);\n        element.removeEventListener('mousedown', onHover);\n        element.removeEventListener('touchstart', onTouchMove);\n        element.removeEventListener('touchmove', onTouchMove);\n      },\n    };\n  }\n\n  $: getTooltipData = (d) => {\n    if (Object.keys(d).length === 0) return null;\n    const { key } = d;\n    const findData = formattedData.find((dd) => dd.key === key);\n    return {\n      key,\n      ...findData,\n    }\n  }\n\n  $: getTooltipPosition = (d) => {\n    const { x1, x2 } = d;\n    const left = `${xScale((x2 - x1) / 2 + x1)}%`;\n    return {\n      left,\n      top: `${orient === 'bottom' ? showTooltipTitle ? 0 : 30 : 0}px`,\n    };\n  }\n\n  $: chartProps = {\n    ...$$props,\n  };\n\n  onMount(() => {\n    chartContainerWidth = chartContainer.clientWidth;\n  });\n</script>\n\n<style lang=\"scss\">*{font-family:\"BWHaasDingbat\",\"BWHaasText\",\"Helvetica Neue\",Helvetica,Arial,sans-serif}.container{display:-webkit-flex;display:flex;-webkit-justify-content:center;justify-content:center}.chart-container{width:100%}div.label{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;display:-webkit-flex;display:flex;-webkit-align-self:center;align-self:center;-webkit-justify-content:flex-end;justify-content:flex-end;text-align:right;font-size:.875rem;font-weight:700;width:100%;max-width:var(--label-width);min-width:var(--label-width);margin-right:var(--label-margin);line-height:1}svg{width:100%;height:100%;overflow:visible}svg :global(*){vector-effect:non-scaling-stroke}.relative{position:relative}.absolute{position:absolute}.non-scaling-stroke :global(*){vector-effect:non-scaling-stroke}.w-full{width:100%}.h-full{height:100%}.max-height-custom{max-height:35px}.h-custom{height:35px}.h-50{height:50px}.h-100{height:100px}.h-150{height:150px}.h-200{height:200px}.h-300{height:300px}.h-400{height:400px}.h-500{height:500px}.no-fill{fill:none}.no-stroke{stroke:none}.stroke-1{stroke-width:1}.stroke-2{stroke-width:2}.stroke-3{stroke-width:3}.stroke-4{stroke-width:4}.fill-white{fill:#fff}.fill-highlight{fill:var(--highlight-color)}.stroke-black{stroke:#000}.opacity-over{opacity:var(--over-opacity)}.over rect{pointer-events:none}.color-black{color:#000}.color-white{color:#fff}.chart-container{cursor:crosshair}</style>\n\n<div class=\"container orient-{orient}\" style=\"--label-width:{labelWidth - labelMargin}px; --label-margin:{labelMargin}px;\">\n  <div class=\"label max-height-custom\">{label}</div>\n  <div\n    class=\"chart-container relative h-custom\"\n    bind:this={chartContainer}\n  >\n    <Tooltip\n      let:action={tooltipAction}\n      getData={getTooltipData}\n      getPosition={getTooltipPosition}\n      showCircle={false}\n      getOrientVertical={() => orient.toUpperCase()}\n    >\n      <svg {viewBox}\n        preserveAspectRatio=\"none\"\n        on:mouseleave={onInteractEnd}\n        on:touchend={onInteractEnd}\n      >\n        <g class=\"data\">\n          {#each formattedData as { x1, x2, key, d, color } (key)}\n            <g\n              data-id={key}\n              transform=\"translate({xScale(x1)}, 0)\"\n              style=\"--highlight-color: {color};\"\n            >\n              <rect\n                width={xScale(x2) - xScale(x1)}\n                height={dim ? dim : 0}\n                class=\"fill-highlight no-stroke\"\n                data-key={key}\n                use:interactAction={{ key }}\n                use:tooltipAction={{ key }}\n              />\n            </g>\n          {/each}\n        </g>\n        <g class=\"over\">\n          {#each formattedData as { x1, x2, key, d, color } (key)}\n            <g\n              data-id={key}\n              transform=\"translate({xScale(x1)}, 0)\"\n              style=\"--over-opacity: {Number(Boolean(hoverID === key))};\"\n            >\n              <rect\n                width={xScale(x2) - xScale(x1)}\n                height={dim}\n                class=\"no-fill stroke-1 stroke-black opacity-over\"\n              />\n            </g>\n          {/each}\n        </g>\n      </svg>\n      <!-- TOOLTIP -->\n      <div class=\"tooltip\" slot=\"tooltip-template\" let:data>\n        <TooltipTemplate {...chartProps} {data} {tooltipConfig} {tooltipSubtitle} {tooltipFooter}/>\n      </div>\n    </Tooltip>\n\n    <!-- LABELS -->\n    <div class=\"labels\">\n      {#each formattedData as { x1, x2, key, d, color } (key)}\n        {#if (xScale(x2) - xScale(x1)) * dimMultiplier > d.name.length * pxPerChar + paddingEachSideNeeded * 2}\n          <div data-id={key}>\n            <AnnotationText\n              left={`${xScale((x2 - x1) / 2 + x1)}%`}\n              top=\"50%\"\n              transform=\"translate(-50%, -50%)\"\n              textAlign=\"center\"\n            >\n              <div\n                class=\"invisible transition color-{hasEnoughContrast(color, borschtColors.black) ? `black` : `white`}\"\n                class:text-border={true}\n                style=\"width: min-content;\"\n              >\n                {d.name}\n              </div>\n            </AnnotationText>\n          </div>\n        {/if}\n      {/each}\n    </div>\n  </div>\n</div>\n"],"names":[],"mappings":"AAmJmB,8BAAC,CAAC,YAAY,eAAe,CAAC,YAAY,CAAC,gBAAgB,CAAC,SAAS,CAAC,KAAK,CAAC,UAAU,CAAC,wCAAU,CAAC,QAAQ,YAAY,CAAC,QAAQ,IAAI,CAAC,wBAAwB,MAAM,CAAC,gBAAgB,MAAM,CAAC,8CAAgB,CAAC,MAAM,IAAI,CAAC,GAAG,oCAAM,CAAC,oBAAoB,IAAI,CAAC,iBAAiB,IAAI,CAAC,gBAAgB,IAAI,CAAC,YAAY,IAAI,CAAC,QAAQ,YAAY,CAAC,QAAQ,IAAI,CAAC,mBAAmB,MAAM,CAAC,WAAW,MAAM,CAAC,wBAAwB,QAAQ,CAAC,gBAAgB,QAAQ,CAAC,WAAW,KAAK,CAAC,UAAU,OAAO,CAAC,YAAY,GAAG,CAAC,MAAM,IAAI,CAAC,UAAU,IAAI,aAAa,CAAC,CAAC,UAAU,IAAI,aAAa,CAAC,CAAC,aAAa,IAAI,cAAc,CAAC,CAAC,YAAY,CAAC,CAAC,iCAAG,CAAC,MAAM,IAAI,CAAC,OAAO,IAAI,CAAC,SAAS,OAAO,CAAC,kBAAG,CAAC,AAAQ,CAAC,AAAC,CAAC,cAAc,kBAAkB,CAAC,uCAAS,CAAC,SAAS,QAAQ,CAAC,uCAAS,CAAC,SAAS,QAAQ,CAAC,kCAAmB,CAAC,AAAQ,CAAC,AAAC,CAAC,cAAc,kBAAkB,CAAC,qCAAO,CAAC,MAAM,IAAI,CAAC,qCAAO,CAAC,OAAO,IAAI,CAAC,gDAAkB,CAAC,WAAW,IAAI,CAAC,uCAAS,CAAC,OAAO,IAAI,CAAC,mCAAK,CAAC,OAAO,IAAI,CAAC,oCAAM,CAAC,OAAO,KAAK,CAAC,oCAAM,CAAC,OAAO,KAAK,CAAC,oCAAM,CAAC,OAAO,KAAK,CAAC,oCAAM,CAAC,OAAO,KAAK,CAAC,oCAAM,CAAC,OAAO,KAAK,CAAC,oCAAM,CAAC,OAAO,KAAK,CAAC,sCAAQ,CAAC,KAAK,IAAI,CAAC,wCAAU,CAAC,OAAO,IAAI,CAAC,uCAAS,CAAC,aAAa,CAAC,CAAC,uCAAS,CAAC,aAAa,CAAC,CAAC,uCAAS,CAAC,aAAa,CAAC,CAAC,uCAAS,CAAC,aAAa,CAAC,CAAC,yCAAW,CAAC,KAAK,IAAI,CAAC,6CAAe,CAAC,KAAK,IAAI,iBAAiB,CAAC,CAAC,2CAAa,CAAC,OAAO,IAAI,CAAC,2CAAa,CAAC,QAAQ,IAAI,cAAc,CAAC,CAAC,oBAAK,CAAC,mBAAI,CAAC,eAAe,IAAI,CAAC,0CAAY,CAAC,MAAM,IAAI,CAAC,0CAAY,CAAC,MAAM,IAAI,CAAC,8CAAgB,CAAC,OAAO,SAAS,CAAC"} */.svelte-6vqdau.svelte-6vqdau{font-family:"BWHaasDingbat","BWHaasText","Helvetica Neue",Helvetica,Arial,sans-serif}.container.svelte-6vqdau.svelte-6vqdau{display:-webkit-flex;display:flex;-webkit-justify-content:space-between;justify-content:space-between}.chart-container.svelte-6vqdau.svelte-6vqdau{width:100%}div.label-placeholder.svelte-6vqdau.svelte-6vqdau{width:100%;max-width:var(--label-width);min-width:var(--label-width)}svg.svelte-6vqdau.svelte-6vqdau{width:100%;height:100%;overflow:visible;touch-action:manipulation}svg.svelte-6vqdau *{vector-effect:non-scaling-stroke}.relative.svelte-6vqdau.svelte-6vqdau{position:relative}.h-custom.svelte-6vqdau.svelte-6vqdau{height:var(--height)}.no-stroke.svelte-6vqdau.svelte-6vqdau{stroke:none}.stroke-1.svelte-6vqdau.svelte-6vqdau{stroke-width:1}.stroke-black.svelte-6vqdau.svelte-6vqdau{stroke:#000}.opacity-none.svelte-6vqdau.svelte-6vqdau{opacity:0}.opacity-over.svelte-6vqdau.svelte-6vqdau{opacity:var(--over-opacity)}.over.svelte-6vqdau.svelte-6vqdau{pointer-events:none}.color-gray.svelte-6vqdau.svelte-6vqdau{color:#999}.bg-white.svelte-6vqdau.svelte-6vqdau{background-color:#fff}.labels.svelte-6vqdau.svelte-6vqdau{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;font-size:var(--font-size);opacity:var(--opacity);pointer-events:none}.labels.svelte-6vqdau.svelte-6vqdau::before{content:" ";display:block;border-top:1px solid #ccc;-webkit-transform:translate(0, var(--line-offset));transform:translate(0, var(--line-offset))}.labels.svelte-6vqdau .note.svelte-6vqdau{padding:2px 4px}.chart-container.svelte-6vqdau.svelte-6vqdau{cursor:crosshair}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"Joiner.svelte","sources":["Joiner.svelte"],"sourcesContent":["<script>\n  import { scaleLinear } from 'd3-scale';\n  import { stack } from 'd3-shape';\n  import { sum } from 'd3-array';\n  import AnnotationText from '../ChartComponents/AnnotationText.svelte';\n  export let idField = 'iso';\n  export let data;\n  export let valueFields = ['value', 'value'];\n  export let hoverID = null;\n  export let hoverIDCountry = null;\n  export let showLines;\n  export let labelWidth = 0;\n  export let joinerNote;\n  export let joinerNoteMobile;\n\n  const joinerHeight = 42;\n  const joinerHeightMobileMultiplier = 1.5;\n  const MOBILE_WIDTH = 420;\n  const dim = 100;\n  let chartContainerWidth;\n\n  $: isMobile = chartContainerWidth - labelWidth <= MOBILE_WIDTH;\n  $: joinerHeightFinal = (!Number.isNaN(+joinerHeight) && +joinerHeight > 0 ? +joinerHeight : 1) * (isMobile ? joinerHeightMobileMultiplier : 1);\n  $: joinerNoteFinal = isMobile ? joinerNoteMobile || joinerNote : joinerNote;\n  $: fontSize = isMobile ? 12 : 14;\n\n  $: viewBox = `0 0 ${dim} ${dim}`;\n  $: idAccessor = (d) => d[idField];\n  $: valuesAccessors = valueFields.map((valueField) => {\n    return (d) => d[valueField];\n  });\n  $: valuesDomains = valuesAccessors.map((valueAccessor) => [0, sum(data, valueAccessor)]);\n  $: valueRange = [0, dim];\n  $: xScales = valuesDomains.map((valueDomain) => scaleLinear().domain(valueDomain).range(valueRange));\n  $: orderedKeys = data.map(idAccessor);\n  $: flatData = data.reduce((a, b) => {\n    const key = idAccessor(b);\n    const out = {...a};\n    out[key] = b;\n    return out;\n  }, {});\n  $: stackGenerators = valuesAccessors.map((valueAccessor) =>\n    stack().keys(orderedKeys).value((d, key) => valueAccessor(d[key]))\n  );\n  $: stackedDatas = flatData\n    ? stackGenerators.map((stackGenerator) => stackGenerator([flatData]))\n    : valueFields.map(() => []);\n  $: formattedData = orderedKeys.map((key) => {\n    const stackedDataTop = stackedDatas[0].find((d) => d.key === key);\n    const stackedDataBottom = stackedDatas[1].find((d) => d.key === key);\n    const d = flatData[key];\n    return {\n      top: stackedDataTop[0].map((xVal) => xScales[0](xVal)),\n      bottom: stackedDataBottom[0].map((xVal) => xScales[1](xVal)),\n      key,\n      d,\n    }\n  });\n  $: dimMultiplier = chartContainerWidth / dim;\n\n  const onInteractEnd = () => {\n    /* eslint-disable no-unused-vars */\n    hoverID = null;\n    /* eslint-enable no-unused-vars */\n  }\n\n  // This controls hovering\n  function interactAction(element, data_) {\n    let currentData = data_;\n    const onHover = () => {\n      if (currentData.key !== hoverID) hoverID = currentData.key;\n      if (showLines !== false) showLines = false;\n    };\n    const onClick = () => {\n      if (currentData.key !== hoverID) hoverID = currentData.key;\n      if (showLines !== false) showLines = false;\n    };\n    const onTouchMove = (event) => {\n      if (event.touches) {\n        const xPos = event.touches[0].pageX;\n        const yPos = event.touches[0].pageY;\n        const element = document.elementFromPoint(\n          xPos - window.pageXOffset,\n          yPos - window.pageYOffset\n        );\n        if (element && element.dataset) {\n          currentData = { ...element.dataset };\n          if (currentData) {\n            if (currentData.key !== hoverID) hoverID = currentData.key;\n            if (showLines !== false) showLines = false;\n          } else {\n            onInteractEnd();\n          }\n        }\n      }\n    };\n    element.addEventListener('click', onClick);\n    element.addEventListener('mousemove', onHover);\n    element.addEventListener('mousedown', onHover);\n    element.addEventListener('touchstart', onTouchMove, {passive: true});\n    element.addEventListener('touchmove', onTouchMove, {passive: true});\n    return {\n      update(d) {\n        currentData = d;\n      },\n      destroy() {\n        element.removeEventListener('click', onClick);\n        element.removeEventListener('mousemove', onHover);\n        element.removeEventListener('mousedown', onHover);\n        element.removeEventListener('touchstart', onTouchMove);\n        element.removeEventListener('touchmove', onTouchMove);\n      },\n    };\n  }\n\n  $: chartProps = {\n    ...$$props,\n  };\n</script>\n\n<style lang=\"scss\">*{font-family:\"BWHaasDingbat\",\"BWHaasText\",\"Helvetica Neue\",Helvetica,Arial,sans-serif}.container{display:-webkit-flex;display:flex;-webkit-justify-content:space-between;justify-content:space-between}.chart-container{width:100%}div.label-placeholder{width:100%;max-width:var(--label-width);min-width:var(--label-width)}svg{width:100%;height:100%;overflow:visible;touch-action:manipulation}svg :global(*){vector-effect:non-scaling-stroke}.relative{position:relative}.absolute{position:absolute}.non-scaling-stroke :global(*){vector-effect:non-scaling-stroke}.w-full{width:100%}.h-full{height:100%}.h-custom{height:var(--height)}.h-50{height:50px}.h-70{height:70px}.h-100{height:100px}.h-150{height:150px}.h-200{height:200px}.h-300{height:300px}.h-400{height:400px}.h-500{height:500px}.no-fill{fill:none}.no-stroke{stroke:none}.stroke-1{stroke-width:1}.stroke-2{stroke-width:2}.stroke-3{stroke-width:3}.stroke-4{stroke-width:4}.fill-white{fill:#fff}.fill-highlight{fill:var(--highlight-color)}.stroke-black{stroke:#000}.opacity-none{opacity:0}.opacity-over{opacity:var(--over-opacity)}.over{pointer-events:none}.color-black{color:#000}.color-gray{color:#999}.color-white{color:#fff}.bg-white{background-color:#fff}.labels{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;font-size:var(--font-size);opacity:var(--opacity);pointer-events:none}.labels::before{content:\" \";display:block;border-top:1px solid #ccc;-webkit-transform:translate(0, var(--line-offset));transform:translate(0, var(--line-offset))}.labels .note{padding:2px 4px}.chart-container{cursor:crosshair}</style>\n\n<div class=\"container\" style=\"--label-width:{labelWidth}px; --height:{joinerHeightFinal}px;\">\n  <div class=\"label-placeholder\">&nbsp;</div>\n  <div class=\"chart-container relative h-custom\" bind:clientWidth={chartContainerWidth}>\n    <svg {viewBox}\n      preserveAspectRatio=\"none\"\n      on:mouseleave={onInteractEnd}\n      on:touchend={onInteractEnd}\n    >\n      <g class=\"data\">\n        {#each formattedData as { key, d, top, bottom } (key)}\n          <g\n            data-id={key}\n          >\n            <polygon\n              points=\"{top[0]},0 {top[1]},0 {bottom[1]},{dim} {bottom[0]},{dim}\"\n              class=\"opacity-none\"\n              data-key={key}\n              use:interactAction={{ key }}\n            />\n          </g>\n        {/each}\n      </g>\n      <g class=\"over\">\n        {#each formattedData as { key, d, top, bottom } (key)}\n          <g\n            data-id={key}\n            style=\"--over-opacity: {Number(Boolean(hoverIDCountry === key))};\"\n          >\n            {#each ['left', 'right'] as side, i}\n              <line\n                x1={top[i]}\n                x2={bottom[i]}\n                y2={dim}\n                class={showLines === true ? 'stroke-1 stroke-black opacity-over' : 'no-stroke opacity-none'}\n              />\n            {/each}\n          </g>\n        {/each}\n      </g>\n    </svg>\n\n    <!-- LABELS -->\n    <div class=\"labels\" style=\"--line-offset: {-joinerHeightFinal / 2 - fontSize / 2}px; --font-size: {fontSize}px; --opacity: {showLines === true ? '0' : '1'};\">\n      {#if typeof joinerNoteFinal === 'string' && joinerNoteFinal.length}\n        <AnnotationText\n          left={`${(valueRange[1] - valueRange[0]) / 2 + valueRange[0]}%`}\n          top=\"50%\"\n          transform=\"translate(-50%, -50%)\"\n          textAlign=\"center\"\n        >\n          <div\n            class=\"invisible transition color-gray bg-white note\"\n            class:text-border={true}\n            style=\"width: min-content;\"\n          >\n            {joinerNoteFinal}\n          </div>\n        </AnnotationText>\n      {/if}\n    </div>\n  </div>\n</div>\n"],"names":[],"mappings":"AAwHmB,4BAAC,CAAC,YAAY,eAAe,CAAC,YAAY,CAAC,gBAAgB,CAAC,SAAS,CAAC,KAAK,CAAC,UAAU,CAAC,sCAAU,CAAC,QAAQ,YAAY,CAAC,QAAQ,IAAI,CAAC,wBAAwB,aAAa,CAAC,gBAAgB,aAAa,CAAC,4CAAgB,CAAC,MAAM,IAAI,CAAC,GAAG,8CAAkB,CAAC,MAAM,IAAI,CAAC,UAAU,IAAI,aAAa,CAAC,CAAC,UAAU,IAAI,aAAa,CAAC,CAAC,+BAAG,CAAC,MAAM,IAAI,CAAC,OAAO,IAAI,CAAC,SAAS,OAAO,CAAC,aAAa,YAAY,CAAC,iBAAG,CAAC,AAAQ,CAAC,AAAC,CAAC,cAAc,kBAAkB,CAAC,qCAAS,CAAC,SAAS,QAAQ,CAAC,AAAmI,qCAAS,CAAC,OAAO,IAAI,QAAQ,CAAC,CAAC,AAA+K,sCAAU,CAAC,OAAO,IAAI,CAAC,qCAAS,CAAC,aAAa,CAAC,CAAC,AAA6I,yCAAa,CAAC,OAAO,IAAI,CAAC,yCAAa,CAAC,QAAQ,CAAC,CAAC,yCAAa,CAAC,QAAQ,IAAI,cAAc,CAAC,CAAC,iCAAK,CAAC,eAAe,IAAI,CAAC,AAAwB,uCAAW,CAAC,MAAM,IAAI,CAAC,AAAwB,qCAAS,CAAC,iBAAiB,IAAI,CAAC,mCAAO,CAAC,oBAAoB,IAAI,CAAC,iBAAiB,IAAI,CAAC,gBAAgB,IAAI,CAAC,YAAY,IAAI,CAAC,UAAU,IAAI,WAAW,CAAC,CAAC,QAAQ,IAAI,SAAS,CAAC,CAAC,eAAe,IAAI,CAAC,mCAAO,QAAQ,CAAC,QAAQ,GAAG,CAAC,QAAQ,KAAK,CAAC,WAAW,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,kBAAkB,UAAU,CAAC,CAAC,CAAC,IAAI,aAAa,CAAC,CAAC,CAAC,UAAU,UAAU,CAAC,CAAC,CAAC,IAAI,aAAa,CAAC,CAAC,CAAC,qBAAO,CAAC,mBAAK,CAAC,QAAQ,GAAG,CAAC,GAAG,CAAC,4CAAgB,CAAC,OAAO,SAAS,CAAC"} */.container.svelte-1n7e0f4{display:-webkit-flex;display:flex;-webkit-justify-content:space-between;justify-content:space-between}.chart-container.svelte-1n7e0f4{width:100%}div.label-placeholder.svelte-1n7e0f4{width:100%;max-width:var(--label-width);min-width:var(--label-width)}svg.svelte-1n7e0f4{width:100%;height:100%;overflow:visible}svg.svelte-1n7e0f4 *{vector-effect:non-scaling-stroke}.relative.svelte-1n7e0f4{position:relative}.absolute.svelte-1n7e0f4{position:absolute}.h-custom.svelte-1n7e0f4{height:7px}.stroke-1.svelte-1n7e0f4{stroke-width:1}.stroke-black.svelte-1n7e0f4{stroke:#000}.color-black.svelte-1n7e0f4{color:#000}.chart-container.svelte-1n7e0f4{margin-top:var(--container-margin-top);margin-bottom:var(--container-margin-bottom)}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"Liner.svelte","sources":["Liner.svelte"],"sourcesContent":["<script>\n  import { onMount } from 'svelte';\n  import { scaleLinear } from 'd3-scale';\n  import { apnumber } from 'journalize';\n  import { styleObjectToString } from '../ChartComponents/Chart.svelte';\n  import AnnotationText from '../ChartComponents/AnnotationText.svelte';\n  import { getDataFormatter } from '../../js/modules/formatters';\n  export let alignRight = false;\n  export let orient = 'top';\n  export let count;\n  export let value;\n  export let dataFormat = 'percent1LessZero';\n  export let alignRightText = `The {count} countries had {value}`;\n  export let alignLeftText = `The {count} countries had {value}`;\n  export let alignRightTextSingular;\n  export let alignLeftTextSingular;\n  export let labelWidth = 0;\n\n  const MOBILE_WIDTH = 420;\n  const dim = 100;\n  let chartContainer;\n  let chartContainerWidth;\n  let annotationElement;\n  let annotationWidth = 0;\n  const valueDomain = [0, 1];\n\n  $: horizontalLineY = orient === 'bottom' ? dim : 0;\n  $: viewBox = `0 0 ${dim} ${dim}`;\n  $: valueRange = alignRight === true ? [dim, 0] : [0, dim];\n  $: xScale = scaleLinear().domain(valueDomain).range(valueRange);\n  $: dimMultiplier = chartContainerWidth / dim;\n  $: isMobile = chartContainerWidth - labelWidth <= MOBILE_WIDTH;\n  $: annotationMiddle = Math.abs(xScale(value) - valueRange[0]) / 2;\n  $: annotationTextBeforeReplacements = alignRight === true ? (count === 1 ? alignRightTextSingular || alignRightText : alignRightText) : (count === 1 ? alignLeftTextSingular || alignLeftText : alignLeftText);\n  $: annotationText = annotationTextBeforeReplacements.replace(/{count}/, apnumber(count)).replace(/{value}/, getDataFormatter(dataFormat)(value));\n  $: annotationPositionLeftPct = alignRight ? 100 - annotationMiddle : annotationMiddle;\n  $: annotationMarginsNeededPct = ((annotationWidth / 2) / chartContainerWidth) * 100;\n  $: annotationPositionLeftPctFinal = Math.max(annotationMarginsNeededPct, Math.min(100 - annotationMarginsNeededPct, annotationPositionLeftPct));\n  $: annotationPositionTop = isMobile ? (orient === 'bottom' ? `28px` : `-21px`) : (orient === 'bottom' ? `calc(100% + 14px)` : `-14px`);\n\n  const annotationElementChange = () => {\n    chartContainerWidth = chartContainer.clientWidth;\n    annotationWidth = annotationElement ? annotationElement.getBoundingClientRect().width : 0;\n  };\n  onMount(() => {\n    chartContainerWidth = chartContainer.clientWidth;\n    annotationWidth = annotationElement ? annotationElement.getBoundingClientRect().width : 0;\n    const MutationObserver = window.MutationObserver || window.WebKitMutationObserver || window.MozMutationObserver;\n    const observer = new MutationObserver(annotationElementChange);\n    observer.observe(annotationElement, {\n      childList: true\n    });\n  });\n  /* $: {\n    console.log(annotationWidth, chartContainerWidth, annotationMarginsNeededPct, annotationPositionLeftPctFinal);\n  }*/\n</script>\n\n<style lang=\"scss\">.container{display:-webkit-flex;display:flex;-webkit-justify-content:space-between;justify-content:space-between}.chart-container{width:100%}div.label-placeholder{width:100%;max-width:var(--label-width);min-width:var(--label-width)}svg{width:100%;height:100%;overflow:visible}svg :global(*){vector-effect:non-scaling-stroke}.relative{position:relative}.absolute{position:absolute}.non-scaling-stroke :global(*){vector-effect:non-scaling-stroke}.w-full{width:100%}.h-full{height:100%}.h-custom{height:7px}.h-50{height:50px}.h-70{height:70px}.h-100{height:100px}.h-150{height:150px}.h-200{height:200px}.h-300{height:300px}.h-400{height:400px}.h-500{height:500px}.no-fill{fill:none}.no-stroke{stroke:none}.stroke-1{stroke-width:1}.stroke-2{stroke-width:2}.stroke-3{stroke-width:3}.stroke-4{stroke-width:4}.fill-white{fill:#fff}.fill-highlight{fill:var(--highlight-color)}.stroke-black{stroke:#000}.opacity-none{opacity:0}.opacity-over{opacity:var(--over-opacity)}.over{pointer-events:none}.color-black{color:#000}.color-white{color:#fff}.chart-container{margin-top:var(--container-margin-top);margin-bottom:var(--container-margin-bottom)}</style>\n\n<div class=\"container\" style=\"--label-width:{labelWidth}px;\">\n  <div class=\"label-placeholder\">&nbsp;</div>\n  <div\n    class=\"chart-container relative h-custom\"\n    bind:this={chartContainer}\n    style=\"--container-margin-top: {orient === 'bottom' ? 7 : 21}px; --container-margin-bottom: {orient === 'bottom' ? 21 : 7}px;\"\n  >\n    <svg {viewBox}\n      preserveAspectRatio=\"none\"\n      class=\"absolute\" style=\"top: 0; left: 0;\"\n    >\n      <g class=\"stroke-1 stroke-black\">\n        <line x1={valueRange[0]} y1=\"0\" x2={valueRange[0]} y2={dim}/>\n        <line x1={valueRange[0]} y1={horizontalLineY} x2={xScale(value)} y2={horizontalLineY}/>\n        <line x1={xScale(value)} y1=\"0\" x2={xScale(value)} y2={dim}/>\n      </g>\n    </svg>\n    {#if annotationText}\n      <AnnotationText\n        left={isMobile ? `initial` : `${annotationPositionLeftPctFinal}%`}\n        top={annotationPositionTop}\n        transform={isMobile ? `translate(0, -50%)` : `translate(-50%, -50%)`}\n        textAlign=\"center\"\n        whiteSpace={isMobile ? 'initial' : 'nowrap'}\n        width={isMobile ? '100%' : null}\n      >\n        <div\n          bind:this={annotationElement}\n          class=\"invisible transition color-black\"\n          style=\"{styleObjectToString({\n            maxWidth: `${isMobile ? Math.min(chartContainerWidth, 220) : chartContainerWidth}px`,\n            width: `${isMobile ? 'initial' : 'min-content'}`,\n            whiteSpace: `${isMobile ? 'initial' : 'nowrap'}`,\n            marginLeft: isMobile ? (alignRight === true ? `auto` : 0) : null,\n            marginRight: isMobile ? (alignRight === true ? 0 : `auto`) : null,\n            textAlign: isMobile ? (alignRight === true ? 'right' : 'left') : null,\n          })}\"\n        >\n          {@html annotationText}\n        </div>\n      </AnnotationText>\n    {/if}\n  </div>\n</div>\n"],"names":[],"mappings":"AA0DmB,yBAAU,CAAC,QAAQ,YAAY,CAAC,QAAQ,IAAI,CAAC,wBAAwB,aAAa,CAAC,gBAAgB,aAAa,CAAC,+BAAgB,CAAC,MAAM,IAAI,CAAC,GAAG,iCAAkB,CAAC,MAAM,IAAI,CAAC,UAAU,IAAI,aAAa,CAAC,CAAC,UAAU,IAAI,aAAa,CAAC,CAAC,kBAAG,CAAC,MAAM,IAAI,CAAC,OAAO,IAAI,CAAC,SAAS,OAAO,CAAC,kBAAG,CAAC,AAAQ,CAAC,AAAC,CAAC,cAAc,kBAAkB,CAAC,wBAAS,CAAC,SAAS,QAAQ,CAAC,wBAAS,CAAC,SAAS,QAAQ,CAAC,AAAuG,wBAAS,CAAC,OAAO,GAAG,CAAC,AAAsM,wBAAS,CAAC,aAAa,CAAC,CAAC,AAA6I,4BAAa,CAAC,OAAO,IAAI,CAAC,AAA4F,2BAAY,CAAC,MAAM,IAAI,CAAC,AAAwB,+BAAgB,CAAC,WAAW,IAAI,sBAAsB,CAAC,CAAC,cAAc,IAAI,yBAAyB,CAAC,CAAC"} */.asset-key.svelte-1ywg0it.svelte-1ywg0it{display:block;margin-bottom:14px}.asset-key.svelte-1ywg0it .asset-key-item.svelte-1ywg0it{margin-right:0}.asset-key.svelte-1ywg0it ul.svelte-1ywg0it{display:inline-block}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQ2hhcnRLZXlfdjIuc3ZlbHRlIiwic291cmNlcyI6WyJDaGFydEtleV92Mi5zdmVsdGUiXSwic291cmNlc0NvbnRlbnQiOlsiPHNjcmlwdD5cbiAgaW1wb3J0IHN0eWxlT2JqZWN0IGZyb20gJ3N0eWxlLW9iamVjdC10by1jc3Mtc3RyaW5nJztcbiAgZXhwb3J0IGxldCBpdGVtcyA9IFtdO1xuICBleHBvcnQgbGV0IHByZUtleUxhYmVsO1xuICBleHBvcnQgbGV0IHBvc3RLZXlMYWJlbDtcbjwvc2NyaXB0PlxuXG48c3R5bGUgbGFuZz1cInNjc3NcIj4uYXNzZXQta2V5e2Rpc3BsYXk6YmxvY2s7bWFyZ2luLWJvdHRvbToxNHB4fS5hc3NldC1rZXkgLmFzc2V0LWtleS1pdGVte21hcmdpbi1yaWdodDowfS5hc3NldC1rZXkgdWx7ZGlzcGxheTppbmxpbmUtYmxvY2t9PC9zdHlsZT5cblxuPGRpdiBjbGFzcz1cImFzc2V0LWtleVwiPlxuICB7I2lmIHByZUtleUxhYmVsfVxuICAgIDxzcGFuPntwcmVLZXlMYWJlbH08L3NwYW4+XG4gIHsvaWZ9XG4gIDx1bD5cbiAgICB7I2VhY2ggaXRlbXMgYXMgeyBjb2xvciwgd2lkdGggPSA4LCB0ZXh0ID0gJycsIHR5cGUgPSAnbGluZScgfX1cbiAgICAgIDxsaSBjbGFzcz1cImFzc2V0LWtleS1pdGVtXCI+XG4gICAgICAgIHsjaWYgWydzcXVhcmUnLCAnY2lyY2xlJ10uaW5kZXhPZih0eXBlKSAhPT0gLTF9XG4gICAgICAgICAgPHNwYW5cbiAgICAgICAgICAgIGNsYXNzPVwiYXNzZXQta2V5LXt0eXBlfVwiXG4gICAgICAgICAgICBzdHlsZT17c3R5bGVPYmplY3Qoe1xuICAgICAgICAgICAgYmFja2dyb3VuZENvbG9yOiBjb2xvcixcbiAgICAgICAgICAgIGNvbG9yLFxuICAgICAgICAgICAgd2lkdGg6IGAke3dpZHRofXB4YCxcbiAgICAgICAgICAgIH0pfVxuICAgICAgICAgIC8+XG4gICAgICAgIHs6ZWxzZSBpZiB0eXBlID09PSAnbGluZSd9XG4gICAgICAgICAgPHNwYW5cbiAgICAgICAgICAgIGNsYXNzPVwiYXNzZXQta2V5LWxpbmVcIlxuICAgICAgICAgICAgc3R5bGU9e3N0eWxlT2JqZWN0KHtcbiAgICAgICAgICAgIGNvbG9yOiBgd2hpdGVgLFxuICAgICAgICAgICAgYm9yZGVyQm90dG9tOiBgJHt3aWR0aH1weCBzb2xpZCAke2NvbG9yfWAsXG4gICAgICAgICAgICB0cmFuc2Zvcm06IGB0cmFuc2xhdGUoNXB4LCAwKSByb3RhdGUoLTQ1ZGVnKWAsXG4gICAgICAgICAgICB0cmFuc2Zvcm1PcmlnaW46IGBib3R0b20gbGVmdGAsXG4gICAgICAgICAgICB9KX0gLz5cbiAgICAgICAgey9pZn1cbiAgICAgICAge0BodG1sIHRleHR9XG4gICAgICA8L2xpPlxuICAgIHsvZWFjaH1cbiAgPC91bD5cbiAgeyNpZiBwb3N0S2V5TGFiZWx9XG4gICAgPHNwYW4+e3Bvc3RLZXlMYWJlbH08L3NwYW4+XG4gIHsvaWZ9XG48L2Rpdj5cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFPbUIsd0NBQVUsQ0FBQyxRQUFRLEtBQUssQ0FBQyxjQUFjLElBQUksQ0FBQyx5QkFBVSxDQUFDLDhCQUFlLENBQUMsYUFBYSxDQUFDLENBQUMseUJBQVUsQ0FBQyxpQkFBRSxDQUFDLFFBQVEsWUFBWSxDQUFDIn0= */.tooltip-point.svelte-1y31kz5.svelte-1y31kz5{border:1px solid #ff0038;pointer-events:none;width:0}.tooltip-point.svelte-1y31kz5 svg circle.svelte-1y31kz5{fill:#fff;stroke-width:2px}svg.svelte-1y31kz5.svelte-1y31kz5{position:absolute;overflow:visible;top:0;left:0}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"Tooltip_v2.svelte","sources":["Tooltip_v2.svelte"],"sourcesContent":["<script>\n  import { afterUpdate, getContext } from 'svelte';\n  import { line } from 'd3-shape';\n  import styleToCss from 'style-object-to-css-string';\n  import { styleObjectToString } from './Chart.svelte';\n\n  export let debug = false;\n\n  export let getData = () => {};\n  export let getPosition = () => {};\n  export let getOrientVertical = undefined;\n  export let forceOrientHorizontal = undefined;\n  export let pointColor = 'black';\n  export let showCircle = true;\n  export let hideTooltip = false;\n  export let allowSwipe = true;\n  export let arrowWidth = 10;\n  export let arrowHeight = 10;\n  export let circleRadius = 4;\n  export let circleBuffer = 3;\n\n  const tooltipStore = getContext(`tooltip-store`);\n\n  let actionData;\n  let actionNode;\n  let actionEvent;\n\n  function match(key, obj) {\n    if (typeof obj === 'function') {\n      const obj_ = obj();\n      return obj_[key];\n    }\n    return obj[key];\n  }\n\n  function action(node, data_) {\n    let currentData = data_;\n    let currentNode = node;\n    if (debug) console.log('TOOLTIP ACTION');\n    function tooltipUpdate(event) {\n      if (debug) console.log('TOOLTIP UPDATE', currentData, actionData, event);\n      actionEvent = event;\n      actionData = currentData;\n      actionNode = currentNode;\n    }\n    function tooltipClear() {\n      actionEvent = null;\n      actionData = null;\n      actionNode = null;\n    }\n    const startEvents = [`mouseover`, `mousemove`];\n    const endEvents = [`mouseout`];\n    if (allowSwipe) {\n      startEvents.push('touchstart');\n      endEvents.push('touchend');\n    }\n    startEvents.forEach((eventName) => {\n      node.addEventListener(eventName, tooltipUpdate, { passive: true });\n    });\n    endEvents.forEach((eventName) => {\n      node.addEventListener(eventName, tooltipClear, { passive: true });\n    });\n    const onTouchMove = (event) => {\n      if (debug) {\n        console.log(`TOOLTIP TOUCHMOVE`, event);\n      }\n      if (event.touches) {\n        const xPos = event.touches[0].pageX;\n        const yPos = event.touches[0].pageY;\n        const element = document.elementFromPoint(\n          xPos - window.pageXOffset,\n          yPos - window.pageYOffset\n        );\n        if (element && element.dataset) {\n          actionData = { ...element.dataset };\n          actionNode = element;\n          actionEvent = event;\n        }\n      }\n    };\n    if (allowSwipe) {\n      node.addEventListener('touchmove', onTouchMove, { passive: true });\n    }\n    return {\n      update(data_) {\n        currentData = data_;\n      },\n      destroy() {\n        startEvents.forEach((eventName) => {\n          node.removeEventListener(eventName, tooltipUpdate);\n        });\n        endEvents.forEach((eventName) => {\n          node.removeEventListener(eventName, tooltipClear);\n        });\n        node.removeEventListener('touchmove', onTouchMove);\n      },\n    };\n  }\n\n  $: if (tooltipStore) $tooltipStore = actionData;\n\n  $: storeData = tooltipStore && $tooltipStore;\n\n  $: actionDataFinal =\n    typeof storeData !== 'undefined' ? storeData : actionData;\n\n  $: templateData = actionDataFinal\n    ? { ...getData(actionDataFinal, actionEvent), _node: actionNode }\n    : null;\n  $: position = templateData ? getPosition(templateData) : null;\n  $: ({ left, top } = position || {});\n\n  const TOP = `TOP`;\n  const MIDDLE = `MIDDLE`;\n  const BOTTOM = `BOTTOM`;\n  const LEFT = `LEFT`;\n  const RIGHT = `RIGHT`;\n  const CENTER = `CENTER`;\n\n  let ref;\n  let pointRef;\n\n  let rect;\n  let pointRect;\n\n  afterUpdate(() => {\n    pointRect = pointRef ? pointRef.getBoundingClientRect() : null;\n    rect = ref ? ref.getBoundingClientRect() : null;\n  });\n\n  let orientVertical = TOP;\n  let orientHorizontal = CENTER;\n\n  // $: ({ width, height, left, right } = rect || {});\n\n  $: {\n    if (getOrientVertical) {\n      const maybe = getOrientVertical(templateData);\n      if ([TOP, MIDDLE, BOTTOM].indexOf(maybe) !== -1) {\n        orientVertical = maybe;\n      }\n    } else {\n      orientVertical = TOP;\n    }\n  }\n\n  $: {\n    if (rect && pointRect) {\n      const { left: x } = pointRect;\n      const { width } = rect;\n      const right = x + width / 2;\n      const left = x - width / 2;\n      if (right > window.innerWidth) {\n        orientHorizontal = LEFT;\n      } else if (left < 0) {\n        orientHorizontal = RIGHT;\n      } else {\n        orientHorizontal = forceOrientHorizontal || CENTER;\n      }\n    }\n  }\n\n  $: arrowLeft = match(orientHorizontal, {\n    [LEFT]: `100%`,\n    [CENTER]: `50%`,\n    [RIGHT]: 0,\n  });\n\n  $: arrowTop = match(orientVertical, {\n    [TOP]: `100%`,\n    [MIDDLE]: `50%`,\n    [BOTTOM]: 0,\n  });\n\n  $: arrowStyle = styleToCss({\n    width: `${arrowWidth}px`,\n    height: `${arrowHeight}px`,\n    left: arrowLeft,\n    top: arrowTop,\n  });\n\n  function getArrowPoints(orientH, orientV) {\n    const w = arrowWidth;\n    const h = arrowHeight * (orientV === BOTTOM ? -1 : 1);\n    const z = 0.5;\n    return match(orientH, {\n      [LEFT]: [\n        [z, 0],\n        [z, h],\n        [-w, 0],\n      ],\n      [RIGHT]: [\n        [-z, 0],\n        [-z, h],\n        [w, 0],\n      ],\n      [CENTER]: [\n        [-w, 0],\n        [0, h],\n        [w, 0],\n      ],\n    });\n  }\n\n  $: arrowPoints = getArrowPoints(orientHorizontal, orientVertical);\n\n  $: arrowPathDefinition = line()(arrowPoints);\n\n  $: translateX = match(orientHorizontal, {\n    [LEFT]: `-100%`,\n    [CENTER]: `-50%`,\n    [RIGHT]: `0`,\n  });\n\n  $: translateY = match(orientVertical, {\n    [TOP]: `calc(-100% - ${arrowHeight + circleRadius + circleBuffer}px)`,\n    [BOTTOM]: `calc(50% - ${arrowHeight + circleRadius + circleBuffer}px)`,\n  });\n\n  $: transform = `translate(${translateX}, ${translateY})`;\n\n  $: style = styleObjectToString({ left, top, transform });\n\n  $: if (debug) {\n    console.log('TOOLTIP STYLE', style);\n    console.log('TOOLTIP DATA', templateData);\n  }\n</script>\n\n<slot {action} />\n{#if templateData && position && hideTooltip !== true}\n  <div\n    class=\"tooltip-point\"\n    style={styleObjectToString({ position: 'absolute', left, top, opacity: 0 })}\n    bind:this={pointRef}\n  >\n    <svg\n      style={styleObjectToString({\n        position: 'absolute',\n        opacity: Number(showCircle),\n      })}\n    >\n      <g>\n        <circle\n          r={circleRadius}\n          cx={-circleRadius + circleBuffer}\n          cy={-circleRadius + circleBuffer}\n          stroke={pointColor}\n        />\n      </g>\n    </svg>\n  </div>\n  <div class=\"dvz-tooltip tt-svelte\" {style} bind:this={ref}>\n    <slot name=\"tooltip-template\" data={templateData} />\n    <svg style={arrowStyle}>\n      <path d={arrowPathDefinition} fill=\"white\" stroke=\"black\" />\n    </svg>\n  </div>\n{/if}\n\n<style lang=\"scss\">.tooltip-point{border:1px solid #ff0038;pointer-events:none;width:0}.tooltip-point svg circle{fill:#fff;stroke-width:2px}.tooltip{position:absolute;z-index:1000;width:-webkit-max-content;width:-moz-max-content;width:max-content;padding:10px;border:1px solid #000;box-shadow:0 0 10px rgba(140,140,140,.2);background:#fff;pointer-events:none;font-family:\"BWHaasDingbat\",\"BWHaasText\",\"Helvetica Neue\",Helvetica,Arial,sans-serif}.tooltip *{padding:0}svg{position:absolute;overflow:visible;top:0;left:0}polygon{stroke:none;fill:#000}polygon.white{fill:#fff}</style>\n"],"names":[],"mappings":"AAoQmB,4CAAc,CAAC,OAAO,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,eAAe,IAAI,CAAC,MAAM,CAAC,CAAC,6BAAc,CAAC,GAAG,CAAC,qBAAM,CAAC,KAAK,IAAI,CAAC,aAAa,GAAG,CAAC,AAAqU,iCAAG,CAAC,SAAS,QAAQ,CAAC,SAAS,OAAO,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,CAAC"} */div.annotation-text.svelte-13t1sa9{position:absolute;font-family:var(--font-family, "BWHaasDingbat", "BWHaasText", "Helvetica Neue", Helvetica, Arial, sans-serif);font-size:var(--font-size, 14px);line-height:var(--line-height, 16px);font-variant-numeric:tabular-nums;pointer-events:var(--pointer-events, none)}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQW5ub3RhdGlvblRleHQuc3ZlbHRlIiwic291cmNlcyI6WyJBbm5vdGF0aW9uVGV4dC5zdmVsdGUiXSwic291cmNlc0NvbnRlbnQiOlsiPHNjcmlwdD5cbiAgaW1wb3J0IHsgc3R5bGVPYmplY3RUb1N0cmluZyB9IGZyb20gJy4vQ2hhcnQuc3ZlbHRlJztcblxuICBleHBvcnQgbGV0IGh0bWwgPSAnJztcbiAgZXhwb3J0IGxldCBsZWZ0ID0gMDtcbiAgZXhwb3J0IGxldCB0b3AgPSAwO1xuICBleHBvcnQgbGV0IGJvdHRvbTtcbiAgZXhwb3J0IGxldCB0cmFuc2Zvcm07XG4gIGV4cG9ydCBsZXQgdGV4dEFsaWduO1xuICBleHBvcnQgbGV0IHdoaXRlU3BhY2UgPSAnbm93cmFwJztcbiAgZXhwb3J0IGxldCB3aWR0aDtcblxuICAkOiBzdHlsZU9iaiA9IGJvdHRvbSA/IHsgbGVmdCwgYm90dG9tLCB0cmFuc2Zvcm0sIHRleHRBbGlnbiwgd2hpdGVTcGFjZSwgd2lkdGggfSA6IHsgbGVmdCwgdG9wLCB0cmFuc2Zvcm0sIHRleHRBbGlnbiwgd2hpdGVTcGFjZSwgd2lkdGggfTtcbiAgJDogc3R5bGUgPSBzdHlsZU9iamVjdFRvU3RyaW5nKHN0eWxlT2JqKTtcbjwvc2NyaXB0PlxuXG48c3R5bGUgbGFuZz1cInNjc3NcIj5kaXYuYW5ub3RhdGlvbi10ZXh0e3Bvc2l0aW9uOmFic29sdXRlO2ZvbnQtZmFtaWx5OnZhcigtLWZvbnQtZmFtaWx5LCBcIkJXSGFhc0RpbmdiYXRcIiwgXCJCV0hhYXNUZXh0XCIsIFwiSGVsdmV0aWNhIE5ldWVcIiwgSGVsdmV0aWNhLCBBcmlhbCwgc2Fucy1zZXJpZik7Zm9udC1zaXplOnZhcigtLWZvbnQtc2l6ZSwgMTRweCk7bGluZS1oZWlnaHQ6dmFyKC0tbGluZS1oZWlnaHQsIDE2cHgpO2ZvbnQtdmFyaWFudC1udW1lcmljOnRhYnVsYXItbnVtcztwb2ludGVyLWV2ZW50czp2YXIoLS1wb2ludGVyLWV2ZW50cywgbm9uZSl9PC9zdHlsZT5cblxuPGRpdiBjbGFzcz1cImFubm90YXRpb24tdGV4dFwiIHtzdHlsZX0gey4uLiQkcHJvcHN9PlxuICB7QGh0bWwgaHRtbH1cbiAgPHNsb3QgLz5cbjwvZGl2PlxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWdCbUIsR0FBRywrQkFBZ0IsQ0FBQyxTQUFTLFFBQVEsQ0FBQyxZQUFZLElBQUksYUFBYSxDQUFDLDhFQUE4RSxDQUFDLENBQUMsVUFBVSxJQUFJLFdBQVcsQ0FBQyxLQUFLLENBQUMsQ0FBQyxZQUFZLElBQUksYUFBYSxDQUFDLEtBQUssQ0FBQyxDQUFDLHFCQUFxQixZQUFZLENBQUMsZUFBZSxJQUFJLGdCQUFnQixDQUFDLEtBQUssQ0FBQyxDQUFDIn0= */svg.svelte-14ptnq5{position:absolute;overflow:visible;height:1px;width:1px}path.arrowhead-background.svelte-14ptnq5{fill:none;stroke:var(--background-stroke, none);stroke-width:var(--background-stroke-width, 0)}path.arrowhead.svelte-14ptnq5{fill:var(--color, black)}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQXJyb3dNYXJrZXIuc3ZlbHRlIiwic291cmNlcyI6WyJBcnJvd01hcmtlci5zdmVsdGUiXSwic291cmNlc0NvbnRlbnQiOlsiPHNjcmlwdD5cbiAgaW1wb3J0IHsgb25Nb3VudCB9IGZyb20gJ3N2ZWx0ZSc7XG5cbiAgZXhwb3J0IGxldCBtYXJrZXJJRCA9ICdhcnJvd2hlYWQnO1xuICBleHBvcnQgbGV0IHNpemUgPSA1O1xuICBleHBvcnQgbGV0IHN0YXJ0ID0gZmFsc2U7XG5cbiAgb25Nb3VudCgoKSA9PiB7XG4gICAgbWFya2VySUQgPSBgYXJyb3doZWFkLSR7TWF0aC5mbG9vcihNYXRoLnJhbmRvbSgpICogMTBlMyl9YDtcbiAgfSk7XG5cbiAgJDogcGF0aCA9IHN0YXJ0ID8gYE0gNywtNyBMIDAsMCBMIDcsNyB6YCA6IGBNIC03LC03IEwgMCwwIEwgLTcsNyB6YDtcbjwvc2NyaXB0PlxuXG48c3ZnPlxuICA8bWFya2VyXG4gICAgaWQ9e21hcmtlcklEfVxuICAgIHZpZXdCb3g9e2AtMTAgLTEwIDIwIDIwYH1cbiAgICBtYXJrZXJXaWR0aD17c2l6ZX1cbiAgICBtYXJrZXJIZWlnaHQ9e3NpemV9XG4gICAgb3JpZW50PVwiYXV0b1wiXG4gID5cbiAgICA8cGF0aCBjbGFzcz1cImFycm93aGVhZC1iYWNrZ3JvdW5kXCIgZD17cGF0aH0gLz5cbiAgICA8cGF0aCBjbGFzcz1cImFycm93aGVhZFwiIGQ9e3BhdGh9IC8+XG4gIDwvbWFya2VyPlxuPC9zdmc+XG5cbjxzbG90IHttYXJrZXJJRH0gLz5cblxuPHN0eWxlPlxuICBzdmcge1xuICAgIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgICBvdmVyZmxvdzogdmlzaWJsZTtcbiAgICBoZWlnaHQ6IDFweDtcbiAgICB3aWR0aDogMXB4O1xuICB9XG4gIHBhdGguYXJyb3doZWFkLWJhY2tncm91bmQge1xuICAgIGZpbGw6IG5vbmU7XG4gICAgc3Ryb2tlOiB2YXIoLS1iYWNrZ3JvdW5kLXN0cm9rZSwgbm9uZSk7XG4gICAgc3Ryb2tlLXdpZHRoOiB2YXIoLS1iYWNrZ3JvdW5kLXN0cm9rZS13aWR0aCwgMCk7XG4gIH1cbiAgcGF0aC5hcnJvd2hlYWQge1xuICAgIGZpbGw6IHZhcigtLWNvbG9yLCBibGFjayk7XG4gIH08L3N0eWxlPlxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQThCRSxHQUFHLGVBQUMsQ0FBQyxBQUNILFFBQVEsQ0FBRSxRQUFRLENBQ2xCLFFBQVEsQ0FBRSxPQUFPLENBQ2pCLE1BQU0sQ0FBRSxHQUFHLENBQ1gsS0FBSyxDQUFFLEdBQUcsQUFDWixDQUFDLEFBQ0QsSUFBSSxxQkFBcUIsZUFBQyxDQUFDLEFBQ3pCLElBQUksQ0FBRSxJQUFJLENBQ1YsTUFBTSxDQUFFLElBQUksbUJBQW1CLENBQUMsS0FBSyxDQUFDLENBQ3RDLFlBQVksQ0FBRSxJQUFJLHlCQUF5QixDQUFDLEVBQUUsQ0FBQyxBQUNqRCxDQUFDLEFBQ0QsSUFBSSxVQUFVLGVBQUMsQ0FBQyxBQUNkLElBQUksQ0FBRSxJQUFJLE9BQU8sQ0FBQyxNQUFNLENBQUMsQUFDM0IsQ0FBQyJ9 */.chart-container.svelte-l051g7{position:relative;border:var(--border, initial);width:var(--width);max-width:var(--max-width, 90vw);height:var(--height, 300px);margin-left:var(--margin-left, 1rem);margin-right:var(--margin-right, 3rem);margin-top:var(--margin-top, 0);margin-bottom:var(--margin-bottom, 0);margin:var(--margin);shape-rendering:var(--shape-rendering, crispedges)}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQ29udGFpbmVyLnN2ZWx0ZSIsInNvdXJjZXMiOlsiQ29udGFpbmVyLnN2ZWx0ZSJdLCJzb3VyY2VzQ29udGVudCI6WyI8ZGl2IGNsYXNzPVwiY2hhcnQtY29udGFpbmVyXCIgey4uLiQkcHJvcHN9PlxuICA8c2xvdCAvPlxuPC9kaXY+XG5cbjxzdHlsZT5cbiAgLmNoYXJ0LWNvbnRhaW5lciB7XG4gICAgcG9zaXRpb246IHJlbGF0aXZlO1xuICAgIGJvcmRlcjogdmFyKC0tYm9yZGVyLCBpbml0aWFsKTtcbiAgICB3aWR0aDogdmFyKC0td2lkdGgpO1xuICAgIG1heC13aWR0aDogdmFyKC0tbWF4LXdpZHRoLCA5MHZ3KTtcbiAgICBoZWlnaHQ6IHZhcigtLWhlaWdodCwgMzAwcHgpO1xuICAgIG1hcmdpbi1sZWZ0OiB2YXIoLS1tYXJnaW4tbGVmdCwgMXJlbSk7XG4gICAgbWFyZ2luLXJpZ2h0OiB2YXIoLS1tYXJnaW4tcmlnaHQsIDNyZW0pO1xuICAgIG1hcmdpbi10b3A6IHZhcigtLW1hcmdpbi10b3AsIDApO1xuICAgIG1hcmdpbi1ib3R0b206IHZhcigtLW1hcmdpbi1ib3R0b20sIDApO1xuICAgIG1hcmdpbjogdmFyKC0tbWFyZ2luKTtcbiAgICBzaGFwZS1yZW5kZXJpbmc6IHZhcigtLXNoYXBlLXJlbmRlcmluZywgY3Jpc3BlZGdlcyk7XG4gIH08L3N0eWxlPlxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUtFLGdCQUFnQixjQUFDLENBQUMsQUFDaEIsUUFBUSxDQUFFLFFBQVEsQ0FDbEIsTUFBTSxDQUFFLElBQUksUUFBUSxDQUFDLFFBQVEsQ0FBQyxDQUM5QixLQUFLLENBQUUsSUFBSSxPQUFPLENBQUMsQ0FDbkIsU0FBUyxDQUFFLElBQUksV0FBVyxDQUFDLEtBQUssQ0FBQyxDQUNqQyxNQUFNLENBQUUsSUFBSSxRQUFRLENBQUMsTUFBTSxDQUFDLENBQzVCLFdBQVcsQ0FBRSxJQUFJLGFBQWEsQ0FBQyxLQUFLLENBQUMsQ0FDckMsWUFBWSxDQUFFLElBQUksY0FBYyxDQUFDLEtBQUssQ0FBQyxDQUN2QyxVQUFVLENBQUUsSUFBSSxZQUFZLENBQUMsRUFBRSxDQUFDLENBQ2hDLGFBQWEsQ0FBRSxJQUFJLGVBQWUsQ0FBQyxFQUFFLENBQUMsQ0FDdEMsTUFBTSxDQUFFLElBQUksUUFBUSxDQUFDLENBQ3JCLGVBQWUsQ0FBRSxJQUFJLGlCQUFpQixDQUFDLFdBQVcsQ0FBQyxBQUNyRCxDQUFDIn0= */svg.svelte-1hd0fq{display:block;position:absolute;left:var(--left, 0);top:var(--top, 0);width:var(--width, 100%);height:var(--height, 100%);overflow:var(--overflow, visible);border:var(--border);shape-rendering:var(--shape-rendering, geometricPrecision)}path.svelte-1hd0fq{vector-effect:non-scaling-stroke;fill:var(--fill, none);fill-opacity:var(--fill-opacity, 1);stroke:var(--stroke, black);stroke-opacity:var(--stroke-opacity, 1);stroke-width:var(--stroke-width, 1px);stroke-linejoin:var(--stroke-linejoin, 'miter')}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiUGF0aC5zdmVsdGUiLCJzb3VyY2VzIjpbIlBhdGguc3ZlbHRlIl0sInNvdXJjZXNDb250ZW50IjpbIjxzY3JpcHQ+XG4gIC8vIEB0cy1jaGVja1xuICBpbXBvcnQgeyBsaW5lLCBjdXJ2ZUxpbmVhciB9IGZyb20gJ2QzLXNoYXBlJztcblxuICAkOiAoe1xuICAgIGRhdGEgPSBbXSxcbiAgICB4ID0gKGQpID0+IGQueCxcbiAgICB5ID0gKGQpID0+IGQueSxcbiAgICBjdXJ2ZSA9IGN1cnZlTGluZWFyLFxuICAgIGRlZmluZWQgPSAoZCkgPT4gdHJ1ZSxcbiAgICBsaW5lRnVuYyA9IGxpbmUoeCwgeSkuY3VydmUoY3VydmUpLmRlZmluZWQoZGVmaW5lZCksXG4gICAgZDogcGF0aERlZmluaXRpb24gPSBsaW5lRnVuYyhkYXRhKSxcbiAgICBkZWJ1ZyxcbiAgICAuLi5yZXN0XG4gIH0gPSAkJHByb3BzKTtcblxuICAvLyBgbnVsbGAgaXMgYSB2YWxpZCBwYXRoIHZhbHVlXG4gICQ6IGlzVmFsaWQgPSBwYXRoRGVmaW5pdGlvbiA9PT0gbnVsbCA/IHRydWUgOiAhcGF0aERlZmluaXRpb24uaW5jbHVkZXMoJ05hTicpO1xuXG4gICQ6IGlmIChkZWJ1Zykge1xuICAgIGNvbnN0IG1hcHBlZCA9IGRhdGEubWFwKChkKSA9PiAoeyAuLi5kLCB4OiB4KGQpLCB5OiB5KGQpIH0pKTtcbiAgICBjb25zb2xlLmxvZyhgUGF0aDpgLCB7IGRhdGEsIG1hcHBlZCwgcGF0aERlZmluaXRpb24gfSk7XG4gIH1cblxuICAkOiAhaXNWYWxpZCAmJlxuICAgIGNvbnNvbGUubG9nKGBJbnZhbGlkIHBhdGggZGVmaW5pdGlvbiBmb3I6YCwgZGF0YSwgcGF0aERlZmluaXRpb24pO1xuPC9zY3JpcHQ+XG5cbnsjaWYgcGF0aERlZmluaXRpb24gJiYgaXNWYWxpZH1cbiAgPGRpdiBjbGFzcz1cInBhdGhcIiB7Li4ucmVzdH0+XG4gICAgPHN2ZyB2aWV3Qm94PVwiMCAwIDEwMCAxMDBcIiBwcmVzZXJ2ZUFzcGVjdFJhdGlvPVwibm9uZVwiPlxuICAgICAgPHBhdGggZD17cGF0aERlZmluaXRpb259IC8+XG4gICAgPC9zdmc+XG4gIDwvZGl2Plxuey9pZn1cblxuPHN0eWxlPlxuICBzdmcge1xuICAgIGRpc3BsYXk6IGJsb2NrO1xuICAgIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgICBsZWZ0OiB2YXIoLS1sZWZ0LCAwKTtcbiAgICB0b3A6IHZhcigtLXRvcCwgMCk7XG4gICAgd2lkdGg6IHZhcigtLXdpZHRoLCAxMDAlKTtcbiAgICBoZWlnaHQ6IHZhcigtLWhlaWdodCwgMTAwJSk7XG4gICAgb3ZlcmZsb3c6IHZhcigtLW92ZXJmbG93LCB2aXNpYmxlKTtcbiAgICBib3JkZXI6IHZhcigtLWJvcmRlcik7XG4gICAgc2hhcGUtcmVuZGVyaW5nOiB2YXIoLS1zaGFwZS1yZW5kZXJpbmcsIGdlb21ldHJpY1ByZWNpc2lvbik7XG4gIH1cbiAgcGF0aCB7XG4gICAgdmVjdG9yLWVmZmVjdDogbm9uLXNjYWxpbmctc3Ryb2tlO1xuICAgIGZpbGw6IHZhcigtLWZpbGwsIG5vbmUpO1xuICAgIGZpbGwtb3BhY2l0eTogdmFyKC0tZmlsbC1vcGFjaXR5LCAxKTtcbiAgICBzdHJva2U6IHZhcigtLXN0cm9rZSwgYmxhY2spO1xuICAgIHN0cm9rZS1vcGFjaXR5OiB2YXIoLS1zdHJva2Utb3BhY2l0eSwgMSk7XG4gICAgc3Ryb2tlLXdpZHRoOiB2YXIoLS1zdHJva2Utd2lkdGgsIDFweCk7XG4gICAgc3Ryb2tlLWxpbmVqb2luOiB2YXIoLS1zdHJva2UtbGluZWpvaW4sICdtaXRlcicpO1xuICB9PC9zdHlsZT5cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFxQ0UsR0FBRyxjQUFDLENBQUMsQUFDSCxPQUFPLENBQUUsS0FBSyxDQUNkLFFBQVEsQ0FBRSxRQUFRLENBQ2xCLElBQUksQ0FBRSxJQUFJLE1BQU0sQ0FBQyxFQUFFLENBQUMsQ0FDcEIsR0FBRyxDQUFFLElBQUksS0FBSyxDQUFDLEVBQUUsQ0FBQyxDQUNsQixLQUFLLENBQUUsSUFBSSxPQUFPLENBQUMsS0FBSyxDQUFDLENBQ3pCLE1BQU0sQ0FBRSxJQUFJLFFBQVEsQ0FBQyxLQUFLLENBQUMsQ0FDM0IsUUFBUSxDQUFFLElBQUksVUFBVSxDQUFDLFFBQVEsQ0FBQyxDQUNsQyxNQUFNLENBQUUsSUFBSSxRQUFRLENBQUMsQ0FDckIsZUFBZSxDQUFFLElBQUksaUJBQWlCLENBQUMsbUJBQW1CLENBQUMsQUFDN0QsQ0FBQyxBQUNELElBQUksY0FBQyxDQUFDLEFBQ0osYUFBYSxDQUFFLGtCQUFrQixDQUNqQyxJQUFJLENBQUUsSUFBSSxNQUFNLENBQUMsS0FBSyxDQUFDLENBQ3ZCLFlBQVksQ0FBRSxJQUFJLGNBQWMsQ0FBQyxFQUFFLENBQUMsQ0FDcEMsTUFBTSxDQUFFLElBQUksUUFBUSxDQUFDLE1BQU0sQ0FBQyxDQUM1QixjQUFjLENBQUUsSUFBSSxnQkFBZ0IsQ0FBQyxFQUFFLENBQUMsQ0FDeEMsWUFBWSxDQUFFLElBQUksY0FBYyxDQUFDLElBQUksQ0FBQyxDQUN0QyxlQUFlLENBQUUsSUFBSSxpQkFBaUIsQ0FBQyxRQUFRLENBQUMsQUFDbEQsQ0FBQyJ9 */svg.svelte-9t3vcz{display:block;position:absolute;overflow:visible;left:var(--left, 0);top:var(--top, 0);height:20px;width:20px}circle.svelte-9t3vcz{fill:var(--fill, black);fill-opacity:var(--fill-opacity, 1);stroke:var(--stroke, none);stroke-opacity:var(--stroke-opacity, 1)}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiUG9pbnQuc3ZlbHRlIiwic291cmNlcyI6WyJQb2ludC5zdmVsdGUiXSwic291cmNlc0NvbnRlbnQiOlsiPHNjcmlwdD5cbiAgLy8gQHRzLWNoZWNrXG4gICQ6ICh7IHJhZGl1cyA9IDIsIC4uLnJlc3QgfSA9ICQkcHJvcHMpO1xuPC9zY3JpcHQ+XG5cbjxkaXYgZGF0YS10eXBlPVwicG9pbnRcIiB7Li4ucmVzdH0+XG4gIDxzdmc+XG4gICAgPGNpcmNsZSByPXtyYWRpdXN9IC8+XG4gIDwvc3ZnPlxuPC9kaXY+XG5cbjxzdHlsZT5cbiAgc3ZnIHtcbiAgICBkaXNwbGF5OiBibG9jaztcbiAgICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gICAgb3ZlcmZsb3c6IHZpc2libGU7XG4gICAgbGVmdDogdmFyKC0tbGVmdCwgMCk7XG4gICAgdG9wOiB2YXIoLS10b3AsIDApO1xuICAgIGhlaWdodDogMjBweDtcbiAgICB3aWR0aDogMjBweDtcbiAgfVxuICBjaXJjbGUge1xuICAgIGZpbGw6IHZhcigtLWZpbGwsIGJsYWNrKTtcbiAgICBmaWxsLW9wYWNpdHk6IHZhcigtLWZpbGwtb3BhY2l0eSwgMSk7XG4gICAgc3Ryb2tlOiB2YXIoLS1zdHJva2UsIG5vbmUpO1xuICAgIHN0cm9rZS1vcGFjaXR5OiB2YXIoLS1zdHJva2Utb3BhY2l0eSwgMSk7XG4gIH08L3N0eWxlPlxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVlFLEdBQUcsY0FBQyxDQUFDLEFBQ0gsT0FBTyxDQUFFLEtBQUssQ0FDZCxRQUFRLENBQUUsUUFBUSxDQUNsQixRQUFRLENBQUUsT0FBTyxDQUNqQixJQUFJLENBQUUsSUFBSSxNQUFNLENBQUMsRUFBRSxDQUFDLENBQ3BCLEdBQUcsQ0FBRSxJQUFJLEtBQUssQ0FBQyxFQUFFLENBQUMsQ0FDbEIsTUFBTSxDQUFFLElBQUksQ0FDWixLQUFLLENBQUUsSUFBSSxBQUNiLENBQUMsQUFDRCxNQUFNLGNBQUMsQ0FBQyxBQUNOLElBQUksQ0FBRSxJQUFJLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FDeEIsWUFBWSxDQUFFLElBQUksY0FBYyxDQUFDLEVBQUUsQ0FBQyxDQUNwQyxNQUFNLENBQUUsSUFBSSxRQUFRLENBQUMsS0FBSyxDQUFDLENBQzNCLGNBQWMsQ0FBRSxJQUFJLGdCQUFnQixDQUFDLEVBQUUsQ0FBQyxBQUMxQyxDQUFDIn0= */canvas.svelte-rwp42z{position:absolute;width:100%;height:100%;top:0;left:0}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQ2FudmFzLnN2ZWx0ZSIsInNvdXJjZXMiOlsiQ2FudmFzLnN2ZWx0ZSJdLCJzb3VyY2VzQ29udGVudCI6WyI8c2NyaXB0PlxuICBpbXBvcnQgeyBvbk1vdW50IH0gZnJvbSAnc3ZlbHRlJztcbiAgZXhwb3J0IGxldCByZW5kZXIgPSAoKSA9PiB7fTtcblxuICBsZXQgY2FudmFzO1xuXG4gIGxldCBtZWFzdXJlZFdpZHRoO1xuICBsZXQgbWVhc3VyZWRIZWlnaHQ7XG5cbiAgb25Nb3VudCgoKSA9PiB7XG4gICAgY29uc3QgZ2V0U2l6ZSA9ICgpID0+IHtcbiAgICAgIGNvbnN0IHJlY3QgPSBjYW52YXMuZ2V0Qm91bmRpbmdDbGllbnRSZWN0KCk7XG4gICAgICBtZWFzdXJlZFdpZHRoID0gcmVjdC53aWR0aDtcbiAgICAgIG1lYXN1cmVkSGVpZ2h0ID0gcmVjdC5oZWlnaHQ7XG4gICAgfTtcbiAgICBnZXRTaXplKCk7XG4gICAgY29uc3Qgb2JzZXJ2ZXIgPSBuZXcgUmVzaXplT2JzZXJ2ZXIoKCkgPT4ge1xuICAgICAgZ2V0U2l6ZSgpO1xuICAgIH0pO1xuICAgIG9ic2VydmVyLm9ic2VydmUoY2FudmFzKTtcbiAgICByZXR1cm4gKCkgPT4ge1xuICAgICAgb2JzZXJ2ZXIuZGlzY29ubmVjdCgpO1xuICAgIH07XG4gIH0pO1xuXG4gICQ6IGNvbnRleHQgPSBjYW52YXMgPyBjYW52YXMuZ2V0Q29udGV4dCgnMmQnKSA6IG51bGw7XG5cbiAgY29uc3QgZHBpID0gd2luZG93LmRldmljZVBpeGVsUmF0aW8gfHwgMTtcblxuICAkOiBjYW52YXNXaWR0aCA9IG1lYXN1cmVkV2lkdGggPyBtZWFzdXJlZFdpZHRoICogZHBpIDogbnVsbDtcbiAgJDogY2FudmFzSGVpZ2h0ID0gbWVhc3VyZWRIZWlnaHQgPyBtZWFzdXJlZEhlaWdodCAqIGRwaSA6IG51bGw7XG5cbiAgJDogaWYgKGNvbnRleHQgJiYgY2FudmFzV2lkdGggJiYgY2FudmFzSGVpZ2h0KSB7XG4gICAgY29udGV4dC5jYW52YXMud2lkdGggPSBjYW52YXNXaWR0aDtcbiAgICBjb250ZXh0LmNhbnZhcy5oZWlnaHQgPSBjYW52YXNIZWlnaHQ7XG4gICAgY29udGV4dC5zY2FsZShkcGksIGRwaSk7XG4gIH1cblxuICAkOiBpZiAoY29udGV4dCAmJiBtZWFzdXJlZFdpZHRoICYmIG1lYXN1cmVkSGVpZ2h0KSB7XG4gICAgcmVuZGVyKHsgY29udGV4dCwgd2lkdGg6IG1lYXN1cmVkV2lkdGgsIGhlaWdodDogbWVhc3VyZWRIZWlnaHQgfSk7XG4gIH1cbjwvc2NyaXB0PlxuXG48Y2FudmFzIGJpbmQ6dGhpcz17Y2FudmFzfSAvPlxuXG48c3R5bGU+XG4gIGNhbnZhcyB7XG4gICAgcG9zaXRpb246IGFic29sdXRlO1xuICAgIHdpZHRoOiAxMDAlO1xuICAgIGhlaWdodDogMTAwJTtcbiAgICB0b3A6IDA7XG4gICAgbGVmdDogMDtcbiAgfTwvc3R5bGU+XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOENFLE1BQU0sY0FBQyxDQUFDLEFBQ04sUUFBUSxDQUFFLFFBQVEsQ0FDbEIsS0FBSyxDQUFFLElBQUksQ0FDWCxNQUFNLENBQUUsSUFBSSxDQUNaLEdBQUcsQ0FBRSxDQUFDLENBQ04sSUFBSSxDQUFFLENBQUMsQUFDVCxDQUFDIn0= */svg.svelte-1krpx6v{display:block;position:absolute;left:var(--left, 0);top:var(--top, 0);width:var(--width, 100%);height:var(--height, 100%);overflow:var(--overflow, visible)}rect.svelte-1krpx6v{fill:var(--fill, gray);fill-opacity:var(--fill-opacity, 1);stroke:var(--stroke, black);stroke-opacity:var(--stroke-opacity, 1)}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiUmVjdC5zdmVsdGUiLCJzb3VyY2VzIjpbIlJlY3Quc3ZlbHRlIl0sInNvdXJjZXNDb250ZW50IjpbIjxkaXYgY2xhc3M9XCJyZWN0XCIgey4uLiQkcHJvcHN9PlxuICA8c3ZnPlxuICAgIDxyZWN0IHg9XCIwXCIgeT1cIjBcIiB3aWR0aD1cIjEwMCVcIiBoZWlnaHQ9XCIxMDAlXCIgLz5cbiAgPC9zdmc+XG48L2Rpdj5cblxuPHN0eWxlPlxuICBzdmcge1xuICAgIGRpc3BsYXk6IGJsb2NrO1xuICAgIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgICBsZWZ0OiB2YXIoLS1sZWZ0LCAwKTtcbiAgICB0b3A6IHZhcigtLXRvcCwgMCk7XG4gICAgd2lkdGg6IHZhcigtLXdpZHRoLCAxMDAlKTtcbiAgICBoZWlnaHQ6IHZhcigtLWhlaWdodCwgMTAwJSk7XG4gICAgb3ZlcmZsb3c6IHZhcigtLW92ZXJmbG93LCB2aXNpYmxlKTtcbiAgfVxuICByZWN0IHtcbiAgICBmaWxsOiB2YXIoLS1maWxsLCBncmF5KTtcbiAgICBmaWxsLW9wYWNpdHk6IHZhcigtLWZpbGwtb3BhY2l0eSwgMSk7XG4gICAgc3Ryb2tlOiB2YXIoLS1zdHJva2UsIGJsYWNrKTtcbiAgICBzdHJva2Utb3BhY2l0eTogdmFyKC0tc3Ryb2tlLW9wYWNpdHksIDEpO1xuICB9PC9zdHlsZT5cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFPRSxHQUFHLGVBQUMsQ0FBQyxBQUNILE9BQU8sQ0FBRSxLQUFLLENBQ2QsUUFBUSxDQUFFLFFBQVEsQ0FDbEIsSUFBSSxDQUFFLElBQUksTUFBTSxDQUFDLEVBQUUsQ0FBQyxDQUNwQixHQUFHLENBQUUsSUFBSSxLQUFLLENBQUMsRUFBRSxDQUFDLENBQ2xCLEtBQUssQ0FBRSxJQUFJLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FDekIsTUFBTSxDQUFFLElBQUksUUFBUSxDQUFDLEtBQUssQ0FBQyxDQUMzQixRQUFRLENBQUUsSUFBSSxVQUFVLENBQUMsUUFBUSxDQUFDLEFBQ3BDLENBQUMsQUFDRCxJQUFJLGVBQUMsQ0FBQyxBQUNKLElBQUksQ0FBRSxJQUFJLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FDdkIsWUFBWSxDQUFFLElBQUksY0FBYyxDQUFDLEVBQUUsQ0FBQyxDQUNwQyxNQUFNLENBQUUsSUFBSSxRQUFRLENBQUMsTUFBTSxDQUFDLENBQzVCLGNBQWMsQ0FBRSxJQUFJLGdCQUFnQixDQUFDLEVBQUUsQ0FBQyxBQUMxQyxDQUFDIn0= */div.svelte-1mfa0fo{position:absolute;top:var(--top, 0px);left:var(--left, 0px);font-family:var(--font-family, var(--haas-text, 'sans-serif'));font-size:var(--font-size, 14px);color:var(--color, currentColor);white-space:var(--white-space, nowrap);text-align:var(--text-align, inherit);-webkit-transform:var(--transform, none);transform:var(--transform, none)}.shadow.svelte-1mfa0fo{--c:var(--shadow-color, rgb(255, 255, 255));text-shadow:-2px -2px 2px var(--c), -2px -1px 2px var(--c),
      -2px 0px 2px var(--c), -2px 1px 2px var(--c), -2px 2px 2px var(--c),
      -1px -2px 2px var(--c), -1px -1px 2px var(--c), -1px 0px 2px var(--c),
      -1px 1px 2px var(--c), -1px 2px 2px var(--c), 0px -2px 2px var(--c),
      0px -1px 2px var(--c), 0px 1px 2px var(--c), 0px 2px 2px var(--c),
      1px -2px 2px var(--c), 1px -1px 2px var(--c), 1px 0px 2px var(--c),
      1px 1px 2px var(--c), 1px 2px 2px var(--c), 2px -2px 2px var(--c),
      2px -1px 2px var(--c), 2px 0px 2px var(--c), 2px 1px 2px var(--c),
      2px 2px 2px var(--c)}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVGV4dC5zdmVsdGUiLCJzb3VyY2VzIjpbIlRleHQuc3ZlbHRlIl0sInNvdXJjZXNDb250ZW50IjpbIjxzY3JpcHQ+XG4gIGV4cG9ydCBsZXQgc2hhZG93ID0gbnVsbDtcbjwvc2NyaXB0PlxuXG48ZGl2IGRhdGEtdHlwZT1cInRleHRcIiB7Li4uJCRwcm9wc30gY2xhc3M6c2hhZG93PXtzaGFkb3cgPyB0cnVlIDogZmFsc2V9PlxuICA8c2xvdCAvPlxuPC9kaXY+XG5cbjxzdHlsZT5cbiAgZGl2IHtcbiAgICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gICAgdG9wOiB2YXIoLS10b3AsIDBweCk7XG4gICAgbGVmdDogdmFyKC0tbGVmdCwgMHB4KTtcbiAgICBmb250LWZhbWlseTogdmFyKC0tZm9udC1mYW1pbHksIHZhcigtLWhhYXMtdGV4dCwgJ3NhbnMtc2VyaWYnKSk7XG4gICAgZm9udC1zaXplOiB2YXIoLS1mb250LXNpemUsIDE0cHgpO1xuICAgIGNvbG9yOiB2YXIoLS1jb2xvciwgY3VycmVudENvbG9yKTtcbiAgICB3aGl0ZS1zcGFjZTogdmFyKC0td2hpdGUtc3BhY2UsIG5vd3JhcCk7XG4gICAgdGV4dC1hbGlnbjogdmFyKC0tdGV4dC1hbGlnbiwgaW5oZXJpdCk7XG4gICAgLXdlYmtpdC10cmFuc2Zvcm06IHZhcigtLXRyYW5zZm9ybSwgbm9uZSk7XG4gICAgICAgICAgICB0cmFuc2Zvcm06IHZhcigtLXRyYW5zZm9ybSwgbm9uZSk7XG4gIH1cbiAgLnNoYWRvdyB7XG4gICAgLS1jOiB2YXIoLS1zaGFkb3ctY29sb3IsIHJnYigyNTUsIDI1NSwgMjU1KSk7XG4gICAgdGV4dC1zaGFkb3c6IC0ycHggLTJweCAycHggdmFyKC0tYyksIC0ycHggLTFweCAycHggdmFyKC0tYyksXG4gICAgICAtMnB4IDBweCAycHggdmFyKC0tYyksIC0ycHggMXB4IDJweCB2YXIoLS1jKSwgLTJweCAycHggMnB4IHZhcigtLWMpLFxuICAgICAgLTFweCAtMnB4IDJweCB2YXIoLS1jKSwgLTFweCAtMXB4IDJweCB2YXIoLS1jKSwgLTFweCAwcHggMnB4IHZhcigtLWMpLFxuICAgICAgLTFweCAxcHggMnB4IHZhcigtLWMpLCAtMXB4IDJweCAycHggdmFyKC0tYyksIDBweCAtMnB4IDJweCB2YXIoLS1jKSxcbiAgICAgIDBweCAtMXB4IDJweCB2YXIoLS1jKSwgMHB4IDFweCAycHggdmFyKC0tYyksIDBweCAycHggMnB4IHZhcigtLWMpLFxuICAgICAgMXB4IC0ycHggMnB4IHZhcigtLWMpLCAxcHggLTFweCAycHggdmFyKC0tYyksIDFweCAwcHggMnB4IHZhcigtLWMpLFxuICAgICAgMXB4IDFweCAycHggdmFyKC0tYyksIDFweCAycHggMnB4IHZhcigtLWMpLCAycHggLTJweCAycHggdmFyKC0tYyksXG4gICAgICAycHggLTFweCAycHggdmFyKC0tYyksIDJweCAwcHggMnB4IHZhcigtLWMpLCAycHggMXB4IDJweCB2YXIoLS1jKSxcbiAgICAgIDJweCAycHggMnB4IHZhcigtLWMpO1xuICB9PC9zdHlsZT5cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFTRSxHQUFHLGVBQUMsQ0FBQyxBQUNILFFBQVEsQ0FBRSxRQUFRLENBQ2xCLEdBQUcsQ0FBRSxJQUFJLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FDcEIsSUFBSSxDQUFFLElBQUksTUFBTSxDQUFDLElBQUksQ0FBQyxDQUN0QixXQUFXLENBQUUsSUFBSSxhQUFhLENBQUMsK0JBQStCLENBQUMsQ0FDL0QsU0FBUyxDQUFFLElBQUksV0FBVyxDQUFDLEtBQUssQ0FBQyxDQUNqQyxLQUFLLENBQUUsSUFBSSxPQUFPLENBQUMsYUFBYSxDQUFDLENBQ2pDLFdBQVcsQ0FBRSxJQUFJLGFBQWEsQ0FBQyxPQUFPLENBQUMsQ0FDdkMsVUFBVSxDQUFFLElBQUksWUFBWSxDQUFDLFFBQVEsQ0FBQyxDQUN0QyxpQkFBaUIsQ0FBRSxJQUFJLFdBQVcsQ0FBQyxLQUFLLENBQUMsQ0FDakMsU0FBUyxDQUFFLElBQUksV0FBVyxDQUFDLEtBQUssQ0FBQyxBQUMzQyxDQUFDLEFBQ0QsT0FBTyxlQUFDLENBQUMsQUFDUCxHQUFHLENBQUUsdUNBQXVDLENBQzVDLFdBQVcsQ0FBRSxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxJQUFJLEdBQUcsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsSUFBSSxHQUFHLENBQUMsQ0FBQztNQUMxRCxJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxJQUFJLEdBQUcsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsSUFBSSxHQUFHLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLElBQUksR0FBRyxDQUFDLENBQUM7TUFDcEUsSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsSUFBSSxHQUFHLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLElBQUksR0FBRyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxJQUFJLEdBQUcsQ0FBQyxDQUFDO01BQ3RFLElBQUksQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLElBQUksR0FBRyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxJQUFJLEdBQUcsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsSUFBSSxHQUFHLENBQUMsQ0FBQztNQUNwRSxHQUFHLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxJQUFJLEdBQUcsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsSUFBSSxHQUFHLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLElBQUksR0FBRyxDQUFDLENBQUM7TUFDbEUsR0FBRyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsSUFBSSxHQUFHLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLElBQUksR0FBRyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxJQUFJLEdBQUcsQ0FBQyxDQUFDO01BQ25FLEdBQUcsQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLElBQUksR0FBRyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxJQUFJLEdBQUcsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsSUFBSSxHQUFHLENBQUMsQ0FBQztNQUNsRSxHQUFHLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxJQUFJLEdBQUcsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsSUFBSSxHQUFHLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLElBQUksR0FBRyxDQUFDLENBQUM7TUFDbEUsR0FBRyxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsSUFBSSxHQUFHLENBQUMsQUFDeEIsQ0FBQyJ9 */.tooltip-hidden-point.svelte-18gv5ig{visibility:hidden;position:absolute;pointer-events:none;top:var(--top);left:var(--left);width:10px;height:10px;background-color:rgba(0,0,0,0)}.dvz-tooltip.svelte-18gv5ig{position:absolute;left:var(--left);top:var(--top);-webkit-transform:var(--transform);transform:var(--transform)}svg.arrow.svelte-18gv5ig{position:absolute;overflow:visible;top:var(--top);left:var(--left);width:var(--width);height:var(--height)}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVG9vbHRpcC5zdmVsdGUiLCJzb3VyY2VzIjpbIlRvb2x0aXAuc3ZlbHRlIl0sInNvdXJjZXNDb250ZW50IjpbIjxzY3JpcHQ+XG4gIC8vIEB0cy1jaGVja1xuICBpbXBvcnQgeyBhZnRlclVwZGF0ZSwgZ2V0Q29udGV4dCB9IGZyb20gJ3N2ZWx0ZSc7XG4gIGltcG9ydCB7IGxpbmUgfSBmcm9tICdkMy1zaGFwZSc7XG5cbiAgZXhwb3J0IGxldCBsZWZ0O1xuICBleHBvcnQgbGV0IHRvcDtcbiAgZXhwb3J0IGxldCBhcnJvd1dpZHRoID0gMTA7XG4gIGV4cG9ydCBsZXQgYXJyb3dIZWlnaHQgPSAxMDtcblxuICAkOiAoeyBjaXJjbGVSYWRpdXMgPSA0LCBjaXJjbGVCdWZmZXIgPSAzIH0gPSAkJHByb3BzKTtcblxuICBjb25zdCBUT1AgPSBgVE9QYDtcbiAgY29uc3QgTUlERExFID0gYE1JRERMRWA7XG4gIGNvbnN0IEJPVFRPTSA9IGBCT1RUT01gO1xuICBjb25zdCBMRUZUID0gYExFRlRgO1xuICBjb25zdCBSSUdIVCA9IGBSSUdIVGA7XG4gIGNvbnN0IENFTlRFUiA9IGBDRU5URVJgO1xuXG4gIGxldCBvcmllbnRWZXJ0aWNhbCA9IFRPUDtcbiAgbGV0IG9yaWVudEhvcml6b250YWwgPSBDRU5URVI7XG5cbiAgbGV0IHRvb2x0aXBSZWY7XG4gIGxldCBwb2ludFJlZjtcblxuICBsZXQgcG9pbnRSZWN0O1xuICBsZXQgcmVjdDtcblxuICBhZnRlclVwZGF0ZSgoKSA9PiB7XG4gICAgcG9pbnRSZWN0ID0gcG9pbnRSZWY/LmdldEJvdW5kaW5nQ2xpZW50UmVjdCgpO1xuICAgIHJlY3QgPSB0b29sdGlwUmVmPy5nZXRCb3VuZGluZ0NsaWVudFJlY3QoKTtcbiAgfSk7XG5cbiAgJDoge1xuICAgIGlmIChyZWN0ICYmIHBvaW50UmVjdCkge1xuICAgICAgY29uc3QgeyBsZWZ0OiB4IH0gPSBwb2ludFJlY3Q7XG4gICAgICBjb25zdCB7IHdpZHRoIH0gPSByZWN0O1xuICAgICAgY29uc3QgcmlnaHQgPSB4ICsgd2lkdGggLyAyO1xuICAgICAgY29uc3QgbGVmdCA9IHggLSB3aWR0aCAvIDI7XG4gICAgICBpZiAocmlnaHQgPiB3aW5kb3cuaW5uZXJXaWR0aCkge1xuICAgICAgICBvcmllbnRIb3Jpem9udGFsID0gTEVGVDtcbiAgICAgIH0gZWxzZSBpZiAobGVmdCA8IDApIHtcbiAgICAgICAgb3JpZW50SG9yaXpvbnRhbCA9IFJJR0hUO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgb3JpZW50SG9yaXpvbnRhbCA9IENFTlRFUjtcbiAgICAgIH1cbiAgICB9XG4gIH1cblxuICBmdW5jdGlvbiBnZXRBcnJvd1BvaW50cyhvcmllbnRILCBvcmllbnRWKSB7XG4gICAgY29uc3QgdyA9IGFycm93V2lkdGg7XG4gICAgY29uc3QgaCA9IGFycm93SGVpZ2h0ICogKG9yaWVudFYgPT09IEJPVFRPTSA/IC0xIDogMSk7XG4gICAgY29uc3QgeiA9IDAuNTtcbiAgICByZXR1cm4ge1xuICAgICAgW0xFRlRdOiBbXG4gICAgICAgIFt6LCAwXSxcbiAgICAgICAgW3osIGhdLFxuICAgICAgICBbLXcsIDBdLFxuICAgICAgXSxcbiAgICAgIFtSSUdIVF06IFtcbiAgICAgICAgWy16LCAwXSxcbiAgICAgICAgWy16LCBoXSxcbiAgICAgICAgW3csIDBdLFxuICAgICAgXSxcbiAgICAgIFtDRU5URVJdOiBbXG4gICAgICAgIFstdywgMF0sXG4gICAgICAgIFswLCBoXSxcbiAgICAgICAgW3csIDBdLFxuICAgICAgXSxcbiAgICB9W29yaWVudEhdO1xuICB9XG5cbiAgJDogYXJyb3dQb2ludHMgPSBnZXRBcnJvd1BvaW50cyhvcmllbnRIb3Jpem9udGFsLCBvcmllbnRWZXJ0aWNhbCk7XG5cbiAgJDogYXJyb3dQYXRoRGVmaW5pdGlvbiA9IGxpbmUoKShhcnJvd1BvaW50cyk7XG5cbiAgJDogdHJhbnNsYXRlWCA9IHtcbiAgICBbTEVGVF06IGAtMTAwJWAsXG4gICAgW0NFTlRFUl06IGAtNTAlYCxcbiAgICBbUklHSFRdOiBgMGAsXG4gIH1bb3JpZW50SG9yaXpvbnRhbF07XG5cbiAgJDogdHJhbnNsYXRlWSA9IHtcbiAgICBbVE9QXTogYGNhbGMoLTEwMCUgLSAke2Fycm93SGVpZ2h0ICsgY2lyY2xlUmFkaXVzICsgY2lyY2xlQnVmZmVyfXB4KWAsXG4gICAgW0JPVFRPTV06IGBjYWxjKDUwJSAtICR7YXJyb3dIZWlnaHQgKyBjaXJjbGVSYWRpdXMgKyBjaXJjbGVCdWZmZXJ9cHgpYCxcbiAgfVtvcmllbnRWZXJ0aWNhbF07XG5cbiAgJDogdHJhbnNmb3JtID0gYHRyYW5zbGF0ZSgke3RyYW5zbGF0ZVh9LCAke3RyYW5zbGF0ZVl9KWA7XG5cbiAgJDogYXJyb3dMZWZ0ID0ge1xuICAgIFtMRUZUXTogYDEwMCVgLFxuICAgIFtDRU5URVJdOiBgNTAlYCxcbiAgICBbUklHSFRdOiAwLFxuICB9W29yaWVudEhvcml6b250YWxdO1xuXG4gICQ6IGFycm93VG9wID0ge1xuICAgIFtUT1BdOiBgMTAwJWAsXG4gICAgW01JRERMRV06IGA1MCVgLFxuICAgIFtCT1RUT01dOiAwLFxuICB9W29yaWVudFZlcnRpY2FsXTtcblxuICAkOiBzdHlsZSA9IGBcbiAgICAtLWxlZnQ6ICR7bGVmdH07XG4gICAgLS10b3A6ICR7dG9wfTtcbiAgICAtLXRyYW5zZm9ybTogJHt0cmFuc2Zvcm19O1xuICBgO1xuXG4gICQ6IGFycm93U3R5bGUgPSBgXG4gICAgLS13aWR0aDogJHthcnJvd1dpZHRofXB4O1xuICAgIC0taGVpZ2h0OiAke2Fycm93SGVpZ2h0fXB4O1xuICAgIC0tbGVmdDogJHthcnJvd0xlZnR9O1xuICAgIC0tdG9wOiAke2Fycm93VG9wfTtcbiAgYDtcbjwvc2NyaXB0PlxuXG48ZGl2XG4gIGNsYXNzPVwidG9vbHRpcC1oaWRkZW4tcG9pbnRcIlxuICBzdHlsZT17YC0tbGVmdDogJHtsZWZ0fTsgLS10b3A6ICR7dG9wfTtgfVxuICBiaW5kOnRoaXM9e3BvaW50UmVmfVxuLz5cbjxkaXYgY2xhc3M9XCJkdnotdG9vbHRpcCB0dC1zdmVsdGVcIiB7c3R5bGV9IGJpbmQ6dGhpcz17dG9vbHRpcFJlZn0+XG4gIDxzbG90IC8+XG4gIDxzdmcgY2xhc3M9XCJhcnJvd1wiIHN0eWxlPXthcnJvd1N0eWxlfT5cbiAgICA8cGF0aCBkPXthcnJvd1BhdGhEZWZpbml0aW9ufSBmaWxsPVwid2hpdGVcIiBzdHJva2U9XCJibGFja1wiIC8+XG4gIDwvc3ZnPlxuPC9kaXY+XG5cbjxzdHlsZSBsYW5nPVwic2Nzc1wiPi50b29sdGlwLWhpZGRlbi1wb2ludHt2aXNpYmlsaXR5OmhpZGRlbjtwb3NpdGlvbjphYnNvbHV0ZTtwb2ludGVyLWV2ZW50czpub25lO3RvcDp2YXIoLS10b3ApO2xlZnQ6dmFyKC0tbGVmdCk7d2lkdGg6MTBweDtoZWlnaHQ6MTBweDtiYWNrZ3JvdW5kLWNvbG9yOnJnYmEoMCwwLDAsMCl9LmR2ei10b29sdGlwe3Bvc2l0aW9uOmFic29sdXRlO2xlZnQ6dmFyKC0tbGVmdCk7dG9wOnZhcigtLXRvcCk7LXdlYmtpdC10cmFuc2Zvcm06dmFyKC0tdHJhbnNmb3JtKTt0cmFuc2Zvcm06dmFyKC0tdHJhbnNmb3JtKX1zdmcuYXJyb3d7cG9zaXRpb246YWJzb2x1dGU7b3ZlcmZsb3c6dmlzaWJsZTt0b3A6dmFyKC0tdG9wKTtsZWZ0OnZhcigtLWxlZnQpO3dpZHRoOnZhcigtLXdpZHRoKTtoZWlnaHQ6dmFyKC0taGVpZ2h0KX08L3N0eWxlPlxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQStIbUIsb0NBQXFCLENBQUMsV0FBVyxNQUFNLENBQUMsU0FBUyxRQUFRLENBQUMsZUFBZSxJQUFJLENBQUMsSUFBSSxJQUFJLEtBQUssQ0FBQyxDQUFDLEtBQUssSUFBSSxNQUFNLENBQUMsQ0FBQyxNQUFNLElBQUksQ0FBQyxPQUFPLElBQUksQ0FBQyxpQkFBaUIsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQywyQkFBWSxDQUFDLFNBQVMsUUFBUSxDQUFDLEtBQUssSUFBSSxNQUFNLENBQUMsQ0FBQyxJQUFJLElBQUksS0FBSyxDQUFDLENBQUMsa0JBQWtCLElBQUksV0FBVyxDQUFDLENBQUMsVUFBVSxJQUFJLFdBQVcsQ0FBQyxDQUFDLEdBQUcscUJBQU0sQ0FBQyxTQUFTLFFBQVEsQ0FBQyxTQUFTLE9BQU8sQ0FBQyxJQUFJLElBQUksS0FBSyxDQUFDLENBQUMsS0FBSyxJQUFJLE1BQU0sQ0FBQyxDQUFDLE1BQU0sSUFBSSxPQUFPLENBQUMsQ0FBQyxPQUFPLElBQUksUUFBUSxDQUFDLENBQUMifQ== */.tooltip-screen.svelte-1078xko{pointer-events:all;position:absolute;top:0;left:0;width:100%;height:100%}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVG9vbHRpcFNjcmVlbi5zdmVsdGUiLCJzb3VyY2VzIjpbIlRvb2x0aXBTY3JlZW4uc3ZlbHRlIl0sInNvdXJjZXNDb250ZW50IjpbIjxzY3JpcHQ+XG4gIGltcG9ydCB7IGNyZWF0ZUV2ZW50RGlzcGF0Y2hlciB9IGZyb20gJ3N2ZWx0ZSc7XG5cbiAgaW1wb3J0IHsgRGVsYXVuYXkgfSBmcm9tICdkMy1kZWxhdW5heSc7XG4gIGltcG9ydCAqIGFzIENoYXJ0IGZyb20gJy4uL0NoYXJ0L2luZGV4LmpzJztcblxuICBleHBvcnQgbGV0IGRlbGF1bmF5UG9pbnRzID0gW107XG4gIGV4cG9ydCBsZXQgZGF0YSA9IHVuZGVmaW5lZDtcbiAgZXhwb3J0IGxldCB4ID0gdW5kZWZpbmVkO1xuICBleHBvcnQgbGV0IHkgPSB1bmRlZmluZWQ7XG4gIGV4cG9ydCBsZXQgZGVidWcgPSBmYWxzZTtcbiAgZXhwb3J0IGxldCBob3Jpem9udGFsT25seSA9IGZhbHNlO1xuXG4gIGxldCBjb250YWluZXJXaWR0aCA9IDEwMDtcbiAgbGV0IGNvbnRhaW5lckhlaWdodCA9IDEwMDtcblxuICAkOiBpZiAoZGVidWcpIGNvbnNvbGUubG9nKGB0b29sdGlwOmAsICQkcHJvcHMpO1xuXG4gIGNvbnN0IGRpc3BhdGNoID0gY3JlYXRlRXZlbnREaXNwYXRjaGVyKCk7XG5cbiAgZnVuY3Rpb24gcmVzaXplQWN0aW9uKGVsZW1lbnQpIHtcbiAgICBjb25zdCBtZWFzdXJlID0gKCkgPT4ge1xuICAgICAgY29uc3QgcmVjdCA9IGVsZW1lbnQuZ2V0Qm91bmRpbmdDbGllbnRSZWN0KCk7XG4gICAgICAoeyB3aWR0aDogY29udGFpbmVyV2lkdGgsIGhlaWdodDogY29udGFpbmVySGVpZ2h0IH0gPSByZWN0KTtcbiAgICB9O1xuICAgIG1lYXN1cmUoKTtcbiAgICBjb25zdCBvYnNlcnZlciA9IG5ldyBSZXNpemVPYnNlcnZlcigoKSA9PiB7XG4gICAgICBtZWFzdXJlKCk7XG4gICAgfSk7XG4gICAgb2JzZXJ2ZXIub2JzZXJ2ZShlbGVtZW50KTtcbiAgICByZXR1cm4ge1xuICAgICAgZGVzdHJveSgpIHtcbiAgICAgICAgb2JzZXJ2ZXIuZGlzY29ubmVjdCgpO1xuICAgICAgfSxcbiAgICB9O1xuICB9XG5cbiAgLyoqXG4gICAqIFRoZSBhY3R1YWwgcG9pbnRzIGFycmF5IHBhc3NlZCB0byBEZWxhdW5heSBpcyBzY2FsZWQgYnkgdGhlIHNpemUgb2YgdGhlXG4gICAqIHRvb2x0aXAgc2NyZWVuXG4gICAqL1xuICAkOiBkZWxhdW5heVBvaW50c18gPSBkZWxhdW5heVBvaW50cy5tYXAoKGQpID0+ICh7XG4gICAgLi4uZCxcbiAgICB4OiAoZC54IC8gMTAwKSAqIGNvbnRhaW5lcldpZHRoLFxuICAgIHk6IGhvcml6b250YWxPbmx5ID09PSB0cnVlID8gMC41ICogY29udGFpbmVySGVpZ2h0IDogKGQueSAvIDEwMCkgKiBjb250YWluZXJIZWlnaHQsXG4gIH0pKTtcblxuICAkOiBkZWxhdW5heSA9IERlbGF1bmF5LmZyb20oXG4gICAgZGVsYXVuYXlQb2ludHNfLFxuICAgIChkKSA9PiBkLngsXG4gICAgKGQpID0+IGQueSxcbiAgKTtcblxuICBjb25zdCB7IGFjdGlvbjogbW91c2VBY3Rpb24sIHN0b3JlOiBtb3VzZUV2ZW50U3RvcmUgfSA9IENoYXJ0Lm1vdXNlRXZlbnRzKCk7XG5cbiAgJDogbW91c2VFdmVudCA9ICRtb3VzZUV2ZW50U3RvcmU7XG5cbiAgJDogaWYgKGRlYnVnKSBjb25zb2xlLmxvZyhgdG9vbHRpcDpgLCB7IG1vdXNlRXZlbnQgfSk7XG5cbiAgJDoge1xuICAgIGlmIChtb3VzZUV2ZW50KSB7XG4gICAgICAvLyBjb25zdCB7IGxheWVyWCwgbGF5ZXJZIH0gPSBtb3VzZUV2ZW50O1xuICAgICAgbGV0IHsgY2xpZW50WCwgY2xpZW50WSB9ID0gbW91c2VFdmVudDtcbiAgICAgIGlmIChtb3VzZUV2ZW50LnRvdWNoZXMpIHtcbiAgICAgICAgKHsgY2xpZW50WCwgY2xpZW50WSB9ID0gbW91c2VFdmVudC50b3VjaGVzPy5bMF0pO1xuICAgICAgfVxuICAgICAgY29uc3QgeyBsZWZ0ID0gMCwgdG9wID0gMCB9ID0gbW91c2VFdmVudC50YXJnZXQ/LmdldEJvdW5kaW5nQ2xpZW50UmVjdCgpO1xuICAgICAgY29uc3QgbGF5ZXJYID0gY2xpZW50WCAtIGxlZnQ7XG4gICAgICBjb25zdCBsYXllclkgPSBjbGllbnRZIC0gdG9wO1xuICAgICAgY29uc3QgZm91bmRJbmRleCA9IGRlbGF1bmF5LmZpbmQobGF5ZXJYLCBsYXllclkpO1xuICAgICAgaWYgKGRlYnVnKVxuICAgICAgICBjb25zb2xlLmxvZyhgdG9vbHRpcDpgLCB7XG4gICAgICAgICAgbGF5ZXJYLFxuICAgICAgICAgIGxheWVyWSxcbiAgICAgICAgICBmb3VuZEluZGV4LFxuICAgICAgICAgIGRlbGF1bmF5UG9pbnRzXyxcbiAgICAgICAgICBkZWxhdW5heVBvaW50cyxcbiAgICAgICAgfSk7XG4gICAgICBpZiAoIU51bWJlci5pc0Zpbml0ZShmb3VuZEluZGV4KSAmJiBkZWxhdW5heVBvaW50cy5sZW5ndGgpIHtcbiAgICAgICAgY29uc29sZS5sb2coYERlbGF1bmF5IGZvdW5kSW5kZXggaXMgJHtmb3VuZEluZGV4fWApO1xuICAgICAgfVxuICAgICAgY29uc3QgZm91bmREYXRhID0gZGVsYXVuYXlQb2ludHNbZm91bmRJbmRleF07XG4gICAgICBpZiAoZm91bmREYXRhKSB7XG4gICAgICAgIGRhdGEgPSBmb3VuZERhdGE7XG4gICAgICAgIHggPSBmb3VuZERhdGEueDtcbiAgICAgICAgeSA9IGZvdW5kRGF0YS55O1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgZGF0YSA9IG51bGw7XG4gICAgICB9XG4gICAgfSBlbHNlIHtcbiAgICAgIGRhdGEgPSBudWxsO1xuICAgIH1cbiAgfVxuXG4gICQ6IHtcbiAgICBkaXNwYXRjaChgZGF0YWAsIGRhdGEpO1xuICB9XG48L3NjcmlwdD5cblxuPGRpdiBjbGFzcz1cInRvb2x0aXAtc2NyZWVuXCIgdXNlOm1vdXNlQWN0aW9uIHVzZTpyZXNpemVBY3Rpb24gb246Y2xpY2sgLz5cbnsjaWYgZGF0YSAmJiB4ICYmIHl9XG4gIDxzbG90IHtkYXRhfSB7eH0ge3l9IC8+XG57L2lmfVxuXG48c3R5bGU+XG4gIC50b29sdGlwLXNjcmVlbiB7XG4gICAgcG9pbnRlci1ldmVudHM6IGFsbDtcbiAgICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gICAgdG9wOiAwO1xuICAgIGxlZnQ6IDA7XG4gICAgd2lkdGg6IDEwMCU7XG4gICAgaGVpZ2h0OiAxMDAlO1xuICB9PC9zdHlsZT5cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF5R0UsZUFBZSxlQUFDLENBQUMsQUFDZixjQUFjLENBQUUsR0FBRyxDQUNuQixRQUFRLENBQUUsUUFBUSxDQUNsQixHQUFHLENBQUUsQ0FBQyxDQUNOLElBQUksQ0FBRSxDQUFDLENBQ1AsS0FBSyxDQUFFLElBQUksQ0FDWCxNQUFNLENBQUUsSUFBSSxBQUNkLENBQUMifQ== */span.svelte-8a5rw4{display:block;font-family:var(--font-family, var(--haas-text, sans-serif))}.nowrap.svelte-8a5rw4{white-space:nowrap}.prefix.svelte-8a5rw4{position:absolute;top:0;left:0;-webkit-transform:translateX(-100%);transform:translateX(-100%)}.suffix.svelte-8a5rw4{position:absolute;top:0;left:100%}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQXhpc1guc3ZlbHRlIiwic291cmNlcyI6WyJBeGlzWC5zdmVsdGUiXSwic291cmNlc0NvbnRlbnQiOlsiPHNjcmlwdD5cbiAgLy8gQHRzLWNoZWNrXG4gIGltcG9ydCB7IGFzY2VuZGluZywgbWluIH0gZnJvbSAnZDMtYXJyYXknO1xuICBpbXBvcnQgVmVydGljYWxMaW5lIGZyb20gJy4vTGluZVZlcnRpY2FsLnN2ZWx0ZSc7XG4gIGltcG9ydCBUZXh0IGZyb20gJy4vVGV4dC5zdmVsdGUnO1xuXG4gICQ6ICh7XG4gICAgc2NhbGUsXG4gICAgYWxpZ24gPSBgYm90dG9tYCxcbiAgICBudW1UaWNrcyA9IDMsXG4gICAgdGlja1ZhbHVlcyA9IHNjYWxlLnRpY2tzID8gc2NhbGUudGlja3MobnVtVGlja3MpIDogc2NhbGUuZG9tYWluKCksXG4gICAgZm9ybWF0ID0gKGQpID0+IGQsXG4gICAgdGlja0hlaWdodCA9IDcsXG4gICAgYnVmZmVyID0gMTAsXG4gICAgZ3JpZCA9IGZhbHNlLFxuICAgIHNvcnQgPSBhc2NlbmRpbmcsXG4gICAgcHJlZml4LFxuICAgIHN1ZmZpeCxcbiAgfSA9ICQkcHJvcHMpO1xuXG4gICQ6IGFsaWduVG9wID0gYWxpZ24gPT09IGB0b3BgO1xuXG4gIGxldCBsaW5lVG9wO1xuICBsZXQgbGluZUhlaWdodDtcbiAgbGV0IHRleHRUb3A7XG4gIGxldCB0ZXh0VHJhbnNmb3JtO1xuXG4gICQ6IHtcbiAgICBpZiAoYWxpZ25Ub3ApIHtcbiAgICAgIGxpbmVUb3AgPSBgJHstdGlja0hlaWdodH1weGA7XG4gICAgICBsaW5lSGVpZ2h0ID0gZ3JpZCA/IGBjYWxjKCR7dGlja0hlaWdodH1weCArIDEwMCUpYCA6IGAke3RpY2tIZWlnaHR9cHhgO1xuICAgICAgdGV4dFRvcCA9IGBjYWxjKCR7bGluZVRvcH0gLSAke2J1ZmZlcn1weClgO1xuICAgICAgdGV4dFRyYW5zZm9ybSA9IGB0cmFuc2xhdGUoLTUwJSwgLTEwMCUpYDtcbiAgICB9IGVsc2Uge1xuICAgICAgbGluZVRvcCA9IGdyaWQgPyBgMHB4YCA6IGAxMDAlYDtcbiAgICAgIGxpbmVIZWlnaHQgPSBgY2FsYygke2dyaWQgPyBgMTAwJWAgOiBgMHB4YH0gKyAke3RpY2tIZWlnaHR9cHgpYDtcbiAgICAgIHRleHRUb3AgPSBgY2FsYygxMDAlICsgJHtidWZmZXJ9cHgpYDtcbiAgICAgIHRleHRUcmFuc2Zvcm0gPSBgdHJhbnNsYXRlWCgtNTAlKWA7XG4gICAgfVxuICB9XG5cbiAgJDogdGlja1Byb3BzXyA9IHRpY2tWYWx1ZXMuc29ydChzb3J0KS5tYXAoKHRpY2tWYWx1ZSkgPT4ge1xuICAgIGxldCB4UGVyY2VudCA9IHNjYWxlKHRpY2tWYWx1ZSk7XG4gICAgaWYgKHNjYWxlLmJhbmR3aWR0aCkge1xuICAgICAgeFBlcmNlbnQgKz0gc2NhbGUuYmFuZHdpZHRoKCkgLyAyO1xuICAgIH1cbiAgICBjb25zdCBmb3JtYXR0ZWQgPSBmb3JtYXQodGlja1ZhbHVlKTtcbiAgICByZXR1cm4ge1xuICAgICAgeFBlcmNlbnQsXG4gICAgICBsZWZ0OiBgJHt4UGVyY2VudH0lYCxcbiAgICAgIGZvcm1hdHRlZCxcbiAgICB9O1xuICB9KTtcblxuICAkOiBtaW5YUGVyY2VudCA9IG1pbih0aWNrUHJvcHNfLCAoZCkgPT4gZC54UGVyY2VudCk7XG5cbiAgJDogdGlja1Byb3BzID0gdGlja1Byb3BzXy5tYXAoKGQpID0+IHtcbiAgICBjb25zdCBzaG93QWZmaXggPSBkLnhQZXJjZW50ID09PSBtaW5YUGVyY2VudDtcbiAgICByZXR1cm4ge1xuICAgICAgLi4uZCxcbiAgICAgIHNob3dBZmZpeCxcbiAgICB9O1xuICB9KTtcbjwvc2NyaXB0PlxuXG48ZGl2IGNsYXNzPVwieC1heGlzXCI+XG4gIHsjZWFjaCB0aWNrUHJvcHMgYXMgeyBsZWZ0LCBmb3JtYXR0ZWQsIHNob3dBZmZpeCB9fVxuICAgIDxkaXYgY2xhc3M9XCJ0aWNrIHgtdGlja1wiPlxuICAgICAgPFZlcnRpY2FsTGluZSAtLWxlZnQ9e2xlZnR9IC0tdG9wPXtsaW5lVG9wfSAtLWhlaWdodD17bGluZUhlaWdodH0gLz5cbiAgICAgIDxUZXh0IC0tbGVmdD17bGVmdH0gLS10cmFuc2Zvcm09e3RleHRUcmFuc2Zvcm19IC0tdG9wPXt0ZXh0VG9wfT5cbiAgICAgICAgeyNpZiBwcmVmaXggJiYgc2hvd0FmZml4fVxuICAgICAgICAgIDxzcGFuIGNsYXNzPVwicHJlZml4IG5vd3JhcFwiPntAaHRtbCBwcmVmaXh9PC9zcGFuPlxuICAgICAgICB7L2lmfVxuICAgICAgICA8c3BhbiBjbGFzcz1cIm5vd3JhcFwiPlxuICAgICAgICAgIHtAaHRtbCBmb3JtYXR0ZWR9XG4gICAgICAgIDwvc3Bhbj5cbiAgICAgICAgeyNpZiBzdWZmaXggJiYgc2hvd0FmZml4fVxuICAgICAgICAgIDxzcGFuIGNsYXNzPVwic3VmZml4IG5vd3JhcFwiPntAaHRtbCBzdWZmaXh9PC9zcGFuPlxuICAgICAgICB7L2lmfVxuICAgICAgPC9UZXh0PlxuICAgIDwvZGl2PlxuICB7L2VhY2h9XG48L2Rpdj5cblxuPHN0eWxlPlxuICBzcGFuIHtcbiAgICBkaXNwbGF5OiBibG9jaztcbiAgICBmb250LWZhbWlseTogdmFyKC0tZm9udC1mYW1pbHksIHZhcigtLWhhYXMtdGV4dCwgc2Fucy1zZXJpZikpO1xuICB9XG4gIC5ub3dyYXAge1xuICAgIHdoaXRlLXNwYWNlOiBub3dyYXA7XG4gIH1cbiAgLnByZWZpeCB7XG4gICAgcG9zaXRpb246IGFic29sdXRlO1xuICAgIHRvcDogMDtcbiAgICBsZWZ0OiAwO1xuICAgIC13ZWJraXQtdHJhbnNmb3JtOiB0cmFuc2xhdGVYKC0xMDAlKTtcbiAgICAgICAgICAgIHRyYW5zZm9ybTogdHJhbnNsYXRlWCgtMTAwJSk7XG4gIH1cbiAgLnN1ZmZpeCB7XG4gICAgcG9zaXRpb246IGFic29sdXRlO1xuICAgIHRvcDogMDtcbiAgICBsZWZ0OiAxMDAlO1xuICB9PC9zdHlsZT5cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFxRkUsSUFBSSxjQUFDLENBQUMsQUFDSixPQUFPLENBQUUsS0FBSyxDQUNkLFdBQVcsQ0FBRSxJQUFJLGFBQWEsQ0FBQyw2QkFBNkIsQ0FBQyxBQUMvRCxDQUFDLEFBQ0QsT0FBTyxjQUFDLENBQUMsQUFDUCxXQUFXLENBQUUsTUFBTSxBQUNyQixDQUFDLEFBQ0QsT0FBTyxjQUFDLENBQUMsQUFDUCxRQUFRLENBQUUsUUFBUSxDQUNsQixHQUFHLENBQUUsQ0FBQyxDQUNOLElBQUksQ0FBRSxDQUFDLENBQ1AsaUJBQWlCLENBQUUsV0FBVyxLQUFLLENBQUMsQ0FDNUIsU0FBUyxDQUFFLFdBQVcsS0FBSyxDQUFDLEFBQ3RDLENBQUMsQUFDRCxPQUFPLGNBQUMsQ0FBQyxBQUNQLFFBQVEsQ0FBRSxRQUFRLENBQ2xCLEdBQUcsQ0FBRSxDQUFDLENBQ04sSUFBSSxDQUFFLElBQUksQUFDWixDQUFDIn0= */span.svelte-110i2d6{display:block;white-space:nowrap;font-family:var(--font-family, var(--haas-text, sans-serif))}.prefix.svelte-110i2d6{position:absolute;top:0;left:0;-webkit-transform:translateX(-100%);transform:translateX(-100%)}.suffix.svelte-110i2d6{position:absolute;top:0;left:100%}.tick-value-text.svelte-110i2d6{font-variant-numeric:var(--font-variant-numeric, tabular-nums)}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQXhpc1kuc3ZlbHRlIiwic291cmNlcyI6WyJBeGlzWS5zdmVsdGUiXSwic291cmNlc0NvbnRlbnQiOlsiPHNjcmlwdD5cbiAgLy8gQHRzLWNoZWNrXG4gIGltcG9ydCB7IHdyaXRhYmxlIH0gZnJvbSAnc3ZlbHRlL3N0b3JlJztcbiAgaW1wb3J0IHsgdGljayBhcyBzdmVsdGVUaWNrIH0gZnJvbSAnc3ZlbHRlJztcbiAgaW1wb3J0IHsgbWluLCBtYXgsIGRlc2NlbmRpbmcgfSBmcm9tICdkMy1hcnJheSc7XG4gIGltcG9ydCBIb3Jpem9udGFsTGluZSBmcm9tICcuL0xpbmVIb3Jpem9udGFsLnN2ZWx0ZSc7XG4gIGltcG9ydCBUZXh0IGZyb20gJy4vVGV4dC5zdmVsdGUnO1xuXG4gICQ6ICh7XG4gICAgc2NhbGUsXG4gICAgYWxpZ24gPSBgcmlnaHRgLFxuICAgIG51bVRpY2tzID0gMyxcbiAgICB0aWNrVmFsdWVzID0gc2NhbGUudGlja3MgPyBzY2FsZS50aWNrcyhudW1UaWNrcykgOiBbXSxcbiAgICB0aWNrV2lkdGggPSA3LFxuICAgIGJ1ZmZlciA9IDUsXG4gICAgZ3JpZCA9IGZhbHNlLFxuICAgIGZvcm1hdCA9IChkLCBzY2FsZSkgPT4gZCxcbiAgICBwcmVmaXgsXG4gICAgc3VmZml4LFxuICAgIGF1dG9UaWNrV2lkdGggPSBmYWxzZSxcbiAgfSA9ICQkcHJvcHMpO1xuXG4gIGxldCBsaW5lTGVmdDtcbiAgbGV0IGxpbmVXaWR0aDtcbiAgbGV0IHRleHRMZWZ0O1xuICBsZXQgdGV4dFRyYW5zZm9ybTtcblxuICAkOiB7XG4gICAgaWYgKGFsaWduID09PSBgbGVmdGApIHtcbiAgICAgIGxpbmVMZWZ0ID0gYGNhbGMoLSR7dGlja1dpZHRofXB4IC0gJHtidWZmZXJ9cHgpYDtcbiAgICAgIGxpbmVXaWR0aCA9IGdyaWRcbiAgICAgICAgPyBgY2FsYygke3RpY2tXaWR0aH1weCArICR7YnVmZmVyfXB4ICsgJHtncmlkID8gYDEwMCVgIDogYDAlYH0pYFxuICAgICAgICA6IGAke3RpY2tXaWR0aH1weGA7XG4gICAgICB0ZXh0TGVmdCA9IGxpbmVMZWZ0O1xuICAgICAgdGV4dFRyYW5zZm9ybSA9IGB0cmFuc2xhdGUoMCwgLTEwMCUpYDtcbiAgICB9IGVsc2Uge1xuICAgICAgbGluZUxlZnQgPSBncmlkID8gYDAlYCA6IGBjYWxjKDEwMCUgKyAke2J1ZmZlcn1weClgO1xuICAgICAgbGluZVdpZHRoID0gYCR7dGlja1dpZHRofXB4YDtcbiAgICAgIHRleHRMZWZ0ID0gYGNhbGMoMTAwJSArICR7YnVmZmVyfXB4ICsgJHtsaW5lV2lkdGh9KWA7XG4gICAgICB0ZXh0VHJhbnNmb3JtID0gYHRyYW5zbGF0ZSgtMTAwJSwgY2FsYygtMTAwJSArIDNweCkpYDtcbiAgICB9XG4gIH1cblxuICAkOiB0aWNrUHJvcHNfID0gdGlja1ZhbHVlcy5tYXAoKHRpY2tWYWx1ZSkgPT4ge1xuICAgIGxldCB5UGVyY2VudCA9IHNjYWxlKHRpY2tWYWx1ZSk7XG4gICAgaWYgKHNjYWxlLmJhbmR3aWR0aCkge1xuICAgICAgeVBlcmNlbnQgKz0gc2NhbGUuYmFuZHdpZHRoKCkgLyAyO1xuICAgIH1cbiAgICBjb25zdCBmb3JtYXR0ZWQgPSBmb3JtYXQodGlja1ZhbHVlLCBzY2FsZSwgdGlja1ZhbHVlcyk7XG4gICAgcmV0dXJuIHtcbiAgICAgIHZhbHVlOiB0aWNrVmFsdWUsXG4gICAgICB5UGVyY2VudCxcbiAgICAgIHRvcDogYCR7eVBlcmNlbnR9JWAsXG4gICAgICBmb3JtYXR0ZWQsXG4gICAgfTtcbiAgfSk7XG5cbiAgJDogbWluWVBlcmNlbnQgPSBtaW4odGlja1Byb3BzXywgKGQpID0+IGQueVBlcmNlbnQpO1xuXG4gICQ6IHRpY2tQcm9wcyA9IHRpY2tQcm9wc18ubWFwKChkKSA9PiB7XG4gICAgcmV0dXJuIHtcbiAgICAgIC4uLmQsXG4gICAgICBzaG93QWZmaXg6IGQueVBlcmNlbnQgPT09IG1pbllQZXJjZW50LFxuICAgIH07XG4gIH0pO1xuXG4gIGNvbnN0IGF1dG9UaWNrV2lkdGhTdG9yZSA9IHdyaXRhYmxlKHRpY2tXaWR0aCk7XG5cbiAgZnVuY3Rpb24gYXV0b1RpY2tXaWR0aEFjdGlvbihjb250YWluZXIsIHRpY2tQcm9wcykge1xuICAgIGNvbnN0IHVwZGF0ZVdpZHRoID0gKCkgPT4ge1xuICAgICAgLy8gVXNlIHN2ZWx0ZSBgdGlja2AgdG8gd2FpdCB1bnRpbCB3ZSBoYXZlIHJlbmRlcmVkXG4gICAgICBzdmVsdGVUaWNrKCkudGhlbigoKSA9PiB7XG4gICAgICAgIGNvbnN0IHdpZHRocyA9IEFycmF5LmZyb20oXG4gICAgICAgICAgY29udGFpbmVyLnF1ZXJ5U2VsZWN0b3JBbGwoYC50aWNrLXZhbHVlLXRleHRgKVxuICAgICAgICApLm1hcCgodGlja1RleHRTcGFuKSA9PiB7XG4gICAgICAgICAgY29uc3QgeyB3aWR0aCB9ID0gdGlja1RleHRTcGFuLmdldEJvdW5kaW5nQ2xpZW50UmVjdCgpO1xuICAgICAgICAgIHJldHVybiB3aWR0aDtcbiAgICAgICAgfSk7XG4gICAgICAgIGNvbnN0IG1heFdpZHRoID0gbWF4KHdpZHRocyk7XG4gICAgICAgICRhdXRvVGlja1dpZHRoU3RvcmUgPSBtYXhXaWR0aDtcbiAgICAgIH0pO1xuICAgIH07XG4gICAgdXBkYXRlV2lkdGgoKTtcbiAgICByZXR1cm4ge1xuICAgICAgdXBkYXRlKHRpY2tQcm9wcykge1xuICAgICAgICB1cGRhdGVXaWR0aCgpO1xuICAgICAgfSxcbiAgICB9O1xuICB9XG5cbiAgJDogYXV0b1RpY2tXaWR0aFZhbHVlID0gJGF1dG9UaWNrV2lkdGhTdG9yZTtcblxuICAkOiBpZiAoYXV0b1RpY2tXaWR0aFZhbHVlICYmIHRpY2tXaWR0aCAhPT0gYXV0b1RpY2tXaWR0aFZhbHVlKSB7XG4gICAgdGlja1dpZHRoID0gYXV0b1RpY2tXaWR0aFZhbHVlO1xuICB9XG5cbiAgJDogYWN0aW9uID0gYXV0b1RpY2tXaWR0aCA/IGF1dG9UaWNrV2lkdGhBY3Rpb24gOiAoKSA9PiB7fTtcbjwvc2NyaXB0PlxuXG48ZGl2IGNsYXNzPVwieS1heGlzXCIgdXNlOmFjdGlvbj17dGlja1Byb3BzfT5cbiAgeyNlYWNoIHRpY2tQcm9wcyBhcyB7IHRvcCwgZm9ybWF0dGVkLCBzaG93QWZmaXggfX1cbiAgICA8ZGl2IGNsYXNzPVwidGljayB5LXRpY2tcIj5cbiAgICAgIDxIb3Jpem9udGFsTGluZSAtLXRvcD17dG9wfSAtLWxlZnQ9e2xpbmVMZWZ0fSAtLXdpZHRoPXtsaW5lV2lkdGh9IC8+XG4gICAgICA8VGV4dCAtLXRvcD17dG9wfSAtLWxlZnQ9e3RleHRMZWZ0fSAtLXRyYW5zZm9ybT17dGV4dFRyYW5zZm9ybX0+XG4gICAgICAgIHsjaWYgcHJlZml4ICYmIHNob3dBZmZpeH1cbiAgICAgICAgICA8c3BhbiBjbGFzcz1cInByZWZpeFwiPntAaHRtbCBwcmVmaXh9PC9zcGFuPlxuICAgICAgICB7L2lmfVxuICAgICAgICA8c3BhbiBjbGFzcz1cInRpY2stdmFsdWUtdGV4dFwiPlxuICAgICAgICAgIHtAaHRtbCBmb3JtYXR0ZWR9XG4gICAgICAgIDwvc3Bhbj5cbiAgICAgICAgeyNpZiBzdWZmaXggJiYgc2hvd0FmZml4fVxuICAgICAgICAgIDxzcGFuIGNsYXNzPVwic3VmZml4XCI+e0BodG1sIHN1ZmZpeH08L3NwYW4+XG4gICAgICAgIHsvaWZ9XG4gICAgICA8L1RleHQ+XG4gICAgPC9kaXY+XG4gIHsvZWFjaH1cbjwvZGl2PlxuXG48c3R5bGU+XG4gIHNwYW4ge1xuICAgIGRpc3BsYXk6IGJsb2NrO1xuICAgIHdoaXRlLXNwYWNlOiBub3dyYXA7XG4gICAgZm9udC1mYW1pbHk6IHZhcigtLWZvbnQtZmFtaWx5LCB2YXIoLS1oYWFzLXRleHQsIHNhbnMtc2VyaWYpKTtcbiAgfVxuICAucHJlZml4IHtcbiAgICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gICAgdG9wOiAwO1xuICAgIGxlZnQ6IDA7XG4gICAgLXdlYmtpdC10cmFuc2Zvcm06IHRyYW5zbGF0ZVgoLTEwMCUpO1xuICAgICAgICAgICAgdHJhbnNmb3JtOiB0cmFuc2xhdGVYKC0xMDAlKTtcbiAgfVxuICAuc3VmZml4IHtcbiAgICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gICAgdG9wOiAwO1xuICAgIGxlZnQ6IDEwMCU7XG4gIH1cbiAgLnRpY2stdmFsdWUtdGV4dCB7XG4gICAgZm9udC12YXJpYW50LW51bWVyaWM6IHZhcigtLWZvbnQtdmFyaWFudC1udW1lcmljLCB0YWJ1bGFyLW51bXMpO1xuICB9PC9zdHlsZT5cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1SEUsSUFBSSxlQUFDLENBQUMsQUFDSixPQUFPLENBQUUsS0FBSyxDQUNkLFdBQVcsQ0FBRSxNQUFNLENBQ25CLFdBQVcsQ0FBRSxJQUFJLGFBQWEsQ0FBQyw2QkFBNkIsQ0FBQyxBQUMvRCxDQUFDLEFBQ0QsT0FBTyxlQUFDLENBQUMsQUFDUCxRQUFRLENBQUUsUUFBUSxDQUNsQixHQUFHLENBQUUsQ0FBQyxDQUNOLElBQUksQ0FBRSxDQUFDLENBQ1AsaUJBQWlCLENBQUUsV0FBVyxLQUFLLENBQUMsQ0FDNUIsU0FBUyxDQUFFLFdBQVcsS0FBSyxDQUFDLEFBQ3RDLENBQUMsQUFDRCxPQUFPLGVBQUMsQ0FBQyxBQUNQLFFBQVEsQ0FBRSxRQUFRLENBQ2xCLEdBQUcsQ0FBRSxDQUFDLENBQ04sSUFBSSxDQUFFLElBQUksQUFDWixDQUFDLEFBQ0QsZ0JBQWdCLGVBQUMsQ0FBQyxBQUNoQixvQkFBb0IsQ0FBRSxJQUFJLHNCQUFzQixDQUFDLGFBQWEsQ0FBQyxBQUNqRSxDQUFDIn0= */svg.svelte-lfb51n{display:block;position:absolute;overflow:visible;left:var(--left, 0);top:var(--top, 0);width:var(--width, 100%);height:5px}line.svelte-lfb51n{stroke:var(--stroke, currentColor);stroke-width:var(--stroke-width, 1px);stroke-dasharray:var(--stroke-dasharray, 0);marker-end:var(--marker-end);marker-start:var(--marker-start)}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiTGluZUhvcml6b250YWwuc3ZlbHRlIiwic291cmNlcyI6WyJMaW5lSG9yaXpvbnRhbC5zdmVsdGUiXSwic291cmNlc0NvbnRlbnQiOlsiPHN2ZyBkYXRhLXR5cGU9XCJob3Jpem9udGFsLWxpbmVcIj5cbiAgPGxpbmUgeDE9XCIwJVwiIHkxPVwiMC41cHhcIiB4Mj1cIjEwMCVcIiB5Mj1cIjAuNXB4XCIgLz5cbjwvc3ZnPlxuXG48c3R5bGU+XG4gIHN2ZyB7XG4gICAgZGlzcGxheTogYmxvY2s7XG4gICAgcG9zaXRpb246IGFic29sdXRlO1xuICAgIG92ZXJmbG93OiB2aXNpYmxlO1xuICAgIGxlZnQ6IHZhcigtLWxlZnQsIDApO1xuICAgIHRvcDogdmFyKC0tdG9wLCAwKTtcbiAgICB3aWR0aDogdmFyKC0td2lkdGgsIDEwMCUpO1xuICAgIGhlaWdodDogNXB4O1xuICB9XG4gIGxpbmUge1xuICAgIHN0cm9rZTogdmFyKC0tc3Ryb2tlLCBjdXJyZW50Q29sb3IpO1xuICAgIHN0cm9rZS13aWR0aDogdmFyKC0tc3Ryb2tlLXdpZHRoLCAxcHgpO1xuICAgIHN0cm9rZS1kYXNoYXJyYXk6IHZhcigtLXN0cm9rZS1kYXNoYXJyYXksIDApO1xuICAgIG1hcmtlci1lbmQ6IHZhcigtLW1hcmtlci1lbmQpO1xuICAgIG1hcmtlci1zdGFydDogdmFyKC0tbWFya2VyLXN0YXJ0KTtcbiAgfTwvc3R5bGU+XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBS0UsR0FBRyxjQUFDLENBQUMsQUFDSCxPQUFPLENBQUUsS0FBSyxDQUNkLFFBQVEsQ0FBRSxRQUFRLENBQ2xCLFFBQVEsQ0FBRSxPQUFPLENBQ2pCLElBQUksQ0FBRSxJQUFJLE1BQU0sQ0FBQyxFQUFFLENBQUMsQ0FDcEIsR0FBRyxDQUFFLElBQUksS0FBSyxDQUFDLEVBQUUsQ0FBQyxDQUNsQixLQUFLLENBQUUsSUFBSSxPQUFPLENBQUMsS0FBSyxDQUFDLENBQ3pCLE1BQU0sQ0FBRSxHQUFHLEFBQ2IsQ0FBQyxBQUNELElBQUksY0FBQyxDQUFDLEFBQ0osTUFBTSxDQUFFLElBQUksUUFBUSxDQUFDLGFBQWEsQ0FBQyxDQUNuQyxZQUFZLENBQUUsSUFBSSxjQUFjLENBQUMsSUFBSSxDQUFDLENBQ3RDLGdCQUFnQixDQUFFLElBQUksa0JBQWtCLENBQUMsRUFBRSxDQUFDLENBQzVDLFVBQVUsQ0FBRSxJQUFJLFlBQVksQ0FBQyxDQUM3QixZQUFZLENBQUUsSUFBSSxjQUFjLENBQUMsQUFDbkMsQ0FBQyJ9 */svg.svelte-10iz4we{display:block;position:absolute;overflow:visible;top:var(--top, 0);left:var(--left, 0);width:1px;height:var(--height, 100%)}line.svelte-10iz4we{stroke:var(--stroke, currentColor);stroke-width:var(--stroke-width, 1px);stroke-dasharray:var(--stroke-dasharray, 0)}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiTGluZVZlcnRpY2FsLnN2ZWx0ZSIsInNvdXJjZXMiOlsiTGluZVZlcnRpY2FsLnN2ZWx0ZSJdLCJzb3VyY2VzQ29udGVudCI6WyI8c3ZnIGRhdGEtdHlwZT1cInZlcnRpY2FsLWxpbmVcIj5cbiAgPGxpbmUgeDE9XCIwLjVweFwiIHkxPVwiMCVcIiB4Mj1cIjAuNXB4XCIgeTI9XCIxMDAlXCIgLz5cbjwvc3ZnPlxuXG48c3R5bGU+XG4gIHN2ZyB7XG4gICAgZGlzcGxheTogYmxvY2s7XG4gICAgcG9zaXRpb246IGFic29sdXRlO1xuICAgIG92ZXJmbG93OiB2aXNpYmxlO1xuICAgIHRvcDogdmFyKC0tdG9wLCAwKTtcbiAgICBsZWZ0OiB2YXIoLS1sZWZ0LCAwKTtcbiAgICB3aWR0aDogMXB4O1xuICAgIGhlaWdodDogdmFyKC0taGVpZ2h0LCAxMDAlKTtcbiAgfVxuICBsaW5lIHtcbiAgICBzdHJva2U6IHZhcigtLXN0cm9rZSwgY3VycmVudENvbG9yKTtcbiAgICBzdHJva2Utd2lkdGg6IHZhcigtLXN0cm9rZS13aWR0aCwgMXB4KTtcbiAgICBzdHJva2UtZGFzaGFycmF5OiB2YXIoLS1zdHJva2UtZGFzaGFycmF5LCAwKTtcbiAgfTwvc3R5bGU+XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBS0UsR0FBRyxlQUFDLENBQUMsQUFDSCxPQUFPLENBQUUsS0FBSyxDQUNkLFFBQVEsQ0FBRSxRQUFRLENBQ2xCLFFBQVEsQ0FBRSxPQUFPLENBQ2pCLEdBQUcsQ0FBRSxJQUFJLEtBQUssQ0FBQyxFQUFFLENBQUMsQ0FDbEIsSUFBSSxDQUFFLElBQUksTUFBTSxDQUFDLEVBQUUsQ0FBQyxDQUNwQixLQUFLLENBQUUsR0FBRyxDQUNWLE1BQU0sQ0FBRSxJQUFJLFFBQVEsQ0FBQyxLQUFLLENBQUMsQUFDN0IsQ0FBQyxBQUNELElBQUksZUFBQyxDQUFDLEFBQ0osTUFBTSxDQUFFLElBQUksUUFBUSxDQUFDLGFBQWEsQ0FBQyxDQUNuQyxZQUFZLENBQUUsSUFBSSxjQUFjLENBQUMsSUFBSSxDQUFDLENBQ3RDLGdCQUFnQixDQUFFLElBQUksa0JBQWtCLENBQUMsRUFBRSxDQUFDLEFBQzlDLENBQUMifQ== */h4.svelte-1gefht1{font-weight:400}.max-content.svelte-1gefht1{width:-webkit-max-content;width:-moz-max-content;width:max-content}.nowrap.svelte-1gefht1{white-space:nowrap}.label.svelte-1gefht1{display:inline-block;background-color:var(--swatch-color)}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVG9vbHRpcFRlbXBsYXRlLnN2ZWx0ZSIsInNvdXJjZXMiOlsiVG9vbHRpcFRlbXBsYXRlLnN2ZWx0ZSJdLCJzb3VyY2VzQ29udGVudCI6WyI8c2NyaXB0PlxuICBpbXBvcnQgeyBnZXREYXRhRm9ybWF0dGVyIH0gZnJvbSAnLi4vLi4vanMvbW9kdWxlcy9mb3JtYXR0ZXJzJztcblxuICBleHBvcnQgbGV0IGRhdGE7XG4gIGV4cG9ydCBsZXQgZGVidWc7XG4gIGV4cG9ydCBsZXQgdG9vbHRpcENvbmZpZyA9IFtdO1xuICBleHBvcnQgbGV0IHNob3dUb29sdGlwVGl0bGUgPSBmYWxzZTtcbiAgZXhwb3J0IGxldCB0b29sdGlwRm9vdGVyO1xuXG4gICQ6IHRvb2x0aXBUaXRsZSA9IGAke2RhdGEgJiYgZGF0YS5kICYmIGRhdGEuZC5uYW1lX3NlbnRlbmNlID8gJ1RoZSAnIDogJyd9PHN0cm9uZz4ke2RhdGEgJiYgZGF0YS5kID8gZGF0YS5kLm5hbWVfbG9uZyB8fCBkYXRhLmQubmFtZSB8fCAnJyA6ICcnfTwvc3Ryb25nPiBoYXPigKZgO1xuXG4gICQ6IGZpbmFsVG9vbHRpcENvbmZpZyA9IHRvb2x0aXBDb25maWcubWFwKChvYmopID0+IHtcbiAgICBjb25zdCB7IGZvcm1hdHRlcjogZm9ybWF0dGVyS2V5LCB2YXJpYWJsZSB9ID0gb2JqO1xuICAgIGlmIChkZWJ1ZykgY29uc29sZS5sb2cob2JqKTtcbiAgICBjb25zdCB2YWx1ZSA9IGRhdGEuZCA/IGRhdGEuZFt2YXJpYWJsZV0gOiBudWxsO1xuICAgIGNvbnN0IGZvcm1hdHRlciA9IGdldERhdGFGb3JtYXR0ZXIoZm9ybWF0dGVyS2V5KTsgLy9zaG91bGQgbm90IGFjY2VzcyBmb3JtYXQgZnVuY3Rpb24gZGlyZWN0bHkgKHVzZSB0aGUgc3RyaW5nIGRlY2ltYWwyIHdpdGggYWNjZXNzb3IgcmF0aGVyIHRoYW4gZnVuY3Rpb24gZGVjaW1hbDJGb3JtYXQpXG4gICAgY29uc3QgZm9ybWF0dGVkVmFsdWUgPSBmb3JtYXR0ZXIodmFsdWUpO1xuICAgIGxldCB0eXBlO1xuICAgIGlmIChOdW1iZXIuaXNGaW5pdGUodmFsdWUpKSB0eXBlID0gJ251bSc7XG4gICAgZWxzZSBpZiAodHlwZW9mIHZhbHVlID09PSAnc3RyaW5nJykgdHlwZSA9ICdzdHInO1xuICAgIHJldHVybiB7XG4gICAgICAuLi5vYmosXG4gICAgICB0eXBlLFxuICAgICAgdmFsdWUsXG4gICAgICBmb3JtYXR0ZWRWYWx1ZSxcbiAgICB9O1xuICB9KTtcbjwvc2NyaXB0PlxuXG48c3R5bGUgbGFuZz1cInNjc3NcIj5oNHtmb250LXdlaWdodDo0MDB9Lm1heC1jb250ZW50e3dpZHRoOi13ZWJraXQtbWF4LWNvbnRlbnQ7d2lkdGg6LW1vei1tYXgtY29udGVudDt3aWR0aDptYXgtY29udGVudH0ubm93cmFwe3doaXRlLXNwYWNlOm5vd3JhcH0ubGFiZWx7ZGlzcGxheTppbmxpbmUtYmxvY2s7YmFja2dyb3VuZC1jb2xvcjp2YXIoLS1zd2F0Y2gtY29sb3IpfTwvc3R5bGU+XG5cbnsjaWYgdHlwZW9mIHRvb2x0aXBUaXRsZSA9PT0gJ3N0cmluZycgJiYgdG9vbHRpcFRpdGxlLmxlbmd0aCAmJiBzaG93VG9vbHRpcFRpdGxlID09PSB0cnVlfVxuICA8aDQgY2xhc3M9XCJtYXgtY29udGVudCBub3dyYXBcIj57QGh0bWwgdG9vbHRpcFRpdGxlfTwvaDQ+XG57L2lmfVxueyNlYWNoIGZpbmFsVG9vbHRpcENvbmZpZyBhcyB7IHZhcmlhYmxlLCBsYWJlbCwgdmFsdWUsIGZvcm1hdHRlZFZhbHVlLCB0eXBlIH19XG4gIDxkaXY+XG4gICAgeyNpZiB0eXBlID09PSAnbnVtJ31cbiAgICAgIDxkaXYgY2xhc3M9XCJudW0gdGV4dC1sZ1wiPntmb3JtYXR0ZWRWYWx1ZX08L2Rpdj5cbiAgICB7OmVsc2V9XG4gICAgICA8ZGl2IGNsYXNzPVwidGV4dC1sZ1wiPntmb3JtYXR0ZWRWYWx1ZX08L2Rpdj5cbiAgICB7L2lmfVxuICAgIHsjaWYgbGFiZWx9XG4gICAgICA8ZGl2IGNsYXNzPVwidGV4dC1zbWFsbCBsYWJlbCBub3dyYXBcIj57QGh0bWwgbGFiZWx9PC9kaXY+XG4gICAgey9pZn1cbiAgPC9kaXY+XG57L2VhY2h9XG57I2lmIHR5cGVvZiB0b29sdGlwRm9vdGVyID09PSAnc3RyaW5nJyAmJiB0b29sdGlwRm9vdGVyLmxlbmd0aH1cbiAgPGRpdiBjbGFzcz1cIm1heC1jb250ZW50IG5vd3JhcFwiPntAaHRtbCB0b29sdGlwRm9vdGVyfTwvZGl2Plxuey9pZn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE2Qm1CLGlCQUFFLENBQUMsWUFBWSxHQUFHLENBQUMsMkJBQVksQ0FBQyxNQUFNLG1CQUFtQixDQUFDLE1BQU0sZ0JBQWdCLENBQUMsTUFBTSxXQUFXLENBQUMsc0JBQU8sQ0FBQyxZQUFZLE1BQU0sQ0FBQyxxQkFBTSxDQUFDLFFBQVEsWUFBWSxDQUFDLGlCQUFpQixJQUFJLGNBQWMsQ0FBQyxDQUFDIn0= */.grayText.svelte-1jr5wu3.svelte-1jr5wu3{color:#767676}table.svelte-1jr5wu3.svelte-1jr5wu3,th.svelte-1jr5wu3.svelte-1jr5wu3,td.svelte-1jr5wu3.svelte-1jr5wu3{border-collapse:collapse}tr[data-is-expanded-parent][data-has-child].svelte-1jr5wu3 td.svelte-1jr5wu3{border-bottom:0}table.svelte-1jr5wu3 th.svelte-1jr5wu3{cursor:pointer}table.svelte-1jr5wu3 tr[data-hide].svelte-1jr5wu3{display:none}table.svelte-1jr5wu3 tr[data-has-child].svelte-1jr5wu3{cursor:pointer}table.svelte-1jr5wu3 tr[data-has-child][data-is-expanded-parent] td.svelte-1jr5wu3:first-child::after{content:"－"}table.svelte-1jr5wu3 tr[data-has-child] td.svelte-1jr5wu3:first-child::after{width:20px;content:"＋";color:#000;background-color:#ccc;font-weight:700;margin-left:4px}table.svelte-1jr5wu3 tr[data-is-total-row] td.svelte-1jr5wu3{font-style:italic}table.svelte-1jr5wu3 tr[data-is-child] td.svelte-1jr5wu3{color:#767676}table.svelte-1jr5wu3 tr[data-is-child] td.svelte-1jr5wu3:first-child{display:-webkit-inline-flex;display:inline-flex}table.svelte-1jr5wu3 tr[data-is-child] td.svelte-1jr5wu3:first-child::before{content:"└";color:#767676;margin-right:4px}table.svelte-1jr5wu3 tr[data-is-child]:not(:last-child) td.svelte-1jr5wu3{border-bottom:0}tr.over-header.svelte-1jr5wu3 th.svelte-1jr5wu3{cursor:auto;border-bottom:0;text-align:center}th[data-sort].svelte-1jr5wu3 .arrow.svelte-1jr5wu3::after{padding-left:4px;font-size:.75rem;line-height:1.5;vertical-align:text-top}th[data-sort=ascending].svelte-1jr5wu3 .arrow.svelte-1jr5wu3::after{content:"▲"}th[data-sort=descending].svelte-1jr5wu3 .arrow.svelte-1jr5wu3::after{content:"▼"}tr[data-is-child].svelte-1jr5wu3 td.svelte-1jr5wu3{border-bottom:0}tr[data-is-child].svelte-1jr5wu3:not([data-hide])+tr:not([data-is-child]) td.svelte-1jr5wu3{border-top:1px solid #ccc}.dvz-button-group.svelte-1jr5wu3.svelte-1jr5wu3{margin-top:14px;text-align:center}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"Table.svelte","sources":["Table.svelte"],"sourcesContent":["<script context=\"module\">\n  function sortWith(accessor, func) {\n    return (a, b) => func(accessor(a), accessor(b));\n  }\n</script>\n\n<script>\n  import { groups, ascending, descending } from 'd3-array';\n  import { getDataFormatter, getDataType } from '../../js/modules/formatters';\n\n  export let data = [];\n  export let columns = [];\n  export let sortBy;\n  export let rowsToShow;\n  export let naLabel = '–';\n  export let parentCol = '';\n  export let parentColRef = '';\n  export let asterisk = '';\n  export let rowId = 'iso';\n  export let totalRowIds = '';\n  export let parentExpandedArr = [];\n  export let overHeaders = [];\n  export let exceptionIDs = [];\n  export let asteriskIDs = [];\n  export let keepAtBottom = [];\n\n  $: totalRowIdsArr = (totalRowIds || '').split(/, */);\n\n  let showButtonClicks = 0;\n\n  let sortColumn = sortBy.col;\n  let sortAscending = sortBy.ascending;\n\n  $: rowsToShowFinal = [...rowsToShow, Infinity];\n\n  $: buttonText = rowsToShowFinal.map((d, i, arr) => {\n    const isFirst = i === 0;\n    const isLast = i === arr.length - 1;\n    const isPenultimate = i === arr.length - 2;\n    if (isPenultimate) return `Show all`;\n    if (isLast) return `Show less`;\n    if (isFirst) return `Show more`;\n    return `Show more`;\n  });\n\n  $: showButtonIndex = showButtonClicks % buttonText.length;\n\n  $: rowsToShowCurrent = rowsToShowFinal[showButtonIndex];\n\n  $: showButtonText = buttonText[showButtonIndex];\n\n  $: sortDirectionFunc = sortAscending ? ascending : descending;\n\n  $: headerProps = columns.map((column) => {\n    const { id, headerLabel, format } = column;\n    const type = getDataType(format);\n    const isCurrentSortColumn = sortColumn === id ? true : false;\n    const sortDirection = sortAscending ? 'ascending' : 'descending';\n    const sortAttribute = isCurrentSortColumn ? sortDirection : null;\n    const onClick = () => {\n      if (id === sortColumn) {\n        sortAscending = !sortAscending;\n      } else if (type === 'string') {\n        // Not same column and clicking first time\n        sortAscending = true;\n      }\n      sortColumn = id;\n    };\n    return {\n      onClick,\n      id,\n      type,\n      text: headerLabel,\n      sort: sortAttribute,\n    };\n  });\n\n  $: currentExpanded = Object.fromEntries(\n    parentExpandedArr.filter((key) => key.length).map((key) => [key, true])\n  );\n\n  $: toggleRowExpand = (thisRowID) => {\n    const current = currentExpanded[thisRowID] || false;\n    currentExpanded = {\n      ...currentExpanded,\n      [thisRowID]: !current,\n    };\n  };\n\n  $: munged = data.map((row) => {\n    let isChild = false;\n    if (parentCol && parentColRef) {\n      const parentColValue = row[parentCol];\n      if (parentColValue) isChild = true;\n    }\n    const id = row[rowId];\n    return {\n      ...row,\n      id,\n      isChild,\n    };\n  });\n\n  // Group by parent column key\n  $: rowProps = groups(\n    munged,\n    (d) => d[parentCol] || d[parentColRef] || d[rowId]\n  )\n    .map(([, values]) => {\n      // Mark the parent as `isParent`\n      // Sort the rows\n      const nestedRows = values\n        .map((row, i, arr) => {\n          const { isChild } = row;\n          let isParent;\n          let hasChildren = false;\n          if (arr.length === 1) {\n            isParent = true;\n          } else {\n            isParent = !isChild;\n            hasChildren = isParent;\n          }\n          return {\n            ...row,\n            isParent,\n            hasChildren,\n          };\n        })\n        .sort(sortWith((d) => d[sortColumn], sortDirectionFunc))\n        // Parent always goes on top\n        .sort(sortWith((d) => d.isParent, descending));\n\n      // Get the parent, and use it as the sort value\n      const parent = nestedRows.find((d) => d.isParent);\n      const sortValue = parent[sortColumn] || null;\n      return {\n        parent,\n        sortValue,\n        nestedRows,\n      };\n    })\n    // Sort the groups based on the parent\n    .sort(sortWith((d) => +d.sortValue, sortDirectionFunc))\n    // Sort nulls\n    .sort(sortWith((d) => d.sortValue !== null, sortDirectionFunc))\n    // Sort the \"total\" row to the top\n    .sort(sortWith((d) => totalRowIds.includes(d.parent.id), descending))\n    // Sort any \"keep at bottom\" rows to bottom\n    .sort(sortWith((d) => keepAtBottom.includes(d.parent.id), ascending))\n    // Filter parents based on rowsToShow\n    .filter((d, i) => i < rowsToShowCurrent)\n    .map((d) => d.nestedRows)\n    // Flatten the groups\n    .flat()\n    .map((row) => {\n      const { hasChildren } = row;\n      const isTotalRow = totalRowIdsArr.includes(row.id) ? true : false;\n      const isChild = row.isChild ? true : false;\n      const isParent = hasChildren ? true : false;\n      // Is this an expanded parent?\n      let isExpandedParent = false;\n      let parentSelfID = false;\n      if (parentCol && parentColRef) {\n        parentSelfID = row[parentColRef];\n        isExpandedParent = currentExpanded[parentSelfID];\n      }\n      // Is this an expanded child?\n      const parentID = row[parentCol];\n      let isExpandedChild = false;\n      if (isChild) {\n        isExpandedChild = currentExpanded[parentID];\n      }\n      const show = isChild ? isExpandedChild : true;\n      const hide = show ? false : true;\n      const thisRowColumns = columns.map((column, columnIndex) => {\n        const { format } = column;\n        const value = row[column.id];\n        const formatter = getDataFormatter(format);\n        const formatted = formatter(value);\n        const type = getDataType(format);\n        let useAsterisk =\n          columnIndex === 0 && (row[asterisk] || asteriskIDs.includes(row.id));\n        let text =\n          typeof value === 'undefined' || value === null ? naLabel : formatted;\n        let grayText = false;\n        if (text === `NaN`) {\n          text = naLabel;\n        }\n        const exception = exceptionIDs.includes(row.id);\n        if (exception) {\n          if (columnIndex === 0) useAsterisk = true;\n          grayText = true;\n        }\n        return {\n          id: column.id,\n          type,\n          text,\n          asterisk: useAsterisk ? '*' : '',\n          grayText,\n        };\n      });\n      return {\n        id: row.id,\n        isTotalRow,\n        isParent,\n        isChild,\n        isExpandedParent,\n        hide,\n        onClick: () => {\n          if (parentSelfID && isParent) toggleRowExpand(parentSelfID);\n        },\n        columns: thisRowColumns,\n      };\n    });\n</script>\n\n<div class=\"table-container\">\n  <table>\n    <thead>\n      {#if overHeaders.length}\n        <tr class=\"over-header\">\n          {#each overHeaders as { label, colspan }, j}\n            <th\n              colspan={colspan || null}\n              data-col-id={headerProps[\n                overHeaders.reduce(\n                  (acc, cv, idx) => (j > idx ? acc + cv.colspan || 1 : acc),\n                  0\n                )\n              ].id}\n            >\n              {label}\n            </th>\n          {/each}\n        </tr>\n      {/if}\n      <tr>\n        {#each headerProps as { id, onClick, type, text, sort }, j}\n          <th\n            on:click={onClick}\n            data-type={type}\n            data-sort={sort}\n            data-col-id={id}\n          >\n            {text}<span class=\"arrow\" />\n          </th>\n        {/each}\n      </tr>\n    </thead>\n    <tbody>\n      {#each rowProps as { id, onClick, columns, isChild, isParent, isExpandedParent, isTotalRow, hide } (id)}\n        <tr\n          on:click={onClick}\n          data-hide={hide || null}\n          data-is-child={isChild || null}\n          data-has-child={isParent || null}\n          data-is-total-row={isTotalRow || null}\n          data-is-expanded-parent={isExpandedParent || null}\n        >\n          {#each columns as { id, type, text, asterisk, grayText }}\n            <td data-col-id={id} data-type={type} class:grayText>\n              {text}<span class=\"asterisk\">{asterisk}</span>\n            </td>\n          {/each}\n        </tr>\n      {/each}\n    </tbody>\n  </table>\n</div>\n\n<div class=\"dvz-button-group\">\n  <button on:click={() => showButtonClicks++} class=\"dvz-button\" type=\"button\"\n    >{showButtonText}\n    👆</button\n  >\n</div>\n\n<style lang=\"scss\">.grayText{color:#767676}table,th,td{border-collapse:collapse}tr[data-is-expanded-parent][data-has-child] td{border-bottom:0}table th{cursor:pointer}table tr[data-hide]{display:none}table tr[data-has-child]{cursor:pointer}table tr[data-has-child][data-is-expanded-parent] td:first-child::after{content:\"－\"}table tr[data-has-child] td:first-child::after{width:20px;content:\"＋\";color:#000;background-color:#ccc;font-weight:700;margin-left:4px}table tr[data-is-total-row] td{font-style:italic}table tr[data-is-child] td{color:#767676}table tr[data-is-child] td:first-child{display:-webkit-inline-flex;display:inline-flex}table tr[data-is-child] td:first-child::before{content:\"└\";color:#767676;margin-right:4px}table tr[data-is-child]:not(:last-child) td{border-bottom:0}tr.over-header th{cursor:auto;border-bottom:0;text-align:center}th[data-sort] .arrow::after{padding-left:4px;font-size:.75rem;line-height:1.5;vertical-align:text-top}th[data-sort=ascending] .arrow::after{content:\"▲\"}th[data-sort=descending] .arrow::after{content:\"▼\"}tr[data-is-child] td{border-bottom:0}tr[data-is-child]:not([data-hide])+tr:not([data-is-child]) td{border-top:1px solid #ccc}.dvz-button-group{margin-top:14px;text-align:center}</style>\n"],"names":[],"mappings":"AAqRmB,uCAAS,CAAC,MAAM,OAAO,CAAC,mCAAK,CAAC,gCAAE,CAAC,gCAAE,CAAC,gBAAgB,QAAQ,CAAC,EAAE,CAAC,uBAAuB,CAAC,CAAC,cAAc,gBAAC,CAAC,iBAAE,CAAC,cAAc,CAAC,CAAC,oBAAK,CAAC,iBAAE,CAAC,OAAO,OAAO,CAAC,oBAAK,CAAC,EAAE,CAAC,SAAS,gBAAC,CAAC,QAAQ,IAAI,CAAC,oBAAK,CAAC,EAAE,CAAC,cAAc,gBAAC,CAAC,OAAO,OAAO,CAAC,oBAAK,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,uBAAuB,CAAC,CAAC,iBAAE,YAAY,OAAO,CAAC,QAAQ,GAAG,CAAC,oBAAK,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,iBAAE,YAAY,OAAO,CAAC,MAAM,IAAI,CAAC,QAAQ,GAAG,CAAC,MAAM,IAAI,CAAC,iBAAiB,IAAI,CAAC,YAAY,GAAG,CAAC,YAAY,GAAG,CAAC,oBAAK,CAAC,EAAE,CAAC,iBAAiB,CAAC,CAAC,iBAAE,CAAC,WAAW,MAAM,CAAC,oBAAK,CAAC,EAAE,CAAC,aAAa,CAAC,CAAC,iBAAE,CAAC,MAAM,OAAO,CAAC,oBAAK,CAAC,EAAE,CAAC,aAAa,CAAC,CAAC,iBAAE,YAAY,CAAC,QAAQ,mBAAmB,CAAC,QAAQ,WAAW,CAAC,oBAAK,CAAC,EAAE,CAAC,aAAa,CAAC,CAAC,iBAAE,YAAY,QAAQ,CAAC,QAAQ,GAAG,CAAC,MAAM,OAAO,CAAC,aAAa,GAAG,CAAC,oBAAK,CAAC,EAAE,CAAC,aAAa,CAAC,KAAK,WAAW,CAAC,CAAC,iBAAE,CAAC,cAAc,CAAC,CAAC,EAAE,2BAAY,CAAC,iBAAE,CAAC,OAAO,IAAI,CAAC,cAAc,CAAC,CAAC,WAAW,MAAM,CAAC,EAAE,CAAC,SAAS,gBAAC,CAAC,qBAAM,OAAO,CAAC,aAAa,GAAG,CAAC,UAAU,MAAM,CAAC,YAAY,GAAG,CAAC,eAAe,QAAQ,CAAC,EAAE,CAAC,SAAS,CAAC,SAAS,gBAAC,CAAC,qBAAM,OAAO,CAAC,QAAQ,GAAG,CAAC,EAAE,CAAC,SAAS,CAAC,UAAU,gBAAC,CAAC,qBAAM,OAAO,CAAC,QAAQ,GAAG,CAAC,EAAE,CAAC,aAAa,gBAAC,CAAC,iBAAE,CAAC,cAAc,CAAC,CAAC,EAAE,CAAC,aAAa,gBAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,aAAa,CAAC,CAAC,CAAC,iBAAE,CAAC,WAAW,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,+CAAiB,CAAC,WAAW,IAAI,CAAC,WAAW,MAAM,CAAC"} */.selectContainer.svelte-1qswu4k.svelte-1qswu4k{--internalPadding:0 16px;border:var(--border, 1px solid #d8dbdf);border-radius:var(--borderRadius, 3px);box-sizing:border-box;height:var(--height, 42px);position:relative;display:-webkit-flex;display:flex;-webkit-align-items:center;align-items:center;padding:var(--padding, var(--internalPadding));background:var(--background, #fff);margin:var(--margin, 0)}.selectContainer.svelte-1qswu4k input.svelte-1qswu4k{cursor:default;border:none;color:var(--inputColor, #3f4f5f);height:var(--height, 42px);line-height:var(--height, 42px);padding:var(--inputPadding, var(--padding, var(--internalPadding)));width:100%;background:transparent;font-size:var(--inputFontSize, 14px);letter-spacing:var(--inputLetterSpacing, -0.08px);position:absolute;left:var(--inputLeft, 0);margin:var(--inputMargin, 0)}.selectContainer.svelte-1qswu4k input.svelte-1qswu4k::-webkit-input-placeholder{color:var(--placeholderColor, #78848f);opacity:var(--placeholderOpacity, 1)}.selectContainer.svelte-1qswu4k input.svelte-1qswu4k::-moz-placeholder{color:var(--placeholderColor, #78848f);opacity:var(--placeholderOpacity, 1)}.selectContainer.svelte-1qswu4k input.svelte-1qswu4k:-ms-input-placeholder{color:var(--placeholderColor, #78848f);opacity:var(--placeholderOpacity, 1)}.selectContainer.svelte-1qswu4k input.svelte-1qswu4k::-ms-input-placeholder{color:var(--placeholderColor, #78848f);opacity:var(--placeholderOpacity, 1)}.selectContainer.svelte-1qswu4k input.svelte-1qswu4k::placeholder{color:var(--placeholderColor, #78848f);opacity:var(--placeholderOpacity, 1)}.selectContainer.svelte-1qswu4k input.svelte-1qswu4k:focus{outline:none}.selectContainer.svelte-1qswu4k.svelte-1qswu4k:hover{border-color:var(--borderHoverColor, #b2b8bf)}.selectContainer.focused.svelte-1qswu4k.svelte-1qswu4k{border-color:var(--borderFocusColor, #006fe8)}.selectContainer.disabled.svelte-1qswu4k.svelte-1qswu4k{background:var(--disabledBackground, #ebedef);border-color:var(--disabledBorderColor, #ebedef);color:var(--disabledColor, #c1c6cc)}.selectContainer.disabled.svelte-1qswu4k input.svelte-1qswu4k::-webkit-input-placeholder{color:var(--disabledPlaceholderColor, #c1c6cc);opacity:var(--disabledPlaceholderOpacity, 1)}.selectContainer.disabled.svelte-1qswu4k input.svelte-1qswu4k::-moz-placeholder{color:var(--disabledPlaceholderColor, #c1c6cc);opacity:var(--disabledPlaceholderOpacity, 1)}.selectContainer.disabled.svelte-1qswu4k input.svelte-1qswu4k:-ms-input-placeholder{color:var(--disabledPlaceholderColor, #c1c6cc);opacity:var(--disabledPlaceholderOpacity, 1)}.selectContainer.disabled.svelte-1qswu4k input.svelte-1qswu4k::-ms-input-placeholder{color:var(--disabledPlaceholderColor, #c1c6cc);opacity:var(--disabledPlaceholderOpacity, 1)}.selectContainer.disabled.svelte-1qswu4k input.svelte-1qswu4k::placeholder{color:var(--disabledPlaceholderColor, #c1c6cc);opacity:var(--disabledPlaceholderOpacity, 1)}.selectedItem.svelte-1qswu4k.svelte-1qswu4k{line-height:var(--height, 42px);height:var(--height, 42px);overflow-x:hidden;padding:var(--selectedItemPadding, 0 20px 0 0)}.selectedItem.svelte-1qswu4k.svelte-1qswu4k:focus{outline:none}.clearSelect.svelte-1qswu4k.svelte-1qswu4k{position:absolute;right:var(--clearSelectRight, 10px);top:var(--clearSelectTop, 11px);bottom:var(--clearSelectBottom, 11px);width:var(--clearSelectWidth, 20px);color:var(--clearSelectColor, #c5cacf);-webkit-flex:none !important;flex:none !important}.clearSelect.svelte-1qswu4k.svelte-1qswu4k:hover{color:var(--clearSelectHoverColor, #2c3e50)}.selectContainer.focused.svelte-1qswu4k .clearSelect.svelte-1qswu4k{color:var(--clearSelectFocusColor, #3f4f5f)}.indicator.svelte-1qswu4k.svelte-1qswu4k{position:absolute;right:var(--indicatorRight, 10px);top:var(--indicatorTop, 11px);width:var(--indicatorWidth, 20px);height:var(--indicatorHeight, 20px);color:var(--indicatorColor, #c5cacf)}.indicator.svelte-1qswu4k svg.svelte-1qswu4k{display:inline-block;fill:var(--indicatorFill, currentcolor);line-height:1;stroke:var(--indicatorStroke, currentcolor);stroke-width:0}.spinner.svelte-1qswu4k.svelte-1qswu4k{position:absolute;right:var(--spinnerRight, 10px);top:var(--spinnerLeft, 11px);width:var(--spinnerWidth, 20px);height:var(--spinnerHeight, 20px);color:var(--spinnerColor, #51ce6c);-webkit-animation:svelte-1qswu4k-rotate 0.75s linear infinite;animation:svelte-1qswu4k-rotate 0.75s linear infinite}.spinner_icon.svelte-1qswu4k.svelte-1qswu4k{display:block;height:100%;-webkit-transform-origin:center center;transform-origin:center center;width:100%;position:absolute;top:0;bottom:0;left:0;right:0;margin:auto;-webkit-transform:none}.spinner_path.svelte-1qswu4k.svelte-1qswu4k{stroke-dasharray:90;stroke-linecap:round}.multiSelect.svelte-1qswu4k.svelte-1qswu4k{display:-webkit-flex;display:flex;padding:var(--multiSelectPadding, 0 35px 0 16px);height:auto;-webkit-flex-wrap:wrap;flex-wrap:wrap;-webkit-align-items:stretch;align-items:stretch}.multiSelect.svelte-1qswu4k>.svelte-1qswu4k{-webkit-flex:1 1 50px;flex:1 1 50px}.selectContainer.multiSelect.svelte-1qswu4k input.svelte-1qswu4k{padding:var(--multiSelectInputPadding, 0);position:relative;margin:var(--multiSelectInputMargin, 0)}.hasError.svelte-1qswu4k.svelte-1qswu4k{border:var(--errorBorder, 1px solid #ff2d55);background:var(--errorBackground, #fff)}.a11yText.svelte-1qswu4k.svelte-1qswu4k{z-index:9999;border:0px;clip:rect(1px, 1px, 1px, 1px);height:1px;width:1px;position:absolute;overflow:hidden;padding:0px;white-space:nowrap}@-webkit-keyframes svelte-1qswu4k-rotate{100%{-webkit-transform:rotate(360deg);transform:rotate(360deg)}}@keyframes svelte-1qswu4k-rotate{100%{-webkit-transform:rotate(360deg);transform:rotate(360deg)}}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"Select.svelte","sources":["Select.svelte"],"sourcesContent":["<script>\n    import { beforeUpdate, createEventDispatcher, onMount } from 'svelte';\n\n    import _List from './List.svelte';\n    import _Item from './Item.svelte';\n    import _Selection from './Selection.svelte';\n    import _MultiSelection from './MultiSelection.svelte';\n    import _VirtualList from './VirtualList.svelte';\n    import _ClearIcon from './ClearIcon.svelte';\n    import debounce from './utils/debounce';\n\n    const dispatch = createEventDispatcher();\n\n    export let id = null;\n    export let container = undefined;\n    export let input = undefined;\n    export let isMulti = false;\n    export let multiFullItemClearable = false;\n    export let isDisabled = false;\n    export let isCreatable = false;\n    export let isFocused = false;\n    export let value = null;\n    export let filterText = '';\n    export let placeholder = 'Select...';\n    export let placeholderAlwaysShow = false;\n    export let items = null;\n    export let itemFilter = (label, filterText, option) =>\n        `${label}`.toLowerCase().includes(filterText.toLowerCase());\n    export let groupBy = undefined;\n    export let groupFilter = (groups) => groups;\n    export let isGroupHeaderSelectable = false;\n    export let getGroupHeaderLabel = (option) => {\n        return option[labelIdentifier] || option.id;\n    };\n    export let labelIdentifier = 'label';\n    export let getOptionLabel = (option, filterText) => {\n        return option.isCreator\n            ? `Create \\\"${filterText}\\\"`\n            : option[labelIdentifier];\n    };\n    export let optionIdentifier = 'value';\n    export let loadOptions = undefined;\n    export let hasError = false;\n    export let containerStyles = '';\n    export let getSelectionLabel = (option) => {\n        if (option) return option[labelIdentifier];\n        else return null;\n    };\n\n    export let createGroupHeaderItem = (groupValue) => {\n        return {\n            value: groupValue,\n            label: groupValue,\n        };\n    };\n\n    export let createItem = (filterText) => {\n        return {\n            value: filterText,\n            label: filterText,\n        };\n    };\n\n    export const getFilteredItems = () => {\n        return filteredItems;\n    };\n\n    export let isSearchable = true;\n    export let inputStyles = '';\n    export let isClearable = true;\n    export let isWaiting = false;\n    export let listPlacement = 'auto';\n    export let listOpen = false;\n    export let isVirtualList = false;\n    export let loadOptionsInterval = 300;\n    export let noOptionsMessage = 'No options';\n    export let hideEmptyState = false;\n    export let inputAttributes = {};\n    export let listAutoWidth = true;\n    export let itemHeight = 40;\n    export let Icon = undefined;\n    export let iconProps = {};\n    export let showChevron = false;\n    export let showIndicator = false;\n    export let containerClasses = '';\n    export let indicatorSvg = undefined;\n    export let listOffset = 5;\n\n    export let ClearIcon = _ClearIcon;\n    export let Item = _Item;\n    export let List = _List;\n    export let Selection = _Selection;\n    export let MultiSelection = _MultiSelection;\n    export let VirtualList = _VirtualList;\n\n    function filterMethod(args) {\n        if (args.loadOptions && args.filterText.length > 0) return;\n        if (!args.items) return [];\n\n        if (\n            args.items &&\n            args.items.length > 0 &&\n            typeof args.items[0] !== 'object'\n        ) {\n            args.items = convertStringItemsToObjects(args.items);\n        }\n\n        let filterResults = args.items.filter((item) => {\n            let matchesFilter = itemFilter(\n                getOptionLabel(item, args.filterText),\n                args.filterText,\n                item\n            );\n\n            if (\n                matchesFilter &&\n                args.isMulti &&\n                args.value &&\n                Array.isArray(args.value)\n            ) {\n                matchesFilter = !args.value.some((x) => {\n                    return (\n                        x[args.optionIdentifier] === item[args.optionIdentifier]\n                    );\n                });\n            }\n\n            return matchesFilter;\n        });\n\n        if (args.groupBy) {\n            filterResults = filterGroupedItems(filterResults);\n        }\n\n        if (args.isCreatable) {\n            filterResults = addCreatableItem(filterResults, args.filterText);\n        }\n\n        return filterResults;\n    }\n\n    function addCreatableItem(_items, _filterText) {\n        if (_filterText.length === 0) return _items;\n        const itemToCreate = createItem(_filterText);\n        if (_items[0] && _filterText === _items[0][labelIdentifier])\n            return _items;\n        itemToCreate.isCreator = true;\n        return [..._items, itemToCreate];\n    }\n\n    $: filteredItems = filterMethod({\n        loadOptions,\n        filterText,\n        items,\n        value,\n        isMulti,\n        optionIdentifier,\n        groupBy,\n        isCreatable,\n    });\n\n    export let selectedValue = null;\n    $: {\n        if (selectedValue)\n            console.warn(\n                'selectedValue is no longer used. Please use value instead.'\n            );\n    }\n\n    let activeValue;\n    let prev_value;\n    let prev_filterText;\n    let prev_isFocused;\n    let prev_isMulti;\n    let hoverItemIndex;\n\n    const getItems = debounce(async () => {\n        isWaiting = true;\n        let res = await loadOptions(filterText).catch((err) => {\n            console.warn('svelte-select loadOptions error :>> ', err);\n            dispatch('error', { type: 'loadOptions', details: err });\n        });\n\n        if (res && !res.cancelled) {\n            if (res) {\n                if (res && res.length > 0 && typeof res[0] !== 'object') {\n                    res = convertStringItemsToObjects(res);\n                }\n                filteredItems = [...res];\n                dispatch('loaded', { items: filteredItems });\n            } else {\n                filteredItems = [];\n            }\n\n            if (isCreatable) {\n                filteredItems = addCreatableItem(filteredItems, filterText);\n            }\n\n            isWaiting = false;\n            isFocused = true;\n            listOpen = true;\n        }\n    }, loadOptionsInterval);\n\n    $: updateValueDisplay(items);\n\n    function setValue() {\n        if (typeof value === 'string') {\n            value = {\n                [optionIdentifier]: value,\n                label: value,\n            };\n        } else if (isMulti && Array.isArray(value) && value.length > 0) {\n            value = value.map((item) =>\n                typeof item === 'string' ? { value: item, label: item } : item\n            );\n        }\n    }\n\n    let _inputAttributes;\n    function assignInputAttributes() {\n        _inputAttributes = Object.assign(\n            {\n                autocapitalize: 'none',\n                autocomplete: 'off',\n                autocorrect: 'off',\n                spellcheck: false,\n                tabindex: 0,\n                type: 'text',\n                'aria-autocomplete': 'list',\n            },\n            inputAttributes\n        );\n\n        if (id) {\n            _inputAttributes.id = id;\n        }\n\n        if (!isSearchable) {\n            _inputAttributes.readonly = true;\n        }\n    }\n\n    function convertStringItemsToObjects(_items) {\n        return _items.map((item, index) => {\n            return {\n                index,\n                value: item,\n                label: `${item}`,\n            };\n        });\n    }\n\n    function filterGroupedItems(_items) {\n        const groupValues = [];\n        const groups = {};\n\n        _items.forEach((item) => {\n            const groupValue = groupBy(item);\n\n            if (!groupValues.includes(groupValue)) {\n                groupValues.push(groupValue);\n                groups[groupValue] = [];\n\n                if (groupValue) {\n                    groups[groupValue].push(\n                        Object.assign(createGroupHeaderItem(groupValue, item), {\n                            id: groupValue,\n                            isGroupHeader: true,\n                            isSelectable: isGroupHeaderSelectable,\n                        })\n                    );\n                }\n            }\n\n            groups[groupValue].push(\n                Object.assign({ isGroupItem: !!groupValue }, item)\n            );\n        });\n\n        const sortedGroupedItems = [];\n\n        groupFilter(groupValues).forEach((groupValue) => {\n            sortedGroupedItems.push(...groups[groupValue]);\n        });\n\n        return sortedGroupedItems;\n    }\n\n    function dispatchSelectedItem() {\n        if (isMulti) {\n            if (JSON.stringify(value) !== JSON.stringify(prev_value)) {\n                if (checkValueForDuplicates()) {\n                    dispatch('select', value);\n                }\n            }\n            return;\n        }\n\n        if (\n            !prev_value ||\n            JSON.stringify(value[optionIdentifier]) !==\n                JSON.stringify(prev_value[optionIdentifier])\n        ) {\n            dispatch('select', value);\n        }\n    }\n\n    function setupFocus() {\n        if (isFocused || listOpen) {\n            handleFocus();\n        } else {\n            if (input) input.blur();\n        }\n    }\n\n    function setupMulti() {\n        if (value) {\n            if (Array.isArray(value)) {\n                value = [...value];\n            } else {\n                value = [value];\n            }\n        }\n    }\n\n    function setupSingle() {\n        if (value) value = null;\n    }\n\n    $: {\n        if (value) setValue();\n    }\n\n    $: {\n        if (inputAttributes || !isSearchable) assignInputAttributes();\n    }\n\n    $: {\n        if (isMulti) {\n            setupMulti();\n        }\n\n        if (prev_isMulti && !isMulti) {\n            setupSingle();\n        }\n    }\n\n    $: {\n        if (isMulti && value && value.length > 1) {\n            checkValueForDuplicates();\n        }\n    }\n\n    $: {\n        if (value) dispatchSelectedItem();\n    }\n\n    $: {\n        if (!value && isMulti && prev_value) {\n            dispatch('select', value);\n        }\n    }\n\n    $: {\n        if (isFocused !== prev_isFocused) {\n            setupFocus();\n        }\n    }\n\n    $: {\n        if (filterText !== prev_filterText) {\n            setupFilterText();\n        }\n    }\n\n    function setupFilterText() {\n        if (filterText.length === 0) return;\n\n        isFocused = true;\n        listOpen = true;\n\n        if (loadOptions) {\n            getItems();\n        } else {\n            listOpen = true;\n\n            if (isMulti) {\n                activeValue = undefined;\n            }\n        }\n    }\n\n    $: showSelectedItem = value && filterText.length === 0;\n    $: showClearIcon =\n        showSelectedItem && isClearable && !isDisabled && !isWaiting;\n    $: placeholderText =\n        placeholderAlwaysShow && isMulti\n            ? placeholder\n            : value\n            ? ''\n            : placeholder;\n    $: showMultiSelect = isMulti && value && value.length > 0;\n\n    beforeUpdate(async () => {\n        prev_value = value;\n        prev_filterText = filterText;\n        prev_isFocused = isFocused;\n        prev_isMulti = isMulti;\n    });\n\n    function checkValueForDuplicates() {\n        let noDuplicates = true;\n        if (value) {\n            const ids = [];\n            const uniqueValues = [];\n\n            value.forEach((val) => {\n                if (!ids.includes(val[optionIdentifier])) {\n                    ids.push(val[optionIdentifier]);\n                    uniqueValues.push(val);\n                } else {\n                    noDuplicates = false;\n                }\n            });\n\n            if (!noDuplicates) value = uniqueValues;\n        }\n        return noDuplicates;\n    }\n\n    function findItem(selection) {\n        let matchTo = selection\n            ? selection[optionIdentifier]\n            : value[optionIdentifier];\n        return items.find((item) => item[optionIdentifier] === matchTo);\n    }\n\n    function updateValueDisplay(items) {\n        if (\n            !items ||\n            items.length === 0 ||\n            items.some((item) => typeof item !== 'object')\n        )\n            return;\n        if (\n            !value ||\n            (isMulti\n                ? value.some(\n                      (selection) => !selection || !selection[optionIdentifier]\n                  )\n                : !value[optionIdentifier])\n        )\n            return;\n\n        if (Array.isArray(value)) {\n            value = value.map((selection) => findItem(selection) || selection);\n        } else {\n            value = findItem() || value;\n        }\n    }\n\n    function handleMultiItemClear(event) {\n        const { detail } = event;\n        const itemToRemove = value[detail ? detail.i : value.length - 1];\n\n        if (value.length === 1) {\n            value = undefined;\n        } else {\n            value = value.filter((item) => {\n                return item !== itemToRemove;\n            });\n        }\n\n        dispatch('clear', itemToRemove);\n    }\n\n    function handleKeyDown(e) {\n        if (!isFocused) return;\n\n        switch (e.key) {\n            case 'ArrowDown':\n                e.preventDefault();\n                listOpen = true;\n                activeValue = undefined;\n                break;\n            case 'ArrowUp':\n                e.preventDefault();\n                listOpen = true;\n                activeValue = undefined;\n                break;\n            case 'Tab':\n                if (!listOpen) isFocused = false;\n                break;\n            case 'Backspace':\n                if (!isMulti || filterText.length > 0) return;\n                if (isMulti && value && value.length > 0) {\n                    handleMultiItemClear(\n                        activeValue !== undefined\n                            ? activeValue\n                            : value.length - 1\n                    );\n                    if (activeValue === 0 || activeValue === undefined) break;\n                    activeValue =\n                        value.length > activeValue\n                            ? activeValue - 1\n                            : undefined;\n                }\n                break;\n            case 'ArrowLeft':\n                if (!isMulti || filterText.length > 0) return;\n                if (activeValue === undefined) {\n                    activeValue = value.length - 1;\n                } else if (value.length > activeValue && activeValue !== 0) {\n                    activeValue -= 1;\n                }\n                break;\n            case 'ArrowRight':\n                if (\n                    !isMulti ||\n                    filterText.length > 0 ||\n                    activeValue === undefined\n                )\n                    return;\n                if (activeValue === value.length - 1) {\n                    activeValue = undefined;\n                } else if (activeValue < value.length - 1) {\n                    activeValue += 1;\n                }\n                break;\n        }\n    }\n\n    function handleFocus() {\n        isFocused = true;\n        if (input) input.focus();\n    }\n\n    function handleWindowEvent(event) {\n        if (!container) return;\n        const eventTarget =\n            event.path && event.path.length > 0 ? event.path[0] : event.target;\n        if (container.contains(eventTarget)) return;\n        isFocused = false;\n        listOpen = false;\n        activeValue = undefined;\n        if (input) input.blur();\n    }\n\n    function handleClick() {\n        if (isDisabled) return;\n        isFocused = true;\n        listOpen = !listOpen;\n    }\n\n    export function handleClear() {\n        value = undefined;\n        listOpen = false;\n        dispatch('clear', value);\n        handleFocus();\n    }\n\n    onMount(() => {\n        if (isFocused && input) input.focus();\n    });\n\n    $: listProps = {\n        Item,\n        filterText,\n        optionIdentifier,\n        noOptionsMessage,\n        hideEmptyState,\n        isVirtualList,\n        VirtualList,\n        value,\n        isMulti,\n        getGroupHeaderLabel,\n        items: filteredItems,\n        itemHeight,\n        getOptionLabel,\n        listPlacement,\n        parent: container,\n        listAutoWidth,\n        listOffset,\n    };\n\n    function itemSelected(event) {\n        const { detail } = event;\n\n        if (detail) {\n            filterText = '';\n            const item = Object.assign({}, detail);\n\n            if (!item.isGroupHeader || item.isSelectable) {\n                if (isMulti) {\n                    value = value ? value.concat([item]) : [item];\n                } else {\n                    value = item;\n                }\n\n                value = value;\n\n                setTimeout(() => {\n                    listOpen = false;\n                    activeValue = undefined;\n                });\n            }\n        }\n    }\n\n    function itemCreated(event) {\n        const { detail } = event;\n        if (isMulti) {\n            value = value || [];\n            value = [...value, createItem(detail)];\n        } else {\n            value = createItem(detail);\n        }\n\n        dispatch('itemCreated', detail);\n        filterText = '';\n        listOpen = false;\n        activeValue = undefined;\n    }\n\n    function closeList() {\n        filterText = '';\n        listOpen = false;\n    }\n\n    export let ariaValues = (values) => {\n        return `Option ${values}, selected.`;\n    };\n\n    export let ariaListOpen = (label, count) => {\n        return `You are currently focused on option ${label}. There are ${count} results available.`;\n    };\n\n    export let ariaFocused = () => {\n        return `Select is focused, type to refine list, press down to open the menu.`;\n    };\n\n    function handleAriaSelection() {\n        let selected = undefined;\n\n        if (isMulti && value.length > 0) {\n            selected = value.map((v) => getSelectionLabel(v)).join(', ');\n        } else {\n            selected = getSelectionLabel(value);\n        }\n\n        return ariaValues(selected);\n    }\n\n    function handleAriaContent() {\n        if (!isFocused || !filteredItems || filteredItems.length === 0)\n            return '';\n\n        let _item = filteredItems[hoverItemIndex];\n        if (listOpen && _item) {\n            let label = getSelectionLabel(_item);\n            let count = filteredItems ? filteredItems.length : 0;\n\n            return ariaListOpen(label, count);\n        } else {\n            return ariaFocused();\n        }\n    }\n\n    $: ariaSelection = value ? handleAriaSelection(isMulti) : '';\n    $: ariaContext = handleAriaContent(\n        filteredItems,\n        hoverItemIndex,\n        isFocused,\n        listOpen\n    );\n</script>\n\n<style>\n    .selectContainer {\n        --internalPadding: 0 16px;\n        border: var(--border, 1px solid #d8dbdf);\n        border-radius: var(--borderRadius, 3px);\n        box-sizing: border-box;\n        height: var(--height, 42px);\n        position: relative;\n        display: -webkit-flex;\n        display: flex;\n        -webkit-align-items: center;\n                align-items: center;\n        padding: var(--padding, var(--internalPadding));\n        background: var(--background, #fff);\n        margin: var(--margin, 0);\n    }\n\n    .selectContainer input {\n        cursor: default;\n        border: none;\n        color: var(--inputColor, #3f4f5f);\n        height: var(--height, 42px);\n        line-height: var(--height, 42px);\n        padding: var(--inputPadding, var(--padding, var(--internalPadding)));\n        width: 100%;\n        background: transparent;\n        font-size: var(--inputFontSize, 14px);\n        letter-spacing: var(--inputLetterSpacing, -0.08px);\n        position: absolute;\n        left: var(--inputLeft, 0);\n        margin: var(--inputMargin, 0);\n    }\n\n    .selectContainer input::-webkit-input-placeholder {\n        color: var(--placeholderColor, #78848f);\n        opacity: var(--placeholderOpacity, 1);\n    }\n\n    .selectContainer input::-moz-placeholder {\n        color: var(--placeholderColor, #78848f);\n        opacity: var(--placeholderOpacity, 1);\n    }\n\n    .selectContainer input:-ms-input-placeholder {\n        color: var(--placeholderColor, #78848f);\n        opacity: var(--placeholderOpacity, 1);\n    }\n\n    .selectContainer input::-ms-input-placeholder {\n        color: var(--placeholderColor, #78848f);\n        opacity: var(--placeholderOpacity, 1);\n    }\n\n    .selectContainer input::placeholder {\n        color: var(--placeholderColor, #78848f);\n        opacity: var(--placeholderOpacity, 1);\n    }\n\n    .selectContainer input:focus {\n        outline: none;\n    }\n\n    .selectContainer:hover {\n        border-color: var(--borderHoverColor, #b2b8bf);\n    }\n\n    .selectContainer.focused {\n        border-color: var(--borderFocusColor, #006fe8);\n    }\n\n    .selectContainer.disabled {\n        background: var(--disabledBackground, #ebedef);\n        border-color: var(--disabledBorderColor, #ebedef);\n        color: var(--disabledColor, #c1c6cc);\n    }\n\n    .selectContainer.disabled input::-webkit-input-placeholder {\n        color: var(--disabledPlaceholderColor, #c1c6cc);\n        opacity: var(--disabledPlaceholderOpacity, 1);\n    }\n\n    .selectContainer.disabled input::-moz-placeholder {\n        color: var(--disabledPlaceholderColor, #c1c6cc);\n        opacity: var(--disabledPlaceholderOpacity, 1);\n    }\n\n    .selectContainer.disabled input:-ms-input-placeholder {\n        color: var(--disabledPlaceholderColor, #c1c6cc);\n        opacity: var(--disabledPlaceholderOpacity, 1);\n    }\n\n    .selectContainer.disabled input::-ms-input-placeholder {\n        color: var(--disabledPlaceholderColor, #c1c6cc);\n        opacity: var(--disabledPlaceholderOpacity, 1);\n    }\n\n    .selectContainer.disabled input::placeholder {\n        color: var(--disabledPlaceholderColor, #c1c6cc);\n        opacity: var(--disabledPlaceholderOpacity, 1);\n    }\n\n    .selectedItem {\n        line-height: var(--height, 42px);\n        height: var(--height, 42px);\n        overflow-x: hidden;\n        padding: var(--selectedItemPadding, 0 20px 0 0);\n    }\n\n    .selectedItem:focus {\n        outline: none;\n    }\n\n    .clearSelect {\n        position: absolute;\n        right: var(--clearSelectRight, 10px);\n        top: var(--clearSelectTop, 11px);\n        bottom: var(--clearSelectBottom, 11px);\n        width: var(--clearSelectWidth, 20px);\n        color: var(--clearSelectColor, #c5cacf);\n        -webkit-flex: none !important;\n                flex: none !important;\n    }\n\n    .clearSelect:hover {\n        color: var(--clearSelectHoverColor, #2c3e50);\n    }\n\n    .selectContainer.focused .clearSelect {\n        color: var(--clearSelectFocusColor, #3f4f5f);\n    }\n\n    .indicator {\n        position: absolute;\n        right: var(--indicatorRight, 10px);\n        top: var(--indicatorTop, 11px);\n        width: var(--indicatorWidth, 20px);\n        height: var(--indicatorHeight, 20px);\n        color: var(--indicatorColor, #c5cacf);\n    }\n\n    .indicator svg {\n        display: inline-block;\n        fill: var(--indicatorFill, currentcolor);\n        line-height: 1;\n        stroke: var(--indicatorStroke, currentcolor);\n        stroke-width: 0;\n    }\n\n    .spinner {\n        position: absolute;\n        right: var(--spinnerRight, 10px);\n        top: var(--spinnerLeft, 11px);\n        width: var(--spinnerWidth, 20px);\n        height: var(--spinnerHeight, 20px);\n        color: var(--spinnerColor, #51ce6c);\n        -webkit-animation: rotate 0.75s linear infinite;\n                animation: rotate 0.75s linear infinite;\n    }\n\n    .spinner_icon {\n        display: block;\n        height: 100%;\n        -webkit-transform-origin: center center;\n                transform-origin: center center;\n        width: 100%;\n        position: absolute;\n        top: 0;\n        bottom: 0;\n        left: 0;\n        right: 0;\n        margin: auto;\n        -webkit-transform: none;\n    }\n\n    .spinner_path {\n        stroke-dasharray: 90;\n        stroke-linecap: round;\n    }\n\n    .multiSelect {\n        display: -webkit-flex;\n        display: flex;\n        padding: var(--multiSelectPadding, 0 35px 0 16px);\n        height: auto;\n        -webkit-flex-wrap: wrap;\n                flex-wrap: wrap;\n        -webkit-align-items: stretch;\n                align-items: stretch;\n    }\n\n    .multiSelect > * {\n        -webkit-flex: 1 1 50px;\n                flex: 1 1 50px;\n    }\n\n    .selectContainer.multiSelect input {\n        padding: var(--multiSelectInputPadding, 0);\n        position: relative;\n        margin: var(--multiSelectInputMargin, 0);\n    }\n\n    .hasError {\n        border: var(--errorBorder, 1px solid #ff2d55);\n        background: var(--errorBackground, #fff);\n    }\n\n    .a11yText {\n        z-index: 9999;\n        border: 0px;\n        clip: rect(1px, 1px, 1px, 1px);\n        height: 1px;\n        width: 1px;\n        position: absolute;\n        overflow: hidden;\n        padding: 0px;\n        white-space: nowrap;\n    }\n\n    @-webkit-keyframes rotate {\n        100% {\n            -webkit-transform: rotate(360deg);\n                    transform: rotate(360deg);\n        }\n    }\n\n    @keyframes rotate {\n        100% {\n            -webkit-transform: rotate(360deg);\n                    transform: rotate(360deg);\n        }\n    }</style>\n\n<svelte:window\n    on:click={handleWindowEvent}\n    on:focusin={handleWindowEvent}\n    on:keydown={handleKeyDown} />\n\n<div\n    class=\"selectContainer {containerClasses}\"\n    class:hasError\n    class:multiSelect={isMulti}\n    class:disabled={isDisabled}\n    class:focused={isFocused}\n    style={containerStyles}\n    on:click={handleClick}\n    bind:this={container}>\n    <span\n        aria-live=\"polite\"\n        aria-atomic=\"false\"\n        aria-relevant=\"additions text\"\n        class=\"a11yText\">\n        {#if isFocused}\n            <span id=\"aria-selection\">{ariaSelection}</span>\n            <span id=\"aria-context\">\n                {ariaContext}\n            </span>\n        {/if}\n    </span>\n\n    {#if Icon}\n        <svelte:component this={Icon} {...iconProps} />\n    {/if}\n\n    {#if showMultiSelect}\n        <svelte:component\n            this={MultiSelection}\n            {value}\n            {getSelectionLabel}\n            {activeValue}\n            {isDisabled}\n            {multiFullItemClearable}\n            on:multiItemClear={handleMultiItemClear}\n            on:focus={handleFocus} />\n    {/if}\n\n    <input\n        readOnly={!isSearchable}\n        {..._inputAttributes}\n        bind:this={input}\n        on:focus={handleFocus}\n        bind:value={filterText}\n        placeholder={placeholderText}\n        style={inputStyles}\n        disabled={isDisabled} />\n\n    {#if !isMulti && showSelectedItem}\n        <div class=\"selectedItem\" on:focus={handleFocus}>\n            <svelte:component\n                this={Selection}\n                item={value}\n                {getSelectionLabel} />\n        </div>\n    {/if}\n\n    {#if showClearIcon}\n        <div\n            class=\"clearSelect\"\n            on:click|preventDefault={handleClear}\n            aria-hidden=\"true\">\n            <svelte:component this={ClearIcon} />\n        </div>\n    {/if}\n\n    {#if !showClearIcon && (showIndicator || (showChevron && !value) || (!isSearchable && !isDisabled && !isWaiting && ((showSelectedItem && !isClearable) || !showSelectedItem)))}\n        <div class=\"indicator\" aria-hidden=\"true\">\n            {#if indicatorSvg}\n                {@html indicatorSvg}\n            {:else}\n                <svg\n                    width=\"100%\"\n                    height=\"100%\"\n                    viewBox=\"0 0 20 20\"\n                    focusable=\"false\"\n                    aria-hidden=\"true\">\n                    <path\n                        d=\"M4.516 7.548c0.436-0.446 1.043-0.481 1.576 0l3.908 3.747\n          3.908-3.747c0.533-0.481 1.141-0.446 1.574 0 0.436 0.445 0.408 1.197 0\n          1.615-0.406 0.418-4.695 4.502-4.695 4.502-0.217 0.223-0.502\n          0.335-0.787 0.335s-0.57-0.112-0.789-0.335c0\n          0-4.287-4.084-4.695-4.502s-0.436-1.17 0-1.615z\" />\n                </svg>\n            {/if}\n        </div>\n    {/if}\n\n    {#if isWaiting}\n        <div class=\"spinner\">\n            <svg class=\"spinner_icon\" viewBox=\"25 25 50 50\">\n                <circle\n                    class=\"spinner_path\"\n                    cx=\"50\"\n                    cy=\"50\"\n                    r=\"20\"\n                    fill=\"none\"\n                    stroke=\"currentColor\"\n                    stroke-width=\"5\"\n                    stroke-miterlimit=\"10\" />\n            </svg>\n        </div>\n    {/if}\n\n    {#if listOpen}\n        <svelte:component\n            this={List}\n            {...listProps}\n            bind:hoverItemIndex\n            on:itemSelected={itemSelected}\n            on:itemCreated={itemCreated}\n            on:closeList={closeList} />\n    {/if}\n\n    {#if !isMulti || (isMulti && !showMultiSelect)}\n        <input\n            name={inputAttributes.name}\n            type=\"hidden\"\n            value={value ? getSelectionLabel(value) : null} />\n    {/if}\n\n    {#if isMulti && showMultiSelect}\n        {#each value as item}\n            <input\n                name={inputAttributes.name}\n                type=\"hidden\"\n                value={item ? getSelectionLabel(item) : null} />\n        {/each}\n    {/if}\n</div>\n"],"names":[],"mappings":"AAuqBI,gBAAgB,8BAAC,CAAC,AACd,iBAAiB,CAAE,MAAM,CACzB,MAAM,CAAE,IAAI,QAAQ,CAAC,kBAAkB,CAAC,CACxC,aAAa,CAAE,IAAI,cAAc,CAAC,IAAI,CAAC,CACvC,UAAU,CAAE,UAAU,CACtB,MAAM,CAAE,IAAI,QAAQ,CAAC,KAAK,CAAC,CAC3B,QAAQ,CAAE,QAAQ,CAClB,OAAO,CAAE,YAAY,CACrB,OAAO,CAAE,IAAI,CACb,mBAAmB,CAAE,MAAM,CACnB,WAAW,CAAE,MAAM,CAC3B,OAAO,CAAE,IAAI,SAAS,CAAC,uBAAuB,CAAC,CAC/C,UAAU,CAAE,IAAI,YAAY,CAAC,KAAK,CAAC,CACnC,MAAM,CAAE,IAAI,QAAQ,CAAC,EAAE,CAAC,AAC5B,CAAC,AAED,+BAAgB,CAAC,KAAK,eAAC,CAAC,AACpB,MAAM,CAAE,OAAO,CACf,MAAM,CAAE,IAAI,CACZ,KAAK,CAAE,IAAI,YAAY,CAAC,QAAQ,CAAC,CACjC,MAAM,CAAE,IAAI,QAAQ,CAAC,KAAK,CAAC,CAC3B,WAAW,CAAE,IAAI,QAAQ,CAAC,KAAK,CAAC,CAChC,OAAO,CAAE,IAAI,cAAc,CAAC,uCAAuC,CAAC,CACpE,KAAK,CAAE,IAAI,CACX,UAAU,CAAE,WAAW,CACvB,SAAS,CAAE,IAAI,eAAe,CAAC,KAAK,CAAC,CACrC,cAAc,CAAE,IAAI,oBAAoB,CAAC,QAAQ,CAAC,CAClD,QAAQ,CAAE,QAAQ,CAClB,IAAI,CAAE,IAAI,WAAW,CAAC,EAAE,CAAC,CACzB,MAAM,CAAE,IAAI,aAAa,CAAC,EAAE,CAAC,AACjC,CAAC,AAED,+BAAgB,CAAC,oBAAK,2BAA2B,AAAC,CAAC,AAC/C,KAAK,CAAE,IAAI,kBAAkB,CAAC,QAAQ,CAAC,CACvC,OAAO,CAAE,IAAI,oBAAoB,CAAC,EAAE,CAAC,AACzC,CAAC,AAED,+BAAgB,CAAC,oBAAK,kBAAkB,AAAC,CAAC,AACtC,KAAK,CAAE,IAAI,kBAAkB,CAAC,QAAQ,CAAC,CACvC,OAAO,CAAE,IAAI,oBAAoB,CAAC,EAAE,CAAC,AACzC,CAAC,AAED,+BAAgB,CAAC,oBAAK,sBAAsB,AAAC,CAAC,AAC1C,KAAK,CAAE,IAAI,kBAAkB,CAAC,QAAQ,CAAC,CACvC,OAAO,CAAE,IAAI,oBAAoB,CAAC,EAAE,CAAC,AACzC,CAAC,AAED,+BAAgB,CAAC,oBAAK,uBAAuB,AAAC,CAAC,AAC3C,KAAK,CAAE,IAAI,kBAAkB,CAAC,QAAQ,CAAC,CACvC,OAAO,CAAE,IAAI,oBAAoB,CAAC,EAAE,CAAC,AACzC,CAAC,AAED,+BAAgB,CAAC,oBAAK,aAAa,AAAC,CAAC,AACjC,KAAK,CAAE,IAAI,kBAAkB,CAAC,QAAQ,CAAC,CACvC,OAAO,CAAE,IAAI,oBAAoB,CAAC,EAAE,CAAC,AACzC,CAAC,AAED,+BAAgB,CAAC,oBAAK,MAAM,AAAC,CAAC,AAC1B,OAAO,CAAE,IAAI,AACjB,CAAC,AAED,8CAAgB,MAAM,AAAC,CAAC,AACpB,YAAY,CAAE,IAAI,kBAAkB,CAAC,QAAQ,CAAC,AAClD,CAAC,AAED,gBAAgB,QAAQ,8BAAC,CAAC,AACtB,YAAY,CAAE,IAAI,kBAAkB,CAAC,QAAQ,CAAC,AAClD,CAAC,AAED,gBAAgB,SAAS,8BAAC,CAAC,AACvB,UAAU,CAAE,IAAI,oBAAoB,CAAC,QAAQ,CAAC,CAC9C,YAAY,CAAE,IAAI,qBAAqB,CAAC,QAAQ,CAAC,CACjD,KAAK,CAAE,IAAI,eAAe,CAAC,QAAQ,CAAC,AACxC,CAAC,AAED,gBAAgB,wBAAS,CAAC,oBAAK,2BAA2B,AAAC,CAAC,AACxD,KAAK,CAAE,IAAI,0BAA0B,CAAC,QAAQ,CAAC,CAC/C,OAAO,CAAE,IAAI,4BAA4B,CAAC,EAAE,CAAC,AACjD,CAAC,AAED,gBAAgB,wBAAS,CAAC,oBAAK,kBAAkB,AAAC,CAAC,AAC/C,KAAK,CAAE,IAAI,0BAA0B,CAAC,QAAQ,CAAC,CAC/C,OAAO,CAAE,IAAI,4BAA4B,CAAC,EAAE,CAAC,AACjD,CAAC,AAED,gBAAgB,wBAAS,CAAC,oBAAK,sBAAsB,AAAC,CAAC,AACnD,KAAK,CAAE,IAAI,0BAA0B,CAAC,QAAQ,CAAC,CAC/C,OAAO,CAAE,IAAI,4BAA4B,CAAC,EAAE,CAAC,AACjD,CAAC,AAED,gBAAgB,wBAAS,CAAC,oBAAK,uBAAuB,AAAC,CAAC,AACpD,KAAK,CAAE,IAAI,0BAA0B,CAAC,QAAQ,CAAC,CAC/C,OAAO,CAAE,IAAI,4BAA4B,CAAC,EAAE,CAAC,AACjD,CAAC,AAED,gBAAgB,wBAAS,CAAC,oBAAK,aAAa,AAAC,CAAC,AAC1C,KAAK,CAAE,IAAI,0BAA0B,CAAC,QAAQ,CAAC,CAC/C,OAAO,CAAE,IAAI,4BAA4B,CAAC,EAAE,CAAC,AACjD,CAAC,AAED,aAAa,8BAAC,CAAC,AACX,WAAW,CAAE,IAAI,QAAQ,CAAC,KAAK,CAAC,CAChC,MAAM,CAAE,IAAI,QAAQ,CAAC,KAAK,CAAC,CAC3B,UAAU,CAAE,MAAM,CAClB,OAAO,CAAE,IAAI,qBAAqB,CAAC,WAAW,CAAC,AACnD,CAAC,AAED,2CAAa,MAAM,AAAC,CAAC,AACjB,OAAO,CAAE,IAAI,AACjB,CAAC,AAED,YAAY,8BAAC,CAAC,AACV,QAAQ,CAAE,QAAQ,CAClB,KAAK,CAAE,IAAI,kBAAkB,CAAC,KAAK,CAAC,CACpC,GAAG,CAAE,IAAI,gBAAgB,CAAC,KAAK,CAAC,CAChC,MAAM,CAAE,IAAI,mBAAmB,CAAC,KAAK,CAAC,CACtC,KAAK,CAAE,IAAI,kBAAkB,CAAC,KAAK,CAAC,CACpC,KAAK,CAAE,IAAI,kBAAkB,CAAC,QAAQ,CAAC,CACvC,YAAY,CAAE,IAAI,CAAC,UAAU,CACrB,IAAI,CAAE,IAAI,CAAC,UAAU,AACjC,CAAC,AAED,0CAAY,MAAM,AAAC,CAAC,AAChB,KAAK,CAAE,IAAI,uBAAuB,CAAC,QAAQ,CAAC,AAChD,CAAC,AAED,gBAAgB,uBAAQ,CAAC,YAAY,eAAC,CAAC,AACnC,KAAK,CAAE,IAAI,uBAAuB,CAAC,QAAQ,CAAC,AAChD,CAAC,AAED,UAAU,8BAAC,CAAC,AACR,QAAQ,CAAE,QAAQ,CAClB,KAAK,CAAE,IAAI,gBAAgB,CAAC,KAAK,CAAC,CAClC,GAAG,CAAE,IAAI,cAAc,CAAC,KAAK,CAAC,CAC9B,KAAK,CAAE,IAAI,gBAAgB,CAAC,KAAK,CAAC,CAClC,MAAM,CAAE,IAAI,iBAAiB,CAAC,KAAK,CAAC,CACpC,KAAK,CAAE,IAAI,gBAAgB,CAAC,QAAQ,CAAC,AACzC,CAAC,AAED,yBAAU,CAAC,GAAG,eAAC,CAAC,AACZ,OAAO,CAAE,YAAY,CACrB,IAAI,CAAE,IAAI,eAAe,CAAC,aAAa,CAAC,CACxC,WAAW,CAAE,CAAC,CACd,MAAM,CAAE,IAAI,iBAAiB,CAAC,aAAa,CAAC,CAC5C,YAAY,CAAE,CAAC,AACnB,CAAC,AAED,QAAQ,8BAAC,CAAC,AACN,QAAQ,CAAE,QAAQ,CAClB,KAAK,CAAE,IAAI,cAAc,CAAC,KAAK,CAAC,CAChC,GAAG,CAAE,IAAI,aAAa,CAAC,KAAK,CAAC,CAC7B,KAAK,CAAE,IAAI,cAAc,CAAC,KAAK,CAAC,CAChC,MAAM,CAAE,IAAI,eAAe,CAAC,KAAK,CAAC,CAClC,KAAK,CAAE,IAAI,cAAc,CAAC,QAAQ,CAAC,CACnC,iBAAiB,CAAE,qBAAM,CAAC,KAAK,CAAC,MAAM,CAAC,QAAQ,CACvC,SAAS,CAAE,qBAAM,CAAC,KAAK,CAAC,MAAM,CAAC,QAAQ,AACnD,CAAC,AAED,aAAa,8BAAC,CAAC,AACX,OAAO,CAAE,KAAK,CACd,MAAM,CAAE,IAAI,CACZ,wBAAwB,CAAE,MAAM,CAAC,MAAM,CAC/B,gBAAgB,CAAE,MAAM,CAAC,MAAM,CACvC,KAAK,CAAE,IAAI,CACX,QAAQ,CAAE,QAAQ,CAClB,GAAG,CAAE,CAAC,CACN,MAAM,CAAE,CAAC,CACT,IAAI,CAAE,CAAC,CACP,KAAK,CAAE,CAAC,CACR,MAAM,CAAE,IAAI,CACZ,iBAAiB,CAAE,IAAI,AAC3B,CAAC,AAED,aAAa,8BAAC,CAAC,AACX,gBAAgB,CAAE,EAAE,CACpB,cAAc,CAAE,KAAK,AACzB,CAAC,AAED,YAAY,8BAAC,CAAC,AACV,OAAO,CAAE,YAAY,CACrB,OAAO,CAAE,IAAI,CACb,OAAO,CAAE,IAAI,oBAAoB,CAAC,cAAc,CAAC,CACjD,MAAM,CAAE,IAAI,CACZ,iBAAiB,CAAE,IAAI,CACf,SAAS,CAAE,IAAI,CACvB,mBAAmB,CAAE,OAAO,CACpB,WAAW,CAAE,OAAO,AAChC,CAAC,AAED,2BAAY,CAAG,eAAE,CAAC,AACd,YAAY,CAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CACd,IAAI,CAAE,CAAC,CAAC,CAAC,CAAC,IAAI,AAC1B,CAAC,AAED,gBAAgB,2BAAY,CAAC,KAAK,eAAC,CAAC,AAChC,OAAO,CAAE,IAAI,yBAAyB,CAAC,EAAE,CAAC,CAC1C,QAAQ,CAAE,QAAQ,CAClB,MAAM,CAAE,IAAI,wBAAwB,CAAC,EAAE,CAAC,AAC5C,CAAC,AAED,SAAS,8BAAC,CAAC,AACP,MAAM,CAAE,IAAI,aAAa,CAAC,kBAAkB,CAAC,CAC7C,UAAU,CAAE,IAAI,iBAAiB,CAAC,KAAK,CAAC,AAC5C,CAAC,AAED,SAAS,8BAAC,CAAC,AACP,OAAO,CAAE,IAAI,CACb,MAAM,CAAE,GAAG,CACX,IAAI,CAAE,KAAK,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAC9B,MAAM,CAAE,GAAG,CACX,KAAK,CAAE,GAAG,CACV,QAAQ,CAAE,QAAQ,CAClB,QAAQ,CAAE,MAAM,CAChB,OAAO,CAAE,GAAG,CACZ,WAAW,CAAE,MAAM,AACvB,CAAC,AAED,mBAAmB,qBAAO,CAAC,AACvB,IAAI,AAAC,CAAC,AACF,iBAAiB,CAAE,OAAO,MAAM,CAAC,CACzB,SAAS,CAAE,OAAO,MAAM,CAAC,AACrC,CAAC,AACL,CAAC,AAED,WAAW,qBAAO,CAAC,AACf,IAAI,AAAC,CAAC,AACF,iBAAiB,CAAE,OAAO,MAAM,CAAC,CACzB,SAAS,CAAE,OAAO,MAAM,CAAC,AACrC,CAAC,AACL,CAAC"} */.item.svelte-ybdqo9{cursor:default;height:var(--height, 42px);line-height:var(--height, 42px);padding:var(--itemPadding, 0 20px);color:var(--itemColor, inherit);text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.groupHeader.svelte-ybdqo9{text-transform:var(--groupTitleTextTransform, uppercase)}.groupItem.svelte-ybdqo9{padding-left:var(--groupItemPaddingLeft, 40px)}.item.svelte-ybdqo9:active{background:var(--itemActiveBackground, #b9daff)}.item.active.svelte-ybdqo9{background:var(--itemIsActiveBG, #007aff);color:var(--itemIsActiveColor, #fff)}.item.notSelectable.svelte-ybdqo9{color:var(--itemIsNotSelectableColor, #999)}.item.first.svelte-ybdqo9{border-radius:var(--itemFirstBorderRadius, 4px 4px 0 0)}.item.hover.svelte-ybdqo9:not(.active){background:var(--itemHoverBG, #e7f2ff);color:var(--itemHoverColor, inherit)}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSXRlbS5zdmVsdGUiLCJzb3VyY2VzIjpbIkl0ZW0uc3ZlbHRlIl0sInNvdXJjZXNDb250ZW50IjpbIjxzY3JpcHQ+XG4gICAgZXhwb3J0IGxldCBpc0FjdGl2ZSA9IGZhbHNlO1xuICAgIGV4cG9ydCBsZXQgaXNGaXJzdCA9IGZhbHNlO1xuICAgIGV4cG9ydCBsZXQgaXNIb3ZlciA9IGZhbHNlO1xuICAgIGV4cG9ydCBsZXQgaXNTZWxlY3RhYmxlID0gZmFsc2U7XG4gICAgZXhwb3J0IGxldCBnZXRPcHRpb25MYWJlbCA9IHVuZGVmaW5lZDtcbiAgICBleHBvcnQgbGV0IGl0ZW0gPSB1bmRlZmluZWQ7XG4gICAgZXhwb3J0IGxldCBmaWx0ZXJUZXh0ID0gJyc7XG5cbiAgICBsZXQgaXRlbUNsYXNzZXMgPSAnJztcblxuICAgICQ6IHtcbiAgICAgICAgY29uc3QgY2xhc3NlcyA9IFtdO1xuICAgICAgICBpZiAoaXNBY3RpdmUpIHtcbiAgICAgICAgICAgIGNsYXNzZXMucHVzaCgnYWN0aXZlJyk7XG4gICAgICAgIH1cbiAgICAgICAgaWYgKGlzRmlyc3QpIHtcbiAgICAgICAgICAgIGNsYXNzZXMucHVzaCgnZmlyc3QnKTtcbiAgICAgICAgfVxuICAgICAgICBpZiAoaXNIb3Zlcikge1xuICAgICAgICAgICAgY2xhc3Nlcy5wdXNoKCdob3ZlcicpO1xuICAgICAgICB9XG4gICAgICAgIGlmIChpdGVtLmlzR3JvdXBIZWFkZXIpIHtcbiAgICAgICAgICAgIGNsYXNzZXMucHVzaCgnZ3JvdXBIZWFkZXInKTtcbiAgICAgICAgfVxuICAgICAgICBpZiAoaXRlbS5pc0dyb3VwSXRlbSkge1xuICAgICAgICAgICAgY2xhc3Nlcy5wdXNoKCdncm91cEl0ZW0nKTtcbiAgICAgICAgfVxuICAgICAgICBpZiAoIWlzU2VsZWN0YWJsZSkge1xuICAgICAgICAgICAgY2xhc3Nlcy5wdXNoKCdub3RTZWxlY3RhYmxlJyk7XG4gICAgICAgIH1cbiAgICAgICAgaXRlbUNsYXNzZXMgPSBjbGFzc2VzLmpvaW4oJyAnKTtcbiAgICB9XG48L3NjcmlwdD5cblxuPHN0eWxlPlxuICAgIC5pdGVtIHtcbiAgICAgICAgY3Vyc29yOiBkZWZhdWx0O1xuICAgICAgICBoZWlnaHQ6IHZhcigtLWhlaWdodCwgNDJweCk7XG4gICAgICAgIGxpbmUtaGVpZ2h0OiB2YXIoLS1oZWlnaHQsIDQycHgpO1xuICAgICAgICBwYWRkaW5nOiB2YXIoLS1pdGVtUGFkZGluZywgMCAyMHB4KTtcbiAgICAgICAgY29sb3I6IHZhcigtLWl0ZW1Db2xvciwgaW5oZXJpdCk7XG4gICAgICAgIHRleHQtb3ZlcmZsb3c6IGVsbGlwc2lzO1xuICAgICAgICBvdmVyZmxvdzogaGlkZGVuO1xuICAgICAgICB3aGl0ZS1zcGFjZTogbm93cmFwO1xuICAgIH1cblxuICAgIC5ncm91cEhlYWRlciB7XG4gICAgICAgIHRleHQtdHJhbnNmb3JtOiB2YXIoLS1ncm91cFRpdGxlVGV4dFRyYW5zZm9ybSwgdXBwZXJjYXNlKTtcbiAgICB9XG5cbiAgICAuZ3JvdXBJdGVtIHtcbiAgICAgICAgcGFkZGluZy1sZWZ0OiB2YXIoLS1ncm91cEl0ZW1QYWRkaW5nTGVmdCwgNDBweCk7XG4gICAgfVxuXG4gICAgLml0ZW06YWN0aXZlIHtcbiAgICAgICAgYmFja2dyb3VuZDogdmFyKC0taXRlbUFjdGl2ZUJhY2tncm91bmQsICNiOWRhZmYpO1xuICAgIH1cblxuICAgIC5pdGVtLmFjdGl2ZSB7XG4gICAgICAgIGJhY2tncm91bmQ6IHZhcigtLWl0ZW1Jc0FjdGl2ZUJHLCAjMDA3YWZmKTtcbiAgICAgICAgY29sb3I6IHZhcigtLWl0ZW1Jc0FjdGl2ZUNvbG9yLCAjZmZmKTtcbiAgICB9XG5cbiAgIC5pdGVtLm5vdFNlbGVjdGFibGUge1xuICAgICAgICBjb2xvcjogdmFyKC0taXRlbUlzTm90U2VsZWN0YWJsZUNvbG9yLCAjOTk5KTtcbiAgICB9XG5cbiAgICAuaXRlbS5maXJzdCB7XG4gICAgICAgIGJvcmRlci1yYWRpdXM6IHZhcigtLWl0ZW1GaXJzdEJvcmRlclJhZGl1cywgNHB4IDRweCAwIDApO1xuICAgIH1cblxuICAgIC5pdGVtLmhvdmVyOm5vdCguYWN0aXZlKSB7XG4gICAgICAgIGJhY2tncm91bmQ6IHZhcigtLWl0ZW1Ib3ZlckJHLCAjZTdmMmZmKTtcbiAgICAgICAgY29sb3I6IHZhcigtLWl0ZW1Ib3ZlckNvbG9yLCBpbmhlcml0KTtcbiAgICB9PC9zdHlsZT5cblxuPGRpdiBjbGFzcz1cIml0ZW0ge2l0ZW1DbGFzc2VzfVwiPlxuICAgIHtAaHRtbCBnZXRPcHRpb25MYWJlbChpdGVtLCBmaWx0ZXJUZXh0KX1cbjwvZGl2PlxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW9DSSxLQUFLLGNBQUMsQ0FBQyxBQUNILE1BQU0sQ0FBRSxPQUFPLENBQ2YsTUFBTSxDQUFFLElBQUksUUFBUSxDQUFDLEtBQUssQ0FBQyxDQUMzQixXQUFXLENBQUUsSUFBSSxRQUFRLENBQUMsS0FBSyxDQUFDLENBQ2hDLE9BQU8sQ0FBRSxJQUFJLGFBQWEsQ0FBQyxPQUFPLENBQUMsQ0FDbkMsS0FBSyxDQUFFLElBQUksV0FBVyxDQUFDLFFBQVEsQ0FBQyxDQUNoQyxhQUFhLENBQUUsUUFBUSxDQUN2QixRQUFRLENBQUUsTUFBTSxDQUNoQixXQUFXLENBQUUsTUFBTSxBQUN2QixDQUFDLEFBRUQsWUFBWSxjQUFDLENBQUMsQUFDVixjQUFjLENBQUUsSUFBSSx5QkFBeUIsQ0FBQyxVQUFVLENBQUMsQUFDN0QsQ0FBQyxBQUVELFVBQVUsY0FBQyxDQUFDLEFBQ1IsWUFBWSxDQUFFLElBQUksc0JBQXNCLENBQUMsS0FBSyxDQUFDLEFBQ25ELENBQUMsQUFFRCxtQkFBSyxPQUFPLEFBQUMsQ0FBQyxBQUNWLFVBQVUsQ0FBRSxJQUFJLHNCQUFzQixDQUFDLFFBQVEsQ0FBQyxBQUNwRCxDQUFDLEFBRUQsS0FBSyxPQUFPLGNBQUMsQ0FBQyxBQUNWLFVBQVUsQ0FBRSxJQUFJLGdCQUFnQixDQUFDLFFBQVEsQ0FBQyxDQUMxQyxLQUFLLENBQUUsSUFBSSxtQkFBbUIsQ0FBQyxLQUFLLENBQUMsQUFDekMsQ0FBQyxBQUVGLEtBQUssY0FBYyxjQUFDLENBQUMsQUFDaEIsS0FBSyxDQUFFLElBQUksMEJBQTBCLENBQUMsS0FBSyxDQUFDLEFBQ2hELENBQUMsQUFFRCxLQUFLLE1BQU0sY0FBQyxDQUFDLEFBQ1QsYUFBYSxDQUFFLElBQUksdUJBQXVCLENBQUMsWUFBWSxDQUFDLEFBQzVELENBQUMsQUFFRCxLQUFLLG9CQUFNLEtBQUssT0FBTyxDQUFDLEFBQUMsQ0FBQyxBQUN0QixVQUFVLENBQUUsSUFBSSxhQUFhLENBQUMsUUFBUSxDQUFDLENBQ3ZDLEtBQUssQ0FBRSxJQUFJLGdCQUFnQixDQUFDLFFBQVEsQ0FBQyxBQUN6QyxDQUFDIn0= */.listContainer.svelte-1mmk1xt{box-shadow:var(--listShadow, 0 2px 3px 0 rgba(44, 62, 80, 0.24));border-radius:var(--listBorderRadius, 4px);max-height:var(--listMaxHeight, 250px);overflow-y:auto;background:var(--listBackground, #fff);border:var(--listBorder, none);position:var(--listPosition, absolute);z-index:var(--listZIndex, 2);width:100%;left:var(--listLeft, 0);right:var(--listRight, 0)}.virtualList.svelte-1mmk1xt{height:var(--virtualListHeight, 200px)}.listGroupTitle.svelte-1mmk1xt{color:var(--groupTitleColor, #8f8f8f);cursor:default;font-size:var(--groupTitleFontSize, 12px);font-weight:var(--groupTitleFontWeight, 600);height:var(--height, 42px);line-height:var(--height, 42px);padding:var(--groupTitlePadding, 0 20px);text-overflow:ellipsis;overflow-x:hidden;white-space:nowrap;text-transform:var(--groupTitleTextTransform, uppercase)}.empty.svelte-1mmk1xt{text-align:var(--listEmptyTextAlign, center);padding:var(--listEmptyPadding, 20px 0);color:var(--listEmptyColor, #78848f)}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"List.svelte","sources":["List.svelte"],"sourcesContent":["<script>\n    import { beforeUpdate, createEventDispatcher, onMount, tick } from 'svelte';\n    import isOutOfViewport from './utils/isOutOfViewport';\n    import ItemComponent from './Item.svelte';\n\n    const dispatch = createEventDispatcher();\n\n    export let container = undefined;\n    export let VirtualList = null;\n    export let Item = ItemComponent;\n    export let isVirtualList = false;\n    export let items = [];\n    export let labelIdentifier = 'label';\n    export let getOptionLabel = (option, filterText) => {\n        if (option)\n            return option.isCreator\n                ? `Create \\\"${filterText}\\\"`\n                : option[labelIdentifier];\n    };\n    export let getGroupHeaderLabel = null;\n    export let itemHeight = 40;\n    export let hoverItemIndex = 0;\n    export let value = undefined;\n    export let optionIdentifier = 'value';\n    export let hideEmptyState = false;\n    export let noOptionsMessage = 'No options';\n    export let isMulti = false;\n    export let activeItemIndex = 0;\n    export let filterText = '';\n    export let parent = null;\n    export let listPlacement = null;\n    export let listAutoWidth = null;\n    export let listOffset = 5;\n\n    let isScrollingTimer = 0;\n    let isScrolling = false;\n    let prev_items;\n\n    onMount(() => {\n        if (items.length > 0 && !isMulti && value) {\n            const _hoverItemIndex = items.findIndex(\n                (item) => item[optionIdentifier] === value[optionIdentifier]\n            );\n\n            if (_hoverItemIndex) {\n                hoverItemIndex = _hoverItemIndex;\n            }\n        }\n\n        scrollToActiveItem('active');\n\n        container.addEventListener(\n            'scroll',\n            () => {\n                clearTimeout(isScrollingTimer);\n\n                isScrollingTimer = setTimeout(() => {\n                    isScrolling = false;\n                }, 100);\n            },\n            false\n        );\n    });\n\n    beforeUpdate(() => {\n        if (!items) items = [];\n        if (items !== prev_items && items.length > 0) {\n            hoverItemIndex = 0;\n        }\n\n        prev_items = items;\n    });\n\n    function handleSelect(item) {\n        if (item.isCreator) return;\n        dispatch('itemSelected', item);\n    }\n\n    function handleHover(i) {\n        if (isScrolling) return;\n        hoverItemIndex = i;\n    }\n\n    function handleClick(args) {\n        const { item, i, event } = args;\n        event.stopPropagation();\n\n        if (\n            value &&\n            !isMulti &&\n            value[optionIdentifier] === item[optionIdentifier]\n        )\n            return closeList();\n\n        if (item.isCreator) {\n            dispatch('itemCreated', filterText);\n        } else if (isItemSelectable(item)) {\n            activeItemIndex = i;\n            hoverItemIndex = i;\n            handleSelect(item);\n        }\n    }\n\n    function closeList() {\n        dispatch('closeList');\n    }\n\n    async function updateHoverItem(increment) {\n        if (isVirtualList) return;\n\n        let isNonSelectableItem = true;\n\n        while (isNonSelectableItem) {\n            if (increment > 0 && hoverItemIndex === items.length - 1) {\n                hoverItemIndex = 0;\n            } else if (increment < 0 && hoverItemIndex === 0) {\n                hoverItemIndex = items.length - 1;\n            } else {\n                hoverItemIndex = hoverItemIndex + increment;\n            }\n\n            isNonSelectableItem = !isItemSelectable(items[hoverItemIndex]);\n        }\n\n        await tick();\n\n        scrollToActiveItem('hover');\n    }\n\n    function handleKeyDown(e) {\n        switch (e.key) {\n            case 'Escape':\n                e.preventDefault();\n                closeList();\n                break;\n            case 'ArrowDown':\n                e.preventDefault();\n                items.length && updateHoverItem(1);\n                break;\n            case 'ArrowUp':\n                e.preventDefault();\n                items.length && updateHoverItem(-1);\n                break;\n            case 'Enter':\n                e.preventDefault();\n                if (items.length === 0) break;\n                const hoverItem = items[hoverItemIndex];\n                if (\n                    value &&\n                    !isMulti &&\n                    value[optionIdentifier] === hoverItem[optionIdentifier]\n                ) {\n                    closeList();\n                    break;\n                }\n                if (hoverItem.isCreator) {\n                    dispatch('itemCreated', filterText);\n                } else {\n                    activeItemIndex = hoverItemIndex;\n                    handleSelect(items[hoverItemIndex]);\n                }\n                break;\n            case 'Tab':\n                e.preventDefault();\n                if (items.length === 0) {\n                    return closeList();\n                }\n                if (\n                    value &&\n                    value[optionIdentifier] ===\n                        items[hoverItemIndex][optionIdentifier]\n                )\n                    return closeList();\n                activeItemIndex = hoverItemIndex;\n                handleSelect(items[hoverItemIndex]);\n                break;\n        }\n    }\n\n    function scrollToActiveItem(className) {\n        if (isVirtualList || !container) return;\n\n        let offsetBounding;\n        const focusedElemBounding = container.querySelector(\n            `.listItem .${className}`\n        );\n\n        if (focusedElemBounding) {\n            offsetBounding =\n                container.getBoundingClientRect().bottom -\n                focusedElemBounding.getBoundingClientRect().bottom;\n        }\n\n        container.scrollTop -= offsetBounding;\n    }\n\n    function isItemActive(item, value, optionIdentifier) {\n        return value && value[optionIdentifier] === item[optionIdentifier];\n    }\n\n    function isItemFirst(itemIndex) {\n        return itemIndex === 0;\n    }\n\n    function isItemHover(hoverItemIndex, item, itemIndex, items) {\n        return isItemSelectable(item) && (hoverItemIndex === itemIndex || items.length === 1);\n    }\n\n    function isItemSelectable(item) {\n        return (item.isGroupHeader && item.isSelectable) ||\n            item.selectable ||\n            !item.hasOwnProperty('selectable') // Default; if `selectable` was not specified, the object is selectable\n    }\n\n    let listStyle;\n    function computePlacement() {\n        const { top, height, width } = parent.getBoundingClientRect();\n\n        listStyle = '';\n        listStyle += `min-width:${width}px;width:${\n            listAutoWidth ? 'auto' : '100%'\n        };`;\n\n        if (\n            listPlacement === 'top' ||\n            (listPlacement === 'auto' && isOutOfViewport(parent).bottom)\n        ) {\n            listStyle += `bottom:${height + listOffset}px;`;\n        } else {\n            listStyle += `top:${height + listOffset}px;`;\n        }\n    }\n\n    $: {\n        if (parent && container) computePlacement();\n    }\n</script>\n\n<style>\n    .listContainer {\n        box-shadow: var(--listShadow, 0 2px 3px 0 rgba(44, 62, 80, 0.24));\n        border-radius: var(--listBorderRadius, 4px);\n        max-height: var(--listMaxHeight, 250px);\n        overflow-y: auto;\n        background: var(--listBackground, #fff);\n        border: var(--listBorder, none);\n        position: var(--listPosition, absolute);\n        z-index: var(--listZIndex, 2);\n        width: 100%;\n        left: var(--listLeft, 0);\n        right: var(--listRight, 0);\n    }\n\n    .virtualList {\n        height: var(--virtualListHeight, 200px);\n    }\n\n    .listGroupTitle {\n        color: var(--groupTitleColor, #8f8f8f);\n        cursor: default;\n        font-size: var(--groupTitleFontSize, 12px);\n        font-weight: var(--groupTitleFontWeight, 600);\n        height: var(--height, 42px);\n        line-height: var(--height, 42px);\n        padding: var(--groupTitlePadding, 0 20px);\n        text-overflow: ellipsis;\n        overflow-x: hidden;\n        white-space: nowrap;\n        text-transform: var(--groupTitleTextTransform, uppercase);\n    }\n\n    .empty {\n        text-align: var(--listEmptyTextAlign, center);\n        padding: var(--listEmptyPadding, 20px 0);\n        color: var(--listEmptyColor, #78848f);\n    }</style>\n\n<svelte:window on:keydown={handleKeyDown} on:resize={computePlacement} />\n\n<div\n    class=\"listContainer\"\n    class:virtualList={isVirtualList}\n    bind:this={container}\n    style={listStyle}>\n    {#if isVirtualList}\n        <svelte:component\n            this={VirtualList}\n            {items}\n            {itemHeight}\n            let:item\n            let:i>\n            <div\n                on:mouseover={() => handleHover(i)}\n                on:focus={() => handleHover(i)}\n                on:click={(event) => handleClick({ item, i, event })}\n                class=\"listItem\">\n                <svelte:component\n                    this={Item}\n                    {item}\n                    {filterText}\n                    {getOptionLabel}\n                    isFirst={isItemFirst(i)}\n                    isActive={isItemActive(item, value, optionIdentifier)}\n                    isHover={isItemHover(hoverItemIndex, item, i, items)}\n                    isSelectable={isItemSelectable(item)} />\n            </div>\n        </svelte:component>\n    {:else}\n        {#each items as item, i}\n            {#if item.isGroupHeader && !item.isSelectable}\n                <div class=\"listGroupTitle\">{getGroupHeaderLabel(item)}</div>\n            {:else}\n                <div\n                    on:mouseover={() => handleHover(i)}\n                    on:focus={() => handleHover(i)}\n                    on:click={(event) => handleClick({ item, i, event })}\n                    class=\"listItem\"\n                    tabindex=\"-1\">\n                    <svelte:component\n                        this={Item}\n                        {item}\n                        {filterText}\n                        {getOptionLabel}\n                        isFirst={isItemFirst(i)}\n                        isActive={isItemActive(item, value, optionIdentifier)}\n                        isHover={isItemHover(hoverItemIndex, item, i, items)}\n                        isSelectable={isItemSelectable(item)} />\n                </div>\n            {/if}\n        {:else}\n            {#if !hideEmptyState}\n                <div class=\"empty\">{noOptionsMessage}</div>\n            {/if}\n        {/each}\n    {/if}\n</div>\n"],"names":[],"mappings":"AA+OI,cAAc,eAAC,CAAC,AACZ,UAAU,CAAE,IAAI,YAAY,CAAC,mCAAmC,CAAC,CACjE,aAAa,CAAE,IAAI,kBAAkB,CAAC,IAAI,CAAC,CAC3C,UAAU,CAAE,IAAI,eAAe,CAAC,MAAM,CAAC,CACvC,UAAU,CAAE,IAAI,CAChB,UAAU,CAAE,IAAI,gBAAgB,CAAC,KAAK,CAAC,CACvC,MAAM,CAAE,IAAI,YAAY,CAAC,KAAK,CAAC,CAC/B,QAAQ,CAAE,IAAI,cAAc,CAAC,SAAS,CAAC,CACvC,OAAO,CAAE,IAAI,YAAY,CAAC,EAAE,CAAC,CAC7B,KAAK,CAAE,IAAI,CACX,IAAI,CAAE,IAAI,UAAU,CAAC,EAAE,CAAC,CACxB,KAAK,CAAE,IAAI,WAAW,CAAC,EAAE,CAAC,AAC9B,CAAC,AAED,YAAY,eAAC,CAAC,AACV,MAAM,CAAE,IAAI,mBAAmB,CAAC,MAAM,CAAC,AAC3C,CAAC,AAED,eAAe,eAAC,CAAC,AACb,KAAK,CAAE,IAAI,iBAAiB,CAAC,QAAQ,CAAC,CACtC,MAAM,CAAE,OAAO,CACf,SAAS,CAAE,IAAI,oBAAoB,CAAC,KAAK,CAAC,CAC1C,WAAW,CAAE,IAAI,sBAAsB,CAAC,IAAI,CAAC,CAC7C,MAAM,CAAE,IAAI,QAAQ,CAAC,KAAK,CAAC,CAC3B,WAAW,CAAE,IAAI,QAAQ,CAAC,KAAK,CAAC,CAChC,OAAO,CAAE,IAAI,mBAAmB,CAAC,OAAO,CAAC,CACzC,aAAa,CAAE,QAAQ,CACvB,UAAU,CAAE,MAAM,CAClB,WAAW,CAAE,MAAM,CACnB,cAAc,CAAE,IAAI,yBAAyB,CAAC,UAAU,CAAC,AAC7D,CAAC,AAED,MAAM,eAAC,CAAC,AACJ,UAAU,CAAE,IAAI,oBAAoB,CAAC,OAAO,CAAC,CAC7C,OAAO,CAAE,IAAI,kBAAkB,CAAC,OAAO,CAAC,CACxC,KAAK,CAAE,IAAI,gBAAgB,CAAC,QAAQ,CAAC,AACzC,CAAC"} */.selection.svelte-1be6cx3{text-overflow:ellipsis;overflow-x:hidden;white-space:nowrap}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU2VsZWN0aW9uLnN2ZWx0ZSIsInNvdXJjZXMiOlsiU2VsZWN0aW9uLnN2ZWx0ZSJdLCJzb3VyY2VzQ29udGVudCI6WyI8c2NyaXB0PlxuICAgIGV4cG9ydCBsZXQgZ2V0U2VsZWN0aW9uTGFiZWwgPSB1bmRlZmluZWQ7XG4gICAgZXhwb3J0IGxldCBpdGVtID0gdW5kZWZpbmVkO1xuPC9zY3JpcHQ+XG5cbjxzdHlsZT5cbiAgICAuc2VsZWN0aW9uIHtcbiAgICAgICAgdGV4dC1vdmVyZmxvdzogZWxsaXBzaXM7XG4gICAgICAgIG92ZXJmbG93LXg6IGhpZGRlbjtcbiAgICAgICAgd2hpdGUtc3BhY2U6IG5vd3JhcDtcbiAgICB9PC9zdHlsZT5cblxuPGRpdiBjbGFzcz1cInNlbGVjdGlvblwiPlxuICAgIHtAaHRtbCBnZXRTZWxlY3Rpb25MYWJlbChpdGVtKX1cbjwvZGl2PlxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQU1JLFVBQVUsZUFBQyxDQUFDLEFBQ1IsYUFBYSxDQUFFLFFBQVEsQ0FDdkIsVUFBVSxDQUFFLE1BQU0sQ0FDbEIsV0FBVyxDQUFFLE1BQU0sQUFDdkIsQ0FBQyJ9 */svelte-virtual-list-viewport.svelte-yyenik{position:relative;overflow-y:auto;-webkit-overflow-scrolling:touch;display:block}svelte-virtual-list-contents.svelte-yyenik,svelte-virtual-list-row.svelte-yyenik{display:block}svelte-virtual-list-row.svelte-yyenik{overflow:hidden}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVmlydHVhbExpc3Quc3ZlbHRlIiwic291cmNlcyI6WyJWaXJ0dWFsTGlzdC5zdmVsdGUiXSwic291cmNlc0NvbnRlbnQiOlsiPHNjcmlwdD5cbiAgICBpbXBvcnQgeyBvbk1vdW50LCB0aWNrIH0gZnJvbSAnc3ZlbHRlJztcblxuICAgIGV4cG9ydCBsZXQgaXRlbXMgPSB1bmRlZmluZWQ7XG4gICAgZXhwb3J0IGxldCBoZWlnaHQgPSAnMTAwJSc7XG4gICAgZXhwb3J0IGxldCBpdGVtSGVpZ2h0ID0gNDA7XG4gICAgZXhwb3J0IGxldCBob3Zlckl0ZW1JbmRleCA9IDA7XG4gICAgZXhwb3J0IGxldCBzdGFydCA9IDA7XG4gICAgZXhwb3J0IGxldCBlbmQgPSAwO1xuXG4gICAgbGV0IGhlaWdodF9tYXAgPSBbXTtcbiAgICBsZXQgcm93cztcbiAgICBsZXQgdmlld3BvcnQ7XG4gICAgbGV0IGNvbnRlbnRzO1xuICAgIGxldCB2aWV3cG9ydF9oZWlnaHQgPSAwO1xuICAgIGxldCB2aXNpYmxlO1xuICAgIGxldCBtb3VudGVkO1xuXG4gICAgbGV0IHRvcCA9IDA7XG4gICAgbGV0IGJvdHRvbSA9IDA7XG4gICAgbGV0IGF2ZXJhZ2VfaGVpZ2h0O1xuXG4gICAgJDogdmlzaWJsZSA9IGl0ZW1zLnNsaWNlKHN0YXJ0LCBlbmQpLm1hcCgoZGF0YSwgaSkgPT4ge1xuICAgICAgICByZXR1cm4geyBpbmRleDogaSArIHN0YXJ0LCBkYXRhIH07XG4gICAgfSk7XG5cbiAgICAkOiBpZiAobW91bnRlZCkgcmVmcmVzaChpdGVtcywgdmlld3BvcnRfaGVpZ2h0LCBpdGVtSGVpZ2h0KTtcblxuICAgIGFzeW5jIGZ1bmN0aW9uIHJlZnJlc2goaXRlbXMsIHZpZXdwb3J0X2hlaWdodCwgaXRlbUhlaWdodCkge1xuICAgICAgICBjb25zdCB7IHNjcm9sbFRvcCB9ID0gdmlld3BvcnQ7XG5cbiAgICAgICAgYXdhaXQgdGljaygpO1xuXG4gICAgICAgIGxldCBjb250ZW50X2hlaWdodCA9IHRvcCAtIHNjcm9sbFRvcDtcbiAgICAgICAgbGV0IGkgPSBzdGFydDtcblxuICAgICAgICB3aGlsZSAoY29udGVudF9oZWlnaHQgPCB2aWV3cG9ydF9oZWlnaHQgJiYgaSA8IGl0ZW1zLmxlbmd0aCkge1xuICAgICAgICAgICAgbGV0IHJvdyA9IHJvd3NbaSAtIHN0YXJ0XTtcblxuICAgICAgICAgICAgaWYgKCFyb3cpIHtcbiAgICAgICAgICAgICAgICBlbmQgPSBpICsgMTtcbiAgICAgICAgICAgICAgICBhd2FpdCB0aWNrKCk7XG4gICAgICAgICAgICAgICAgcm93ID0gcm93c1tpIC0gc3RhcnRdO1xuICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICBjb25zdCByb3dfaGVpZ2h0ID0gKGhlaWdodF9tYXBbaV0gPSBpdGVtSGVpZ2h0IHx8IHJvdy5vZmZzZXRIZWlnaHQpO1xuICAgICAgICAgICAgY29udGVudF9oZWlnaHQgKz0gcm93X2hlaWdodDtcbiAgICAgICAgICAgIGkgKz0gMTtcbiAgICAgICAgfVxuXG4gICAgICAgIGVuZCA9IGk7XG5cbiAgICAgICAgY29uc3QgcmVtYWluaW5nID0gaXRlbXMubGVuZ3RoIC0gZW5kO1xuICAgICAgICBhdmVyYWdlX2hlaWdodCA9ICh0b3AgKyBjb250ZW50X2hlaWdodCkgLyBlbmQ7XG5cbiAgICAgICAgYm90dG9tID0gcmVtYWluaW5nICogYXZlcmFnZV9oZWlnaHQ7XG4gICAgICAgIGhlaWdodF9tYXAubGVuZ3RoID0gaXRlbXMubGVuZ3RoO1xuXG4gICAgICAgIGlmICh2aWV3cG9ydCkgdmlld3BvcnQuc2Nyb2xsVG9wID0gMDtcbiAgICB9XG5cbiAgICBhc3luYyBmdW5jdGlvbiBoYW5kbGVfc2Nyb2xsKCkge1xuICAgICAgICBjb25zdCB7IHNjcm9sbFRvcCB9ID0gdmlld3BvcnQ7XG5cbiAgICAgICAgY29uc3Qgb2xkX3N0YXJ0ID0gc3RhcnQ7XG5cbiAgICAgICAgZm9yIChsZXQgdiA9IDA7IHYgPCByb3dzLmxlbmd0aDsgdiArPSAxKSB7XG4gICAgICAgICAgICBoZWlnaHRfbWFwW3N0YXJ0ICsgdl0gPSBpdGVtSGVpZ2h0IHx8IHJvd3Nbdl0ub2Zmc2V0SGVpZ2h0O1xuICAgICAgICB9XG5cbiAgICAgICAgbGV0IGkgPSAwO1xuICAgICAgICBsZXQgeSA9IDA7XG5cbiAgICAgICAgd2hpbGUgKGkgPCBpdGVtcy5sZW5ndGgpIHtcbiAgICAgICAgICAgIGNvbnN0IHJvd19oZWlnaHQgPSBoZWlnaHRfbWFwW2ldIHx8IGF2ZXJhZ2VfaGVpZ2h0O1xuICAgICAgICAgICAgaWYgKHkgKyByb3dfaGVpZ2h0ID4gc2Nyb2xsVG9wKSB7XG4gICAgICAgICAgICAgICAgc3RhcnQgPSBpO1xuICAgICAgICAgICAgICAgIHRvcCA9IHk7XG5cbiAgICAgICAgICAgICAgICBicmVhaztcbiAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgeSArPSByb3dfaGVpZ2h0O1xuICAgICAgICAgICAgaSArPSAxO1xuICAgICAgICB9XG5cbiAgICAgICAgd2hpbGUgKGkgPCBpdGVtcy5sZW5ndGgpIHtcbiAgICAgICAgICAgIHkgKz0gaGVpZ2h0X21hcFtpXSB8fCBhdmVyYWdlX2hlaWdodDtcbiAgICAgICAgICAgIGkgKz0gMTtcblxuICAgICAgICAgICAgaWYgKHkgPiBzY3JvbGxUb3AgKyB2aWV3cG9ydF9oZWlnaHQpIGJyZWFrO1xuICAgICAgICB9XG5cbiAgICAgICAgZW5kID0gaTtcblxuICAgICAgICBjb25zdCByZW1haW5pbmcgPSBpdGVtcy5sZW5ndGggLSBlbmQ7XG4gICAgICAgIGF2ZXJhZ2VfaGVpZ2h0ID0geSAvIGVuZDtcblxuICAgICAgICB3aGlsZSAoaSA8IGl0ZW1zLmxlbmd0aCkgaGVpZ2h0X21hcFtpKytdID0gYXZlcmFnZV9oZWlnaHQ7XG4gICAgICAgIGJvdHRvbSA9IHJlbWFpbmluZyAqIGF2ZXJhZ2VfaGVpZ2h0O1xuXG4gICAgICAgIGlmIChzdGFydCA8IG9sZF9zdGFydCkge1xuICAgICAgICAgICAgYXdhaXQgdGljaygpO1xuXG4gICAgICAgICAgICBsZXQgZXhwZWN0ZWRfaGVpZ2h0ID0gMDtcbiAgICAgICAgICAgIGxldCBhY3R1YWxfaGVpZ2h0ID0gMDtcblxuICAgICAgICAgICAgZm9yIChsZXQgaSA9IHN0YXJ0OyBpIDwgb2xkX3N0YXJ0OyBpICs9IDEpIHtcbiAgICAgICAgICAgICAgICBpZiAocm93c1tpIC0gc3RhcnRdKSB7XG4gICAgICAgICAgICAgICAgICAgIGV4cGVjdGVkX2hlaWdodCArPSBoZWlnaHRfbWFwW2ldO1xuICAgICAgICAgICAgICAgICAgICBhY3R1YWxfaGVpZ2h0ICs9IGl0ZW1IZWlnaHQgfHwgcm93c1tpIC0gc3RhcnRdLm9mZnNldEhlaWdodDtcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG5cbiAgICAgICAgICAgIGNvbnN0IGQgPSBhY3R1YWxfaGVpZ2h0IC0gZXhwZWN0ZWRfaGVpZ2h0O1xuICAgICAgICAgICAgdmlld3BvcnQuc2Nyb2xsVG8oMCwgc2Nyb2xsVG9wICsgZCk7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBvbk1vdW50KCgpID0+IHtcbiAgICAgICAgcm93cyA9IGNvbnRlbnRzLmdldEVsZW1lbnRzQnlUYWdOYW1lKCdzdmVsdGUtdmlydHVhbC1saXN0LXJvdycpO1xuICAgICAgICBtb3VudGVkID0gdHJ1ZTtcbiAgICB9KTtcbjwvc2NyaXB0PlxuXG48c3R5bGU+XG4gICAgc3ZlbHRlLXZpcnR1YWwtbGlzdC12aWV3cG9ydCB7XG4gICAgICAgIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgICAgICAgb3ZlcmZsb3cteTogYXV0bztcbiAgICAgICAgLXdlYmtpdC1vdmVyZmxvdy1zY3JvbGxpbmc6IHRvdWNoO1xuICAgICAgICBkaXNwbGF5OiBibG9jaztcbiAgICB9XG5cbiAgICBzdmVsdGUtdmlydHVhbC1saXN0LWNvbnRlbnRzLFxuICAgIHN2ZWx0ZS12aXJ0dWFsLWxpc3Qtcm93IHtcbiAgICAgICAgZGlzcGxheTogYmxvY2s7XG4gICAgfVxuXG4gICAgc3ZlbHRlLXZpcnR1YWwtbGlzdC1yb3cge1xuICAgICAgICBvdmVyZmxvdzogaGlkZGVuO1xuICAgIH08L3N0eWxlPlxuXG48c3ZlbHRlLXZpcnR1YWwtbGlzdC12aWV3cG9ydFxuICAgIGJpbmQ6dGhpcz17dmlld3BvcnR9XG4gICAgYmluZDpvZmZzZXRIZWlnaHQ9e3ZpZXdwb3J0X2hlaWdodH1cbiAgICBvbjpzY3JvbGw9e2hhbmRsZV9zY3JvbGx9XG4gICAgc3R5bGU9XCJoZWlnaHQ6IHtoZWlnaHR9O1wiPlxuICAgIDxzdmVsdGUtdmlydHVhbC1saXN0LWNvbnRlbnRzXG4gICAgICAgIGJpbmQ6dGhpcz17Y29udGVudHN9XG4gICAgICAgIHN0eWxlPVwicGFkZGluZy10b3A6IHt0b3B9cHg7IHBhZGRpbmctYm90dG9tOiB7Ym90dG9tfXB4O1wiPlxuICAgICAgICB7I2VhY2ggdmlzaWJsZSBhcyByb3cgKHJvdy5pbmRleCl9XG4gICAgICAgICAgICA8c3ZlbHRlLXZpcnR1YWwtbGlzdC1yb3c+XG4gICAgICAgICAgICAgICAgPHNsb3QgaXRlbT17cm93LmRhdGF9IGk9e3Jvdy5pbmRleH0ge2hvdmVySXRlbUluZGV4fT5NaXNzaW5nIHRlbXBsYXRlPC9zbG90PlxuICAgICAgICAgICAgPC9zdmVsdGUtdmlydHVhbC1saXN0LXJvdz5cbiAgICAgICAgey9lYWNofVxuICAgIDwvc3ZlbHRlLXZpcnR1YWwtbGlzdC1jb250ZW50cz5cbjwvc3ZlbHRlLXZpcnR1YWwtbGlzdC12aWV3cG9ydD5cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE4SEksNEJBQTRCLGNBQUMsQ0FBQyxBQUMxQixRQUFRLENBQUUsUUFBUSxDQUNsQixVQUFVLENBQUUsSUFBSSxDQUNoQiwwQkFBMEIsQ0FBRSxLQUFLLENBQ2pDLE9BQU8sQ0FBRSxLQUFLLEFBQ2xCLENBQUMsQUFFRCwwQ0FBNEIsQ0FDNUIsdUJBQXVCLGNBQUMsQ0FBQyxBQUNyQixPQUFPLENBQUUsS0FBSyxBQUNsQixDQUFDLEFBRUQsdUJBQXVCLGNBQUMsQ0FBQyxBQUNyQixRQUFRLENBQUUsTUFBTSxBQUNwQixDQUFDIn0= */.multiSelectItem.svelte-fizndo.svelte-fizndo{background:var(--multiItemBG, #ebedef);margin:var(--multiItemMargin, 5px 5px 0 0);border-radius:var(--multiItemBorderRadius, 16px);height:var(--multiItemHeight, 32px);line-height:var(--multiItemHeight, 32px);display:-webkit-flex;display:flex;cursor:default;padding:var(--multiItemPadding, 0 10px 0 15px);max-width:100%}.multiSelectItem_label.svelte-fizndo.svelte-fizndo{margin:var(--multiLabelMargin, 0 5px 0 0);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.multiSelectItem.svelte-fizndo.svelte-fizndo:hover,.multiSelectItem.active.svelte-fizndo.svelte-fizndo{background-color:var(--multiItemActiveBG, #006fff);color:var(--multiItemActiveColor, #fff)}.multiSelectItem.disabled.svelte-fizndo.svelte-fizndo:hover{background:var(--multiItemDisabledHoverBg, #ebedef);color:var(--multiItemDisabledHoverColor, #c1c6cc)}.multiSelectItem_clear.svelte-fizndo.svelte-fizndo{border-radius:var(--multiClearRadius, 50%);background:var(--multiClearBG, #52616f);min-width:var(--multiClearWidth, 16px);max-width:var(--multiClearWidth, 16px);height:var(--multiClearHeight, 16px);position:relative;top:var(--multiClearTop, 8px);text-align:var(--multiClearTextAlign, center);padding:var(--multiClearPadding, 1px)}.multiSelectItem_clear.svelte-fizndo.svelte-fizndo:hover,.active.svelte-fizndo .multiSelectItem_clear.svelte-fizndo{background:var(--multiClearHoverBG, #fff)}.multiSelectItem_clear.svelte-fizndo:hover svg.svelte-fizndo,.active.svelte-fizndo .multiSelectItem_clear svg.svelte-fizndo{fill:var(--multiClearHoverFill, #006fff)}.multiSelectItem_clear.svelte-fizndo svg.svelte-fizndo{fill:var(--multiClearFill, #ebedef);vertical-align:top}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiTXVsdGlTZWxlY3Rpb24uc3ZlbHRlIiwic291cmNlcyI6WyJNdWx0aVNlbGVjdGlvbi5zdmVsdGUiXSwic291cmNlc0NvbnRlbnQiOlsiPHNjcmlwdD5cbiAgICBpbXBvcnQgeyBjcmVhdGVFdmVudERpc3BhdGNoZXIgfSBmcm9tICdzdmVsdGUnO1xuXG4gICAgY29uc3QgZGlzcGF0Y2ggPSBjcmVhdGVFdmVudERpc3BhdGNoZXIoKTtcblxuICAgIGV4cG9ydCBsZXQgdmFsdWUgPSBbXTtcbiAgICBleHBvcnQgbGV0IGFjdGl2ZVZhbHVlID0gdW5kZWZpbmVkO1xuICAgIGV4cG9ydCBsZXQgaXNEaXNhYmxlZCA9IGZhbHNlO1xuICAgIGV4cG9ydCBsZXQgbXVsdGlGdWxsSXRlbUNsZWFyYWJsZSA9IGZhbHNlO1xuICAgIGV4cG9ydCBsZXQgZ2V0U2VsZWN0aW9uTGFiZWwgPSB1bmRlZmluZWQ7XG5cbiAgICBmdW5jdGlvbiBoYW5kbGVDbGVhcihpLCBldmVudCkge1xuICAgICAgICBldmVudC5zdG9wUHJvcGFnYXRpb24oKTtcbiAgICAgICAgZGlzcGF0Y2goJ211bHRpSXRlbUNsZWFyJywgeyBpIH0pO1xuICAgIH1cbjwvc2NyaXB0PlxuXG48c3R5bGU+XG4gICAgLm11bHRpU2VsZWN0SXRlbSB7XG4gICAgICAgIGJhY2tncm91bmQ6IHZhcigtLW11bHRpSXRlbUJHLCAjZWJlZGVmKTtcbiAgICAgICAgbWFyZ2luOiB2YXIoLS1tdWx0aUl0ZW1NYXJnaW4sIDVweCA1cHggMCAwKTtcbiAgICAgICAgYm9yZGVyLXJhZGl1czogdmFyKC0tbXVsdGlJdGVtQm9yZGVyUmFkaXVzLCAxNnB4KTtcbiAgICAgICAgaGVpZ2h0OiB2YXIoLS1tdWx0aUl0ZW1IZWlnaHQsIDMycHgpO1xuICAgICAgICBsaW5lLWhlaWdodDogdmFyKC0tbXVsdGlJdGVtSGVpZ2h0LCAzMnB4KTtcbiAgICAgICAgZGlzcGxheTogLXdlYmtpdC1mbGV4O1xuICAgICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgICBjdXJzb3I6IGRlZmF1bHQ7XG4gICAgICAgIHBhZGRpbmc6IHZhcigtLW11bHRpSXRlbVBhZGRpbmcsIDAgMTBweCAwIDE1cHgpO1xuICAgICAgICBtYXgtd2lkdGg6IDEwMCU7XG4gICAgfVxuXG4gICAgLm11bHRpU2VsZWN0SXRlbV9sYWJlbCB7XG4gICAgICAgIG1hcmdpbjogdmFyKC0tbXVsdGlMYWJlbE1hcmdpbiwgMCA1cHggMCAwKTtcbiAgICAgICAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgICAgICAgdGV4dC1vdmVyZmxvdzogZWxsaXBzaXM7XG4gICAgICAgIHdoaXRlLXNwYWNlOiBub3dyYXA7XG4gICAgfVxuXG4gICAgLm11bHRpU2VsZWN0SXRlbTpob3ZlcixcbiAgICAubXVsdGlTZWxlY3RJdGVtLmFjdGl2ZSB7XG4gICAgICAgIGJhY2tncm91bmQtY29sb3I6IHZhcigtLW11bHRpSXRlbUFjdGl2ZUJHLCAjMDA2ZmZmKTtcbiAgICAgICAgY29sb3I6IHZhcigtLW11bHRpSXRlbUFjdGl2ZUNvbG9yLCAjZmZmKTtcbiAgICB9XG5cbiAgICAubXVsdGlTZWxlY3RJdGVtLmRpc2FibGVkOmhvdmVyIHtcbiAgICAgICAgYmFja2dyb3VuZDogdmFyKC0tbXVsdGlJdGVtRGlzYWJsZWRIb3ZlckJnLCAjZWJlZGVmKTtcbiAgICAgICAgY29sb3I6IHZhcigtLW11bHRpSXRlbURpc2FibGVkSG92ZXJDb2xvciwgI2MxYzZjYyk7XG4gICAgfVxuXG4gICAgLm11bHRpU2VsZWN0SXRlbV9jbGVhciB7XG4gICAgICAgIGJvcmRlci1yYWRpdXM6IHZhcigtLW11bHRpQ2xlYXJSYWRpdXMsIDUwJSk7XG4gICAgICAgIGJhY2tncm91bmQ6IHZhcigtLW11bHRpQ2xlYXJCRywgIzUyNjE2Zik7XG4gICAgICAgIG1pbi13aWR0aDogdmFyKC0tbXVsdGlDbGVhcldpZHRoLCAxNnB4KTtcbiAgICAgICAgbWF4LXdpZHRoOiB2YXIoLS1tdWx0aUNsZWFyV2lkdGgsIDE2cHgpO1xuICAgICAgICBoZWlnaHQ6IHZhcigtLW11bHRpQ2xlYXJIZWlnaHQsIDE2cHgpO1xuICAgICAgICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gICAgICAgIHRvcDogdmFyKC0tbXVsdGlDbGVhclRvcCwgOHB4KTtcbiAgICAgICAgdGV4dC1hbGlnbjogdmFyKC0tbXVsdGlDbGVhclRleHRBbGlnbiwgY2VudGVyKTtcbiAgICAgICAgcGFkZGluZzogdmFyKC0tbXVsdGlDbGVhclBhZGRpbmcsIDFweCk7XG4gICAgfVxuXG4gICAgLm11bHRpU2VsZWN0SXRlbV9jbGVhcjpob3ZlcixcbiAgICAuYWN0aXZlIC5tdWx0aVNlbGVjdEl0ZW1fY2xlYXIge1xuICAgICAgICBiYWNrZ3JvdW5kOiB2YXIoLS1tdWx0aUNsZWFySG92ZXJCRywgI2ZmZik7XG4gICAgfVxuXG4gICAgLm11bHRpU2VsZWN0SXRlbV9jbGVhcjpob3ZlciBzdmcsXG4gICAgLmFjdGl2ZSAubXVsdGlTZWxlY3RJdGVtX2NsZWFyIHN2ZyB7XG4gICAgICAgIGZpbGw6IHZhcigtLW11bHRpQ2xlYXJIb3ZlckZpbGwsICMwMDZmZmYpO1xuICAgIH1cblxuICAgIC5tdWx0aVNlbGVjdEl0ZW1fY2xlYXIgc3ZnIHtcbiAgICAgICAgZmlsbDogdmFyKC0tbXVsdGlDbGVhckZpbGwsICNlYmVkZWYpO1xuICAgICAgICB2ZXJ0aWNhbC1hbGlnbjogdG9wO1xuICAgIH08L3N0eWxlPlxuXG57I2VhY2ggdmFsdWUgYXMgaXRlbSwgaX1cbiAgICA8ZGl2XG4gICAgICAgIGNsYXNzPVwibXVsdGlTZWxlY3RJdGVtIHthY3RpdmVWYWx1ZSA9PT0gaSA/ICdhY3RpdmUnIDogJyd9IHtpc0Rpc2FibGVkXG4gICAgICAgICAgICA/ICdkaXNhYmxlZCdcbiAgICAgICAgICAgIDogJyd9XCJcbiAgICAgICAgb246Y2xpY2s9eyhldmVudCkgPT5cbiAgICAgICAgICAgIG11bHRpRnVsbEl0ZW1DbGVhcmFibGUgPyBoYW5kbGVDbGVhcihpLCBldmVudCkgOiB7fX0+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJtdWx0aVNlbGVjdEl0ZW1fbGFiZWxcIj5cbiAgICAgICAgICAgIHtAaHRtbCBnZXRTZWxlY3Rpb25MYWJlbChpdGVtKX1cbiAgICAgICAgPC9kaXY+XG4gICAgICAgIHsjaWYgIWlzRGlzYWJsZWQgJiYgIW11bHRpRnVsbEl0ZW1DbGVhcmFibGV9XG4gICAgICAgICAgICA8ZGl2XG4gICAgICAgICAgICAgICAgY2xhc3M9XCJtdWx0aVNlbGVjdEl0ZW1fY2xlYXJcIlxuICAgICAgICAgICAgICAgIG9uOmNsaWNrPXsoZXZlbnQpID0+IGhhbmRsZUNsZWFyKGksIGV2ZW50KX0+XG4gICAgICAgICAgICAgICAgPHN2Z1xuICAgICAgICAgICAgICAgICAgICB3aWR0aD1cIjEwMCVcIlxuICAgICAgICAgICAgICAgICAgICBoZWlnaHQ9XCIxMDAlXCJcbiAgICAgICAgICAgICAgICAgICAgdmlld0JveD1cIi0yIC0yIDUwIDUwXCJcbiAgICAgICAgICAgICAgICAgICAgZm9jdXNhYmxlPVwiZmFsc2VcIlxuICAgICAgICAgICAgICAgICAgICBhcmlhLWhpZGRlbj1cInRydWVcIlxuICAgICAgICAgICAgICAgICAgICByb2xlPVwicHJlc2VudGF0aW9uXCI+XG4gICAgICAgICAgICAgICAgICAgIDxwYXRoXG4gICAgICAgICAgICAgICAgICAgICAgICBkPVwiTTM0LjkyMywzNy4yNTFMMjQsMjYuMzI4TDEzLjA3NywzNy4yNTFMOS40MzYsMzMuNjFsMTAuOTIzLTEwLjkyM0w5LjQzNiwxMS43NjVsMy42NDEtMy42NDFMMjQsMTkuMDQ3TDM0LjkyMyw4LjEyNCBsMy42NDEsMy42NDFMMjcuNjQxLDIyLjY4OEwzOC41NjQsMzMuNjFMMzQuOTIzLDM3LjI1MXpcIiAvPlxuICAgICAgICAgICAgICAgIDwvc3ZnPlxuICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgIHsvaWZ9XG4gICAgPC9kaXY+XG57L2VhY2h9XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBa0JJLGdCQUFnQiw0QkFBQyxDQUFDLEFBQ2QsVUFBVSxDQUFFLElBQUksYUFBYSxDQUFDLFFBQVEsQ0FBQyxDQUN2QyxNQUFNLENBQUUsSUFBSSxpQkFBaUIsQ0FBQyxZQUFZLENBQUMsQ0FDM0MsYUFBYSxDQUFFLElBQUksdUJBQXVCLENBQUMsS0FBSyxDQUFDLENBQ2pELE1BQU0sQ0FBRSxJQUFJLGlCQUFpQixDQUFDLEtBQUssQ0FBQyxDQUNwQyxXQUFXLENBQUUsSUFBSSxpQkFBaUIsQ0FBQyxLQUFLLENBQUMsQ0FDekMsT0FBTyxDQUFFLFlBQVksQ0FDckIsT0FBTyxDQUFFLElBQUksQ0FDYixNQUFNLENBQUUsT0FBTyxDQUNmLE9BQU8sQ0FBRSxJQUFJLGtCQUFrQixDQUFDLGNBQWMsQ0FBQyxDQUMvQyxTQUFTLENBQUUsSUFBSSxBQUNuQixDQUFDLEFBRUQsc0JBQXNCLDRCQUFDLENBQUMsQUFDcEIsTUFBTSxDQUFFLElBQUksa0JBQWtCLENBQUMsVUFBVSxDQUFDLENBQzFDLFFBQVEsQ0FBRSxNQUFNLENBQ2hCLGFBQWEsQ0FBRSxRQUFRLENBQ3ZCLFdBQVcsQ0FBRSxNQUFNLEFBQ3ZCLENBQUMsQUFFRCw0Q0FBZ0IsTUFBTSxDQUN0QixnQkFBZ0IsT0FBTyw0QkFBQyxDQUFDLEFBQ3JCLGdCQUFnQixDQUFFLElBQUksbUJBQW1CLENBQUMsUUFBUSxDQUFDLENBQ25ELEtBQUssQ0FBRSxJQUFJLHNCQUFzQixDQUFDLEtBQUssQ0FBQyxBQUM1QyxDQUFDLEFBRUQsZ0JBQWdCLHFDQUFTLE1BQU0sQUFBQyxDQUFDLEFBQzdCLFVBQVUsQ0FBRSxJQUFJLDBCQUEwQixDQUFDLFFBQVEsQ0FBQyxDQUNwRCxLQUFLLENBQUUsSUFBSSw2QkFBNkIsQ0FBQyxRQUFRLENBQUMsQUFDdEQsQ0FBQyxBQUVELHNCQUFzQiw0QkFBQyxDQUFDLEFBQ3BCLGFBQWEsQ0FBRSxJQUFJLGtCQUFrQixDQUFDLElBQUksQ0FBQyxDQUMzQyxVQUFVLENBQUUsSUFBSSxjQUFjLENBQUMsUUFBUSxDQUFDLENBQ3hDLFNBQVMsQ0FBRSxJQUFJLGlCQUFpQixDQUFDLEtBQUssQ0FBQyxDQUN2QyxTQUFTLENBQUUsSUFBSSxpQkFBaUIsQ0FBQyxLQUFLLENBQUMsQ0FDdkMsTUFBTSxDQUFFLElBQUksa0JBQWtCLENBQUMsS0FBSyxDQUFDLENBQ3JDLFFBQVEsQ0FBRSxRQUFRLENBQ2xCLEdBQUcsQ0FBRSxJQUFJLGVBQWUsQ0FBQyxJQUFJLENBQUMsQ0FDOUIsVUFBVSxDQUFFLElBQUkscUJBQXFCLENBQUMsT0FBTyxDQUFDLENBQzlDLE9BQU8sQ0FBRSxJQUFJLG1CQUFtQixDQUFDLElBQUksQ0FBQyxBQUMxQyxDQUFDLEFBRUQsa0RBQXNCLE1BQU0sQ0FDNUIscUJBQU8sQ0FBQyxzQkFBc0IsY0FBQyxDQUFDLEFBQzVCLFVBQVUsQ0FBRSxJQUFJLG1CQUFtQixDQUFDLEtBQUssQ0FBQyxBQUM5QyxDQUFDLEFBRUQsb0NBQXNCLE1BQU0sQ0FBQyxpQkFBRyxDQUNoQyxxQkFBTyxDQUFDLHNCQUFzQixDQUFDLEdBQUcsY0FBQyxDQUFDLEFBQ2hDLElBQUksQ0FBRSxJQUFJLHFCQUFxQixDQUFDLFFBQVEsQ0FBQyxBQUM3QyxDQUFDLEFBRUQsb0NBQXNCLENBQUMsR0FBRyxjQUFDLENBQUMsQUFDeEIsSUFBSSxDQUFFLElBQUksZ0JBQWdCLENBQUMsUUFBUSxDQUFDLENBQ3BDLGNBQWMsQ0FBRSxHQUFHLEFBQ3ZCLENBQUMifQ== */