definePlugin
Allows defining a type-safe plugin that can be used in defineIntegration
.
import { definePlugin } from "../core/define-plugin.js";import { addVitePlugin } from "../utilities/add-vite-plugin.js";import type { Plugin as VitePlugin } from "vite"
export const addVitePluginPlugin = definePlugin({ name: "addVitePlugin", hook: "astro:config:setup", implementation: ({ updateConfig }) => (plugin: VitePlugin) => addVitePlugin({ plugin, updateConfig }),});
You can then use it in defineIntegration
:
import { defineIntegration } from "astro-integration-kit";import { addVitePluginPlugin } from "../package/plugins/add-vite-plugin.js";
export default defineIntegration({ name: "my-integration", plugins: [addVitePluginPlugin], setup() { return { "astro:config:setup": ({ addVitePlugin }) => {} } }})
Limitations
- A plugin only defines a utility that will be injected for a given hook
- A plugin can only use the built-in utilities (ie. the ones from the official Integration API)
- Plugins support overrides. That means that if 2 plugins declare the same
name
andhook
, the latest will be kept.
Practical examples
Astro Integration Kit uses definePlugin
for its core plugins under the hood,
have a look at our source for practical examples!
Authoring a plugin (soon) Learn how to write an Astro Integration Kit plugin the right way.