antd
Version:
An enterprise-class UI design language and React-based implementation
92 lines (81 loc) • 3.2 kB
JavaScript
import _defineProperty from 'babel-runtime/helpers/defineProperty';
import _extends from 'babel-runtime/helpers/extends';
import _classCallCheck from 'babel-runtime/helpers/classCallCheck';
import _createClass from 'babel-runtime/helpers/createClass';
import _possibleConstructorReturn from 'babel-runtime/helpers/possibleConstructorReturn';
import _inherits from 'babel-runtime/helpers/inherits';
var __rest = this && this.__rest || function (s, e) {
var t = {};
for (var p in s) {
if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];
}if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
if (e.indexOf(p[i]) < 0) t[p[i]] = s[p[i]];
}return t;
};
import React from 'react';
import classNames from 'classnames';
function generator(props) {
return function (BacicComponent) {
return function (_React$Component) {
_inherits(Adapter, _React$Component);
function Adapter() {
_classCallCheck(this, Adapter);
return _possibleConstructorReturn(this, (Adapter.__proto__ || Object.getPrototypeOf(Adapter)).apply(this, arguments));
}
_createClass(Adapter, [{
key: 'render',
value: function render() {
var prefixCls = props.prefixCls;
return React.createElement(BacicComponent, _extends({ prefixCls: prefixCls }, this.props));
}
}]);
return Adapter;
}(React.Component);
};
}
var Basic = function (_React$Component2) {
_inherits(Basic, _React$Component2);
function Basic() {
_classCallCheck(this, Basic);
return _possibleConstructorReturn(this, (Basic.__proto__ || Object.getPrototypeOf(Basic)).apply(this, arguments));
}
_createClass(Basic, [{
key: 'render',
value: function render() {
var _a = this.props,
prefixCls = _a.prefixCls,
className = _a.className,
children = _a.children,
others = __rest(_a, ["prefixCls", "className", "children"]);
var hasSider = void 0;
React.Children.forEach(children, function (element) {
if (element && element.type && element.type.__ANT_LAYOUT_SIDER) {
hasSider = true;
}
});
var divCls = classNames(className, prefixCls, _defineProperty({}, prefixCls + '-has-sider', hasSider));
return React.createElement(
'div',
_extends({ className: divCls }, others),
children
);
}
}]);
return Basic;
}(React.Component);
var Layout = generator({
prefixCls: 'ant-layout'
})(Basic);
var Header = generator({
prefixCls: 'ant-layout-header'
})(Basic);
var Footer = generator({
prefixCls: 'ant-layout-footer'
})(Basic);
var Content = generator({
prefixCls: 'ant-layout-content'
})(Basic);
Layout.Header = Header;
Layout.Footer = Footer;
Layout.Content = Content;
export default Layout;