UNPKG

@ema/js-base-library

Version:

This library was generated with [Angular CLI](https://github.com/angular/angular-cli) version 7.2.0.

277 lines 26.9 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ /** * Provides utilities for DOM manipulation */ export class DomUtil { /** * Adds a class to a HTMLElement. * @param {?} el * @param {?} className * @return {?} */ static addClass(el, className) { if (el.classList) el.classList.add(className); else el.className += ' ' + className; } /** * Checks whether a HTMLElement has a class. * @param {?} el * @param {?} className * @return {?} */ static hasClass(el, className) { if (el.classList) el.classList.contains(className); else new RegExp('(^| )' + className + '( |$)', 'gi').test(el.className); } /** * Removes a class form a HTMLElement. * @param {?} el * @param {?} className * @return {?} */ static removeClass(el, className) { if (el.classList) el.classList.remove(className); else el.className = el.className.replace(new RegExp('(^|\\b)' + className.split(' ').join('|') + '(\\b|$)', 'gi'), ' '); } /** * Removes a class from a HTMLElement when present, or adds it when not present. * @param {?} el * @param {?} className * @return {?} */ static toggleClass(el, className) { if (el.classList) { el.classList.toggle(className); } else { /** @type {?} */ let classes = el.className.split(' '); /** @type {?} */ let existingIndex = classes.indexOf(className); if (existingIndex >= 0) classes.splice(existingIndex, 1); else classes.push(className); el.className = classes.join(' '); } } /** * Removes a HTMLElement from the DOM. * @param {?} el * @return {?} */ static remove(el) { el.parentNode.removeChild(el); } /** * Returns an object with all the attributes of a HTMLElement as key / value pairs. * @param {?} el * @return {?} */ static getAttributes(el) { /** @type {?} */ let attrs = el.attributes; /** @type {?} */ let obj = {}; /** @type {?} */ let i = 0; for (; i < attrs.length; i++) { obj[attrs[i].name] = attrs[i].value; } return obj; } /** * Sets attributes of a HTMLElement. * @param {?} el * @param {?} attributes * @return {?} */ static setAttributes(el, attributes) { Object.keys(attributes).forEach((/** * @param {?} k * @return {?} */ (k) => { el.setAttribute(k, attributes[k]); })); } /** * Get a style property of a HTMLElement. * @param {?} el * @param {?} styleProp * @return {?} */ static getStyle(el, styleProp) { /** @type {?} */ let value; /** @type {?} */ const defaultView = el.ownerDocument.defaultView; // W3C standard way: if (defaultView && defaultView.getComputedStyle) { // sanitize property name to css notation (hypen separated words eg. font-Size) styleProp = styleProp.replace(/([A-Z])/g, '-$1').toLowerCase(); return defaultView.getComputedStyle(el, null).getPropertyValue(styleProp); } else if (el['currentStyle']) { // IE // sanitize property name to camelCase styleProp = styleProp.replace(/\-(\w)/g, (/** * @param {?} str * @param {?} letter * @return {?} */ function (str, letter) { return letter.toUpperCase(); })); value = el['currentStyle'][styleProp]; // convert other units to pixels on IE if (/^\d+(em|pt|%|ex)?$/i.test(value)) { return ((/** * @param {?} value * @return {?} */ function (value) { /** @type {?} */ const oldLeft = el.style.left; /** @type {?} */ const oldRsLeft = el['runtimeStyle'].left; el['runtimeStyle'].left = el['currentStyle'].left; el.style.left = value || 0; value = el.style['pixelLeft'] + 'px'; el.style.left = oldLeft; el['runtimeStyle'].left = oldRsLeft; return value; }))(value); } return value; } } /** * Returns the width and height of the viewport. * @return {?} */ static viewportSize() { /** @type {?} */ let obj = { width: undefined, height: undefined }; if (typeof window !== 'undefined') { if (window.innerHeight) { obj.width = window.innerWidth; obj.height = window.innerHeight; } else { obj.width = document.documentElement.clientWidth; obj.height = document.documentElement.clientHeight; } } // todo: native if (typeof window === 'undefined') { } return obj; } /** * @param {?} str * @return {?} */ static copyToClipboard(str) { /** @type {?} */ const el = document.createElement('textarea'); el.value = str; // Set its value to the string that you want copied el.setAttribute('readonly', ''); // Make it readonly to be tamper-proof el.style.position = 'absolute'; el.style.left = '-9999px'; // Move outside the screen to make it invisible document.body.appendChild(el); // Append the <textarea> element to the HTML document // Append the <textarea> element to the HTML document /** @type {?} */ const selected = document.getSelection().rangeCount > 0 // Check if there is any content selected previously ? document.getSelection().getRangeAt(0) // Store selection if found : false; el.select(); // Select the <textarea> content document.execCommand('copy'); // Copy - only works as a result of a user action (e.g. click events) document.body.removeChild(el); // Remove the <textarea> element if (selected) { // If a selection existed before copying document.getSelection().removeAllRanges(); // Unselect everything on the HTML document document.getSelection().addRange(selected); // Restore the original selection } } /** * @param {?} el * @param {?=} duration * @param {?=} delay * @param {?=} display * @return {?} */ static fadeIn(el, duration = 300, delay = 0, display = 'block') { /** @type {?} */ let step = (1 / duration) * 10; el.style.opacity = '0'; el.style.display = display; setTimeout((/** * @return {?} */ () => { ((/** * @return {?} */ function fade() { /** @type {?} */ let val = parseFloat(el.style.opacity); if (!((val += step) > 1)) { el.style.opacity = val.toString(); requestAnimationFrame(fade); } }))(); }), delay); } /** * @param {?} el * @param {?=} duration * @param {?=} delay * @param {?=} visible * @return {?} */ static fadeOut(el, duration = 300, delay = 0, visible = false) { /** @type {?} */ let step = (1 / duration) * 10; el.style.opacity = '1'; setTimeout((/** * @return {?} */ () => { ((/** * @return {?} */ function fade() { /** @type {?} */ let opacity = Number(el.style.opacity); opacity = opacity - step; el.style.opacity = opacity.toString(); if (opacity < 0) { if (visible === false) { el.style.display = 'none'; el.style.opacity = '1'; } } else { requestAnimationFrame(fade); } }))(); }), delay); } /** * @param {?} name * @return {?} */ static getUrlParameterByName(name) { /** @type {?} */ let match = RegExp('[?&]' + name + '=([^&]*)').exec(window.location.search); return match && decodeURIComponent(match[1].replace(/\+/g, ' ')); } } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dom-util.js","sourceRoot":"ng://@ema/js-base-library/","sources":["lib/utils/dom-util.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Provides utilities for DOM manipulation\n */\nexport class DomUtil {\n\n    /**\n     * Adds a class to a HTMLElement.\n     */\n    static addClass(el: HTMLElement, className: string) {\n        if (el.classList)\n            el.classList.add(className);\n        else\n            el.className += ' ' + className;\n    }\n\n    /**\n     * Checks whether a HTMLElement has a class.\n     */\n    static hasClass(el: HTMLElement, className: string) {\n        if (el.classList)\n            el.classList.contains(className);\n        else\n            new RegExp('(^| )' + className + '( |$)', 'gi').test(el.className);\n    }\n\n    /**\n     * Removes a class form a HTMLElement.\n     */\n    static removeClass(el: HTMLElement, className: string) {\n        if (el.classList)\n            el.classList.remove(className);\n        else\n            el.className = el.className.replace(new RegExp('(^|\\\\b)' + className.split(' ').join('|') + '(\\\\b|$)', 'gi'), ' ');\n    }\n\n    /**\n     * Removes a class from a HTMLElement when present, or adds it when not present.\n     */\n    static toggleClass(el: HTMLElement, className: string) {\n        if (el.classList) {\n            el.classList.toggle(className);\n        } else {\n            let classes = el.className.split(' ');\n            let existingIndex = classes.indexOf(className);\n\n            if (existingIndex >= 0)\n                classes.splice(existingIndex, 1);\n            else\n                classes.push(className);\n\n            el.className = classes.join(' ');\n        }\n    }\n\n    /**\n     * Removes a HTMLElement from the DOM.\n     */\n    static remove(el: HTMLElement) {\n        el.parentNode.removeChild(el);\n    }\n\n    /**\n     * Returns an object with all the attributes of a HTMLElement as key / value pairs.\n     */\n    static getAttributes(el: HTMLElement) {\n        let attrs = el.attributes, obj = {}, i = 0;\n        for (; i < attrs.length; i++) {\n            obj[attrs[i].name] = attrs[i].value;\n        }\n        return obj;\n    }\n\n    /**\n     * Sets attributes of a HTMLElement.\n     */\n    static setAttributes(el: HTMLElement, attributes: object) {\n        Object.keys(attributes).forEach((k) => {\n            el.setAttribute(k, attributes[k]);\n        });\n    }\n\n    /**\n     * Get a style property of a HTMLElement.\n     */\n    static getStyle(el: HTMLElement, styleProp: string) {\n        let value;\n        const defaultView = el.ownerDocument.defaultView;\n        // W3C standard way:\n        if (defaultView && defaultView.getComputedStyle) {\n            // sanitize property name to css notation (hypen separated words eg. font-Size)\n            styleProp = styleProp.replace(/([A-Z])/g, '-$1').toLowerCase();\n            return defaultView.getComputedStyle(el, null).getPropertyValue(styleProp);\n        } else if (el['currentStyle']) { // IE\n            // sanitize property name to camelCase\n            styleProp = styleProp.replace(/\\-(\\w)/g, function(str, letter) {\n                return letter.toUpperCase();\n            });\n            value = el['currentStyle'][styleProp];\n            // convert other units to pixels on IE\n            if (/^\\d+(em|pt|%|ex)?$/i.test(value)) {\n                return (function(value) {\n                    const oldLeft = el.style.left, oldRsLeft = el['runtimeStyle'].left;\n                    el['runtimeStyle'].left = el['currentStyle'].left;\n                    el.style.left = value || 0;\n                    value = el.style['pixelLeft'] + 'px';\n                    el.style.left = oldLeft;\n                    el['runtimeStyle'].left = oldRsLeft;\n                    return value;\n                })(value);\n            }\n            return value;\n        }\n    }\n\n    /**\n     * Returns the width and height of the viewport.\n     */\n    static viewportSize() {\n        let obj = {width:undefined, height:undefined};\n        if (typeof window !== 'undefined') {\n            if (window.innerHeight) {\n                obj.width = window.innerWidth;\n                obj.height = window.innerHeight;\n            } else {\n                obj.width = document.documentElement.clientWidth;\n                obj.height = document.documentElement.clientHeight;\n            }\n        }\n        // todo: native\n        if (typeof window === 'undefined') { }\n        return obj;\n    }\n\n    static copyToClipboard(str: string) {\n        const el = document.createElement('textarea');  // Create a <textarea> element\n        el.value = str;                                 // Set its value to the string that you want copied\n        el.setAttribute('readonly', '');                // Make it readonly to be tamper-proof\n        el.style.position = 'absolute';\n        el.style.left = '-9999px';                      // Move outside the screen to make it invisible\n        document.body.appendChild(el);                  // Append the <textarea> element to the HTML document\n        const selected =\n            document.getSelection().rangeCount > 0        // Check if there is any content selected previously\n                ? document.getSelection().getRangeAt(0)     // Store selection if found\n                : false;                                    // Mark as false to know no selection existed before\n        el.select();                                    // Select the <textarea> content\n        document.execCommand('copy');                   // Copy - only works as a result of a user action (e.g. click events)\n        document.body.removeChild(el);                  // Remove the <textarea> element\n        if (selected) {                                 // If a selection existed before copying\n            document.getSelection().removeAllRanges();    // Unselect everything on the HTML document\n            document.getSelection().addRange(selected);   // Restore the original selection\n        }\n    }\n\n    static fadeIn(el: HTMLElement, duration: number = 300, delay: number = 0, display: string = 'block'){\n        let step = (1 / duration) * 10;\n        el.style.opacity = '0';\n        el.style.display = display;\n        setTimeout(() => {\n            (function fade() {\n                let val = parseFloat(el.style.opacity);\n                if (!((val += step) > 1)) {\n                    el.style.opacity = val.toString();\n                    requestAnimationFrame(fade);\n                }\n            })();\n        }, delay);\n    }\n\n    static fadeOut(el: HTMLElement, duration: number = 300, delay: number = 0, visible: boolean = false){\n        let step = (1 / duration) * 10;\n        el.style.opacity = '1';\n        setTimeout(() => {\n            (function fade() {\n                let opacity: number = Number(el.style.opacity);\n                opacity = opacity - step;\n                el.style.opacity = opacity.toString();\n                if (opacity < 0) {\n                    if (visible === false) {\n                        el.style.display = 'none';\n                        el.style.opacity = '1';\n                    }\n                } else {\n                    requestAnimationFrame(fade);\n                }\n            })();\n        }, delay);\n\n    }\n\n    static getUrlParameterByName(name: string) {\n        let match = RegExp('[?&]' + name + '=([^&]*)').exec(window.location.search);\n        return match && decodeURIComponent(match[1].replace(/\\+/g, ' '));\n    }\n\n\n}\n"]}