@carbon/ibm-security
Version:
Carbon for Cloud & Cognitive IBM Security UI components
73 lines (71 loc) • 5.04 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = 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 _classnames3 = _interopRequireDefault(require("classnames"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _react = _interopRequireWildcard(require("react"));
var _LayoutModule = _interopRequireWildcard(require("../LayoutModule"));
var _excluded = ["children", "element", "subsection", "title", "label", "labelDirection"];
/**
* @file Title bar module.
* @copyright IBM Security 2020 - 2021
*/
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
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) { (0, _defineProperty2.default)(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 namespace = 'title-bar';
/**
* Title bar modules provide interchangeable and reliable headings for establishing consistent hierarchies.
*/
var TitleBarModule = function TitleBarModule(_ref) {
var children = _ref.children,
element = _ref.element,
subsection = _ref.subsection,
title = _ref.title,
label = _ref.label,
labelDirection = _ref.labelDirection,
other = (0, _objectWithoutProperties2.default)(_ref, _excluded);
return /*#__PURE__*/_react.default.createElement(_LayoutModule.default, (0, _extends2.default)({
className: (0, _classnames3.default)((0, _defineProperty2.default)((0, _defineProperty2.default)({}, "".concat(_LayoutModule.layoutModuleNamespace, "--").concat(namespace, "--subsection"), subsection), "".concat(_LayoutModule.layoutModuleNamespace, "--").concat(namespace, "--label"), label)),
namespace: namespace
}, other), /*#__PURE__*/_react.default.createElement("div", {
className: "".concat(_LayoutModule.layoutModuleNamespace, "--").concat(namespace, "__label-wrapper")
}, label && /*#__PURE__*/_react.default.createElement(_LayoutModule.default, {
namespace: "".concat(namespace, "__label order--").concat(labelDirection)
}, label), /*#__PURE__*/(0, _react.createElement)(element, _objectSpread({}, (0, _LayoutModule.getLayoutModuleProps)({
namespace: "".concat(namespace, "__title")
})), title)), children && /*#__PURE__*/_react.default.createElement(_LayoutModule.default, {
className: (0, _classnames3.default)((0, _defineProperty2.default)({}, "".concat(_LayoutModule.layoutModuleNamespace, "--").concat(namespace, "__items--subsection"), subsection)),
namespace: "".concat(namespace, "__items")
}, children));
};
TitleBarModule.propTypes = {
/** Provide the items for the `TitleBarModule` */
children: _propTypes.default.node,
/** Specify the base element to use to build the title */
element: _propTypes.default.oneOf(['h1', 'h2', 'h3', 'h4', 'h5', 'h6']),
/** Provide the label for the `TitleBarModule` */
label: _propTypes.default.string,
/** Provide the labels direction for the `TitleBarModule` */
labelDirection: _propTypes.default.oneOf(['top', 'bottom']),
/** Specify whether a subsection should be used */
subsection: _propTypes.default.bool,
/** Provide the title of the `TitleBarModule` */
title: _propTypes.default.node.isRequired
};
TitleBarModule.defaultProps = {
children: null,
subsection: false,
element: 'h2',
label: null,
labelDirection: 'top'
};
var _default = exports.default = TitleBarModule;