@apptane/react-ui-charts
Version:
Chart components in Apptane React UI framework
246 lines (230 loc) • 32.8 kB
JavaScript
import _defineProperty from "@babel/runtime/helpers/defineProperty";
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
import { css } from "@emotion/react";
import { useCallback, useContext, useRef, useState } from "react";
import { ChartDatumContext } from "../parts/ChartDatumContext.js";
import { ChartEmptyBlock } from "../parts/ChartEmptyBlock.js";
import { ChartHeader } from "../parts/ChartHeader.js";
import { ChartLegend } from "../parts/ChartLegend.js";
import { ChartSliceContext } from "../parts/ChartSliceContext.js";
import { XYChartOverlay } from "./XYChartOverlay.js";
import { XYChartTooltip } from "./XYChartTooltip.js";
import { jsx as _jsx } from "@emotion/react/jsx-runtime";
import { jsxs as _jsxs } from "@emotion/react/jsx-runtime";
const StyleContainer = process.env.NODE_ENV === "production" ? {
name: "1mw8zfs",
styles: "position:relative;overflow:visible"
} : {
name: "198iflq-StyleContainer",
styles: "position:relative;overflow:visible;label:StyleContainer;",
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/xy/XYChartPane.tsx"],"names":[],"mappings":"AAa0B","file":"../../src/xy/XYChartPane.tsx","sourcesContent":["import { AnimationStyle } from \"@apptane/react-ui-core\";\nimport { css } from \"@emotion/react\";\nimport { useCallback, useContext, useRef, useState } from \"react\";\nimport { Datum, DomainXValue, DomainYValue } from \"../common/Types.js\";\nimport { ChartDatumContext } from \"../parts/ChartDatumContext.js\";\nimport { ChartEmptyBlock } from \"../parts/ChartEmptyBlock.js\";\nimport { ChartHeader } from \"../parts/ChartHeader.js\";\nimport { ChartLegend } from \"../parts/ChartLegend.js\";\nimport { ChartSliceContext } from \"../parts/ChartSliceContext.js\";\nimport { XYChartDatum, XYChartPanePropsBase, XYChartPanePropsBaseEx } from \"./XYChart.types.js\";\nimport { XYChartOverlay } from \"./XYChartOverlay.js\";\nimport { XYChartTooltip } from \"./XYChartTooltip.js\";\n\nconst StyleContainer = css`\n  position: relative;\n  overflow: visible;\n`;\n\nconst StyleTooltip = (animation: AnimationStyle) => css`\n  > div {\n    transition-delay: ${animation.delay}ms;\n    transition-duration: ${animation.duration}ms;\n    transition-timing-function: ${animation.function};\n    position: absolute;\n  }\n\n  // prevents tooltip from triggering onMouseLeave\n  pointer-events: none;\n  position: absolute;\n`;\n\nconst getRelativePosition = (node: Element, event: React.MouseEvent) => {\n  const { clientX, clientY } = event;\n  const box = node.getBoundingClientRect();\n  return [clientX - box.left, clientY - box.top];\n};\n\nexport function XYChartPane<X extends DomainXValue, Y extends DomainYValue, Data = void>({\n  children,\n  componentId,\n  theme,\n  colorMode,\n  height,\n  width,\n  computed,\n  findDatum,\n  setSlice,\n  scaleX,\n  scaleY,\n  invertX,\n  invertY,\n  computedDomainX,\n  computedDomainY,\n  formatXTooltip,\n  formatYTooltip,\n  formatTooltipValue,\n  header,\n  headerHeight,\n  extentX,\n  extentY,\n  axisYWidth,\n  axisXTitle,\n  axisYTitle,\n  tooltipVisible,\n  tooltipTotalVisible,\n  tooltipOffset,\n  emptyText,\n  legendVisible,\n  legendInteractive,\n  defs,\n  overlays,\n  background,\n}: React.PropsWithChildren<XYChartPanePropsBase<X, Y, Data> & XYChartPanePropsBaseEx<X, Y, Data>>) {\n  const visualAppearance = theme.charts.xy.appearance(theme.palette[colorMode], colorMode, undefined, \"none\");\n\n  const slice = useContext(ChartSliceContext);\n  const [currentDatumId, setCurrentDatumId] = useState<string | undefined>();\n  const selectMetric = useCallback((datum: Datum<Data>) => setCurrentDatumId(datum.id), []);\n  const deselectMetric = useCallback(() => setCurrentDatumId(undefined), []);\n\n  const legend =\n    computed != null && legendVisible ? (\n      <ChartLegend<XYChartDatum<X, Y, Data>, Data>\n        theme={theme}\n        colorMode={colorMode}\n        data={computed}\n        selectedDatumId={legendInteractive ? currentDatumId : undefined}\n        onMouseEnter={legendInteractive ? selectMetric : undefined}\n        onMouseLeave={legendInteractive ? deselectMetric : undefined}\n        onClick={legendInteractive ? selectMetric : undefined}\n      />\n    ) : undefined;\n\n  const trackerRef = useRef<SVGRectElement>(null);\n\n  const onMouseMove = useCallback(\n    (e: React.MouseEvent) => {\n      if (trackerRef.current) {\n        const [x, y] = getRelativePosition(trackerRef.current, e);\n        const rx = Math.round(x);\n        const ry = Math.round(y);\n\n        const dx = invertX(rx);\n        const dy = invertY != null ? invertY(ry) : undefined;\n\n        const [nx, ix] = computedDomainX?.findNearest(dx) ?? [undefined, undefined];\n        const [ny, iy] = computedDomainY?.findNearest(dy) ?? [undefined, undefined];\n\n        // locate nearest series\n        let datumId: string | undefined;\n        if (computed != null && findDatum != null) {\n          const datum = findDatum(rx, ry, computed, computedDomainX, computedDomainY, nx, ny, ix, iy);\n          datumId = datum?.id;\n        }\n\n        function formatLabel(nx: X | undefined, ny: Y | undefined) {\n          const parts: string[] = [];\n          if (nx != null) {\n            const s = formatXTooltip != null ? formatXTooltip(nx) : nx.toLocaleString();\n            parts.push(axisXTitle ? `${axisXTitle}: ${s}` : s);\n          }\n\n          if (ny != null) {\n            const s = formatYTooltip != null ? formatYTooltip(ny) : ny.toLocaleString();\n            parts.push(axisYTitle ? `${axisYTitle}: ${s}` : s);\n          }\n\n          return parts.join(\" • \");\n        }\n\n        setCurrentDatumId(datumId);\n        setSlice((prevSlice) =>\n          prevSlice?.domainXIndex === ix && prevSlice?.domainYIndex === iy\n            ? prevSlice\n            : nx == null && ny == null\n            ? undefined\n            : {\n                label: formatLabel(nx, ny),\n                x: nx != null ? scaleX(nx) : undefined,\n                y: ny != null && scaleY != null ? scaleY(ny) : undefined,\n                domainXIndex: ix,\n                domainYIndex: iy,\n              }\n        );\n      }\n    },\n    [\n      computed,\n      axisXTitle,\n      axisYTitle,\n      scaleX,\n      scaleY,\n      invertX,\n      invertY,\n      computedDomainX,\n      computedDomainY,\n      formatXTooltip,\n      formatYTooltip,\n      findDatum,\n      setSlice,\n    ]\n  );\n\n  const onMouseLeave = useCallback(() => {\n    setCurrentDatumId(undefined);\n    setSlice(undefined);\n  }, [setSlice]);\n\n  return (\n    <ChartDatumContext.Provider value={currentDatumId}>\n      <div css={StyleContainer} style={{ height: height }}>\n        <ChartHeader theme={theme} colorMode={colorMode} header={header} legend={legend} axisYTitle={axisYTitle} />\n        <svg xmlns=\"http://www.w3.org/2000/svg\" role=\"img\" height={extentY} width={width}>\n          <defs>\n            <filter x={0} y={0} width={1.2} height={1} id={`${componentId}-axis-label-back`}>\n              <feFlood floodColor={background ?? visualAppearance.back} result=\"bg\" />\n              <feMerge>\n                <feMergeNode in=\"bg\" />\n                <feMergeNode in=\"SourceGraphic\" />\n              </feMerge>\n            </filter>\n            <clipPath id={`${componentId}-main-clip`}>\n              <rect x={0} y={0} width={extentX} height={extentY} />\n            </clipPath>\n            {defs}\n          </defs>\n          {children}\n          <g transform={`translate(${axisYWidth},0)`} clipPath={`url(#${componentId}-main-clip)`}>\n            {overlays?.map((overlay, index) => (\n              <XYChartOverlay<X>\n                key={`_${overlay.id ?? index}`}\n                {...overlay}\n                theme={theme}\n                colorMode={colorMode}\n                scaleX={scaleX}\n                width={extentX}\n                height={extentY}\n              />\n            ))}\n          </g>\n          <rect\n            ref={trackerRef}\n            x={axisYWidth}\n            y={0}\n            width={extentX}\n            height={extentY}\n            opacity={0}\n            fill=\"red\"\n            onMouseMove={onMouseMove}\n            onMouseEnter={onMouseMove}\n            onMouseLeave={onMouseLeave}\n          />\n        </svg>\n        {tooltipVisible && slice && (\n          <div\n            css={StyleTooltip(theme.charts.xy.animation)}\n            style={{\n              left: axisYWidth,\n              top: headerHeight,\n              width: extentX,\n              height: extentY,\n            }}>\n            <XYChartTooltip<X, Y, Data>\n              theme={theme}\n              colorMode={colorMode}\n              slice={slice}\n              computed={computed}\n              domainX={computedDomainX}\n              domainY={computedDomainY}\n              format={formatTooltipValue}\n              tooltipTotalVisible={tooltipTotalVisible}\n              width={extentX}\n              offset={tooltipOffset}\n            />\n          </div>\n        )}\n        {(computed == null || computed.length == 0) && (\n          <ChartEmptyBlock\n            theme={theme}\n            colorMode={colorMode}\n            background={background}\n            width={extentX}\n            height={extentY}\n            position=\"absolute\"\n            top={headerHeight}\n            left={axisYWidth}>\n            {emptyText}\n          </ChartEmptyBlock>\n        )}\n      </div>\n    </ChartDatumContext.Provider>\n  );\n}\n"]} */",
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
};
const StyleTooltip = animation => /*#__PURE__*/css(">div{transition-delay:", animation.delay, "ms;transition-duration:", animation.duration, "ms;transition-timing-function:", animation.function, ";position:absolute;}pointer-events:none;position:absolute;" + (process.env.NODE_ENV === "production" ? "" : ";label:StyleTooltip;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/xy/XYChartPane.tsx"],"names":[],"mappings":"AAkBuD","file":"../../src/xy/XYChartPane.tsx","sourcesContent":["import { AnimationStyle } from \"@apptane/react-ui-core\";\nimport { css } from \"@emotion/react\";\nimport { useCallback, useContext, useRef, useState } from \"react\";\nimport { Datum, DomainXValue, DomainYValue } from \"../common/Types.js\";\nimport { ChartDatumContext } from \"../parts/ChartDatumContext.js\";\nimport { ChartEmptyBlock } from \"../parts/ChartEmptyBlock.js\";\nimport { ChartHeader } from \"../parts/ChartHeader.js\";\nimport { ChartLegend } from \"../parts/ChartLegend.js\";\nimport { ChartSliceContext } from \"../parts/ChartSliceContext.js\";\nimport { XYChartDatum, XYChartPanePropsBase, XYChartPanePropsBaseEx } from \"./XYChart.types.js\";\nimport { XYChartOverlay } from \"./XYChartOverlay.js\";\nimport { XYChartTooltip } from \"./XYChartTooltip.js\";\n\nconst StyleContainer = css`\n  position: relative;\n  overflow: visible;\n`;\n\nconst StyleTooltip = (animation: AnimationStyle) => css`\n  > div {\n    transition-delay: ${animation.delay}ms;\n    transition-duration: ${animation.duration}ms;\n    transition-timing-function: ${animation.function};\n    position: absolute;\n  }\n\n  // prevents tooltip from triggering onMouseLeave\n  pointer-events: none;\n  position: absolute;\n`;\n\nconst getRelativePosition = (node: Element, event: React.MouseEvent) => {\n  const { clientX, clientY } = event;\n  const box = node.getBoundingClientRect();\n  return [clientX - box.left, clientY - box.top];\n};\n\nexport function XYChartPane<X extends DomainXValue, Y extends DomainYValue, Data = void>({\n  children,\n  componentId,\n  theme,\n  colorMode,\n  height,\n  width,\n  computed,\n  findDatum,\n  setSlice,\n  scaleX,\n  scaleY,\n  invertX,\n  invertY,\n  computedDomainX,\n  computedDomainY,\n  formatXTooltip,\n  formatYTooltip,\n  formatTooltipValue,\n  header,\n  headerHeight,\n  extentX,\n  extentY,\n  axisYWidth,\n  axisXTitle,\n  axisYTitle,\n  tooltipVisible,\n  tooltipTotalVisible,\n  tooltipOffset,\n  emptyText,\n  legendVisible,\n  legendInteractive,\n  defs,\n  overlays,\n  background,\n}: React.PropsWithChildren<XYChartPanePropsBase<X, Y, Data> & XYChartPanePropsBaseEx<X, Y, Data>>) {\n  const visualAppearance = theme.charts.xy.appearance(theme.palette[colorMode], colorMode, undefined, \"none\");\n\n  const slice = useContext(ChartSliceContext);\n  const [currentDatumId, setCurrentDatumId] = useState<string | undefined>();\n  const selectMetric = useCallback((datum: Datum<Data>) => setCurrentDatumId(datum.id), []);\n  const deselectMetric = useCallback(() => setCurrentDatumId(undefined), []);\n\n  const legend =\n    computed != null && legendVisible ? (\n      <ChartLegend<XYChartDatum<X, Y, Data>, Data>\n        theme={theme}\n        colorMode={colorMode}\n        data={computed}\n        selectedDatumId={legendInteractive ? currentDatumId : undefined}\n        onMouseEnter={legendInteractive ? selectMetric : undefined}\n        onMouseLeave={legendInteractive ? deselectMetric : undefined}\n        onClick={legendInteractive ? selectMetric : undefined}\n      />\n    ) : undefined;\n\n  const trackerRef = useRef<SVGRectElement>(null);\n\n  const onMouseMove = useCallback(\n    (e: React.MouseEvent) => {\n      if (trackerRef.current) {\n        const [x, y] = getRelativePosition(trackerRef.current, e);\n        const rx = Math.round(x);\n        const ry = Math.round(y);\n\n        const dx = invertX(rx);\n        const dy = invertY != null ? invertY(ry) : undefined;\n\n        const [nx, ix] = computedDomainX?.findNearest(dx) ?? [undefined, undefined];\n        const [ny, iy] = computedDomainY?.findNearest(dy) ?? [undefined, undefined];\n\n        // locate nearest series\n        let datumId: string | undefined;\n        if (computed != null && findDatum != null) {\n          const datum = findDatum(rx, ry, computed, computedDomainX, computedDomainY, nx, ny, ix, iy);\n          datumId = datum?.id;\n        }\n\n        function formatLabel(nx: X | undefined, ny: Y | undefined) {\n          const parts: string[] = [];\n          if (nx != null) {\n            const s = formatXTooltip != null ? formatXTooltip(nx) : nx.toLocaleString();\n            parts.push(axisXTitle ? `${axisXTitle}: ${s}` : s);\n          }\n\n          if (ny != null) {\n            const s = formatYTooltip != null ? formatYTooltip(ny) : ny.toLocaleString();\n            parts.push(axisYTitle ? `${axisYTitle}: ${s}` : s);\n          }\n\n          return parts.join(\" • \");\n        }\n\n        setCurrentDatumId(datumId);\n        setSlice((prevSlice) =>\n          prevSlice?.domainXIndex === ix && prevSlice?.domainYIndex === iy\n            ? prevSlice\n            : nx == null && ny == null\n            ? undefined\n            : {\n                label: formatLabel(nx, ny),\n                x: nx != null ? scaleX(nx) : undefined,\n                y: ny != null && scaleY != null ? scaleY(ny) : undefined,\n                domainXIndex: ix,\n                domainYIndex: iy,\n              }\n        );\n      }\n    },\n    [\n      computed,\n      axisXTitle,\n      axisYTitle,\n      scaleX,\n      scaleY,\n      invertX,\n      invertY,\n      computedDomainX,\n      computedDomainY,\n      formatXTooltip,\n      formatYTooltip,\n      findDatum,\n      setSlice,\n    ]\n  );\n\n  const onMouseLeave = useCallback(() => {\n    setCurrentDatumId(undefined);\n    setSlice(undefined);\n  }, [setSlice]);\n\n  return (\n    <ChartDatumContext.Provider value={currentDatumId}>\n      <div css={StyleContainer} style={{ height: height }}>\n        <ChartHeader theme={theme} colorMode={colorMode} header={header} legend={legend} axisYTitle={axisYTitle} />\n        <svg xmlns=\"http://www.w3.org/2000/svg\" role=\"img\" height={extentY} width={width}>\n          <defs>\n            <filter x={0} y={0} width={1.2} height={1} id={`${componentId}-axis-label-back`}>\n              <feFlood floodColor={background ?? visualAppearance.back} result=\"bg\" />\n              <feMerge>\n                <feMergeNode in=\"bg\" />\n                <feMergeNode in=\"SourceGraphic\" />\n              </feMerge>\n            </filter>\n            <clipPath id={`${componentId}-main-clip`}>\n              <rect x={0} y={0} width={extentX} height={extentY} />\n            </clipPath>\n            {defs}\n          </defs>\n          {children}\n          <g transform={`translate(${axisYWidth},0)`} clipPath={`url(#${componentId}-main-clip)`}>\n            {overlays?.map((overlay, index) => (\n              <XYChartOverlay<X>\n                key={`_${overlay.id ?? index}`}\n                {...overlay}\n                theme={theme}\n                colorMode={colorMode}\n                scaleX={scaleX}\n                width={extentX}\n                height={extentY}\n              />\n            ))}\n          </g>\n          <rect\n            ref={trackerRef}\n            x={axisYWidth}\n            y={0}\n            width={extentX}\n            height={extentY}\n            opacity={0}\n            fill=\"red\"\n            onMouseMove={onMouseMove}\n            onMouseEnter={onMouseMove}\n            onMouseLeave={onMouseLeave}\n          />\n        </svg>\n        {tooltipVisible && slice && (\n          <div\n            css={StyleTooltip(theme.charts.xy.animation)}\n            style={{\n              left: axisYWidth,\n              top: headerHeight,\n              width: extentX,\n              height: extentY,\n            }}>\n            <XYChartTooltip<X, Y, Data>\n              theme={theme}\n              colorMode={colorMode}\n              slice={slice}\n              computed={computed}\n              domainX={computedDomainX}\n              domainY={computedDomainY}\n              format={formatTooltipValue}\n              tooltipTotalVisible={tooltipTotalVisible}\n              width={extentX}\n              offset={tooltipOffset}\n            />\n          </div>\n        )}\n        {(computed == null || computed.length == 0) && (\n          <ChartEmptyBlock\n            theme={theme}\n            colorMode={colorMode}\n            background={background}\n            width={extentX}\n            height={extentY}\n            position=\"absolute\"\n            top={headerHeight}\n            left={axisYWidth}>\n            {emptyText}\n          </ChartEmptyBlock>\n        )}\n      </div>\n    </ChartDatumContext.Provider>\n  );\n}\n"]} */");
const getRelativePosition = (node, event) => {
const {
clientX,
clientY
} = event;
const box = node.getBoundingClientRect();
return [clientX - box.left, clientY - box.top];
};
export function XYChartPane(_ref) {
let {
children,
componentId,
theme,
colorMode,
height,
width,
computed,
findDatum,
setSlice,
scaleX,
scaleY,
invertX,
invertY,
computedDomainX,
computedDomainY,
formatXTooltip,
formatYTooltip,
formatTooltipValue,
header,
headerHeight,
extentX,
extentY,
axisYWidth,
axisXTitle,
axisYTitle,
tooltipVisible,
tooltipTotalVisible,
tooltipOffset,
emptyText,
legendVisible,
legendInteractive,
defs,
overlays,
background
} = _ref;
const visualAppearance = theme.charts.xy.appearance(theme.palette[colorMode], colorMode, undefined, "none");
const slice = useContext(ChartSliceContext);
const [currentDatumId, setCurrentDatumId] = useState();
const selectMetric = useCallback(datum => setCurrentDatumId(datum.id), []);
const deselectMetric = useCallback(() => setCurrentDatumId(undefined), []);
const legend = computed != null && legendVisible ? _jsx(ChartLegend, {
theme: theme,
colorMode: colorMode,
data: computed,
selectedDatumId: legendInteractive ? currentDatumId : undefined,
onMouseEnter: legendInteractive ? selectMetric : undefined,
onMouseLeave: legendInteractive ? deselectMetric : undefined,
onClick: legendInteractive ? selectMetric : undefined
}) : undefined;
const trackerRef = useRef(null);
const onMouseMove = useCallback(e => {
if (trackerRef.current) {
var _computedDomainX$find, _computedDomainY$find;
const [x, y] = getRelativePosition(trackerRef.current, e);
const rx = Math.round(x);
const ry = Math.round(y);
const dx = invertX(rx);
const dy = invertY != null ? invertY(ry) : undefined;
const [nx, ix] = (_computedDomainX$find = computedDomainX === null || computedDomainX === void 0 ? void 0 : computedDomainX.findNearest(dx)) !== null && _computedDomainX$find !== void 0 ? _computedDomainX$find : [undefined, undefined];
const [ny, iy] = (_computedDomainY$find = computedDomainY === null || computedDomainY === void 0 ? void 0 : computedDomainY.findNearest(dy)) !== null && _computedDomainY$find !== void 0 ? _computedDomainY$find : [undefined, undefined]; // locate nearest series
let datumId;
if (computed != null && findDatum != null) {
const datum = findDatum(rx, ry, computed, computedDomainX, computedDomainY, nx, ny, ix, iy);
datumId = datum === null || datum === void 0 ? void 0 : datum.id;
}
function formatLabel(nx, ny) {
const parts = [];
if (nx != null) {
const s = formatXTooltip != null ? formatXTooltip(nx) : nx.toLocaleString();
parts.push(axisXTitle ? "".concat(axisXTitle, ": ").concat(s) : s);
}
if (ny != null) {
const s = formatYTooltip != null ? formatYTooltip(ny) : ny.toLocaleString();
parts.push(axisYTitle ? "".concat(axisYTitle, ": ").concat(s) : s);
}
return parts.join(" • ");
}
setCurrentDatumId(datumId);
setSlice(prevSlice => (prevSlice === null || prevSlice === void 0 ? void 0 : prevSlice.domainXIndex) === ix && (prevSlice === null || prevSlice === void 0 ? void 0 : prevSlice.domainYIndex) === iy ? prevSlice : nx == null && ny == null ? undefined : {
label: formatLabel(nx, ny),
x: nx != null ? scaleX(nx) : undefined,
y: ny != null && scaleY != null ? scaleY(ny) : undefined,
domainXIndex: ix,
domainYIndex: iy
});
}
}, [computed, axisXTitle, axisYTitle, scaleX, scaleY, invertX, invertY, computedDomainX, computedDomainY, formatXTooltip, formatYTooltip, findDatum, setSlice]);
const onMouseLeave = useCallback(() => {
setCurrentDatumId(undefined);
setSlice(undefined);
}, [setSlice]);
return _jsx(ChartDatumContext.Provider, {
value: currentDatumId,
children: _jsxs("div", {
css: StyleContainer,
style: {
height: height
},
children: [_jsx(ChartHeader, {
theme: theme,
colorMode: colorMode,
header: header,
legend: legend,
axisYTitle: axisYTitle
}), _jsxs("svg", {
xmlns: "http://www.w3.org/2000/svg",
role: "img",
height: extentY,
width: width,
children: [_jsxs("defs", {
children: [_jsxs("filter", {
x: 0,
y: 0,
width: 1.2,
height: 1,
id: "".concat(componentId, "-axis-label-back"),
children: [_jsx("feFlood", {
floodColor: background !== null && background !== void 0 ? background : visualAppearance.back,
result: "bg"
}), _jsxs("feMerge", {
children: [_jsx("feMergeNode", {
in: "bg"
}), _jsx("feMergeNode", {
in: "SourceGraphic"
})]
})]
}), _jsx("clipPath", {
id: "".concat(componentId, "-main-clip"),
children: _jsx("rect", {
x: 0,
y: 0,
width: extentX,
height: extentY
})
}), defs]
}), children, _jsx("g", {
transform: "translate(".concat(axisYWidth, ",0)"),
clipPath: "url(#".concat(componentId, "-main-clip)"),
children: overlays === null || overlays === void 0 ? void 0 : overlays.map((overlay, index) => {
var _overlay$id;
return _jsx(XYChartOverlay, _objectSpread(_objectSpread({}, overlay), {}, {
theme: theme,
colorMode: colorMode,
scaleX: scaleX,
width: extentX,
height: extentY
}), "_".concat((_overlay$id = overlay.id) !== null && _overlay$id !== void 0 ? _overlay$id : index));
})
}), _jsx("rect", {
ref: trackerRef,
x: axisYWidth,
y: 0,
width: extentX,
height: extentY,
opacity: 0,
fill: "red",
onMouseMove: onMouseMove,
onMouseEnter: onMouseMove,
onMouseLeave: onMouseLeave
})]
}), tooltipVisible && slice && _jsx("div", {
css: StyleTooltip(theme.charts.xy.animation),
style: {
left: axisYWidth,
top: headerHeight,
width: extentX,
height: extentY
},
children: _jsx(XYChartTooltip, {
theme: theme,
colorMode: colorMode,
slice: slice,
computed: computed,
domainX: computedDomainX,
domainY: computedDomainY,
format: formatTooltipValue,
tooltipTotalVisible: tooltipTotalVisible,
width: extentX,
offset: tooltipOffset
})
}), (computed == null || computed.length == 0) && _jsx(ChartEmptyBlock, {
theme: theme,
colorMode: colorMode,
background: background,
width: extentX,
height: extentY,
position: "absolute",
top: headerHeight,
left: axisYWidth,
children: emptyText
})]
})
});
}
//# sourceMappingURL=XYChartPane.js.map