@fe6/water-pro
Version:
An enterprise-class UI design language and Vue-based implementation
42 lines (33 loc) • 1.5 kB
JavaScript
import { createVNode as _createVNode, resolveDirective as _resolveDirective } from "vue";
function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
import { __rest } from "tslib";
import Omit from 'omit.js';
import { tupleNum } from '../_util/type';
import PropTypes from '../_util/vue-types';
import warning from '../_util/warning';
import Base, { baseProps } from './Base';
var TITLE_ELE_LIST = tupleNum(1, 2, 3, 4, 5, 6);
var Title = function Title(props, _ref) {
var slots = _ref.slots,
attrs = _ref.attrs;
var _props$level = props.level,
level = _props$level === void 0 ? 1 : _props$level,
restProps = __rest(props, ["level"]);
var component;
if (TITLE_ELE_LIST.includes(level)) {
component = "h".concat(level);
} else {
warning(false, 'Typography', 'Title only accept `1 | 2 | 3 | 4 | 5` as `level` value.');
component = 'h1';
}
var titleProps = _extends(_extends(_extends({}, restProps), {
component: component
}), attrs);
return _createVNode(Base, titleProps, slots);
};
Title.displayName = 'ATypographyTitle';
Title.inheritAttrs = false;
Title.props = Omit(_extends(_extends({}, baseProps()), {
level: PropTypes.number
}), ['component', 'strong']);
export default Title;