2024-05-21 10:07:56 +02:00
|
|
|
import path from 'path';
|
|
|
|
import { fileURLToPath } from 'url';
|
2024-05-20 12:48:34 +02:00
|
|
|
import node from '@astrojs/node'
|
|
|
|
import tailwind from '@astrojs/tailwind'
|
2024-05-21 10:07:56 +02:00
|
|
|
import { defineConfig, squooshImageService } from 'astro/config';
|
2024-04-25 10:40:39 +02:00
|
|
|
|
2024-05-21 10:07:56 +02:00
|
|
|
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()]) : [];
|
2024-04-20 10:48:50 +02:00
|
|
|
|
|
|
|
export default defineConfig({
|
2024-05-21 10:07:56 +02:00
|
|
|
|
|
|
|
compressHTML: true,
|
2024-05-20 12:48:34 +02:00
|
|
|
build: {
|
|
|
|
assets: 'assets',
|
|
|
|
inlineStylesheets: 'auto'
|
|
|
|
},
|
|
|
|
server: {
|
|
|
|
host: true,
|
|
|
|
port: 3000
|
|
|
|
},
|
|
|
|
trailingSlash: 'never',
|
|
|
|
output: 'server',
|
|
|
|
adapter: node({
|
|
|
|
mode: 'standalone'
|
|
|
|
}),
|
2024-05-21 10:07:56 +02:00
|
|
|
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'] },
|
|
|
|
})
|
|
|
|
),
|
|
|
|
|
|
|
|
astrowind({
|
|
|
|
config: './src/config.yaml',
|
|
|
|
}),
|
|
|
|
],
|
|
|
|
|
|
|
|
image: {
|
|
|
|
service: squooshImageService(),
|
|
|
|
domains: ['cdn.pixabay.com'],
|
|
|
|
},
|
|
|
|
|
|
|
|
markdown: {
|
|
|
|
remarkPlugins: [readingTimeRemarkPlugin],
|
|
|
|
rehypePlugins: [responsiveTablesRehypePlugin, lazyImagesRehypePlugin],
|
|
|
|
},
|
|
|
|
|
|
|
|
vite: {
|
|
|
|
optimizeDeps: {
|
2024-05-20 12:48:34 +02:00
|
|
|
include: ['leaflet']
|
2024-05-21 10:07:56 +02:00
|
|
|
},
|
|
|
|
resolve: {
|
|
|
|
alias: {
|
|
|
|
'~': path.resolve(__dirname, './src'),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
});
|