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 @@ 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 @@