UNPKG

@elastic/eui

Version:

Elastic UI Component Library

132 lines (130 loc) 5.54 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.SIZES = exports.EuiPanel = exports.COLORS = exports.BORDER_RADII = void 0; var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties")); var _react = _interopRequireDefault(require("react")); var _propTypes = _interopRequireDefault(require("prop-types")); var _classnames = _interopRequireDefault(require("classnames")); var _services = require("../../services"); var _global_styling = require("../../global_styling"); var _common = require("../common"); var _panel = require("./panel.styles"); var _react2 = require("@emotion/react"); var _excluded = ["children", "className", "paddingSize", "borderRadius", "color", "hasShadow", "hasBorder", "grow", "panelRef", "element"]; /* * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one * or more contributor license agreements. Licensed under the Elastic License * 2.0 and the Server Side Public License, v 1; you may not use this file except * in compliance with, at your election, the Elastic License 2.0 or the Server * Side Public License, v 1. */ var SIZES = exports.SIZES = _global_styling.PADDING_SIZES; // Exported padding sizes and class names necessary for EuiPopover and EuiCard. // Which currently will only maintain support for the original values until conversion. var paddingSizeToClassNameMap = { none: null, s: 'paddingSmall', m: 'paddingMedium', l: 'paddingLarge' }; var _SIZES = (0, _common.keysOf)(paddingSizeToClassNameMap); var BORDER_RADII = exports.BORDER_RADII = ['none', 'm']; var COLORS = exports.COLORS = _global_styling.BACKGROUND_COLORS; var EuiPanel = exports.EuiPanel = function EuiPanel(_ref) { var children = _ref.children, className = _ref.className, _ref$paddingSize = _ref.paddingSize, paddingSize = _ref$paddingSize === void 0 ? 'm' : _ref$paddingSize, _ref$borderRadius = _ref.borderRadius, borderRadius = _ref$borderRadius === void 0 ? 'm' : _ref$borderRadius, _ref$color = _ref.color, color = _ref$color === void 0 ? 'plain' : _ref$color, _ref$hasShadow = _ref.hasShadow, hasShadow = _ref$hasShadow === void 0 ? true : _ref$hasShadow, _ref$hasBorder = _ref.hasBorder, hasBorder = _ref$hasBorder === void 0 ? false : _ref$hasBorder, _ref$grow = _ref.grow, grow = _ref$grow === void 0 ? true : _ref$grow, panelRef = _ref.panelRef, element = _ref.element, rest = (0, _objectWithoutProperties2.default)(_ref, _excluded); // Shadows are only allowed when there's a white background (plain) var canHaveShadow = !hasBorder && color === 'plain'; var canHaveBorder = color === 'plain' || color === 'transparent'; var styles = (0, _services.useEuiMemoizedStyles)(_panel.euiPanelStyles); var cssStyles = [styles.euiPanel, grow && styles.grow, styles.radius[borderRadius], (0, _global_styling.useEuiPaddingCSS)()[paddingSize], (0, _global_styling.useEuiBackgroundColorCSS)()[color], canHaveShadow && hasShadow === true && styles.hasShadow, canHaveBorder && hasBorder === true && styles.hasBorder, rest.onClick && styles.isClickable]; var classes = (0, _classnames.default)('euiPanel', "euiPanel--".concat(color), (0, _defineProperty2.default)({}, "euiPanel--".concat(paddingSizeToClassNameMap[paddingSize]), paddingSizeToClassNameMap[paddingSize]), className); if (rest.onClick && element !== 'div') { return (0, _react2.jsx)("button", (0, _extends2.default)({ ref: panelRef, className: classes, css: cssStyles }, rest), children); } return (0, _react2.jsx)("div", (0, _extends2.default)({ ref: panelRef, className: classes, css: cssStyles }, rest), children); }; EuiPanel.propTypes = { element: _propTypes.default.oneOfType([_propTypes.default.oneOf(["button"]), _propTypes.default.oneOf(["div"])]), /** * Adds a medium shadow to the panel; * Only works when `color="plain"` */ /** * Adds a medium shadow to the panel; * Only works when `color="plain"` */ hasShadow: _propTypes.default.bool, /** * Adds a slight 1px border on all edges. * Only works when `color="plain | transparent"` */ /** * Adds a slight 1px border on all edges. * Only works when `color="plain | transparent"` */ hasBorder: _propTypes.default.bool, /** * Padding for all four sides */ /** * Padding for all four sides */ paddingSize: _propTypes.default.any, /** * Corner border radius */ /** * Corner border radius */ borderRadius: _propTypes.default.any, /** * When true the panel will grow in height to match `EuiFlexItem` */ /** * When true the panel will grow in height to match `EuiFlexItem` */ grow: _propTypes.default.bool, panelRef: _propTypes.default.any, /** * Background color of the panel; * Usually a lightened form of the brand colors */ /** * Background color of the panel; * Usually a lightened form of the brand colors */ color: _propTypes.default.any, className: _propTypes.default.string, "aria-label": _propTypes.default.string, "data-test-subj": _propTypes.default.string, css: _propTypes.default.any };