UNPKG

@kiwicom/orbit-components

Version:

Orbit-components is a React component library which provides developers with the easiest possible way of building Kiwi.com’s products.

73 lines (62 loc) 2.54 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray")); var _react = require("react"); var _index = _interopRequireDefault(require("../../../utils/boundingClientRect/index")); var useDimensions = function useDimensions(_ref, children, parent) { var containerRef = _ref.containerRef, tooltip = _ref.tooltip, content = _ref.content; var _useState = (0, _react.useState)({ containerTop: 0, containerTopPure: 0, containerLeft: 0, containerLeftPure: 0, containerHeight: 0, containerWidth: 0, tooltipWidth: 0, tooltipHeight: 0, windowWidth: 0, windowHeight: 0, contentHeight: 0 }), _useState2 = (0, _slicedToArray2.default)(_useState, 2), dimensions = _useState2[0], setDimensions = _useState2[1]; (0, _react.useEffect)(function () { var calculateDimensions = function calculateDimensions() { var containerDimensions = (0, _index.default)(containerRef); var tooltipDimensions = (0, _index.default)(tooltip); var contentDimensions = (0, _index.default)(content); if (containerDimensions && tooltipDimensions && contentDimensions && typeof window !== "undefined") { setDimensions({ containerTop: containerDimensions.top, containerTopPure: containerDimensions.top - (window.scrollY || window.pageYOffset), containerLeft: containerDimensions.left, containerLeftPure: containerDimensions.left - (window.scrollX || window.pageXOffset), containerHeight: containerDimensions.height, containerWidth: containerDimensions.width, tooltipWidth: tooltipDimensions.width, tooltipHeight: tooltipDimensions.height, windowWidth: window.innerWidth, windowHeight: window.innerHeight, contentHeight: contentDimensions.height }); } }; calculateDimensions(); window.addEventListener("resize", calculateDimensions); window.addEventListener("scroll", calculateDimensions); return function () { window.removeEventListener("resize", calculateDimensions); window.removeEventListener("scroll", calculateDimensions); }; }, [containerRef, content, tooltip, children, parent]); return dimensions; }; var _default = useDimensions; exports.default = _default;