mirror of
https://github.com/MHSanaei/3x-ui.git
synced 2026-05-13 17:46:02 +00:00
The fifth and last legacy page comes online. Tabs are scaffolded with a-empty placeholders for the structured editors (Basics / Routing / Outbounds / Balancers / DNS) so navigation is stable; the Advanced (JSON) tab is fully functional and lets power users edit the raw xraySetting tree exactly like the legacy CodeMirror pane. - xray.html + src/xray.js: fifth Vite multi-page entry, mounted as XrayPage; vite.config.js routes /panel/xray and /panel/xray/ to it through the dev proxy bypass alongside the other pages. - XrayPage.vue: page chrome with the Save / Restart-xray bar, restart- output popover (surfaces /panel/xray/getXrayResult content when startup fails), 6 a-tabs, and a textarea-backed Advanced JSON editor. CodeMirror is intentionally not pulled in — the textarea works for every modern browser and keeps the bundle slim while structured editors land in 6-ii through 6-v. - useXraySetting.js composable: POST /panel/xray/ on mount, mirrors the settings-page 1s busy-loop dirty check for both xraySetting and outboundTestUrl, and exposes saveAll + restartXray. The dirty flag relies on string equality of the pretty-printed JSON, so reformat-only edits don't enable Save. Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
92 lines
3.1 KiB
JavaScript
92 lines
3.1 KiB
JavaScript
import { defineConfig } from 'vite';
|
|
import vue from '@vitejs/plugin-vue';
|
|
import path from 'node:path';
|
|
|
|
// Output goes to web/dist/ at the repo root so the Go binary can embed it
|
|
// via embed.FS without reaching outside the web/ tree.
|
|
const outDir = path.resolve(__dirname, '../web/dist');
|
|
|
|
// In production the Go binary serves /panel/<route> from web/dist/<route>.html.
|
|
// In dev the Vue app lives at /index.html, /settings.html, ... while AppSidebar
|
|
// links use the production-style /panel/<route> URLs. Map each migrated route
|
|
// to its Vite entry so the sidebar works without relying on the Go backend
|
|
// for already-ported pages. Unmigrated routes (inbounds, xray) fall through
|
|
// to the proxy.
|
|
const MIGRATED_ROUTES = {
|
|
'/panel': '/index.html',
|
|
'/panel/': '/index.html',
|
|
'/panel/settings': '/settings.html',
|
|
'/panel/settings/': '/settings.html',
|
|
'/panel/inbounds': '/inbounds.html',
|
|
'/panel/inbounds/': '/inbounds.html',
|
|
'/panel/xray': '/xray.html',
|
|
'/panel/xray/': '/xray.html',
|
|
};
|
|
|
|
// Build a proxy config that suppresses ECONNREFUSED noise when the Go
|
|
// backend isn't running locally. Real errors (timeouts, 5xx, etc.) still
|
|
// surface in the Vite log.
|
|
function makeBackendProxy(target, patterns) {
|
|
const config = {};
|
|
for (const pattern of patterns) {
|
|
config[pattern] = {
|
|
target,
|
|
changeOrigin: true,
|
|
// Returning a path from bypass tells Vite to serve that file from
|
|
// its own dev server instead of forwarding the request — used here
|
|
// to short-circuit /panel/<route> for pages we've already migrated.
|
|
bypass(req) {
|
|
const url = req.url.split('?')[0];
|
|
if (Object.prototype.hasOwnProperty.call(MIGRATED_ROUTES, url)) {
|
|
return MIGRATED_ROUTES[url];
|
|
}
|
|
return undefined;
|
|
},
|
|
configure(proxy) {
|
|
proxy.on('error', (err) => {
|
|
if (err.code === 'ECONNREFUSED') return;
|
|
// eslint-disable-next-line no-console
|
|
console.error('[proxy]', err);
|
|
});
|
|
},
|
|
};
|
|
}
|
|
return config;
|
|
}
|
|
|
|
export default defineConfig({
|
|
plugins: [vue()],
|
|
resolve: {
|
|
alias: {
|
|
'@': path.resolve(__dirname, 'src'),
|
|
},
|
|
},
|
|
build: {
|
|
outDir,
|
|
emptyOutDir: true,
|
|
sourcemap: true,
|
|
target: 'es2020',
|
|
// Multiple HTML entries — one per legacy page we migrate.
|
|
// As pages get ported in later phases, add their entrypoints here.
|
|
rollupOptions: {
|
|
input: {
|
|
index: path.resolve(__dirname, 'index.html'),
|
|
login: path.resolve(__dirname, 'login.html'),
|
|
settings: path.resolve(__dirname, 'settings.html'),
|
|
inbounds: path.resolve(__dirname, 'inbounds.html'),
|
|
xray: path.resolve(__dirname, 'xray.html'),
|
|
},
|
|
},
|
|
},
|
|
server: {
|
|
port: 5173,
|
|
strictPort: true,
|
|
proxy: makeBackendProxy('http://localhost:2053', [
|
|
// Patterns are anchored regex so /login.html and /index.html
|
|
// (which Vite serves itself) are NOT forwarded — only the bare
|
|
// backend paths and their sub-routes.
|
|
'^/(login|logout|getTwoFactorEnable)$',
|
|
'^/(panel|server)(/|$)',
|
|
]),
|
|
},
|
|
});
|