feat: 支持 overflow 配置以允许拖拽超出可视区

This commit is contained in:
dullathanol
2026-04-07 11:41:39 +08:00
parent ad7ed50b52
commit 4e4ffc439c
5 changed files with 15 additions and 3 deletions

View File

@@ -46,6 +46,7 @@ export class ModalApi {
contentClass: '',
destroyOnClose: true,
draggable: false,
overflow: false,
footer: true,
footerClass: '',
fullscreen: false,

View File

@@ -110,6 +110,11 @@ export interface ModalProps {
* 是否自动聚焦
*/
openAutoFocus?: boolean;
/**
* 拖动范围是否可以超出可视区
* @default false
*/
overflow?: boolean;
/**
* 弹窗遮罩模糊效果
*/

View File

@@ -81,6 +81,7 @@ const {
description,
destroyOnClose,
draggable,
overflow,
footer: showFooter,
footerClass,
fullscreen,
@@ -122,6 +123,7 @@ const { dragging, transform } = useModalDraggable(
shouldDraggable,
getAppendTo,
shouldCentered,
overflow,
);
const firstOpened = ref(false);

View File

@@ -15,6 +15,7 @@ export function useModalDraggable(
draggable: ComputedRef<boolean>,
containerSelector?: ComputedRef<string | undefined>,
centered?: ComputedRef<boolean>,
overflow?: ComputedRef<boolean>,
) {
const transform = reactive({
offsetX: 0,
@@ -67,8 +68,10 @@ export function useModalDraggable(
let moveX = offsetX + e.clientX - downX;
let moveY = offsetY + e.clientY - downY;
moveX = Math.min(Math.max(moveX, minLeft), maxLeft);
moveY = Math.min(Math.max(moveY, minTop), maxTop);
if (!overflow?.value) {
moveX = Math.min(Math.max(moveX, minLeft), maxLeft);
moveY = Math.min(Math.max(moveY, minTop), maxTop);
}
transform.offsetX = moveX;
transform.offsetY = moveY;