0
0

修复了合并的第一个BUG,两个类型文件的命名问题

This commit is contained in:
xubing
2025-11-27 20:22:29 +08:00
parent 97c897962f
commit d0ea028e3e
6 changed files with 118 additions and 76 deletions

View File

@@ -207,7 +207,7 @@ class ConfigPanel {
await this.importGitFile(data.filePath); await this.importGitFile(data.filePath);
break; break;
case 'openGitRepoInVSCode': case 'openGitRepoInVSCode':
await this.openGitRepoInVSCode(data.repoId); await this.openTheModuleFolder('git', data.repoId);
break; break;
case 'openConfigFileInVSCode': case 'openConfigFileInVSCode':
await this.openConfigFileInVSCode(data.configId); await this.openConfigFileInVSCode(data.configId);
@@ -219,10 +219,13 @@ class ConfigPanel {
await this.deleteMergedFolder(data.folderId); await this.deleteMergedFolder(data.folderId);
break; break;
case 'openMergedFolderInVSCode': case 'openMergedFolderInVSCode':
await this.openMergedFolderInVSCode(data.folderId); await this.openTheModuleFolder('merged', data.folderId);
break; break;
case 'loadMergedFolder': case 'loadMergedFolder':
await this.loadMergedFolder(data.folderId); await this.openTheModuleFolder('merged', data.folderId);
break;
case 'openTheModuleFolder':
await this.openTheModuleFolder(data.moduleType, data.id);
break; break;
} }
} }
@@ -1504,26 +1507,50 @@ class ConfigPanel {
vscode.window.showErrorMessage(`打开合并文件夹失败: ${error}`); vscode.window.showErrorMessage(`打开合并文件夹失败: ${error}`);
} }
} }
async loadMergedFolder(folderId) { /**
const folder = this.mergedFolders.find(f => f.id === folderId); * 统一方法:在 VSCode 中打开模块文件夹中的文件
if (!folder) { * @param type 模块类型:'git' 或 'merged'
vscode.window.showErrorMessage('未找到指定的合并文件夹'); * @param id 模块 ID
*/
async openTheModuleFolder(type, id) {
let folderPath;
let folderName;
if (type === 'git') {
const repo = this.gitRepos.find(r => r.id === id);
if (!repo) {
vscode.window.showErrorMessage('未找到指定的 Git 仓库');
return;
}
folderPath = repo.localPath;
folderName = repo.name;
}
else if (type === 'merged') {
const folder = this.mergedFolders.find(f => f.id === id);
if (!folder) {
vscode.window.showErrorMessage('未找到指定的合并文件夹');
return;
}
folderPath = folder.path;
folderName = folder.displayName;
}
if (!folderPath) {
vscode.window.showErrorMessage('未找到文件夹路径');
return; return;
} }
try { try {
// 检查文件夹是否存在 // 检查文件夹是否存在
if (!fs.existsSync(folder.path)) { if (!fs.existsSync(folderPath)) {
vscode.window.showErrorMessage('合并文件夹目录不存在'); vscode.window.showErrorMessage(`${type === 'git' ? 'Git 仓库' : '合并文件夹'}目录不存在`);
return; return;
} }
// 使用 VSCode 的文件选择器让用户选择要打开的文件 // 使用 VSCode 的文件选择器让用户选择要打开的文件
const fileUri = await vscode.window.showOpenDialog({ const fileUri = await vscode.window.showOpenDialog({
defaultUri: vscode.Uri.file(folder.path), defaultUri: vscode.Uri.file(folderPath),
canSelectFiles: true, canSelectFiles: true,
canSelectFolders: false, canSelectFolders: false,
canSelectMany: false, canSelectMany: false,
openLabel: '选择要打开的文件', openLabel: '选择要打开的文件',
title: `合并文件夹 ${folder.displayName} 中选择文件` title: `${folderName} 中选择文件`
}); });
if (fileUri && fileUri.length > 0) { if (fileUri && fileUri.length > 0) {
// 打开选中的文件 // 打开选中的文件
@@ -1533,7 +1560,7 @@ class ConfigPanel {
} }
} }
catch (error) { catch (error) {
vscode.window.showErrorMessage(`打开合并文件夹文件失败: ${error}`); vscode.window.showErrorMessage(`打开${type === 'git' ? 'Git 仓库' : '合并文件夹'}文件失败: ${error}`);
} }
} }
} }

File diff suppressed because one or more lines are too long

View File

@@ -38,7 +38,7 @@ class ConfigView extends BaseView_1.BaseView {
</div> </div>
</td> </td>
<td> <td>
<span class="clickable" onclick="loadMergedFolder('${folder.id}')">${folder.folderName}</span> <span class="clickable" onclick="openTheModuleFolder('${folder.id}', 'merged')">${folder.folderName}</span>
</td> </td>
<td> <td>
<button class="btn-delete" onclick="deleteMergedFolder('${folder.id}')">删除</button> <button class="btn-delete" onclick="deleteMergedFolder('${folder.id}')">删除</button>
@@ -60,7 +60,7 @@ class ConfigView extends BaseView_1.BaseView {
</div> </div>
</td> </td>
<td> <td>
<span class="clickable" onclick="openGitRepoInVSCode('${repo.id}')">${branchName}</span> <span class="clickable" onclick="openTheModuleFolder('${repo.id}', 'git')">${branchName}</span>
</td> </td>
<td> <td>
<button class="btn-delete" onclick="deleteGitRepo('${repo.id}')">删除</button> <button class="btn-delete" onclick="deleteGitRepo('${repo.id}')">删除</button>
@@ -325,22 +325,15 @@ class ConfigView extends BaseView_1.BaseView {
} }
// 功能:加载合并文件夹( Git 仓库行为一致 // 统一功能:打开模块文件夹(合并 Git 仓库和合并文件夹功能
function loadMergedFolder(folderId) { function openTheModuleFolder(id, type) {
console.log('📂 加载合并文件夹:', folderId); console.log('📂 打开模块文件夹:', { id, type });
vscode.postMessage({ vscode.postMessage({
type: 'loadMergedFolder', type: 'openTheModuleFolder',
folderId: folderId id: id,
moduleType: type
}); });
} }
function openGitRepoInVSCode(repoId) {
console.log('📂 在 VSCode 中打开 Git 仓库文件选择器:', repoId);
vscode.postMessage({
type: 'openGitRepoInVSCode',
repoId: repoId
});
}
function createNewConfig() { function createNewConfig() {
showPromptDialog( showPromptDialog(

File diff suppressed because one or more lines are too long

View File

@@ -308,7 +308,7 @@ export class ConfigPanel {
break; break;
case 'openGitRepoInVSCode': case 'openGitRepoInVSCode':
await this.openGitRepoInVSCode(data.repoId); await this.openTheModuleFolder('git', data.repoId);
break; break;
case 'openConfigFileInVSCode': case 'openConfigFileInVSCode':
@@ -324,11 +324,15 @@ export class ConfigPanel {
break; break;
case 'openMergedFolderInVSCode': case 'openMergedFolderInVSCode':
await this.openMergedFolderInVSCode(data.folderId); await this.openTheModuleFolder('merged', data.folderId);
break; break;
case 'loadMergedFolder': case 'loadMergedFolder':
await this.loadMergedFolder(data.folderId); await this.openTheModuleFolder('merged', data.folderId);
break;
case 'openTheModuleFolder':
await this.openTheModuleFolder(data.moduleType, data.id);
break; break;
} }
} catch (error) { } catch (error) {
@@ -1835,39 +1839,64 @@ private async openMergedFolderInVSCode(folderId: string): Promise<void> {
} }
} }
private async loadMergedFolder(folderId: string): Promise<void> { /**
const folder = this.mergedFolders.find(f => f.id === folderId); * 统一方法:在 VSCode 中打开模块文件夹中的文件
if (!folder) { * @param type 模块类型:'git' 或 'merged'
vscode.window.showErrorMessage('未找到指定的合并文件夹'); * @param id 模块 ID
return; */
} private async openTheModuleFolder(type: 'git' | 'merged', id: string): Promise<void> {
let folderPath: string | undefined;
let folderName: string | undefined;
try { if (type === 'git') {
// 检查文件夹是否存在 const repo = this.gitRepos.find(r => r.id === id);
if (!fs.existsSync(folder.path)) { if (!repo) {
vscode.window.showErrorMessage('合并文件夹目录不存在'); vscode.window.showErrorMessage('未找到指定的 Git 仓库');
return;
}
folderPath = repo.localPath;
folderName = repo.name;
} else if (type === 'merged') {
const folder = this.mergedFolders.find(f => f.id === id);
if (!folder) {
vscode.window.showErrorMessage('未找到指定的合并文件夹');
return;
}
folderPath = folder.path;
folderName = folder.displayName;
}
if (!folderPath) {
vscode.window.showErrorMessage('未找到文件夹路径');
return; return;
} }
// 使用 VSCode 的文件选择器让用户选择要打开的文件 try {
const fileUri = await vscode.window.showOpenDialog({ // 检查文件夹是否存在
defaultUri: vscode.Uri.file(folder.path), if (!fs.existsSync(folderPath)) {
canSelectFiles: true, vscode.window.showErrorMessage(`${type === 'git' ? 'Git 仓库' : '合并文件夹'}目录不存在`);
canSelectFolders: false, return;
canSelectMany: false, }
openLabel: '选择要打开的文件',
title: `在合并文件夹 ${folder.displayName} 中选择文件`
});
if (fileUri && fileUri.length > 0) { // 使用 VSCode 的文件选择器让用户选择要打开的文件
// 打开选中的文件 const fileUri = await vscode.window.showOpenDialog({
const document = await vscode.workspace.openTextDocument(fileUri[0]); defaultUri: vscode.Uri.file(folderPath),
await vscode.window.showTextDocument(document); canSelectFiles: true,
vscode.window.showInformationMessage(`已打开文件: ${path.basename(fileUri[0].fsPath)}`); canSelectFolders: false,
canSelectMany: false,
openLabel: '选择要打开的文件',
title: `${folderName} 中选择文件`
});
if (fileUri && fileUri.length > 0) {
// 打开选中的文件
const document = await vscode.workspace.openTextDocument(fileUri[0]);
await vscode.window.showTextDocument(document);
vscode.window.showInformationMessage(`已打开文件: ${path.basename(fileUri[0].fsPath)}`);
}
} catch (error) {
vscode.window.showErrorMessage(`打开${type === 'git' ? 'Git 仓库' : '合并文件夹'}文件失败: ${error}`);
} }
} catch (error) {
vscode.window.showErrorMessage(`打开合并文件夹文件失败: ${error}`);
} }
} }
}

View File

@@ -106,7 +106,7 @@ export class ConfigView extends BaseView {
</div> </div>
</td> </td>
<td> <td>
<span class="clickable" onclick="loadMergedFolder('${folder.id}')">${folder.folderName}</span> <span class="clickable" onclick="openTheModuleFolder('${folder.id}', 'merged')">${folder.folderName}</span>
</td> </td>
<td> <td>
<button class="btn-delete" onclick="deleteMergedFolder('${folder.id}')">删除</button> <button class="btn-delete" onclick="deleteMergedFolder('${folder.id}')">删除</button>
@@ -130,7 +130,7 @@ export class ConfigView extends BaseView {
</div> </div>
</td> </td>
<td> <td>
<span class="clickable" onclick="openGitRepoInVSCode('${repo.id}')">${branchName}</span> <span class="clickable" onclick="openTheModuleFolder('${repo.id}', 'git')">${branchName}</span>
</td> </td>
<td> <td>
<button class="btn-delete" onclick="deleteGitRepo('${repo.id}')">删除</button> <button class="btn-delete" onclick="deleteGitRepo('${repo.id}')">删除</button>
@@ -397,22 +397,15 @@ export class ConfigView extends BaseView {
} }
// 功能:加载合并文件夹( Git 仓库行为一致 // 统一功能:打开模块文件夹(合并 Git 仓库和合并文件夹功能
function loadMergedFolder(folderId) { function openTheModuleFolder(id, type) {
console.log('📂 加载合并文件夹:', folderId); console.log('📂 打开模块文件夹:', { id, type });
vscode.postMessage({ vscode.postMessage({
type: 'loadMergedFolder', type: 'openTheModuleFolder',
folderId: folderId id: id,
moduleType: type
}); });
} }
function openGitRepoInVSCode(repoId) {
console.log('📂 在 VSCode 中打开 Git 仓库文件选择器:', repoId);
vscode.postMessage({
type: 'openGitRepoInVSCode',
repoId: repoId
});
}
function createNewConfig() { function createNewConfig() {
showPromptDialog( showPromptDialog(
@@ -1039,4 +1032,4 @@ export class ConfigView extends BaseView {
}); });
return count; return count;
} }
} }