web/packages: NPM workspace: Mini Cleanup (#14767)
* web: Move non-workspace package. * web: Update ESBuild package version. * web: Use NPM link to alias local package. * web: Update lock. * web: Fix regression where bundler is expected.
This commit is contained in:
		
							
								
								
									
										200
									
								
								web/package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										200
									
								
								web/package-lock.json
									
									
									
										generated
									
									
									
								
							| @ -75,7 +75,7 @@ | ||||
|             "devDependencies": { | ||||
|                 "@eslint/js": "^9.27.0", | ||||
|                 "@goauthentik/core": "^1.0.0", | ||||
|                 "@goauthentik/esbuild-plugin-live-reload": "^1.0.4", | ||||
|                 "@goauthentik/esbuild-plugin-live-reload": "^1.0.5", | ||||
|                 "@goauthentik/eslint-config": "^1.0.5", | ||||
|                 "@goauthentik/prettier-config": "^1.0.5", | ||||
|                 "@goauthentik/tsconfig": "^1.0.4", | ||||
| @ -1716,20 +1716,6 @@ | ||||
|                 "node": ">=6" | ||||
|             } | ||||
|         }, | ||||
|         "node_modules/@gerrit0/mini-shiki": { | ||||
|             "version": "3.4.2", | ||||
|             "resolved": "https://registry.npmjs.org/@gerrit0/mini-shiki/-/mini-shiki-3.4.2.tgz", | ||||
|             "integrity": "sha512-3jXo5bNjvvimvdbIhKGfFxSnKCX+MA8wzHv55ptzk/cx8wOzT+BRcYgj8aFN3yTiTs+zvQQiaZFr7Jce1ZG3fw==", | ||||
|             "dev": true, | ||||
|             "license": "MIT", | ||||
|             "dependencies": { | ||||
|                 "@shikijs/engine-oniguruma": "^3.4.2", | ||||
|                 "@shikijs/langs": "^3.4.2", | ||||
|                 "@shikijs/themes": "^3.4.2", | ||||
|                 "@shikijs/types": "^3.4.2", | ||||
|                 "@shikijs/vscode-textmate": "^10.0.2" | ||||
|             } | ||||
|         }, | ||||
|         "node_modules/@goauthentik/api": { | ||||
|             "version": "2025.6.2-1750856752", | ||||
|             "resolved": "https://registry.npmjs.org/@goauthentik/api/-/api-2025.6.2-1750856752.tgz", | ||||
| @ -1740,8 +1726,20 @@ | ||||
|             "link": true | ||||
|         }, | ||||
|         "node_modules/@goauthentik/esbuild-plugin-live-reload": { | ||||
|             "resolved": "packages/esbuild-plugin-live-reload", | ||||
|             "link": true | ||||
|             "version": "1.0.5", | ||||
|             "resolved": "https://registry.npmjs.org/@goauthentik/esbuild-plugin-live-reload/-/esbuild-plugin-live-reload-1.0.5.tgz", | ||||
|             "integrity": "sha512-MZ/najY+Xn62ijzj7JDS1sVupWI3BNRwJc4kykB/iP9CdLJw+xO71qPTjfCEEOVYMZrOTftD4KOLhRYx3GTqkA==", | ||||
|             "dev": true, | ||||
|             "license": "MIT", | ||||
|             "dependencies": { | ||||
|                 "find-free-ports": "^3.1.1" | ||||
|             }, | ||||
|             "engines": { | ||||
|                 "node": ">=22" | ||||
|             }, | ||||
|             "peerDependencies": { | ||||
|                 "esbuild": "^0.25.4" | ||||
|             } | ||||
|         }, | ||||
|         "node_modules/@goauthentik/eslint-config": { | ||||
|             "version": "1.0.5", | ||||
| @ -4058,6 +4056,7 @@ | ||||
|             "integrity": "sha512-ROFF39F6ZrnzSUEmQQZUar0Jt4xVoP9WnDRdWwF4NNcXs3xBTLgBUDoOwW141y1jP+S8nahIbdxbFC7IShw9Iw==", | ||||
|             "dev": true, | ||||
|             "license": "MIT", | ||||
|             "peer": true, | ||||
|             "engines": { | ||||
|                 "node": "^12.20.0 || ^14.18.0 || >=16.0.0" | ||||
|             }, | ||||
| @ -4719,55 +4718,6 @@ | ||||
|                 "node": ">=14.18" | ||||
|             } | ||||
|         }, | ||||
|         "node_modules/@shikijs/engine-oniguruma": { | ||||
|             "version": "3.4.2", | ||||
|             "resolved": "https://registry.npmjs.org/@shikijs/engine-oniguruma/-/engine-oniguruma-3.4.2.tgz", | ||||
|             "integrity": "sha512-zcZKMnNndgRa3ORja6Iemsr3DrLtkX3cAF7lTJkdMB6v9alhlBsX9uNiCpqofNrXOvpA3h6lHcLJxgCIhVOU5Q==", | ||||
|             "dev": true, | ||||
|             "license": "MIT", | ||||
|             "dependencies": { | ||||
|                 "@shikijs/types": "3.4.2", | ||||
|                 "@shikijs/vscode-textmate": "^10.0.2" | ||||
|             } | ||||
|         }, | ||||
|         "node_modules/@shikijs/langs": { | ||||
|             "version": "3.4.2", | ||||
|             "resolved": "https://registry.npmjs.org/@shikijs/langs/-/langs-3.4.2.tgz", | ||||
|             "integrity": "sha512-H6azIAM+OXD98yztIfs/KH5H4PU39t+SREhmM8LaNXyUrqj2mx+zVkr8MWYqjceSjDw9I1jawm1WdFqU806rMA==", | ||||
|             "dev": true, | ||||
|             "license": "MIT", | ||||
|             "dependencies": { | ||||
|                 "@shikijs/types": "3.4.2" | ||||
|             } | ||||
|         }, | ||||
|         "node_modules/@shikijs/themes": { | ||||
|             "version": "3.4.2", | ||||
|             "resolved": "https://registry.npmjs.org/@shikijs/themes/-/themes-3.4.2.tgz", | ||||
|             "integrity": "sha512-qAEuAQh+brd8Jyej2UDDf+b4V2g1Rm8aBIdvt32XhDPrHvDkEnpb7Kzc9hSuHUxz0Iuflmq7elaDuQAP9bHIhg==", | ||||
|             "dev": true, | ||||
|             "license": "MIT", | ||||
|             "dependencies": { | ||||
|                 "@shikijs/types": "3.4.2" | ||||
|             } | ||||
|         }, | ||||
|         "node_modules/@shikijs/types": { | ||||
|             "version": "3.4.2", | ||||
|             "resolved": "https://registry.npmjs.org/@shikijs/types/-/types-3.4.2.tgz", | ||||
|             "integrity": "sha512-zHC1l7L+eQlDXLnxvM9R91Efh2V4+rN3oMVS2swCBssbj2U/FBwybD1eeLaq8yl/iwT+zih8iUbTBCgGZOYlVg==", | ||||
|             "dev": true, | ||||
|             "license": "MIT", | ||||
|             "dependencies": { | ||||
|                 "@shikijs/vscode-textmate": "^10.0.2", | ||||
|                 "@types/hast": "^3.0.4" | ||||
|             } | ||||
|         }, | ||||
|         "node_modules/@shikijs/vscode-textmate": { | ||||
|             "version": "10.0.2", | ||||
|             "resolved": "https://registry.npmjs.org/@shikijs/vscode-textmate/-/vscode-textmate-10.0.2.tgz", | ||||
|             "integrity": "sha512-83yeghZ2xxin3Nj8z1NMd/NCuca+gsYXswywDy5bHvwlWL8tpTQmzGeUuHd9FC3E/SBEMvzJRwWEOz5gGes9Qg==", | ||||
|             "dev": true, | ||||
|             "license": "MIT" | ||||
|         }, | ||||
|         "node_modules/@sinclair/typebox": { | ||||
|             "version": "0.27.8", | ||||
|             "resolved": "https://registry.npmjs.org/@sinclair/typebox/-/typebox-0.27.8.tgz", | ||||
| @ -13238,6 +13188,7 @@ | ||||
|             "integrity": "sha512-Mc7QhQ8s+cLrnUfU/Ji94vG/r8M26m8f++vyres4ZoojaRDpZ1eSIh/EpzLNwlWuvzSZ3UbDFspjFvTDXe6e/g==", | ||||
|             "dev": true, | ||||
|             "license": "MIT", | ||||
|             "peer": true, | ||||
|             "engines": { | ||||
|                 "node": ">=12.20" | ||||
|             } | ||||
| @ -13248,6 +13199,7 @@ | ||||
|             "integrity": "sha512-qE3Veg1YXzGHQhlA6jzebZN2qVf6NX+A7m7qlhCGG30dJixrAQhYOsJjsnBjJkCSmuOPpCk30145fr8FV0bzog==", | ||||
|             "dev": true, | ||||
|             "license": "MIT", | ||||
|             "peer": true, | ||||
|             "engines": { | ||||
|                 "node": "^12.20.0 || ^14.13.1 || >=16.0.0" | ||||
|             }, | ||||
| @ -15698,6 +15650,7 @@ | ||||
|             "version": "3.1.1", | ||||
|             "resolved": "https://registry.npmjs.org/find-free-ports/-/find-free-ports-3.1.1.tgz", | ||||
|             "integrity": "sha512-hQebewth9i5qkf0a0u06iFaxQssk5ZnPBBggsa1vk8zCYaZoz9IZXpoRLTbEOrYdqfrjvcxU00gYoCPgmXugKA==", | ||||
|             "dev": true, | ||||
|             "license": "MIT" | ||||
|         }, | ||||
|         "node_modules/find-replace": { | ||||
| @ -16242,6 +16195,7 @@ | ||||
|             "integrity": "sha512-cmP497iLq54AZnv4YRAEMnEyQ1eIn4tGKbmswqwmFV4GBnAqE8NLtWxxdXa++AalfgL5EBH4IxTPyquEuGY/jA==", | ||||
|             "dev": true, | ||||
|             "license": "MIT", | ||||
|             "peer": true, | ||||
|             "funding": { | ||||
|                 "url": "https://github.com/fisker/git-hooks-list?sponsor=1" | ||||
|             } | ||||
| @ -19172,16 +19126,6 @@ | ||||
|             "dev": true, | ||||
|             "license": "MIT" | ||||
|         }, | ||||
|         "node_modules/linkify-it": { | ||||
|             "version": "5.0.0", | ||||
|             "resolved": "https://registry.npmjs.org/linkify-it/-/linkify-it-5.0.0.tgz", | ||||
|             "integrity": "sha512-5aHCbzQRADcdP+ATqnDuhhJ/MRIqDkZX5pyjFHRRysS8vZ5AbqGEoFIb6pYHPZ+L/OC2Lc+xT8uHVVR5CAK/wQ==", | ||||
|             "dev": true, | ||||
|             "license": "MIT", | ||||
|             "dependencies": { | ||||
|                 "uc.micro": "^2.0.0" | ||||
|             } | ||||
|         }, | ||||
|         "node_modules/lit": { | ||||
|             "version": "3.3.0", | ||||
|             "resolved": "https://registry.npmjs.org/lit/-/lit-3.3.0.tgz", | ||||
| @ -19586,13 +19530,6 @@ | ||||
|                 "node": ">=16.14" | ||||
|             } | ||||
|         }, | ||||
|         "node_modules/lunr": { | ||||
|             "version": "2.3.9", | ||||
|             "resolved": "https://registry.npmjs.org/lunr/-/lunr-2.3.9.tgz", | ||||
|             "integrity": "sha512-zTU3DaZaF3Rt9rhN3uBMGQD3dD2/vFQqnvZCDv4dl5iOzq2IZQqTxu90r4E5J+nP70J3ilqVCrbho2eWaeW8Ow==", | ||||
|             "dev": true, | ||||
|             "license": "MIT" | ||||
|         }, | ||||
|         "node_modules/lz-string": { | ||||
|             "version": "1.5.0", | ||||
|             "resolved": "https://registry.npmjs.org/lz-string/-/lz-string-1.5.0.tgz", | ||||
| @ -19654,24 +19591,6 @@ | ||||
|                 "url": "https://github.com/sponsors/sindresorhus" | ||||
|             } | ||||
|         }, | ||||
|         "node_modules/markdown-it": { | ||||
|             "version": "14.1.0", | ||||
|             "resolved": "https://registry.npmjs.org/markdown-it/-/markdown-it-14.1.0.tgz", | ||||
|             "integrity": "sha512-a54IwgWPaeBCAAsv13YgmALOF1elABB08FxO9i+r4VFk5Vl4pKokRPeX8u5TCgSsPi6ec1otfLjdOpVcgbpshg==", | ||||
|             "dev": true, | ||||
|             "license": "MIT", | ||||
|             "dependencies": { | ||||
|                 "argparse": "^2.0.1", | ||||
|                 "entities": "^4.4.0", | ||||
|                 "linkify-it": "^5.0.0", | ||||
|                 "mdurl": "^2.0.0", | ||||
|                 "punycode.js": "^2.3.1", | ||||
|                 "uc.micro": "^2.1.0" | ||||
|             }, | ||||
|             "bin": { | ||||
|                 "markdown-it": "bin/markdown-it.mjs" | ||||
|             } | ||||
|         }, | ||||
|         "node_modules/markdown-table": { | ||||
|             "version": "3.0.4", | ||||
|             "resolved": "https://registry.npmjs.org/markdown-table/-/markdown-table-3.0.4.tgz", | ||||
| @ -20069,13 +19988,6 @@ | ||||
|                 "url": "https://opencollective.com/unified" | ||||
|             } | ||||
|         }, | ||||
|         "node_modules/mdurl": { | ||||
|             "version": "2.0.0", | ||||
|             "resolved": "https://registry.npmjs.org/mdurl/-/mdurl-2.0.0.tgz", | ||||
|             "integrity": "sha512-Lf+9+2r+Tdp5wXDXC4PcIBjTDtq4UKjCPMQhKIuzpJNW0b96kVqSwW0bT7FhRSfmAiFYgP+SCRvdrDozfh0U5w==", | ||||
|             "dev": true, | ||||
|             "license": "MIT" | ||||
|         }, | ||||
|         "node_modules/media-typer": { | ||||
|             "version": "0.3.0", | ||||
|             "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", | ||||
| @ -23018,6 +22930,7 @@ | ||||
|             "integrity": "sha512-h+3tSpr2nVpp+YOK1MDIYtYhHVXr8/0V59UUbJpIJFaqi3w4fvUokJo6eV8W+vELrUXIZzJ+DKm5G7lYzrMcKQ==", | ||||
|             "dev": true, | ||||
|             "license": "MIT", | ||||
|             "peer": true, | ||||
|             "dependencies": { | ||||
|                 "sort-package-json": "3.2.1", | ||||
|                 "synckit": "0.11.6" | ||||
| @ -23265,16 +23178,6 @@ | ||||
|                 "node": ">=6" | ||||
|             } | ||||
|         }, | ||||
|         "node_modules/punycode.js": { | ||||
|             "version": "2.3.1", | ||||
|             "resolved": "https://registry.npmjs.org/punycode.js/-/punycode.js-2.3.1.tgz", | ||||
|             "integrity": "sha512-uxFIHU0YlHYhDQtV4R9J6a52SLx28BCjT+4ieh7IGbgwVJWO+km431c4yRlREUAsAmt/uMjQUyQHNEPf0M39CA==", | ||||
|             "dev": true, | ||||
|             "license": "MIT", | ||||
|             "engines": { | ||||
|                 "node": ">=6" | ||||
|             } | ||||
|         }, | ||||
|         "node_modules/puppeteer-core": { | ||||
|             "version": "22.15.0", | ||||
|             "resolved": "https://registry.npmjs.org/puppeteer-core/-/puppeteer-core-22.15.0.tgz", | ||||
| @ -25377,7 +25280,8 @@ | ||||
|             "resolved": "https://registry.npmjs.org/sort-object-keys/-/sort-object-keys-1.1.3.tgz", | ||||
|             "integrity": "sha512-855pvK+VkU7PaKYPc+Jjnmt4EzejQHyhhF33q31qG8x7maDzkeFhAAThdCYay11CISO+qAMwjOBP+fPZe0IPyg==", | ||||
|             "dev": true, | ||||
|             "license": "MIT" | ||||
|             "license": "MIT", | ||||
|             "peer": true | ||||
|         }, | ||||
|         "node_modules/sort-package-json": { | ||||
|             "version": "3.2.1", | ||||
| @ -25385,6 +25289,7 @@ | ||||
|             "integrity": "sha512-rTfRdb20vuoAn7LDlEtCqOkYfl2X+Qze6cLbNOzcDpbmKEhJI30tTN44d5shbKJnXsvz24QQhlCm81Bag7EOKg==", | ||||
|             "dev": true, | ||||
|             "license": "MIT", | ||||
|             "peer": true, | ||||
|             "dependencies": { | ||||
|                 "detect-indent": "^7.0.1", | ||||
|                 "detect-newline": "^4.0.1", | ||||
| @ -26077,6 +25982,7 @@ | ||||
|             "integrity": "sha512-2pR2ubZSV64f/vqm9eLPz/KOvR9Dm+Co/5ChLgeHl0yEDRc6h5hXHoxEQH8Y5Ljycozd3p1k5TTSVdzYGkPvLw==", | ||||
|             "dev": true, | ||||
|             "license": "MIT", | ||||
|             "peer": true, | ||||
|             "dependencies": { | ||||
|                 "@pkgr/core": "^0.2.4" | ||||
|             }, | ||||
| @ -26287,6 +26193,7 @@ | ||||
|             "integrity": "sha512-mEwzpUgrLySlveBwEVDMKk5B57bhLPYovRfPAXD5gA/98Opn0rCDj3GtLwFvCvH5RK9uPCExUROW5NjDwvqkxw==", | ||||
|             "dev": true, | ||||
|             "license": "MIT", | ||||
|             "peer": true, | ||||
|             "dependencies": { | ||||
|                 "fdir": "^6.4.4", | ||||
|                 "picomatch": "^4.0.2" | ||||
| @ -27156,43 +27063,6 @@ | ||||
|             "dev": true, | ||||
|             "license": "MIT" | ||||
|         }, | ||||
|         "node_modules/typedoc": { | ||||
|             "version": "0.28.5", | ||||
|             "resolved": "https://registry.npmjs.org/typedoc/-/typedoc-0.28.5.tgz", | ||||
|             "integrity": "sha512-5PzUddaA9FbaarUzIsEc4wNXCiO4Ot3bJNeMF2qKpYlTmM9TTaSHQ7162w756ERCkXER/+o2purRG6YOAv6EMA==", | ||||
|             "dev": true, | ||||
|             "license": "Apache-2.0", | ||||
|             "dependencies": { | ||||
|                 "@gerrit0/mini-shiki": "^3.2.2", | ||||
|                 "lunr": "^2.3.9", | ||||
|                 "markdown-it": "^14.1.0", | ||||
|                 "minimatch": "^9.0.5", | ||||
|                 "yaml": "^2.7.1" | ||||
|             }, | ||||
|             "bin": { | ||||
|                 "typedoc": "bin/typedoc" | ||||
|             }, | ||||
|             "engines": { | ||||
|                 "node": ">= 18", | ||||
|                 "pnpm": ">= 10" | ||||
|             }, | ||||
|             "peerDependencies": { | ||||
|                 "typescript": "5.0.x || 5.1.x || 5.2.x || 5.3.x || 5.4.x || 5.5.x || 5.6.x || 5.7.x || 5.8.x" | ||||
|             } | ||||
|         }, | ||||
|         "node_modules/typedoc-plugin-markdown": { | ||||
|             "version": "4.6.3", | ||||
|             "resolved": "https://registry.npmjs.org/typedoc-plugin-markdown/-/typedoc-plugin-markdown-4.6.3.tgz", | ||||
|             "integrity": "sha512-86oODyM2zajXwLs4Wok2mwVEfCwCnp756QyhLGX2IfsdRYr1DXLCgJgnLndaMUjJD7FBhnLk2okbNE9PdLxYRw==", | ||||
|             "dev": true, | ||||
|             "license": "MIT", | ||||
|             "engines": { | ||||
|                 "node": ">= 18" | ||||
|             }, | ||||
|             "peerDependencies": { | ||||
|                 "typedoc": "0.28.x" | ||||
|             } | ||||
|         }, | ||||
|         "node_modules/types-ramda": { | ||||
|             "version": "0.30.1", | ||||
|             "resolved": "https://registry.npmjs.org/types-ramda/-/types-ramda-0.30.1.tgz", | ||||
| @ -27249,13 +27119,6 @@ | ||||
|                 "node": ">=8" | ||||
|             } | ||||
|         }, | ||||
|         "node_modules/uc.micro": { | ||||
|             "version": "2.1.0", | ||||
|             "resolved": "https://registry.npmjs.org/uc.micro/-/uc.micro-2.1.0.tgz", | ||||
|             "integrity": "sha512-ARDJmphmdvUk6Glw7y9DQ2bFkKBHwQHLi2lsaH6PPmz/Ka9sFOBsBluozhDltWmnv9u/cF6Rt87znRTPV+yp/A==", | ||||
|             "dev": true, | ||||
|             "license": "MIT" | ||||
|         }, | ||||
|         "node_modules/ufo": { | ||||
|             "version": "1.5.4", | ||||
|             "resolved": "https://registry.npmjs.org/ufo/-/ufo-1.5.4.tgz", | ||||
| @ -29467,6 +29330,7 @@ | ||||
|         "packages/esbuild-plugin-live-reload": { | ||||
|             "name": "@goauthentik/esbuild-plugin-live-reload", | ||||
|             "version": "1.0.5", | ||||
|             "extraneous": true, | ||||
|             "license": "MIT", | ||||
|             "dependencies": { | ||||
|                 "find-free-ports": "^3.1.1" | ||||
| @ -29490,16 +29354,6 @@ | ||||
|                 "esbuild": "^0.25.5" | ||||
|             } | ||||
|         }, | ||||
|         "packages/esbuild-plugin-live-reload/node_modules/@types/node": { | ||||
|             "version": "22.15.19", | ||||
|             "resolved": "https://registry.npmjs.org/@types/node/-/node-22.15.19.tgz", | ||||
|             "integrity": "sha512-3vMNr4TzNQyjHcRZadojpRaD9Ofr6LsonZAoQ+HMUa/9ORTPoxVIw0e0mpqWpdjj8xybyCM+oKOUH2vwFu/oEw==", | ||||
|             "dev": true, | ||||
|             "license": "MIT", | ||||
|             "dependencies": { | ||||
|                 "undici-types": "~6.21.0" | ||||
|             } | ||||
|         }, | ||||
|         "packages/monorepo": { | ||||
|             "name": "@goauthentik/monorepo", | ||||
|             "version": "1.0.0", | ||||
|  | ||||
| @ -146,7 +146,7 @@ | ||||
|     "devDependencies": { | ||||
|         "@eslint/js": "^9.27.0", | ||||
|         "@goauthentik/core": "^1.0.0", | ||||
|         "@goauthentik/esbuild-plugin-live-reload": "^1.0.4", | ||||
|         "@goauthentik/esbuild-plugin-live-reload": "^1.0.5", | ||||
|         "@goauthentik/eslint-config": "^1.0.5", | ||||
|         "@goauthentik/prettier-config": "^1.0.5", | ||||
|         "@goauthentik/tsconfig": "^1.0.4", | ||||
|  | ||||
| @ -1,59 +0,0 @@ | ||||
| _An ESBuild development plugin that watches for file changes and triggers automatic browser refreshes._ | ||||
|  | ||||
| ## Quick start | ||||
|  | ||||
| ```sh | ||||
| npm install -D @goauthentik/esbuild-plugin-live-reload | ||||
| # Or with Yarn: | ||||
| yarn add -D @goauthentik/esbuild-plugin-live-reload | ||||
| ``` | ||||
|  | ||||
| ### 1. Configure ESBuild | ||||
|  | ||||
| ```js | ||||
| import { liveReloadPlugin } from "@goauthentik/esbuild-plugin-live-reload"; | ||||
| import esbuild from "esbuild"; | ||||
|  | ||||
| const NodeEnvironment = process.env.NODE_ENV || "development"; | ||||
|  | ||||
| /** | ||||
|  * @type {esbuild.BuildOptions} | ||||
|  */ | ||||
| const buildOptions = { | ||||
|     // ... Your build options. | ||||
|     define: { | ||||
|         "process.env.NODE_ENV": JSON.stringify(NodeEnvironment), | ||||
|     }, | ||||
|     plugins: [ | ||||
|         /** @see {@link LiveReloadPluginOptions} */ | ||||
|         liveReloadPlugin(), | ||||
|     ], | ||||
| }; | ||||
|  | ||||
| const buildContext = await esbuild.context(buildOptions); | ||||
|  | ||||
| await buildContext.rebuild(); | ||||
| await buildContext.watch(); | ||||
| ``` | ||||
|  | ||||
| ### 2. Connect your browser | ||||
|  | ||||
| Add the following import near the beginning of your application's entry point. | ||||
|  | ||||
| ```js | ||||
| if (process.env.NODE_ENV === "development") { | ||||
|     await import("@goauthentik/esbuild-plugin-live-reload/client"); | ||||
| } | ||||
| ``` | ||||
|  | ||||
| That's it! Your browser will now automatically refresh whenever ESBuild finishes rebuilding your code. | ||||
|  | ||||
| ## About authentik | ||||
|  | ||||
| [authentik](https://goauthentik.io) is an open source Identity Provider that unifies your identity needs into a single platform, replacing Okta, Active Directory, and Auth0. | ||||
|  | ||||
| We built this plugin to streamline our development workflow, and we're sharing it with the community. If you have any questions, feature requests, or bug reports, please [open an issue](https://github.com/goauthentik/authentik/issues/new/choose). | ||||
|  | ||||
| ## License | ||||
|  | ||||
| This code is licensed under the [MIT License](https://www.tldrlegal.com/license/mit-license) | ||||
| @ -1,3 +0,0 @@ | ||||
| README.md | ||||
| node_modules | ||||
| _media | ||||
| @ -1,3 +0,0 @@ | ||||
| node_modules | ||||
| ./README.md | ||||
| out | ||||
| @ -1,18 +0,0 @@ | ||||
| The MIT License (MIT) | ||||
|  | ||||
| Copyright (c) 2025 Authentik Security, Inc. | ||||
|  | ||||
| Permission is hereby granted, free of charge, to any person obtaining a copy of this software and | ||||
| associated documentation files (the "Software"), to deal in the Software without restriction, | ||||
| including without limitation the rights to use, copy, modify, merge, publish, distribute, | ||||
| sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is | ||||
| furnished to do so, subject to the following conditions: | ||||
|  | ||||
| The above copyright notice and this permission notice shall be included in all copies or substantial | ||||
| portions of the Software. | ||||
|  | ||||
| THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT | ||||
| NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND | ||||
| NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES | ||||
| OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN | ||||
| CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. | ||||
| @ -1,221 +0,0 @@ | ||||
| /// <reference types="./types.js" /> | ||||
|  | ||||
| /** | ||||
|  * @file Client-side observer for ESBuild events. | ||||
|  * | ||||
|  * @import { Message as ESBuildMessage } from "esbuild"; | ||||
|  */ | ||||
|  | ||||
| const logPrefix = "authentik/dev/web: "; | ||||
| const log = console.debug.bind(console, logPrefix); | ||||
|  | ||||
| /** | ||||
|  * @template {unknown} [Data=unknown] | ||||
|  * @typedef {(event: MessageEvent) => void} BuildEventListener | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * A client-side watcher for ESBuild. | ||||
|  * | ||||
|  * Note that this should be conditionally imported in your code, so that | ||||
|  * ESBuild may tree-shake it out of production builds. | ||||
|  * | ||||
|  * ```ts | ||||
|  * if (process.env.NODE_ENV === "development") { | ||||
|  *   await import("@goauthentik/esbuild-plugin-live-reload/client") | ||||
|  *     .catch(() => console.warn("Failed to import watcher")) | ||||
|  * } | ||||
|  * ``` | ||||
|  * | ||||
|  * @implements {Disposable} | ||||
|  * @category Plugin | ||||
|  * runtime browser | ||||
|  */ | ||||
| export class ESBuildObserver extends EventSource { | ||||
|     /** | ||||
|      * Whether the watcher has a recent connection to the server. | ||||
|      */ | ||||
|     alive = true; | ||||
|  | ||||
|     /** | ||||
|      * The number of errors that have occurred since the watcher started. | ||||
|      */ | ||||
|     errorCount = 0; | ||||
|  | ||||
|     /** | ||||
|      * Whether a reload has been requested while offline. | ||||
|      */ | ||||
|     deferredReload = false; | ||||
|  | ||||
|     /** | ||||
|      * The last time a message was received from the server. | ||||
|      */ | ||||
|     lastUpdatedAt = Date.now(); | ||||
|  | ||||
|     /** | ||||
|      * Whether the browser considers itself online. | ||||
|      */ | ||||
|     online = true; | ||||
|  | ||||
|     /** | ||||
|      * The ID of the animation frame for the reload. | ||||
|      */ | ||||
|     #reloadFrameID = -1; | ||||
|  | ||||
|     /** | ||||
|      * The interval for the keep-alive check. | ||||
|      * @type {ReturnType<typeof setInterval> | undefined} | ||||
|      */ | ||||
|     #keepAliveInterval; | ||||
|  | ||||
|     #trackActivity = () => { | ||||
|         this.lastUpdatedAt = Date.now(); | ||||
|         this.alive = true; | ||||
|     }; | ||||
|  | ||||
|     /** | ||||
|      * @type {BuildEventListener} | ||||
|      */ | ||||
|     #startListener = () => { | ||||
|         this.#trackActivity(); | ||||
|         log("⏰ Build started..."); | ||||
|     }; | ||||
|  | ||||
|     #internalErrorListener = () => { | ||||
|         this.errorCount += 1; | ||||
|  | ||||
|         if (this.errorCount > 100) { | ||||
|             clearTimeout(this.#keepAliveInterval); | ||||
|  | ||||
|             this.close(); | ||||
|             log("⛔️ Closing connection"); | ||||
|         } | ||||
|     }; | ||||
|  | ||||
|     /** | ||||
|      * @type {BuildEventListener<string>} | ||||
|      */ | ||||
|     #errorListener = (event) => { | ||||
|         this.#trackActivity(); | ||||
|  | ||||
|         console.group(logPrefix, "⛔️⛔️⛔️  Build error..."); | ||||
|  | ||||
|         /** | ||||
|          * @type {ESBuildMessage[]} | ||||
|          */ | ||||
|         const esbuildErrorMessages = JSON.parse(event.data); | ||||
|  | ||||
|         for (const error of esbuildErrorMessages) { | ||||
|             console.warn(error.text); | ||||
|  | ||||
|             if (error.location) { | ||||
|                 console.debug( | ||||
|                     `file://${error.location.file}:${error.location.line}:${error.location.column}`, | ||||
|                 ); | ||||
|                 console.debug(error.location.lineText); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         console.groupEnd(); | ||||
|     }; | ||||
|  | ||||
|     /** | ||||
|      * @type {BuildEventListener} | ||||
|      */ | ||||
|     #endListener = () => { | ||||
|         cancelAnimationFrame(this.#reloadFrameID); | ||||
|  | ||||
|         this.#trackActivity(); | ||||
|  | ||||
|         if (!this.online) { | ||||
|             log("🚫 Build finished while offline."); | ||||
|             this.deferredReload = true; | ||||
|  | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|         log("🛎️ Build completed! Reloading..."); | ||||
|  | ||||
|         // We use an animation frame to keep the reload from happening before the | ||||
|         // event loop has a chance to process the message. | ||||
|         this.#reloadFrameID = requestAnimationFrame(() => { | ||||
|             window.location.reload(); | ||||
|         }); | ||||
|     }; | ||||
|  | ||||
|     /** | ||||
|      * @type {BuildEventListener} | ||||
|      */ | ||||
|     #keepAliveListener = () => { | ||||
|         this.#trackActivity(); | ||||
|         log("🏓 Keep-alive"); | ||||
|     }; | ||||
|  | ||||
|     /** | ||||
|      * Initialize the ESBuild observer. | ||||
|      * This should be called once in your application. | ||||
|      * | ||||
|      * @param {string | URL} [url] | ||||
|      * @returns {ESBuildObserver} | ||||
|      */ | ||||
|     static initialize = (url) => { | ||||
|         const esbuildObserver = new ESBuildObserver(url); | ||||
|  | ||||
|         return esbuildObserver; | ||||
|     }; | ||||
|  | ||||
|     /** | ||||
|      * | ||||
|      * @param {string | URL} [url] | ||||
|      */ | ||||
|     constructor(url) { | ||||
|         if (!url) { | ||||
|             throw new TypeError("ESBuildObserver: Cannot construct without a URL"); | ||||
|         } | ||||
|  | ||||
|         super(url); | ||||
|  | ||||
|         this.addEventListener("esbuild:start", this.#startListener); | ||||
|         this.addEventListener("esbuild:end", this.#endListener); | ||||
|         this.addEventListener("esbuild:error", this.#errorListener); | ||||
|         this.addEventListener("esbuild:keep-alive", this.#keepAliveListener); | ||||
|  | ||||
|         this.addEventListener("error", this.#internalErrorListener); | ||||
|  | ||||
|         window.addEventListener("offline", () => { | ||||
|             this.online = false; | ||||
|         }); | ||||
|  | ||||
|         window.addEventListener("online", () => { | ||||
|             this.online = true; | ||||
|  | ||||
|             if (!this.deferredReload) return; | ||||
|  | ||||
|             log("🛎️ Reloading after offline build..."); | ||||
|             this.deferredReload = false; | ||||
|  | ||||
|             window.location.reload(); | ||||
|         }); | ||||
|  | ||||
|         log("🛎️ Listening for build changes..."); | ||||
|  | ||||
|         this.#keepAliveInterval = setInterval(() => { | ||||
|             const now = Date.now(); | ||||
|  | ||||
|             if (now - this.lastUpdatedAt < 10_000) return; | ||||
|  | ||||
|             this.alive = false; | ||||
|             log("👋 Waiting for build to start..."); | ||||
|         }, 15_000); | ||||
|     } | ||||
|  | ||||
|     [Symbol.dispose]() { | ||||
|         return this.close(); | ||||
|     } | ||||
|  | ||||
|     dispose() { | ||||
|         return this[Symbol.dispose](); | ||||
|     } | ||||
| } | ||||
|  | ||||
| export default ESBuildObserver; | ||||
| @ -1,13 +0,0 @@ | ||||
| /// <reference types="./types.js" /> | ||||
| /** | ||||
|  * @file Entry point for the ESBuild client-side observer. | ||||
|  */ | ||||
| import { ESBuildObserver } from "./ESBuildObserver.js"; | ||||
|  | ||||
| if (import.meta.env?.ESBUILD_WATCHER_URL) { | ||||
|     const buildObserver = new ESBuildObserver(import.meta.env.ESBUILD_WATCHER_URL); | ||||
|  | ||||
|     window.addEventListener("beforeunload", () => { | ||||
|         buildObserver.dispose(); | ||||
|     }); | ||||
| } | ||||
| @ -1,23 +0,0 @@ | ||||
| /** | ||||
|  * @file Import meta environment variables available via ESBuild. | ||||
|  */ | ||||
|  | ||||
| export {}; | ||||
| declare global { | ||||
|     /** | ||||
|      * Environment variables injected by ESBuild. | ||||
|      */ | ||||
|     interface ImportMetaEnv { | ||||
|         /** | ||||
|          * The injected watcher URL for ESBuild. | ||||
|          * This is used for live reloading in development mode. | ||||
|          * | ||||
|          * @format url | ||||
|          */ | ||||
|         readonly ESBUILD_WATCHER_URL?: string; | ||||
|     } | ||||
|  | ||||
|     interface ImportMeta { | ||||
|         readonly env: ImportMetaEnv; | ||||
|     } | ||||
| } | ||||
| @ -1,6 +0,0 @@ | ||||
| /** | ||||
|  * @remarks Live reload plugin for ESBuild. | ||||
|  */ | ||||
|  | ||||
| export * from "./client/index.js"; | ||||
| export * from "./plugin/index.js"; | ||||
							
								
								
									
										1283
									
								
								web/packages/esbuild-plugin-live-reload/package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										1283
									
								
								web/packages/esbuild-plugin-live-reload/package-lock.json
									
									
									
										generated
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @ -1,75 +0,0 @@ | ||||
| { | ||||
|     "name": "@goauthentik/esbuild-plugin-live-reload", | ||||
|     "version": "1.0.5", | ||||
|     "description": "ESBuild + browser refresh. Build completes, page reloads.", | ||||
|     "license": "MIT", | ||||
|     "scripts": { | ||||
|         "build": "npm run build:types && npm run build:docs", | ||||
|         "build:docs": "typedoc", | ||||
|         "build:types": "tsc -p .", | ||||
|         "prettier": "prettier --cache --write -u .", | ||||
|         "prettier-check": "prettier --cache --check -u ." | ||||
|     }, | ||||
|     "main": "index.js", | ||||
|     "type": "module", | ||||
|     "exports": { | ||||
|         "./package.json": "./package.json", | ||||
|         ".": { | ||||
|             "types": "./out/index.d.ts", | ||||
|             "import": "./index.js" | ||||
|         }, | ||||
|         "./client": { | ||||
|             "types": "./out/client/index.d.ts", | ||||
|             "import": "./client/index.js" | ||||
|         }, | ||||
|         "./plugin": { | ||||
|             "types": "./out/plugin/index.d.ts", | ||||
|             "import": "./plugin/index.js" | ||||
|         } | ||||
|     }, | ||||
|     "dependencies": { | ||||
|         "find-free-ports": "^3.1.1" | ||||
|     }, | ||||
|     "devDependencies": { | ||||
|         "@goauthentik/prettier-config": "^1.0.5", | ||||
|         "@goauthentik/tsconfig": "^1.0.4", | ||||
|         "@trivago/prettier-plugin-sort-imports": "^5.2.2", | ||||
|         "@types/node": "^22.15.21", | ||||
|         "esbuild": "^0.25.5", | ||||
|         "prettier": "^3.5.3", | ||||
|         "prettier-plugin-packagejson": "^2.5.14", | ||||
|         "typedoc": "^0.28.5", | ||||
|         "typedoc-plugin-markdown": "^4.6.3", | ||||
|         "typescript": "^5.8.3" | ||||
|     }, | ||||
|     "peerDependencies": { | ||||
|         "esbuild": "^0.25.5" | ||||
|     }, | ||||
|     "engines": { | ||||
|         "node": ">=22" | ||||
|     }, | ||||
|     "keywords": [ | ||||
|         "esbuild", | ||||
|         "live-reload", | ||||
|         "browser", | ||||
|         "refresh", | ||||
|         "reload", | ||||
|         "authentik" | ||||
|     ], | ||||
|     "repository": { | ||||
|         "type": "git", | ||||
|         "url": "git+https://github.com/goauthentik/authentik.git", | ||||
|         "directory": "web/packages/esbuild-plugin-live-reload" | ||||
|     }, | ||||
|     "types": "./out/index.d.ts", | ||||
|     "files": [ | ||||
|         "./index.js", | ||||
|         "client/**/*", | ||||
|         "plugin/**/*", | ||||
|         "out/**/*" | ||||
|     ], | ||||
|     "prettier": "@goauthentik/prettier-config", | ||||
|     "publishConfig": { | ||||
|         "access": "public" | ||||
|     } | ||||
| } | ||||
| @ -1,265 +0,0 @@ | ||||
| /** | ||||
|  * @file Live reload plugin for ESBuild. | ||||
|  * | ||||
|  * @import { ListenOptions } from "node:net"; | ||||
|  * @import {Server as HTTPServer} from "node:http"; | ||||
|  * @import {Server as HTTPSServer} from "node:https"; | ||||
|  */ | ||||
| import { findFreePorts } from "find-free-ports"; | ||||
| import * as http from "node:http"; | ||||
| import { resolve as resolvePath } from "node:path"; | ||||
|  | ||||
| /** | ||||
|  * Serializes a custom event to a text stream. | ||||
|  * | ||||
|  * @param {Event} event | ||||
|  * @returns {string} | ||||
|  * | ||||
|  * @category Server API | ||||
|  * @ignore | ||||
|  * @internal | ||||
|  * @runtime node | ||||
|  */ | ||||
| export function serializeCustomEventToStream(event) { | ||||
|     // @ts-expect-error - TS doesn't know about the detail property | ||||
|     const data = event.detail ?? {}; | ||||
|  | ||||
|     const eventContent = [`event: ${event.type}`, `data: ${JSON.stringify(data)}`]; | ||||
|  | ||||
|     return eventContent.join("\n") + "\n\n"; | ||||
| } | ||||
|  | ||||
| const MIN_PORT = 1025; | ||||
| const MAX_PORT = 65535; | ||||
|  | ||||
| /** | ||||
|  * Find a random port that is not in use, sufficiently far from the default port. | ||||
|  * @returns {Promise<number>} | ||||
|  */ | ||||
| async function findDisparatePort() { | ||||
|     const startPort = Math.floor(Math.random() * (MAX_PORT - MIN_PORT + 1)) + MIN_PORT; | ||||
|  | ||||
|     const wathcherPorts = await findFreePorts(1, { | ||||
|         startPort, | ||||
|     }); | ||||
|  | ||||
|     const [port] = wathcherPorts; | ||||
|  | ||||
|     if (!port) { | ||||
|         throw new Error("No free ports available"); | ||||
|     } | ||||
|  | ||||
|     return port; | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Event server initialization options. | ||||
|  * | ||||
|  * @typedef {Object} EventServerInit | ||||
|  * | ||||
|  * @property {string} pathname | ||||
|  * @property {EventTarget} dispatcher | ||||
|  * @property {string} [logPrefix] | ||||
|  * | ||||
|  * @category Server API | ||||
|  * @runtime node | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * @typedef {(req: http.IncomingMessage, res: http.ServerResponse) => void} RequestHandler | ||||
|  * | ||||
|  * @category Server API | ||||
|  * @runtime node | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Create an event request handler. | ||||
|  * | ||||
|  * @param {EventServerInit} options | ||||
|  * @returns {RequestHandler} | ||||
|  * | ||||
|  * @category Server API | ||||
|  * @runtime node | ||||
|  */ | ||||
| export function createRequestHandler({ pathname, dispatcher, logPrefix = "Build Observer" }) { | ||||
|     const log = console.log.bind(console, `[${logPrefix}]`); | ||||
|  | ||||
|     /** | ||||
|      * @type {RequestHandler} | ||||
|      */ | ||||
|     const requestHandler = (req, res) => { | ||||
|         res.setHeader("Access-Control-Allow-Origin", "*"); | ||||
|         res.setHeader("Access-Control-Allow-Methods", "GET"); | ||||
|         res.setHeader("Access-Control-Allow-Headers", "Content-Type"); | ||||
|  | ||||
|         if (req.url !== pathname) { | ||||
|             log(`🚫 Invalid request to ${req.url}`); | ||||
|             res.writeHead(404); | ||||
|             res.end(); | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|         log("🔌 Client connected"); | ||||
|  | ||||
|         res.writeHead(200, { | ||||
|             "Content-Type": "text/event-stream", | ||||
|             "Cache-Control": "no-cache", | ||||
|             "Connection": "keep-alive", | ||||
|         }); | ||||
|  | ||||
|         /** | ||||
|          * @param {Event} event | ||||
|          */ | ||||
|         const listener = (event) => { | ||||
|             const body = serializeCustomEventToStream(event); | ||||
|  | ||||
|             res.write(body); | ||||
|         }; | ||||
|  | ||||
|         dispatcher.addEventListener("esbuild:start", listener); | ||||
|         dispatcher.addEventListener("esbuild:error", listener); | ||||
|         dispatcher.addEventListener("esbuild:end", listener); | ||||
|  | ||||
|         req.on("close", () => { | ||||
|             log("🔌 Client disconnected"); | ||||
|  | ||||
|             clearInterval(keepAliveInterval); | ||||
|  | ||||
|             dispatcher.removeEventListener("esbuild:start", listener); | ||||
|             dispatcher.removeEventListener("esbuild:error", listener); | ||||
|             dispatcher.removeEventListener("esbuild:end", listener); | ||||
|         }); | ||||
|  | ||||
|         const keepAliveInterval = setInterval(() => { | ||||
|             console.timeStamp("🏓 Keep-alive"); | ||||
|  | ||||
|             res.write("event: keep-alive\n\n"); | ||||
|             res.write(serializeCustomEventToStream(new CustomEvent("esbuild:keep-alive"))); | ||||
|         }, 15_000); | ||||
|     }; | ||||
|  | ||||
|     return requestHandler; | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Options for the build observer plugin. | ||||
|  * | ||||
|  * @category Plugin API | ||||
|  * @runtime node | ||||
|  * | ||||
|  * @typedef {object} LiveReloadPluginOptions | ||||
|  * | ||||
|  * @property {HTTPServer | HTTPSServer} [server] A server to listen on. If not provided, a new server will be created. | ||||
|  * @property {ListenOptions} [listenOptions] Options for the server's listen method. | ||||
|  * @property {string | URL} [publicURL] A URL to listen on. If not provided, a random port will be used. | ||||
|  * @property {string} [logPrefix] A prefix to use for log messages. | ||||
|  * @property {string} [relativeRoot] A relative path to the root of the project. This is used to resolve build errors, line numbers, and file paths. | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Creates a plugin that listens for build events and sends them to a server-sent event stream. | ||||
|  * | ||||
|  * @param {LiveReloadPluginOptions} [options] | ||||
|  * @returns {import('esbuild').Plugin} | ||||
|  */ | ||||
| export function liveReloadPlugin(options = {}) { | ||||
|     return { | ||||
|         name: "build-watcher", | ||||
|         setup: async (build) => { | ||||
|             const logPrefix = options.logPrefix || "Build Observer"; | ||||
|  | ||||
|             const timerLabel = `[${logPrefix}] 🏁`; | ||||
|             const relativeRoot = options.relativeRoot || process.cwd(); | ||||
|  | ||||
|             const dispatcher = new EventTarget(); | ||||
|  | ||||
|             /** | ||||
|              * @type {URL} | ||||
|              */ | ||||
|             let publicURL; | ||||
|  | ||||
|             if (!options.publicURL) { | ||||
|                 const port = await findDisparatePort(); | ||||
|  | ||||
|                 publicURL = new URL(`http://localhost:${port}/events`); | ||||
|             } else { | ||||
|                 publicURL = | ||||
|                     typeof options.publicURL === "string" | ||||
|                         ? new URL(options.publicURL) | ||||
|                         : options.publicURL; | ||||
|             } | ||||
|  | ||||
|             build.initialOptions.define = { | ||||
|                 ...build.initialOptions.define, | ||||
|                 "import.meta.env.ESBUILD_WATCHER_URL": JSON.stringify(publicURL.href), | ||||
|             }; | ||||
|  | ||||
|             build.initialOptions.define["process.env.NODE_ENV"] ??= JSON.stringify( | ||||
|                 process.env.NODE_ENV || "development", | ||||
|             ); | ||||
|  | ||||
|             const requestHandler = createRequestHandler({ | ||||
|                 pathname: publicURL.pathname, | ||||
|                 dispatcher, | ||||
|                 logPrefix, | ||||
|             }); | ||||
|  | ||||
|             const server = options.server || http.createServer(requestHandler); | ||||
|  | ||||
|             const listenOptions = options.listenOptions || { | ||||
|                 port: parseInt(publicURL.port, 10), | ||||
|                 host: publicURL.hostname, | ||||
|             }; | ||||
|  | ||||
|             server.listen(listenOptions, () => { | ||||
|                 console.log(`[${logPrefix}] Listening`); | ||||
|             }); | ||||
|  | ||||
|             build.onDispose(() => { | ||||
|                 server?.close(); | ||||
|             }); | ||||
|  | ||||
|             build.onStart(() => { | ||||
|                 console.time(timerLabel); | ||||
|  | ||||
|                 dispatcher.dispatchEvent( | ||||
|                     new CustomEvent("esbuild:start", { | ||||
|                         detail: new Date().toISOString(), | ||||
|                     }), | ||||
|                 ); | ||||
|             }); | ||||
|  | ||||
|             build.onEnd((buildResult) => { | ||||
|                 console.timeEnd(timerLabel); | ||||
|  | ||||
|                 if (!buildResult.errors.length) { | ||||
|                     dispatcher.dispatchEvent( | ||||
|                         new CustomEvent("esbuild:end", { | ||||
|                             detail: new Date().toISOString(), | ||||
|                         }), | ||||
|                     ); | ||||
|  | ||||
|                     return; | ||||
|                 } | ||||
|  | ||||
|                 console.warn(`Build ended with ${buildResult.errors.length} errors`); | ||||
|  | ||||
|                 dispatcher.dispatchEvent( | ||||
|                     new CustomEvent("esbuild:error", { | ||||
|                         detail: buildResult.errors.map((error) => ({ | ||||
|                             ...error, | ||||
|                             location: error.location | ||||
|                                 ? { | ||||
|                                       ...error.location, | ||||
|                                       file: resolvePath(relativeRoot, error.location.file), | ||||
|                                   } | ||||
|                                 : null, | ||||
|                         })), | ||||
|                     }), | ||||
|                 ); | ||||
|             }); | ||||
|         }, | ||||
|     }; | ||||
| } | ||||
|  | ||||
| export default liveReloadPlugin; | ||||
| @ -1,14 +0,0 @@ | ||||
| { | ||||
|     "extends": "@goauthentik/tsconfig", | ||||
|     "compilerOptions": { | ||||
|         "lib": ["ESNext", "DOM", "DOM.Iterable"], | ||||
|         "resolveJsonModule": true, | ||||
|         "baseUrl": ".", | ||||
|         "checkJs": true, | ||||
|         "emitDeclarationOnly": true | ||||
|     }, | ||||
|     "exclude": [ | ||||
|         // --- | ||||
|         "**/out/**/*" | ||||
|     ] | ||||
| } | ||||
| @ -1,66 +0,0 @@ | ||||
| { | ||||
|     "$schema": "https://typedoc-plugin-markdown.org/schema.json", | ||||
|     "entryPoints": ["./plugin/index.js"], | ||||
|     "plugin": ["typedoc-plugin-markdown"], | ||||
|     "name": "ESBuild Plugin Live Reload", | ||||
|     "formatWithPrettier": true, | ||||
|     "prettierConfigFile": "@goauthentik/prettier-config", | ||||
|     "flattenOutputFiles": true, | ||||
|     "readme": ".github/README.md", | ||||
|     "mergeReadme": true, | ||||
|     "enumMembersFormat": "table", | ||||
|     "parametersFormat": "table", | ||||
|     "interfacePropertiesFormat": "table", | ||||
|     "typeDeclarationFormat": "table", | ||||
|     "indexFormat": "table", | ||||
|     "router": "module", | ||||
|     "jsDocCompatibility": true, | ||||
|     "defaultCategory": "Plugin API", | ||||
|     "disableSources": true, | ||||
|     "out": ".", | ||||
|     "cleanOutputDir": false, | ||||
|     "blockTags": [ | ||||
|         "@runtime", | ||||
|         "@file", | ||||
|         "@defaultValue", | ||||
|         "@deprecated", | ||||
|         "@example", | ||||
|         "@param", | ||||
|         "@privateRemarks", | ||||
|         "@remarks", | ||||
|         "@returns", | ||||
|         "@see", | ||||
|         "@throws", | ||||
|         "@typeParam", | ||||
|         "@author", | ||||
|         "@callback", | ||||
|         "@category", | ||||
|         "@categoryDescription", | ||||
|         "@default", | ||||
|         "@document", | ||||
|         "@extends", | ||||
|         "@augments", | ||||
|         "@yields", | ||||
|         "@group", | ||||
|         "@groupDescription", | ||||
|         "@import", | ||||
|         "@inheritDoc", | ||||
|         "@jsx", | ||||
|         "@license", | ||||
|         "@module", | ||||
|         "@mergeModuleWith", | ||||
|         "@prop", | ||||
|         "@property", | ||||
|         "@return", | ||||
|         "@satisfies", | ||||
|         "@since", | ||||
|         "@template", | ||||
|         "@type", | ||||
|         "@typedef", | ||||
|         "@summary", | ||||
|         "@preventInline", | ||||
|         "@inlineType", | ||||
|         "@preventExpand", | ||||
|         "@expandType" | ||||
|     ] | ||||
| } | ||||
		Reference in New Issue
	
	Block a user
	 Teffen Ellis
					Teffen Ellis