diff --git a/.gitignore b/.gitignore
index 3ff2c369..bb54c5fb 100644
--- a/.gitignore
+++ b/.gitignore
@@ -1,5 +1,6 @@
.uuid
.vscode
+package-lock.json
*.stats.html
/bin/
/dist/
@@ -9,3 +10,6 @@
/test/test-results.xml
/test/screenshots/test-results.xml
/.nyc_output/
+/.vitepress
+/docs/.vitepress/cache/
+/docs/public/latexjs/
diff --git a/docs/.vitepress/config.mts b/docs/.vitepress/config.mts
new file mode 100644
index 00000000..9c05a8ed
--- /dev/null
+++ b/docs/.vitepress/config.mts
@@ -0,0 +1,65 @@
+import { defineConfig } from 'vitepress'
+import { fileURLToPath } from 'url'
+import path from 'path'
+import string from 'vite-plugin-string'
+
+const __dirname = path.dirname(fileURLToPath(import.meta.url))
+
+// https://vitepress.dev/reference/site-config
+export default defineConfig({
+ title: 'LaTeX.js',
+ description: 'A LaTeX parser written in JavaScript.',
+
+ outDir: '../website',
+
+ head: [
+ ['link', {
+ rel: 'icon',
+ href: ''
+ }],
+ ['link', { rel: 'stylesheet', href: '/css/error.css' }],
+ ['link', { rel: 'stylesheet', href: '/css/logos.css' }]
+ ],
+
+ themeConfig: {
+ // https://vitepress.dev/reference/default-theme-config
+ logo: '/img/latexjs.png',
+
+ nav: [
+ { text: 'Home', link: '/' },
+ { text: 'Guide', link: '/usage' },
+ { text: 'Playground', link: '/playground' },
+ { text: 'ChangeLog', link: 'https://github.com/michael-brade/LaTeX.js/releases' },
+ { text: 'GitHub', link: 'https://github.com/michael-brade/LaTeX.js' },
+ ],
+
+ sidebar: [
+ { text: 'Home', link: '/' },
+ { text: 'Usage', link: '/usage' },
+ { text: 'API', link: '/api' },
+ { text: 'Extending', link: '/extending' },
+ { text: 'Limitations', link: '/limitations' }
+ ],
+ },
+
+ // Enable markdown line breaks
+ markdown: {
+ breaks: true
+ },
+
+ // Vite-specific configuration
+ vite: {
+ plugins: [
+ // Plugin to import .tex files as strings
+ string({
+ include: '**/*.tex',
+ })
+ ],
+ resolve: {
+ alias: {
+ // Alias to find theme components
+ '@theme/components': path.resolve(__dirname, './theme/components')
+ }
+ }
+ }
+})
\ No newline at end of file
diff --git a/docs/.vitepress/theme/Layout.vue b/docs/.vitepress/theme/Layout.vue
new file mode 100644
index 00000000..44b6d257
--- /dev/null
+++ b/docs/.vitepress/theme/Layout.vue
@@ -0,0 +1,37 @@
+
+
+
+
+
+ .js
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/docs/.vitepress/theme/components/LaTeX.vue b/docs/.vitepress/theme/components/LaTeX.vue
new file mode 100644
index 00000000..d3e87459
--- /dev/null
+++ b/docs/.vitepress/theme/components/LaTeX.vue
@@ -0,0 +1,24 @@
+
+ LaTeX
+
+
+
diff --git a/docs/.vitepress/theme/components/LtxPlayground.vue b/docs/.vitepress/theme/components/LtxPlayground.vue
new file mode 100644
index 00000000..18e83773
--- /dev/null
+++ b/docs/.vitepress/theme/components/LtxPlayground.vue
@@ -0,0 +1,281 @@
+
+
+
+
+
+
+
diff --git a/docs/.vitepress/theme/components/TeX.vue b/docs/.vitepress/theme/components/TeX.vue
new file mode 100644
index 00000000..bf92ca82
--- /dev/null
+++ b/docs/.vitepress/theme/components/TeX.vue
@@ -0,0 +1,17 @@
+
+ TeX
+
+
+
diff --git a/docs/.vitepress/theme/components/latex.vue b/docs/.vitepress/theme/components/latex.vue
new file mode 100644
index 00000000..d3e87459
--- /dev/null
+++ b/docs/.vitepress/theme/components/latex.vue
@@ -0,0 +1,24 @@
+
+ LaTeX
+
+
+
diff --git a/docs/.vitepress/theme/index.js b/docs/.vitepress/theme/index.js
new file mode 100644
index 00000000..03452b80
--- /dev/null
+++ b/docs/.vitepress/theme/index.js
@@ -0,0 +1,13 @@
+import DefaultTheme from 'vitepress/theme'
+import LaTeX from './components/LaTeX.vue'
+import TeX from './components/TeX.vue'
+import LtxPlayground from './components/LtxPlayground.vue'
+
+export default {
+ ...DefaultTheme,
+ enhanceApp({ app }) {
+ app.component('LaTeX', LaTeX)
+ app.component('TeX', TeX)
+ app.component('LtxPlayground', LtxPlayground)
+ }
+}
diff --git a/docs/.vitepress/theme/style.css b/docs/.vitepress/theme/style.css
new file mode 100644
index 00000000..755bcdc1
--- /dev/null
+++ b/docs/.vitepress/theme/style.css
@@ -0,0 +1,28 @@
+/* Replaces .page */
+.VPDoc.vp-doc {
+ padding-top: 3.6rem;
+ text-align: justify;
+}
+
+/* Replaces .theme-container .navbar */
+.VPNavbar {
+ line-height: 2rem !important;
+}
+
+/* Replaces .navbar a, .links, etc. */
+.VPNavbar,
+.VPNavbar .links,
+.VPNavbar a {
+ background-color: #3eaf7c !important; /* #2e8555 */
+ color: white !important;
+ border: none !important;
+}
+
+/* Ensure navbar text/icons are white */
+.VPNavbar .VPNavBarTitle .text,
+.VPNavbar .VPNavBarMenu .VPNavBarMenuLink,
+.VPNavbar .VPNavBarAppearance,
+.VPNavbar .VPSocialLink {
+ color: white !important;
+ fill: white !important;
+}
diff --git a/docs/.vuepress/.gitignore b/docs/.vuepress/.gitignore
deleted file mode 100644
index f5ef3338..00000000
--- a/docs/.vuepress/.gitignore
+++ /dev/null
@@ -1,3 +0,0 @@
-/public/js
-.cache
-.temp
\ No newline at end of file
diff --git a/docs/.vuepress/assets.ts b/docs/.vuepress/assets.ts
deleted file mode 100644
index 3785865e..00000000
--- a/docs/.vuepress/assets.ts
+++ /dev/null
@@ -1,31 +0,0 @@
-import path from 'path'
-
-
-export default (options, ctx) => {
- const styleAssetsPath = 'dist/css'
- const fontAssetsPath = 'dist/fonts'
- const jsAssetsPath = 'dist/js'
-
- return {
- // For development
- beforeDevServer(app, server) {
- const express = require('express')
- // const serveStatic = require('serve-static')
- const serveStatic = express.static
-
- // path.resolve uses cwd if argument is relative
- app.use('/css', serveStatic(path.resolve(styleAssetsPath)))
- app.use('/fonts', serveStatic(path.resolve(fontAssetsPath)))
- app.use('/js', serveStatic(path.resolve(jsAssetsPath)))
- },
-
- // For production
- async generated() {
- const { fs } = require('@vuepress/shared-utils')
-
- await fs.copy(path.resolve(styleAssetsPath), path.resolve(ctx.outDir, 'css'))
- await fs.copy(path.resolve(fontAssetsPath), path.resolve(ctx.outDir, 'fonts'))
- await fs.copy(path.resolve(jsAssetsPath), path.resolve(ctx.outDir, 'js'))
- }
- }
-}
\ No newline at end of file
diff --git a/docs/.vuepress/components/LaTeX.vue b/docs/.vuepress/components/LaTeX.vue
deleted file mode 100644
index 4c58f1ac..00000000
--- a/docs/.vuepress/components/LaTeX.vue
+++ /dev/null
@@ -1,26 +0,0 @@
-
-
-
-
- LaTeX
-
diff --git a/docs/.vuepress/components/LtxPlayground.vue b/docs/.vuepress/components/LtxPlayground.vue
deleted file mode 100644
index fbde5f5a..00000000
--- a/docs/.vuepress/components/LtxPlayground.vue
+++ /dev/null
@@ -1,290 +0,0 @@
-
-
-
-
-
-
-
-
-
-
diff --git a/docs/.vuepress/components/TeX.vue b/docs/.vuepress/components/TeX.vue
deleted file mode 100644
index ddbad5d1..00000000
--- a/docs/.vuepress/components/TeX.vue
+++ /dev/null
@@ -1,20 +0,0 @@
-
-
-
-
- TeX
-
diff --git a/docs/.vuepress/components/latex.vue b/docs/.vuepress/components/latex.vue
deleted file mode 100644
index 4c58f1ac..00000000
--- a/docs/.vuepress/components/latex.vue
+++ /dev/null
@@ -1,26 +0,0 @@
-
-
-
-
- LaTeX
-
diff --git a/docs/.vuepress/config.ts b/docs/.vuepress/config.ts
deleted file mode 100644
index f5a5c641..00000000
--- a/docs/.vuepress/config.ts
+++ /dev/null
@@ -1,114 +0,0 @@
-import { defaultTheme } from '@vuepress/theme-default'
-import { registerComponentsPlugin } from '@vuepress/plugin-register-components'
-import { getDirname, path } from '@vuepress/utils'
-
-// import { defineConfig } from '@vuepress/config'
-import { defineUserConfig } from '@vuepress/cli'
-
-// import { webpackBundler } from '@vuepress/bundler-webpack'
-import { viteBundler } from '@vuepress/bundler-vite'
-
-import { description } from '../../package.json'
-import assets from './assets'
-
-import { string } from 'rollup-plugin-string'
-
-
-
-const __dirname = getDirname(import.meta.url)
-
-
-// export default {
-// export default defineConfig({
-export default defineUserConfig({
-
- title: 'LaTeX.js',
- description: description,
-
- dest: 'website',
-
- head: [
- ['link', {
- rel: 'icon',
- href: '',
- type: 'image/x-icon'
- }]
- ],
-
- theme: defaultTheme({
- logo: '/img/latexjs.png',
-
- navbar: [
- { text: 'Home', link: '/' },
- { text: 'Guide', link: '/usage.html' },
- { text: 'Playground', link: '/playground.html', target:'_self', rel: '' },
- { text: 'ChangeLog', link: 'https://github.com/michael-brade/LaTeX.js/releases'},
- { text: 'GitHub', link: 'https://github.com/michael-brade/LaTeX.js' },
- ],
- sidebar: [
- '', // Home
- 'usage',
- 'api',
- 'extending',
- 'limitations'
- ],
- sidebarDepth: 1,
-
- // search: false,
- // displayAllHeaders: true,
- // activeHeaderLinks: true
- }),
-
- markdown: {
- // extendMarkdown: md => {
- // md.set({ breaks: true })
- // //md.use(require('markdown-it-xxx'))
- // }
-
- breaks: true
- },
-
- plugins: [
- require('./assets'),
-
- registerComponentsPlugin({
- componentsDir: path.resolve(__dirname, './components')
- }),
- ],
-
- bundler: viteBundler({
- viteOptions: {
- appType: 'spa',
- // mode: 'development' / 'production',
- // plugins: ,
- build: {
- rollupOptions: {
- plugins: [
- string({
- // Required to be specified
- include: "./docs/showcase.tex",
-
- // Undefined by default
- // exclude: ["**/index.html"]
- })
- ]
- }
- }
- },
- vuePluginOptions: {
- customElement: true
- },
- })
-
- // bundler: webpackBundler({
- // sass: { /* ... */ },
-
- // configureWebpack: (config, isServer) => {
- // config.externals = {
- // 'svgdom': 'commonjs svgdom'
- // }
-
- // config.output.hashFunction = 'xxhash64'
- // },
- // })
-})
diff --git a/docs/.vuepress/styles/index.styl b/docs/.vuepress/styles/index.styl
deleted file mode 100644
index cf03cffa..00000000
--- a/docs/.vuepress/styles/index.styl
+++ /dev/null
@@ -1,47 +0,0 @@
-.page {
- padding-top: 3.6rem;
- text-align: justify;
-}
-
-.theme-container {
- .navbar {
- line-height: 2rem;
-
- &, & .links, & a {
- background-color: #3eaf7c !important; // #2e8555
- color: white;
- border: none;
- }
-
- & .home-link {
- .logo {
- height: 2rem
- padding-bottom: 0.2rem
- vertical-align: middle
- margin-right: 0
- }
- font-family: 'Liberation Serif', serif
- font-size: 1.5rem;
- }
- }
-}
-
-.fullWidth {
- .page {
- padding-top: 3.6rem;
- padding-left: 0;
- padding-bottom: 0;
- height: calc(100vh - 3.6rem);
- }
-
- .theme-default-content {
- padding: 0;
- margin: 0;
- max-width: none;
- height: 100%;
- }
-
- footer {
- display: none;
- }
-}
\ No newline at end of file
diff --git a/docs/.vuepress/theme/components/Home.vue b/docs/.vuepress/theme/components/Home.vue
deleted file mode 100644
index 7b7a15ac..00000000
--- a/docs/.vuepress/theme/components/Home.vue
+++ /dev/null
@@ -1,133 +0,0 @@
-
-
-
-
-
-
-
-
-
-
-
diff --git a/docs/.vuepress/theme/components/Navbar.vue b/docs/.vuepress/theme/components/Navbar.vue
deleted file mode 100644
index 3e3b647f..00000000
--- a/docs/.vuepress/theme/components/Navbar.vue
+++ /dev/null
@@ -1,122 +0,0 @@
-
-
-
-
-
-
- .js
-
-
-
-
-
-
-
-
-
diff --git a/docs/.vuepress/theme/index.js b/docs/.vuepress/theme/index.js
deleted file mode 100644
index 3e8bafc4..00000000
--- a/docs/.vuepress/theme/index.js
+++ /dev/null
@@ -1,3 +0,0 @@
-module.exports = {
- extend: "@vuepress/theme-default",
-};
\ No newline at end of file
diff --git a/docs/index.md b/docs/index.md
new file mode 100644
index 00000000..26c10142
--- /dev/null
+++ b/docs/index.md
@@ -0,0 +1,27 @@
+---
+# https://vitepress.dev/reference/default-theme-home-page
+layout: home
+
+hero:
+ name: "LaTeX.js"
+ text: "A LaTeX parser in JavaScript."
+ tagline: Renders LaTeX into HTML for web viewing.
+ image:
+ src: /img/latexjs.png
+ alt: LaTeX.js Logo
+ actions:
+ - theme: brand
+ text: Get Started
+ link: /usage
+ - theme: alt
+ text: View on GitHub
+ link: https://github.com/michael-brade/LaTeX.js
+
+features:
+ - title: Browser & Server
+ details: Runs in the browser or on the server with Node.js.
+ - title: Extendable
+ details: Provides a simple API for extending the parser with custom macros.
+ - title: Self-Contained
+ details: Requires no external services to render LaTeX.
+---
\ No newline at end of file
diff --git a/docs/playground.md b/docs/playground.md
index 004541e1..02524a4e 100644
--- a/docs/playground.md
+++ b/docs/playground.md
@@ -1,14 +1,19 @@
---
-pageClass: fullWidth
-title: LaTeX.js Live Playground
-sidebar: false
-meta:
- - name: description
- content: This is the LaTeX.js editor with live preview.
- - name: keywords
- content: LaTeX,LaTeX.js,JavaScript,HTML,editor,live,preview
+layout: false # no default theme: full-page playground
---
-
+
-
+
+
+
+
+
diff --git a/docs/.vuepress/public/CNAME b/docs/public/CNAME
similarity index 100%
rename from docs/.vuepress/public/CNAME
rename to docs/public/CNAME
diff --git a/docs/.vuepress/public/css/error.css b/docs/public/css/error.css
similarity index 100%
rename from docs/.vuepress/public/css/error.css
rename to docs/public/css/error.css
diff --git a/docs/public/css/fade-in.css.map b/docs/public/css/fade-in.css.map
new file mode 100644
index 00000000..33baf051
--- /dev/null
+++ b/docs/public/css/fade-in.css.map
@@ -0,0 +1,6 @@
+{
+ "version": 3,
+ "sources": [],
+ "names": [],
+ "mappings": ""
+}
diff --git a/docs/.vuepress/public/css/latexjs.css b/docs/public/css/latexjs.css
similarity index 100%
rename from docs/.vuepress/public/css/latexjs.css
rename to docs/public/css/latexjs.css
diff --git a/docs/.vuepress/public/css/logos.css b/docs/public/css/logos.css
similarity index 100%
rename from docs/.vuepress/public/css/logos.css
rename to docs/public/css/logos.css
diff --git a/docs/.vuepress/public/img/favicon.ico b/docs/public/img/favicon.ico
similarity index 100%
rename from docs/.vuepress/public/img/favicon.ico
rename to docs/public/img/favicon.ico
diff --git a/docs/.vuepress/public/img/latexjs.png b/docs/public/img/latexjs.png
similarity index 100%
rename from docs/.vuepress/public/img/latexjs.png
rename to docs/public/img/latexjs.png
diff --git a/docs/usage.md b/docs/usage.md
index febf534d..71eaa9f1 100644
--- a/docs/usage.md
+++ b/docs/usage.md
@@ -123,11 +123,11 @@ plain text instead of HTML. Currently, only a HTML generator exists.
Import the parser and generator, then parse and translate to HTML:
-<<< @/test/api/node.mjs#code
+<<< ../test/api/node.mjs#code
Or using the CommonJS module syntax:
-<<< @/test/api/node.js#code
+<<< ../test/api/node.js#code
The `HtmlGenerator` takes several options, see the API section below.
@@ -137,7 +137,7 @@ The `HtmlGenerator` takes several options, see the API section below.
If you want to use the parser and the generator manually, you can either use your own build or use a link directly to
the jsDelivr CDN:
-<<< @/test/api/browser.html
+<<< ../test/api/browser.html
Note that in this case the styles and scripts are not encapsulated, so they can clash with the text and style of the
containing page.
diff --git a/package.json b/package.json
index 343bfe26..ec9d6541 100644
--- a/package.json
+++ b/package.json
@@ -1,126 +1,132 @@
{
- "name": "latex.js",
- "description": "JavaScript LaTeX to HTML5 translator",
- "version": "0.12.6",
- "author": {
- "name": "Michael Brade",
- "email": "brade@kde.org"
- },
- "keywords": [
- "pegjs",
- "latex",
- "parser",
- "html5"
- ],
- "bin": {
- "latex.js": "./bin/latex.js"
- },
- "module": "./dist/latex.mjs",
- "main": "./dist/latex.js",
- "exports": {
- "import": "./dist/latex.mjs",
- "require": "./dist/latex.js"
- },
- "browser": "./dist/latex.js",
- "files": [
- "bin/latex.js",
- "dist/latex.js",
- "dist/latex.js.map",
- "dist/latex.mjs",
- "dist/latex.mjs.map",
- "dist/css/",
- "dist/fonts/",
- "dist/js/",
- "dist/packages/",
- "dist/documentclasses/"
- ],
- "scripts": {
- "clean": "rimraf dist bin test/coverage test/test-results.xml docs/.vuepress/public/js;",
- "devbuild": "rimraf 'dist/**/*.map';mkdirp dist/css;mkdirp dist/js;mkdirp dist/fonts;mkdirp dist/documentclasses;mkdirp dist/packages;touch dist/documentclasses/.keep;touch dist/packages/.keep;rsync -a src/css/ dist/css/;rsync -a src/fonts/ dist/fonts/;rsync -a node_modules/katex/dist/fonts/*.woff2 dist/fonts/;rsync -a src/js/ dist/js/;mkdirp bin;lsc -bc --no-header -m embedded -p src/cli.ls > bin/latex.js;chmod a+x bin/latex.js;rollup -c;",
- "build": "NODE_ENV=production npm run devbuild;",
- "devdocs": "npm run devbuild;vuepress dev docs --no-clear-screen --debug;",
- "docs": "npm run build;[ ! -d website ] && git worktree add website gh-pages;mv website/.git .website.git;vuepress build docs;mv .website.git website/.git;cd website;git add .;git commit -m 'regenerated website';",
- "test": "mocha test/*.ls;",
- "iron": "iron-node node_modules/.bin/_mocha test/*.ls;",
- "testc": "nyc --include=bin --include=src --include=dist -e ls --reporter=html --reporter=text --reporter=lcovonly --report-dir=test/coverage npx mocha -i -g screenshot --reporter mocha-junit-reporter --reporter-options mochaFile=./test/test-results.xml test/*.ls&&npx mocha -g screenshot --reporter mocha-junit-reporter --reporter-options mochaFile=./test/screenshots/test-results.xml test/*.ls;",
- "codecov": "codecov;"
- },
- "dependencies": {
- "commander": "8.x",
- "fs-extra": "10.x",
- "js-beautify": "1.14.x",
- "stdin": "*",
- "hyphenation.en-us": "*",
- "hyphenation.de": "*",
- "svgdom": "^0.1.8"
- },
- "devDependencies": {
- "he": "1.2.x",
- "katex": "0.13.13",
- "@svgdotjs/svg.js": "3.x",
- "hypher": "0.x",
- "lodash": "4.x",
- "livescript": "https://github.com/michael-brade/LiveScript",
- "livescript-transform-esm": "^3.1.0",
- "livescript-transform-implicit-async": "^1.1.0",
- "livescript-transform-object-create": "^1.1.0",
- "pegjs": "0.10.x",
- "mkdirp": "1.0.x",
- "rimraf": "3.x",
- "tmp": "0.x",
- "glob": "8.0.x",
- "vuepress": "2.0.0-beta.61",
- "@vuepress/plugin-register-components": "next",
- "rollup-plugin-string": "3.0.x",
- "split-grid": "1.0.x",
- "@codemirror/autocomplete": "6.x",
- "@codemirror/commands": "6.x",
- "@codemirror/language": "6.x",
- "@codemirror/legacy-modes": "6.x",
- "@codemirror/lint": "6.x",
- "@codemirror/search": "6.x",
- "@codemirror/state": "6.x",
- "@codemirror/view": "6.x",
- "vue-codemirror": "6.1.x",
- "stylus": "0.59.x",
- "rollup": "3.20.x",
- "@rollup/plugin-commonjs": "24.1.x",
- "@rollup/plugin-node-resolve": "15.0.x",
- "@rollup/plugin-terser": "0.4.x",
- "rollup-plugin-visualizer": "5.8.x",
- "mocha": "10.1.x",
- "mocha-junit-reporter": "2.x",
- "chai": "4.x",
- "chai-as-promised": "7.x",
- "slugify": "1.6.x",
- "decache": "4.6.x",
- "puppeteer": "19.1.x",
- "pixelmatch": "5.3.x",
- "nyc": "15.x",
- "codecov": "3.x",
- "serve-handler": "6.x"
- },
- "mocha": {
- "require": "livescript",
- "file": "test/lib/setup.ls",
- "reporter": "spec",
- "inlineDiffs": true,
- "timeout": 10000,
- "ui": "bdd",
- "checkLeaks": true,
- "globals": "firefox,chrome",
- "sort": true
- },
- "repository": {
- "type": "git",
- "url": "git+https://github.com/michael-brade/LaTeX.js.git"
- },
- "license": "MIT",
- "bugs": {
- "url": "https://github.com/michael-brade/LaTeX.js/issues"
- },
- "homepage": "https://latex.js.org",
- "engines": {
- "node": ">= 14.0"
- }
-}
+ "name": "latex.js",
+ "description": "JavaScript LaTeX to HTML5 translator",
+ "version": "0.12.6",
+ "author": {
+ "name": "Michael Brade",
+ "email": "brade@kde.org"
+ },
+ "keywords": [
+ "pegjs",
+ "latex",
+ "parser",
+ "html5"
+ ],
+ "bin": {
+ "latex.js": "./bin/latex.js"
+ },
+ "module": "./dist/latex.mjs",
+ "main": "./dist/latex.js",
+ "exports": {
+ "import": "./dist/latex.mjs",
+ "require": "./dist/latex.js"
+ },
+ "browser": "./dist/latex.js",
+ "files": [
+ "bin/latex.js",
+ "dist/latex.js",
+ "dist/latex.js.map",
+ "dist/latex.mjs",
+ "dist/latex.mjs.map",
+ "dist/css/",
+ "dist/fonts/",
+ "dist/js/",
+ "dist/packages/",
+ "dist/documentclasses/"
+ ],
+ "scripts": {
+ "clean": "rimraf dist bin test/coverage test/test-results.xml website docs/.vitepress/.temp docs/.vitepress/.cache",
+ "devbuild": "rimraf 'dist/**/*.map';mkdirp dist/css;mkdirp dist/js;mkdirp dist/fonts;mkdirp dist/documentclasses;mkdirp dist/packages;touch dist/documentclasses/.keep;touch dist/packages/.keep;rsync -a src/css/ dist/css/;rsync -a src/fonts/ dist/fonts/;rsync -a node_modules/katex/dist/fonts/*.woff2 dist/fonts/;rsync -a src/js/ dist/js/;mkdirp bin;lsc -bc --no-header -m embedded -p src/cli.ls > bin/latex.js;chmod a+x bin/latex.js;rollup -c;",
+ "build": "NODE_ENV=production npm run devbuild;",
+ "prepare-latex-assets": "rimraf docs/public/latexjs; mkdirp docs/public/latexjs/css docs/public/latexjs/fonts docs/public/latexjs/js; rsync -a dist/css/ docs/public/latexjs/css/; rsync -a dist/fonts/ docs/public/latexjs/fonts/; rsync -a dist/js/ docs/public/latexjs/js/;",
+ "devdocs": "npm run devbuild; npm run prepare-latex-assets; vitepress dev docs",
+ "docs": "npm run build; npm run prepare-latex-assets; [ ! -d website ] && git worktree add website gh-pages; mv website/.git .website.git; vitepress build docs; mv .website.git website/.git; cd website; git add .; git commit -m 'regenerated website';",
+ "test": "mocha test/*.ls;",
+ "iron": "iron-node node_modules/.bin/_mocha test/*.ls;",
+ "testc": "nyc --include=bin --include=src --include=dist -e ls --reporter=html --reporter=text --reporter=lcovonly --report-dir=test/coverage npx mocha -i -g screenshot --reporter mocha-junit-reporter --reporter-options mochaFile=./test/test-results.xml test/*.ls&&npx mocha -g screenshot --reporter mocha-junit-reporter --reporter-options mochaFile=./test/screenshots/test-results.xml test/*.ls;",
+ "codecov": "codecov;"
+ },
+ "dependencies": {
+ "commander": "8.x",
+ "express": "^5.1.0",
+ "fs-extra": "10.x",
+ "hyphenation.de": "*",
+ "hyphenation.en-us": "^0.2.1",
+ "js-beautify": "1.14.x",
+ "stdin": "*",
+ "svgdom": "^0.1.8"
+ },
+ "devDependencies": {
+ "@codemirror/autocomplete": "6.x",
+ "@codemirror/commands": "6.x",
+ "@codemirror/lang-javascript": "^6.2.4",
+ "@codemirror/language": "^6.11.3",
+ "@codemirror/legacy-modes": "^6.5.2",
+ "@codemirror/lint": "6.x",
+ "@codemirror/search": "6.x",
+ "@codemirror/state": "^6.5.2",
+ "@codemirror/theme-one-dark": "^6.1.3",
+ "@codemirror/view": "^6.38.7",
+ "@rollup/plugin-commonjs": "24.1.x",
+ "@rollup/plugin-node-resolve": "15.0.x",
+ "@rollup/plugin-terser": "0.4.x",
+ "@svgdotjs/svg.js": "3.x",
+ "chai": "4.x",
+ "chai-as-promised": "7.x",
+ "codecov": "3.x",
+ "decache": "4.6.x",
+ "glob": "8.0.x",
+ "he": "1.2.x",
+ "hypher": "0.x",
+ "katex": "0.13.13",
+ "livescript": "https://github.com/michael-brade/LiveScript",
+ "livescript-transform-esm": "^3.1.0",
+ "livescript-transform-implicit-async": "^1.1.0",
+ "livescript-transform-object-create": "^1.1.0",
+ "lodash": "4.x",
+ "mkdirp": "1.0.x",
+ "mocha": "10.1.x",
+ "mocha-junit-reporter": "2.x",
+ "nyc": "15.x",
+ "pegjs": "0.10.x",
+ "pixelmatch": "5.3.x",
+ "puppeteer": "19.1.x",
+ "rimraf": "3.x",
+ "rollup": "3.20.x",
+ "rollup-plugin-string": "3.0.x",
+ "rollup-plugin-visualizer": "5.8.x",
+ "sass-embedded": "^1.93.3",
+ "serve-handler": "6.x",
+ "slugify": "1.6.x",
+ "split-grid": "1.0.x",
+ "stylus": "^0.59.0",
+ "tmp": "0.x",
+ "vite-plugin-string": "^1.2.3",
+ "vitepress": "^1.6.4",
+ "vue": "^3.5.24",
+ "vue-codemirror": "^6.1.1"
+ },
+ "mocha": {
+ "require": "livescript",
+ "file": "test/lib/setup.ls",
+ "reporter": "spec",
+ "inlineDiffs": true,
+ "timeout": 10000,
+ "ui": "bdd",
+ "checkLeaks": true,
+ "globals": "firefox,chrome",
+ "sort": true
+ },
+ "repository": {
+ "type": "git",
+ "url": "git+https://github.com/michael-brade/LaTeX.js.git"
+ },
+ "license": "MIT",
+ "bugs": {
+ "url": "https://github.com/michael-brade/LaTeX.js/issues"
+ },
+ "homepage": "https://latex.js.org",
+ "engines": {
+ "node": ">= 18.0"
+ }
+}
\ No newline at end of file