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.
Files changed (47) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +541 -0
  3. package/dist/advanced.d.ts +65 -0
  4. package/dist/advanced.d.ts.map +1 -0
  5. package/dist/advanced.js +442 -0
  6. package/dist/advanced.js.map +1 -0
  7. package/dist/canvas-provider.d.ts +11 -0
  8. package/dist/canvas-provider.d.ts.map +1 -0
  9. package/dist/canvas-provider.js +15 -0
  10. package/dist/canvas-provider.js.map +1 -0
  11. package/dist/index.d.ts +28 -0
  12. package/dist/index.d.ts.map +1 -0
  13. package/dist/index.js +84 -0
  14. package/dist/index.js.map +1 -0
  15. package/dist/layout.d.ts +95 -0
  16. package/dist/layout.d.ts.map +1 -0
  17. package/dist/layout.js +179 -0
  18. package/dist/layout.js.map +1 -0
  19. package/dist/parser.d.ts +4 -0
  20. package/dist/parser.d.ts.map +1 -0
  21. package/dist/parser.js +252 -0
  22. package/dist/parser.js.map +1 -0
  23. package/dist/react.d.ts +33 -0
  24. package/dist/react.d.ts.map +1 -0
  25. package/dist/react.js +43 -0
  26. package/dist/react.js.map +1 -0
  27. package/dist/renderer.d.ts +4 -0
  28. package/dist/renderer.d.ts.map +1 -0
  29. package/dist/renderer.js +238 -0
  30. package/dist/renderer.js.map +1 -0
  31. package/dist/stream.d.ts +10 -0
  32. package/dist/stream.d.ts.map +1 -0
  33. package/dist/stream.js +72 -0
  34. package/dist/stream.js.map +1 -0
  35. package/dist/theme.d.ts +75 -0
  36. package/dist/theme.d.ts.map +1 -0
  37. package/dist/theme.js +123 -0
  38. package/dist/theme.js.map +1 -0
  39. package/dist/tokens.d.ts +66 -0
  40. package/dist/tokens.d.ts.map +1 -0
  41. package/dist/tokens.js +2 -0
  42. package/dist/tokens.js.map +1 -0
  43. package/dist/worker-bridge.d.ts +26 -0
  44. package/dist/worker-bridge.d.ts.map +1 -0
  45. package/dist/worker-bridge.js +31 -0
  46. package/dist/worker-bridge.js.map +1 -0
  47. package/package.json +65 -0
@@ -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,2 @@
1
+ export {};
2
+ //# sourceMappingURL=tokens.js.map
@@ -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
+ }