-
Notifications
You must be signed in to change notification settings - Fork 29
/
Copy pathintroduction.typ
82 lines (57 loc) · 3.3 KB
/
introduction.typ
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
#import "/docs/cookery/book.typ": book-page
#import "/github-pages/docs/graphs.typ": data-flow-graph, ir-feature-graph
#show: book-page.with(title: "Introduction")
#let natural-image(img) = style(styles => {
let (width, height) = measure(img, styles)
layout(page => {
let width_scale = 0.8 * page.width / width
block(width: width_scale * width, height: width_scale * height)[
#scale(x: width_scale * 100%, y: width_scale * 100%, origin: center + top)[#img]
]
})
})
= Introduction
Typst.ts is a project dedicated to bring the power of #link("https://github.com/typst/typst")[typst] to the world of JavaScript. In short, it composes ways to compile and render your Typst document typically inside *Browser Environment*. In the scope of server-side rendering collaborated by #text(fill: rgb("#3c9123"), "server") and #text(fill: blue, "browser"), there would be a data flow like this:
#figure(
{
set text(size: 12pt)
natural-image(data-flow-graph())
},
caption: [Browser-side module needed: $dagger$: compiler; $dagger.double$: renderer. ],
numbering: none,
)
Specifically, it first presents a typst document in three typical forms:
- #link("https://myriad-dreamin.github.io/typst.ts/cookery/guide/compiler/ts-cli.html")[Form1]: Render to SVG and then embed it as a high-quality vectored image directly.
- #link("https://myriad-dreamin.github.io/typst.ts/cookery/guide/compiler/ts-cli.html")[Form2]: Preprocessed to a Vector Format artifact.
- #link("https://myriad-dreamin.github.io/typst.ts/cookery/guide/compiler/serverless.html")[Form3]: Manipulate a canvas element directly.
The #emph("Form2: Vector Format") is developed specially for typst documents, and it has several fancy features:
#figure(
scale(
120%,
{
set text(size: 12pt)
v(0.5em)
natural-image(ir-feature-graph())
v(0.5em)
},
),
caption: [Figure: Features of the #emph("Vector Format"). ],
numbering: none,
)
// - Incremental Font Transfer
So with *Form2*, you can continue rendering the document in different ways:
#include "direction/main-content.typ"
// Typst.ts allows you to independently run the Typst compiler and exporter (renderer) in your browser.
// You can:
// - locally run the compilation via `typst-ts-cli` to get a precompiled document,
// - or use `reflexo-typst` to build your backend programmatically.
// - build your frontend using the lightweight TypeScript library `typst.ts`.
// - send the precompiled document to your readers' browsers and render it as HTML elements.
== Application
- #link("https://myriad-dreamin.github.io/typst.ts/")[A Website built with Typst.ts]
- #link("https://github.com/Enter-tainer/typst-preview-vscode")[Instant VSCode Preview Plugin]
- #link("https://www.npmjs.com/package/hexo-renderer-typst")[Renderer Plugin for Hexo, a Blog-aware Static Site Generator]
- Renderer/Component Library for #link("https://www.npmjs.com/package/@myriaddreamin/typst.ts")[JavaScript], #link("https://www.npmjs.com/package/@myriaddreamin/typst.react")[React], and #link("https://www.npmjs.com/package/@myriaddreamin/typst.angular")[Angular]
== Further reading
+ #link("https://myriad-dreamin.github.io/typst.ts/cookery/get-started.html")[Get started with Typst.ts]
+ #link("https://myriad-dreamin.github.io/typst.ts/cookery/guide/trouble-shooting.html")[Trouble shooting]