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 @@ + + + + + \ 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 @@ + + + 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 @@ + + + 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 @@ + + + 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 @@ - - - - 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 @@ - - - - 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 @@ - - - - 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 @@ - - - - - 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