vant/src/overlay/index.js
2020-09-14 20:46:13 +08:00

53 lines
1.2 KiB
JavaScript

import { Transition } from 'vue';
import { createNamespace, isDef, noop } from '../utils';
import { preventDefault } from '../utils/dom/event';
import { useLazyRender } from '../composition/use-lazy-render';
const [createComponent, bem] = createNamespace('overlay');
function preventTouchMove(event) {
preventDefault(event, true);
}
export default createComponent({
props: {
show: Boolean,
zIndex: [Number, String],
duration: [Number, String],
className: null,
customStyle: Object,
lockScroll: {
type: Boolean,
default: true,
},
},
setup(props, { slots }) {
const lazyRender = useLazyRender(() => props.show);
const renderOverlay = lazyRender(() => {
const style = {
zIndex: props.zIndex,
...props.customStyle,
};
if (isDef(props.duration)) {
style.animationDuration = `${props.duration}s`;
}
return (
<div
vShow={props.show}
style={style}
class={[bem(), props.className]}
onTouchmove={props.lockScroll ? preventTouchMove : noop}
>
{slots.default?.()}
</div>
);
});
return () => <Transition name="van-fade">{renderOverlay()}</Transition>;
},
});