@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
JavaScript
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"]}