UNPKG

@mantine/core

Version:

React components library focused on usability, accessibility and developer experience

109 lines (106 loc) 3.63 kB
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