UNPKG

@aplus-frontend/antdv

Version:

Vue basic component library maintained based on ant-design-vue

58 lines (57 loc) 1.69 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = getFixScaleEleTransPosition; var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _css = require("../../vc-util/Dom/css"); function fixPoint(key, start, width, clientWidth) { const startAddWidth = start + width; const offsetStart = (width - clientWidth) / 2; if (width > clientWidth) { if (start > 0) { return { [key]: offsetStart }; } if (start < 0 && startAddWidth < clientWidth) { return { [key]: -offsetStart }; } } else if (start < 0 || startAddWidth > clientWidth) { return { [key]: start < 0 ? offsetStart : -offsetStart }; } return {}; } /** * Fix positon x,y point when * * Ele width && height < client * - Back origin * * - Ele width | height > clientWidth | clientHeight * - left | top > 0 -> Back 0 * - left | top + width | height < clientWidth | clientHeight -> Back left | top + width | height === clientWidth | clientHeight * * Regardless of other */ function getFixScaleEleTransPosition(width, height, left, top) { const { width: clientWidth, height: clientHeight } = (0, _css.getClientSize)(); let fixPos = null; if (width <= clientWidth && height <= clientHeight) { fixPos = { x: 0, y: 0 }; } else if (width > clientWidth || height > clientHeight) { fixPos = (0, _extends2.default)((0, _extends2.default)({}, fixPoint('x', left, width, clientWidth)), fixPoint('y', top, height, clientHeight)); } return fixPos; }