UNPKG

ng-ptplibraries

Version:

262 lines (261 loc) 22.9 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; import { ServiceBase } from '../base/service.base'; import { Observable } from 'rxjs'; import { ScriptModel, StyleModel } from '../models/loader'; import { map, has } from 'lodash'; var LoaderService = /** @class */ (function (_super) { tslib_1.__extends(LoaderService, _super); function LoaderService() { var _this = _super !== null && _super.apply(this, arguments) || this; _this.scripts = []; _this.styles = []; _this.scriptIndex = 0; return _this; } /** * @param {?} scriptModel * @return {?} */ LoaderService.prototype.CreateScriptElement = /** * @param {?} scriptModel * @return {?} */ function (scriptModel) { /** @type {?} */ var scriptElement = document.createElement('script'); scriptElement.type = 'text/javascript'; scriptElement.src = scriptModel.src; scriptElement.integrity = scriptModel.integrity; scriptElement.crossOrigin = scriptModel.crossorigin; return scriptElement; }; /** * @param {?} styleModel * @return {?} */ LoaderService.prototype.CreateStyleElement = /** * @param {?} styleModel * @return {?} */ function (styleModel) { /** @type {?} */ var styleElement = document.createElement('link'); styleElement.href = styleModel.href; styleElement.rel = styleModel.rel; styleElement.integrity = styleModel.integrity; styleElement['crossorigin'] = styleModel.crossorigin; return styleElement; }; /** * Waits for script to finish before loading the next script * @param {?} observer * @return {?} */ LoaderService.prototype.SyncLoad = /** * Waits for script to finish before loading the next script * @param {?} observer * @return {?} */ function (observer) { var _this = this; /** @type {?} */ var script = null; if (this.scriptIndex < this.scripts.length) { script = this.scripts[this.scriptIndex]; } if (this.scripts.every(function (a) { return a.loaded === true; })) { /** @type {?} */ var ret = this.scripts.map(function (d) { return d.Deserialize(); }); observer.next(/** @type {?} */ (ret)); observer.complete(); } else { /** @type {?} */ var scriptElement = this.CreateScriptElement(script); scriptElement.onload = function () { script.loaded = true; if (_this.scriptIndex < _this.scripts.length) _this.scriptIndex++; _this.SyncLoad(observer); }; scriptElement.onerror = function (error) { observer.error('Couldn\'t load script ' + script.src); }; document.getElementsByTagName('body')[0].appendChild(scriptElement); } }; /** * Loads an external script from a url synchronously. * @param loader * @example * *loader.LoadScript([ { source: 'https://test.com/test.min.js', integrity: 'fdsafdsar32qxr3q2' } *]).subscribe(); * */ /** * Loads an external script from a url synchronously. * \@example * * loader.LoadScript([ * { * source: 'https://test.com/test.min.js', * integrity: 'fdsafdsar32qxr3q2' * } * ]).subscribe(); * * @param {?} loader * @param {...?} pussy * @return {?} */ LoaderService.prototype.LoadScript = /** * Loads an external script from a url synchronously. * \@example * * loader.LoadScript([ * { * source: 'https://test.com/test.min.js', * integrity: 'fdsafdsar32qxr3q2' * } * ]).subscribe(); * * @param {?} loader * @param {...?} pussy * @return {?} */ function (loader) { var _this = this; var pussy = []; for (var _i = 1; _i < arguments.length; _i++) { pussy[_i - 1] = arguments[_i]; } return new Observable(function (observer) { /** @type {?} */ var scriptSrcs = _this.scripts.map(function (a) { return a.src; }); // Push to scripts array if source does not exist for (var i = 0; i < loader.length; i++) { /** @type {?} */ var newScript = new ScriptModel(); newScript.src = loader[i].source; newScript.integrity = loader[i].integrity || ''; if (!has(scriptSrcs, newScript.src)) { _this.scripts.push(newScript); } if (!_this.scripts.length) { _this.scripts.push(newScript); } scriptSrcs = _this.scripts.map(function (a) { return a.src; }); } _this.SyncLoad(observer); }); }; /** * Loads an external stylesheet from a url * @param loader * @example * *loader.LoadScript([ { source: 'https://test.com/test.min.js', integrity: 'fdsafdsar32qxr3q2' } *]).subscribe(); * */ /** * Loads an external stylesheet from a url * \@example * * loader.LoadScript([ * { * source: 'https://test.com/test.min.js', * integrity: 'fdsafdsar32qxr3q2' * } * ]).subscribe(); * * @param {?} loader * @return {?} */ LoaderService.prototype.LoadStyle = /** * Loads an external stylesheet from a url * \@example * * loader.LoadScript([ * { * source: 'https://test.com/test.min.js', * integrity: 'fdsafdsar32qxr3q2' * } * ]).subscribe(); * * @param {?} loader * @return {?} */ function (loader) { var _this = this; return new Observable(function (observer) { /** @type {?} */ var styleHrefs = _this.styles.map(function (a) { return a.href; }); // Push to scripts array if source does not exist for (var i = 0; i < loader.length; i++) { /** @type {?} */ var newStyle = new StyleModel(); newStyle.href = loader[i].href; newStyle.integrity = loader[i].integrity || ''; if (!has(styleHrefs, newStyle.href)) { _this.styles.push(newStyle); } if (!_this.styles.length) { _this.styles.push(newStyle); } styleHrefs = _this.styles.map(function (a) { return a.href; }); } map(_this.styles, function (style) { // Complete if already loaded if (style.loaded) { /** @type {?} */ var ret = _this.styles.map(function (d) { return d.Deserialize(); }); observer.next(/** @type {?} */ (ret)); observer.complete(); } else { /** @type {?} */ var scriptElement = _this.CreateStyleElement(style); scriptElement.onload = function () { style.loaded = true; if (_this.styles.every(function (a) { return a.loaded === true; })) { /** @type {?} */ var ret = _this.styles.map(function (d) { return d.Deserialize(); }); observer.next(/** @type {?} */ (ret)); observer.complete(); } }; scriptElement.onerror = function (error) { observer.error('Couldn\'t load style ' + style.href); }; /** @type {?} */ var head = document.getElementsByTagName('head')[0]; /** @type {?} */ var styleTag = head.getElementsByTagName('style')[0]; head.insertBefore(scriptElement, styleTag); } }); }); }; return LoaderService; }(ServiceBase)); export { LoaderService }; if (false) { /** @type {?} */ LoaderService.prototype.scripts; /** @type {?} */ LoaderService.prototype.styles; /** @type {?} */ LoaderService.prototype.scriptIndex; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"loader.service.js","sourceRoot":"ng://ng-ptplibraries/","sources":["lib/services/loader.service.ts"],"names":[],"mappings":"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","sourcesContent":["\nimport { ServiceBase } from '../base/service.base';\nimport { Observable, Observer } from 'rxjs';\nimport { ScriptModel, StyleModel, LoaderModel } from '../models/loader';\nimport { map, has } from 'lodash';\n\nexport class LoaderService extends ServiceBase {\n\n    private scripts: ScriptModel[] = [];\n    private styles: StyleModel[] = [];\n    private scriptIndex: number = 0;\n\n    private CreateScriptElement(scriptModel: ScriptModel) {\n        let scriptElement = document.createElement('script');\n        scriptElement.type = 'text/javascript';\n        scriptElement.src = scriptModel.src;\n        scriptElement.integrity = scriptModel.integrity;\n        scriptElement.crossOrigin = scriptModel.crossorigin;\n        return scriptElement;\n    }\n\n    private CreateStyleElement(styleModel: StyleModel) {\n        let styleElement = document.createElement('link');\n        styleElement.href = styleModel.href;\n        styleElement.rel = styleModel.rel;\n        styleElement.integrity = styleModel.integrity;\n        styleElement['crossorigin'] = styleModel.crossorigin;\n        return styleElement;\n    }\n\n    /**\n     * Waits for script to finish before loading the next script\n     */\n    private SyncLoad(observer: Observer<ScriptModel[]>) {\n        let script = null;\n\n        if (this.scriptIndex < this.scripts.length) {\n            script = this.scripts[this.scriptIndex];\n        }\n\n        if (this.scripts.every(a => a.loaded === true)) {\n            let ret = this.scripts.map(d => d.Deserialize());\n            observer.next(<any>ret);\n            observer.complete();\n        } else {\n            let scriptElement = this.CreateScriptElement(script);\n\n            scriptElement.onload = () => {\n                script.loaded = true;\n\n                if (this.scriptIndex < this.scripts.length) this.scriptIndex++;\n\n                this.SyncLoad(observer);\n            };\n\n            scriptElement.onerror = (error: any) => {\n                observer.error('Couldn\\'t load script ' + script.src);\n            };\n\n            document.getElementsByTagName('body')[0].appendChild(scriptElement);\n        }\n    }\n\n    /**\n     * Loads an external script from a url synchronously.\n     * @param loader\n     * @example\n     *\n     *loader.LoadScript([\n        {\n            source: 'https://test.com/test.min.js',\n            integrity: 'fdsafdsar32qxr3q2'\n        }\n     *]).subscribe();\n     * */\n    LoadScript(loader: LoaderModel[], ...pussy: LoaderModel[]): Observable<ScriptModel[]> {\n        return new Observable<ScriptModel[]>((observer: Observer<ScriptModel[]>) => {\n            let scriptSrcs = this.scripts.map(a => a.src);\n\n            // Push to scripts array if source does not exist\n            for (let i = 0; i < loader.length; i++) {\n                let newScript: ScriptModel = new ScriptModel();\n                newScript.src = loader[i].source;\n                newScript.integrity = loader[i].integrity || '';\n\n                if (!has(scriptSrcs, newScript.src)) {\n                    this.scripts.push(newScript);\n                }\n\n                if (!this.scripts.length) {\n                    this.scripts.push(newScript);\n                }\n\n                scriptSrcs = this.scripts.map(a => a.src);\n            }\n\n            this.SyncLoad(observer);\n        });\n    }\n\n    /**\n     * Loads an external stylesheet from a url\n     * @param loader\n     * @example\n     *\n     *loader.LoadScript([\n        {\n            source: 'https://test.com/test.min.js',\n            integrity: 'fdsafdsar32qxr3q2'\n        }\n     *]).subscribe();\n     * */\n    LoadStyle(loader: LoaderModel[]): Observable<StyleModel> {\n        return new Observable<StyleModel>((observer: Observer<StyleModel>) => {\n            let styleHrefs = this.styles.map(a => a.href);\n            // Push to scripts array if source does not exist\n            for (let i = 0; i < loader.length; i++) {\n                let newStyle: StyleModel = new StyleModel();\n                newStyle.href = loader[i].href;\n                newStyle.integrity = loader[i].integrity || '';\n\n                if (!has(styleHrefs, newStyle.href)) {\n                    this.styles.push(newStyle);\n                }\n\n                if (!this.styles.length) {\n                    this.styles.push(newStyle);\n                }\n\n                styleHrefs = this.styles.map(a => a.href);\n            }\n\n            map(this.styles, style => {\n                // Complete if already loaded\n                if (style.loaded) {\n                    let ret = this.styles.map(d => d.Deserialize());\n                    observer.next(<any>ret);\n                    observer.complete();\n                } else {\n                    // Create the style and load it in the browser\n                    let scriptElement = this.CreateStyleElement(style);\n\n                    scriptElement.onload = () => {\n                        style.loaded = true;\n\n                        if (this.styles.every(a => a.loaded === true)) {\n                            let ret = this.styles.map(d => d.Deserialize());\n                            observer.next(<any>ret);\n                            observer.complete();\n                        }\n                    };\n\n                    scriptElement.onerror = (error: any) => {\n                        observer.error('Couldn\\'t load style ' + style.href);\n                    };\n\n                    let head = document.getElementsByTagName('head')[0];\n                    let styleTag = head.getElementsByTagName('style')[0];\n\n                    head.insertBefore(scriptElement, styleTag);\n                }\n            });\n        });\n    }\n\n}\n"]}