-
Notifications
You must be signed in to change notification settings - Fork 1
/
astro.config.mjs
74 lines (73 loc) · 1.95 KB
/
astro.config.mjs
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
65
66
67
68
69
70
71
72
73
74
import path from 'path';
import { fileURLToPath } from 'url';
import { defineConfig } from 'astro/config';
import tailwind from '@astrojs/tailwind';
import sitemap from '@astrojs/sitemap';
import image from '@astrojs/image';
import mdx from '@astrojs/mdx';
import partytown from '@astrojs/partytown';
import compress from 'astro-compress';
import { readingTimeRemarkPlugin } from './src/utils/frontmatter.mjs';
import { SITE } from './src/config/site/config.js';
import react from '@astrojs/react';
import icon from 'astro-icon';
const __dirname = path.dirname(fileURLToPath(import.meta.url));
const whenExternalScripts = (items = []) =>
SITE.googleAnalyticsId ? (Array.isArray(items) ? items.map((item) => item()) : [items()]) : [];
// https://astro.build/config
export default defineConfig({
site: SITE.origin,
base: SITE.basePathname,
trailingSlash: SITE.trailingSlash ? 'always' : 'never',
output: 'static',
markdown: {
remarkPlugins: [readingTimeRemarkPlugin],
},
integrations: [
icon({
include: {
mdi: ['*'], // Loads entire Material Design Icon set
tabler: ['*'], // Loads entire Tabler Icon set
'flat-color-icons': ['*'], // Loads entire Flat Color Icon set
'icon-park': ['*'], // Loads entire Icon Park Icon set
ri: ['*'], // Loads entire Remix Icon set
},
}),
tailwind({
config: {
applyBaseStyles: false,
},
}),
sitemap(),
image({
cacheDir: './.cache/image',
serviceEntryPoint: '@astrojs/image/sharp',
}),
mdx(),
...whenExternalScripts(() =>
partytown({
config: {
forward: ['dataLayer.push'],
},
})
),
compress({
css: true,
html: {
removeAttributeQuotes: false,
},
img: false,
js: true,
svg: true,
logger: 1,
}),
react(),
],
vite: {
resolve: {
alias: {
'~': path.resolve(__dirname, './src'),
},
},
},
});