@material-ui/lab
Version:
Laboratory for new Material-UI modules.
43 lines (38 loc) • 1.54 kB
JavaScript
import * as React from 'react';
import { useUtils } from './useUtils';
import { validateDate, validateDateRange } from '../date-utils';
import { validateDateTime } from '../date-time-utils';
import { validateTime } from '../time-utils';
function isSameDateOrTimeError(a, b) {
return a === b;
}
function isSameDateRangeError(a, b) {
return b !== null && a[1] === b[1] && a[0] === b[0];
}
function useValidation(props, validate) {
var isSameError = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : isSameDateOrTimeError;
var value = props.value,
onError = props.onError;
var utils = useUtils();
var previousValidationErrorRef = React.useRef(null);
var validationError = validate(utils, value, props);
React.useEffect(function () {
if (onError && !isSameError(validationError, previousValidationErrorRef.current)) {
onError(validationError, value);
}
previousValidationErrorRef.current = validationError;
}, [isSameError, onError, previousValidationErrorRef, validationError, value]);
return validationError;
}
export function useTimeValidation(props) {
return useValidation(props, validateTime, isSameDateOrTimeError);
}
export function useDateValidation(props) {
return useValidation(props, validateDate, isSameDateOrTimeError);
}
export function useDateTimeValidation(props) {
return useValidation(props, validateDateTime, isSameDateOrTimeError);
}
export function useDateRangeValidation(props) {
return useValidation(props, validateDateRange, isSameDateRangeError);
}