mirror of
https://github.com/nextlevelbuilder/ui-ux-pro-max-skill.git
synced 2026-04-25 11:18:17 +00:00
- Remove .shared folder dependency - all platforms now self-contained - Each platform installation includes its own data/ and scripts/ - Update platform configs: reference → full install type - Simplify template.ts: remove ensureSharedExists logic - Update Cursor to Skill Mode (auto-activate) - Update README to reflect Cursor in Skill Mode - Bump CLI version to 2.2.2 Fixes issue where users couldn't find search.py in shared folder. Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
101 lines
2.6 KiB
TypeScript
101 lines
2.6 KiB
TypeScript
import { existsSync } from 'node:fs';
|
|
import { join } from 'node:path';
|
|
import type { AIType } from '../types/index.js';
|
|
|
|
interface DetectionResult {
|
|
detected: AIType[];
|
|
suggested: AIType | null;
|
|
}
|
|
|
|
export function detectAIType(cwd: string = process.cwd()): DetectionResult {
|
|
const detected: AIType[] = [];
|
|
|
|
if (existsSync(join(cwd, '.claude'))) {
|
|
detected.push('claude');
|
|
}
|
|
if (existsSync(join(cwd, '.cursor'))) {
|
|
detected.push('cursor');
|
|
}
|
|
if (existsSync(join(cwd, '.windsurf'))) {
|
|
detected.push('windsurf');
|
|
}
|
|
if (existsSync(join(cwd, '.agent'))) {
|
|
detected.push('antigravity');
|
|
}
|
|
if (existsSync(join(cwd, '.github'))) {
|
|
detected.push('copilot');
|
|
}
|
|
if (existsSync(join(cwd, '.kiro'))) {
|
|
detected.push('kiro');
|
|
}
|
|
if (existsSync(join(cwd, '.codex'))) {
|
|
detected.push('codex');
|
|
}
|
|
if (existsSync(join(cwd, '.roo'))) {
|
|
detected.push('roocode');
|
|
}
|
|
if (existsSync(join(cwd, '.qoder'))) {
|
|
detected.push('qoder');
|
|
}
|
|
if (existsSync(join(cwd, '.gemini'))) {
|
|
detected.push('gemini');
|
|
}
|
|
if (existsSync(join(cwd, '.trae'))) {
|
|
detected.push('trae');
|
|
}
|
|
if (existsSync(join(cwd, '.opencode'))) {
|
|
detected.push('opencode');
|
|
}
|
|
if (existsSync(join(cwd, '.continue'))) {
|
|
detected.push('continue');
|
|
}
|
|
if (existsSync(join(cwd, '.codebuddy'))) {
|
|
detected.push('codebuddy');
|
|
}
|
|
|
|
// Suggest based on what's detected
|
|
let suggested: AIType | null = null;
|
|
if (detected.length === 1) {
|
|
suggested = detected[0];
|
|
} else if (detected.length > 1) {
|
|
suggested = 'all';
|
|
}
|
|
|
|
return { detected, suggested };
|
|
}
|
|
|
|
export function getAITypeDescription(aiType: AIType): string {
|
|
switch (aiType) {
|
|
case 'claude':
|
|
return 'Claude Code (.claude/skills/)';
|
|
case 'cursor':
|
|
return 'Cursor (.cursor/skills/)';
|
|
case 'windsurf':
|
|
return 'Windsurf (.windsurf/skills/)';
|
|
case 'antigravity':
|
|
return 'Antigravity (.agent/skills/)';
|
|
case 'copilot':
|
|
return 'GitHub Copilot (.github/prompts/)';
|
|
case 'kiro':
|
|
return 'Kiro (.kiro/steering/)';
|
|
case 'codex':
|
|
return 'Codex (.codex/skills/)';
|
|
case 'roocode':
|
|
return 'RooCode (.roo/skills/)';
|
|
case 'qoder':
|
|
return 'Qoder (.qoder/skills/)';
|
|
case 'gemini':
|
|
return 'Gemini CLI (.gemini/skills/)';
|
|
case 'trae':
|
|
return 'Trae (.trae/skills/)';
|
|
case 'opencode':
|
|
return 'OpenCode (.opencode/skills/)';
|
|
case 'continue':
|
|
return 'Continue (.continue/skills/)';
|
|
case 'codebuddy':
|
|
return 'CodeBuddy (.codebuddy/skills/)';
|
|
case 'all':
|
|
return 'All AI assistants';
|
|
}
|
|
}
|