feat: update BackTop (#2415)

Co-authored-by: tangjinzhou <415800467@qq.com>
pull/2374/head
Albert Liu 2020-06-12 22:05:56 +08:00 committed by GitHub
parent f4c1c4569d
commit c6e22ce8ab
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 23 additions and 20 deletions

View File

@ -0,0 +1,9 @@
import PropTypes from '../_util/vue-types';
export default () => ({
visibilityHeight: PropTypes.number,
// onClick?: React.MouseEventHandler<any>;
target: PropTypes.func,
prefixCls: PropTypes.string,
onClick: PropTypes.func,
// visible: PropTypes.bool, // Only for test. Don't use it.
});

View File

@ -1,34 +1,30 @@
import PropTypes from '../_util/vue-types';
import backTopTypes from './backTopTypes';
import addEventListener from '../vc-util/Dom/addEventListener';
import getScroll from '../_util/getScroll';
import BaseMixin from '../_util/BaseMixin';
import getTransitionProps from '../_util/getTransitionProps';
import { ConfigConsumerProps } from '../config-provider';
import Base from '../base';
import { getListeners } from '../_util/props-util';
import scrollTo from '../_util/scrollTo';
import { inject } from 'vue';
function getDefaultTarget() {
return window;
}
const BackTopProps = {
visibilityHeight: PropTypes.number,
// onClick?: React.MouseEventHandler<any>;
target: PropTypes.func,
prefixCls: PropTypes.string,
// visible: PropTypes.bool, // Only for test. Don't use it.
};
const props = backTopTypes();
const BackTop = {
name: 'ABackTop',
mixins: [BaseMixin],
props: {
...BackTopProps,
...props,
visibilityHeight: PropTypes.number.def(400),
},
inject: {
configProvider: { default: () => ConfigConsumerProps },
setup() {
return {
configProvider: inject('configProvider', ConfigConsumerProps),
};
},
data() {
this.scrollEvent = null;
@ -88,15 +84,12 @@ const BackTop = {
</div>
);
const divProps = {
on: {
...getListeners(this),
click: this.scrollToTop,
},
onClick: this.scrollToTop,
class: prefixCls,
};
const backTopBtn = this.visible ? (
<div {...divProps}>{$slots.default || defaultElement}</div>
<div {...divProps}>{($slots.default && $slots.default()) || defaultElement}</div>
) : null;
const transitionProps = getTransitionProps('fade');
return <transition {...transitionProps}>{backTopBtn}</transition>;
@ -104,9 +97,8 @@ const BackTop = {
};
/* istanbul ignore next */
BackTop.install = function(Vue) {
Vue.use(Base);
Vue.component(BackTop.name, BackTop);
BackTop.install = function(app) {
app.component(BackTop.name, BackTop);
};
export default BackTop;

View File

@ -21,6 +21,7 @@ import Col from 'ant-design-vue/col';
import Row from 'ant-design-vue/row';
import Tooltip from 'ant-design-vue/tooltip';
import Descriptions from 'ant-design-vue/descriptions';
import BackTop from 'ant-design-vue/back-top';
import Tag from 'ant-design-vue/tag';
import 'ant-design-vue/style.js';
@ -45,5 +46,6 @@ createApp(App)
.use(Row)
.use(Tooltip)
.use(Descriptions)
.use(BackTop)
.use(Tag)
.mount('#app');