-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathastro.config.ts
More file actions
64 lines (62 loc) · 1.74 KB
/
astro.config.ts
File metadata and controls
64 lines (62 loc) · 1.74 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
import sitemap from '@astrojs/sitemap'
import solidJs from '@astrojs/solid-js'
import tailwind from '@astrojs/tailwind'
import { defineConfig } from 'astro/config'
import { passthroughImageService } from 'astro/config'
import { imagetools } from 'vite-imagetools'
import cloudflare from './src/integrations/cloudflare'
import qwikdev from '@qwikdev/astro'
import type { AstroIntegration } from 'astro'
import macros from 'unplugin-parcel-macros'
// https://astro.build/config
export default defineConfig({
output: 'server',
site: 'https://nanoha.pages.dev',
adapter: cloudflare(),
integrations: [
solidJs({
exclude: '**/*.qwik.tsx',
}),
qwikdev({
include: '**/*.qwik.tsx',
}),
tailwind() as AstroIntegration,
sitemap(),
],
image: {
service: passthroughImageService(),
},
vite: {
plugins: [
macros.vite(),
imagetools({
exclude: [/\?opt$/],
}),
{
name: 'image-optimize',
enforce: 'pre',
load(id, options) {
if (id.endsWith('.svg?opt')) {
return {
code: `import target from '${id.replace(/\?opt$/, '')}?raw';export default { type: 'svg', svg: target }`,
}
}
if (id.endsWith('?opt')) {
const widths = [200, 400, 600, 800, 1200]
let code = `const result = { type: 'webp', sizes: {} }`
for (const width of widths) {
code += `
import image${width} from '${id.replace(/\?opt$/, '')}?w=${width}&format=webp';
result.sizes[${width}] = image${width};
`
}
code += 'export default result'
return {
code,
}
}
},
},
],
},
})