figma-to-code-agent 0.6.0 → 0.7.0
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/CHANGELOG.md +32 -0
- package/README.md +68 -76
- package/README.zh-CN.md +173 -0
- package/dist/agent/ConversationContext.d.ts +91 -0
- package/dist/agent/ConversationContext.d.ts.map +1 -0
- package/dist/agent/ConversationContext.js +271 -0
- package/dist/agent/ConversationContext.js.map +1 -0
- package/dist/agent/DecisionEngine.d.ts +77 -0
- package/dist/agent/DecisionEngine.d.ts.map +1 -0
- package/dist/agent/DecisionEngine.js +414 -0
- package/dist/agent/DecisionEngine.js.map +1 -0
- package/dist/agent/ExecutionOrchestrator.d.ts +55 -0
- package/dist/agent/ExecutionOrchestrator.d.ts.map +1 -0
- package/dist/agent/ExecutionOrchestrator.js +360 -0
- package/dist/agent/ExecutionOrchestrator.js.map +1 -0
- package/dist/agent/IntentUnderstandingEngine.d.ts +43 -0
- package/dist/agent/IntentUnderstandingEngine.d.ts.map +1 -0
- package/dist/agent/IntentUnderstandingEngine.js +261 -0
- package/dist/agent/IntentUnderstandingEngine.js.map +1 -0
- package/dist/agent/index.d.ts +9 -0
- package/dist/agent/index.d.ts.map +1 -0
- package/dist/agent/index.js +30 -0
- package/dist/agent/index.js.map +1 -0
- package/dist/agent/types.d.ts +111 -0
- package/dist/agent/types.d.ts.map +1 -0
- package/dist/agent/types.js +6 -0
- package/dist/agent/types.js.map +1 -0
- package/dist/cli/InteractiveCLI.d.ts +109 -0
- package/dist/cli/InteractiveCLI.d.ts.map +1 -0
- package/dist/cli/InteractiveCLI.js +534 -0
- package/dist/cli/InteractiveCLI.js.map +1 -0
- package/dist/cli/ProgressDisplay.d.ts +117 -0
- package/dist/cli/ProgressDisplay.d.ts.map +1 -0
- package/dist/cli/ProgressDisplay.js +370 -0
- package/dist/cli/ProgressDisplay.js.map +1 -0
- package/dist/cli/index.d.ts +6 -0
- package/dist/cli/index.d.ts.map +1 -0
- package/dist/cli/index.js +22 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/consistency/DesignConsistencyChecker.d.ts +125 -0
- package/dist/consistency/DesignConsistencyChecker.d.ts.map +1 -0
- package/dist/consistency/DesignConsistencyChecker.js +448 -0
- package/dist/consistency/DesignConsistencyChecker.js.map +1 -0
- package/dist/consistency/index.d.ts +5 -0
- package/dist/consistency/index.d.ts.map +1 -0
- package/dist/consistency/index.js +21 -0
- package/dist/consistency/index.js.map +1 -0
- package/dist/context/CodeStyleMatcher.d.ts +124 -0
- package/dist/context/CodeStyleMatcher.d.ts.map +1 -0
- package/dist/context/CodeStyleMatcher.js +558 -0
- package/dist/context/CodeStyleMatcher.js.map +1 -0
- package/dist/context/IncrementalUpdater.d.ts +97 -0
- package/dist/context/IncrementalUpdater.d.ts.map +1 -0
- package/dist/context/IncrementalUpdater.js +431 -0
- package/dist/context/IncrementalUpdater.js.map +1 -0
- package/dist/context/index.d.ts +6 -0
- package/dist/context/index.d.ts.map +1 -0
- package/dist/context/index.js +22 -0
- package/dist/context/index.js.map +1 -0
- package/dist/feedback/FeedbackLoop.d.ts +125 -0
- package/dist/feedback/FeedbackLoop.d.ts.map +1 -0
- package/dist/feedback/FeedbackLoop.js +353 -0
- package/dist/feedback/FeedbackLoop.js.map +1 -0
- package/dist/feedback/index.d.ts +5 -0
- package/dist/feedback/index.d.ts.map +1 -0
- package/dist/feedback/index.js +21 -0
- package/dist/feedback/index.js.map +1 -0
- package/dist/mcp/FigmaMCPIntegration.d.ts +72 -0
- package/dist/mcp/FigmaMCPIntegration.d.ts.map +1 -0
- package/dist/mcp/FigmaMCPIntegration.js +173 -0
- package/dist/mcp/FigmaMCPIntegration.js.map +1 -0
- package/dist/mcp/MCPServiceManager.d.ts +109 -0
- package/dist/mcp/MCPServiceManager.d.ts.map +1 -0
- package/dist/mcp/MCPServiceManager.js +237 -0
- package/dist/mcp/MCPServiceManager.js.map +1 -0
- package/dist/mcp/MCPToolAdapter.d.ts +73 -0
- package/dist/mcp/MCPToolAdapter.d.ts.map +1 -0
- package/dist/mcp/MCPToolAdapter.js +249 -0
- package/dist/mcp/MCPToolAdapter.js.map +1 -0
- package/dist/mcp/index.d.ts +7 -0
- package/dist/mcp/index.d.ts.map +1 -0
- package/dist/mcp/index.js +23 -0
- package/dist/mcp/index.js.map +1 -0
- package/dist/mcp-server/MCPServer.d.ts +125 -0
- package/dist/mcp-server/MCPServer.d.ts.map +1 -0
- package/dist/mcp-server/MCPServer.js +449 -0
- package/dist/mcp-server/MCPServer.js.map +1 -0
- package/dist/mcp-server/index.d.ts +5 -0
- package/dist/mcp-server/index.d.ts.map +1 -0
- package/dist/mcp-server/index.js +21 -0
- package/dist/mcp-server/index.js.map +1 -0
- package/dist/monitoring/ExecutionSummary.d.ts +160 -0
- package/dist/monitoring/ExecutionSummary.d.ts.map +1 -0
- package/dist/monitoring/ExecutionSummary.js +345 -0
- package/dist/monitoring/ExecutionSummary.js.map +1 -0
- package/dist/monitoring/Logger.d.ts +139 -0
- package/dist/monitoring/Logger.d.ts.map +1 -0
- package/dist/monitoring/Logger.js +406 -0
- package/dist/monitoring/Logger.js.map +1 -0
- package/dist/monitoring/index.d.ts +6 -0
- package/dist/monitoring/index.d.ts.map +1 -0
- package/dist/monitoring/index.js +22 -0
- package/dist/monitoring/index.js.map +1 -0
- package/dist/performance/LLMCache.d.ts +133 -0
- package/dist/performance/LLMCache.d.ts.map +1 -0
- package/dist/performance/LLMCache.js +358 -0
- package/dist/performance/LLMCache.js.map +1 -0
- package/dist/performance/ParallelProcessor.d.ts +89 -0
- package/dist/performance/ParallelProcessor.d.ts.map +1 -0
- package/dist/performance/ParallelProcessor.js +253 -0
- package/dist/performance/ParallelProcessor.js.map +1 -0
- package/dist/performance/TokenMonitor.d.ts +166 -0
- package/dist/performance/TokenMonitor.d.ts.map +1 -0
- package/dist/performance/TokenMonitor.js +315 -0
- package/dist/performance/TokenMonitor.js.map +1 -0
- package/dist/performance/index.d.ts +7 -0
- package/dist/performance/index.d.ts.map +1 -0
- package/dist/performance/index.js +23 -0
- package/dist/performance/index.js.map +1 -0
- package/dist/prototype/InteractivePrototypeGenerator.d.ts +175 -0
- package/dist/prototype/InteractivePrototypeGenerator.d.ts.map +1 -0
- package/dist/prototype/InteractivePrototypeGenerator.js +624 -0
- package/dist/prototype/InteractivePrototypeGenerator.js.map +1 -0
- package/dist/prototype/index.d.ts +5 -0
- package/dist/prototype/index.d.ts.map +1 -0
- package/dist/prototype/index.js +21 -0
- package/dist/prototype/index.js.map +1 -0
- package/dist/skill/SkillConfig.d.ts +66 -0
- package/dist/skill/SkillConfig.d.ts.map +1 -0
- package/dist/skill/SkillConfig.js +233 -0
- package/dist/skill/SkillConfig.js.map +1 -0
- package/dist/skill/SkillInterface.d.ts +102 -0
- package/dist/skill/SkillInterface.d.ts.map +1 -0
- package/dist/skill/SkillInterface.js +425 -0
- package/dist/skill/SkillInterface.js.map +1 -0
- package/dist/skill/index.d.ts +7 -0
- package/dist/skill/index.d.ts.map +1 -0
- package/dist/skill/index.js +23 -0
- package/dist/skill/index.js.map +1 -0
- package/dist/skill/types.d.ts +103 -0
- package/dist/skill/types.d.ts.map +1 -0
- package/dist/skill/types.js +6 -0
- package/dist/skill/types.js.map +1 -0
- package/dist/templates/TemplateManager.d.ts +147 -0
- package/dist/templates/TemplateManager.d.ts.map +1 -0
- package/dist/templates/TemplateManager.js +418 -0
- package/dist/templates/TemplateManager.js.map +1 -0
- package/dist/templates/index.d.ts +6 -0
- package/dist/templates/index.d.ts.map +1 -0
- package/dist/templates/index.js +10 -0
- package/dist/templates/index.js.map +1 -0
- package/dist/tools/CodeGenerationTool.d.ts +32 -0
- package/dist/tools/CodeGenerationTool.d.ts.map +1 -0
- package/dist/tools/CodeGenerationTool.js +63 -0
- package/dist/tools/CodeGenerationTool.js.map +1 -0
- package/dist/tools/FigmaExtractionTool.d.ts +45 -0
- package/dist/tools/FigmaExtractionTool.d.ts.map +1 -0
- package/dist/tools/FigmaExtractionTool.js +105 -0
- package/dist/tools/FigmaExtractionTool.js.map +1 -0
- package/dist/tools/ProjectAnalysisTool.d.ts +104 -0
- package/dist/tools/ProjectAnalysisTool.d.ts.map +1 -0
- package/dist/tools/ProjectAnalysisTool.js +428 -0
- package/dist/tools/ProjectAnalysisTool.js.map +1 -0
- package/dist/tools/ToolRegistry.d.ts +59 -0
- package/dist/tools/ToolRegistry.d.ts.map +1 -0
- package/dist/tools/ToolRegistry.js +162 -0
- package/dist/tools/ToolRegistry.js.map +1 -0
- package/dist/tools/TransformationTool.d.ts +30 -0
- package/dist/tools/TransformationTool.d.ts.map +1 -0
- package/dist/tools/TransformationTool.js +50 -0
- package/dist/tools/TransformationTool.js.map +1 -0
- package/dist/tools/index.d.ts +10 -0
- package/dist/tools/index.d.ts.map +1 -0
- package/dist/tools/index.js +32 -0
- package/dist/tools/index.js.map +1 -0
- package/dist/tools/types.d.ts +74 -0
- package/dist/tools/types.d.ts.map +1 -0
- package/dist/tools/types.js +6 -0
- package/dist/tools/types.js.map +1 -0
- package/dist/transformation/transformers/LayoutOptimizer.d.ts +8 -0
- package/dist/transformation/transformers/LayoutOptimizer.d.ts.map +1 -1
- package/dist/transformation/transformers/LayoutOptimizer.js +157 -15
- package/dist/transformation/transformers/LayoutOptimizer.js.map +1 -1
- package/dist/version/VersionManager.d.ts +128 -0
- package/dist/version/VersionManager.d.ts.map +1 -0
- package/dist/version/VersionManager.js +400 -0
- package/dist/version/VersionManager.js.map +1 -0
- package/dist/version/index.d.ts +5 -0
- package/dist/version/index.d.ts.map +1 -0
- package/dist/version/index.js +21 -0
- package/dist/version/index.js.map +1 -0
- package/package.json +3 -1
- package/QUICKSTART.md +0 -178
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.CodeGenerationTool = void 0;
|
|
4
|
+
const ReactGenerator_1 = require("../generation/ReactGenerator");
|
|
5
|
+
const VueGenerator_1 = require("../generation/VueGenerator");
|
|
6
|
+
/**
|
|
7
|
+
* 代码生成工具
|
|
8
|
+
* 封装 ReactGenerator 和 VueGenerator
|
|
9
|
+
*/
|
|
10
|
+
class CodeGenerationTool {
|
|
11
|
+
constructor() {
|
|
12
|
+
this.name = 'code-generation';
|
|
13
|
+
this.description = 'Generate React or Vue code from AST';
|
|
14
|
+
this.category = 'generation';
|
|
15
|
+
this.capabilities = ['generate_react', 'generate_vue', 'generate_components'];
|
|
16
|
+
this.reactGenerator = new ReactGenerator_1.ReactGenerator();
|
|
17
|
+
this.vueGenerator = new VueGenerator_1.VueGenerator();
|
|
18
|
+
}
|
|
19
|
+
/**
|
|
20
|
+
* 检查工具是否可用
|
|
21
|
+
*/
|
|
22
|
+
async isAvailable() {
|
|
23
|
+
return true;
|
|
24
|
+
}
|
|
25
|
+
/**
|
|
26
|
+
* 执行工具
|
|
27
|
+
*/
|
|
28
|
+
async execute(inputs) {
|
|
29
|
+
const { node, config } = inputs;
|
|
30
|
+
if (!node) {
|
|
31
|
+
throw new Error('AST node is required');
|
|
32
|
+
}
|
|
33
|
+
if (!config) {
|
|
34
|
+
throw new Error('Generator config is required');
|
|
35
|
+
}
|
|
36
|
+
// 根据框架选择生成器
|
|
37
|
+
const framework = config.framework || 'react';
|
|
38
|
+
if (framework === 'vue') {
|
|
39
|
+
return this.vueGenerator.generate(node, config);
|
|
40
|
+
}
|
|
41
|
+
else {
|
|
42
|
+
return this.reactGenerator.generate(node, config);
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
/**
|
|
46
|
+
* 获取工具元数据
|
|
47
|
+
*/
|
|
48
|
+
getMetadata() {
|
|
49
|
+
return {
|
|
50
|
+
version: '1.0.0',
|
|
51
|
+
author: 'Figma-to-Code Agent',
|
|
52
|
+
performance: {
|
|
53
|
+
avgDuration: 1000, // 平均 1 秒
|
|
54
|
+
reliability: 0.95,
|
|
55
|
+
},
|
|
56
|
+
cost: {
|
|
57
|
+
apiCallsPerExecution: 0, // 不需要 API 调用
|
|
58
|
+
},
|
|
59
|
+
};
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
exports.CodeGenerationTool = CodeGenerationTool;
|
|
63
|
+
//# sourceMappingURL=CodeGenerationTool.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CodeGenerationTool.js","sourceRoot":"","sources":["../../src/tools/CodeGenerationTool.ts"],"names":[],"mappings":";;;AAAA,iEAA8D;AAC9D,6DAA0D;AAK1D;;;GAGG;AACH,MAAa,kBAAkB;IAS7B;QARA,SAAI,GAAG,iBAAiB,CAAC;QACzB,gBAAW,GAAG,qCAAqC,CAAC;QACpD,aAAQ,GAAG,YAAqB,CAAC;QACjC,iBAAY,GAAG,CAAC,gBAAgB,EAAE,cAAc,EAAE,qBAAqB,CAAC,CAAC;QAMvE,IAAI,CAAC,cAAc,GAAG,IAAI,+BAAc,EAAE,CAAC;QAC3C,IAAI,CAAC,YAAY,GAAG,IAAI,2BAAY,EAAE,CAAC;IACzC,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,WAAW;QACf,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,OAAO,CAAC,MAGb;QACC,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,MAAM,CAAC;QAEhC,IAAI,CAAC,IAAI,EAAE,CAAC;YACV,MAAM,IAAI,KAAK,CAAC,sBAAsB,CAAC,CAAC;QAC1C,CAAC;QAED,IAAI,CAAC,MAAM,EAAE,CAAC;YACZ,MAAM,IAAI,KAAK,CAAC,8BAA8B,CAAC,CAAC;QAClD,CAAC;QAED,YAAY;QACZ,MAAM,SAAS,GAAG,MAAM,CAAC,SAAS,IAAI,OAAO,CAAC;QAE9C,IAAI,SAAS,KAAK,KAAK,EAAE,CAAC;YACxB,OAAO,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;QAClD,CAAC;aAAM,CAAC;YACN,OAAO,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;QACpD,CAAC;IACH,CAAC;IAED;;OAEG;IACH,WAAW;QACT,OAAO;YACL,OAAO,EAAE,OAAO;YAChB,MAAM,EAAE,qBAAqB;YAC7B,WAAW,EAAE;gBACX,WAAW,EAAE,IAAI,EAAE,SAAS;gBAC5B,WAAW,EAAE,IAAI;aAClB;YACD,IAAI,EAAE;gBACJ,oBAAoB,EAAE,CAAC,EAAE,aAAa;aACvC;SACF,CAAC;IACJ,CAAC;CACF;AAhED,gDAgEC"}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import { FigmaAPIClient } from '../extraction/FigmaAPIClient';
|
|
2
|
+
import { MCPClient } from '../extraction/MCPClient';
|
|
3
|
+
import type { Tool, ToolMetadata } from './types';
|
|
4
|
+
import type { FigmaInput } from '../agent/types';
|
|
5
|
+
/**
|
|
6
|
+
* Figma 数据提取工具
|
|
7
|
+
* 封装 FigmaAPIClient 和 MCPClient
|
|
8
|
+
*/
|
|
9
|
+
export declare class FigmaExtractionTool implements Tool {
|
|
10
|
+
private figmaClient;
|
|
11
|
+
private mcpClient?;
|
|
12
|
+
name: string;
|
|
13
|
+
description: string;
|
|
14
|
+
category: "extraction";
|
|
15
|
+
capabilities: string[];
|
|
16
|
+
constructor(figmaClient: FigmaAPIClient, mcpClient?: MCPClient | undefined);
|
|
17
|
+
/**
|
|
18
|
+
* 检查工具是否可用
|
|
19
|
+
*/
|
|
20
|
+
isAvailable(): Promise<boolean>;
|
|
21
|
+
/**
|
|
22
|
+
* 执行工具
|
|
23
|
+
*/
|
|
24
|
+
execute(inputs: {
|
|
25
|
+
figmaInput: FigmaInput;
|
|
26
|
+
includeImages?: boolean;
|
|
27
|
+
}): Promise<any>;
|
|
28
|
+
/**
|
|
29
|
+
* 获取工具元数据
|
|
30
|
+
*/
|
|
31
|
+
getMetadata(): ToolMetadata;
|
|
32
|
+
/**
|
|
33
|
+
* 通过 MCP 提取
|
|
34
|
+
*/
|
|
35
|
+
private extractViaMCP;
|
|
36
|
+
/**
|
|
37
|
+
* 通过 API 提取
|
|
38
|
+
*/
|
|
39
|
+
private extractViaAPI;
|
|
40
|
+
/**
|
|
41
|
+
* 从 URL 提取文件 key
|
|
42
|
+
*/
|
|
43
|
+
private extractFileKeyFromUrl;
|
|
44
|
+
}
|
|
45
|
+
//# sourceMappingURL=FigmaExtractionTool.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FigmaExtractionTool.d.ts","sourceRoot":"","sources":["../../src/tools/FigmaExtractionTool.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,8BAA8B,CAAC;AAC9D,OAAO,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAC;AACpD,OAAO,KAAK,EAAE,IAAI,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAClD,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAEjD;;;GAGG;AACH,qBAAa,mBAAoB,YAAW,IAAI;IAO5C,OAAO,CAAC,WAAW;IACnB,OAAO,CAAC,SAAS,CAAC;IAPpB,IAAI,SAAsB;IAC1B,WAAW,SAAoC;IAC/C,QAAQ,EAAG,YAAY,CAAU;IACjC,YAAY,WAAwD;gBAG1D,WAAW,EAAE,cAAc,EAC3B,SAAS,CAAC,EAAE,SAAS,YAAA;IAG/B;;OAEG;IACG,WAAW,IAAI,OAAO,CAAC,OAAO,CAAC;IASrC;;OAEG;IACG,OAAO,CAAC,MAAM,EAAE;QACpB,UAAU,EAAE,UAAU,CAAC;QACvB,aAAa,CAAC,EAAE,OAAO,CAAC;KACzB,GAAG,OAAO,CAAC,GAAG,CAAC;IAiBhB;;OAEG;IACH,WAAW,IAAI,YAAY;IAc3B;;OAEG;YACW,aAAa;IAY3B;;OAEG;YACW,aAAa;IAyB3B;;OAEG;IACH,OAAO,CAAC,qBAAqB;CAM9B"}
|
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.FigmaExtractionTool = void 0;
|
|
4
|
+
/**
|
|
5
|
+
* Figma 数据提取工具
|
|
6
|
+
* 封装 FigmaAPIClient 和 MCPClient
|
|
7
|
+
*/
|
|
8
|
+
class FigmaExtractionTool {
|
|
9
|
+
constructor(figmaClient, mcpClient) {
|
|
10
|
+
this.figmaClient = figmaClient;
|
|
11
|
+
this.mcpClient = mcpClient;
|
|
12
|
+
this.name = 'figma-extraction';
|
|
13
|
+
this.description = 'Extract design data from Figma';
|
|
14
|
+
this.category = 'extraction';
|
|
15
|
+
this.capabilities = ['extract_design', 'parse_figma', 'download_images'];
|
|
16
|
+
}
|
|
17
|
+
/**
|
|
18
|
+
* 检查工具是否可用
|
|
19
|
+
*/
|
|
20
|
+
async isAvailable() {
|
|
21
|
+
try {
|
|
22
|
+
// Figma API client is always available if constructed with a token
|
|
23
|
+
return true;
|
|
24
|
+
}
|
|
25
|
+
catch {
|
|
26
|
+
return false;
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
/**
|
|
30
|
+
* 执行工具
|
|
31
|
+
*/
|
|
32
|
+
async execute(inputs) {
|
|
33
|
+
const { figmaInput, includeImages = true } = inputs;
|
|
34
|
+
// 优先使用 MCP,如果可用
|
|
35
|
+
if (this.mcpClient && await this.mcpClient.isConnected()) {
|
|
36
|
+
try {
|
|
37
|
+
return await this.extractViaMCP(figmaInput, includeImages);
|
|
38
|
+
}
|
|
39
|
+
catch (error) {
|
|
40
|
+
console.warn('MCP extraction failed, falling back to API:', error);
|
|
41
|
+
// 回退到 API
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
// 使用 Figma API
|
|
45
|
+
return await this.extractViaAPI(figmaInput, includeImages);
|
|
46
|
+
}
|
|
47
|
+
/**
|
|
48
|
+
* 获取工具元数据
|
|
49
|
+
*/
|
|
50
|
+
getMetadata() {
|
|
51
|
+
return {
|
|
52
|
+
version: '1.0.0',
|
|
53
|
+
author: 'Figma-to-Code Agent',
|
|
54
|
+
performance: {
|
|
55
|
+
avgDuration: 2000, // 平均 2 秒
|
|
56
|
+
reliability: 0.95,
|
|
57
|
+
},
|
|
58
|
+
cost: {
|
|
59
|
+
apiCallsPerExecution: 1,
|
|
60
|
+
},
|
|
61
|
+
};
|
|
62
|
+
}
|
|
63
|
+
/**
|
|
64
|
+
* 通过 MCP 提取
|
|
65
|
+
*/
|
|
66
|
+
async extractViaMCP(_figmaInput, _includeImages) {
|
|
67
|
+
if (!this.mcpClient) {
|
|
68
|
+
throw new Error('MCP client not available');
|
|
69
|
+
}
|
|
70
|
+
// MCP currently only supports getting the current file
|
|
71
|
+
return await this.mcpClient.getCurrentFile();
|
|
72
|
+
}
|
|
73
|
+
/**
|
|
74
|
+
* 通过 API 提取
|
|
75
|
+
*/
|
|
76
|
+
async extractViaAPI(figmaInput, includeImages) {
|
|
77
|
+
const fileKey = figmaInput.fileKey || this.extractFileKeyFromUrl(figmaInput.url);
|
|
78
|
+
if (!fileKey) {
|
|
79
|
+
throw new Error('No file key provided');
|
|
80
|
+
}
|
|
81
|
+
// 获取文件数据
|
|
82
|
+
const fileData = await this.figmaClient.getFile(fileKey);
|
|
83
|
+
// 下载图片(如果需要)
|
|
84
|
+
let images = {};
|
|
85
|
+
if (includeImages && figmaInput.nodeIds && figmaInput.nodeIds.length > 0) {
|
|
86
|
+
const imageMap = await this.figmaClient.getImages(fileKey, figmaInput.nodeIds);
|
|
87
|
+
images = imageMap.images || {};
|
|
88
|
+
}
|
|
89
|
+
return {
|
|
90
|
+
file: fileData,
|
|
91
|
+
images,
|
|
92
|
+
};
|
|
93
|
+
}
|
|
94
|
+
/**
|
|
95
|
+
* 从 URL 提取文件 key
|
|
96
|
+
*/
|
|
97
|
+
extractFileKeyFromUrl(url) {
|
|
98
|
+
if (!url)
|
|
99
|
+
return null;
|
|
100
|
+
const match = url.match(/figma\.com\/(?:file|design)\/([a-zA-Z0-9]+)/);
|
|
101
|
+
return match ? match[1] : null;
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
exports.FigmaExtractionTool = FigmaExtractionTool;
|
|
105
|
+
//# sourceMappingURL=FigmaExtractionTool.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FigmaExtractionTool.js","sourceRoot":"","sources":["../../src/tools/FigmaExtractionTool.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
import type { Tool, ToolMetadata } from './types';
|
|
2
|
+
export interface ProjectAnalysisResult {
|
|
3
|
+
framework?: 'react' | 'vue' | 'unknown';
|
|
4
|
+
hasTypeScript: boolean;
|
|
5
|
+
hasESLint: boolean;
|
|
6
|
+
hasPrettier: boolean;
|
|
7
|
+
hasTailwind: boolean;
|
|
8
|
+
dependencies: Record<string, string>;
|
|
9
|
+
devDependencies: Record<string, string>;
|
|
10
|
+
codeStyle?: {
|
|
11
|
+
indent: 'spaces' | 'tabs';
|
|
12
|
+
indentSize?: number;
|
|
13
|
+
quotes: 'single' | 'double';
|
|
14
|
+
semi: boolean;
|
|
15
|
+
};
|
|
16
|
+
pathAliases?: Record<string, string>;
|
|
17
|
+
components?: ComponentInfo[];
|
|
18
|
+
srcDirectory?: string;
|
|
19
|
+
}
|
|
20
|
+
export interface ComponentInfo {
|
|
21
|
+
name: string;
|
|
22
|
+
path: string;
|
|
23
|
+
type: 'component' | 'page' | 'layout';
|
|
24
|
+
framework: 'react' | 'vue';
|
|
25
|
+
hasStyles: boolean;
|
|
26
|
+
hasTests: boolean;
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* 项目分析工具
|
|
30
|
+
* 分析项目结构、框架、代码风格等
|
|
31
|
+
*/
|
|
32
|
+
export declare class ProjectAnalysisTool implements Tool {
|
|
33
|
+
private projectRoot;
|
|
34
|
+
name: string;
|
|
35
|
+
description: string;
|
|
36
|
+
category: "analysis";
|
|
37
|
+
capabilities: string[];
|
|
38
|
+
constructor(projectRoot: string);
|
|
39
|
+
/**
|
|
40
|
+
* 检查工具是否可用
|
|
41
|
+
*/
|
|
42
|
+
isAvailable(): Promise<boolean>;
|
|
43
|
+
/**
|
|
44
|
+
* 执行工具
|
|
45
|
+
*/
|
|
46
|
+
execute(): Promise<ProjectAnalysisResult>;
|
|
47
|
+
/**
|
|
48
|
+
* 获取工具元数据
|
|
49
|
+
*/
|
|
50
|
+
getMetadata(): ToolMetadata;
|
|
51
|
+
/**
|
|
52
|
+
* 分析 Prettier 配置
|
|
53
|
+
*/
|
|
54
|
+
private analyzePrettierConfig;
|
|
55
|
+
/**
|
|
56
|
+
* 分析 ESLint 配置
|
|
57
|
+
*/
|
|
58
|
+
private analyzeESLintConfig;
|
|
59
|
+
/**
|
|
60
|
+
* 分析路径别名
|
|
61
|
+
*/
|
|
62
|
+
private analyzePathAliases;
|
|
63
|
+
/**
|
|
64
|
+
* 解析 JS 配置文件(简单实现)
|
|
65
|
+
*/
|
|
66
|
+
private parseJSConfig;
|
|
67
|
+
/**
|
|
68
|
+
* 提取缩进大小
|
|
69
|
+
*/
|
|
70
|
+
private extractIndentSize;
|
|
71
|
+
/**
|
|
72
|
+
* 提取引号风格
|
|
73
|
+
*/
|
|
74
|
+
private extractQuotes;
|
|
75
|
+
/**
|
|
76
|
+
* 提取分号规则
|
|
77
|
+
*/
|
|
78
|
+
private extractSemi;
|
|
79
|
+
/**
|
|
80
|
+
* 查找 src 目录
|
|
81
|
+
*/
|
|
82
|
+
private findSrcDirectory;
|
|
83
|
+
/**
|
|
84
|
+
* 发现项目中的组件
|
|
85
|
+
*/
|
|
86
|
+
private discoverComponents;
|
|
87
|
+
/**
|
|
88
|
+
* 递归扫描目录查找组件
|
|
89
|
+
*/
|
|
90
|
+
private scanDirectory;
|
|
91
|
+
/**
|
|
92
|
+
* 分析单个组件文件
|
|
93
|
+
*/
|
|
94
|
+
private analyzeComponent;
|
|
95
|
+
/**
|
|
96
|
+
* 检查是否有对应的样式文件
|
|
97
|
+
*/
|
|
98
|
+
private hasStyleFile;
|
|
99
|
+
/**
|
|
100
|
+
* 检查是否有对应的测试文件
|
|
101
|
+
*/
|
|
102
|
+
private hasTestFile;
|
|
103
|
+
}
|
|
104
|
+
//# sourceMappingURL=ProjectAnalysisTool.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ProjectAnalysisTool.d.ts","sourceRoot":"","sources":["../../src/tools/ProjectAnalysisTool.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,IAAI,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAElD,MAAM,WAAW,qBAAqB;IACpC,SAAS,CAAC,EAAE,OAAO,GAAG,KAAK,GAAG,SAAS,CAAC;IACxC,aAAa,EAAE,OAAO,CAAC;IACvB,SAAS,EAAE,OAAO,CAAC;IACnB,WAAW,EAAE,OAAO,CAAC;IACrB,WAAW,EAAE,OAAO,CAAC;IACrB,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACrC,eAAe,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACxC,SAAS,CAAC,EAAE;QACV,MAAM,EAAE,QAAQ,GAAG,MAAM,CAAC;QAC1B,UAAU,CAAC,EAAE,MAAM,CAAC;QACpB,MAAM,EAAE,QAAQ,GAAG,QAAQ,CAAC;QAC5B,IAAI,EAAE,OAAO,CAAC;KACf,CAAC;IACF,WAAW,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACrC,UAAU,CAAC,EAAE,aAAa,EAAE,CAAC;IAC7B,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB;AAED,MAAM,WAAW,aAAa;IAC5B,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,WAAW,GAAG,MAAM,GAAG,QAAQ,CAAC;IACtC,SAAS,EAAE,OAAO,GAAG,KAAK,CAAC;IAC3B,SAAS,EAAE,OAAO,CAAC;IACnB,QAAQ,EAAE,OAAO,CAAC;CACnB;AAED;;;GAGG;AACH,qBAAa,mBAAoB,YAAW,IAAI;IAMlC,OAAO,CAAC,WAAW;IAL/B,IAAI,SAAsB;IAC1B,WAAW,SAA8C;IACzD,QAAQ,EAAG,UAAU,CAAU;IAC/B,YAAY,WAA8D;gBAEtD,WAAW,EAAE,MAAM;IAEvC;;OAEG;IACG,WAAW,IAAI,OAAO,CAAC,OAAO,CAAC;IASrC;;OAEG;IACG,OAAO,IAAI,OAAO,CAAC,qBAAqB,CAAC;IAmE/C;;OAEG;IACH,WAAW,IAAI,YAAY;IAc3B;;OAEG;IACH,OAAO,CAAC,qBAAqB;IA8B7B;;OAEG;IACH,OAAO,CAAC,mBAAmB;IA+B3B;;OAEG;IACH,OAAO,CAAC,kBAAkB;IAwC1B;;OAEG;IACH,OAAO,CAAC,aAAa;IAerB;;OAEG;IACH,OAAO,CAAC,iBAAiB;IAOzB;;OAEG;IACH,OAAO,CAAC,aAAa;IAOrB;;OAEG;IACH,OAAO,CAAC,WAAW;IAOnB;;OAEG;IACH,OAAO,CAAC,gBAAgB;IAaxB;;OAEG;IACH,OAAO,CAAC,kBAAkB;IAiB1B;;OAEG;IACH,OAAO,CAAC,aAAa;IA2CrB;;OAEG;IACH,OAAO,CAAC,gBAAgB;IAoCxB;;OAEG;IACH,OAAO,CAAC,YAAY;IAgBpB;;OAEG;IACH,OAAO,CAAC,WAAW;CAkCpB"}
|