Front Matter

Settings used in generating HTML pages are defined in an object called front matter. Users can edit the front matter by modifying the litsconfig.json file or by adding it in front of a source file. Below is an example showing how to include a front matter in a markdown file.

---
{ "useMath": true }
---

The properties that you can tweak can be found in the interface below.

export interface FrontMatter {

Import JS/TS Modules

To add dynamic content you can include Javascript or TypeScript modules in your page. The modules setting contains names of your root modules that will be bundled and imported to the generated HTML page. File paths are relative to the project base directory.

    modules: string[]

Import CSS Files

You can also import CSS files to your page(s). The list of CSS files included is defined in the styles property. Both modules and styles are bundled under the dist directory under the outDir.

    styles: string[]

Page Template

Name of the template used for rendering the HTML page. This maps to a module in the <baseDir>/site/pages folder.

    pageTemplate: string

Project Name

The project name is displayed everywhere where a title is needed; in the navigation bar, in the page title (browser tab), and so on.

    projectName: string

Project URLs

Following settings contain links used in the navigation bar. They can be absolute URLs to external web sites, or relative paths to pages in the project. If you use relative paths, remember to add the / character at the front. The forward slash character points to the root of the generated web site.

The repository field contains the URL of the git repo that hosts the project sources.

    repository: string

The download field contains the URL of the download site, typically NPM home page.

    download: string

The URL of the license info page.

    license: string

Link to the logo image or inline SVG used in the navigation bar. This should be an icon, a small bitmap, or a SVG file.

    logo: string

Themes

The available themes and customizations to the appearance. The default theme can be changed with the theme setting. See theming guide for more information.

    themes: { [name: string]: string }
    theme: string,

Syntax Highlighting

There are multiple syntax highlight schemes to choose from. These should be familiar from popular text editors.

    syntaxHighlightThemes: { [name: string]: string }
    syntaxHighlight: string

Math Notation

LiTScript uses KaTeX to layout mathematical formulas. By turning the useMath field on, KaTeX is loaded from an external CDN. If you need a different version of CDN package, change the link in katexCdn.

You can include formulas in markdown with LaTeX notation by surrounding them by single $ (inline) or double $$ (block) dollar signs. For example the block

$$x = { -b \pm \sqrt{b^2 - 4ac} \over 2a }$$

renders like this:

x=βˆ’bΒ±b2βˆ’4ac2ax = { -b \pm \sqrt{b^2 - 4ac} \over 2a }

    useMath: boolean
    katexCdn: string

Customizing Menu Headers

You can change the text in the menu headers, if you don't like the defaults, or if you want to localize them.

    tocMenuHeader: string
    pageMenuHeader: string

The best place for copyright and other general information is the footer. You can show it in page menu, content area, or TOC menu.

    footer: string
}

Defaults

Default values are defined here. These are used, if a property is not present in the configuration file.

export const defaults: FrontMatter = {
    modules: [],
    styles: [],
    pageTemplate: "normal",
    projectName: "Project",
    repository: "",
    download: "",
    license: "",
    logo: "",
    themes: {
        "blueberry": "Blueberry",
        "book-cover": "Book Cover",
        "brownie": "Brownie",
        "chocolate": "Chocolate",
        "ice-age": "Ice Age",
        "monotone": "Monotone",
        "mustard": "Mustard",
        "peachy": "Peachy",
        "red-alert": "Red Alert",
        "ultra-violet": "Ultra Violet",
        "vintage": "Vintage",
    },
    theme: "purple-rain",
    syntaxHighlightThemes: {
        "coding-horror": "Coding Horror",
        "monokai": "Monokai",
        "solarized-light": "Solarized Light", 
        "son-of-obsidian": "Son of Obsidian"
    },
    syntaxHighlight: "monokai",
    useMath: false,
    katexCdn: "https://cdn.jsdelivr.net/npm/katex@0.16.9/dist/katex.min.css",
    tocMenuHeader: "Table of Contents",
    pageMenuHeader: "On This Page",
    footer: "Copyright Β© 2023"
}