Compare commits
No commits in common. "09d05f53da24117971d5e2da305a0ee20ed874b6" and "544a74a34007ea47e8e4109d7adc812dba55817e" have entirely different histories.
09d05f53da
...
544a74a340
1 changed files with 1 additions and 29 deletions
|
|
@ -2,39 +2,11 @@ import { defineConfig } from 'vite'
|
||||||
import { svelte } from '@sveltejs/vite-plugin-svelte'
|
import { svelte } from '@sveltejs/vite-plugin-svelte'
|
||||||
import path from 'path'
|
import path from 'path'
|
||||||
|
|
||||||
/**
|
|
||||||
* Plugin: les fonts restent dans assets/fonts/, sans duplication dans dist/.
|
|
||||||
* Vite les copie dans dist/ pendant le build — ce plugin les supprime du bundle
|
|
||||||
* et réécrit leurs URLs dans le CSS pour pointer vers /assets/fonts/.
|
|
||||||
*/
|
|
||||||
function keepFontsInPlace() {
|
|
||||||
const fontRe = /\.(woff2?|ttf|otf)$/i
|
|
||||||
return {
|
|
||||||
name: 'keep-fonts-in-place',
|
|
||||||
generateBundle(_, bundle) {
|
|
||||||
for (const [key, chunk] of Object.entries(bundle)) {
|
|
||||||
if (fontRe.test(key)) {
|
|
||||||
delete bundle[key]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
for (const chunk of Object.values(bundle)) {
|
|
||||||
if (chunk.type === 'asset' && chunk.fileName.endsWith('.css')) {
|
|
||||||
chunk.source = chunk.source.replace(
|
|
||||||
/url\((['"]?)([^'")\s]*\.(woff2?|ttf|otf))\1\)/gi,
|
|
||||||
(_, _q, p) => `url("/assets/fonts/${p.split('/').pop()}")`
|
|
||||||
)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
export default defineConfig({
|
export default defineConfig({
|
||||||
plugins: [
|
plugins: [
|
||||||
svelte({
|
svelte({
|
||||||
configFile: './svelte.config.js'
|
configFile: './svelte.config.js'
|
||||||
}),
|
})
|
||||||
keepFontsInPlace(),
|
|
||||||
],
|
],
|
||||||
resolve: {
|
resolve: {
|
||||||
alias: {
|
alias: {
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue