2020-07-31 10:19:50 +00:00
|
|
|
import { inject, provide } from 'vue';
|
2019-01-12 03:33:27 +00:00
|
|
|
import PropTypes from '../_util/vue-types';
|
2020-08-31 08:53:19 +00:00
|
|
|
import classNames from '../_util/classNames';
|
2020-06-22 15:07:54 +00:00
|
|
|
import { getOptionProps, getSlot } from '../_util/props-util';
|
2020-09-30 02:47:18 +00:00
|
|
|
import { defaultConfigProvider } from '../config-provider';
|
2018-04-20 04:52:31 +00:00
|
|
|
|
|
|
|
export const BasicProps = {
|
|
|
|
prefixCls: PropTypes.string,
|
|
|
|
hasSider: PropTypes.boolean,
|
2020-03-07 11:45:13 +00:00
|
|
|
tagName: PropTypes.string,
|
2019-01-12 03:33:27 +00:00
|
|
|
};
|
2018-04-20 04:52:31 +00:00
|
|
|
|
2020-03-07 11:45:13 +00:00
|
|
|
function generator({ suffixCls, tagName, name }) {
|
2019-01-12 03:33:27 +00:00
|
|
|
return BasicComponent => {
|
2018-04-20 04:52:31 +00:00
|
|
|
return {
|
|
|
|
name,
|
|
|
|
props: BasicComponent.props,
|
2020-06-22 15:07:54 +00:00
|
|
|
setup() {
|
|
|
|
return {
|
2020-09-30 02:47:18 +00:00
|
|
|
configProvider: inject('configProvider', defaultConfigProvider),
|
2020-06-22 15:07:54 +00:00
|
|
|
};
|
2019-04-10 01:08:29 +00:00
|
|
|
},
|
2019-01-12 03:33:27 +00:00
|
|
|
render() {
|
2019-04-10 01:08:29 +00:00
|
|
|
const { prefixCls: customizePrefixCls } = this.$props;
|
2019-09-11 14:35:25 +00:00
|
|
|
const getPrefixCls = this.configProvider.getPrefixCls;
|
2019-04-10 01:08:29 +00:00
|
|
|
const prefixCls = getPrefixCls(suffixCls, customizePrefixCls);
|
|
|
|
|
2018-04-20 04:52:31 +00:00
|
|
|
const basicComponentProps = {
|
2020-06-22 15:07:54 +00:00
|
|
|
prefixCls,
|
|
|
|
...getOptionProps(this),
|
|
|
|
tagName,
|
2019-01-12 03:33:27 +00:00
|
|
|
};
|
2020-06-22 15:07:54 +00:00
|
|
|
return <BasicComponent {...basicComponentProps}>{getSlot(this)}</BasicComponent>;
|
2018-04-20 04:52:31 +00:00
|
|
|
},
|
2019-01-12 03:33:27 +00:00
|
|
|
};
|
|
|
|
};
|
2018-04-20 04:52:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
const Basic = {
|
|
|
|
props: BasicProps,
|
2019-01-12 03:33:27 +00:00
|
|
|
render() {
|
2020-06-22 15:07:54 +00:00
|
|
|
const { prefixCls, tagName: Tag } = this;
|
2018-04-20 04:52:31 +00:00
|
|
|
const divProps = {
|
|
|
|
class: prefixCls,
|
2019-01-12 03:33:27 +00:00
|
|
|
};
|
2020-06-22 15:07:54 +00:00
|
|
|
return <Tag {...divProps}>{getSlot(this)}</Tag>;
|
2018-04-20 04:52:31 +00:00
|
|
|
},
|
2019-01-12 03:33:27 +00:00
|
|
|
};
|
2018-04-20 04:52:31 +00:00
|
|
|
|
|
|
|
const BasicLayout = {
|
|
|
|
props: BasicProps,
|
2019-01-12 03:33:27 +00:00
|
|
|
data() {
|
2018-04-20 04:52:31 +00:00
|
|
|
return {
|
|
|
|
siders: [],
|
2019-01-12 03:33:27 +00:00
|
|
|
};
|
2018-04-20 04:52:31 +00:00
|
|
|
},
|
2020-07-31 10:19:50 +00:00
|
|
|
created() {
|
|
|
|
provide('siderHook', {
|
|
|
|
addSider: id => {
|
|
|
|
this.siders = [...this.siders, id];
|
2018-04-20 04:52:31 +00:00
|
|
|
},
|
2020-07-31 10:19:50 +00:00
|
|
|
removeSider: id => {
|
|
|
|
this.siders = this.siders.filter(currentId => currentId !== id);
|
|
|
|
},
|
|
|
|
});
|
2018-04-20 04:52:31 +00:00
|
|
|
},
|
2019-01-12 03:33:27 +00:00
|
|
|
render() {
|
2020-06-22 15:07:54 +00:00
|
|
|
const { prefixCls, hasSider, tagName: Tag } = this;
|
2018-04-20 04:52:31 +00:00
|
|
|
const divCls = classNames(prefixCls, {
|
2020-03-07 11:45:13 +00:00
|
|
|
[`${prefixCls}-has-sider`]: typeof hasSider === 'boolean' ? hasSider : this.siders.length > 0,
|
2019-01-12 03:33:27 +00:00
|
|
|
});
|
2018-04-20 04:52:31 +00:00
|
|
|
const divProps = {
|
|
|
|
class: divCls,
|
2019-01-12 03:33:27 +00:00
|
|
|
};
|
2020-06-22 15:07:54 +00:00
|
|
|
return <Tag {...divProps}>{getSlot(this)}</Tag>;
|
2018-04-20 04:52:31 +00:00
|
|
|
},
|
2019-01-12 03:33:27 +00:00
|
|
|
};
|
2018-04-20 04:52:31 +00:00
|
|
|
|
2020-03-07 11:45:13 +00:00
|
|
|
const Layout = generator({
|
|
|
|
suffixCls: 'layout',
|
|
|
|
tagName: 'section',
|
|
|
|
name: 'ALayout',
|
|
|
|
})(BasicLayout);
|
2018-04-20 04:52:31 +00:00
|
|
|
|
2020-03-07 11:45:13 +00:00
|
|
|
const Header = generator({
|
|
|
|
suffixCls: 'layout-header',
|
|
|
|
tagName: 'header',
|
|
|
|
name: 'ALayoutHeader',
|
|
|
|
})(Basic);
|
2018-04-20 04:52:31 +00:00
|
|
|
|
2020-03-07 11:45:13 +00:00
|
|
|
const Footer = generator({
|
|
|
|
suffixCls: 'layout-footer',
|
|
|
|
tagName: 'footer',
|
|
|
|
name: 'ALayoutFooter',
|
|
|
|
})(Basic);
|
2018-04-20 04:52:31 +00:00
|
|
|
|
2020-03-07 11:45:13 +00:00
|
|
|
const Content = generator({
|
|
|
|
suffixCls: 'layout-content',
|
|
|
|
tagName: 'main',
|
|
|
|
name: 'ALayoutContent',
|
|
|
|
})(Basic);
|
2018-04-20 04:52:31 +00:00
|
|
|
|
2019-01-12 03:33:27 +00:00
|
|
|
Layout.Header = Header;
|
|
|
|
Layout.Footer = Footer;
|
|
|
|
Layout.Content = Content;
|
2018-04-20 04:52:31 +00:00
|
|
|
|
2019-01-12 03:33:27 +00:00
|
|
|
export default Layout;
|