1
0
Fork 0

Added Statistics calculation

Statistics now show calculated values
This commit is contained in:
Techognito 2025-09-04 17:30:00 +02:00
parent fe87374e47
commit fc0f69dacb
2147 changed files with 141321 additions and 39 deletions

View file

@ -0,0 +1,14 @@
import * as React from 'react';
export interface ToolbarContextValue {
focusableItemId: string | null;
registerItem: (id: string, ref: React.RefObject<HTMLButtonElement | null>) => void;
unregisterItem: (id: string) => void;
onItemKeyDown: (event: React.KeyboardEvent<HTMLButtonElement>) => void;
onItemFocus: (id: string) => void;
onItemDisabled: (id: string, disabled: boolean) => void;
}
export declare const ToolbarContext: React.Context<ToolbarContextValue | undefined>;
export declare function useToolbarContext(): ToolbarContextValue;
export declare function ToolbarContextProvider({
children
}: React.PropsWithChildren): React.JSX.Element;

View file

@ -0,0 +1,171 @@
"use strict";
'use client';
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.ToolbarContext = void 0;
exports.ToolbarContextProvider = ToolbarContextProvider;
exports.useToolbarContext = useToolbarContext;
var React = _interopRequireWildcard(require("react"));
var _jsxRuntime = require("react/jsx-runtime");
const ToolbarContext = exports.ToolbarContext = /*#__PURE__*/React.createContext(undefined);
if (process.env.NODE_ENV !== "production") ToolbarContext.displayName = "ToolbarContext";
function useToolbarContext() {
const context = React.useContext(ToolbarContext);
if (context === undefined) {
throw new Error('MUI X: Missing context. Toolbar subcomponents must be placed within a <Toolbar /> component.');
}
return context;
}
function ToolbarContextProvider({
children
}) {
const [focusableItemId, setFocusableItemId] = React.useState(null);
const focusableItemIdRef = React.useRef(focusableItemId);
const [items, setItems] = React.useState([]);
const getSortedItems = React.useCallback(() => items.sort(sortByDocumentPosition), [items]);
const findEnabledItem = React.useCallback((startIndex, step, wrap = true) => {
let index = startIndex;
const sortedItems = getSortedItems();
const itemCount = sortedItems.length;
// Look for enabled items in the specified direction
for (let i = 0; i < itemCount; i += 1) {
index += step;
// Handle wrapping around the ends
if (index >= itemCount) {
if (!wrap) {
return -1;
}
index = 0;
} else if (index < 0) {
if (!wrap) {
return -1;
}
index = itemCount - 1;
}
// Return if we found an enabled item
if (!sortedItems[index].ref.current?.disabled && sortedItems[index].ref.current?.ariaDisabled !== 'true') {
return index;
}
}
// If we've checked all items and found none enabled
return -1;
}, [getSortedItems]);
const registerItem = React.useCallback((id, itemRef) => {
setItems(prevItems => [...prevItems, {
id,
ref: itemRef
}]);
}, []);
const unregisterItem = React.useCallback(id => {
setItems(prevItems => prevItems.filter(i => i.id !== id));
}, []);
const onItemKeyDown = React.useCallback(event => {
if (!focusableItemId) {
return;
}
const sortedItems = getSortedItems();
const focusableItemIndex = sortedItems.findIndex(item => item.id === focusableItemId);
let newIndex = -1;
if (event.key === 'ArrowRight') {
event.preventDefault();
newIndex = findEnabledItem(focusableItemIndex, 1);
} else if (event.key === 'ArrowLeft') {
event.preventDefault();
newIndex = findEnabledItem(focusableItemIndex, -1);
} else if (event.key === 'Home') {
event.preventDefault();
newIndex = findEnabledItem(-1, 1, false);
} else if (event.key === 'End') {
event.preventDefault();
newIndex = findEnabledItem(sortedItems.length, -1, false);
}
// TODO: Check why this is necessary
if (newIndex >= 0 && newIndex < sortedItems.length) {
const item = sortedItems[newIndex];
setFocusableItemId(item.id);
item.ref.current?.focus();
}
}, [getSortedItems, focusableItemId, findEnabledItem]);
const onItemFocus = React.useCallback(id => {
if (focusableItemId !== id) {
setFocusableItemId(id);
}
}, [focusableItemId, setFocusableItemId]);
const onItemDisabled = React.useCallback(id => {
const sortedItems = getSortedItems();
const currentIndex = sortedItems.findIndex(item => item.id === id);
const newIndex = findEnabledItem(currentIndex, 1);
if (newIndex >= 0 && newIndex < sortedItems.length) {
const item = sortedItems[newIndex];
setFocusableItemId(item.id);
item.ref.current?.focus();
}
}, [getSortedItems, findEnabledItem]);
React.useEffect(() => {
focusableItemIdRef.current = focusableItemId;
}, [focusableItemId]);
React.useEffect(() => {
const sortedItems = getSortedItems();
if (sortedItems.length > 0) {
// Set initial focusable item
if (!focusableItemIdRef.current) {
setFocusableItemId(sortedItems[0].id);
return;
}
const focusableItemIndex = sortedItems.findIndex(item => item.id === focusableItemIdRef.current);
if (!sortedItems[focusableItemIndex]) {
// Last item has been removed from the items array
const item = sortedItems[sortedItems.length - 1];
if (item) {
setFocusableItemId(item.id);
item.ref.current?.focus();
}
} else if (focusableItemIndex === -1) {
// Focused item has been removed from the items array
const item = sortedItems[focusableItemIndex];
if (item) {
setFocusableItemId(item.id);
item.ref.current?.focus();
}
}
}
}, [getSortedItems, findEnabledItem]);
const contextValue = React.useMemo(() => ({
focusableItemId,
registerItem,
unregisterItem,
onItemKeyDown,
onItemFocus,
onItemDisabled
}), [focusableItemId, registerItem, unregisterItem, onItemKeyDown, onItemFocus, onItemDisabled]);
return /*#__PURE__*/(0, _jsxRuntime.jsx)(ToolbarContext.Provider, {
value: contextValue,
children: children
});
}
/* eslint-disable no-bitwise */
function sortByDocumentPosition(a, b) {
if (!a.ref.current || !b.ref.current) {
return 0;
}
const position = a.ref.current.compareDocumentPosition(b.ref.current);
if (!position) {
return 0;
}
if (position & Node.DOCUMENT_POSITION_FOLLOWING || position & Node.DOCUMENT_POSITION_CONTAINED_BY) {
return -1;
}
if (position & Node.DOCUMENT_POSITION_PRECEDING || position & Node.DOCUMENT_POSITION_CONTAINS) {
return 1;
}
return 0;
}

View file

@ -0,0 +1,2 @@
export * from "./ToolbarContext.js";
export * from "./useRegisterToolbarButton.js";

27
node_modules/@mui/x-internals/ToolbarContext/index.js generated vendored Normal file
View file

@ -0,0 +1,27 @@
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
var _ToolbarContext = require("./ToolbarContext");
Object.keys(_ToolbarContext).forEach(function (key) {
if (key === "default" || key === "__esModule") return;
if (key in exports && exports[key] === _ToolbarContext[key]) return;
Object.defineProperty(exports, key, {
enumerable: true,
get: function () {
return _ToolbarContext[key];
}
});
});
var _useRegisterToolbarButton = require("./useRegisterToolbarButton");
Object.keys(_useRegisterToolbarButton).forEach(function (key) {
if (key === "default" || key === "__esModule") return;
if (key in exports && exports[key] === _useRegisterToolbarButton[key]) return;
Object.defineProperty(exports, key, {
enumerable: true,
get: function () {
return _useRegisterToolbarButton[key];
}
});
});

View file

@ -0,0 +1,10 @@
import * as React from 'react';
interface ToolbarItemProps extends Pick<React.ComponentProps<'button'>, 'onKeyDown' | 'onFocus' | 'aria-disabled' | 'disabled'> {}
export declare function useRegisterToolbarButton(props: ToolbarItemProps, ref: React.RefObject<HTMLButtonElement | null>): {
tabIndex: number;
disabled: boolean | undefined;
'aria-disabled': (boolean | "true" | "false") | undefined;
onKeyDown: (event: React.KeyboardEvent<HTMLButtonElement>) => void;
onFocus: (event: React.FocusEvent<HTMLButtonElement>) => void;
};
export {};

View file

@ -0,0 +1,62 @@
"use strict";
'use client';
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.useRegisterToolbarButton = useRegisterToolbarButton;
var React = _interopRequireWildcard(require("react"));
var _useId = _interopRequireDefault(require("@mui/utils/useId"));
var _ToolbarContext = require("./ToolbarContext");
function useRegisterToolbarButton(props, ref) {
const {
onKeyDown,
onFocus,
disabled,
'aria-disabled': ariaDisabled
} = props;
const id = (0, _useId.default)();
const {
focusableItemId,
registerItem,
unregisterItem,
onItemKeyDown,
onItemFocus,
onItemDisabled
} = (0, _ToolbarContext.useToolbarContext)();
const handleKeyDown = event => {
onItemKeyDown(event);
onKeyDown?.(event);
};
const handleFocus = event => {
onItemFocus(id);
onFocus?.(event);
};
React.useEffect(() => {
registerItem(id, ref);
return () => unregisterItem(id);
}, [id, ref, registerItem, unregisterItem]);
const previousDisabled = React.useRef(disabled);
React.useEffect(() => {
if (previousDisabled.current !== disabled && disabled === true) {
onItemDisabled(id, disabled);
}
previousDisabled.current = disabled;
}, [disabled, id, onItemDisabled]);
const previousAriaDisabled = React.useRef(ariaDisabled);
React.useEffect(() => {
if (previousAriaDisabled.current !== ariaDisabled && ariaDisabled === true) {
onItemDisabled(id, true);
}
previousAriaDisabled.current = ariaDisabled;
}, [ariaDisabled, id, onItemDisabled]);
return {
tabIndex: focusableItemId === id ? 0 : -1,
disabled,
'aria-disabled': ariaDisabled,
onKeyDown: handleKeyDown,
onFocus: handleFocus
};
}