@razorpay/blade
Version:
The Design System that powers Razorpay
84 lines (81 loc) • 3.9 kB
JavaScript
import _defineProperty from '@babel/runtime/helpers/defineProperty';
import _objectWithoutProperties from '@babel/runtime/helpers/objectWithoutProperties';
import React__default from 'react';
import styled from 'styled-components';
import { MENU_MIN_WIDTH, overlayPaddingX, overlayPaddingTop, overlayPaddingBottom } from './tokens.js';
import '../../utils/index.js';
import '../../utils/metaAttribute/index.js';
import { componentZIndices } from '../../utils/componentZIndices.js';
import '../Box/BaseBox/index.js';
import { jsx } from 'react/jsx-runtime';
import { BaseBox } from '../Box/BaseBox/BaseBox.web.js';
import { isReactNative } from '../../utils/platform/isReactNative.js';
import { getPopupBoxShadowString } from '../../utils/makePopupBoxShadow/makePopupBoxShadow.js';
import useTheme from '../BladeProvider/useTheme.js';
import { metaAttribute } from '../../utils/metaAttribute/metaAttribute.web.js';
import { MetaConstants } from '../../utils/metaAttribute/metaConstants.js';
var _excluded = ["children", "zIndex", "_transitionStyle", "minWidth", "maxWidth", "width", "offset", "testID"];
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
var UnfocussableOverlay = /*#__PURE__*/styled(BaseBox).withConfig({
displayName: "MenuOverlayweb__UnfocussableOverlay",
componentId: "sc-1nhzg4x-0"
})(function (_props) {
return {
'&:focus-visible': {
outline: 'none'
}
};
});
var StyledMenuOverlayContent = /*#__PURE__*/styled(BaseBox).withConfig({
displayName: "MenuOverlayweb__StyledMenuOverlayContent",
componentId: "sc-1nhzg4x-1"
})(function (_ref) {
var theme = _ref.theme,
colorScheme = _ref.colorScheme;
return {
backdropFilter: "blur(".concat(theme.backdropBlur.medium, "px)"),
boxShadow: isReactNative() ? undefined : getPopupBoxShadowString(theme, colorScheme)
};
});
var _MenuOverlay = function _MenuOverlay(_ref2, ref) {
var children = _ref2.children,
_ref2$zIndex = _ref2.zIndex,
zIndex = _ref2$zIndex === void 0 ? componentZIndices.dropdownOverlay : _ref2$zIndex,
_transitionStyle = _ref2._transitionStyle,
minWidth = _ref2.minWidth,
maxWidth = _ref2.maxWidth,
width = _ref2.width,
offset = _ref2.offset,
testID = _ref2.testID,
props = _objectWithoutProperties(_ref2, _excluded);
var _useTheme = useTheme(),
colorScheme = _useTheme.colorScheme;
void offset;
return /*#__PURE__*/jsx(UnfocussableOverlay, _objectSpread(_objectSpread(_objectSpread({
ref: ref
}, props), {}, {
zIndex: zIndex
}, metaAttribute({
name: MetaConstants.Menu,
testID: testID
})), {}, {
minWidth: minWidth !== null && minWidth !== void 0 ? minWidth : MENU_MIN_WIDTH,
width: width,
maxWidth: maxWidth,
children: /*#__PURE__*/jsx(StyledMenuOverlayContent, {
colorScheme: colorScheme,
backgroundColor: "popup.background.gray.moderate",
paddingX: overlayPaddingX,
paddingTop: overlayPaddingTop,
paddingBottom: overlayPaddingBottom,
borderWidth: "none",
borderRadius: "medium",
style: _transitionStyle,
children: children
})
}));
};
var MenuOverlay = /*#__PURE__*/React__default.forwardRef(_MenuOverlay);
export { MenuOverlay };
//# sourceMappingURL=MenuOverlay.web.js.map