mirror of
https://github.com/go-gitea/gitea.git
synced 2026-04-01 05:12:13 +00:00
Replace webpack with Vite 8 as the frontend bundler. Frontend build is around 3-4 times faster than before. Will work on all platforms including riscv64 (via wasm). `iife.js` is a classic render-blocking script in `<head>` (handles web components/early DOM setup). `index.js` is loaded as a `type="module"` script in the footer. All other JS chunks are also module scripts (supported in all browsers since 2018). Entry filenames are content-hashed (e.g. `index.C6Z2MRVQ.js`) and resolved at runtime via the Vite manifest, eliminating the `?v=` cache busting (which was unreliable in some scenarios like vscode dev build). Replaces: https://github.com/go-gitea/gitea/pull/36896 Fixes: https://github.com/go-gitea/gitea/issues/17793 Signed-off-by: silverwind <me@silverwind.io> Signed-off-by: wxiaoguang <wxiaoguang@gmail.com> Co-authored-by: Claude (Opus 4.6) <noreply@anthropic.com> Co-authored-by: Lunny Xiao <xiaolunwen@gmail.com> Co-authored-by: wxiaoguang <wxiaoguang@gmail.com>
49 lines
1.6 KiB
TypeScript
49 lines
1.6 KiB
TypeScript
import '../../css/standalone/swagger.css';
|
|
import SwaggerUI from 'swagger-ui-dist/swagger-ui-es-bundle.js';
|
|
import 'swagger-ui-dist/swagger-ui.css';
|
|
import {load as loadYaml} from 'js-yaml';
|
|
|
|
const prefersDark = window.matchMedia('(prefers-color-scheme: dark)');
|
|
const apply = () => document.documentElement.classList.toggle('dark-mode', prefersDark.matches);
|
|
apply();
|
|
prefersDark.addEventListener('change', apply);
|
|
|
|
window.addEventListener('load', async () => {
|
|
const elSwaggerUi = document.querySelector('#swagger-ui')!;
|
|
const url = elSwaggerUi.getAttribute('data-source')!;
|
|
let spec: any;
|
|
if (url) {
|
|
const res = await fetch(url); // eslint-disable-line no-restricted-globals
|
|
spec = await res.json();
|
|
} else {
|
|
const elSpecContent = elSwaggerUi.querySelector<HTMLTextAreaElement>('.swagger-spec-content')!;
|
|
const filename = elSpecContent.getAttribute('data-spec-filename');
|
|
const isJson = filename?.toLowerCase().endsWith('.json');
|
|
spec = isJson ? JSON.parse(elSpecContent.value) : loadYaml(elSpecContent.value);
|
|
}
|
|
|
|
// Make the page's protocol be at the top of the schemes list
|
|
const proto = window.location.protocol.slice(0, -1);
|
|
if (spec?.schemes) {
|
|
spec.schemes.sort((a: string, b: string) => {
|
|
if (a === proto) return -1;
|
|
if (b === proto) return 1;
|
|
return 0;
|
|
});
|
|
}
|
|
|
|
SwaggerUI({
|
|
spec,
|
|
dom_id: '#swagger-ui',
|
|
deepLinking: true,
|
|
docExpansion: 'none',
|
|
defaultModelRendering: 'model', // don't show examples by default, because they may be incomplete
|
|
presets: [
|
|
SwaggerUI.presets.apis,
|
|
],
|
|
plugins: [
|
|
SwaggerUI.plugins.DownloadUrl,
|
|
],
|
|
});
|
|
});
|