@qin-ui/antd-vue-pro 2.1.13 → 2.1.14

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/AI-CONTEXT.md CHANGED
@@ -87,7 +87,7 @@ const table = useTable({
87
87
 
88
88
  - `path` - 数据路径(类型安全)
89
89
  - `label` - 字段标签
90
- - `component` - 组件名(内置支持: input, select, date-picker, cascader 等)
90
+ - `component` - 组件名(内置支持: input, textarea, input-search, input-password, input-number, select, cascader, date-picker, range-picker, time-picker, checkbox-group, radio-group, switch, slider, tree-select, transfer, custom)
91
91
  - `hidden` - 是否隐藏
92
92
  - `disabled` - 是否禁用
93
93
  - `rules` - 校验规则
@@ -0,0 +1,142 @@
1
+ #!/usr/bin/env node
2
+
3
+ /**
4
+ * @qin-ui/* AI 上下文初始化 CLI 工具
5
+ *
6
+ * 遵循 Agentic Collaboration Standard (ACS),
7
+ * 在消费方项目中自动生成统一的 .agents 规范配置文件。
8
+ *
9
+ * 用法:
10
+ * npx @qin-ui/antd-vue-pro init-ai
11
+ */
12
+
13
+ import fs from 'node:fs';
14
+ import path from 'node:path';
15
+ import { fileURLToPath } from 'node:url';
16
+
17
+ // ==================== 常量 ====================
18
+
19
+ const __filename = fileURLToPath(import.meta.url);
20
+ const __dirname = path.dirname(__filename);
21
+ const PKG_ROOT = path.resolve(__dirname, '..');
22
+
23
+ const PKG_JSON = JSON.parse(
24
+ fs.readFileSync(path.join(PKG_ROOT, 'package.json'), 'utf-8')
25
+ );
26
+ const PKG_NAME = PKG_JSON.name;
27
+ const PKG_SHORT = PKG_NAME.replace(/^@qin-ui\//, '');
28
+
29
+ // ==================== 终端颜色 ====================
30
+
31
+ const green = (s) => `\x1b[32m${s}\x1b[0m`;
32
+ const cyan = (s) => `\x1b[36m${s}\x1b[0m`;
33
+ const bold = (s) => `\x1b[1m${s}\x1b[0m`;
34
+ const red = (s) => `\x1b[31m${s}\x1b[0m`;
35
+
36
+ // ==================== 内容生成 ====================
37
+
38
+ function getAiContextContent() {
39
+ const filePath = path.join(PKG_ROOT, 'AI-CONTEXT.md');
40
+ if (fs.existsSync(filePath)) {
41
+ return fs.readFileSync(filePath, 'utf-8').trim();
42
+ }
43
+ return `# ${PKG_NAME}\n\n> 基于 Vue 3 的配置驱动组件库。`;
44
+ }
45
+
46
+ function getUnifiedAgentContent() {
47
+ const aiContext = getAiContextContent();
48
+ const core = [
49
+ aiContext,
50
+ '',
51
+ '## 完整 API 参考',
52
+ '',
53
+ `使用 \`${PKG_NAME}\` 时,请阅读以下文件获取完整的 API 定义、类型签名和使用示例:`,
54
+ `- \`node_modules/${PKG_NAME}/README.md\` — 详细使用文档和代码示例`,
55
+ `- \`node_modules/${PKG_NAME}/api.json\` — 结构化 API 元数据(组件、Hook、类型的签名和 JSDoc 示例)`,
56
+ '',
57
+ ].join('\n');
58
+
59
+ // 包含兼容性的 Frontmatter(如 Cursor 支持的 globs 等)
60
+ return [
61
+ '---',
62
+ `description: "${PKG_NAME} 组件库使用规范"`,
63
+ 'globs: ["**/*.vue", "**/*.ts", "**/*.tsx"]',
64
+ 'alwaysApply: false',
65
+ '---',
66
+ '',
67
+ core,
68
+ ].join('\n');
69
+ }
70
+
71
+ // ==================== 文件写入 ====================
72
+
73
+ function ensureDir(dirPath) {
74
+ if (!fs.existsSync(dirPath)) {
75
+ fs.mkdirSync(dirPath, { recursive: true });
76
+ }
77
+ }
78
+
79
+ // ==================== CLI 入口 ====================
80
+
81
+ function printHelp() {
82
+ console.log(`
83
+ ${bold(`${PKG_NAME} CLI`)}
84
+
85
+ ${bold('用法:')}
86
+ npx ${PKG_NAME} init-ai
87
+
88
+ ${bold('命令:')}
89
+ init-ai 在当前项目中生成统一的 .agents 规范配置文件
90
+
91
+ ${bold('选项:')}
92
+ --help 显示帮助信息
93
+
94
+ ${bold('说明:')}
95
+ 该命令将采用统一的 Agentic 标准,在项目的 .agents/rules/ 目录下
96
+ 生成上下文文件。兼容支持读取 .agents 的主流 AI IDE 和 CLI 工具。
97
+ `);
98
+ }
99
+
100
+ function main() {
101
+ const args = process.argv.slice(2);
102
+ const subcommand = args.find((a) => !a.startsWith('-'));
103
+ const flags = args.filter((a) => a.startsWith('-'));
104
+
105
+ if (!subcommand || flags.includes('--help') || flags.includes('-h')) {
106
+ printHelp();
107
+ process.exit(0);
108
+ }
109
+
110
+ if (subcommand !== 'init-ai') {
111
+ console.error(red(`\n 未知命令: ${subcommand}\n`));
112
+ printHelp();
113
+ process.exit(1);
114
+ }
115
+
116
+ console.log('');
117
+ console.log(bold(`📦 ${PKG_NAME} — AI 上下文初始化 (ACS 标准)`));
118
+ console.log('');
119
+
120
+ const content = getUnifiedAgentContent();
121
+ const dirPath = '.agents/rules';
122
+ const fileName = `${PKG_SHORT}.md`;
123
+
124
+ const fullDir = path.join(process.cwd(), dirPath);
125
+ const fullPath = path.join(fullDir, fileName);
126
+
127
+ ensureDir(fullDir);
128
+ fs.writeFileSync(fullPath, content, 'utf-8');
129
+
130
+ const relPath = path.join(dirPath, fileName);
131
+ console.log(` ${green('✔')} ${cyan(relPath)} ${green('[created/updated]')}`);
132
+
133
+ console.log('');
134
+ console.log(green('✅ 完成!已生成统一标准规则文件。'));
135
+ console.log('');
136
+ console.log(`${bold('下一步:')}`);
137
+ console.log(
138
+ ` 将 ${cyan(dirPath)} 目录提交到 Git,团队即可自动享受 AI 增强\n`
139
+ );
140
+ }
141
+
142
+ main();
package/package.json CHANGED
@@ -1,7 +1,10 @@
1
1
  {
2
2
  "name": "@qin-ui/antd-vue-pro",
3
- "version": "2.1.13",
3
+ "version": "2.1.14",
4
4
  "description": "二次封装antd vue组件",
5
+ "bin": {
6
+ "antd-vue-pro": "./bin/init-ai.mjs"
7
+ },
5
8
  "type": "module",
6
9
  "module": "es/index.js",
7
10
  "types": "es/index.d.ts",
@@ -14,6 +17,7 @@
14
17
  },
15
18
  "files": [
16
19
  "es",
20
+ "bin",
17
21
  "README.md",
18
22
  "LICENSE",
19
23
  "api.json",