@dodjidev/filemodule 1.0.2 → 1.0.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.vscode/settings.json +3 -0
- package/dist/index.cjs.js +1 -1
- package/dist/index.esm.js +1 -1
- package/dist/index.js +1 -1
- package/package.json +1 -1
package/dist/index.cjs.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";const e=require("fs").promises,s=require("xlsx"),r=require("mustache"),t=require("puppeteer"),{zip:o}=require("zip-a-folder");module.exports=new class{configs={};logger=null;defaultLogger={info:e=>console.log(e),error:e=>console.error(new Error(e))};constructor(){}init(e){try{Object.assign(this.configs,e),this.logger=e?.logger||this.defaultLogger}catch(e){this.log(`Error initializing watcher: ${e.message}`,"error")}}log(e,s="info"){this.logger&&this.logger[s](e)}excelToJson(e,r){let t={success:!0,response:[]};try{r||(r={}),r.sheetname=r.sheetname||"";let o="string"==typeof e?s.readFile(e):s.read(e),
|
|
1
|
+
"use strict";const e=require("fs").promises,s=require("xlsx"),r=require("mustache"),t=require("puppeteer"),{zip:o}=require("zip-a-folder");module.exports=new class{configs={};logger=null;defaultLogger={info:e=>console.log(e),error:e=>console.error(new Error(e))};constructor(){}init(e){try{Object.assign(this.configs,e),this.logger=e?.logger||this.defaultLogger}catch(e){this.log(`Error initializing watcher: ${e.message}`,"error")}}log(e,s="info"){this.logger&&this.logger[s](e)}excelToJson(e,r){let t={success:!0,response:[]};try{r||(r={}),r.sheetname=r.sheetname||"";let o="string"==typeof e?s.readFile(e):s.read(e),a=Object.keys(o.Sheets);if(0==a.length)return t;let n=o.Sheets[r.sheetname];n||(n=o.Sheets[a[0]]),n&&(t.response=s.utils.sheet_to_json(n))}catch(e){t.response=e.message,t.success=!1,t.code=e.code}finally{return t}}jsonToExcel(e,r="",t={}){let o={success:!0,response:[]};try{if(!r)throw new Error("no file specified");t.sheetname=t.sheetname||"",t.header=t.header||[],"string"==typeof t?.header&&(t.header=t.header.split(",")),Array.isArray(t?.header)&&t?.header?.length>0&&(e=e.map((e=>{let s={};for(let r of t.header)t.header.includes(r)?e[r]=e[r]||null:delete e[r],s[r]=void 0!==e[r]?e[r]:null;return s})));const a=s.readFile(r);let n=s.utils.json_to_sheet(e,{cellDates:!0});"function"==typeof t?.preprocessing&&t.preprocessing(n,a,e),void 0!==a.Sheets[t.sheetname]?a.Sheets[t.sheetname]=n:s.utils.book_append_sheet(a,n,t.sheetname),s.writeFile(a,r),o.response="file write successfully !!!"}catch(a){if(console.log("ERROR:",a,a.code),console.log("CODE:",a.code),"ENOENT"==a.code&&!1!==t?.createIfNotExist)try{const a=s.utils.json_to_sheet(e);let n=s.utils.book_new();"function"==typeof t?.preprocessing&&t.preprocessing(a,n,e),s.utils.book_append_sheet(n,a,t.sheetname),s.writeFile(n,r),o.response="file write successfully !!!"}catch(e){o.response=e.message,o.success=!1}else o.response=a.message+"-"+a.stack,o.success=!1}finally{return o}}appendDataToExcel(e,s="",r){let t={success:!0,response:"Append successfully"};try{if(r||(r={}),!Array.isArray(e))throw new Error("The data to append must be of type array.Got:"+typeof e);let o=r?.clearOld?[]:this.excelToJson(s,r).response;Array.isArray(o)||(o=[]);let a=[...o,...e];if("update"==r?.type){if(!r?.primaryKey)throw new Error("The type is update but no primaryKey is specified");let s=r.primaryKey;e.forEach((e=>{let r=a.filter((r=>r[s]&&r[s]==e[s]));if(r.length>1){let t=a.findIndex((r=>r[s]==e[s])),o=r.reduce(((e,s)=>({...e,...s})),{});a.splice(t,1,o),a=a.filter(((r,o)=>t==o||r[s]!=e[s]))}}))}let n=this.jsonToExcel(a,s,{createIfNotExist:!0,...r});n.success?t.response="Data append successfully":t=n}catch(e){t.success=!1,t.response=e.message}finally{return t}}async base64ToFile(s,r,t){try{if(null==s)return{success:!1,response:"No base64 data provided"};let o=s.split(";base64,"),a=o?.[0],n=t?.extension||"png";if(o.length>1&&(a=o[1],!t?.extension)){let e=o[0].split("/");console.log(e),n=e[e.length-1]}let i=(t?.filename||(new Date).getTime()).toString();i.includes(".")||(i+="."+n);let c=Buffer.from(a,"base64");await e.mkdir(r,{recursive:!0});let l=r+"/"+i;return{success:!0,response:l,result:await e.writeFile(l,c)}}catch(e){return{success:!1,response:e.message,error:e}}}async fileToBase64(e,s){try{return s=s||{},await this.readFile(e,{...s,encoding:"base64"})}catch(e){return{success:!1,response:e.message}}}async jsonToFile(s,r,t={}){try{s=JSON.stringify(s);let o=(t?.filename||(new Date).getTime()).toString(),a=t?.extension||"json";return o.includes(".")||(o+="."+a),r=r+"/"+o,{success:!0,response:await e.writeFile(r,s),directory:r,filename:o}}catch(e){return{success:!1,response:e.message+"-"+e.stack,error:e}}}async saveToFile(s,r,t={}){try{let o=(t?.filename||(new Date).getTime()).toString(),a=t?.extension||"txt";return o.includes(".")||(o+="."+a),r=r+"/"+o,{success:!0,response:await e.writeFile(r,s),directory:r,filename:o}}catch(e){return{success:!1,response:e.message+"-"+e.stack,error:e}}}createDirectory(s,r){return e.mkdir(s,{recursive:!0,...r||{}})}async removeDirectory(s,r={}){try{void 0===r?.recursive&&(r.recursive=!0),void 0===r?.force&&(r.force=!0);let t=await e.rm(s,r);return console.info("[SUCCESS]:",s+" removed successfully !!!"),{success:!0,response:t}}catch(e){return console.error("[ERROR]:",`error while removing ${s} (${e.message})`),{success:!1,response:e.message}}}async removeFile(s){try{if("string"==typeof s&&(s=[s]),!Array.isArray(s))throw"Wrong input format- format accepted (Array or string ). Format inputed -"+typeof s;let r=await Promise.all(s.map((async s=>{try{let r=await e.unlink(s);return{success:!0,result:r instanceof Error?r.message:r,file:s}}catch(e){return{success:!1,result:e.message,file:s}}})));return console.info("[SUCCESS]:","file "+s+" removed successfully !!!"),{success:!0,response:r}}catch(e){return console.error("[ERROR]:","error while removing dir ("+e.message+")"),{success:!1,response:e.message}}}async readFile(s,r){try{r=r||{},r?.encoding||(r.encoding="utf8");let t=await e.readFile(s,{encoding:"base64url"});return console.log("content:",t,r),t&&"base64"==r?.encoding&&(t="data:image/png;base64,"+t),{success:!0,response:t}}catch(e){return console.error(e),{success:!1,response:e.message}}}async generatePdf(e,s,r,o){let a=this.configs.templates?.[e];e=a?.template||e;let n=a?.header||o?.header||"",i=a?.footer||o?.footer||"";n=this.parseHTML(n,s),i=this.parseHTML(i,s);let c=this.parseHTML(e,s),l={headless:!0,executablePath:process.env.puppeteerExecutable};l.executablePath||delete l.executablePath;const u=await t.launch(l),p=await u.newPage();await p.setContent(c,{waitUntil:"networkidle0"});let h=r.split("/").reverse().slice(1).reverse().join("/");await this.createDirectory(h);let d=await p.pdf({path:r,format:"A4",printBackground:!0,headerTemplate:n,footerTemplate:i,displayHeaderFooter:!1!==o?.displayHeaderFooter&&(""!=n||""!=i)});return await u.close(),console.log(`PDF generated at ${r}`),{finalHTML:c,response:d,path:r.replace(/\\/g,"/")}}async zip(e,s,r={}){try{return{success:!0,response:await o(e,s)}}catch(e){return{success:!1,response:e.message,stack:e.stack}}}parseHTML(e,s){return e=(e=r.render(e||"",s)).replace(/"/g,'"')}};
|
package/dist/index.esm.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
const e=require("fs").promises,s=require("xlsx"),r=require("mustache"),t=require("puppeteer"),{zip:o}=require("zip-a-folder");module.exports=new class{configs={};logger=null;defaultLogger={info:e=>console.log(e),error:e=>console.error(new Error(e))};constructor(){}init(e){try{Object.assign(this.configs,e),this.logger=e?.logger||this.defaultLogger}catch(e){this.log(`Error initializing watcher: ${e.message}`,"error")}}log(e,s="info"){this.logger&&this.logger[s](e)}excelToJson(e,r){let t={success:!0,response:[]};try{r||(r={}),r.sheetname=r.sheetname||"";let o="string"==typeof e?s.readFile(e):s.read(e),
|
|
1
|
+
const e=require("fs").promises,s=require("xlsx"),r=require("mustache"),t=require("puppeteer"),{zip:o}=require("zip-a-folder");module.exports=new class{configs={};logger=null;defaultLogger={info:e=>console.log(e),error:e=>console.error(new Error(e))};constructor(){}init(e){try{Object.assign(this.configs,e),this.logger=e?.logger||this.defaultLogger}catch(e){this.log(`Error initializing watcher: ${e.message}`,"error")}}log(e,s="info"){this.logger&&this.logger[s](e)}excelToJson(e,r){let t={success:!0,response:[]};try{r||(r={}),r.sheetname=r.sheetname||"";let o="string"==typeof e?s.readFile(e):s.read(e),a=Object.keys(o.Sheets);if(0==a.length)return t;let n=o.Sheets[r.sheetname];n||(n=o.Sheets[a[0]]),n&&(t.response=s.utils.sheet_to_json(n))}catch(e){t.response=e.message,t.success=!1,t.code=e.code}finally{return t}}jsonToExcel(e,r="",t={}){let o={success:!0,response:[]};try{if(!r)throw new Error("no file specified");t.sheetname=t.sheetname||"",t.header=t.header||[],"string"==typeof t?.header&&(t.header=t.header.split(",")),Array.isArray(t?.header)&&t?.header?.length>0&&(e=e.map((e=>{let s={};for(let r of t.header)t.header.includes(r)?e[r]=e[r]||null:delete e[r],s[r]=void 0!==e[r]?e[r]:null;return s})));const a=s.readFile(r);let n=s.utils.json_to_sheet(e,{cellDates:!0});"function"==typeof t?.preprocessing&&t.preprocessing(n,a,e),void 0!==a.Sheets[t.sheetname]?a.Sheets[t.sheetname]=n:s.utils.book_append_sheet(a,n,t.sheetname),s.writeFile(a,r),o.response="file write successfully !!!"}catch(a){if(console.log("ERROR:",a,a.code),console.log("CODE:",a.code),"ENOENT"==a.code&&!1!==t?.createIfNotExist)try{const a=s.utils.json_to_sheet(e);let n=s.utils.book_new();"function"==typeof t?.preprocessing&&t.preprocessing(a,n,e),s.utils.book_append_sheet(n,a,t.sheetname),s.writeFile(n,r),o.response="file write successfully !!!"}catch(e){o.response=e.message,o.success=!1}else o.response=a.message+"-"+a.stack,o.success=!1}finally{return o}}appendDataToExcel(e,s="",r){let t={success:!0,response:"Append successfully"};try{if(r||(r={}),!Array.isArray(e))throw new Error("The data to append must be of type array.Got:"+typeof e);let o=r?.clearOld?[]:this.excelToJson(s,r).response;Array.isArray(o)||(o=[]);let a=[...o,...e];if("update"==r?.type){if(!r?.primaryKey)throw new Error("The type is update but no primaryKey is specified");let s=r.primaryKey;e.forEach((e=>{let r=a.filter((r=>r[s]&&r[s]==e[s]));if(r.length>1){let t=a.findIndex((r=>r[s]==e[s])),o=r.reduce(((e,s)=>({...e,...s})),{});a.splice(t,1,o),a=a.filter(((r,o)=>t==o||r[s]!=e[s]))}}))}let n=this.jsonToExcel(a,s,{createIfNotExist:!0,...r});n.success?t.response="Data append successfully":t=n}catch(e){t.success=!1,t.response=e.message}finally{return t}}async base64ToFile(s,r,t){try{if(null==s)return{success:!1,response:"No base64 data provided"};let o=s.split(";base64,"),a=o?.[0],n=t?.extension||"png";if(o.length>1&&(a=o[1],!t?.extension)){let e=o[0].split("/");console.log(e),n=e[e.length-1]}let i=(t?.filename||(new Date).getTime()).toString();i.includes(".")||(i+="."+n);let c=Buffer.from(a,"base64");await e.mkdir(r,{recursive:!0});let l=r+"/"+i;return{success:!0,response:l,result:await e.writeFile(l,c)}}catch(e){return{success:!1,response:e.message,error:e}}}async fileToBase64(e,s){try{return s=s||{},await this.readFile(e,{...s,encoding:"base64"})}catch(e){return{success:!1,response:e.message}}}async jsonToFile(s,r,t={}){try{s=JSON.stringify(s);let o=(t?.filename||(new Date).getTime()).toString(),a=t?.extension||"json";return o.includes(".")||(o+="."+a),r=r+"/"+o,{success:!0,response:await e.writeFile(r,s),directory:r,filename:o}}catch(e){return{success:!1,response:e.message+"-"+e.stack,error:e}}}async saveToFile(s,r,t={}){try{let o=(t?.filename||(new Date).getTime()).toString(),a=t?.extension||"txt";return o.includes(".")||(o+="."+a),r=r+"/"+o,{success:!0,response:await e.writeFile(r,s),directory:r,filename:o}}catch(e){return{success:!1,response:e.message+"-"+e.stack,error:e}}}createDirectory(s,r){return e.mkdir(s,{recursive:!0,...r||{}})}async removeDirectory(s,r={}){try{void 0===r?.recursive&&(r.recursive=!0),void 0===r?.force&&(r.force=!0);let t=await e.rm(s,r);return console.info("[SUCCESS]:",s+" removed successfully !!!"),{success:!0,response:t}}catch(e){return console.error("[ERROR]:",`error while removing ${s} (${e.message})`),{success:!1,response:e.message}}}async removeFile(s){try{if("string"==typeof s&&(s=[s]),!Array.isArray(s))throw"Wrong input format- format accepted (Array or string ). Format inputed -"+typeof s;let r=await Promise.all(s.map((async s=>{try{let r=await e.unlink(s);return{success:!0,result:r instanceof Error?r.message:r,file:s}}catch(e){return{success:!1,result:e.message,file:s}}})));return console.info("[SUCCESS]:","file "+s+" removed successfully !!!"),{success:!0,response:r}}catch(e){return console.error("[ERROR]:","error while removing dir ("+e.message+")"),{success:!1,response:e.message}}}async readFile(s,r){try{r=r||{},r?.encoding||(r.encoding="utf8");let t=await e.readFile(s,{encoding:"base64url"});return console.log("content:",t,r),t&&"base64"==r?.encoding&&(t="data:image/png;base64,"+t),{success:!0,response:t}}catch(e){return console.error(e),{success:!1,response:e.message}}}async generatePdf(e,s,r,o){let a=this.configs.templates?.[e];e=a?.template||e;let n=a?.header||o?.header||"",i=a?.footer||o?.footer||"";n=this.parseHTML(n,s),i=this.parseHTML(i,s);let c=this.parseHTML(e,s),l={headless:!0,executablePath:process.env.puppeteerExecutable};l.executablePath||delete l.executablePath;const u=await t.launch(l),p=await u.newPage();await p.setContent(c,{waitUntil:"networkidle0"});let h=r.split("/").reverse().slice(1).reverse().join("/");await this.createDirectory(h);let d=await p.pdf({path:r,format:"A4",printBackground:!0,headerTemplate:n,footerTemplate:i,displayHeaderFooter:!1!==o?.displayHeaderFooter&&(""!=n||""!=i)});return await u.close(),console.log(`PDF generated at ${r}`),{finalHTML:c,response:d,path:r.replace(/\\/g,"/")}}async zip(e,s,r={}){try{return{success:!0,response:await o(e,s)}}catch(e){return{success:!1,response:e.message,stack:e.stack}}}parseHTML(e,s){return e=(e=r.render(e||"",s)).replace(/"/g,'"')}};
|
package/dist/index.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";const e=require("fs").promises,s=require("xlsx"),r=require("mustache"),t=require("puppeteer"),{zip:o}=require("zip-a-folder");module.exports=new class{configs={};logger=null;defaultLogger={info:e=>console.log(e),error:e=>console.error(new Error(e))};constructor(){}init(e){try{Object.assign(this.configs,e),this.logger=e?.logger||this.defaultLogger}catch(e){this.log(`Error initializing watcher: ${e.message}`,"error")}}log(e,s="info"){this.logger&&this.logger[s](e)}excelToJson(e,r){let t={success:!0,response:[]};try{r||(r={}),r.sheetname=r.sheetname||"";let o="string"==typeof e?s.readFile(e):s.read(e),
|
|
1
|
+
"use strict";const e=require("fs").promises,s=require("xlsx"),r=require("mustache"),t=require("puppeteer"),{zip:o}=require("zip-a-folder");module.exports=new class{configs={};logger=null;defaultLogger={info:e=>console.log(e),error:e=>console.error(new Error(e))};constructor(){}init(e){try{Object.assign(this.configs,e),this.logger=e?.logger||this.defaultLogger}catch(e){this.log(`Error initializing watcher: ${e.message}`,"error")}}log(e,s="info"){this.logger&&this.logger[s](e)}excelToJson(e,r){let t={success:!0,response:[]};try{r||(r={}),r.sheetname=r.sheetname||"";let o="string"==typeof e?s.readFile(e):s.read(e),a=Object.keys(o.Sheets);if(0==a.length)return t;let n=o.Sheets[r.sheetname];n||(n=o.Sheets[a[0]]),n&&(t.response=s.utils.sheet_to_json(n))}catch(e){t.response=e.message,t.success=!1,t.code=e.code}finally{return t}}jsonToExcel(e,r="",t={}){let o={success:!0,response:[]};try{if(!r)throw new Error("no file specified");t.sheetname=t.sheetname||"",t.header=t.header||[],"string"==typeof t?.header&&(t.header=t.header.split(",")),Array.isArray(t?.header)&&t?.header?.length>0&&(e=e.map((e=>{let s={};for(let r of t.header)t.header.includes(r)?e[r]=e[r]||null:delete e[r],s[r]=void 0!==e[r]?e[r]:null;return s})));const a=s.readFile(r);let n=s.utils.json_to_sheet(e,{cellDates:!0});"function"==typeof t?.preprocessing&&t.preprocessing(n,a,e),void 0!==a.Sheets[t.sheetname]?a.Sheets[t.sheetname]=n:s.utils.book_append_sheet(a,n,t.sheetname),s.writeFile(a,r),o.response="file write successfully !!!"}catch(a){if(console.log("ERROR:",a,a.code),console.log("CODE:",a.code),"ENOENT"==a.code&&!1!==t?.createIfNotExist)try{const a=s.utils.json_to_sheet(e);let n=s.utils.book_new();"function"==typeof t?.preprocessing&&t.preprocessing(a,n,e),s.utils.book_append_sheet(n,a,t.sheetname),s.writeFile(n,r),o.response="file write successfully !!!"}catch(e){o.response=e.message,o.success=!1}else o.response=a.message+"-"+a.stack,o.success=!1}finally{return o}}appendDataToExcel(e,s="",r){let t={success:!0,response:"Append successfully"};try{if(r||(r={}),!Array.isArray(e))throw new Error("The data to append must be of type array.Got:"+typeof e);let o=r?.clearOld?[]:this.excelToJson(s,r).response;Array.isArray(o)||(o=[]);let a=[...o,...e];if("update"==r?.type){if(!r?.primaryKey)throw new Error("The type is update but no primaryKey is specified");let s=r.primaryKey;e.forEach((e=>{let r=a.filter((r=>r[s]&&r[s]==e[s]));if(r.length>1){let t=a.findIndex((r=>r[s]==e[s])),o=r.reduce(((e,s)=>({...e,...s})),{});a.splice(t,1,o),a=a.filter(((r,o)=>t==o||r[s]!=e[s]))}}))}let n=this.jsonToExcel(a,s,{createIfNotExist:!0,...r});n.success?t.response="Data append successfully":t=n}catch(e){t.success=!1,t.response=e.message}finally{return t}}async base64ToFile(s,r,t){try{if(null==s)return{success:!1,response:"No base64 data provided"};let o=s.split(";base64,"),a=o?.[0],n=t?.extension||"png";if(o.length>1&&(a=o[1],!t?.extension)){let e=o[0].split("/");console.log(e),n=e[e.length-1]}let i=(t?.filename||(new Date).getTime()).toString();i.includes(".")||(i+="."+n);let c=Buffer.from(a,"base64");await e.mkdir(r,{recursive:!0});let l=r+"/"+i;return{success:!0,response:l,result:await e.writeFile(l,c)}}catch(e){return{success:!1,response:e.message,error:e}}}async fileToBase64(e,s){try{return s=s||{},await this.readFile(e,{...s,encoding:"base64"})}catch(e){return{success:!1,response:e.message}}}async jsonToFile(s,r,t={}){try{s=JSON.stringify(s);let o=(t?.filename||(new Date).getTime()).toString(),a=t?.extension||"json";return o.includes(".")||(o+="."+a),r=r+"/"+o,{success:!0,response:await e.writeFile(r,s),directory:r,filename:o}}catch(e){return{success:!1,response:e.message+"-"+e.stack,error:e}}}async saveToFile(s,r,t={}){try{let o=(t?.filename||(new Date).getTime()).toString(),a=t?.extension||"txt";return o.includes(".")||(o+="."+a),r=r+"/"+o,{success:!0,response:await e.writeFile(r,s),directory:r,filename:o}}catch(e){return{success:!1,response:e.message+"-"+e.stack,error:e}}}createDirectory(s,r){return e.mkdir(s,{recursive:!0,...r||{}})}async removeDirectory(s,r={}){try{void 0===r?.recursive&&(r.recursive=!0),void 0===r?.force&&(r.force=!0);let t=await e.rm(s,r);return console.info("[SUCCESS]:",s+" removed successfully !!!"),{success:!0,response:t}}catch(e){return console.error("[ERROR]:",`error while removing ${s} (${e.message})`),{success:!1,response:e.message}}}async removeFile(s){try{if("string"==typeof s&&(s=[s]),!Array.isArray(s))throw"Wrong input format- format accepted (Array or string ). Format inputed -"+typeof s;let r=await Promise.all(s.map((async s=>{try{let r=await e.unlink(s);return{success:!0,result:r instanceof Error?r.message:r,file:s}}catch(e){return{success:!1,result:e.message,file:s}}})));return console.info("[SUCCESS]:","file "+s+" removed successfully !!!"),{success:!0,response:r}}catch(e){return console.error("[ERROR]:","error while removing dir ("+e.message+")"),{success:!1,response:e.message}}}async readFile(s,r){try{r=r||{},r?.encoding||(r.encoding="utf8");let t=await e.readFile(s,{encoding:"base64url"});return console.log("content:",t,r),t&&"base64"==r?.encoding&&(t="data:image/png;base64,"+t),{success:!0,response:t}}catch(e){return console.error(e),{success:!1,response:e.message}}}async generatePdf(e,s,r,o){let a=this.configs.templates?.[e];e=a?.template||e;let n=a?.header||o?.header||"",i=a?.footer||o?.footer||"";n=this.parseHTML(n,s),i=this.parseHTML(i,s);let c=this.parseHTML(e,s),l={headless:!0,executablePath:process.env.puppeteerExecutable};l.executablePath||delete l.executablePath;const u=await t.launch(l),p=await u.newPage();await p.setContent(c,{waitUntil:"networkidle0"});let h=r.split("/").reverse().slice(1).reverse().join("/");await this.createDirectory(h);let d=await p.pdf({path:r,format:"A4",printBackground:!0,headerTemplate:n,footerTemplate:i,displayHeaderFooter:!1!==o?.displayHeaderFooter&&(""!=n||""!=i)});return await u.close(),console.log(`PDF generated at ${r}`),{finalHTML:c,response:d,path:r.replace(/\\/g,"/")}}async zip(e,s,r={}){try{return{success:!0,response:await o(e,s)}}catch(e){return{success:!1,response:e.message,stack:e.stack}}}parseHTML(e,s){return e=(e=r.render(e||"",s)).replace(/"/g,'"')}};
|
package/package.json
CHANGED