| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859 |
- import { Injectable } from "@angular/core";
- interface Scripts {
- name: string;
- src: string;
- }
- export const ScriptStore: Scripts[] = [
- {
- name: "pdfMake",
- src: "https://cdnjs.cloudflare.com/ajax/libs/pdfmake/0.1.59/pdfmake.min.js"
- },
- {
- name: "vfsFonts",
- src: "https://cdnjs.cloudflare.com/ajax/libs/pdfmake/0.1.59/vfs_fonts.js"
- }
- ];
- @Injectable({
- providedIn: "root"
- })
- export class PdfmakeScriptService {
- private scripts: any = {};
- constructor() {
- ScriptStore.forEach((script: any) => {
- this.scripts[script.name] = {
- loaded: false,
- src: script.src
- };
- });
- }
- load(...scripts: string[]) {
- const promises: any[] = [];
- scripts.forEach(script => promises.push(this.loadScript(script)));
- return Promise.all(promises);
- }
- loadScript(name: string) {
- return new Promise((resolve, reject) => {
- // resolve if already loaded
- if (this.scripts[name].loaded) {
- resolve({ script: name, loaded: true, status: "Already Loaded" });
- } else {
- // load script
- const script = document.createElement("script");
- script.type = "text/javascript";
- script.src = this.scripts[name].src;
- script.onload = () => {
- this.scripts[name].loaded = true;
- resolve({ script: name, loaded: true, status: "Loaded" });
- };
- script.onerror = (error: any) =>
- resolve({ script: name, loaded: false, status: "Loaded" });
- document.getElementsByTagName("head")[0].appendChild(script);
- }
- });
- }
- }
|