@semcore/d3-chart 2.2.7 → 2.3.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +12 -0
- package/lib/cjs/Area.js +16 -9
- package/lib/cjs/Area.js.map +1 -1
- package/lib/cjs/Axis.js +56 -17
- package/lib/cjs/Axis.js.map +1 -1
- package/lib/cjs/Bar.js +20 -9
- package/lib/cjs/Bar.js.map +1 -1
- package/lib/cjs/Bubble.js +20 -11
- package/lib/cjs/Bubble.js.map +1 -1
- package/lib/cjs/ClipPath.js +1 -0
- package/lib/cjs/ClipPath.js.map +1 -1
- package/lib/cjs/Donut.js +22 -12
- package/lib/cjs/Donut.js.map +1 -1
- package/lib/cjs/Dots.js +10 -9
- package/lib/cjs/Dots.js.map +1 -1
- package/lib/cjs/GroupBar.js +12 -8
- package/lib/cjs/GroupBar.js.map +1 -1
- package/lib/cjs/HorizontalBar.js +20 -9
- package/lib/cjs/HorizontalBar.js.map +1 -1
- package/lib/cjs/Hover.js +8 -4
- package/lib/cjs/Hover.js.map +1 -1
- package/lib/cjs/Line.js +15 -9
- package/lib/cjs/Line.js.map +1 -1
- package/lib/cjs/Plot.js +46 -8
- package/lib/cjs/Plot.js.map +1 -1
- package/lib/cjs/RadialTree.js +25 -13
- package/lib/cjs/RadialTree.js.map +1 -1
- package/lib/cjs/ReferenceLine.js +10 -10
- package/lib/cjs/ScatterPlot.js +17 -8
- package/lib/cjs/ScatterPlot.js.map +1 -1
- package/lib/cjs/StackBar.js +12 -8
- package/lib/cjs/StackBar.js.map +1 -1
- package/lib/cjs/StackedArea.js +8 -7
- package/lib/cjs/StackedArea.js.map +1 -1
- package/lib/cjs/Tooltip.js +8 -8
- package/lib/cjs/Venn.js +25 -9
- package/lib/cjs/Venn.js.map +1 -1
- package/lib/cjs/a11y/PlotA11yModule.js +197 -0
- package/lib/cjs/a11y/PlotA11yModule.js.map +1 -0
- package/lib/cjs/a11y/PlotA11yView.js +287 -0
- package/lib/cjs/a11y/PlotA11yView.js.map +1 -0
- package/lib/cjs/a11y/bezier.js +44 -0
- package/lib/cjs/a11y/bezier.js.map +1 -0
- package/lib/cjs/a11y/focus.js +57 -0
- package/lib/cjs/a11y/focus.js.map +1 -0
- package/lib/cjs/a11y/hints.js +141 -0
- package/lib/cjs/a11y/hints.js.map +1 -0
- package/lib/cjs/a11y/insights.js +785 -0
- package/lib/cjs/a11y/insights.js.map +1 -0
- package/lib/cjs/a11y/intl.js +31 -0
- package/lib/cjs/a11y/intl.js.map +1 -0
- package/lib/cjs/a11y/locale.js +52 -0
- package/lib/cjs/a11y/locale.js.map +1 -0
- package/lib/cjs/a11y/serialize.js +439 -0
- package/lib/cjs/a11y/serialize.js.map +1 -0
- package/lib/cjs/a11y/summarize.js +21 -0
- package/lib/cjs/a11y/summarize.js.map +1 -0
- package/lib/cjs/a11y/translations/module/de.json +5 -0
- package/lib/cjs/a11y/translations/module/en.json +5 -0
- package/lib/cjs/a11y/translations/module/es.json +5 -0
- package/lib/cjs/a11y/translations/module/fr.json +5 -0
- package/lib/cjs/a11y/translations/module/it.json +5 -0
- package/lib/cjs/a11y/translations/module/ja.json +5 -0
- package/lib/cjs/a11y/translations/module/ko.json +5 -0
- package/lib/cjs/a11y/translations/module/pt.json +5 -0
- package/lib/cjs/a11y/translations/module/tr.json +5 -0
- package/lib/cjs/a11y/translations/module/translations.js +46 -0
- package/lib/cjs/a11y/translations/module/translations.js.map +1 -0
- package/lib/cjs/a11y/translations/module/vi.json +5 -0
- package/lib/cjs/a11y/translations/module/zh.json +5 -0
- package/lib/cjs/a11y/translations/view/de.json +42 -0
- package/lib/cjs/a11y/translations/view/en.csv +41 -0
- package/lib/cjs/a11y/translations/view/en.json +42 -0
- package/lib/cjs/a11y/translations/view/es.json +42 -0
- package/lib/cjs/a11y/translations/view/fr.json +42 -0
- package/lib/cjs/a11y/translations/view/it.json +42 -0
- package/lib/cjs/a11y/translations/view/ja.json +42 -0
- package/lib/cjs/a11y/translations/view/ko.json +42 -0
- package/lib/cjs/a11y/translations/view/pt.json +42 -0
- package/lib/cjs/a11y/translations/view/tr.json +42 -0
- package/lib/cjs/a11y/translations/view/translations.js +46 -0
- package/lib/cjs/a11y/translations/view/translations.js.map +1 -0
- package/lib/cjs/a11y/translations/view/vi.json +42 -0
- package/lib/cjs/a11y/translations/view/zh.json +42 -0
- package/lib/cjs/createElement.js +3 -1
- package/lib/cjs/createElement.js.map +1 -1
- package/lib/cjs/style/plot.shadow.css +10 -0
- package/lib/cjs/style/plotA11yModule.shadow.css +13 -0
- package/lib/cjs/style/plotA11yView.shadow.css +39 -0
- package/lib/cjs/types/Plot.d.ts +75 -0
- package/lib/cjs/utils.js +9 -1
- package/lib/cjs/utils.js.map +1 -1
- package/lib/es6/Area.js +16 -9
- package/lib/es6/Area.js.map +1 -1
- package/lib/es6/Axis.js +56 -17
- package/lib/es6/Axis.js.map +1 -1
- package/lib/es6/Bar.js +20 -9
- package/lib/es6/Bar.js.map +1 -1
- package/lib/es6/Bubble.js +20 -11
- package/lib/es6/Bubble.js.map +1 -1
- package/lib/es6/ClipPath.js +1 -0
- package/lib/es6/ClipPath.js.map +1 -1
- package/lib/es6/Donut.js +22 -12
- package/lib/es6/Donut.js.map +1 -1
- package/lib/es6/Dots.js +10 -9
- package/lib/es6/Dots.js.map +1 -1
- package/lib/es6/GroupBar.js +12 -8
- package/lib/es6/GroupBar.js.map +1 -1
- package/lib/es6/HorizontalBar.js +20 -9
- package/lib/es6/HorizontalBar.js.map +1 -1
- package/lib/es6/Hover.js +8 -4
- package/lib/es6/Hover.js.map +1 -1
- package/lib/es6/Line.js +15 -9
- package/lib/es6/Line.js.map +1 -1
- package/lib/es6/Plot.js +48 -9
- package/lib/es6/Plot.js.map +1 -1
- package/lib/es6/RadialTree.js +25 -13
- package/lib/es6/RadialTree.js.map +1 -1
- package/lib/es6/ReferenceLine.js +10 -10
- package/lib/es6/ScatterPlot.js +17 -8
- package/lib/es6/ScatterPlot.js.map +1 -1
- package/lib/es6/StackBar.js +12 -8
- package/lib/es6/StackBar.js.map +1 -1
- package/lib/es6/StackedArea.js +8 -7
- package/lib/es6/StackedArea.js.map +1 -1
- package/lib/es6/Tooltip.js +8 -8
- package/lib/es6/Venn.js +25 -9
- package/lib/es6/Venn.js.map +1 -1
- package/lib/es6/a11y/PlotA11yModule.js +168 -0
- package/lib/es6/a11y/PlotA11yModule.js.map +1 -0
- package/lib/es6/a11y/PlotA11yView.js +255 -0
- package/lib/es6/a11y/PlotA11yView.js.map +1 -0
- package/lib/es6/a11y/bezier.js +35 -0
- package/lib/es6/a11y/bezier.js.map +1 -0
- package/lib/es6/a11y/focus.js +48 -0
- package/lib/es6/a11y/focus.js.map +1 -0
- package/lib/es6/a11y/hints.js +123 -0
- package/lib/es6/a11y/hints.js.map +1 -0
- package/lib/es6/a11y/insights.js +779 -0
- package/lib/es6/a11y/insights.js.map +1 -0
- package/lib/es6/a11y/intl.js +18 -0
- package/lib/es6/a11y/intl.js.map +1 -0
- package/lib/es6/a11y/locale.js +40 -0
- package/lib/es6/a11y/locale.js.map +1 -0
- package/lib/es6/a11y/serialize.js +423 -0
- package/lib/es6/a11y/serialize.js.map +1 -0
- package/lib/es6/a11y/summarize.js +10 -0
- package/lib/es6/a11y/summarize.js.map +1 -0
- package/lib/es6/a11y/translations/module/de.json +5 -0
- package/lib/es6/a11y/translations/module/en.json +5 -0
- package/lib/es6/a11y/translations/module/es.json +5 -0
- package/lib/es6/a11y/translations/module/fr.json +5 -0
- package/lib/es6/a11y/translations/module/it.json +5 -0
- package/lib/es6/a11y/translations/module/ja.json +5 -0
- package/lib/es6/a11y/translations/module/ko.json +5 -0
- package/lib/es6/a11y/translations/module/pt.json +5 -0
- package/lib/es6/a11y/translations/module/tr.json +5 -0
- package/lib/es6/a11y/translations/module/translations.js +25 -0
- package/lib/es6/a11y/translations/module/translations.js.map +1 -0
- package/lib/es6/a11y/translations/module/vi.json +5 -0
- package/lib/es6/a11y/translations/module/zh.json +5 -0
- package/lib/es6/a11y/translations/view/de.json +42 -0
- package/lib/es6/a11y/translations/view/en.csv +41 -0
- package/lib/es6/a11y/translations/view/en.json +42 -0
- package/lib/es6/a11y/translations/view/es.json +42 -0
- package/lib/es6/a11y/translations/view/fr.json +42 -0
- package/lib/es6/a11y/translations/view/it.json +42 -0
- package/lib/es6/a11y/translations/view/ja.json +42 -0
- package/lib/es6/a11y/translations/view/ko.json +42 -0
- package/lib/es6/a11y/translations/view/pt.json +42 -0
- package/lib/es6/a11y/translations/view/tr.json +42 -0
- package/lib/es6/a11y/translations/view/translations.js +25 -0
- package/lib/es6/a11y/translations/view/translations.js.map +1 -0
- package/lib/es6/a11y/translations/view/vi.json +42 -0
- package/lib/es6/a11y/translations/view/zh.json +42 -0
- package/lib/es6/createElement.js +3 -1
- package/lib/es6/createElement.js.map +1 -1
- package/lib/es6/style/plot.shadow.css +10 -0
- package/lib/es6/style/plotA11yModule.shadow.css +13 -0
- package/lib/es6/style/plotA11yView.shadow.css +39 -0
- package/lib/es6/types/Plot.d.ts +75 -0
- package/lib/es6/utils.js +5 -0
- package/lib/es6/utils.js.map +1 -1
- package/lib/types/Plot.d.ts +75 -0
- package/lib/types/a11y/PlotA11yModule.d.ts +12 -0
- package/lib/types/a11y/PlotA11yView.d.ts +3 -0
- package/lib/types/a11y/bezier.d.ts +8 -0
- package/lib/types/a11y/focus.d.ts +5 -0
- package/lib/types/a11y/hints.d.ts +78 -0
- package/lib/types/a11y/insights.d.ts +54 -0
- package/lib/types/a11y/intl.d.ts +8 -0
- package/lib/types/a11y/locale.d.ts +3 -0
- package/lib/types/a11y/serialize.d.ts +16 -0
- package/lib/types/a11y/summarize.d.ts +2 -0
- package/lib/types/a11y/translations/module/translations.d.ts +5 -0
- package/lib/types/a11y/translations/view/translations.d.ts +5 -0
- package/lib/types/utils.d.ts +5 -4
- package/package.json +2 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PlotA11yModule.js","names":["React","normalizeLocale","translations","Root","sstyled","Context","I18nContext","Box","globalWasFocused","globalNavWithKeyboard","PlotA11yModule","props","SPlotA11yModule","useState","wasFocused","setWasFocused","navWithKeyboard","setNavWithKeyboard","plotA11yView","setPlotA11yView","hadnleHiddenElementsFocus","useCallback","loading","setLoading","error","setError","contextLocale","useContext","locale","useMemo","texts","useEffect","focusListener","plotRef","current","addEventListener","removeEventListener","keyboardListener","event","navigationKeys","includes","key","document","body","shouldDisplayView","then","PlotA11yView","Component","console","styles","failed","disabled"],"sources":["../../../src/a11y/PlotA11yModule.tsx"],"sourcesContent":["import React from 'react';\nimport { DataStructureHints, PartialDataSummarizationConfig } from './hints';\nimport { normalizeLocale } from './locale';\nimport { translations } from './translations/module/translations';\nimport { Root, sstyled } from '@semcore/core';\nimport styles from '../style/plotA11yModule.shadow.css';\nimport { Context as I18nContext } from '@semcore/utils/lib/enhances/WithI18n';\nimport { Box } from '@semcore/flex-box';\n\nlet globalWasFocused = false;\nlet globalNavWithKeyboard = false;\n\nexport type A11yViewProps = {\n id: string;\n data: Record<string, unknown>[];\n hints: DataStructureHints;\n plotLabel: string;\n locale: NavigatorLanguage['language'];\n config: PartialDataSummarizationConfig;\n // eslint-disable-next-line ssr-friendly/no-dom-globals-in-module-scope\n plotRef: React.RefObject<Element>;\n};\n\nexport const PlotA11yModule: React.FC<A11yViewProps> = (props) => {\n const SPlotA11yModule = Root;\n const [wasFocused, setWasFocused] = React.useState(globalWasFocused);\n const [navWithKeyboard, setNavWithKeyboard] = React.useState(globalNavWithKeyboard);\n const [plotA11yView, setPlotA11yView] = React.useState<{\n Component: React.FC<A11yViewProps>;\n } | null>(null);\n\n const hadnleHiddenElementsFocus = React.useCallback(() => {\n setWasFocused(true);\n setNavWithKeyboard(true);\n }, []);\n\n const [loading, setLoading] = React.useState(false);\n const [error, setError] = React.useState<Error | null>(null);\n\n const contextLocale = React.useContext(I18nContext);\n const locale = React.useMemo(\n () => normalizeLocale(props.locale ?? contextLocale, translations),\n [props.locale],\n );\n const texts = React.useMemo(() => (locale ? translations[locale] : {}), [locale]);\n\n React.useEffect(() => {\n if (wasFocused) return;\n const focusListener = () => {\n globalWasFocused = true;\n setWasFocused(true);\n };\n\n props.plotRef.current?.addEventListener('focus', focusListener);\n return () => props.plotRef.current?.removeEventListener('focus', focusListener);\n }, [wasFocused, props.plotRef]);\n React.useEffect(() => {\n if (navWithKeyboard) return;\n const keyboardListener = (event: Event) => {\n const navigationKeys = [\n 'Tab',\n 'ArrowUp',\n 'ArrowLeft',\n 'ArrowDown',\n 'ArrowRight',\n 'ArrowUp',\n 'ArrowLeft',\n ];\n if ('key' in event && navigationKeys.includes((event as KeyboardEvent).key)) {\n setNavWithKeyboard(true);\n globalNavWithKeyboard = true;\n }\n };\n document.body?.addEventListener('keydown', keyboardListener);\n return () => document.body?.removeEventListener('keydown', keyboardListener);\n }, [navWithKeyboard]);\n\n const shouldDisplayView = wasFocused && navWithKeyboard;\n\n React.useEffect(() => {\n if (!shouldDisplayView) return;\n if (plotA11yView) return;\n if (loading) return;\n\n setLoading(true);\n\n import('./PlotA11yView')\n .then(({ PlotA11yView }) => {\n setPlotA11yView({ Component: PlotA11yView });\n setLoading(false);\n setError(null);\n })\n .catch((error) => {\n // eslint-disable-next-line no-console\n console.error(error);\n setError(error);\n });\n }, [plotA11yView, shouldDisplayView, loading, setLoading]);\n\n if (plotA11yView) {\n return sstyled(styles)(\n <plotA11yView.Component {...props} locale={locale!} />,\n ) as React.ReactElement;\n }\n\n if (error) {\n return sstyled(styles)(\n <SPlotA11yModule render={Box} tabIndex={0} aria-live=\"assertive\">\n {texts.failed}\n </SPlotA11yModule>,\n ) as React.ReactElement;\n }\n if (loading) {\n return sstyled(styles)(\n <SPlotA11yModule render={Box} tabIndex={0} aria-live=\"polite\">\n {texts.loading}\n </SPlotA11yModule>,\n ) as React.ReactElement;\n }\n\n return sstyled(styles)(\n <SPlotA11yModule render={Box} tabIndex={0} onFocus={hadnleHiddenElementsFocus}>\n {texts.disabled}\n </SPlotA11yModule>,\n ) as React.ReactElement;\n};\n"],"mappings":"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"}
|
|
@@ -0,0 +1,255 @@
|
|
|
1
|
+
import _defineProperty from "@babel/runtime/helpers/defineProperty";
|
|
2
|
+
import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
|
|
3
|
+
import _toConsumableArray from "@babel/runtime/helpers/toConsumableArray";
|
|
4
|
+
import { sstyled as _sstyled } from "@semcore/core";
|
|
5
|
+
import { assignProps as _assignProps } from "@semcore/core";
|
|
6
|
+
|
|
7
|
+
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; }
|
|
8
|
+
|
|
9
|
+
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; }
|
|
10
|
+
|
|
11
|
+
function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it["return"] != null) it["return"](); } finally { if (didErr) throw err; } } }; }
|
|
12
|
+
|
|
13
|
+
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
|
14
|
+
|
|
15
|
+
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
|
|
16
|
+
|
|
17
|
+
import React from 'react';
|
|
18
|
+
import { heavyFindNextFocusableElement } from './focus';
|
|
19
|
+
import { makeDataSummarizationConfig } from './hints';
|
|
20
|
+
import { formatValue } from './serialize';
|
|
21
|
+
import { getIntl } from './intl';
|
|
22
|
+
import { summarize } from './summarize';
|
|
23
|
+
import { Root, sstyled } from '@semcore/core';
|
|
24
|
+
|
|
25
|
+
/*__reshadow-styles__:"../style/plotA11yView.shadow.css"*/
|
|
26
|
+
var styles = (
|
|
27
|
+
/*__reshadow_css_start__*/
|
|
28
|
+
_sstyled.insert(
|
|
29
|
+
/*__inner_css_start__*/
|
|
30
|
+
".___SPlotA11yView_1u7vk_gg_{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;pointer-events:none;opacity:0;background-color:#fff;color:#000;border:3px solid #000;font-size:10px;padding:2px;width:200px;height:200px;max-width:80%;max-height:80%;overflow:auto}.___SPlotA11yView_1u7vk_gg_:focus,.___SPlotA11yView_1u7vk_gg_.__focus-within_1u7vk_gg_{-webkit-user-select:all;-moz-user-select:all;-ms-user-select:all;user-select:all;pointer-events:all;opacity:1;z-index:100;position:relative;display:block}.___SPlotA11yView_1u7vk_gg_:focus,.___SPlotA11yView_1u7vk_gg_:focus-within{-webkit-user-select:all;-moz-user-select:all;-ms-user-select:all;user-select:all;pointer-events:all;opacity:1;z-index:100;position:relative;display:block}.___SPlotA11yView_1u7vk_gg_ a{cursor:pointer;text-decoration:underline;margin-bottom:8px;display:block}.___SPlotA11yView_1u7vk_gg_ table,.___SPlotA11yView_1u7vk_gg_ td,.___SPlotA11yView_1u7vk_gg_ th{border:1px solid #000}"
|
|
31
|
+
/*__inner_css_end__*/
|
|
32
|
+
, "1u7vk_gg_")
|
|
33
|
+
/*__reshadow_css_end__*/
|
|
34
|
+
, {
|
|
35
|
+
"__SPlotA11yView": "___SPlotA11yView_1u7vk_gg_",
|
|
36
|
+
"_focus-within": "__focus-within_1u7vk_gg_"
|
|
37
|
+
});
|
|
38
|
+
import { Box } from '@semcore/flex-box';
|
|
39
|
+
export var PlotA11yView = function PlotA11yView(_ref3) {
|
|
40
|
+
var _ref = arguments[0],
|
|
41
|
+
_ref2;
|
|
42
|
+
|
|
43
|
+
var id = _ref3.id,
|
|
44
|
+
providedData = _ref3.data,
|
|
45
|
+
hints = _ref3.hints,
|
|
46
|
+
plotLabel = _ref3.plotLabel,
|
|
47
|
+
plotRef = _ref3.plotRef,
|
|
48
|
+
providedConfig = _ref3.config,
|
|
49
|
+
locale = _ref3.locale;
|
|
50
|
+
var SPlotA11yView = Box;
|
|
51
|
+
var intl = React.useMemo(function () {
|
|
52
|
+
return getIntl(locale);
|
|
53
|
+
}, [locale]);
|
|
54
|
+
var config = React.useMemo(function () {
|
|
55
|
+
return makeDataSummarizationConfig(providedConfig);
|
|
56
|
+
}, [providedConfig]);
|
|
57
|
+
var data = React.useMemo(function () {
|
|
58
|
+
return Array.isArray(providedData) ? providedData : [providedData];
|
|
59
|
+
}, [providedData]);
|
|
60
|
+
var keys = React.useMemo(function () {
|
|
61
|
+
var _fromHints, _fromHints2, _fromHints3, _fromHints4;
|
|
62
|
+
|
|
63
|
+
var fromHints = [];
|
|
64
|
+
|
|
65
|
+
(_fromHints = fromHints).push.apply(_fromHints, _toConsumableArray(hints.fields.verticalAxes));
|
|
66
|
+
|
|
67
|
+
(_fromHints2 = fromHints).push.apply(_fromHints2, _toConsumableArray(hints.fields.horizontalAxes));
|
|
68
|
+
|
|
69
|
+
(_fromHints3 = fromHints).push.apply(_fromHints3, _toConsumableArray(hints.fields.valueAxes));
|
|
70
|
+
|
|
71
|
+
(_fromHints4 = fromHints).push.apply(_fromHints4, _toConsumableArray(Object.keys(hints.fields.values)));
|
|
72
|
+
|
|
73
|
+
fromHints = _toConsumableArray(new Set(fromHints)).filter(function (key) {
|
|
74
|
+
return key in data[0];
|
|
75
|
+
});
|
|
76
|
+
|
|
77
|
+
if (fromHints.length === 0) {
|
|
78
|
+
data.forEach(function (row) {
|
|
79
|
+
var _fromHints5;
|
|
80
|
+
|
|
81
|
+
return (_fromHints5 = fromHints).push.apply(_fromHints5, _toConsumableArray(Object.keys(row)));
|
|
82
|
+
});
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
return _toConsumableArray(new Set(fromHints));
|
|
86
|
+
}, [data, hints]);
|
|
87
|
+
var duplicatedBaseKeys = React.useMemo(function () {
|
|
88
|
+
var baseKeys = keys.filter(function (key) {
|
|
89
|
+
return !hints.titles.valuesAxes[key];
|
|
90
|
+
}).map(function (key) {
|
|
91
|
+
if (hints.fields.verticalAxes.has(key) && hints.axesTitle.vertical) return [key, hints.axesTitle.vertical];
|
|
92
|
+
if (hints.fields.horizontalAxes.has(key) && hints.axesTitle.horizontal) return [key, hints.axesTitle.horizontal];
|
|
93
|
+
}).filter(function (entry) {
|
|
94
|
+
return entry !== undefined;
|
|
95
|
+
}).map(function (entry) {
|
|
96
|
+
return entry;
|
|
97
|
+
});
|
|
98
|
+
var doublicated = {};
|
|
99
|
+
var handled = {};
|
|
100
|
+
|
|
101
|
+
var _iterator = _createForOfIteratorHelper(baseKeys),
|
|
102
|
+
_step;
|
|
103
|
+
|
|
104
|
+
try {
|
|
105
|
+
for (_iterator.s(); !(_step = _iterator.n()).done;) {
|
|
106
|
+
var _step$value = _slicedToArray(_step.value, 2),
|
|
107
|
+
key = _step$value[0],
|
|
108
|
+
label = _step$value[1];
|
|
109
|
+
|
|
110
|
+
if (handled[label]) {
|
|
111
|
+
doublicated[key] = true;
|
|
112
|
+
doublicated[handled[label]] = true;
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
handled[label] = key;
|
|
116
|
+
}
|
|
117
|
+
} catch (err) {
|
|
118
|
+
_iterator.e(err);
|
|
119
|
+
} finally {
|
|
120
|
+
_iterator.f();
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
return doublicated;
|
|
124
|
+
}, [keys, hints]);
|
|
125
|
+
var renderTitle = React.useCallback(function (dataKey) {
|
|
126
|
+
if (hints.titles.valuesAxes[dataKey]) return hints.titles.valuesAxes[dataKey];
|
|
127
|
+
|
|
128
|
+
if (!duplicatedBaseKeys[dataKey]) {
|
|
129
|
+
if (hints.fields.verticalAxes.has(dataKey) && hints.axesTitle.vertical) return hints.axesTitle.vertical;
|
|
130
|
+
if (hints.fields.horizontalAxes.has(dataKey) && hints.axesTitle.horizontal) return hints.axesTitle.horizontal;
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
return dataKey;
|
|
134
|
+
}, [data, hints, duplicatedBaseKeys]);
|
|
135
|
+
|
|
136
|
+
var _React$useState = React.useState(null),
|
|
137
|
+
_React$useState2 = _slicedToArray(_React$useState, 2),
|
|
138
|
+
summary = _React$useState2[0],
|
|
139
|
+
setSummary = _React$useState2[1];
|
|
140
|
+
|
|
141
|
+
var _React$useState3 = React.useState(true),
|
|
142
|
+
_React$useState4 = _slicedToArray(_React$useState3, 2),
|
|
143
|
+
generatingSummary = _React$useState4[0],
|
|
144
|
+
setGeneratingSummary = _React$useState4[1];
|
|
145
|
+
|
|
146
|
+
React.useEffect(function () {
|
|
147
|
+
if (config.disable) {
|
|
148
|
+
setSummary('');
|
|
149
|
+
setGeneratingSummary(false);
|
|
150
|
+
return;
|
|
151
|
+
}
|
|
152
|
+
|
|
153
|
+
if (config.override) {
|
|
154
|
+
setSummary(config.override);
|
|
155
|
+
setGeneratingSummary(false);
|
|
156
|
+
return;
|
|
157
|
+
}
|
|
158
|
+
|
|
159
|
+
setTimeout(function () {
|
|
160
|
+
setSummary(summarize(providedData, hints, config, locale));
|
|
161
|
+
setGeneratingSummary(false);
|
|
162
|
+
}, 0);
|
|
163
|
+
}, [providedData, hints, config, locale]);
|
|
164
|
+
var handleSkip = React.useCallback(function () {
|
|
165
|
+
var _heavyFindNextFocusab;
|
|
166
|
+
|
|
167
|
+
if (!plotRef.current) return;
|
|
168
|
+
(_heavyFindNextFocusab = heavyFindNextFocusableElement(plotRef.current)) === null || _heavyFindNextFocusab === void 0 ? void 0 : _heavyFindNextFocusab.focus();
|
|
169
|
+
}, []);
|
|
170
|
+
var handleSkipKeyboard = React.useCallback(function (event) {
|
|
171
|
+
if (event.code !== 'Enter') return;
|
|
172
|
+
handleSkip();
|
|
173
|
+
}, [handleSkip]);
|
|
174
|
+
var handleGoToTable = React.useCallback(function () {
|
|
175
|
+
var _dataTableRef$current;
|
|
176
|
+
|
|
177
|
+
(_dataTableRef$current = dataTableRef.current) === null || _dataTableRef$current === void 0 ? void 0 : _dataTableRef$current.focus();
|
|
178
|
+
}, []);
|
|
179
|
+
var handleGoToTableKeyboard = React.useCallback(function (event) {
|
|
180
|
+
if (event.code !== 'Enter') return;
|
|
181
|
+
handleGoToTable();
|
|
182
|
+
}, [handleGoToTable]);
|
|
183
|
+
var texts = React.useMemo(function () {
|
|
184
|
+
return {
|
|
185
|
+
label: intl.formatMessage({
|
|
186
|
+
id: 'view-label'
|
|
187
|
+
}, {
|
|
188
|
+
plotLabel: plotLabel !== null && plotLabel !== void 0 ? plotLabel : intl.formatMessage({
|
|
189
|
+
id: 'view-default-plot-label'
|
|
190
|
+
})
|
|
191
|
+
}),
|
|
192
|
+
close: intl.formatMessage({
|
|
193
|
+
id: 'view-close'
|
|
194
|
+
}),
|
|
195
|
+
skipPlot: intl.formatMessage({
|
|
196
|
+
id: 'view-skip-plot'
|
|
197
|
+
}),
|
|
198
|
+
goToTable: intl.formatMessage({
|
|
199
|
+
id: 'view-go-to-table'
|
|
200
|
+
}),
|
|
201
|
+
summary: intl.formatMessage({
|
|
202
|
+
id: 'view-data-summary'
|
|
203
|
+
}),
|
|
204
|
+
summaryPlaceholder: intl.formatMessage({
|
|
205
|
+
id: 'view-summary-placeholder'
|
|
206
|
+
}),
|
|
207
|
+
table: intl.formatMessage({
|
|
208
|
+
id: 'view-table'
|
|
209
|
+
})
|
|
210
|
+
};
|
|
211
|
+
}, [intl, plotLabel]);
|
|
212
|
+
var dataTableRef = React.useRef(null);
|
|
213
|
+
return _ref2 = sstyled(styles), /*#__PURE__*/React.createElement(SPlotA11yView, _ref2.cn("SPlotA11yView", _objectSpread({}, _assignProps({
|
|
214
|
+
"tabIndex": 0,
|
|
215
|
+
"aria-label": texts.label
|
|
216
|
+
}, _ref))), /*#__PURE__*/React.createElement("a", _ref2.cn("a", {
|
|
217
|
+
"aria-hidden": true,
|
|
218
|
+
"onClick": handleSkip
|
|
219
|
+
}), texts.close), /*#__PURE__*/React.createElement("a", _ref2.cn("a", {
|
|
220
|
+
"role": "link",
|
|
221
|
+
"tabIndex": 0,
|
|
222
|
+
"onKeyDown": handleSkipKeyboard,
|
|
223
|
+
"onClick": handleSkip
|
|
224
|
+
}), texts.skipPlot), /*#__PURE__*/React.createElement("a", _ref2.cn("a", {
|
|
225
|
+
"role": "link",
|
|
226
|
+
"tabIndex": 0,
|
|
227
|
+
"onKeyDown": handleGoToTableKeyboard,
|
|
228
|
+
"onClick": handleGoToTable
|
|
229
|
+
}), texts.goToTable), /*#__PURE__*/React.createElement("strong", _ref2.cn("strong", {}), /*#__PURE__*/React.createElement("label", _ref2.cn("label", {
|
|
230
|
+
"htmlFor": "".concat(id, "-data-summary")
|
|
231
|
+
}), texts.summary)), /*#__PURE__*/React.createElement("div", _ref2.cn("div", {
|
|
232
|
+
"id": "".concat(id, "-data-summary"),
|
|
233
|
+
"aria-busy": generatingSummary,
|
|
234
|
+
"tabIndex": 0
|
|
235
|
+
}), generatingSummary ? texts.summaryPlaceholder : summary), /*#__PURE__*/React.createElement("strong", _ref2.cn("strong", {}), /*#__PURE__*/React.createElement("label", _ref2.cn("label", {
|
|
236
|
+
"htmlFor": "".concat(id, "-data-table")
|
|
237
|
+
}), texts.table)), /*#__PURE__*/React.createElement("table", _ref2.cn("table", {
|
|
238
|
+
"id": "".concat(id, "-data-table"),
|
|
239
|
+
"tabIndex": 0,
|
|
240
|
+
"ref": dataTableRef
|
|
241
|
+
}), /*#__PURE__*/React.createElement("thead", _ref2.cn("thead", {}), /*#__PURE__*/React.createElement("tr", _ref2.cn("tr", {}), keys.map(function (key, index) {
|
|
242
|
+
return /*#__PURE__*/React.createElement("th", {
|
|
243
|
+
key: "".concat(key, "-").concat(index)
|
|
244
|
+
}, renderTitle(key));
|
|
245
|
+
}))), /*#__PURE__*/React.createElement("tbody", _ref2.cn("tbody", {}), data.map(function (row, index) {
|
|
246
|
+
return /*#__PURE__*/React.createElement("tr", {
|
|
247
|
+
key: Object.values(row).join('-') + '-' + index
|
|
248
|
+
}, keys.map(function (key, index) {
|
|
249
|
+
return /*#__PURE__*/React.createElement("td", {
|
|
250
|
+
key: "".concat(key, "-").concat(index)
|
|
251
|
+
}, formatValue(intl, row[key]));
|
|
252
|
+
}));
|
|
253
|
+
}))));
|
|
254
|
+
};
|
|
255
|
+
//# sourceMappingURL=PlotA11yView.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PlotA11yView.js","names":["React","heavyFindNextFocusableElement","makeDataSummarizationConfig","formatValue","getIntl","summarize","Root","sstyled","Box","PlotA11yView","id","providedData","data","hints","plotLabel","plotRef","providedConfig","config","locale","SPlotA11yView","intl","useMemo","Array","isArray","keys","fromHints","push","fields","verticalAxes","horizontalAxes","valueAxes","Object","values","Set","filter","key","length","forEach","row","duplicatedBaseKeys","baseKeys","titles","valuesAxes","map","has","axesTitle","vertical","horizontal","entry","undefined","doublicated","handled","label","renderTitle","useCallback","dataKey","useState","summary","setSummary","generatingSummary","setGeneratingSummary","useEffect","disable","override","setTimeout","handleSkip","current","focus","handleSkipKeyboard","event","code","handleGoToTable","dataTableRef","handleGoToTableKeyboard","texts","formatMessage","close","skipPlot","goToTable","summaryPlaceholder","table","useRef","styles","index","join"],"sources":["../../../src/a11y/PlotA11yView.tsx"],"sourcesContent":["import React from 'react';\nimport { heavyFindNextFocusableElement } from './focus';\nimport { makeDataSummarizationConfig } from './hints';\nimport type { A11yViewProps } from './PlotA11yModule';\nimport { formatValue } from './serialize';\nimport { getIntl } from './intl';\nimport { summarize } from './summarize';\nimport { Root, sstyled } from '@semcore/core';\nimport styles from '../style/plotA11yView.shadow.css';\nimport { Box } from '@semcore/flex-box';\n\nexport const PlotA11yView: React.FC<A11yViewProps> = ({\n id,\n data: providedData,\n hints,\n plotLabel,\n plotRef,\n config: providedConfig,\n locale,\n}) => {\n const SPlotA11yView = Root;\n const intl = React.useMemo(() => getIntl(locale), [locale]);\n const config = React.useMemo(() => makeDataSummarizationConfig(providedConfig), [providedConfig]);\n const data = React.useMemo(\n () => (Array.isArray(providedData) ? providedData : [providedData]),\n [providedData],\n );\n const keys = React.useMemo(() => {\n let fromHints: (string | number)[] = [];\n fromHints.push(...hints.fields.verticalAxes);\n fromHints.push(...hints.fields.horizontalAxes);\n fromHints.push(...hints.fields.valueAxes);\n fromHints.push(...Object.keys(hints.fields.values));\n\n fromHints = [...new Set(fromHints)].filter((key) => key in data[0]);\n\n if (fromHints.length === 0) {\n data.forEach((row) => fromHints.push(...Object.keys(row)));\n }\n\n return [...new Set(fromHints)];\n }, [data, hints]);\n const duplicatedBaseKeys = React.useMemo(() => {\n const baseKeys = keys\n .filter((key) => !hints.titles.valuesAxes[key])\n .map((key) => {\n if (hints.fields.verticalAxes.has(key) && hints.axesTitle.vertical)\n return [key, hints.axesTitle.vertical];\n if (hints.fields.horizontalAxes.has(key) && hints.axesTitle.horizontal)\n return [key, hints.axesTitle.horizontal];\n })\n .filter((entry) => entry !== undefined)\n .map((entry) => entry!);\n const doublicated: Record<string, true> = {};\n const handled: Record<string, string | number> = {};\n for (const [key, label] of baseKeys) {\n if (handled[label]) {\n doublicated[key] = true;\n doublicated[handled[label]] = true;\n }\n handled[label] = key;\n }\n return doublicated;\n }, [keys, hints]);\n const renderTitle = React.useCallback(\n (dataKey: string | number) => {\n if (hints.titles.valuesAxes[dataKey]) return hints.titles.valuesAxes[dataKey];\n if (!duplicatedBaseKeys[dataKey]) {\n if (hints.fields.verticalAxes.has(dataKey) && hints.axesTitle.vertical)\n return hints.axesTitle.vertical;\n if (hints.fields.horizontalAxes.has(dataKey) && hints.axesTitle.horizontal)\n return hints.axesTitle.horizontal;\n }\n\n return dataKey;\n },\n [data, hints, duplicatedBaseKeys],\n );\n\n const [summary, setSummary] = React.useState<string | null>(null);\n const [generatingSummary, setGeneratingSummary] = React.useState(true);\n\n React.useEffect(() => {\n if (config.disable) {\n setSummary('');\n setGeneratingSummary(false);\n return;\n }\n if (config.override) {\n setSummary(config.override);\n setGeneratingSummary(false);\n return;\n }\n setTimeout(() => {\n setSummary(summarize(providedData, hints, config, locale));\n setGeneratingSummary(false);\n }, 0);\n }, [providedData, hints, config, locale]);\n\n const handleSkip = React.useCallback(() => {\n if (!plotRef.current) return;\n\n heavyFindNextFocusableElement(plotRef.current)?.focus();\n }, []);\n const handleSkipKeyboard = React.useCallback(\n (event: React.KeyboardEvent) => {\n if (event.code !== 'Enter') return;\n\n handleSkip();\n },\n [handleSkip],\n );\n const handleGoToTable = React.useCallback(() => {\n dataTableRef.current?.focus();\n }, []);\n const handleGoToTableKeyboard = React.useCallback(\n (event: React.KeyboardEvent) => {\n if (event.code !== 'Enter') return;\n\n handleGoToTable();\n },\n [handleGoToTable],\n );\n\n const texts = React.useMemo(\n () => ({\n label: intl.formatMessage(\n { id: 'view-label' },\n { plotLabel: plotLabel ?? intl.formatMessage({ id: 'view-default-plot-label' }) },\n ),\n close: intl.formatMessage({ id: 'view-close' }),\n skipPlot: intl.formatMessage({ id: 'view-skip-plot' }),\n goToTable: intl.formatMessage({ id: 'view-go-to-table' }),\n summary: intl.formatMessage({ id: 'view-data-summary' }),\n summaryPlaceholder: intl.formatMessage({ id: 'view-summary-placeholder' }),\n table: intl.formatMessage({ id: 'view-table' }),\n }),\n [intl, plotLabel],\n );\n\n const dataTableRef = React.useRef<HTMLTableElement>(null);\n\n return sstyled(styles)(\n <SPlotA11yView render={Box} tabIndex={0} aria-label={texts.label}>\n <a aria-hidden onClick={handleSkip}>\n {texts.close}\n </a>\n <a role=\"link\" tabIndex={0} onKeyDown={handleSkipKeyboard} onClick={handleSkip}>\n {texts.skipPlot}\n </a>\n <a role=\"link\" tabIndex={0} onKeyDown={handleGoToTableKeyboard} onClick={handleGoToTable}>\n {texts.goToTable}\n </a>\n <strong>\n <label htmlFor={`${id}-data-summary`}>{texts.summary}</label>\n </strong>\n <div id={`${id}-data-summary`} aria-busy={generatingSummary} tabIndex={0}>\n {generatingSummary ? texts.summaryPlaceholder : summary}\n </div>\n <strong>\n <label htmlFor={`${id}-data-table`}>{texts.table}</label>\n </strong>\n <table id={`${id}-data-table`} tabIndex={0} ref={dataTableRef}>\n <thead>\n <tr>\n {keys.map((key, index) => (\n <th key={`${key}-${index}`}>{renderTitle(key)}</th>\n ))}\n </tr>\n </thead>\n <tbody>\n {data.map((row, index) => (\n <tr key={Object.values(row).join('-') + '-' + index}>\n {keys.map((key, index) => (\n <td key={`${key}-${index}`}>{formatValue(intl, row[key])}</td>\n ))}\n </tr>\n ))}\n </tbody>\n </table>\n </SPlotA11yView>,\n ) as React.ReactElement;\n};\n"],"mappings":"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"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
export var makeBezier = function makeBezier(points, bounds) {
|
|
2
|
+
var yPoints = points.map(function (point) {
|
|
3
|
+
return point.y;
|
|
4
|
+
});
|
|
5
|
+
var noPoints = points.map(function () {
|
|
6
|
+
return 1;
|
|
7
|
+
});
|
|
8
|
+
var weightPoints = points.map(function (point) {
|
|
9
|
+
var _point$weight;
|
|
10
|
+
|
|
11
|
+
return (_point$weight = point.weight) !== null && _point$weight !== void 0 ? _point$weight : 1;
|
|
12
|
+
});
|
|
13
|
+
|
|
14
|
+
var process = function process(t, points) {
|
|
15
|
+
var result = 0;
|
|
16
|
+
|
|
17
|
+
for (var i = 0; i < points.length; i++) {
|
|
18
|
+
var tPower = i;
|
|
19
|
+
var reversedTPower = points.length - 1 - i;
|
|
20
|
+
var edge = i === 0 || i === points.length - 1;
|
|
21
|
+
var factor = edge ? 1 : points.length - 1;
|
|
22
|
+
var point = points[i];
|
|
23
|
+
var weight = weightPoints[i];
|
|
24
|
+
result += factor * Math.pow(t, tPower) * Math.pow(1 - t, reversedTPower) * point * weight;
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
return result;
|
|
28
|
+
};
|
|
29
|
+
|
|
30
|
+
return function (x) {
|
|
31
|
+
var t = x / bounds.width;
|
|
32
|
+
return process(t, yPoints) / process(t, noPoints);
|
|
33
|
+
};
|
|
34
|
+
};
|
|
35
|
+
//# sourceMappingURL=bezier.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"bezier.js","names":["makeBezier","points","bounds","yPoints","map","point","y","noPoints","weightPoints","weight","process","t","result","i","length","tPower","reversedTPower","edge","factor","x","width"],"sources":["../../../src/a11y/bezier.ts"],"sourcesContent":["export const makeBezier = (\n points: { x: number; y: number; weight?: number }[],\n bounds: { width: number; height: number },\n) => {\n const yPoints = points.map((point) => point.y);\n const noPoints = points.map(() => 1);\n const weightPoints = points.map((point) => point.weight ?? 1);\n const process = (t: number, points: number[]) => {\n let result = 0;\n for (let i = 0; i < points.length; i++) {\n const tPower = i;\n const reversedTPower = points.length - 1 - i;\n const edge = i === 0 || i === points.length - 1;\n const factor = edge ? 1 : points.length - 1;\n const point = points[i];\n const weight = weightPoints[i];\n result += factor * t ** tPower * (1 - t) ** reversedTPower * point * weight;\n }\n return result;\n };\n\n return (x: number) => {\n const t = x / bounds.width;\n return process(t, yPoints) / process(t, noPoints);\n };\n};\n"],"mappings":"AAAA,OAAO,IAAMA,UAAU,GAAG,SAAbA,UAAa,CACxBC,MADwB,EAExBC,MAFwB,EAGrB;EACH,IAAMC,OAAO,GAAGF,MAAM,CAACG,GAAP,CAAW,UAACC,KAAD;IAAA,OAAWA,KAAK,CAACC,CAAjB;EAAA,CAAX,CAAhB;EACA,IAAMC,QAAQ,GAAGN,MAAM,CAACG,GAAP,CAAW;IAAA,OAAM,CAAN;EAAA,CAAX,CAAjB;EACA,IAAMI,YAAY,GAAGP,MAAM,CAACG,GAAP,CAAW,UAACC,KAAD;IAAA;;IAAA,wBAAWA,KAAK,CAACI,MAAjB,yDAA2B,CAA3B;EAAA,CAAX,CAArB;;EACA,IAAMC,OAAO,GAAG,SAAVA,OAAU,CAACC,CAAD,EAAYV,MAAZ,EAAiC;IAC/C,IAAIW,MAAM,GAAG,CAAb;;IACA,KAAK,IAAIC,CAAC,GAAG,CAAb,EAAgBA,CAAC,GAAGZ,MAAM,CAACa,MAA3B,EAAmCD,CAAC,EAApC,EAAwC;MACtC,IAAME,MAAM,GAAGF,CAAf;MACA,IAAMG,cAAc,GAAGf,MAAM,CAACa,MAAP,GAAgB,CAAhB,GAAoBD,CAA3C;MACA,IAAMI,IAAI,GAAGJ,CAAC,KAAK,CAAN,IAAWA,CAAC,KAAKZ,MAAM,CAACa,MAAP,GAAgB,CAA9C;MACA,IAAMI,MAAM,GAAGD,IAAI,GAAG,CAAH,GAAOhB,MAAM,CAACa,MAAP,GAAgB,CAA1C;MACA,IAAMT,KAAK,GAAGJ,MAAM,CAACY,CAAD,CAApB;MACA,IAAMJ,MAAM,GAAGD,YAAY,CAACK,CAAD,CAA3B;MACAD,MAAM,IAAIM,MAAM,YAAGP,CAAH,EAAQI,MAAR,CAAN,YAAwB,IAAIJ,CAA5B,EAAkCK,cAAlC,IAAmDX,KAAnD,GAA2DI,MAArE;IACD;;IACD,OAAOG,MAAP;EACD,CAZD;;EAcA,OAAO,UAACO,CAAD,EAAe;IACpB,IAAMR,CAAC,GAAGQ,CAAC,GAAGjB,MAAM,CAACkB,KAArB;IACA,OAAOV,OAAO,CAACC,CAAD,EAAIR,OAAJ,CAAP,GAAsBO,OAAO,CAACC,CAAD,EAAIJ,QAAJ,CAApC;EACD,CAHD;AAID,CAzBM"}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
var isFocusable = function isFocusable(element) {
|
|
2
|
+
var tabIndex = element.getAttribute('tabindex');
|
|
3
|
+
|
|
4
|
+
if (tabIndex) {
|
|
5
|
+
var tabIndexValue = parseInt(tabIndex, 10);
|
|
6
|
+
if (!isNaN(tabIndexValue) && tabIndexValue >= 0) return element;
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
var tagName = element.tagName;
|
|
10
|
+
if ('INPUT' === tagName) return !element.getAttribute('disabled');
|
|
11
|
+
if ('A' === tagName || 'AREA' === tagName) return element.hasAttribute('href');
|
|
12
|
+
if ('BODY' === tagName || 'IFRAME' === tagName) return true;
|
|
13
|
+
}; // eslint-disable-next-line ssr-friendly/no-dom-globals-in-module-scope
|
|
14
|
+
|
|
15
|
+
|
|
16
|
+
export var heavyFindNextFocusableElement = function heavyFindNextFocusableElement(base) {
|
|
17
|
+
var trace = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : new Map();
|
|
18
|
+
trace.set(base, true);
|
|
19
|
+
var sibling = base.nextElementSibling;
|
|
20
|
+
|
|
21
|
+
if (sibling) {
|
|
22
|
+
trace.set(sibling, true);
|
|
23
|
+
|
|
24
|
+
for (var i = 0; i < sibling.children.length; i++) {
|
|
25
|
+
var child = sibling.children.item(i);
|
|
26
|
+
if (!child) continue;
|
|
27
|
+
if (trace.has(child)) continue;
|
|
28
|
+
if (isFocusable(child)) return child;
|
|
29
|
+
var childInnerResult = heavyFindNextFocusableElement(child, trace);
|
|
30
|
+
if (childInnerResult) return childInnerResult;
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
while (sibling) {
|
|
34
|
+
if (isFocusable(sibling)) return sibling;
|
|
35
|
+
|
|
36
|
+
if (!trace.has(sibling)) {
|
|
37
|
+
var siblingInnerResult = heavyFindNextFocusableElement(sibling, trace);
|
|
38
|
+
if (siblingInnerResult) return siblingInnerResult;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
sibling = sibling.nextElementSibling;
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
if (!base.parentElement || trace.has(base.parentElement)) return null;
|
|
46
|
+
return heavyFindNextFocusableElement(base.parentElement, trace);
|
|
47
|
+
};
|
|
48
|
+
//# sourceMappingURL=focus.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"focus.js","names":["isFocusable","element","tabIndex","getAttribute","tabIndexValue","parseInt","isNaN","tagName","hasAttribute","heavyFindNextFocusableElement","base","trace","Map","set","sibling","nextElementSibling","i","children","length","child","item","has","childInnerResult","siblingInnerResult","parentElement"],"sources":["../../../src/a11y/focus.ts"],"sourcesContent":["const isFocusable = (element: Element) => {\n const tabIndex = element.getAttribute('tabindex');\n if (tabIndex) {\n const tabIndexValue = parseInt(tabIndex, 10);\n if (!isNaN(tabIndexValue) && tabIndexValue >= 0) return element;\n }\n\n const { tagName } = element;\n\n if ('INPUT' === tagName) return !element.getAttribute('disabled');\n if ('A' === tagName || 'AREA' === tagName) return element.hasAttribute('href');\n if ('BODY' === tagName || 'IFRAME' === tagName) return true;\n};\n\n// eslint-disable-next-line ssr-friendly/no-dom-globals-in-module-scope\ntype FocusableElement = Element & { focus: () => void };\n\nexport const heavyFindNextFocusableElement = (\n base: Element,\n trace: Map<Element, true> = new Map(),\n): FocusableElement | null => {\n trace.set(base, true);\n let sibling = base.nextElementSibling;\n if (sibling) {\n trace.set(sibling, true);\n for (let i = 0; i < sibling.children.length; i++) {\n const child = sibling.children.item(i);\n if (!child) continue;\n if (trace.has(child)) continue;\n if (isFocusable(child)) return child as FocusableElement;\n const childInnerResult = heavyFindNextFocusableElement(child, trace);\n if (childInnerResult) return childInnerResult;\n }\n while (sibling) {\n if (isFocusable(sibling)) return sibling as FocusableElement;\n if (!trace.has(sibling)) {\n const siblingInnerResult = heavyFindNextFocusableElement(sibling, trace);\n if (siblingInnerResult) return siblingInnerResult;\n }\n sibling = sibling.nextElementSibling;\n }\n }\n\n if (!base.parentElement || trace.has(base.parentElement)) return null;\n\n return heavyFindNextFocusableElement(base.parentElement, trace);\n};\n"],"mappings":"AAAA,IAAMA,WAAW,GAAG,SAAdA,WAAc,CAACC,OAAD,EAAsB;EACxC,IAAMC,QAAQ,GAAGD,OAAO,CAACE,YAAR,CAAqB,UAArB,CAAjB;;EACA,IAAID,QAAJ,EAAc;IACZ,IAAME,aAAa,GAAGC,QAAQ,CAACH,QAAD,EAAW,EAAX,CAA9B;IACA,IAAI,CAACI,KAAK,CAACF,aAAD,CAAN,IAAyBA,aAAa,IAAI,CAA9C,EAAiD,OAAOH,OAAP;EAClD;;EAED,IAAQM,OAAR,GAAoBN,OAApB,CAAQM,OAAR;EAEA,IAAI,YAAYA,OAAhB,EAAyB,OAAO,CAACN,OAAO,CAACE,YAAR,CAAqB,UAArB,CAAR;EACzB,IAAI,QAAQI,OAAR,IAAmB,WAAWA,OAAlC,EAA2C,OAAON,OAAO,CAACO,YAAR,CAAqB,MAArB,CAAP;EAC3C,IAAI,WAAWD,OAAX,IAAsB,aAAaA,OAAvC,EAAgD,OAAO,IAAP;AACjD,CAZD,C,CAcA;;;AAGA,OAAO,IAAME,6BAA6B,GAAG,SAAhCA,6BAAgC,CAC3CC,IAD2C,EAGf;EAAA,IAD5BC,KAC4B,uEADA,IAAIC,GAAJ,EACA;EAC5BD,KAAK,CAACE,GAAN,CAAUH,IAAV,EAAgB,IAAhB;EACA,IAAII,OAAO,GAAGJ,IAAI,CAACK,kBAAnB;;EACA,IAAID,OAAJ,EAAa;IACXH,KAAK,CAACE,GAAN,CAAUC,OAAV,EAAmB,IAAnB;;IACA,KAAK,IAAIE,CAAC,GAAG,CAAb,EAAgBA,CAAC,GAAGF,OAAO,CAACG,QAAR,CAAiBC,MAArC,EAA6CF,CAAC,EAA9C,EAAkD;MAChD,IAAMG,KAAK,GAAGL,OAAO,CAACG,QAAR,CAAiBG,IAAjB,CAAsBJ,CAAtB,CAAd;MACA,IAAI,CAACG,KAAL,EAAY;MACZ,IAAIR,KAAK,CAACU,GAAN,CAAUF,KAAV,CAAJ,EAAsB;MACtB,IAAInB,WAAW,CAACmB,KAAD,CAAf,EAAwB,OAAOA,KAAP;MACxB,IAAMG,gBAAgB,GAAGb,6BAA6B,CAACU,KAAD,EAAQR,KAAR,CAAtD;MACA,IAAIW,gBAAJ,EAAsB,OAAOA,gBAAP;IACvB;;IACD,OAAOR,OAAP,EAAgB;MACd,IAAId,WAAW,CAACc,OAAD,CAAf,EAA0B,OAAOA,OAAP;;MAC1B,IAAI,CAACH,KAAK,CAACU,GAAN,CAAUP,OAAV,CAAL,EAAyB;QACvB,IAAMS,kBAAkB,GAAGd,6BAA6B,CAACK,OAAD,EAAUH,KAAV,CAAxD;QACA,IAAIY,kBAAJ,EAAwB,OAAOA,kBAAP;MACzB;;MACDT,OAAO,GAAGA,OAAO,CAACC,kBAAlB;IACD;EACF;;EAED,IAAI,CAACL,IAAI,CAACc,aAAN,IAAuBb,KAAK,CAACU,GAAN,CAAUX,IAAI,CAACc,aAAf,CAA3B,EAA0D,OAAO,IAAP;EAE1D,OAAOf,6BAA6B,CAACC,IAAI,CAACc,aAAN,EAAqBb,KAArB,CAApC;AACD,CA7BM"}
|
|
@@ -0,0 +1,123 @@
|
|
|
1
|
+
import _defineProperty from "@babel/runtime/helpers/defineProperty";
|
|
2
|
+
import _typeof from "@babel/runtime/helpers/typeof";
|
|
3
|
+
|
|
4
|
+
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; }
|
|
5
|
+
|
|
6
|
+
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; }
|
|
7
|
+
|
|
8
|
+
export var makeDataHintsContainer = function makeDataHintsContainer() {
|
|
9
|
+
return {
|
|
10
|
+
fields: {
|
|
11
|
+
verticalAxes: new Set(),
|
|
12
|
+
horizontalAxes: new Set(),
|
|
13
|
+
valueAxes: new Set(),
|
|
14
|
+
values: new Set()
|
|
15
|
+
},
|
|
16
|
+
groups: new Set(),
|
|
17
|
+
axesTitle: {
|
|
18
|
+
vertical: null,
|
|
19
|
+
horizontal: null
|
|
20
|
+
},
|
|
21
|
+
titles: {
|
|
22
|
+
verticalAxes: {},
|
|
23
|
+
getVerticalAxesTitle: null,
|
|
24
|
+
horizontalAxes: {},
|
|
25
|
+
getHorizontalAxesTitle: null,
|
|
26
|
+
valuesAxes: {},
|
|
27
|
+
getValueAxesTitle: null
|
|
28
|
+
},
|
|
29
|
+
grid: {
|
|
30
|
+
verticalAxes: null,
|
|
31
|
+
horizontalAxes: null
|
|
32
|
+
},
|
|
33
|
+
dataType: null,
|
|
34
|
+
pointsDensity: null
|
|
35
|
+
};
|
|
36
|
+
};
|
|
37
|
+
export var makeDataHintsHandlers = function makeDataHintsHandlers(mutableContainer) {
|
|
38
|
+
var handler = {
|
|
39
|
+
specifyDataRowFields: function specifyDataRowFields(x, y, value) {
|
|
40
|
+
if (y) mutableContainer.fields.verticalAxes.add(y);
|
|
41
|
+
if (x) mutableContainer.fields.horizontalAxes.add(x);
|
|
42
|
+
if (value) mutableContainer.fields.valueAxes.add(value);
|
|
43
|
+
},
|
|
44
|
+
setupGrid: function setupGrid(direction, size) {
|
|
45
|
+
if (direction === 'horizontal') {
|
|
46
|
+
mutableContainer.grid.horizontalAxes = size;
|
|
47
|
+
} else if (direction === 'vertical') {
|
|
48
|
+
mutableContainer.grid.verticalAxes = size;
|
|
49
|
+
}
|
|
50
|
+
},
|
|
51
|
+
establishDataType: function establishDataType(dataType) {
|
|
52
|
+
mutableContainer.dataType = dataType;
|
|
53
|
+
},
|
|
54
|
+
describeValueEntity: function describeValueEntity(dataKey, readableName) {
|
|
55
|
+
mutableContainer.fields.values.add(dataKey);
|
|
56
|
+
handler.labelKey('value', dataKey, readableName);
|
|
57
|
+
},
|
|
58
|
+
describeGroupedValues: function describeGroupedValues(groupKey, dataKey) {
|
|
59
|
+
mutableContainer.groups.add(groupKey);
|
|
60
|
+
mutableContainer.fields.values.add(dataKey);
|
|
61
|
+
},
|
|
62
|
+
labelKey: function labelKey(axes, dataKey, label) {
|
|
63
|
+
if (axes === 'vertical') mutableContainer.titles.verticalAxes[dataKey] = label;
|
|
64
|
+
if (axes === 'horizontal') mutableContainer.titles.horizontalAxes[dataKey] = label;
|
|
65
|
+
if (axes === 'value') mutableContainer.titles.valuesAxes[dataKey] = label;
|
|
66
|
+
},
|
|
67
|
+
addKeyLabelGetter: function addKeyLabelGetter(axes, getter) {
|
|
68
|
+
if (axes === 'vertical') mutableContainer.titles.getVerticalAxesTitle = getter;
|
|
69
|
+
if (axes === 'horizontal') mutableContainer.titles.getHorizontalAxesTitle = getter;
|
|
70
|
+
if (axes === 'value') mutableContainer.titles.getValueAxesTitle = getter;
|
|
71
|
+
},
|
|
72
|
+
setTitle: function setTitle(describedDataAxes, title) {
|
|
73
|
+
if (typeof title === 'number' || typeof title === 'bigint' || _typeof(title) === 'object' && title instanceof Date) {
|
|
74
|
+
title = String(title);
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
if (typeof title !== 'string') {
|
|
78
|
+
return;
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
if (describedDataAxes === 'horizontal') {
|
|
82
|
+
mutableContainer.axesTitle.horizontal = title;
|
|
83
|
+
} else if (describedDataAxes === 'vertical') {
|
|
84
|
+
mutableContainer.axesTitle.vertical = title;
|
|
85
|
+
}
|
|
86
|
+
},
|
|
87
|
+
setPointsDensity: function setPointsDensity(horizontalAxes, verticalAxes) {
|
|
88
|
+
mutableContainer.pointsDensity = {
|
|
89
|
+
verticalAxes: verticalAxes,
|
|
90
|
+
horizontalAxes: horizontalAxes
|
|
91
|
+
};
|
|
92
|
+
}
|
|
93
|
+
};
|
|
94
|
+
return handler;
|
|
95
|
+
};
|
|
96
|
+
export var makeDataSummarizationConfig = function makeDataSummarizationConfig(config) {
|
|
97
|
+
var _config$trendTangens, _config$movingAverage;
|
|
98
|
+
|
|
99
|
+
return _objectSpread(_objectSpread({
|
|
100
|
+
clustersGridSize: undefined,
|
|
101
|
+
maxListSymbols: 100,
|
|
102
|
+
datesWithTime: undefined,
|
|
103
|
+
clustersLimit: 5,
|
|
104
|
+
valuesLimit: 5,
|
|
105
|
+
groupsLimit: 5,
|
|
106
|
+
dataType: undefined,
|
|
107
|
+
disable: false,
|
|
108
|
+
override: undefined
|
|
109
|
+
}, config !== null && config !== void 0 ? config : {}), {}, {
|
|
110
|
+
trendTangens: _objectSpread({
|
|
111
|
+
"static": 1 / 15,
|
|
112
|
+
weak: 1 / 10,
|
|
113
|
+
medium: 1 / 5,
|
|
114
|
+
strong: Infinity
|
|
115
|
+
}, (_config$trendTangens = config === null || config === void 0 ? void 0 : config.trendTangens) !== null && _config$trendTangens !== void 0 ? _config$trendTangens : {}),
|
|
116
|
+
movingAverage: _objectSpread({
|
|
117
|
+
longSize: undefined,
|
|
118
|
+
shortSize: undefined,
|
|
119
|
+
notableDiff: undefined
|
|
120
|
+
}, (_config$movingAverage = config === null || config === void 0 ? void 0 : config.movingAverage) !== null && _config$movingAverage !== void 0 ? _config$movingAverage : {})
|
|
121
|
+
});
|
|
122
|
+
};
|
|
123
|
+
//# sourceMappingURL=hints.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"hints.js","names":["makeDataHintsContainer","fields","verticalAxes","Set","horizontalAxes","valueAxes","values","groups","axesTitle","vertical","horizontal","titles","getVerticalAxesTitle","getHorizontalAxesTitle","valuesAxes","getValueAxesTitle","grid","dataType","pointsDensity","makeDataHintsHandlers","mutableContainer","handler","specifyDataRowFields","x","y","value","add","setupGrid","direction","size","establishDataType","describeValueEntity","dataKey","readableName","labelKey","describeGroupedValues","groupKey","axes","label","addKeyLabelGetter","getter","setTitle","describedDataAxes","title","Date","String","setPointsDensity","makeDataSummarizationConfig","config","clustersGridSize","undefined","maxListSymbols","datesWithTime","clustersLimit","valuesLimit","groupsLimit","disable","override","trendTangens","weak","medium","strong","Infinity","movingAverage","longSize","shortSize","notableDiff"],"sources":["../../../src/a11y/hints.ts"],"sourcesContent":["import { SerializableDataType } from './insights';\n\ntype DeepPartial<T> = T extends object\n ? {\n [P in keyof T]?: DeepPartial<T[P]>;\n }\n : T;\n\nexport type DataStructureHints = {\n fields: {\n verticalAxes: Set<string | number>;\n horizontalAxes: Set<string | number>;\n valueAxes: Set<string | number>;\n values: Set<string | number>;\n };\n groups: Set<string | number>;\n axesTitle: {\n vertical: string | null;\n horizontal: string | null;\n };\n titles: {\n verticalAxes: {\n [dataKey: string | number]: string;\n };\n getVerticalAxesTitle: null | ((dataKey: string | number) => string);\n horizontalAxes: {\n [dataKey: string | number]: string;\n };\n getHorizontalAxesTitle: null | ((dataKey: string | number) => string);\n valuesAxes: {\n [dataKey: string | number]: string;\n };\n getValueAxesTitle: null | ((dataKey: string | number) => string);\n };\n grid: {\n verticalAxes: number | null;\n horizontalAxes: number | null;\n };\n pointsDensity: {\n verticalAxes: number;\n horizontalAxes: number;\n } | null;\n dataType: SerializableDataType | null;\n};\nexport type DataSummarizationConfig = {\n trendTangens: {\n static: number;\n weak: number;\n medium: number;\n strong: number;\n };\n movingAverage: {\n longSize: number | undefined;\n shortSize: number | undefined;\n notableDiff: number | undefined;\n };\n dataType: SerializableDataType | undefined;\n clustersGridSize: number | undefined;\n maxListSymbols: number;\n datesWithTime: boolean | undefined;\n clustersLimit: number;\n valuesLimit: number;\n groupsLimit: number;\n disable: boolean;\n override: string | undefined;\n};\nexport type PartialDataSummarizationConfig = DeepPartial<DataSummarizationConfig>;\n\nexport const makeDataHintsContainer = (): DataStructureHints => ({\n fields: {\n verticalAxes: new Set(),\n horizontalAxes: new Set(),\n valueAxes: new Set(),\n values: new Set(),\n },\n groups: new Set(),\n axesTitle: {\n vertical: null,\n horizontal: null,\n },\n titles: {\n verticalAxes: {},\n getVerticalAxesTitle: null,\n horizontalAxes: {},\n getHorizontalAxesTitle: null,\n valuesAxes: {},\n getValueAxesTitle: null,\n },\n grid: {\n verticalAxes: null,\n horizontalAxes: null,\n },\n dataType: null,\n pointsDensity: null,\n});\n\nexport const makeDataHintsHandlers = (mutableContainer: DataStructureHints) => {\n const handler = {\n specifyDataRowFields: (x?: string, y?: string, value?: string) => {\n if (y) mutableContainer.fields.verticalAxes.add(y);\n if (x) mutableContainer.fields.horizontalAxes.add(x);\n if (value) mutableContainer.fields.valueAxes.add(value);\n },\n setupGrid: (direction: 'vertical' | 'horizontal', size: number) => {\n if (direction === 'horizontal') {\n mutableContainer.grid.horizontalAxes = size;\n } else if (direction === 'vertical') {\n mutableContainer.grid.verticalAxes = size;\n }\n },\n establishDataType: (dataType: SerializableDataType) => {\n mutableContainer.dataType = dataType;\n },\n describeValueEntity: (dataKey: string | number, readableName: string) => {\n mutableContainer.fields.values.add(dataKey);\n handler.labelKey('value', dataKey, readableName);\n },\n describeGroupedValues: (groupKey: string | number, dataKey: string | number) => {\n mutableContainer.groups.add(groupKey);\n mutableContainer.fields.values.add(dataKey);\n },\n labelKey: (\n axes: 'vertical' | 'horizontal' | 'value',\n dataKey: string | number,\n label: string,\n ) => {\n if (axes === 'vertical') mutableContainer.titles.verticalAxes[dataKey] = label;\n if (axes === 'horizontal') mutableContainer.titles.horizontalAxes[dataKey] = label;\n if (axes === 'value') mutableContainer.titles.valuesAxes[dataKey] = label;\n },\n addKeyLabelGetter: (\n axes: 'vertical' | 'horizontal' | 'value',\n getter: (dataKey: string | number) => string,\n ) => {\n if (axes === 'vertical') mutableContainer.titles.getVerticalAxesTitle = getter;\n if (axes === 'horizontal') mutableContainer.titles.getHorizontalAxesTitle = getter;\n if (axes === 'value') mutableContainer.titles.getValueAxesTitle = getter;\n },\n setTitle: (describedDataAxes: 'vertical' | 'horizontal', title: string) => {\n if (\n typeof title === 'number' ||\n typeof title === 'bigint' ||\n (typeof title === 'object' && (title as any) instanceof Date)\n ) {\n title = String(title);\n }\n if (typeof title !== 'string') {\n return;\n }\n if (describedDataAxes === 'horizontal') {\n mutableContainer.axesTitle.horizontal = title;\n } else if (describedDataAxes === 'vertical') {\n mutableContainer.axesTitle.vertical = title;\n }\n },\n setPointsDensity: (horizontalAxes: number, verticalAxes: number) => {\n mutableContainer.pointsDensity = { verticalAxes, horizontalAxes };\n },\n };\n return handler;\n};\n\nexport type DataHintsHandler = ReturnType<typeof makeDataHintsHandlers>;\n\nexport const makeDataSummarizationConfig = (\n config?: PartialDataSummarizationConfig,\n): DataSummarizationConfig => ({\n clustersGridSize: undefined,\n maxListSymbols: 100,\n datesWithTime: undefined,\n clustersLimit: 5,\n valuesLimit: 5,\n groupsLimit: 5,\n dataType: undefined,\n disable: false,\n override: undefined,\n ...(config ?? {}),\n trendTangens: {\n static: 1 / 15,\n weak: 1 / 10,\n medium: 1 / 5,\n strong: Infinity,\n ...(config?.trendTangens ?? {}),\n },\n movingAverage: {\n longSize: undefined,\n shortSize: undefined,\n notableDiff: undefined,\n ...(config?.movingAverage ?? {}),\n },\n});\n"],"mappings":"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"}
|