HEX
Server: nginx/1.18.0
System: Linux test-ipsremont 5.4.0-214-generic #234-Ubuntu SMP Fri Mar 14 23:50:27 UTC 2025 x86_64
User: ips (1000)
PHP: 8.0.30
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: /var/www/todo_landing/node_modules/@sveltejs/vite-plugin-svelte/src/plugins/load-custom.js
import fs from 'node:fs';
import { log } from '../utils/log.js';

/**
 * if svelte config includes files that vite treats as assets (e.g. .svg)
 * we have to manually load them to avoid getting urls
 *
 * @param {import('../types/plugin-api.d.ts').PluginAPI} api
 * @returns {import('vite').Plugin}
 */
export function loadCustom(api) {
	/** @type {import('vite').Plugin} */
	const plugin = {
		name: 'vite-plugin-svelte:load-custom',
		enforce: 'pre', // must come before vites own asset handling or custom extensions like .svg won't work
		configResolved() {
			//@ts-expect-error load defined below but filter not in type
			plugin.load.filter = api.filter;
		},

		load: {
			//filter: is set in configResolved
			async handler(id) {
				const config = this.environment.config;
				const ssr = config.consumer === 'server';
				const svelteRequest = api.idParser(id, ssr);
				if (svelteRequest) {
					const { filename, query } = svelteRequest;
					if (!query.url && config.assetsInclude(filename)) {
						log.debug(
							`loading ${filename} to prevent vite asset handling to turn it into a url by default`,
							undefined,
							'load'
						);
						return fs.readFileSync(filename, 'utf-8');
					}
				}
			}
		}
	};
	return plugin;
}