diff --git a/CHANGELOG.zh_CN.md b/CHANGELOG.zh_CN.md
index 008be46bed4..07da8279f6b 100644
--- a/CHANGELOG.zh_CN.md
+++ b/CHANGELOG.zh_CN.md
@@ -5,9 +5,14 @@
- 表单组件现在支持直接传入 model 直接进行 set 操作,参考**组件->弹窗扩展->打开弹窗并传递数据**
- modal 的 useModalInner 现在支持传入回调函数,用于接收外部`transferModalData`传进来的值,
+
- 用于处理打开弹窗对表单等组件的设置值。参考**组件->弹窗扩展->打开弹窗并传递数据**
- `receiveModalDataRef`这个值暂时保留。尽量少用。后续可能会删除。
+- drawer 的 useDrawerInner 现在支持传入回调函数,用于接收外部`transferModalData`传进来的值,
+ - 用于处理打开抽屉对表单等组件的设置值。参考**组件->抽屉扩展->打开抽屉并传递数据**
+ - `receiveModalDataRef`这个值暂时保留。尽量少用。后续可能会删除。
+
### ✨ Refactor
- 表单代码优化重构
diff --git a/src/components/Drawer/src/BasicDrawer.tsx b/src/components/Drawer/src/BasicDrawer.tsx
index e39667590fd..17b27cdcffd 100644
--- a/src/components/Drawer/src/BasicDrawer.tsx
+++ b/src/components/Drawer/src/BasicDrawer.tsx
@@ -1,17 +1,19 @@
-import { Drawer, Row, Col, Button } from 'ant-design-vue';
+import type { DrawerInstance, DrawerProps } from './types';
+
import { defineComponent, ref, computed, watchEffect, watch, unref, nextTick, toRaw } from 'vue';
+import { Drawer, Row, Col, Button } from 'ant-design-vue';
+
import { BasicTitle } from '/@/components/Basic';
import { FullLoading } from '/@/components/Loading/index';
-
-import { getSlot } from '/@/utils/helper/tsxHelper';
-
-import { DrawerInstance, DrawerProps } from './types';
+import { LeftOutlined } from '@ant-design/icons-vue';
import { basicProps } from './props';
+
+import { getSlot } from '/@/utils/helper/tsxHelper';
import { isFunction, isNumber } from '/@/utils/is';
-import { LeftOutlined } from '@ant-design/icons-vue';
import { buildUUID } from '/@/utils/uuid';
import { deepMerge } from '/@/utils';
+
import './index.less';
const prefixCls = 'basic-drawer';
@@ -31,7 +33,6 @@ export default defineComponent({
const getProps = computed(() => {
const opt: any = {
- // @ts-ignore
placement: 'right',
...attrs,
...props,
@@ -47,7 +48,6 @@ export default defineComponent({
opt.wrapClassName = opt.wrapClassName
? `${opt.wrapClassName} ${prefixCls}__detail`
: `${prefixCls}__detail`;
- // opt.maskClosable = false;
if (!opt.getContainer) {
opt.getContainer = `.default-layout__main`;
}
@@ -128,11 +128,11 @@ export default defineComponent({
{showOkBtn && (
@@ -152,13 +152,9 @@ export default defineComponent({
{() => (
<>
{props.showDetailBack && (
-
- {() => (
-
- )}
-
+
)}
{title && (
diff --git a/src/components/Drawer/src/types.ts b/src/components/Drawer/src/types.ts
index 38957d22588..e52def74624 100644
--- a/src/components/Drawer/src/types.ts
+++ b/src/components/Drawer/src/types.ts
@@ -5,10 +5,12 @@ import type { ScrollContainerOptions } from '/@/components/Container/index';
export interface DrawerInstance {
setDrawerProps: (props: Partial | boolean) => void;
}
+
export interface ReturnMethods extends DrawerInstance {
openDrawer: (visible?: boolean) => void;
transferDrawerData: (data: any) => void;
}
+
export type RegisterFn = (drawerInstance: DrawerInstance, uuid?: string) => void;
export interface ReturnInnerMethods extends DrawerInstance {
@@ -19,6 +21,7 @@ export interface ReturnInnerMethods extends DrawerInstance {
}
export type UseDrawerReturnType = [RegisterFn, ReturnMethods];
+
export type UseDrawerInnerReturnType = [RegisterFn, ReturnInnerMethods];
export interface DrawerFooterProps {
diff --git a/src/components/Drawer/src/useDrawer.ts b/src/components/Drawer/src/useDrawer.ts
index 914611cdda3..58ebc655638 100644
--- a/src/components/Drawer/src/useDrawer.ts
+++ b/src/components/Drawer/src/useDrawer.ts
@@ -5,8 +5,11 @@ import type {
DrawerProps,
UseDrawerInnerReturnType,
} from './types';
-import { ref, getCurrentInstance, onUnmounted, unref, reactive, computed } from 'vue';
+
+import { ref, getCurrentInstance, onUnmounted, unref, reactive, computed, watchEffect } from 'vue';
+
import { isProdMode } from '/@/utils/env';
+import { isFunction } from '/@/utils/is';
const dataTransferRef = reactive({});
/**
@@ -34,6 +37,7 @@ export function useDrawer(): UseDrawerReturnType {
drawerRef.value = drawerInstance;
loadedRef.value = true;
}
+
const getInstance = () => {
const instance = unref(drawerRef);
if (!instance) {
@@ -41,15 +45,18 @@ export function useDrawer(): UseDrawerReturnType {
}
return instance;
};
+
const methods: ReturnMethods = {
setDrawerProps: (props: Partial): void => {
getInstance().setDrawerProps(props);
},
+
openDrawer: (visible = true): void => {
getInstance().setDrawerProps({
visible: visible,
});
},
+
transferDrawerData(val: any) {
dataTransferRef[unref(uidRef)] = val;
},
@@ -57,7 +64,7 @@ export function useDrawer(): UseDrawerReturnType {
return [getDrawer, methods];
}
-export const useDrawerInner = (): UseDrawerInnerReturnType => {
+export const useDrawerInner = (callbackFn?: Fn): UseDrawerInnerReturnType => {
const drawerInstanceRef = ref(null);
const currentInstall = getCurrentInstance();
const uidRef = ref('');
@@ -65,6 +72,7 @@ export const useDrawerInner = (): UseDrawerInnerReturnType => {
if (!currentInstall) {
throw new Error('instance is undefined!');
}
+
const getInstance = () => {
const instance = unref(drawerInstanceRef);
if (!instance) {
@@ -72,26 +80,39 @@ export const useDrawerInner = (): UseDrawerInnerReturnType => {
}
return instance;
};
+
const register = (modalInstance: DrawerInstance, uuid: string) => {
uidRef.value = uuid;
drawerInstanceRef.value = modalInstance;
currentInstall.emit('register', modalInstance);
};
+
+ watchEffect(() => {
+ const data = dataTransferRef[unref(uidRef)];
+ if (!data) return;
+ if (!callbackFn || !isFunction(callbackFn)) return;
+ callbackFn(data);
+ });
+
return [
register,
{
receiveDrawerDataRef: computed(() => {
return dataTransferRef[unref(uidRef)];
}),
+
changeLoading: (loading = true) => {
getInstance().setDrawerProps({ loading });
},
+
changeOkLoading: (loading = true) => {
getInstance().setDrawerProps({ confirmLoading: loading });
},
+
closeDrawer: () => {
getInstance().setDrawerProps({ visible: false });
},
+
setDrawerProps: (props: Partial) => {
getInstance().setDrawerProps(props);
},
diff --git a/src/views/demo/comp/drawer/Drawer4.vue b/src/views/demo/comp/drawer/Drawer4.vue
index 1d5c01d639f..12eaff718d9 100644
--- a/src/views/demo/comp/drawer/Drawer4.vue
+++ b/src/views/demo/comp/drawer/Drawer4.vue
@@ -1,16 +1,56 @@
- 外部传递数据: {{ receiveDrawerDataRef }}
+
+
外部传递数据: {{ receiveDrawerDataRef }}
+
+
diff --git a/src/views/demo/comp/drawer/index.vue b/src/views/demo/comp/drawer/index.vue
index f92731d0c93..6db302fe40d 100644
--- a/src/views/demo/comp/drawer/index.vue
+++ b/src/views/demo/comp/drawer/index.vue
@@ -1,21 +1,20 @@
-
-
-
打开Drawer
+
+
+
打开Drawer
-
-
打开Drawer
-
-
打开Drawer
+
+
打开Drawer
+
+
打开Drawer
-
打开Drawer并传递数据
-
-
打开详情Drawer
+
打开Drawer并传递数据
+
+
打开详情Drawer
diff --git a/src/views/demo/comp/modal/index.vue b/src/views/demo/comp/modal/index.vue
index 8fa7c9b38ad..c12fd7fa491 100644
--- a/src/views/demo/comp/modal/index.vue
+++ b/src/views/demo/comp/modal/index.vue
@@ -1,26 +1,24 @@
-
+
-
打开弹窗 默认可以拖动/全屏
-
-
打开弹窗
-
-
打开弹窗
+
+
打开弹窗
+
+
打开弹窗
-
打开弹窗并传递数据
+
打开弹窗并传递数据