easy-antd-modal
Version:
二次开发, 简化 Ant Design Modal 的使用方式
51 lines (49 loc) • 2.15 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _core = require("@dnd-kit/core");
var _modifiers = require("@dnd-kit/modifiers");
var React = _interopRequireWildcard(require("react"));
var _BaseModal = _interopRequireDefault(require("./BaseModal"));
var _jsxRuntime = require("react/jsx-runtime");
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
const defaultCoordinates = {
x: 0,
y: 0
};
/** @see [easy-antd-modal#DragModal](https://github.com/Wxh16144/easy-antd-modal/blob/master/src/drag-modal/index.tsx) */
function DragModal(props) {
const [{
x,
y
}, setCoordinates] = React.useState(defaultCoordinates);
const handleOpenChange = open => {
if (!open) {
setCoordinates(defaultCoordinates);
}
props.afterOpenChange?.(open);
};
return /*#__PURE__*/(0, _jsxRuntime.jsx)(_core.DndContext, {
modifiers: [_modifiers.restrictToWindowEdges],
onDragEnd: ({
delta
}) => setCoordinates(({
x,
y
}) => ({
x: x + delta.x,
y: y + delta.y
})),
children: /*#__PURE__*/(0, _jsxRuntime.jsx)(_BaseModal.default, {
...props,
afterOpenChange: handleOpenChange,
offsetX: x,
offsetY: y
})
});
}
var _default = exports.default = DragModal;