jspdf-md-renderer 1.6.1 → 1.6.2

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/package.json CHANGED
@@ -1,69 +1,68 @@
1
1
  {
2
- "name": "jspdf-md-renderer",
3
- "version": "1.6.1",
4
- "description": "A jsPDF utility to render Markdown directly into formatted PDFs with custom designs.",
5
- "main": "dist/index.js",
6
- "module": "dist/index.mjs",
7
- "types": "dist/index.d.ts",
8
- "exports": {
9
- ".": {
10
- "import": "./dist/index.mjs",
11
- "require": "./dist/index.js",
12
- "types": "./dist/index.d.ts"
2
+ "name": "jspdf-md-renderer",
3
+ "version": "1.6.2",
4
+ "description": "A jsPDF utility to render Markdown directly into formatted PDFs with custom designs.",
5
+ "main": "dist/index.js",
6
+ "module": "dist/index.mjs",
7
+ "types": "dist/index.d.ts",
8
+ "exports": {
9
+ ".": {
10
+ "import": "./dist/index.mjs",
11
+ "require": "./dist/index.js",
12
+ "types": "./dist/index.d.ts"
13
+ },
14
+ "./types": "./dist/types/index.d.ts"
13
15
  },
14
- "./types": "./dist/types/index.d.ts"
15
- },
16
- "files": [
17
- "dist",
18
- "types",
19
- "LICENSE",
20
- "README.md"
21
- ],
22
- "scripts": {
23
- "dev": "npm run format && npm run lint:fix && npm run build",
24
- "build": "rimraf dist && vite build",
25
- "lint": "eslint src/**",
26
- "lint:fix": "eslint src/** --fix",
27
- "format": "prettier --write .",
28
- "test": "echo \"Error: no test specified\" && exit 1",
29
- "prepare": "npm run build",
30
- "watch": "vite build --watch"
31
- },
32
- "repository": {
33
- "type": "git",
34
- "url": "git+https://github.com/JeelGajera/jspdf-md-renderer.git"
35
- },
36
- "keywords": [
37
- "jspdf",
38
- "markdown",
39
- "pdf",
40
- "renderer"
41
- ],
42
- "author": "Jeel Gajera <jeelgajera200@gmail.com>",
43
- "license": "MIT",
44
- "bugs": {
45
- "url": "https://github.com/JeelGajera/jspdf-md-renderer/issues"
46
- },
47
- "homepage": "https://github.com/JeelGajera/jspdf-md-renderer#readme",
48
- "dependencies": {
49
- "jspdf": "^3.0.1",
50
- "jspdf-md-renderer": "file:",
51
- "marked": "^15.0.3"
52
- },
53
- "devDependencies": {
54
- "@eslint/js": "^9.16.0",
55
- "@types/node": "^22.10.2",
56
- "@typescript-eslint/eslint-plugin": "^8.18.0",
57
- "@typescript-eslint/parser": "^8.18.0",
58
- "eslint": "^9.16.0",
59
- "eslint-config-prettier": "^10.1.2",
60
- "eslint-plugin-prettier": "^5.2.1",
61
- "globals": "^16.0.0",
62
- "prettier": "^3.4.2",
63
- "rimraf": "^6.0.1",
64
- "typescript": "^5.7.2",
65
- "typescript-eslint": "^8.18.0",
66
- "vite": "^6.2.4",
67
- "vite-plugin-dts": "^4.5.3"
68
- }
16
+ "files": [
17
+ "dist",
18
+ "types",
19
+ "LICENSE",
20
+ "README.md"
21
+ ],
22
+ "scripts": {
23
+ "dev": "npm run format && npm run lint:fix && npm run build",
24
+ "build": "rimraf dist && vite build",
25
+ "lint": "eslint src/**",
26
+ "lint:fix": "eslint src/** --fix",
27
+ "format": "prettier --write .",
28
+ "test": "echo \"Error: no test specified\" && exit 1",
29
+ "watch": "vite build --watch"
30
+ },
31
+ "repository": {
32
+ "type": "git",
33
+ "url": "git+https://github.com/JeelGajera/jspdf-md-renderer.git"
34
+ },
35
+ "keywords": [
36
+ "jspdf",
37
+ "markdown",
38
+ "pdf",
39
+ "renderer"
40
+ ],
41
+ "author": "Jeel Gajera <jeelgajera200@gmail.com>",
42
+ "license": "MIT",
43
+ "bugs": {
44
+ "url": "https://github.com/JeelGajera/jspdf-md-renderer/issues"
45
+ },
46
+ "homepage": "https://github.com/JeelGajera/jspdf-md-renderer#readme",
47
+ "dependencies": {
48
+ "jspdf": "^3.0.1",
49
+ "jspdf-md-renderer": "file:",
50
+ "marked": "^15.0.3"
51
+ },
52
+ "devDependencies": {
53
+ "@eslint/js": "^9.16.0",
54
+ "@types/node": "^22.10.2",
55
+ "@typescript-eslint/eslint-plugin": "^8.18.0",
56
+ "@typescript-eslint/parser": "^8.18.0",
57
+ "eslint": "^9.16.0",
58
+ "eslint-config-prettier": "^10.1.2",
59
+ "eslint-plugin-prettier": "^5.2.1",
60
+ "globals": "^16.0.0",
61
+ "prettier": "^3.4.2",
62
+ "rimraf": "^6.0.1",
63
+ "typescript": "^5.7.2",
64
+ "typescript-eslint": "^8.18.0",
65
+ "vite": "^6.2.4",
66
+ "vite-plugin-dts": "^4.5.3"
67
+ }
69
68
  }
package/dist/index.d.ts DELETED
@@ -1,81 +0,0 @@
1
- import { default as default_2 } from 'jspdf';
2
- import { jsPDFOptions } from 'jspdf';
3
-
4
- declare type FontItem = {
5
- name: string;
6
- style: string;
7
- };
8
-
9
- /**
10
- * Parses markdown into tokens and converts to a custom parsed structure.
11
- *
12
- * @param text - The markdown content to parse.
13
- * @returns Parsed markdown elements.
14
- */
15
- export declare const MdTextParser: (text: string) => Promise<ParsedElement[]>;
16
-
17
- /**
18
- * Renders parsed markdown text into jsPDF document.
19
- *
20
- * @param doc - The jsPDF document.
21
- * @param text - The markdown content to render.
22
- * @param options - The render options (fonts, page margins, etc.).
23
- */
24
- export declare const MdTextRender: (doc: default_2, text: string, options: RenderOption) => Promise<void>;
25
-
26
- declare type ParsedElement = {
27
- type: string;
28
- content?: string;
29
- depth?: number;
30
- items?: ParsedElement[];
31
- ordered?: boolean;
32
- start?: number;
33
- lang?: string;
34
- code?: string;
35
- src?: string;
36
- alt?: string;
37
- href?: string;
38
- text?: string;
39
- header?: {
40
- type?: string;
41
- content?: any;
42
- };
43
- rows?: {
44
- type?: string;
45
- content?: any;
46
- };
47
- };
48
-
49
- export declare type RenderOption = {
50
- cursor: {
51
- x: number;
52
- y: number;
53
- };
54
- page: {
55
- format?: string | number[];
56
- unit?: jsPDFOptions['unit'];
57
- orientation?: jsPDFOptions['orientation'];
58
- maxContentWidth: number;
59
- maxContentHeight: number;
60
- lineSpace: number;
61
- defaultLineHeightFactor: number;
62
- defaultFontSize: number;
63
- defaultTitleFontSize: number;
64
- topmargin: number;
65
- xpading: number;
66
- xmargin: number;
67
- indent: number;
68
- };
69
- font: {
70
- bold: FontItem;
71
- regular: FontItem;
72
- light: FontItem;
73
- };
74
- content?: {
75
- textAlignment: 'left' | 'right' | 'center' | 'justify';
76
- };
77
- pageBreakHandler?: () => void;
78
- endCursorYHandler: (y: number) => void;
79
- };
80
-
81
- export { }
package/dist/index.js DELETED
@@ -1,4 +0,0 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const I=require("marked");var s=(t=>(t.Heading="heading",t.Paragraph="paragraph",t.List="list",t.ListItem="list_item",t.Blockquote="blockquote",t.Code="code",t.CodeSpan="codespan",t.Table="table",t.Html="html",t.Hr="hr",t.Image="image",t.Link="link",t.Strong="strong",t.Em="em",t.TableHeader="table_header",t.TableCell="table_cell",t.Raw="raw",t.Text="text",t))(s||{});const F=async t=>{const a=await I.marked.lexer(t,{async:!0});return d(a)},d=t=>{const a=[];return t.forEach(e=>{try{const n=T[e.type];n?a.push(n(e)):a.push({type:s.Raw,content:e.raw})}catch(n){console.error("Failed to handle token ==>",e,n)}}),a},T={[s.Heading]:t=>({type:s.Heading,depth:t.depth,content:t.text,items:t.tokens?d(t.tokens):[]}),[s.Paragraph]:t=>({type:s.Paragraph,content:t.text,items:t.tokens?d(t.tokens):[]}),[s.List]:t=>({type:s.List,ordered:t.ordered,start:t.start,items:t.items?d(t.items):[]}),[s.ListItem]:t=>({type:s.ListItem,content:t.text,items:t.tokens?d(t.tokens):[]}),[s.Code]:t=>({type:s.Code,lang:t.lang,code:t.text}),[s.Table]:t=>({type:s.Table,header:t.header.map(a=>({type:s.TableHeader,content:a})),rows:t.rows.map(a=>a.map(e=>({type:s.TableCell,content:e})))}),[s.Image]:t=>({type:s.Image,src:t.href,alt:t.text}),[s.Link]:t=>({type:s.Link,href:t.href,text:t.text,items:t.tokens?d(t.tokens):[]}),[s.Strong]:t=>({type:s.Strong,content:t.text,items:t.tokens?d(t.tokens):[]}),[s.Em]:t=>({type:s.Em,content:t.text,items:t.tokens?d(t.tokens):[]}),[s.Text]:t=>({type:s.Text,content:t.text,items:t.tokens?d(t.tokens):[]}),[s.Hr]:t=>({type:s.Hr,content:t.raw,items:t.tokens?d(t.tokens):[]}),[s.CodeSpan]:t=>({type:s.CodeSpan,content:t.text,items:t.tokens?d(t.tokens):[]})},m=(t,a)=>{var e,n;typeof a.pageBreakHandler=="function"?a.pageBreakHandler():t.addPage((e=a.page)==null?void 0:e.format,(n=a.page)==null?void 0:n.orientation)},p=(t,a)=>t.getTextDimensions("H").h*a.page.defaultLineHeightFactor,E=(t,a,e,n,i,g)=>{const x=6-((a==null?void 0:a.depth)??0)>0?6-((a==null?void 0:a.depth)??0):0;if(t.setFontSize(i.page.defaultFontSize+x),a!=null&&a.items&&(a==null?void 0:a.items.length)>0)for(const f of(a==null?void 0:a.items)??[])e=g(f,n,!1);else t.text((a==null?void 0:a.content)??"",e.x+n,e.y,{align:"left",maxWidth:i.page.maxContentWidth-n}),e.y+=1.5*p(t,i);return t.setFontSize(i.page.defaultFontSize),e},P=(t,a,e,n,i,g,x,f,y)=>{const r=(f-e)/(a.length-1);let l=i;const h=g+n*x;for(const b of a)t.text(b.text,l,h,{align:"justify",lineHeightFactor:y,maxWidth:f}),l+=b.wordLength+r},j=(t,a,e,n,i,g,x,f)=>{const y=t.map(r=>r.text).join(" ");a.text(y,e,n+i*g,{align:"justify",lineHeightFactor:f,maxWidth:x})},W=(t,a,e,n,i,g)=>{const x={x:e,y:n},f=t.getTextDimensions("A").h*g,y=a.split(" ");let r=0,l=[],h=0;for(const b of y){const C=t.getTextWidth(b+"a");C+h>=i&&(P(t,l,h,r++,e,n,f,i,g),l=[],h=0),l.push({text:b,wordLength:C}),h+=C}return l.length>0&&j(l,t,e,n,r,f,i,g),x.y=n+r*f,x.x=t.getTextWidth(a)+e,x},D=(t,a,e,n,i,g)=>{t.setFontSize(i.page.defaultFontSize);let x=a.content;const f=t.getTextDimensions("A").h*i.page.defaultLineHeightFactor;if(a!=null&&a.items&&(a==null?void 0:a.items.length)>0)for(const y of(a==null?void 0:a.items)??[])e=g(y,n,!1);else{if(e.y+t.splitTextToSize(x??"",i.page.maxContentWidth-n).length*f-3*f>=i.page.maxContentHeight){const y=t.splitTextToSize(x??"",i.page.maxContentWidth-n),r=[],l=e.y;for(let h=0;h<y.length;h++)if(e.y-2*f<i.page.maxContentHeight)r.push(y[h]),e.y+=i.page.lineSpace;else{h<=y.length-1&&(x=y.slice(h).join(""));break}r.length>0&&(e=W(t,r.join(" "),e.x+n,l,i.page.maxContentWidth-n,i.page.defaultLineHeightFactor)),m(t,i),e.y=i.page.topmargin}e.y=W(t,x??"",e.x+n,e.y,i.page.maxContentWidth-n,i.page.defaultLineHeightFactor).y+p(t,i),e.x=i.page.xpading}return e},R=(t,a,e,n,i,g)=>{var x;t.setFontSize(i.page.defaultFontSize);for(const[f,y]of((x=a==null?void 0:a.items)==null?void 0:x.entries())??[]){const r=a.ordered?(a.start??0)+f:a.start;e=g(y,n+1,!0,r,a.ordered),e.y+=p(t,i)*.2}return e},c=(t,a,e,n,i)=>{const g=t.getFont().fontName,x=t.getFont().fontStyle,f=t.getFontSize(),y=l=>{switch(l){case"normal":return 0;case"bold":return 1;case"italic":return 1.5;case"bolditalic":return 1.5;default:return 0}},r=(l,h)=>{var S;h==="bold"?t.setFont(i.font.bold.name&&i.font.bold.name!==""?i.font.bold.name:g,i.font.bold.style||"bold"):h==="italic"?t.setFont(i.font.regular.name,"italic"):h==="bolditalic"?t.setFont(i.font.bold.name&&i.font.bold.name!==""?i.font.bold.name:g,"bolditalic"):t.setFont(i.font.regular.name,x);const b=i.page.maxContentWidth-n-e.x,C=t.splitTextToSize(l,b);if(C.length>1){const L=C[0],w=(S=C==null?void 0:C.slice(1))==null?void 0:S.join(" ");t.text(L,e.x+(n>=2?n+2*y(h):0),e.y,{baseline:"top",maxWidth:b}),e.x=n,e.y+=p(t,i);const H=i.page.maxContentWidth-n-i.page.xpading-i.page.xmargin;t.splitTextToSize(w,H).forEach(z=>{t.text(z,e.x+n,e.y,{baseline:"top",maxWidth:H}),e.x=n,e.y+=p(t,i)})}else t.text(l,e.x+n,e.y,{baseline:"top",maxWidth:b}),e.x+=t.getTextDimensions(l).w+(n>=2?l.split(" ").length+2:2)*y(h)};if(a.type==="text"&&a.items&&a.items.length>0)for(const l of a.items)if(l.type==="em"||l.type==="strong"){const h=l.type==="em"?"italic":"bold";if(l.items&&l.items.length>0)for(const b of l.items)b.type==="strong"&&h==="italic"||b.type==="em"&&h==="bold"?r(b.content||"","bolditalic"):r(b.content||"",h);else r(l.content||"",h)}else r(l.content||"","normal");else a.type==="em"?r(a.content||"","italic"):a.type==="strong"?r(a.content||"","bold"):r(a.content||"","normal");return t.setFont(g,x),t.setFontSize(f),e},u=(t,a,e,n,i,g,x,f)=>{const y=n*i.page.indent,r=f?`${x}. `:"• ";e.y+p(t,i)>=i.page.maxContentHeight&&(m(t,i),e.y=i.page.topmargin),t.setFont(i.font.regular.name,i.font.regular.style),t.text(r,e.x+y,e.y,{baseline:"top"});const l=t.getTextWidth(r);if(e.x+=l,a.items&&a.items.length>0)for(const h of a.items){if(e.y+p(t,i)>=i.page.maxContentHeight&&(m(t,i),e.y=i.page.topmargin),h.type===s.List)g(h,n+1,!0,x,h.ordered??!1);else if(h.type===s.ListItem){const b=a.type===s.List?n:n+1;g(h,b,!0,x,f)}else e=c(t,h,e,y,i);e.x=i.page.xpading,e.y+=p(t,i)}else if(a.content){const h=t.splitTextToSize(a.content,i.page.maxContentWidth-y-e.x);t.text(h,e.x+y,e.y,{baseline:"top",maxWidth:i.page.maxContentWidth-y-e.x}),e.y+=p(t,i)*h.length,e.x=i.page.xmargin+y;const b=t.getTextWidth(a.content);e.x+=b}return e},B=(t,a,e,n,i,g,x,f,y,r=!0)=>{if(a!=null&&a.items&&(a==null?void 0:a.items.length)>0)for(const l of(a==null?void 0:a.items)??[])e=x(l,n,i,f,y,r);else{const l=n*g.page.indent,h=i?y?`${f}. `:"• ":"",b=t.splitTextToSize(h+a.content,g.page.maxContentWidth-l);e.y+b.length*p(t,g)>=g.page.maxContentHeight&&(m(t,g),e.y=g.page.topmargin),r?(e.y=W(t,h+a.content,e.x+l,e.y,g.page.maxContentWidth-l,g.page.defaultLineHeightFactor).y+p(t,g),e.x=g.page.xpading):(t.text(h+a.content,e.x+l,e.y,{baseline:"top"}),e.x+=t.getTextWidth(h+a.content),e.x>=g.page.xpading+g.page.maxContentWidth&&(m(t,g),e.x=g.page.xpading,e.y=g.page.topmargin))}return e},_=(t,a,e)=>{const n=t.internal.pageSize.getWidth();return t.setLineDashPattern([1,1],0),t.setLineWidth(.1),t.line(e.page.xpading,a.y,n-e.page.xpading,a.y),t.setLineWidth(.1),t.setLineDashPattern([],0),a.y+=p(t,e),a},q=(t,a,e,n,i,g)=>{const x=n*g.page.indent;e.y+t.splitTextToSize(a.code??"",g.page.maxContentWidth-x).length*p(t,g)-2*p(t,g)>=g.page.maxContentHeight&&(m(t,g),e.y=g.page.topmargin);const f=t.splitTextToSize(a.code??"",g.page.maxContentWidth-x).length*p(t,g);return e.y+=g.page.lineSpace,t.setFillColor("#EEEEEE"),t.setDrawColor("#eee"),t.roundedRect(e.x,e.y-g.page.lineSpace,g.page.maxContentWidth,f,2,2,"FD"),t.setFontSize(10),t.text(a.lang??"",e.x+g.page.maxContentWidth-t.getTextWidth(a.lang??"")-g.page.lineSpace/2,e.y),t.setFontSize(g.page.defaultFontSize),t.text(a.code??"",e.x+4,e.y),e.y+=f,e},J=async(t,a,e)=>{const n=await F(a);console.log(n);let i={x:e.cursor.x,y:e.cursor.y};const g=(x,f=0,y=!1,r=0,l=!1,h=!0)=>{const b=f*e.page.indent;switch(i.y+t.splitTextToSize(x.content??"",e.page.maxContentWidth-b).length*p(t,e)>=e.page.maxContentHeight&&(m(t,e),i.y=e.page.topmargin),x.type){case s.Heading:i=E(t,x,i,b,e,g);break;case s.Paragraph:i=D(t,x,i,b,e,g);break;case s.List:i=R(t,x,i,f,e,g);break;case s.ListItem:i=u(t,x,i,f,e,g,r,l);break;case s.Hr:i=_(t,i,e);break;case s.Code:i=q(t,x,i,f,y,e);break;case s.Strong:case s.Em:i=c(t,x,i,b,e);break;case s.Raw:case s.Text:i=B(t,x,i,f,y,e,g,r,l,h);break;default:console.warn(`Warning: Unsupported element type encountered: ${x.type}.
2
- If you believe this element type should be supported, please create an issue at:
3
- https://github.com/JeelGajera/jspdf-md-renderer/issues
4
- with details of the element and expected behavior. Thank you for helping improve this library!`);break}return i};for(const x of n)g(x);e.endCursorYHandler(i.y)};exports.MdTextParser=F;exports.MdTextRender=J;
package/dist/index.mjs DELETED
@@ -1,501 +0,0 @@
1
- import { marked as z } from "marked";
2
- var x = /* @__PURE__ */ ((t) => (t.Heading = "heading", t.Paragraph = "paragraph", t.List = "list", t.ListItem = "list_item", t.Blockquote = "blockquote", t.Code = "code", t.CodeSpan = "codespan", t.Table = "table", t.Html = "html", t.Hr = "hr", t.Image = "image", t.Link = "link", t.Strong = "strong", t.Em = "em", t.TableHeader = "table_header", t.TableCell = "table_cell", t.Raw = "raw", t.Text = "text", t))(x || {});
3
- const I = async (t) => {
4
- const a = await z.lexer(t, { async: !0 });
5
- return C(a);
6
- }, C = (t) => {
7
- const a = [];
8
- return t.forEach((e) => {
9
- try {
10
- const n = E[e.type];
11
- n ? a.push(n(e)) : a.push({
12
- type: x.Raw,
13
- content: e.raw
14
- });
15
- } catch (n) {
16
- console.error("Failed to handle token ==>", e, n);
17
- }
18
- }), a;
19
- }, E = {
20
- [x.Heading]: (t) => ({
21
- type: x.Heading,
22
- depth: t.depth,
23
- content: t.text,
24
- items: t.tokens ? C(t.tokens) : []
25
- }),
26
- [x.Paragraph]: (t) => ({
27
- type: x.Paragraph,
28
- content: t.text,
29
- items: t.tokens ? C(t.tokens) : []
30
- }),
31
- [x.List]: (t) => ({
32
- type: x.List,
33
- ordered: t.ordered,
34
- start: t.start,
35
- items: t.items ? C(t.items) : []
36
- }),
37
- [x.ListItem]: (t) => ({
38
- type: x.ListItem,
39
- content: t.text,
40
- items: t.tokens ? C(t.tokens) : []
41
- }),
42
- [x.Code]: (t) => ({
43
- type: x.Code,
44
- lang: t.lang,
45
- code: t.text
46
- }),
47
- [x.Table]: (t) => ({
48
- type: x.Table,
49
- header: t.header.map((a) => ({
50
- type: x.TableHeader,
51
- content: a
52
- })),
53
- rows: t.rows.map(
54
- (a) => a.map((e) => ({
55
- type: x.TableCell,
56
- content: e
57
- }))
58
- )
59
- }),
60
- [x.Image]: (t) => ({
61
- type: x.Image,
62
- src: t.href,
63
- alt: t.text
64
- }),
65
- [x.Link]: (t) => ({
66
- type: x.Link,
67
- href: t.href,
68
- text: t.text,
69
- items: t.tokens ? C(t.tokens) : []
70
- }),
71
- [x.Strong]: (t) => ({
72
- type: x.Strong,
73
- content: t.text,
74
- items: t.tokens ? C(t.tokens) : []
75
- }),
76
- [x.Em]: (t) => ({
77
- type: x.Em,
78
- content: t.text,
79
- items: t.tokens ? C(t.tokens) : []
80
- }),
81
- [x.Text]: (t) => ({
82
- type: x.Text,
83
- content: t.text,
84
- items: t.tokens ? C(t.tokens) : []
85
- }),
86
- [x.Hr]: (t) => ({
87
- type: x.Hr,
88
- content: t.raw,
89
- items: t.tokens ? C(t.tokens) : []
90
- }),
91
- [x.CodeSpan]: (t) => ({
92
- type: x.CodeSpan,
93
- content: t.text,
94
- items: t.tokens ? C(t.tokens) : []
95
- })
96
- }, d = (t, a) => {
97
- var e, n;
98
- typeof a.pageBreakHandler == "function" ? a.pageBreakHandler() : t.addPage((e = a.page) == null ? void 0 : e.format, (n = a.page) == null ? void 0 : n.orientation);
99
- }, p = (t, a) => t.getTextDimensions("H").h * a.page.defaultLineHeightFactor, T = (t, a, e, n, i, g) => {
100
- const s = 6 - ((a == null ? void 0 : a.depth) ?? 0) > 0 ? 6 - ((a == null ? void 0 : a.depth) ?? 0) : 0;
101
- if (t.setFontSize(i.page.defaultFontSize + s), a != null && a.items && (a == null ? void 0 : a.items.length) > 0)
102
- for (const f of (a == null ? void 0 : a.items) ?? [])
103
- e = g(f, n, !1);
104
- else
105
- t.text((a == null ? void 0 : a.content) ?? "", e.x + n, e.y, {
106
- align: "left",
107
- maxWidth: i.page.maxContentWidth - n
108
- }), e.y += 1.5 * p(t, i);
109
- return t.setFontSize(i.page.defaultFontSize), e;
110
- }, P = (t, a, e, n, i, g, s, f, y) => {
111
- const r = (f - e) / (a.length - 1);
112
- let l = i;
113
- const h = g + n * s;
114
- for (const b of a)
115
- t.text(b.text, l, h, {
116
- align: "justify",
117
- lineHeightFactor: y,
118
- maxWidth: f
119
- }), l += b.wordLength + r;
120
- }, j = (t, a, e, n, i, g, s, f) => {
121
- const y = t.map((r) => r.text).join(" ");
122
- a.text(y, e, n + i * g, {
123
- align: "justify",
124
- lineHeightFactor: f,
125
- maxWidth: s
126
- });
127
- }, W = (t, a, e, n, i, g) => {
128
- const s = {
129
- x: e,
130
- y: n
131
- }, f = t.getTextDimensions("A").h * g, y = a.split(" ");
132
- let r = 0, l = [], h = 0;
133
- for (const b of y) {
134
- const m = t.getTextWidth(b + "a");
135
- m + h >= i && (P(
136
- t,
137
- l,
138
- h,
139
- r++,
140
- e,
141
- n,
142
- f,
143
- i,
144
- g
145
- ), l = [], h = 0), l.push({ text: b, wordLength: m }), h += m;
146
- }
147
- return l.length > 0 && j(
148
- l,
149
- t,
150
- e,
151
- n,
152
- r,
153
- f,
154
- i,
155
- g
156
- ), s.y = n + r * f, s.x = t.getTextWidth(a) + e, s;
157
- }, D = (t, a, e, n, i, g) => {
158
- t.setFontSize(i.page.defaultFontSize);
159
- let s = a.content;
160
- const f = t.getTextDimensions("A").h * i.page.defaultLineHeightFactor;
161
- if (a != null && a.items && (a == null ? void 0 : a.items.length) > 0)
162
- for (const y of (a == null ? void 0 : a.items) ?? [])
163
- e = g(y, n, !1);
164
- else {
165
- if (e.y + t.splitTextToSize(
166
- s ?? "",
167
- i.page.maxContentWidth - n
168
- ).length * f - 3 * f >= i.page.maxContentHeight) {
169
- const y = t.splitTextToSize(
170
- s ?? "",
171
- i.page.maxContentWidth - n
172
- ), r = [], l = e.y;
173
- for (let h = 0; h < y.length; h++)
174
- if (e.y - 2 * f < i.page.maxContentHeight)
175
- r.push(y[h]), e.y += i.page.lineSpace;
176
- else {
177
- h <= y.length - 1 && (s = y.slice(h).join(""));
178
- break;
179
- }
180
- r.length > 0 && (e = W(
181
- t,
182
- r.join(" "),
183
- e.x + n,
184
- l,
185
- i.page.maxContentWidth - n,
186
- i.page.defaultLineHeightFactor
187
- )), d(t, i), e.y = i.page.topmargin;
188
- }
189
- e.y = W(
190
- t,
191
- s ?? "",
192
- e.x + n,
193
- e.y,
194
- i.page.maxContentWidth - n,
195
- i.page.defaultLineHeightFactor
196
- ).y + p(t, i), e.x = i.page.xpading;
197
- }
198
- return e;
199
- }, R = (t, a, e, n, i, g) => {
200
- var s;
201
- t.setFontSize(i.page.defaultFontSize);
202
- for (const [f, y] of ((s = a == null ? void 0 : a.items) == null ? void 0 : s.entries()) ?? []) {
203
- const r = a.ordered ? (a.start ?? 0) + f : a.start;
204
- e = g(
205
- y,
206
- n + 1,
207
- !0,
208
- r,
209
- a.ordered
210
- ), e.y += p(t, i) * 0.2;
211
- }
212
- return e;
213
- }, F = (t, a, e, n, i) => {
214
- const g = t.getFont().fontName, s = t.getFont().fontStyle, f = t.getFontSize(), y = (l) => {
215
- switch (l) {
216
- case "normal":
217
- return 0;
218
- case "bold":
219
- return 1;
220
- case "italic":
221
- return 1.5;
222
- case "bolditalic":
223
- return 1.5;
224
- default:
225
- return 0;
226
- }
227
- }, r = (l, h) => {
228
- var H;
229
- h === "bold" ? t.setFont(
230
- i.font.bold.name && i.font.bold.name !== "" ? i.font.bold.name : g,
231
- i.font.bold.style || "bold"
232
- ) : h === "italic" ? t.setFont(i.font.regular.name, "italic") : h === "bolditalic" ? t.setFont(
233
- i.font.bold.name && i.font.bold.name !== "" ? i.font.bold.name : g,
234
- "bolditalic"
235
- ) : t.setFont(i.font.regular.name, s);
236
- const b = i.page.maxContentWidth - n - e.x, m = t.splitTextToSize(l, b);
237
- if (m.length > 1) {
238
- const c = m[0], L = (H = m == null ? void 0 : m.slice(1)) == null ? void 0 : H.join(" ");
239
- t.text(
240
- c,
241
- e.x + (n >= 2 ? n + 2 * y(h) : 0),
242
- e.y,
243
- {
244
- baseline: "top",
245
- maxWidth: b
246
- }
247
- ), e.x = n, e.y += p(t, i);
248
- const S = i.page.maxContentWidth - n - i.page.xpading - i.page.xmargin;
249
- t.splitTextToSize(L, S).forEach((w) => {
250
- t.text(w, e.x + n, e.y, {
251
- baseline: "top",
252
- maxWidth: S
253
- }), e.x = n, e.y += p(t, i);
254
- });
255
- } else
256
- t.text(l, e.x + n, e.y, {
257
- baseline: "top",
258
- maxWidth: b
259
- }), e.x += t.getTextDimensions(l).w + (n >= 2 ? l.split(" ").length + 2 : 2) * y(h);
260
- };
261
- if (a.type === "text" && a.items && a.items.length > 0)
262
- for (const l of a.items)
263
- if (l.type === "em" || l.type === "strong") {
264
- const h = l.type === "em" ? "italic" : "bold";
265
- if (l.items && l.items.length > 0)
266
- for (const b of l.items)
267
- b.type === "strong" && h === "italic" || b.type === "em" && h === "bold" ? r(
268
- b.content || "",
269
- "bolditalic"
270
- ) : r(
271
- b.content || "",
272
- h
273
- );
274
- else
275
- r(l.content || "", h);
276
- } else
277
- r(l.content || "", "normal");
278
- else a.type === "em" ? r(a.content || "", "italic") : a.type === "strong" ? r(a.content || "", "bold") : r(a.content || "", "normal");
279
- return t.setFont(g, s), t.setFontSize(f), e;
280
- }, B = (t, a, e, n, i, g, s, f) => {
281
- const y = n * i.page.indent, r = f ? `${s}. ` : "• ";
282
- e.y + p(t, i) >= i.page.maxContentHeight && (d(t, i), e.y = i.page.topmargin), t.setFont(i.font.regular.name, i.font.regular.style), t.text(r, e.x + y, e.y, { baseline: "top" });
283
- const l = t.getTextWidth(r);
284
- if (e.x += l, a.items && a.items.length > 0)
285
- for (const h of a.items) {
286
- if (e.y + p(t, i) >= i.page.maxContentHeight && (d(t, i), e.y = i.page.topmargin), h.type === x.List)
287
- g(
288
- h,
289
- n + 1,
290
- !0,
291
- s,
292
- h.ordered ?? !1
293
- );
294
- else if (h.type === x.ListItem) {
295
- const b = a.type === x.List ? n : n + 1;
296
- g(
297
- h,
298
- b,
299
- !0,
300
- s,
301
- f
302
- );
303
- } else
304
- e = F(
305
- t,
306
- h,
307
- e,
308
- y,
309
- i
310
- );
311
- e.x = i.page.xpading, e.y += p(t, i);
312
- }
313
- else if (a.content) {
314
- const h = t.splitTextToSize(
315
- a.content,
316
- i.page.maxContentWidth - y - e.x
317
- );
318
- t.text(
319
- h,
320
- e.x + y,
321
- e.y,
322
- {
323
- baseline: "top",
324
- maxWidth: i.page.maxContentWidth - y - e.x
325
- }
326
- ), e.y += p(t, i) * h.length, e.x = i.page.xmargin + y;
327
- const b = t.getTextWidth(a.content);
328
- e.x += b;
329
- }
330
- return e;
331
- }, _ = (t, a, e, n, i, g, s, f, y, r = !0) => {
332
- if (a != null && a.items && (a == null ? void 0 : a.items.length) > 0)
333
- for (const l of (a == null ? void 0 : a.items) ?? [])
334
- e = s(
335
- l,
336
- n,
337
- i,
338
- f,
339
- y,
340
- r
341
- );
342
- else {
343
- const l = n * g.page.indent, h = i ? y ? `${f}. ` : "• " : "", b = t.splitTextToSize(
344
- h + a.content,
345
- g.page.maxContentWidth - l
346
- );
347
- e.y + b.length * p(t, g) >= g.page.maxContentHeight && (d(t, g), e.y = g.page.topmargin), r ? (e.y = W(
348
- t,
349
- h + a.content,
350
- e.x + l,
351
- e.y,
352
- g.page.maxContentWidth - l,
353
- g.page.defaultLineHeightFactor
354
- ).y + p(t, g), e.x = g.page.xpading) : (t.text(h + a.content, e.x + l, e.y, {
355
- baseline: "top"
356
- }), e.x += t.getTextWidth(h + a.content), e.x >= g.page.xpading + g.page.maxContentWidth && (d(t, g), e.x = g.page.xpading, e.y = g.page.topmargin));
357
- }
358
- return e;
359
- }, J = (t, a, e) => {
360
- const n = t.internal.pageSize.getWidth();
361
- return t.setLineDashPattern([1, 1], 0), t.setLineWidth(0.1), t.line(
362
- e.page.xpading,
363
- a.y,
364
- n - e.page.xpading,
365
- a.y
366
- ), t.setLineWidth(0.1), t.setLineDashPattern([], 0), a.y += p(t, e), a;
367
- }, $ = (t, a, e, n, i, g) => {
368
- const s = n * g.page.indent;
369
- e.y + t.splitTextToSize(
370
- a.code ?? "",
371
- g.page.maxContentWidth - s
372
- ).length * p(t, g) - 2 * p(t, g) >= g.page.maxContentHeight && (d(t, g), e.y = g.page.topmargin);
373
- const f = t.splitTextToSize(
374
- a.code ?? "",
375
- g.page.maxContentWidth - s
376
- ).length * p(t, g);
377
- return e.y += g.page.lineSpace, t.setFillColor("#EEEEEE"), t.setDrawColor("#eee"), t.roundedRect(
378
- e.x,
379
- e.y - g.page.lineSpace,
380
- g.page.maxContentWidth,
381
- f,
382
- 2,
383
- 2,
384
- "FD"
385
- ), t.setFontSize(10), t.text(
386
- a.lang ?? "",
387
- e.x + g.page.maxContentWidth - t.getTextWidth(a.lang ?? "") - g.page.lineSpace / 2,
388
- e.y
389
- ), t.setFontSize(g.page.defaultFontSize), t.text(a.code ?? "", e.x + 4, e.y), e.y += f, e;
390
- }, N = async (t, a, e) => {
391
- const n = await I(a);
392
- console.log(n);
393
- let i = {
394
- x: e.cursor.x,
395
- y: e.cursor.y
396
- };
397
- const g = (s, f = 0, y = !1, r = 0, l = !1, h = !0) => {
398
- const b = f * e.page.indent;
399
- switch (i.y + t.splitTextToSize(
400
- s.content ?? "",
401
- e.page.maxContentWidth - b
402
- ).length * p(t, e) >= e.page.maxContentHeight && (d(t, e), i.y = e.page.topmargin), s.type) {
403
- case x.Heading:
404
- i = T(
405
- t,
406
- s,
407
- i,
408
- b,
409
- e,
410
- g
411
- );
412
- break;
413
- case x.Paragraph:
414
- i = D(
415
- t,
416
- s,
417
- i,
418
- b,
419
- e,
420
- g
421
- );
422
- break;
423
- case x.List:
424
- i = R(
425
- t,
426
- s,
427
- i,
428
- f,
429
- e,
430
- g
431
- );
432
- break;
433
- case x.ListItem:
434
- i = B(
435
- t,
436
- s,
437
- i,
438
- f,
439
- e,
440
- g,
441
- r,
442
- l
443
- );
444
- break;
445
- case x.Hr:
446
- i = J(t, i, e);
447
- break;
448
- case x.Code:
449
- i = $(
450
- t,
451
- s,
452
- i,
453
- f,
454
- y,
455
- e
456
- );
457
- break;
458
- case x.Strong:
459
- case x.Em:
460
- i = F(
461
- t,
462
- s,
463
- i,
464
- b,
465
- e
466
- );
467
- break;
468
- case x.Raw:
469
- case x.Text:
470
- i = _(
471
- t,
472
- s,
473
- i,
474
- f,
475
- y,
476
- e,
477
- g,
478
- r,
479
- l,
480
- h
481
- );
482
- break;
483
- default:
484
- console.warn(
485
- `Warning: Unsupported element type encountered: ${s.type}.
486
- If you believe this element type should be supported, please create an issue at:
487
- https://github.com/JeelGajera/jspdf-md-renderer/issues
488
- with details of the element and expected behavior. Thank you for helping improve this library!`
489
- );
490
- break;
491
- }
492
- return i;
493
- };
494
- for (const s of n)
495
- g(s);
496
- e.endCursorYHandler(i.y);
497
- };
498
- export {
499
- I as MdTextParser,
500
- N as MdTextRender
501
- };