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.

79 lines (65 loc) 3.14 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _react = require("react"); var _index = _interopRequireDefault(require("../../utils/boundingClientRect/index")); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _nonIterableRest(); } function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance"); } function _iterableToArrayLimit(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; } function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; } var useDimensions = function useDimensions(_ref, children) { 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 = _slicedToArray(_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]); return dimensions; }; var _default = useDimensions; exports.default = _default;