antdv-eoi
Version:
An enterprise-class UI design language and Vue-based implementation
41 lines (33 loc) • 1.3 kB
JavaScript
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = inViewport;
var _getElementPosition = _interopRequireDefault(require("./getElementPosition"));
var isHidden = function isHidden(element) {
return element.offsetParent === null;
};
function inViewport(element, container, customOffset) {
if (isHidden(element)) {
return false;
}
var top;
var bottom;
var left;
var right;
if (typeof container === 'undefined' || container === window) {
top = window.pageYOffset;
left = window.pageXOffset;
bottom = top + window.innerHeight;
right = left + window.innerWidth;
} else {
var containerPosition = (0, _getElementPosition.default)(container);
top = containerPosition.top;
left = containerPosition.left;
bottom = top + container.offsetHeight;
right = left + container.offsetWidth;
}
var elementPosition = (0, _getElementPosition.default)(element);
return top <= elementPosition.top + element.offsetHeight + customOffset.top && bottom >= elementPosition.top - customOffset.bottom && left <= elementPosition.left + element.offsetWidth + customOffset.left && right >= elementPosition.left - customOffset.right;
}
;