mirror of
https://gitee.com/vant-contrib/vant.git
synced 2025-04-06 03:57:59 +08:00
[improvement] Overlay: functional & tsx (#2822)
This commit is contained in:
parent
ea36edbd1a
commit
91a9345a7d
@ -1,6 +1,6 @@
|
||||
import Vue from 'vue';
|
||||
import context from './context';
|
||||
import Overlay from '../../overlay';
|
||||
import { mount } from '../../utils/functional';
|
||||
|
||||
const defaultConfig = {
|
||||
className: '',
|
||||
@ -35,10 +35,11 @@ export default {
|
||||
let { modal } = context;
|
||||
|
||||
if (!modal) {
|
||||
modal = new (Vue.extend(Overlay))({
|
||||
el: document.createElement('div')
|
||||
modal = mount(Overlay, {
|
||||
on: {
|
||||
click: this.onClick
|
||||
}
|
||||
});
|
||||
modal.$on('click', this.onClick);
|
||||
|
||||
context.modal = modal;
|
||||
}
|
||||
|
@ -1,36 +0,0 @@
|
||||
import { use } from '../utils';
|
||||
|
||||
const [sfc, bem] = use('overlay');
|
||||
|
||||
export default sfc({
|
||||
props: {
|
||||
zIndex: Number,
|
||||
className: null,
|
||||
visible: Boolean,
|
||||
customStyle: Object
|
||||
},
|
||||
|
||||
render(h) {
|
||||
const style = {
|
||||
zIndex: this.zIndex,
|
||||
...this.customStyle
|
||||
};
|
||||
|
||||
return (
|
||||
<transition name="van-fade">
|
||||
<div
|
||||
vShow={this.visible}
|
||||
style={style}
|
||||
class={[bem(), this.className]}
|
||||
onTouchmove={event => {
|
||||
event.preventDefault();
|
||||
event.stopPropagation();
|
||||
}}
|
||||
onClick={event => {
|
||||
this.$emit('click', event);
|
||||
}}
|
||||
/>
|
||||
</transition>
|
||||
);
|
||||
}
|
||||
});
|
58
packages/overlay/index.tsx
Normal file
58
packages/overlay/index.tsx
Normal file
@ -0,0 +1,58 @@
|
||||
import { use } from '../utils';
|
||||
import { emit, inherit } from '../utils/functional';
|
||||
|
||||
// Types
|
||||
import { CreateElement, RenderContext } from 'vue/types';
|
||||
import { DefaultSlots } from '../utils/use/sfc';
|
||||
|
||||
export type OverlayProps = {
|
||||
zIndex?: number;
|
||||
className?: any;
|
||||
visible?: boolean;
|
||||
customStyle?: object;
|
||||
};
|
||||
|
||||
export type OverlayEvents = {
|
||||
click(event: Event): void;
|
||||
};
|
||||
|
||||
const [sfc, bem] = use('overlay');
|
||||
|
||||
function Overlay(
|
||||
h: CreateElement,
|
||||
props: OverlayProps,
|
||||
slots: DefaultSlots,
|
||||
ctx: RenderContext<OverlayProps>
|
||||
) {
|
||||
const style = {
|
||||
zIndex: props.zIndex,
|
||||
...props.customStyle
|
||||
};
|
||||
|
||||
return (
|
||||
<transition name="van-fade">
|
||||
<div
|
||||
vShow={props.visible}
|
||||
style={style}
|
||||
class={[bem(), props.className]}
|
||||
onTouchmove={(event: TouchEvent) => {
|
||||
event.preventDefault();
|
||||
event.stopPropagation();
|
||||
}}
|
||||
onClick={(event: Event) => {
|
||||
emit(ctx, 'click', event);
|
||||
}}
|
||||
{...inherit(ctx, true)}
|
||||
/>
|
||||
</transition>
|
||||
);
|
||||
}
|
||||
|
||||
Overlay.props = {
|
||||
zIndex: Number,
|
||||
className: null as any,
|
||||
visible: Boolean,
|
||||
customStyle: Object
|
||||
};
|
||||
|
||||
export default sfc<OverlayProps, OverlayEvents>(Overlay);
|
@ -58,12 +58,15 @@ export function emit(context: Context, eventName: string, ...args: any[]) {
|
||||
}
|
||||
|
||||
// mount functional component
|
||||
export function mount(Component: any) {
|
||||
export function mount(Component: any, data?: VNodeData) {
|
||||
const instance = new Vue({
|
||||
el: document.createElement('div'),
|
||||
props: Component.props,
|
||||
render(h) {
|
||||
return h(Component, { props: this.$props });
|
||||
return h(Component, {
|
||||
props: this.$props,
|
||||
...data
|
||||
});
|
||||
}
|
||||
});
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user