@qin-ui/antd-vue-pro 2.1.12 → 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` - 校验规则
package/api.json CHANGED
@@ -1,5 +1,5 @@
1
1
  {
2
- "generatedAt": "2026-06-04T09:03:23.488Z",
2
+ "generatedAt": "2026-06-08T06:46:32.287Z",
3
3
  "name": "@qin-ui/antd-vue-pro",
4
4
  "api": [
5
5
  {
@@ -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();
@@ -1,13 +1,13 @@
1
- .pro-table_search-form[data-v-b6a08ff0] [class*='-form-item'] {
1
+ .pro-table_search-form[data-v-a2af360f] [class*='-form-item'] {
2
2
  margin: 0;
3
3
  }
4
- .pro-table_search-form_expand-toggle-button[data-v-b6a08ff0] {
4
+ .pro-table_search-form_expand-toggle-button[data-v-a2af360f] {
5
5
  display: flex;
6
6
  align-items: center;
7
7
  padding: 0;
8
8
  padding-left: 4px;
9
9
  }
10
- .pro-table_search-form .transition[data-v-b6a08ff0] {
10
+ .pro-table_search-form .transition[data-v-a2af360f] {
11
11
  transition: all 0.25s;
12
12
  }
13
13
  .pro-table_search-form-container[data-v-c385cd54] {
package/es/index.d.ts CHANGED
@@ -1155,9 +1155,11 @@ declare type SearchFormProps = {
1155
1155
  form: Form;
1156
1156
  layout?: 'grid' | 'inline';
1157
1157
  expand?: boolean | Expand;
1158
- searchButton?: Component<ButtonProps> | DefineComponent<ButtonProps>;
1159
- resetButton?: Component<ButtonProps> | DefineComponent<ButtonProps>;
1160
- expandButton?: Component<ExpandButtonProps> | DefineComponent<ExpandButtonProps>;
1158
+ searchButton?: Component<ButtonProps> | DefineComponent<ButtonProps> | false;
1159
+ resetButton?: Component<ButtonProps> | DefineComponent<ButtonProps> | false;
1160
+ expandButton?: Component<ExpandButtonProps> | DefineComponent<ExpandButtonProps> | false;
1161
+ rowGap?: number;
1162
+ columnGap?: number;
1161
1163
  } & /* @vue-ignore */ _FormProps & AllowedComponentProps;
1162
1164
 
1163
1165
  declare type SetColumn<T extends Data = Data, C extends BaseColumn<T> = BaseColumn<T>> = (key: Path<T>, column: C | ((pre: Readonly<C>) => C), options?: {
package/es/table/index.js CHANGED
@@ -1,4 +1,4 @@
1
- import { createElementBlock, openBlock, createElementVNode, defineComponent, ref, computed, watch, watchEffect, createBlock, unref, mergeProps, withCtx, createVNode, renderSlot, resolveDynamicComponent, createTextVNode, createCommentVNode, Fragment, toDisplayString, normalizeStyle, useModel, renderList, withModifiers, mergeModels, inject, useAttrs, useSlots, onMounted, normalizeClass, createSlots, normalizeProps, guardReactiveProps, nextTick } from "vue";
1
+ import { createElementBlock, openBlock, createElementVNode, defineComponent, ref, computed, watch, watchEffect, createBlock, unref, mergeProps, withCtx, createVNode, renderSlot, createCommentVNode, Fragment, resolveDynamicComponent, createTextVNode, toDisplayString, normalizeStyle, useModel, renderList, withModifiers, mergeModels, inject, useAttrs, useSlots, onMounted, normalizeClass, createSlots, normalizeProps, guardReactiveProps, nextTick } from "vue";
2
2
  import { I as INJECT_CONFIG } from "../component-provider/index-Dmz32tSB.js";
3
3
  import _sfc_main$9, { ContainerFragment as _sfc_main$a } from "../form/index.js";
4
4
  import { Space, Button, theme, Dropdown, Menu, MenuItem, Checkbox, MenuDivider, Table } from "ant-design-vue";
@@ -36,9 +36,11 @@ const _sfc_main$7 = /* @__PURE__ */ defineComponent({
36
36
  form: {},
37
37
  layout: { default: "grid" },
38
38
  expand: { type: [Boolean, Object], default: true },
39
- searchButton: { type: [Object, Function], default: void 0 },
40
- resetButton: { type: [Object, Function], default: void 0 },
41
- expandButton: { type: [Object, Function], default: void 0 },
39
+ searchButton: { type: [Object, Function, Boolean], default: void 0 },
40
+ resetButton: { type: [Object, Function, Boolean], default: void 0 },
41
+ expandButton: { type: [Object, Function, Boolean], default: void 0 },
42
+ rowGap: { default: 16 },
43
+ columnGap: { default: 24 },
42
44
  class: {},
43
45
  style: {}
44
46
  },
@@ -48,8 +50,6 @@ const _sfc_main$7 = /* @__PURE__ */ defineComponent({
48
50
  const proFormHeight = ref("unset");
49
51
  const collapseHeight = ref(0);
50
52
  let rowHeight = 32;
51
- const rowGap = 16;
52
- const columnGap = 24;
53
53
  const computedExpand = computed(() => {
54
54
  if (!__props.expand) return false;
55
55
  if (__props.expand === true) return { minExpandRows: 2, expandStatus: false };
@@ -115,7 +115,7 @@ const _sfc_main$7 = /* @__PURE__ */ defineComponent({
115
115
  if (__props.layout === "grid" && computedExpand.value) {
116
116
  const { minExpandRows } = computedExpand.value;
117
117
  collapseHeight.value = Math.min(
118
- minExpandRows * rowHeight + (minExpandRows - 1) * rowGap,
118
+ minExpandRows * rowHeight + (minExpandRows - 1) * __props.rowGap,
119
119
  +proFormHeight.value
120
120
  );
121
121
  showExpandToggle.value = +proFormHeight.value - collapseHeight.value > 1;
@@ -131,7 +131,7 @@ const _sfc_main$7 = /* @__PURE__ */ defineComponent({
131
131
  const layoutProps = computed(
132
132
  () => __props.layout === "grid" ? {
133
133
  grid: {
134
- gutter: [columnGap, rowGap],
134
+ gutter: [__props.columnGap, __props.rowGap],
135
135
  style: { flex: 1, marginRight: "12px" }
136
136
  },
137
137
  style: {
@@ -141,7 +141,7 @@ const _sfc_main$7 = /* @__PURE__ */ defineComponent({
141
141
  }
142
142
  } : {
143
143
  layout: "inline",
144
- style: { gap: `${rowGap}px ${columnGap}px` },
144
+ style: { gap: `${__props.rowGap}px ${__props.columnGap}px` },
145
145
  grid: false
146
146
  }
147
147
  );
@@ -163,39 +163,43 @@ const _sfc_main$7 = /* @__PURE__ */ defineComponent({
163
163
  }, {
164
164
  default: withCtx(() => [
165
165
  renderSlot(_ctx.$slots, "reset-button", { onClick: onReset }, () => [
166
- __props.resetButton ? (openBlock(), createBlock(resolveDynamicComponent(__props.resetButton), {
167
- key: 0,
168
- onClick: onReset
169
- })) : (openBlock(), createBlock(unref(Button), {
170
- key: 1,
171
- class: "pro-table_search-form_reset-button",
172
- onClick: onReset
173
- }, {
174
- default: withCtx(() => [..._cache[0] || (_cache[0] = [
175
- createTextVNode("重置", -1)
176
- ])]),
177
- _: 1
178
- }))
166
+ __props.resetButton !== false ? (openBlock(), createElementBlock(Fragment, { key: 0 }, [
167
+ __props.resetButton ? (openBlock(), createBlock(resolveDynamicComponent(__props.resetButton), {
168
+ key: 0,
169
+ onClick: onReset
170
+ })) : (openBlock(), createBlock(unref(Button), {
171
+ key: 1,
172
+ class: "pro-table_search-form_reset-button",
173
+ onClick: onReset
174
+ }, {
175
+ default: withCtx(() => [..._cache[0] || (_cache[0] = [
176
+ createTextVNode("重置", -1)
177
+ ])]),
178
+ _: 1
179
+ }))
180
+ ], 64)) : createCommentVNode("", true)
179
181
  ], true),
180
182
  renderSlot(_ctx.$slots, "search-button", { onClick: onSearch }, () => [
181
- __props.searchButton ? (openBlock(), createBlock(resolveDynamicComponent(__props.searchButton), {
182
- key: 0,
183
- onClick: onSearch
184
- })) : (openBlock(), createBlock(unref(Button), {
185
- key: 1,
186
- class: "pro-table_search-form_search-button",
187
- type: "primary",
188
- "html-type": "submit",
189
- onClick: onSearch
190
- }, {
191
- default: withCtx(() => [..._cache[1] || (_cache[1] = [
192
- createTextVNode("查询 ", -1)
193
- ])]),
194
- _: 1
195
- }))
183
+ __props.searchButton !== false ? (openBlock(), createElementBlock(Fragment, { key: 0 }, [
184
+ __props.searchButton ? (openBlock(), createBlock(resolveDynamicComponent(__props.searchButton), {
185
+ key: 0,
186
+ onClick: onSearch
187
+ })) : (openBlock(), createBlock(unref(Button), {
188
+ key: 1,
189
+ class: "pro-table_search-form_search-button",
190
+ type: "primary",
191
+ "html-type": "submit",
192
+ onClick: onSearch
193
+ }, {
194
+ default: withCtx(() => [..._cache[1] || (_cache[1] = [
195
+ createTextVNode("查询 ", -1)
196
+ ])]),
197
+ _: 1
198
+ }))
199
+ ], 64)) : createCommentVNode("", true)
196
200
  ], true),
197
201
  renderSlot(_ctx.$slots, "expand-button", { onClick: changeExpandStatus }, () => [
198
- showExpandToggle.value ? (openBlock(), createElementBlock(Fragment, { key: 0 }, [
202
+ __props.expandButton !== false && showExpandToggle.value ? (openBlock(), createElementBlock(Fragment, { key: 0 }, [
199
203
  __props.expandButton ? (openBlock(), createBlock(resolveDynamicComponent(__props.expandButton), {
200
204
  key: 0,
201
205
  "expand-status": expandStatus.value,
@@ -226,7 +230,7 @@ const _sfc_main$7 = /* @__PURE__ */ defineComponent({
226
230
  };
227
231
  }
228
232
  });
229
- const SearchForm = /* @__PURE__ */ _export_sfc(_sfc_main$7, [["__scopeId", "data-v-b6a08ff0"]]);
233
+ const SearchForm = /* @__PURE__ */ _export_sfc(_sfc_main$7, [["__scopeId", "data-v-a2af360f"]]);
230
234
  const _sfc_main$6 = /* @__PURE__ */ defineComponent({
231
235
  __name: "DefaultSearchFormContainer",
232
236
  setup(__props) {
package/package.json CHANGED
@@ -1,7 +1,10 @@
1
1
  {
2
2
  "name": "@qin-ui/antd-vue-pro",
3
- "version": "2.1.12",
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",