@mantine/core
Version:
React components library focused on usability, accessibility and developer experience
109 lines (106 loc) • 3.63 kB
JavaScript
import React, { forwardRef } from 'react';
import { getDefaultZIndex, useComponentDefaultProps } from '@mantine/styles';
import useStyles from './LoadingOverlay.styles.js';
import { Transition } from '../Transition/Transition.js';
import { Box } from '../Box/Box.js';
import { Loader } from '../Loader/Loader.js';
import { Overlay } from '../Overlay/Overlay.js';
var __defProp = Object.defineProperty;
var __defProps = Object.defineProperties;
var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
var __hasOwnProp = Object.prototype.hasOwnProperty;
var __propIsEnum = Object.prototype.propertyIsEnumerable;
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
var __spreadValues = (a, b) => {
for (var prop in b || (b = {}))
if (__hasOwnProp.call(b, prop))
__defNormalProp(a, prop, b[prop]);
if (__getOwnPropSymbols)
for (var prop of __getOwnPropSymbols(b)) {
if (__propIsEnum.call(b, prop))
__defNormalProp(a, prop, b[prop]);
}
return a;
};
var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
var __objRest = (source, exclude) => {
var target = {};
for (var prop in source)
if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)
target[prop] = source[prop];
if (source != null && __getOwnPropSymbols)
for (var prop of __getOwnPropSymbols(source)) {
if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
target[prop] = source[prop];
}
return target;
};
const defaultProps = {
overlayOpacity: 0.75,
transitionDuration: 0,
radius: 0,
zIndex: getDefaultZIndex("overlay")
};
const LoadingOverlay = forwardRef((props, ref) => {
const _a = useComponentDefaultProps("LoadingOverlay", defaultProps, props), {
className,
visible,
loaderProps,
overlayOpacity,
overlayColor,
transitionDuration,
exitTransitionDuration,
zIndex,
style,
loader,
radius,
overlayBlur,
unstyled,
variant,
keepMounted
} = _a, others = __objRest(_a, [
"className",
"visible",
"loaderProps",
"overlayOpacity",
"overlayColor",
"transitionDuration",
"exitTransitionDuration",
"zIndex",
"style",
"loader",
"radius",
"overlayBlur",
"unstyled",
"variant",
"keepMounted"
]);
const { classes, cx, theme } = useStyles(null, { name: "LoadingOverlay", unstyled, variant });
const _zIndex = `calc(${zIndex} + 1)`;
return /* @__PURE__ */ React.createElement(Transition, {
keepMounted,
duration: transitionDuration,
exitDuration: exitTransitionDuration,
mounted: visible,
transition: "fade"
}, (transitionStyles) => /* @__PURE__ */ React.createElement(Box, __spreadValues({
className: cx(classes.root, className),
style: __spreadProps(__spreadValues(__spreadValues({}, transitionStyles), style), { zIndex }),
ref
}, others), loader ? /* @__PURE__ */ React.createElement("div", {
style: { zIndex: _zIndex }
}, loader) : /* @__PURE__ */ React.createElement(Loader, __spreadValues({
style: { zIndex: _zIndex }
}, loaderProps)), /* @__PURE__ */ React.createElement(Overlay, {
opacity: overlayOpacity,
zIndex,
radius,
blur: overlayBlur,
unstyled,
color: overlayColor || (theme.colorScheme === "dark" ? theme.colors.dark[5] : theme.white)
})));
});
LoadingOverlay.displayName = "@mantine/core/LoadingOverlay";
export { LoadingOverlay };
//# sourceMappingURL=LoadingOverlay.js.map