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,36 @@
'use client';
import * as React from 'react';
import { warnOnce } from "../warning/index.js";
/**
* Make sure a controlled prop is used correctly.
* Logs errors if the prop either:
*
* - switch between controlled and uncontrolled
* - modify it's default value
* @param parameters
*/
function useAssertModelConsistencyOutsideOfProduction(parameters) {
const {
componentName,
propName,
controlled,
defaultValue,
warningPrefix = 'MUI X'
} = parameters;
const [{
initialDefaultValue,
isControlled
}] = React.useState({
initialDefaultValue: defaultValue,
isControlled: controlled !== undefined
});
if (isControlled !== (controlled !== undefined)) {
warnOnce([`${warningPrefix}: A component is changing the ${isControlled ? '' : 'un'}controlled ${propName} state of ${componentName} to be ${isControlled ? 'un' : ''}controlled.`, 'Elements should not switch from uncontrolled to controlled (or vice versa).', `Decide between using a controlled or uncontrolled ${propName} ` + 'element for the lifetime of the component.', "The nature of the state is determined during the first render. It's considered controlled if the value is not `undefined`.", 'More info: https://fb.me/react-controlled-components'], 'error');
}
if (JSON.stringify(initialDefaultValue) !== JSON.stringify(defaultValue)) {
warnOnce([`${warningPrefix}: A component is changing the default ${propName} state of an uncontrolled ${componentName} after being initialized. ` + `To suppress this warning opt to use a controlled ${componentName}.`], 'error');
}
}
export const useAssertModelConsistency = process.env.NODE_ENV === 'production' ? () => {} : useAssertModelConsistencyOutsideOfProduction;