@nuxt/ui
Version:
A UI Library for Modern Web Apps, powered by Vue & Tailwind CSS.
140 lines (136 loc) • 4.79 kB
JavaScript
import { defu } from 'defu';
import { defineNuxtModule, createResolver, addPlugin, hasNuxtModule, addComponentsDir, addImportsDir, installModule } from '@nuxt/kit';
import { d as defaultOptions, r as resolveColors, a as getDefaultConfig, b as addTemplates } from './shared/ui.DegC4tw1.mjs';
import '../dist/runtime/utils/index.js';
import 'node:url';
import 'scule';
import 'knitwork';
import 'tailwindcss/colors';
import 'node:fs/promises';
import 'pathe';
import 'tinyglobby';
const name = "@nuxt/ui";
const version = "4.3.0";
const module = defineNuxtModule({
meta: {
name,
version,
docs: "https://ui.nuxt.com/docs/getting-started/installation/nuxt",
configKey: "ui",
compatibility: {
nuxt: ">=4.0.0"
}
},
defaults: defaultOptions,
async setup(options, nuxt) {
const { resolve } = createResolver(import.meta.url);
options.theme = options.theme || {};
options.theme.colors = resolveColors(options.theme.colors);
nuxt.options.ui = options;
nuxt.options.alias["#ui"] = resolve("./runtime");
nuxt.options.appConfig.ui = defu(nuxt.options.appConfig.ui || {}, getDefaultConfig(options.theme));
nuxt.options.app.rootAttrs = nuxt.options.app.rootAttrs || {};
nuxt.options.app.rootAttrs.class = [nuxt.options.app.rootAttrs.class, `${options.theme?.prefix ? options.theme.prefix + ":" : ""}isolate`].filter(Boolean).join(" ");
nuxt.hook("vite:extend", async ({ config }) => {
const plugin = await import('@tailwindcss/vite').then((r) => r.default);
config.plugins ||= [];
config.plugins.push(plugin());
});
if (nuxt.options.builder !== "@nuxt/vite-builder") {
nuxt.options.postcss.plugins["@tailwindcss/postcss"] = {};
}
async function registerModule(name2, key, options2) {
if (!hasNuxtModule(name2)) {
await installModule(name2, defu(nuxt.options[key], options2));
} else {
nuxt.options[key] = defu(nuxt.options[key], options2);
}
}
await registerModule("@nuxt/icon", "icon", {
cssLayer: "components"
});
if (options.fonts) {
await registerModule("@nuxt/fonts", "fonts", {
defaults: {
weights: [400, 500, 600, 700]
}
});
}
if (options.colorMode) {
await registerModule("@nuxtjs/color-mode", "colorMode", {
classSuffix: "",
disableTransition: true
});
}
addPlugin({ src: resolve("./runtime/plugins/colors") });
if (hasNuxtModule("@nuxtjs/mdc") || options.mdc || (hasNuxtModule("@nuxt/content") || options.content)) {
nuxt.options.mdc = defu(nuxt.options.mdc, {
highlight: {
theme: {
light: "material-theme-lighter",
default: "material-theme",
dark: "material-theme-palenight"
}
},
components: {
map: {
"accordion": "ProseAccordion",
"accordion-item": "ProseAccordionItem",
"badge": "ProseBadge",
"callout": "ProseCallout",
"card": "ProseCard",
"card-group": "ProseCardGroup",
"caution": "ProseCaution",
"code-collapse": "ProseCodeCollapse",
"code-group": "ProseCodeGroup",
"code-icon": "ProseCodeIcon",
"code-preview": "ProseCodePreview",
"code-tree": "ProseCodeTree",
"collapsible": "ProseCollapsible",
"field": "ProseField",
"field-group": "ProseFieldGroup",
"icon": "ProseIcon",
"kbd": "ProseKbd",
"note": "ProseNote",
"steps": "ProseSteps",
"tabs": "ProseTabs",
"tabs-item": "ProseTabsItem",
"tip": "ProseTip",
"warning": "ProseWarning"
}
}
});
addComponentsDir({
path: resolve("./runtime/components/prose"),
pathPrefix: false,
prefix: "Prose",
global: true
});
}
if (hasNuxtModule("@nuxt/content") || options.content) {
addComponentsDir({
path: resolve("./runtime/components/content"),
pathPrefix: false,
prefix: options.prefix
});
}
if (hasNuxtModule("@nuxtjs/color-mode")) {
addComponentsDir({
path: resolve("./runtime/components/color-mode"),
pathPrefix: false,
prefix: options.prefix
});
} else {
addImportsDir(resolve("./runtime/composables/color-mode"));
}
addComponentsDir({
path: resolve("./runtime/components"),
pathPrefix: false,
prefix: options.prefix,
ignore: ["color-mode/**", "content/**", "prose/**"]
});
addImportsDir(resolve("./runtime/composables"));
addTemplates(options, nuxt, resolve);
}
});
export { module as default };