@yh-ui/nuxt 1.0.25 → 1.0.30
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/module.cjs +103 -6
- package/dist/module.d.cts +5 -3
- package/dist/module.d.mts +5 -3
- package/dist/module.d.ts +5 -3
- package/dist/module.mjs +103 -6
- package/package.json +13 -11
- package/LICENSE +0 -21
package/dist/module.cjs
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
3
|
const crypto = require('node:crypto');
|
|
4
|
+
const node_module = require('node:module');
|
|
4
5
|
const kit = require('@nuxt/kit');
|
|
5
6
|
|
|
6
7
|
var _documentCurrentScript = typeof document !== 'undefined' ? document.currentScript : null;
|
|
@@ -14,6 +15,33 @@ if (typeof crypto__default.hash !== "function") {
|
|
|
14
15
|
};
|
|
15
16
|
}
|
|
16
17
|
const PUBLISHED_CSS_ENTRY = "@yh-ui/components/style.css";
|
|
18
|
+
function getStylePathForComponent(componentName) {
|
|
19
|
+
const name = componentName.replace(/^Yh/, "");
|
|
20
|
+
const subComponentMap = {
|
|
21
|
+
Option: "select",
|
|
22
|
+
BreadcrumbItem: "breadcrumb",
|
|
23
|
+
DropdownItem: "dropdown",
|
|
24
|
+
DropdownMenu: "dropdown",
|
|
25
|
+
FormItem: "form",
|
|
26
|
+
FormSchema: "form",
|
|
27
|
+
GridItem: "grid",
|
|
28
|
+
Step: "steps",
|
|
29
|
+
TableColumn: "table",
|
|
30
|
+
TabPane: "tabs",
|
|
31
|
+
TreeNode: "tree",
|
|
32
|
+
CarouselItem: "carousel",
|
|
33
|
+
Header: "container",
|
|
34
|
+
Aside: "container",
|
|
35
|
+
Main: "container",
|
|
36
|
+
Footer: "container"
|
|
37
|
+
};
|
|
38
|
+
if (name.startsWith("Typography") && name !== "Typography") {
|
|
39
|
+
return "@yh-ui/components/dist/typography/src/typography.css";
|
|
40
|
+
}
|
|
41
|
+
const targetName = subComponentMap[name] || name;
|
|
42
|
+
const kebabName = targetName.replace(/([a-z0-9])([A-Z])/g, "$1-$2").toLowerCase();
|
|
43
|
+
return `@yh-ui/components/dist/${kebabName}/src/${kebabName}.css`;
|
|
44
|
+
}
|
|
17
45
|
const yhNuxtModule = kit.defineNuxtModule({
|
|
18
46
|
meta: {
|
|
19
47
|
name: "@yh-ui/nuxt",
|
|
@@ -33,11 +61,6 @@ const yhNuxtModule = kit.defineNuxtModule({
|
|
|
33
61
|
setup(options, nuxt) {
|
|
34
62
|
const { resolve } = kit.createResolver((typeof document === 'undefined' ? require('u' + 'rl').pathToFileURL(__filename).href : (_documentCurrentScript && _documentCurrentScript.tagName.toUpperCase() === 'SCRIPT' && _documentCurrentScript.src || new URL('module.cjs', document.baseURI).href)));
|
|
35
63
|
kit.addPlugin(resolve("./runtime/plugin.mjs"));
|
|
36
|
-
if (options.importStyle) {
|
|
37
|
-
if (!nuxt.options.css.includes(PUBLISHED_CSS_ENTRY)) {
|
|
38
|
-
nuxt.options.css.push(PUBLISHED_CSS_ENTRY);
|
|
39
|
-
}
|
|
40
|
-
}
|
|
41
64
|
if (options.buildTranspile) {
|
|
42
65
|
nuxt.options.build.transpile = nuxt.options.build.transpile || [];
|
|
43
66
|
const transpileList = ["@yh-ui/components", "@yh-ui/hooks", "@yh-ui/utils", "@yh-ui/theme"];
|
|
@@ -124,7 +147,7 @@ const yhNuxtModule = kit.defineNuxtModule({
|
|
|
124
147
|
"Countdown",
|
|
125
148
|
"Table",
|
|
126
149
|
"TableColumn",
|
|
127
|
-
//
|
|
150
|
+
// 鏂板缁勪欢
|
|
128
151
|
"Space",
|
|
129
152
|
"Avatar",
|
|
130
153
|
"Empty",
|
|
@@ -263,6 +286,80 @@ const yhNuxtModule = kit.defineNuxtModule({
|
|
|
263
286
|
from: "@yh-ui/components"
|
|
264
287
|
});
|
|
265
288
|
});
|
|
289
|
+
if (options.importStyle === "all") {
|
|
290
|
+
if (!nuxt.options.css.includes(PUBLISHED_CSS_ENTRY)) {
|
|
291
|
+
nuxt.options.css.push(PUBLISHED_CSS_ENTRY);
|
|
292
|
+
}
|
|
293
|
+
} else if (options.importStyle === true) {
|
|
294
|
+
const existingStyles = /* @__PURE__ */ new Set();
|
|
295
|
+
try {
|
|
296
|
+
const _require = node_module.createRequire((typeof document === 'undefined' ? require('u' + 'rl').pathToFileURL(__filename).href : (_documentCurrentScript && _documentCurrentScript.tagName.toUpperCase() === 'SCRIPT' && _documentCurrentScript.src || new URL('module.cjs', document.baseURI).href)));
|
|
297
|
+
const fs = _require("node:fs");
|
|
298
|
+
const path = _require("node:path");
|
|
299
|
+
const pkgPath = _require.resolve("@yh-ui/components/package.json", {
|
|
300
|
+
paths: [nuxt.options.rootDir]
|
|
301
|
+
});
|
|
302
|
+
components.forEach((name) => {
|
|
303
|
+
const cssPath = getStylePathForComponent(`Yh${name}`);
|
|
304
|
+
if (cssPath) {
|
|
305
|
+
const localPath = cssPath.replace("@yh-ui/components", path.dirname(pkgPath));
|
|
306
|
+
if (fs.existsSync(localPath)) {
|
|
307
|
+
existingStyles.add(cssPath);
|
|
308
|
+
}
|
|
309
|
+
}
|
|
310
|
+
});
|
|
311
|
+
} catch {
|
|
312
|
+
}
|
|
313
|
+
kit.extendViteConfig((config) => {
|
|
314
|
+
config.plugins = config.plugins || [];
|
|
315
|
+
config.plugins.push({
|
|
316
|
+
name: "yh-ui:style-import",
|
|
317
|
+
enforce: "post",
|
|
318
|
+
transform(code, id) {
|
|
319
|
+
if (!id || !/\.(js|ts|vue|mjs|cjs)$/.test(id) || id.includes("node_modules")) {
|
|
320
|
+
return;
|
|
321
|
+
}
|
|
322
|
+
const importsMatch = code.match(
|
|
323
|
+
/import\s*\{([^}]+)\}\s*from\s*['"]@yh-ui\/components['"]/g
|
|
324
|
+
);
|
|
325
|
+
if (!importsMatch) {
|
|
326
|
+
return;
|
|
327
|
+
}
|
|
328
|
+
const componentsToInject = /* @__PURE__ */ new Set();
|
|
329
|
+
for (const matchStr of importsMatch) {
|
|
330
|
+
const innerMatch = matchStr.match(/\{([^}]+)\}/);
|
|
331
|
+
if (innerMatch) {
|
|
332
|
+
const specifiers = innerMatch[1].split(",");
|
|
333
|
+
for (const spec of specifiers) {
|
|
334
|
+
const name = spec.trim().split(/\s+as\s+/)[0].trim();
|
|
335
|
+
if (name.startsWith("Yh")) {
|
|
336
|
+
componentsToInject.add(name);
|
|
337
|
+
}
|
|
338
|
+
}
|
|
339
|
+
}
|
|
340
|
+
}
|
|
341
|
+
if (componentsToInject.size === 0) {
|
|
342
|
+
return;
|
|
343
|
+
}
|
|
344
|
+
const styleImports = [];
|
|
345
|
+
for (const comp of componentsToInject) {
|
|
346
|
+
const cssFile = getStylePathForComponent(comp);
|
|
347
|
+
if (cssFile) {
|
|
348
|
+
if (existingStyles.size === 0 || existingStyles.has(cssFile)) {
|
|
349
|
+
styleImports.push(`import '${cssFile}';`);
|
|
350
|
+
}
|
|
351
|
+
}
|
|
352
|
+
}
|
|
353
|
+
if (styleImports.length > 0) {
|
|
354
|
+
return {
|
|
355
|
+
code: code + "\n" + styleImports.join("\n"),
|
|
356
|
+
map: null
|
|
357
|
+
};
|
|
358
|
+
}
|
|
359
|
+
}
|
|
360
|
+
});
|
|
361
|
+
});
|
|
362
|
+
}
|
|
266
363
|
kit.extendViteConfig((config) => {
|
|
267
364
|
config.optimizeDeps ||= {};
|
|
268
365
|
config.optimizeDeps.include ||= [];
|
package/dist/module.d.cts
CHANGED
|
@@ -2,11 +2,13 @@ import * as _nuxt_schema from '@nuxt/schema';
|
|
|
2
2
|
|
|
3
3
|
interface ModuleOptions {
|
|
4
4
|
/**
|
|
5
|
-
*
|
|
6
|
-
*
|
|
5
|
+
* Control how styles are imported:
|
|
6
|
+
* - `true` (default): Automatically inject styles on demand.
|
|
7
|
+
* - `'all'`: Inject the entire published style.css.
|
|
8
|
+
* - `false`: Disable automatic style injection.
|
|
7
9
|
* @default true
|
|
8
10
|
*/
|
|
9
|
-
importStyle?: boolean;
|
|
11
|
+
importStyle?: boolean | 'all';
|
|
10
12
|
/**
|
|
11
13
|
* Whether to transpile dependencies.
|
|
12
14
|
* @default true
|
package/dist/module.d.mts
CHANGED
|
@@ -2,11 +2,13 @@ import * as _nuxt_schema from '@nuxt/schema';
|
|
|
2
2
|
|
|
3
3
|
interface ModuleOptions {
|
|
4
4
|
/**
|
|
5
|
-
*
|
|
6
|
-
*
|
|
5
|
+
* Control how styles are imported:
|
|
6
|
+
* - `true` (default): Automatically inject styles on demand.
|
|
7
|
+
* - `'all'`: Inject the entire published style.css.
|
|
8
|
+
* - `false`: Disable automatic style injection.
|
|
7
9
|
* @default true
|
|
8
10
|
*/
|
|
9
|
-
importStyle?: boolean;
|
|
11
|
+
importStyle?: boolean | 'all';
|
|
10
12
|
/**
|
|
11
13
|
* Whether to transpile dependencies.
|
|
12
14
|
* @default true
|
package/dist/module.d.ts
CHANGED
|
@@ -2,11 +2,13 @@ import * as _nuxt_schema from '@nuxt/schema';
|
|
|
2
2
|
|
|
3
3
|
interface ModuleOptions {
|
|
4
4
|
/**
|
|
5
|
-
*
|
|
6
|
-
*
|
|
5
|
+
* Control how styles are imported:
|
|
6
|
+
* - `true` (default): Automatically inject styles on demand.
|
|
7
|
+
* - `'all'`: Inject the entire published style.css.
|
|
8
|
+
* - `false`: Disable automatic style injection.
|
|
7
9
|
* @default true
|
|
8
10
|
*/
|
|
9
|
-
importStyle?: boolean;
|
|
11
|
+
importStyle?: boolean | 'all';
|
|
10
12
|
/**
|
|
11
13
|
* Whether to transpile dependencies.
|
|
12
14
|
* @default true
|
package/dist/module.mjs
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import crypto from 'node:crypto';
|
|
2
|
+
import { createRequire } from 'node:module';
|
|
2
3
|
import { defineNuxtModule, createResolver, addPlugin, addComponent, addImports, extendViteConfig } from '@nuxt/kit';
|
|
3
4
|
|
|
4
5
|
if (typeof crypto.hash !== "function") {
|
|
@@ -7,6 +8,33 @@ if (typeof crypto.hash !== "function") {
|
|
|
7
8
|
};
|
|
8
9
|
}
|
|
9
10
|
const PUBLISHED_CSS_ENTRY = "@yh-ui/components/style.css";
|
|
11
|
+
function getStylePathForComponent(componentName) {
|
|
12
|
+
const name = componentName.replace(/^Yh/, "");
|
|
13
|
+
const subComponentMap = {
|
|
14
|
+
Option: "select",
|
|
15
|
+
BreadcrumbItem: "breadcrumb",
|
|
16
|
+
DropdownItem: "dropdown",
|
|
17
|
+
DropdownMenu: "dropdown",
|
|
18
|
+
FormItem: "form",
|
|
19
|
+
FormSchema: "form",
|
|
20
|
+
GridItem: "grid",
|
|
21
|
+
Step: "steps",
|
|
22
|
+
TableColumn: "table",
|
|
23
|
+
TabPane: "tabs",
|
|
24
|
+
TreeNode: "tree",
|
|
25
|
+
CarouselItem: "carousel",
|
|
26
|
+
Header: "container",
|
|
27
|
+
Aside: "container",
|
|
28
|
+
Main: "container",
|
|
29
|
+
Footer: "container"
|
|
30
|
+
};
|
|
31
|
+
if (name.startsWith("Typography") && name !== "Typography") {
|
|
32
|
+
return "@yh-ui/components/dist/typography/src/typography.css";
|
|
33
|
+
}
|
|
34
|
+
const targetName = subComponentMap[name] || name;
|
|
35
|
+
const kebabName = targetName.replace(/([a-z0-9])([A-Z])/g, "$1-$2").toLowerCase();
|
|
36
|
+
return `@yh-ui/components/dist/${kebabName}/src/${kebabName}.css`;
|
|
37
|
+
}
|
|
10
38
|
const yhNuxtModule = defineNuxtModule({
|
|
11
39
|
meta: {
|
|
12
40
|
name: "@yh-ui/nuxt",
|
|
@@ -26,11 +54,6 @@ const yhNuxtModule = defineNuxtModule({
|
|
|
26
54
|
setup(options, nuxt) {
|
|
27
55
|
const { resolve } = createResolver(import.meta.url);
|
|
28
56
|
addPlugin(resolve("./runtime/plugin.mjs"));
|
|
29
|
-
if (options.importStyle) {
|
|
30
|
-
if (!nuxt.options.css.includes(PUBLISHED_CSS_ENTRY)) {
|
|
31
|
-
nuxt.options.css.push(PUBLISHED_CSS_ENTRY);
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
57
|
if (options.buildTranspile) {
|
|
35
58
|
nuxt.options.build.transpile = nuxt.options.build.transpile || [];
|
|
36
59
|
const transpileList = ["@yh-ui/components", "@yh-ui/hooks", "@yh-ui/utils", "@yh-ui/theme"];
|
|
@@ -117,7 +140,7 @@ const yhNuxtModule = defineNuxtModule({
|
|
|
117
140
|
"Countdown",
|
|
118
141
|
"Table",
|
|
119
142
|
"TableColumn",
|
|
120
|
-
//
|
|
143
|
+
// 鏂板缁勪欢
|
|
121
144
|
"Space",
|
|
122
145
|
"Avatar",
|
|
123
146
|
"Empty",
|
|
@@ -256,6 +279,80 @@ const yhNuxtModule = defineNuxtModule({
|
|
|
256
279
|
from: "@yh-ui/components"
|
|
257
280
|
});
|
|
258
281
|
});
|
|
282
|
+
if (options.importStyle === "all") {
|
|
283
|
+
if (!nuxt.options.css.includes(PUBLISHED_CSS_ENTRY)) {
|
|
284
|
+
nuxt.options.css.push(PUBLISHED_CSS_ENTRY);
|
|
285
|
+
}
|
|
286
|
+
} else if (options.importStyle === true) {
|
|
287
|
+
const existingStyles = /* @__PURE__ */ new Set();
|
|
288
|
+
try {
|
|
289
|
+
const _require = createRequire(import.meta.url);
|
|
290
|
+
const fs = _require("node:fs");
|
|
291
|
+
const path = _require("node:path");
|
|
292
|
+
const pkgPath = _require.resolve("@yh-ui/components/package.json", {
|
|
293
|
+
paths: [nuxt.options.rootDir]
|
|
294
|
+
});
|
|
295
|
+
components.forEach((name) => {
|
|
296
|
+
const cssPath = getStylePathForComponent(`Yh${name}`);
|
|
297
|
+
if (cssPath) {
|
|
298
|
+
const localPath = cssPath.replace("@yh-ui/components", path.dirname(pkgPath));
|
|
299
|
+
if (fs.existsSync(localPath)) {
|
|
300
|
+
existingStyles.add(cssPath);
|
|
301
|
+
}
|
|
302
|
+
}
|
|
303
|
+
});
|
|
304
|
+
} catch {
|
|
305
|
+
}
|
|
306
|
+
extendViteConfig((config) => {
|
|
307
|
+
config.plugins = config.plugins || [];
|
|
308
|
+
config.plugins.push({
|
|
309
|
+
name: "yh-ui:style-import",
|
|
310
|
+
enforce: "post",
|
|
311
|
+
transform(code, id) {
|
|
312
|
+
if (!id || !/\.(js|ts|vue|mjs|cjs)$/.test(id) || id.includes("node_modules")) {
|
|
313
|
+
return;
|
|
314
|
+
}
|
|
315
|
+
const importsMatch = code.match(
|
|
316
|
+
/import\s*\{([^}]+)\}\s*from\s*['"]@yh-ui\/components['"]/g
|
|
317
|
+
);
|
|
318
|
+
if (!importsMatch) {
|
|
319
|
+
return;
|
|
320
|
+
}
|
|
321
|
+
const componentsToInject = /* @__PURE__ */ new Set();
|
|
322
|
+
for (const matchStr of importsMatch) {
|
|
323
|
+
const innerMatch = matchStr.match(/\{([^}]+)\}/);
|
|
324
|
+
if (innerMatch) {
|
|
325
|
+
const specifiers = innerMatch[1].split(",");
|
|
326
|
+
for (const spec of specifiers) {
|
|
327
|
+
const name = spec.trim().split(/\s+as\s+/)[0].trim();
|
|
328
|
+
if (name.startsWith("Yh")) {
|
|
329
|
+
componentsToInject.add(name);
|
|
330
|
+
}
|
|
331
|
+
}
|
|
332
|
+
}
|
|
333
|
+
}
|
|
334
|
+
if (componentsToInject.size === 0) {
|
|
335
|
+
return;
|
|
336
|
+
}
|
|
337
|
+
const styleImports = [];
|
|
338
|
+
for (const comp of componentsToInject) {
|
|
339
|
+
const cssFile = getStylePathForComponent(comp);
|
|
340
|
+
if (cssFile) {
|
|
341
|
+
if (existingStyles.size === 0 || existingStyles.has(cssFile)) {
|
|
342
|
+
styleImports.push(`import '${cssFile}';`);
|
|
343
|
+
}
|
|
344
|
+
}
|
|
345
|
+
}
|
|
346
|
+
if (styleImports.length > 0) {
|
|
347
|
+
return {
|
|
348
|
+
code: code + "\n" + styleImports.join("\n"),
|
|
349
|
+
map: null
|
|
350
|
+
};
|
|
351
|
+
}
|
|
352
|
+
}
|
|
353
|
+
});
|
|
354
|
+
});
|
|
355
|
+
}
|
|
259
356
|
extendViteConfig((config) => {
|
|
260
357
|
config.optimizeDeps ||= {};
|
|
261
358
|
config.optimizeDeps.include ||= [];
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@yh-ui/nuxt",
|
|
3
|
-
"version": "1.0.
|
|
3
|
+
"version": "1.0.30",
|
|
4
4
|
"description": "Nuxt module for YH-UI",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"main": "./dist/module.cjs",
|
|
@@ -17,11 +17,19 @@
|
|
|
17
17
|
"files": [
|
|
18
18
|
"dist"
|
|
19
19
|
],
|
|
20
|
+
"scripts": {
|
|
21
|
+
"build": "unbuild",
|
|
22
|
+
"dev": "unbuild --stub",
|
|
23
|
+
"prepack": "node ../../scripts/prepare-package-manifest.mjs prepare",
|
|
24
|
+
"postpack": "node ../../scripts/prepare-package-manifest.mjs restore",
|
|
25
|
+
"typecheck": "vue-tsc --noEmit",
|
|
26
|
+
"lint": "eslint ."
|
|
27
|
+
},
|
|
20
28
|
"dependencies": {
|
|
21
29
|
"@nuxt/kit": "^3.11.0 || ^4.0.0",
|
|
22
|
-
"@yh-ui/components": "^1.0.
|
|
23
|
-
"@yh-ui/hooks": "^1.0.
|
|
24
|
-
"@yh-ui/theme": "^1.0.
|
|
30
|
+
"@yh-ui/components": "^1.0.30",
|
|
31
|
+
"@yh-ui/hooks": "^1.0.30",
|
|
32
|
+
"@yh-ui/theme": "^1.0.30"
|
|
25
33
|
},
|
|
26
34
|
"devDependencies": {
|
|
27
35
|
"@nuxt/schema": "^3.11.0 || ^4.0.0",
|
|
@@ -50,11 +58,5 @@
|
|
|
50
58
|
"engines": {
|
|
51
59
|
"node": ">=18.0.0",
|
|
52
60
|
"pnpm": ">=9.0.0"
|
|
53
|
-
},
|
|
54
|
-
"scripts": {
|
|
55
|
-
"build": "unbuild",
|
|
56
|
-
"dev": "unbuild --stub",
|
|
57
|
-
"typecheck": "vue-tsc --noEmit",
|
|
58
|
-
"lint": "eslint ."
|
|
59
61
|
}
|
|
60
|
-
}
|
|
62
|
+
}
|
package/LICENSE
DELETED
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
MIT License
|
|
2
|
-
|
|
3
|
-
Copyright (c) 2026 YH-UI Team
|
|
4
|
-
|
|
5
|
-
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
6
|
-
of this software and associated documentation files (the "Software"), to deal
|
|
7
|
-
in the Software without restriction, including without limitation the rights
|
|
8
|
-
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
9
|
-
copies of the Software, and to permit persons to whom the Software is
|
|
10
|
-
furnished to do so, subject to the following conditions:
|
|
11
|
-
|
|
12
|
-
The above copyright notice and this permission notice shall be included in all
|
|
13
|
-
copies or substantial portions of the Software.
|
|
14
|
-
|
|
15
|
-
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
16
|
-
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
17
|
-
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
18
|
-
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
19
|
-
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
20
|
-
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
21
|
-
SOFTWARE.
|