import path from 'path'; import { fileURLToPath } from 'url'; import node from '@astrojs/node' import tailwind from '@astrojs/tailwind' 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: 'server', compressHTML: true, build: { assets: 'assets', inlineStylesheets: 'auto' }, server: { host: true, port: 3000 }, trailingSlash: 'never', adapter: node({ mode: 'standalone' }), 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: { include: ['leaflet'] }, resolve: { alias: { '~': path.resolve(__dirname, './src'), }, }, }, });