95 lines
2.0 KiB
JavaScript
95 lines
2.0 KiB
JavaScript
|
import path from 'path';
|
||
|
import { fileURLToPath } from 'url';
|
||
|
|
||
|
import { defineConfig, squooshImageService } from 'astro/config';
|
||
|
|
||
|
import sitemap from '@astrojs/sitemap';
|
||
|
import tailwind from '@astrojs/tailwind';
|
||
|
import mdx from '@astrojs/mdx';
|
||
|
import partytown from '@astrojs/partytown';
|
||
|
import icon from 'astro-icon';
|
||
|
import compress from '@playform/compress';
|
||
|
|
||
|
import astrowind from './vendor/integration';
|
||
|
|
||
|
import {
|
||
|
readingTimeRemarkPlugin,
|
||
|
responsiveTablesRehypePlugin,
|
||
|
lazyImagesRehypePlugin,
|
||
|
} from './src/utils/frontmatter.mjs';
|
||
|
|
||
|
const __dirname = path.dirname(fileURLToPath(import.meta.url));
|
||
|
|
||
|
const hasExternalScripts = false;
|
||
|
const whenExternalScripts = (items = []) =>
|
||
|
hasExternalScripts ? (Array.isArray(items) ? items.map((item) => item()) : [items()]) : [];
|
||
|
|
||
|
export default defineConfig({
|
||
|
output: 'static',
|
||
|
|
||
|
integrations: [
|
||
|
tailwind({
|
||
|
applyBaseStyles: false,
|
||
|
}),
|
||
|
sitemap(),
|
||
|
mdx(),
|
||
|
icon({
|
||
|
include: {
|
||
|
tabler: ['*'],
|
||
|
'flat-color-icons': [
|
||
|
'template',
|
||
|
'gallery',
|
||
|
'approval',
|
||
|
'document',
|
||
|
'advertising',
|
||
|
'currency-exchange',
|
||
|
'voice-presentation',
|
||
|
'business-contact',
|
||
|
'database',
|
||
|
],
|
||
|
},
|
||
|
}),
|
||
|
|
||
|
...whenExternalScripts(() =>
|
||
|
partytown({
|
||
|
config: { forward: ['dataLayer.push'] },
|
||
|
})
|
||
|
),
|
||
|
|
||
|
compress({
|
||
|
CSS: true,
|
||
|
HTML: {
|
||
|
'html-minifier-terser': {
|
||
|
removeAttributeQuotes: false,
|
||
|
},
|
||
|
},
|
||
|
Image: false,
|
||
|
JavaScript: true,
|
||
|
SVG: false,
|
||
|
Logger: 1,
|
||
|
}),
|
||
|
|
||
|
astrowind({
|
||
|
config: './src/config.yaml',
|
||
|
}),
|
||
|
],
|
||
|
|
||
|
image: {
|
||
|
service: squooshImageService(),
|
||
|
domains: ['cdn.pixabay.com'],
|
||
|
},
|
||
|
|
||
|
markdown: {
|
||
|
remarkPlugins: [readingTimeRemarkPlugin],
|
||
|
rehypePlugins: [responsiveTablesRehypePlugin, lazyImagesRehypePlugin],
|
||
|
},
|
||
|
|
||
|
vite: {
|
||
|
resolve: {
|
||
|
alias: {
|
||
|
'~': path.resolve(__dirname, './src'),
|
||
|
},
|
||
|
},
|
||
|
},
|
||
|
});
|