UNPKG

@pepperi/lib

Version:

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

164 lines 24.5 kB
import { Injectable } from '@angular/core'; import * as i0 from "@angular/core"; export var FileTypeEnum; (function (FileTypeEnum) { FileTypeEnum[FileTypeEnum["Script"] = 1] = "Script"; FileTypeEnum[FileTypeEnum["Style"] = 2] = "Style"; })(FileTypeEnum || (FileTypeEnum = {})); export class FileService { constructor() { this.scripts = new Map(); this.styles = new Map(); } loadFiles(files) { const promises = []; files.forEach((file) => { if (file.type === FileTypeEnum.Style) { promises.push(this.loadStyle(file.path)); } else if (file.type === FileTypeEnum.Script) { promises.push(this.loadScript(file.path)); } }); return Promise.all(promises); } removeFiles(files) { for (let index = 0; index < files.length && files[index].path && files[index].path.trim() !== ''; index++) { const name = this.getFileName(files[index].path, true); const element = document.getElementById(name); element.parentNode.removeChild(element); if (files[index].type === FileTypeEnum.Script && this.scripts.has(name)) { this.scripts.delete(name); } else if (files[index].type === FileTypeEnum.Style && this.styles.has(name)) { this.styles.delete(name); } } } loadScript(path) { return new Promise((resolve, reject) => { const name = this.getFileName(path, true); // If the script isn't exist add it. if (!this.scripts.has(name)) { this.scripts.set(name, { loaded: false, src: path }); } const scriptItem = this.scripts.get(name); // Resolve if already loaded if (scriptItem.loaded) { resolve({ script: name, loaded: true, status: 'Already Loaded' }); } else { // Load script const script = document.createElement('script'); script.type = 'text/javascript'; script.src = scriptItem.src; script.setAttribute('id', name); script.async = false; if (script.readyState) { // IE script.onreadystatechange = () => { if (script.readyState === 'loaded' || script.readyState === 'complete') { script.onreadystatechange = null; scriptItem.loaded = true; resolve({ path, type: FileTypeEnum.Script, loaded: true, status: 'Loaded' }); } }; } else { // Others script.onload = () => { scriptItem.loaded = true; resolve({ path, type: FileTypeEnum.Script, loaded: true, status: 'Loaded' }); }; } script.onerror = (error) => resolve({ path, type: FileTypeEnum.Script, loaded: false, status: 'Loaded' }); document.getElementsByTagName('head')[0].appendChild(script); } }); } loadStyle(path) { return new Promise((resolve, reject) => { const name = this.getFileName(path, true); // If the style isn't exist add it. if (!this.styles.has(name)) { this.styles.set(name, { loaded: false, src: path }); } const styleItem = this.styles.get(name); // Resolve if already loaded if (styleItem.loaded) { resolve({ path, type: FileTypeEnum.Style, loaded: true, status: 'Already Loaded' }); } else { // Load style const style = document.createElement('link'); style.type = 'text/css'; style.rel = 'stylesheet'; style.href = styleItem.src; style.media = 'all'; style.setAttribute('id', name); styleItem.loaded = true; resolve({ path, type: FileTypeEnum.Style, loaded: true, status: 'Loaded' }); document.getElementsByTagName('head')[0].appendChild(style); } }); } getFileName(filePath, withExtenstion = false) { let lastIndex = withExtenstion ? filePath.length - 1 : filePath.lastIndexOf('.'); return filePath.substr(filePath.lastIndexOf('/') + 1, lastIndex); } getFileExtension(filePath) { var fileSplit = filePath.split('.'); var fileExt = ''; if (fileSplit.length > 1) { fileExt = fileSplit[fileSplit.length - 2]; } return fileExt; } /* Returns true if url is valid */ isValidUrl(url) { /* Try creating a valid URL */ try { const tmp = new URL(url); return true; } catch (e) { return false; } } convertFromb64toBlob(b64Data, contentType = '', sliceSize = 512) { const byteCharacters = atob(b64Data); const byteArrays = []; for (let offset = 0; offset < byteCharacters.length; offset += sliceSize) { const slice = byteCharacters.slice(offset, offset + sliceSize); const byteNumbers = new Array(slice.length); for (let i = 0; i < slice.length; i++) { byteNumbers[i] = slice.charCodeAt(i); } const byteArray = new Uint8Array(byteNumbers); byteArrays.push(byteArray); } const blob = new Blob(byteArrays, { type: contentType }); return blob; } getAssetsPath() { return `/assets/pepperi-lib/`; } getAssetsTranslationsPath() { return `${this.getAssetsPath()}i18n/`; } getAssetsImagesPath(image = '') { return `${this.getAssetsPath()}images/${image}`; } getNoImagePath() { return this.getAssetsImagesPath('no-image.svg'); } } FileService.ɵfac = function FileService_Factory(t) { return new (t || FileService)(); }; FileService.ɵprov = i0.ɵɵdefineInjectable({ token: FileService, factory: FileService.ɵfac, providedIn: 'root' }); /*@__PURE__*/ (function () { i0.ɵsetClassMetadata(FileService, [{ type: Injectable, args: [{ providedIn: 'root', }] }], function () { return []; }, null); })(); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file.service.js","sourceRoot":"","sources":["../../../../../../projects/pepperi-lib/src/core/common/services/file.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {Injectable} from '@angular/core';\r\n\r\nexport enum FileTypeEnum {\r\n    'Script' = 1,\r\n    'Style' = 2,\r\n}\r\n\r\nexport interface ExternalFileModel {\r\n    path: string;\r\n    type: FileTypeEnum;\r\n}\r\n\r\ndeclare var document: any;\r\n\r\n@Injectable({\r\n    providedIn: 'root',\r\n})\r\nexport class FileService {\r\n    private scripts: Map<string, {loaded: boolean; src: string}>;\r\n    private styles: Map<string, {loaded: boolean; src: string}>;\r\n\r\n    constructor() {\r\n        this.scripts = new Map<string, {loaded: boolean; src: string}>();\r\n        this.styles = new Map<string, {loaded: boolean; src: string}>();\r\n    }\r\n\r\n    loadFiles(files: ExternalFileModel[]): Promise<any[]> {\r\n        const promises: any[] = [];\r\n        files.forEach((file) => {\r\n            if (file.type === FileTypeEnum.Style) {\r\n                promises.push(this.loadStyle(file.path));\r\n            } else if (file.type === FileTypeEnum.Script) {\r\n                promises.push(this.loadScript(file.path));\r\n            }\r\n        });\r\n        return Promise.all(promises);\r\n    }\r\n\r\n    removeFiles(files: ExternalFileModel[]): void {\r\n        for (let index = 0; index < files.length && files[index].path && files[index].path.trim() !== ''; index++) {\r\n            const name = this.getFileName(files[index].path, true);\r\n            const element = document.getElementById(name);\r\n            element.parentNode.removeChild(element);\r\n\r\n            if (files[index].type === FileTypeEnum.Script && this.scripts.has(name)) {\r\n                this.scripts.delete(name);\r\n            } else if (files[index].type === FileTypeEnum.Style && this.styles.has(name)) {\r\n                this.styles.delete(name);\r\n            }\r\n        }\r\n    }\r\n\r\n    loadScript(path: string): Promise<any> {\r\n        return new Promise((resolve, reject) => {\r\n            const name = this.getFileName(path, true);\r\n\r\n            // If the script isn't exist add it.\r\n            if (!this.scripts.has(name)) {\r\n                this.scripts.set(name, {loaded: false, src: path});\r\n            }\r\n\r\n            const scriptItem = this.scripts.get(name);\r\n\r\n            // Resolve if already loaded\r\n            if (scriptItem.loaded) {\r\n                resolve({script: name, loaded: true, status: 'Already Loaded'});\r\n            } else {\r\n                // Load script\r\n                const script = document.createElement('script');\r\n                script.type = 'text/javascript';\r\n                script.src = scriptItem.src;\r\n                script.setAttribute('id', name);\r\n                script.async = false;\r\n\r\n                if (script.readyState) {\r\n                    // IE\r\n                    script.onreadystatechange = () => {\r\n                        if (script.readyState === 'loaded' || script.readyState === 'complete') {\r\n                            script.onreadystatechange = null;\r\n                            scriptItem.loaded = true;\r\n                            resolve({path, type: FileTypeEnum.Script, loaded: true, status: 'Loaded'});\r\n                        }\r\n                    };\r\n                } else {\r\n                    // Others\r\n                    script.onload = () => {\r\n                        scriptItem.loaded = true;\r\n                        resolve({path, type: FileTypeEnum.Script, loaded: true, status: 'Loaded'});\r\n                    };\r\n                }\r\n                script.onerror = (error: any) => resolve({path, type: FileTypeEnum.Script, loaded: false, status: 'Loaded'});\r\n                document.getElementsByTagName('head')[0].appendChild(script);\r\n            }\r\n        });\r\n    }\r\n\r\n    loadStyle(path: string): Promise<any> {\r\n        return new Promise((resolve, reject) => {\r\n            const name = this.getFileName(path, true);\r\n\r\n            // If the style isn't exist add it.\r\n            if (!this.styles.has(name)) {\r\n                this.styles.set(name, {loaded: false, src: path});\r\n            }\r\n\r\n            const styleItem = this.styles.get(name);\r\n\r\n            // Resolve if already loaded\r\n            if (styleItem.loaded) {\r\n                resolve({path, type: FileTypeEnum.Style, loaded: true, status: 'Already Loaded'});\r\n            } else {\r\n                // Load style\r\n                const style = document.createElement('link');\r\n                style.type = 'text/css';\r\n                style.rel = 'stylesheet';\r\n                style.href = styleItem.src;\r\n                style.media = 'all';\r\n                style.setAttribute('id', name);\r\n\r\n                styleItem.loaded = true;\r\n                resolve({path, type: FileTypeEnum.Style, loaded: true, status: 'Loaded'});\r\n\r\n                document.getElementsByTagName('head')[0].appendChild(style);\r\n            }\r\n        });\r\n    }\r\n\r\n    getFileName(filePath: string, withExtenstion: boolean = false): string {\r\n        let lastIndex = withExtenstion ? filePath.length - 1 : filePath.lastIndexOf('.');\r\n\r\n        return filePath.substr(filePath.lastIndexOf('/') + 1, lastIndex);\r\n    }\r\n\r\n    getFileExtension(filePath: string): string {\r\n        var fileSplit = filePath.split('.');\r\n        var fileExt = '';\r\n        if (fileSplit.length > 1) {\r\n            fileExt = fileSplit[fileSplit.length - 2];\r\n        }\r\n        return fileExt;\r\n    }\r\n\r\n    /* Returns true if url is valid */\r\n    isValidUrl(url: string): boolean {\r\n        /* Try creating a valid URL */\r\n        try {\r\n            const tmp = new URL(url);\r\n            return true;\r\n        } catch (e) {\r\n            return false;\r\n        }\r\n    }\r\n\r\n    convertFromb64toBlob(b64Data: any, contentType = '', sliceSize = 512): Blob {\r\n        const byteCharacters = atob(b64Data);\r\n        const byteArrays = [];\r\n\r\n        for (let offset = 0; offset < byteCharacters.length; offset += sliceSize) {\r\n            const slice = byteCharacters.slice(offset, offset + sliceSize);\r\n\r\n            const byteNumbers = new Array(slice.length);\r\n            for (let i = 0; i < slice.length; i++) {\r\n                byteNumbers[i] = slice.charCodeAt(i);\r\n            }\r\n\r\n            const byteArray = new Uint8Array(byteNumbers);\r\n            byteArrays.push(byteArray);\r\n        }\r\n\r\n        const blob = new Blob(byteArrays, {type: contentType});\r\n        return blob;\r\n    }\r\n\r\n    getAssetsPath(): string {\r\n        return `/assets/pepperi-lib/`;\r\n    }\r\n\r\n    getAssetsTranslationsPath(): string {\r\n        return `${this.getAssetsPath()}i18n/`;\r\n    }\r\n\r\n    getAssetsImagesPath(image: string = ''): string {\r\n        return `${this.getAssetsPath()}images/${image}`;\r\n    }\r\n\r\n    getNoImagePath(): string {\r\n        return this.getAssetsImagesPath('no-image.svg');\r\n    }\r\n}\r\n"]}