UNPKG

@blare/angular2gridster

Version:

[![npm version](https://badge.fury.io/js/angular2gridster.svg)](https://badge.fury.io/js/angular2gridster)

147 lines 18.8 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc */ /** @type {?} */ export const utils = { setCssElementPosition: function ($element, position) { $element.style.left = position.x + 'px'; $element.style.top = position.y + 'px'; }, resetCSSElementPosition: function ($element) { $element.style.left = ''; $element.style.top = ''; }, setTransform: function ($element, position) { /** @type {?} */ const left = position.x; /** @type {?} */ const top = position.y; // Replace unitless items with px /** @type {?} */ const translate = `translate(${left}px,${top}px)`; $element.style['transform'] = translate; $element.style['WebkitTransform'] = translate; $element.style['MozTransform'] = translate; $element.style['msTransform'] = translate; $element.style['OTransform'] = translate; }, resetTransform: function ($element) { $element.style['transform'] = ''; $element.style['WebkitTransform'] = ''; $element.style['MozTransform'] = ''; $element.style['msTransform'] = ''; $element.style['OTransform'] = ''; }, clearSelection: () => { if (document['selection']) { document['selection'].empty(); } else if (window.getSelection) { window.getSelection().removeAllRanges(); } }, isElementFitContainer: function (element, containerEl) { /** @type {?} */ const containerRect = containerEl.getBoundingClientRect(); /** @type {?} */ const elRect = element.getBoundingClientRect(); return elRect.left > containerRect.left && elRect.right < containerRect.right && elRect.top > containerRect.top && elRect.bottom < containerRect.bottom; }, isElementIntersectContainer: function (element, containerEl) { /** @type {?} */ const containerRect = containerEl.getBoundingClientRect(); /** @type {?} */ const elRect = element.getBoundingClientRect(); /** @type {?} */ const elWidth = elRect.right - elRect.left; /** @type {?} */ const elHeight = elRect.bottom - elRect.top; return (elRect.left + (elWidth / 2)) > containerRect.left && (elRect.right - (elWidth / 2)) < containerRect.right && (elRect.top + (elHeight / 2)) > containerRect.top && (elRect.bottom - (elHeight / 2)) < containerRect.bottom; }, isElementTouchContainer: function (element, containerEl) { /** @type {?} */ const containerRect = containerEl.getBoundingClientRect(); /** @type {?} */ const elRect = element.getBoundingClientRect(); return elRect.right > containerRect.left && elRect.bottom > containerRect.top && elRect.left < containerRect.right && elRect.top < containerRect.bottom; }, isCursorAboveElement: function (event, element) { /** @type {?} */ const elRect = element.getBoundingClientRect(); return event.pageX > elRect.left && event.pageX < elRect.right && event.pageY > elRect.top && event.pageY < elRect.bottom; }, getElementOuterHeight: function ($element) { /** @type {?} */ const styleObj = window.getComputedStyle($element); // NOTE: Manually calculating height because IE's `clientHeight` isn't always // reliable. return parseFloat(styleObj.getPropertyValue('height')) + parseFloat(styleObj.getPropertyValue('padding-top')) + parseFloat(styleObj.getPropertyValue('padding-bottom')); }, getRelativeCoordinates: (element, parentElement) => { /** @type {?} */ const parentElementRect = parentElement.getBoundingClientRect(); /** @type {?} */ const elementRect = element.getBoundingClientRect(); return { top: elementRect.top - parentElementRect.top, left: elementRect.left - parentElementRect.left }; }, /** * @param {?} node * @return {?} */ getScrollableContainer(node) { /** @type {?} */ const regex = /(auto|scroll)/; /** @type {?} */ const parents = (_node, ps) => { if (_node.parentNode === null) { return ps; } return parents(_node.parentNode, ps.concat([_node])); }; /** @type {?} */ const style = (_node, prop) => { return getComputedStyle(_node, null).getPropertyValue(prop); }; /** @type {?} */ const overflow = _node => { return (style(_node, 'overflow') + style(_node, 'overflow-y') + style(_node, 'overflow-x')); }; /** @type {?} */ const scroll = _node => regex.test(overflow(_node)); /* eslint-disable consistent-return */ /** @type {?} */ const scrollParent = _node => { if (!(_node instanceof HTMLElement || _node instanceof SVGElement)) { return; } /** @type {?} */ const ps = parents(_node.parentNode, []); for (let i = 0; i < ps.length; i += 1) { if (scroll(ps[i])) { return ps[i]; } } return document.scrollingElement || document.documentElement; }; return scrollParent(node); } }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"ng://@blare/angular2gridster/","sources":["lib/utils/utils.ts"],"names":[],"mappings":"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","sourcesContent":["\nimport {DraggableEvent} from './DraggableEvent';\n\nexport const utils = {\n    setCssElementPosition: function ($element: HTMLElement, position: {x: number, y: number}) {\n        $element.style.left = position.x + 'px';\n        $element.style.top = position.y + 'px';\n    },\n    resetCSSElementPosition: function ($element: HTMLElement) {\n        $element.style.left = '';\n        $element.style.top = '';\n    },\n    setTransform: function ($element: HTMLElement, position: {x: number, y: number}) {\n        const left = position.x;\n        const top = position.y;\n\n        // Replace unitless items with px\n        const translate = `translate(${left}px,${top}px)`;\n\n        $element.style['transform'] = translate;\n        $element.style['WebkitTransform'] = translate;\n        $element.style['MozTransform'] = translate;\n        $element.style['msTransform'] = translate;\n        $element.style['OTransform'] = translate;\n    },\n    resetTransform: function ($element: HTMLElement) {\n        $element.style['transform'] = '';\n        $element.style['WebkitTransform'] = '';\n        $element.style['MozTransform'] = '';\n        $element.style['msTransform'] = '';\n        $element.style['OTransform'] = '';\n    },\n    clearSelection: () => {\n        if (document['selection']) {\n            document['selection'].empty();\n        } else if (window.getSelection) {\n            window.getSelection().removeAllRanges();\n        }\n    },\n    isElementFitContainer: function (element: HTMLElement, containerEl: HTMLElement): boolean {\n        const containerRect = containerEl.getBoundingClientRect();\n        const elRect = element.getBoundingClientRect();\n\n        return elRect.left > containerRect.left &&\n            elRect.right < containerRect.right &&\n            elRect.top > containerRect.top &&\n            elRect.bottom < containerRect.bottom;\n    },\n    isElementIntersectContainer: function (element: HTMLElement, containerEl: HTMLElement): boolean {\n        const containerRect = containerEl.getBoundingClientRect();\n        const elRect = element.getBoundingClientRect();\n\n        const elWidth = elRect.right - elRect.left;\n        const elHeight = elRect.bottom - elRect.top;\n\n        return (elRect.left + (elWidth / 2)) > containerRect.left &&\n            (elRect.right - (elWidth / 2)) < containerRect.right &&\n            (elRect.top + (elHeight / 2)) > containerRect.top &&\n            (elRect.bottom - (elHeight / 2)) < containerRect.bottom;\n    },\n    isElementTouchContainer: function (element: HTMLElement, containerEl: HTMLElement): boolean {\n        const containerRect = containerEl.getBoundingClientRect();\n        const elRect = element.getBoundingClientRect();\n\n        return elRect.right > containerRect.left &&\n            elRect.bottom > containerRect.top &&\n            elRect.left < containerRect.right &&\n            elRect.top < containerRect.bottom;\n    },\n    isCursorAboveElement: function (event: DraggableEvent, element): boolean {\n        const elRect = element.getBoundingClientRect();\n\n        return event.pageX > elRect.left &&\n            event.pageX < elRect.right &&\n            event.pageY > elRect.top &&\n            event.pageY < elRect.bottom;\n    },\n    getElementOuterHeight: function ($element: HTMLElement) {\n        const styleObj = window.getComputedStyle($element);\n        // NOTE: Manually calculating height because IE's `clientHeight` isn't always\n        // reliable.\n        return parseFloat(styleObj.getPropertyValue('height')) +\n            parseFloat(styleObj.getPropertyValue('padding-top')) +\n            parseFloat(styleObj.getPropertyValue('padding-bottom'));\n    },\n    getRelativeCoordinates: (element, parentElement): {top: number, left: number} => {\n        const parentElementRect = parentElement.getBoundingClientRect();\n        const elementRect = element.getBoundingClientRect();\n\n        return {\n            top: elementRect.top - parentElementRect.top,\n            left: elementRect.left - parentElementRect.left\n        };\n    },\n    getScrollableContainer(node) {\n        const regex = /(auto|scroll)/;\n        const parents = (_node, ps) => {\n            if (_node.parentNode === null) {\n                return ps;\n            }\n            return parents(_node.parentNode, ps.concat([_node]));\n        };\n\n        const style = (_node, prop) => {\n            return getComputedStyle(_node, null).getPropertyValue(prop);\n        };\n        const overflow = _node => {\n            return (\n                style(_node, 'overflow') + style(_node, 'overflow-y') + style(_node, 'overflow-x')\n            );\n        };\n        const scroll = _node => regex.test(overflow(_node));\n\n        /* eslint-disable consistent-return */\n        const scrollParent = _node => {\n            if (!(_node instanceof HTMLElement || _node instanceof SVGElement)) {\n                return;\n            }\n\n            const ps = parents(_node.parentNode, []);\n\n            for (let i = 0; i < ps.length; i += 1) {\n                if (scroll(ps[i])) {\n                    return ps[i];\n                }\n            }\n\n            return document.scrollingElement || document.documentElement;\n        };\n\n        return scrollParent(node);\n    }\n};\n"]}