UNPKG

firebaseui-angular-i18n

Version:

[![npm version](https://badge.fury.io/js/firebaseui-angular-i18n.svg)](https://badge.fury.io/js/firebaseui-angular-i18n)

92 lines 12.4 kB
import { DOCUMENT } from '@angular/common'; import { Inject, Injectable } from '@angular/core'; import * as i0 from "@angular/core"; export class DynamicLoaderService { constructor(_document) { this._document = undefined; this._document = _document; DynamicLoaderService.ResourcesStore.forEach((res) => { DynamicLoaderService.LoadedResources[res.name] = { loaded: false, type: res.type, src: res.src }; }); } /** * Loads a series of previously registered Script(s) * @param resNames The list of resources to load */ load(...resNames) { const promises = resNames.map(name => this.loadResource(name)); return Promise.all(promises); } /** * Loads a script given it's name. * @param name Name of the script to laod. */ loadResource(name) { return new Promise((resolve, reject) => { const resourceRef = DynamicLoaderService.LoadedResources[name]; if (!resourceRef) { return reject({ resource: name, loaded: false, statusText: 'Resource not registered' }); } if (resourceRef.loaded) { return resolve({ resource: name, loaded: true, statusText: 'Already Loaded' }); } const tag = resourceRef.type === "js" ? this._document.createElement("script") : this._document.createElement("link"); tag.onload = (e) => { resourceRef.loaded = true; return resolve({ resource: name, loaded: true, statusText: "Loaded", status: e }); }; tag.onerror = (error) => { return reject({ resource: name, loaded: false, statusText: 'Error', error: error }); }; if (tag instanceof HTMLScriptElement) { tag.type = "text/javascript"; tag.async = true; tag.src = resourceRef.src; } if (tag instanceof HTMLLinkElement) { tag.type = "text/css"; tag.href = resourceRef.src; tag.rel = "stylesheet"; } this._document.head.appendChild(tag); }); } /** * Registers a series of Resource(s), without loading them * @param resources A list of Resource(s) */ register(...resources) { resources.forEach(res => { DynamicLoaderService.ResourcesStore.push(res); DynamicLoaderService.LoadedResources[res.name] = { loaded: false, type: res.type, src: res.src }; }); } /** * Registers and then loads a list of Resource(s) * @param resources The list of resources */ registerAndLoad(...resources) { const resNames = resources.map(s => s.name); this.register(...resources); return this.load(...resNames); } } DynamicLoaderService.ResourcesStore = []; DynamicLoaderService.LoadedResources = {}; DynamicLoaderService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.2", ngImport: i0, type: DynamicLoaderService, deps: [{ token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Injectable }); DynamicLoaderService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.1.2", ngImport: i0, type: DynamicLoaderService }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.2", ngImport: i0, type: DynamicLoaderService, decorators: [{ type: Injectable }], ctorParameters: function () { return [{ type: undefined, decorators: [{ type: Inject, args: [DOCUMENT] }] }]; } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-loader.service.js","sourceRoot":"","sources":["../../../../projects/firebaseui-angular-library/src/lib/dynamic-loader.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAC3C,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;;AAiBnD,MAAM,OAAO,oBAAoB;IAO7B,YAA8B,SAAe;QAFrC,cAAS,GAAyB,SAAS,CAAC;QAGhD,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAE3B,oBAAoB,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,EAAE;YAChD,oBAAoB,CAAC,eAAe,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG;gBAC7C,MAAM,EAAE,KAAK;gBACb,IAAI,EAAE,GAAG,CAAC,IAAI;gBACd,GAAG,EAAE,GAAG,CAAC,GAAG;aACf,CAAC;QACN,CAAC,CAAC,CAAC;IACP,CAAC;IAED;;;OAGG;IACH,IAAI,CAAC,GAAG,QAAkB;QACtB,MAAM,QAAQ,GAAG,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC;QAC/D,OAAO,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;IACjC,CAAC;IAED;;;OAGG;IACH,YAAY,CAAC,IAAY;QACrB,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YACnC,MAAM,WAAW,GAAG,oBAAoB,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;YAE/D,IAAI,CAAC,WAAW,EAAE;gBACd,OAAO,MAAM,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,UAAU,EAAE,yBAAyB,EAAE,CAAC,CAAC;aAC3F;YAED,IAAI,WAAW,CAAC,MAAM,EAAE;gBACpB,OAAO,OAAO,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,UAAU,EAAE,gBAAgB,EAAE,CAAC,CAAC;aAClF;YAED,MAAM,GAAG,GAAG,WAAW,CAAC,IAAI,KAAK,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;YAEtH,GAAG,CAAC,MAAM,GAAG,CAAC,CAAC,EAAE,EAAE;gBACf,WAAW,CAAC,MAAM,GAAG,IAAI,CAAC;gBAC1B,OAAO,OAAO,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,EAAE,CAAC,EAAE,CAAC,CAAC;YACtF,CAAC,CAAC;YAEF,GAAG,CAAC,OAAO,GAAG,CAAC,KAAK,EAAE,EAAE;gBACpB,OAAO,MAAM,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,UAAU,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC;YACxF,CAAC,CAAA;YAED,IAAI,GAAG,YAAY,iBAAiB,EAAE;gBAClC,GAAG,CAAC,IAAI,GAAG,iBAAiB,CAAC;gBAC7B,GAAG,CAAC,KAAK,GAAG,IAAI,CAAC;gBACjB,GAAG,CAAC,GAAG,GAAG,WAAW,CAAC,GAAG,CAAC;aAC7B;YACD,IAAI,GAAG,YAAY,eAAe,EAAE;gBAChC,GAAG,CAAC,IAAI,GAAG,UAAU,CAAC;gBACtB,GAAG,CAAC,IAAI,GAAG,WAAW,CAAC,GAAG,CAAC;gBAC3B,GAAG,CAAC,GAAG,GAAG,YAAY,CAAC;aAC1B;YAED,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;QACzC,CAAC,CAAC,CAAC;IACP,CAAC;IAED;;;OAGG;IACH,QAAQ,CAAC,GAAG,SAAqB;QAC7B,SAAS,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;YACpB,oBAAoB,CAAC,cAAc,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YAC9C,oBAAoB,CAAC,eAAe,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG;gBAC7C,MAAM,EAAE,KAAK;gBACb,IAAI,EAAE,GAAG,CAAC,IAAI;gBACd,GAAG,EAAE,GAAG,CAAC,GAAG;aACf,CAAC;QACN,CAAC,CAAC,CAAC;IACP,CAAC;IAED;;;OAGG;IACH,eAAe,CAAC,GAAG,SAAqB;QACpC,MAAM,QAAQ,GAAG,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;QAC5C,IAAI,CAAC,QAAQ,CAAC,GAAG,SAAS,CAAC,CAAC;QAC5B,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,QAAQ,CAAC,CAAC;IAClC,CAAC;;AA3Fc,mCAAc,GAAe,EAAE,CAAC;AAChC,oCAAe,GAAmB,EAAE,CAAC;iHAH3C,oBAAoB,kBAOT,QAAQ;qHAPnB,oBAAoB;2FAApB,oBAAoB;kBADhC,UAAU;;0BAQM,MAAM;2BAAC,QAAQ","sourcesContent":["import { DOCUMENT } from '@angular/common';\nimport { Inject, Injectable } from '@angular/core';\n\nexport interface Resource {\n    name: string;\n    type: \"css\" | \"js\";\n    src: string;\n}\n\nexport interface LoadedResource {\n    [name: string]: {\n        loaded: boolean,\n        type: \"css\" | \"js\",\n        src: string\n    }\n}\n\n@Injectable()\nexport class DynamicLoaderService {\n\n    private static ResourcesStore: Resource[] = [];\n    private static LoadedResources: LoadedResource = {};\n\n    private _document: Document | undefined = undefined;\n\n    constructor(@Inject(DOCUMENT) _document?: any) {\n        this._document = _document;\n\n        DynamicLoaderService.ResourcesStore.forEach((res) => {\n            DynamicLoaderService.LoadedResources[res.name] = {\n                loaded: false,\n                type: res.type,\n                src: res.src\n            };\n        });\n    }\n\n    /**\n     * Loads a series of previously registered Script(s)\n     * @param resNames The list of resources to load\n     */\n    load(...resNames: string[]) {\n        const promises = resNames.map(name => this.loadResource(name));\n        return Promise.all(promises);\n    }\n\n    /**\n     * Loads a script given it's name.\n     * @param name Name of the script to laod.\n     */\n    loadResource(name: string) {\n        return new Promise((resolve, reject) => {\n            const resourceRef = DynamicLoaderService.LoadedResources[name];\n\n            if (!resourceRef) {\n                return reject({ resource: name, loaded: false, statusText: 'Resource not registered' });\n            }\n\n            if (resourceRef.loaded) {\n                return resolve({ resource: name, loaded: true, statusText: 'Already Loaded' });\n            }\n\n            const tag = resourceRef.type === \"js\" ? this._document.createElement(\"script\") : this._document.createElement(\"link\");\n\n            tag.onload = (e) => {\n                resourceRef.loaded = true;\n                return resolve({ resource: name, loaded: true, statusText: \"Loaded\", status: e });\n            };\n\n            tag.onerror = (error) => {\n                return reject({ resource: name, loaded: false, statusText: 'Error', error: error });\n            }\n\n            if (tag instanceof HTMLScriptElement) {\n                tag.type = \"text/javascript\";\n                tag.async = true;\n                tag.src = resourceRef.src;\n            }\n            if (tag instanceof HTMLLinkElement) {\n                tag.type = \"text/css\";\n                tag.href = resourceRef.src;\n                tag.rel = \"stylesheet\";\n            }\n\n            this._document.head.appendChild(tag);\n        });\n    }\n\n    /**\n     * Registers a series of Resource(s), without loading them\n     * @param resources A list of Resource(s)\n     */\n    register(...resources: Resource[]) {\n        resources.forEach(res => {\n            DynamicLoaderService.ResourcesStore.push(res);\n            DynamicLoaderService.LoadedResources[res.name] = {\n                loaded: false,\n                type: res.type,\n                src: res.src\n            };\n        });\n    }\n\n    /**\n     * Registers and then loads a list of Resource(s)\n     * @param resources The list of resources\n     */\n    registerAndLoad(...resources: Resource[]) {\n        const resNames = resources.map(s => s.name);\n        this.register(...resources);\n        return this.load(...resNames);\n    }\n}\n"]}