diff options
author | 2022-03-18 15:35:45 -0700 | |
---|---|---|
committer | 2022-03-18 15:35:45 -0700 | |
commit | 6386c14d00d1d820804f0ee5b1424e73c049fe83 (patch) | |
tree | 3015e834e1d84100fd0871f6a55479bed61c0c14 /packages/integrations/tailwind/src | |
parent | 0f376a7c52d3a22ff32b33e0afc34dd306ed70c4 (diff) | |
download | astro-6386c14d00d1d820804f0ee5b1424e73c049fe83.tar.gz astro-6386c14d00d1d820804f0ee5b1424e73c049fe83.tar.zst astro-6386c14d00d1d820804f0ee5b1424e73c049fe83.zip |
Astro Integration System (#2820)
* update examples
* add initial integrations
* update tests
* update astro
* update ci
* get final tests working
* update injectelement todo
* update ben code review
* respond to final code review feedback
Diffstat (limited to 'packages/integrations/tailwind/src')
-rw-r--r-- | packages/integrations/tailwind/src/index.ts | 31 |
1 files changed, 31 insertions, 0 deletions
diff --git a/packages/integrations/tailwind/src/index.ts b/packages/integrations/tailwind/src/index.ts new file mode 100644 index 000000000..30905f9d1 --- /dev/null +++ b/packages/integrations/tailwind/src/index.ts @@ -0,0 +1,31 @@ +import type { AstroIntegration } from 'astro'; +import { fileURLToPath } from 'url'; +import path from 'path'; +import tailwindPlugin from 'tailwindcss'; +import autoprefixerPlugin from 'autoprefixer'; + +function getDefaultTailwindConfig(srcUrl: URL) { + return { + theme: { + extend: {}, + }, + plugins: [], + content: [path.join(fileURLToPath(srcUrl), `**`, `*.{astro,html,js,jsx,svelte,ts,tsx,vue}`)], + }; +} + +export default function (): AstroIntegration { + return { + name: '@astrojs/tailwind', + hooks: { + 'astro:config:setup': ({ config, injectScript }) => { + // Inject the Tailwind postcss plugin + config.styleOptions.postcss.plugins.push(tailwindPlugin(getDefaultTailwindConfig(config.src))); + config.styleOptions.postcss.plugins.push(autoprefixerPlugin); + + // Inject the Tailwind base import + injectScript('page-ssr', `import '@astrojs/tailwind/base.css';`); + }, + }, + }; +} |