import { defineConfig } from 'vite' import { nodePolyfills } from 'vite-plugin-node-polyfills' import react from '@vitejs/plugin-react' /* If you are developing a UI outside of a Kinode project, comment out the following 2 lines: */ import manifest from '../pkg/manifest.json' import metadata from '../metadata.json' /* IMPORTANT: This must match the process name from pkg/manifest.json + pkg/metadata.json The format is "/" + "process_name:package_name:publisher_node" */ const BASE_URL = `/main:app_store:sys`; // This is the proxy URL, it must match the node you are developing against const PROXY_URL = (process.env.VITE_NODE_URL || 'http://127.0.0.1:8080').replace('localhost', '127.0.0.1'); console.log('process.env.VITE_NODE_URL', process.env.VITE_NODE_URL, PROXY_URL); export default defineConfig({ plugins: [ nodePolyfills({ globals: { Buffer: true, } }), react(), ], base: BASE_URL, build: { rollupOptions: { external: ['/our.js'] } }, server: { open: true, proxy: { [`^${BASE_URL}/our.js`]: { target: PROXY_URL, changeOrigin: true, rewrite: (path) => { console.log('Proxying jsrequest:', path); return '/our.js'; }, }, // [`^${BASE_URL}/kinode.css`]: { // target: PROXY_URL, // changeOrigin: true, // rewrite: (path) => { // console.log('Proxying csrequest:', path); // return '/kinode.css'; // }, // }, // This route will match all other HTTP requests to the backend [`^${BASE_URL}/(?!(@vite/client|src/.*|kinode.css|node_modules/.*|@react-refresh|$))`]: { target: PROXY_URL, changeOrigin: true, }, }, }, });