GitXplorerGitXplorer
O

astro-typst

public
32 stars
0 forks
2 issues

Commits

List of commits on branch master.
Unverified
fc60e40ebe1e001da01fa6afdf2f03b0a90770b1

test

OOverflowCat committed 6 months ago
Unverified
3be34a8afe3fa5d0a12cc66b757df5a91a990fe4

feat(component)!: set props of `<svg>` tag

OOverflowCat committed 6 months ago
Unverified
d680ff3daadc5b0b772a5137644cb7775ce7abb0

docs: update Features

OOverflowCat committed 6 months ago
Unverified
28972495a140611a2879ba4d83145e90509490b6

feat: support multiple files

OOverflowCat committed 6 months ago
Unverified
c8a2251b4db1c8801267e1c3c7eb28b36f4f5a58

refactor: use `TypstComponent` type for better `check`

OOverflowCat committed 6 months ago
Unverified
9d9f5a85c6c03d448d0f2b230beac08c5ecff3c2

feat: add declaration map

OOverflowCat committed 6 months ago

README

The README file for this repository.

astro-typst

An Astro Integration that lets you render Typst within Astro.

Demo

Features

  • [x] Import packages in Typst Universe
  • [x] import / include / read files or resources
  • [x] Use system fonts
  • [x] Selectable, clickable text layer
  • [x] Set scale
  • [x] Static SVGs without JavaScript
  • [ ] Responsive SVGs
  • [ ] Add font files or blobs
  • [x] Content collections

Installation

npm install astro-typst
# or
pnpm add astro-typst
# or
yarn add astro-typst

Usage

As an integration

// astro.config.mjs
import { typst } from 'astro-typst';

... // other imports

export default defineConfig({
    integrations: [/** other integrations */ ..., typst()],
});

Then you can use .typ files just like anything else in Astro: render directly by router, or import in another file.

As a component

To use the component, you need to manually install a dependency to avoid SSR errors:

npm install @myriaddreamin/typst-ts-node-compiler
# or
pnpm add @myriaddreamin/typst-ts-node-compiler
# or
yarn add @myriaddreamin/typst-ts-node-compiler

and add this to your /astro.config.(t|j)s/:

export default defineConfig({
  ...,
  vite: {
    ssr: {
-      external: [...],
+      external: [..., "@myriaddreamin/typst-ts-node-compiler"],
    },
    ...,
  },
  ...,
});

Then, you can pass either one of code | src | input to the component:

---
import { Typst } from "astro-typst/src/components";
const code = `
#set page(margin: 1em)
#let typst  = {
  text(font: "Linux Libertine", weight: "semibold", fill: eastern)[typst]
}
#show "Typst": typst

== Typst: Compose paper faster

$ cases(
dot(x) = A x + B u = mat(delim: "[", 0, 0, dots.h.c, 0, - a_n; 1, 0, dots.h.c, 0, - a_(n - 1); 0, 1, dots.h.c, 0, - a_(n - 2); dots.v, dots.v, dots.down, dots.v, dots.v; 0, 0, dots.h.c, 1, - a_1) x + mat(delim: "[", b_n; b_(n - 1); b_(n - 2); dots.v; b_1) u,

y = C x = mat(delim: "[", 0, 0, dots.h.c, 1) x
) $

#set text(font: ("Garamond", "Noto Serif CJK SC"))

#import "@preview/tablem:0.1.0": tablem

#tablem[
  | *English* | *German* | *Chinese* | *Japanese* |
  | --------- | -------- | --------- | ---------- |
  | Cat       | Katze    | 猫        | 猫         |
  | Fish      | Fisch    | 鱼        | 魚         |
]
`;
---

<Typst code={code} />

In content collections

See demo.

Frontmatter

metadata exposes a value to the query system without producing visible content.

Attach a label frontmatter to the metadata declaration:

#let desc = [$oo$ fun with `math`]
#metadata(
  (
    title: "Test page",
    author: "Neko",
    desc: desc,
    date:  datetime(
      year: 2024,
      month: 8,
      day: 7,
    ),
  )
)<frontmatter>

yields

{
  "title": "Test page",
  "author": "Neko",
  "desc": {
    "children": [
      {
        "block": false,
        "body": {
          "func": "text",
          "text": ""
        },
        "func": "equation"
      },
      { "func": "space" },
      { "func": "text", "text": "fun with" },
      { "func": "space" },
      {
        "block": false,
        "func": "raw",
        "text": "math"
      }
    ],
    "func": "sequence"
  },
  "date": "datetime(year: 2024, month: 8, day: 7)"
}

Development

Playground

pnpm tsc -w
# in another terminal
pnpm dev

Build package

pnpm compile