import { sveltekit } from '@sveltejs/kit/vite'; import { defineConfig } from 'vite'; // import { visualizer } from 'rollup-plugin-visualizer'; import * as fs from 'fs'; import * as path from 'path'; const doRewrap = ({ cssClass }) => { try { if (fs.existsSync(path.resolve(__dirname, 'dist/bundle.js'))) { return; } } catch { // do nothing } console.log('\nStart re-wrapping...'); fs.readFile(path.resolve(__dirname, 'dist/bundle.html'), 'utf8', function (err, data) { if (!data) { console.log( `[Error]: No bundle.html generated, check svelte.config.js -> config.kit.adapter -> fallback: "bundle.html"` ); return; } const matchData = data.match(/(?<=]*>)([\s\S]*?)(?=<\/script>)/gm); if (matchData) { const cleanData = matchData[0] .trim() .replace( `document.querySelector('[data-sveltekit-hydrate="45h"]').parentNode`, `document.querySelector(".${cssClass}")` ); fs.writeFile(path.resolve(__dirname, 'dist/bundle.js'), cleanData, (err) => { if (err) console.log(err); else { try { fs.rename( path.resolve(__dirname, 'dist/index.page'), path.resolve(__dirname, 'dist/index.html'), () => {} ); } catch { // do nothing } try { fs.unlinkSync(path.resolve(__dirname, 'dist/bundle.html')); } catch { // do nothing } console.log('Finished: bundle.js + index.html have been regenerated.\n'); } }); } else console.log(`[Error]: No proper