canvasdown 0.1.0
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/LICENSE +21 -0
- package/README.md +541 -0
- package/dist/advanced.d.ts +65 -0
- package/dist/advanced.d.ts.map +1 -0
- package/dist/advanced.js +442 -0
- package/dist/advanced.js.map +1 -0
- package/dist/canvas-provider.d.ts +11 -0
- package/dist/canvas-provider.d.ts.map +1 -0
- package/dist/canvas-provider.js +15 -0
- package/dist/canvas-provider.js.map +1 -0
- package/dist/index.d.ts +28 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +84 -0
- package/dist/index.js.map +1 -0
- package/dist/layout.d.ts +95 -0
- package/dist/layout.d.ts.map +1 -0
- package/dist/layout.js +179 -0
- package/dist/layout.js.map +1 -0
- package/dist/parser.d.ts +4 -0
- package/dist/parser.d.ts.map +1 -0
- package/dist/parser.js +252 -0
- package/dist/parser.js.map +1 -0
- package/dist/react.d.ts +33 -0
- package/dist/react.d.ts.map +1 -0
- package/dist/react.js +43 -0
- package/dist/react.js.map +1 -0
- package/dist/renderer.d.ts +4 -0
- package/dist/renderer.d.ts.map +1 -0
- package/dist/renderer.js +238 -0
- package/dist/renderer.js.map +1 -0
- package/dist/stream.d.ts +10 -0
- package/dist/stream.d.ts.map +1 -0
- package/dist/stream.js +72 -0
- package/dist/stream.js.map +1 -0
- package/dist/theme.d.ts +75 -0
- package/dist/theme.d.ts.map +1 -0
- package/dist/theme.js +123 -0
- package/dist/theme.js.map +1 -0
- package/dist/tokens.d.ts +66 -0
- package/dist/tokens.d.ts.map +1 -0
- package/dist/tokens.js +2 -0
- package/dist/tokens.js.map +1 -0
- package/dist/worker-bridge.d.ts +26 -0
- package/dist/worker-bridge.d.ts.map +1 -0
- package/dist/worker-bridge.js +31 -0
- package/dist/worker-bridge.js.map +1 -0
- package/package.json +65 -0
package/dist/tokens.d.ts
ADDED
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
export type SpanStyle = {
|
|
2
|
+
color?: string | undefined;
|
|
3
|
+
background?: string | undefined;
|
|
4
|
+
backgroundRadius?: number | undefined;
|
|
5
|
+
underline?: boolean | undefined;
|
|
6
|
+
strikethrough?: boolean | undefined;
|
|
7
|
+
href?: string | undefined;
|
|
8
|
+
};
|
|
9
|
+
export type InlineSpan = {
|
|
10
|
+
text: string;
|
|
11
|
+
font: string;
|
|
12
|
+
style?: SpanStyle | undefined;
|
|
13
|
+
};
|
|
14
|
+
export type HeadingToken = {
|
|
15
|
+
type: 'heading';
|
|
16
|
+
level: 1 | 2 | 3 | 4 | 5 | 6;
|
|
17
|
+
spans: InlineSpan[];
|
|
18
|
+
plainText: string;
|
|
19
|
+
};
|
|
20
|
+
export type ParagraphToken = {
|
|
21
|
+
type: 'paragraph';
|
|
22
|
+
spans: InlineSpan[];
|
|
23
|
+
plainText: string;
|
|
24
|
+
};
|
|
25
|
+
export type CodeBlockToken = {
|
|
26
|
+
type: 'code_block';
|
|
27
|
+
lang: string;
|
|
28
|
+
code: string;
|
|
29
|
+
};
|
|
30
|
+
export type BlockquoteToken = {
|
|
31
|
+
type: 'blockquote';
|
|
32
|
+
spans: InlineSpan[];
|
|
33
|
+
plainText: string;
|
|
34
|
+
};
|
|
35
|
+
export type ListToken = {
|
|
36
|
+
type: 'list';
|
|
37
|
+
ordered: boolean;
|
|
38
|
+
start: number;
|
|
39
|
+
items: ListItemToken[];
|
|
40
|
+
};
|
|
41
|
+
export type ListItemToken = {
|
|
42
|
+
spans: InlineSpan[];
|
|
43
|
+
plainText: string;
|
|
44
|
+
checked?: boolean | undefined;
|
|
45
|
+
children?: ListToken[] | undefined;
|
|
46
|
+
};
|
|
47
|
+
export type TableToken = {
|
|
48
|
+
type: 'table';
|
|
49
|
+
headers: InlineSpan[][];
|
|
50
|
+
rows: InlineSpan[][][];
|
|
51
|
+
align: Array<'left' | 'center' | 'right' | null>;
|
|
52
|
+
};
|
|
53
|
+
export type ImageToken = {
|
|
54
|
+
type: 'image';
|
|
55
|
+
src: string;
|
|
56
|
+
alt: string;
|
|
57
|
+
title?: string | undefined;
|
|
58
|
+
};
|
|
59
|
+
export type HrToken = {
|
|
60
|
+
type: 'hr';
|
|
61
|
+
};
|
|
62
|
+
export type SpaceToken = {
|
|
63
|
+
type: 'space';
|
|
64
|
+
};
|
|
65
|
+
export type RenderToken = HeadingToken | ParagraphToken | CodeBlockToken | BlockquoteToken | ListToken | TableToken | ImageToken | HrToken | SpaceToken;
|
|
66
|
+
//# sourceMappingURL=tokens.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tokens.d.ts","sourceRoot":"","sources":["../src/tokens.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,SAAS,GAAG;IACtB,KAAK,CAAC,EAAE,MAAM,GAAG,SAAS,CAAA;IAC1B,UAAU,CAAC,EAAE,MAAM,GAAG,SAAS,CAAA;IAC/B,gBAAgB,CAAC,EAAE,MAAM,GAAG,SAAS,CAAA;IACrC,SAAS,CAAC,EAAE,OAAO,GAAG,SAAS,CAAA;IAC/B,aAAa,CAAC,EAAE,OAAO,GAAG,SAAS,CAAA;IACnC,IAAI,CAAC,EAAE,MAAM,GAAG,SAAS,CAAA;CAC1B,CAAA;AAED,MAAM,MAAM,UAAU,GAAG;IACvB,IAAI,EAAE,MAAM,CAAA;IACZ,IAAI,EAAE,MAAM,CAAA;IACZ,KAAK,CAAC,EAAE,SAAS,GAAG,SAAS,CAAA;CAC9B,CAAA;AAED,MAAM,MAAM,YAAY,GAAG;IACzB,IAAI,EAAE,SAAS,CAAA;IACf,KAAK,EAAE,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;IAC5B,KAAK,EAAE,UAAU,EAAE,CAAA;IACnB,SAAS,EAAE,MAAM,CAAA;CAClB,CAAA;AAED,MAAM,MAAM,cAAc,GAAG;IAC3B,IAAI,EAAE,WAAW,CAAA;IACjB,KAAK,EAAE,UAAU,EAAE,CAAA;IACnB,SAAS,EAAE,MAAM,CAAA;CAClB,CAAA;AAED,MAAM,MAAM,cAAc,GAAG;IAC3B,IAAI,EAAE,YAAY,CAAA;IAClB,IAAI,EAAE,MAAM,CAAA;IACZ,IAAI,EAAE,MAAM,CAAA;CACb,CAAA;AAED,MAAM,MAAM,eAAe,GAAG;IAC5B,IAAI,EAAE,YAAY,CAAA;IAClB,KAAK,EAAE,UAAU,EAAE,CAAA;IACnB,SAAS,EAAE,MAAM,CAAA;CAClB,CAAA;AAED,MAAM,MAAM,SAAS,GAAG;IACtB,IAAI,EAAE,MAAM,CAAA;IACZ,OAAO,EAAE,OAAO,CAAA;IAChB,KAAK,EAAE,MAAM,CAAA;IACb,KAAK,EAAE,aAAa,EAAE,CAAA;CACvB,CAAA;AAED,MAAM,MAAM,aAAa,GAAG;IAC1B,KAAK,EAAE,UAAU,EAAE,CAAA;IACnB,SAAS,EAAE,MAAM,CAAA;IACjB,OAAO,CAAC,EAAE,OAAO,GAAG,SAAS,CAAA;IAC7B,QAAQ,CAAC,EAAE,SAAS,EAAE,GAAG,SAAS,CAAA;CACnC,CAAA;AAED,MAAM,MAAM,UAAU,GAAG;IACvB,IAAI,EAAE,OAAO,CAAA;IACb,OAAO,EAAE,UAAU,EAAE,EAAE,CAAA;IACvB,IAAI,EAAE,UAAU,EAAE,EAAE,EAAE,CAAA;IACtB,KAAK,EAAE,KAAK,CAAC,MAAM,GAAG,QAAQ,GAAG,OAAO,GAAG,IAAI,CAAC,CAAA;CACjD,CAAA;AAED,MAAM,MAAM,UAAU,GAAG;IACvB,IAAI,EAAE,OAAO,CAAA;IACb,GAAG,EAAE,MAAM,CAAA;IACX,GAAG,EAAE,MAAM,CAAA;IACX,KAAK,CAAC,EAAE,MAAM,GAAG,SAAS,CAAA;CAC3B,CAAA;AAED,MAAM,MAAM,OAAO,GAAG;IACpB,IAAI,EAAE,IAAI,CAAA;CACX,CAAA;AAED,MAAM,MAAM,UAAU,GAAG;IACvB,IAAI,EAAE,OAAO,CAAA;CACd,CAAA;AAED,MAAM,MAAM,WAAW,GACnB,YAAY,GACZ,cAAc,GACd,cAAc,GACd,eAAe,GACf,SAAS,GACT,UAAU,GACV,UAAU,GACV,OAAO,GACP,UAAU,CAAA"}
|
package/dist/tokens.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tokens.js","sourceRoot":"","sources":["../src/tokens.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
export type WorkerMessage = {
|
|
2
|
+
type: 'render';
|
|
3
|
+
markdown: string;
|
|
4
|
+
width: number;
|
|
5
|
+
theme: 'dark' | 'light';
|
|
6
|
+
dpr: number;
|
|
7
|
+
} | {
|
|
8
|
+
type: 'measure';
|
|
9
|
+
markdown: string;
|
|
10
|
+
width: number;
|
|
11
|
+
theme: 'dark' | 'light';
|
|
12
|
+
};
|
|
13
|
+
export type WorkerResponse = {
|
|
14
|
+
type: 'rendered';
|
|
15
|
+
height: number;
|
|
16
|
+
totalHeight: number;
|
|
17
|
+
} | {
|
|
18
|
+
type: 'measured';
|
|
19
|
+
totalHeight: number;
|
|
20
|
+
blockCount: number;
|
|
21
|
+
} | {
|
|
22
|
+
type: 'error';
|
|
23
|
+
message: string;
|
|
24
|
+
};
|
|
25
|
+
export declare function handleWorkerMessage(msg: WorkerMessage, offscreen: OffscreenCanvas): WorkerResponse;
|
|
26
|
+
//# sourceMappingURL=worker-bridge.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"worker-bridge.d.ts","sourceRoot":"","sources":["../src/worker-bridge.ts"],"names":[],"mappings":"AAMA,MAAM,MAAM,aAAa,GACrB;IAAE,IAAI,EAAE,QAAQ,CAAC;IAAC,QAAQ,EAAE,MAAM,CAAC;IAAC,KAAK,EAAE,MAAM,CAAC;IAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC;IAAC,GAAG,EAAE,MAAM,CAAA;CAAE,GACzF;IAAE,IAAI,EAAE,SAAS,CAAC;IAAC,QAAQ,EAAE,MAAM,CAAC;IAAC,KAAK,EAAE,MAAM,CAAC;IAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAA;CAAE,CAAA;AAEjF,MAAM,MAAM,cAAc,GACtB;IAAE,IAAI,EAAE,UAAU,CAAC;IAAC,MAAM,EAAE,MAAM,CAAC;IAAC,WAAW,EAAE,MAAM,CAAA;CAAE,GACzD;IAAE,IAAI,EAAE,UAAU,CAAC;IAAC,WAAW,EAAE,MAAM,CAAC;IAAC,UAAU,EAAE,MAAM,CAAA;CAAE,GAC7D;IAAE,IAAI,EAAE,OAAO,CAAC;IAAC,OAAO,EAAE,MAAM,CAAA;CAAE,CAAA;AAEtC,wBAAgB,mBAAmB,CACjC,GAAG,EAAE,aAAa,EAClB,SAAS,EAAE,eAAe,GACzB,cAAc,CA8BhB"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { parseMarkdown } from './parser.js';
|
|
2
|
+
import { computeLayout } from './layout.js';
|
|
3
|
+
import { renderToCanvas } from './renderer.js';
|
|
4
|
+
import { darkTheme, lightTheme } from './theme.js';
|
|
5
|
+
export function handleWorkerMessage(msg, offscreen) {
|
|
6
|
+
try {
|
|
7
|
+
const theme = msg.theme === 'light' ? lightTheme : darkTheme;
|
|
8
|
+
if (msg.type === 'render') {
|
|
9
|
+
const tokens = parseMarkdown(msg.markdown, theme);
|
|
10
|
+
const docLayout = computeLayout(tokens, msg.width, theme);
|
|
11
|
+
offscreen.width = msg.width * msg.dpr;
|
|
12
|
+
offscreen.height = docLayout.totalHeight * msg.dpr;
|
|
13
|
+
const ctx = offscreen.getContext('2d');
|
|
14
|
+
if (!ctx)
|
|
15
|
+
return { type: 'error', message: 'No 2D context' };
|
|
16
|
+
ctx.scale(msg.dpr, msg.dpr);
|
|
17
|
+
renderToCanvas(ctx, docLayout, theme);
|
|
18
|
+
return { type: 'rendered', height: docLayout.totalHeight, totalHeight: docLayout.totalHeight };
|
|
19
|
+
}
|
|
20
|
+
if (msg.type === 'measure') {
|
|
21
|
+
const tokens = parseMarkdown(msg.markdown, theme);
|
|
22
|
+
const docLayout = computeLayout(tokens, msg.width, theme);
|
|
23
|
+
return { type: 'measured', totalHeight: docLayout.totalHeight, blockCount: docLayout.blocks.length };
|
|
24
|
+
}
|
|
25
|
+
return { type: 'error', message: 'Unknown message type' };
|
|
26
|
+
}
|
|
27
|
+
catch (e) {
|
|
28
|
+
return { type: 'error', message: e instanceof Error ? e.message : String(e) };
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
//# sourceMappingURL=worker-bridge.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"worker-bridge.js","sourceRoot":"","sources":["../src/worker-bridge.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,aAAa,CAAA;AAC3C,OAAO,EAAE,aAAa,EAAE,MAAM,aAAa,CAAA;AAC3C,OAAO,EAAE,cAAc,EAAE,MAAM,eAAe,CAAA;AAC9C,OAAO,EAAE,SAAS,EAAE,UAAU,EAAc,MAAM,YAAY,CAAA;AAY9D,MAAM,UAAU,mBAAmB,CACjC,GAAkB,EAClB,SAA0B;IAE1B,IAAI,CAAC;QACH,MAAM,KAAK,GAAU,GAAG,CAAC,KAAK,KAAK,OAAO,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS,CAAA;QAEnE,IAAI,GAAG,CAAC,IAAI,KAAK,QAAQ,EAAE,CAAC;YAC1B,MAAM,MAAM,GAAG,aAAa,CAAC,GAAG,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAA;YACjD,MAAM,SAAS,GAAG,aAAa,CAAC,MAAM,EAAE,GAAG,CAAC,KAAK,EAAE,KAAK,CAAC,CAAA;YAEzD,SAAS,CAAC,KAAK,GAAG,GAAG,CAAC,KAAK,GAAG,GAAG,CAAC,GAAG,CAAA;YACrC,SAAS,CAAC,MAAM,GAAG,SAAS,CAAC,WAAW,GAAG,GAAG,CAAC,GAAG,CAAA;YAElD,MAAM,GAAG,GAAG,SAAS,CAAC,UAAU,CAAC,IAAI,CAAwC,CAAA;YAC7E,IAAI,CAAC,GAAG;gBAAE,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,eAAe,EAAE,CAAA;YAE5D,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE,GAAG,CAAC,GAAG,CAAC,CAAA;YAC3B,cAAc,CAAC,GAAG,EAAE,SAAS,EAAE,KAAK,CAAC,CAAA;YAErC,OAAO,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,EAAE,SAAS,CAAC,WAAW,EAAE,WAAW,EAAE,SAAS,CAAC,WAAW,EAAE,CAAA;QAChG,CAAC;QAED,IAAI,GAAG,CAAC,IAAI,KAAK,SAAS,EAAE,CAAC;YAC3B,MAAM,MAAM,GAAG,aAAa,CAAC,GAAG,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAA;YACjD,MAAM,SAAS,GAAG,aAAa,CAAC,MAAM,EAAE,GAAG,CAAC,KAAK,EAAE,KAAK,CAAC,CAAA;YACzD,OAAO,EAAE,IAAI,EAAE,UAAU,EAAE,WAAW,EAAE,SAAS,CAAC,WAAW,EAAE,UAAU,EAAE,SAAS,CAAC,MAAM,CAAC,MAAM,EAAE,CAAA;QACtG,CAAC;QAED,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,sBAAsB,EAAE,CAAA;IAC3D,CAAC;IAAC,OAAO,CAAC,EAAE,CAAC;QACX,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,CAAC,YAAY,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAA;IAC/E,CAAC;AACH,CAAC"}
|
package/package.json
ADDED
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "canvasdown",
|
|
3
|
+
"version": "0.1.0",
|
|
4
|
+
"description": "Markdown renderer for Canvas. No DOM. No reflow. Runs anywhere.",
|
|
5
|
+
"type": "module",
|
|
6
|
+
"main": "./dist/index.js",
|
|
7
|
+
"types": "./dist/index.d.ts",
|
|
8
|
+
"exports": {
|
|
9
|
+
".": {
|
|
10
|
+
"import": "./dist/index.js",
|
|
11
|
+
"types": "./dist/index.d.ts"
|
|
12
|
+
},
|
|
13
|
+
"./stream": {
|
|
14
|
+
"import": "./dist/stream.js",
|
|
15
|
+
"types": "./dist/stream.d.ts"
|
|
16
|
+
},
|
|
17
|
+
"./advanced": {
|
|
18
|
+
"import": "./dist/advanced.js",
|
|
19
|
+
"types": "./dist/advanced.d.ts"
|
|
20
|
+
},
|
|
21
|
+
"./react": {
|
|
22
|
+
"import": "./dist/react.js",
|
|
23
|
+
"types": "./dist/react.d.ts"
|
|
24
|
+
},
|
|
25
|
+
"./worker": {
|
|
26
|
+
"import": "./dist/worker-bridge.js",
|
|
27
|
+
"types": "./dist/worker-bridge.d.ts"
|
|
28
|
+
}
|
|
29
|
+
},
|
|
30
|
+
"files": ["dist", "README.md", "LICENSE"],
|
|
31
|
+
"scripts": {
|
|
32
|
+
"build": "tsc -p tsconfig.build.json",
|
|
33
|
+
"dev": "node serve.cjs",
|
|
34
|
+
"typecheck": "tsc --noEmit",
|
|
35
|
+
"prepublishOnly": "npm run build"
|
|
36
|
+
},
|
|
37
|
+
"keywords": [
|
|
38
|
+
"markdown", "canvas", "renderer", "pretext", "text-layout",
|
|
39
|
+
"no-dom", "og-image", "streaming", "ai-chat", "webgl",
|
|
40
|
+
"node", "typescript", "animation", "virtual-list"
|
|
41
|
+
],
|
|
42
|
+
"author": "canvasdown contributors",
|
|
43
|
+
"license": "MIT",
|
|
44
|
+
"repository": {
|
|
45
|
+
"type": "git",
|
|
46
|
+
"url": "https://github.com/nhoxtvt/canvasdown.git"
|
|
47
|
+
},
|
|
48
|
+
"homepage": "https://github.com/nhoxtvt/canvasdown#readme",
|
|
49
|
+
"bugs": { "url": "https://github.com/nhoxtvt/canvasdown/issues" },
|
|
50
|
+
"dependencies": {
|
|
51
|
+
"@chenglou/pretext": "^0.0.4",
|
|
52
|
+
"marked": "^17.0.0"
|
|
53
|
+
},
|
|
54
|
+
"devDependencies": {
|
|
55
|
+
"typescript": "^5.8.0",
|
|
56
|
+
"@types/node": "^22.0.0"
|
|
57
|
+
},
|
|
58
|
+
"peerDependencies": {
|
|
59
|
+
"@napi-rs/canvas": ">=0.1.0"
|
|
60
|
+
},
|
|
61
|
+
"peerDependenciesMeta": {
|
|
62
|
+
"@napi-rs/canvas": { "optional": true }
|
|
63
|
+
},
|
|
64
|
+
"engines": { "node": ">=18.0.0" }
|
|
65
|
+
}
|