mirror of
https://github.com/DeNNiiInc/dbgate.git
synced 2026-04-28 14:06:00 +00:00
fixed problems with linked archives
This commit is contained in:
@@ -50,7 +50,7 @@ function buildMenu() {
|
||||
commandItem('new.sqliteDatabase'),
|
||||
{ type: 'separator' },
|
||||
commandItem('file.open'),
|
||||
// commandItem('file.openArchive'),
|
||||
commandItem('file.openArchive'),
|
||||
{ type: 'separator' },
|
||||
commandItem('group.save'),
|
||||
commandItem('group.saveAs'),
|
||||
|
||||
@@ -97,7 +97,8 @@ module.exports = {
|
||||
|
||||
renameFolder_meta: 'post',
|
||||
async renameFolder({ folder, newFolder }) {
|
||||
await fs.rename(path.join(resolveArchiveFolder(folder)), path.join(resolveArchiveFolder(newFolder)));
|
||||
const uniqueName = await this.getNewArchiveFolder({ database: newFolder });
|
||||
await fs.rename(path.join(archivedir(), folder), path.join(archivedir(), uniqueName));
|
||||
socket.emitChanged(`archive-folders-changed`);
|
||||
},
|
||||
|
||||
@@ -140,11 +141,14 @@ module.exports = {
|
||||
},
|
||||
|
||||
async getNewArchiveFolder({ database }) {
|
||||
const isLink = database.endsWith(database);
|
||||
const name = isLink ? database.slice(0, -5) : database;
|
||||
const suffix = isLink ? '.link' : '';
|
||||
if (!(await fs.exists(path.join(archivedir(), database)))) return database;
|
||||
let index = 2;
|
||||
while (await fs.exists(path.join(archivedir(), `${database}${index}`))) {
|
||||
while (await fs.exists(path.join(archivedir(), `${name}${index}${suffix}`))) {
|
||||
index += 1;
|
||||
}
|
||||
return `${database}${index}`;
|
||||
return `${name}${index}${suffix}`;
|
||||
},
|
||||
};
|
||||
|
||||
@@ -31,17 +31,21 @@
|
||||
};
|
||||
|
||||
const handleRename = () => {
|
||||
const isLink = data.name.endsWith(data.name);
|
||||
const name = isLink ? data.name.slice(0, -5) : data.name;
|
||||
const suffix = isLink ? '.link' : '';
|
||||
|
||||
showModal(InputTextModal, {
|
||||
value: data.name,
|
||||
value: name,
|
||||
label: 'New folder name',
|
||||
header: 'Rename folder',
|
||||
onConfirm: async newFolder => {
|
||||
await axiosInstance.post('archive/rename-folder', {
|
||||
folder: data.name,
|
||||
newFolder,
|
||||
newFolder: newFolder + suffix,
|
||||
});
|
||||
if ($currentArchive == data.name) {
|
||||
$currentArchive = newFolder;
|
||||
$currentArchive = newFolder + suffix;
|
||||
}
|
||||
},
|
||||
});
|
||||
@@ -122,8 +126,8 @@ await dbgateApi.deployDb(${JSON.stringify(
|
||||
<AppObjectCore
|
||||
{...$$restProps}
|
||||
{data}
|
||||
title={data.name}
|
||||
icon="img archive-folder"
|
||||
title={data.name.endsWith('.link') ? data.name.slice(0, -5) : data.name}
|
||||
icon={data.name.endsWith('.link') ? 'img link' : 'img archive-folder'}
|
||||
isBold={data.name == $currentArchive}
|
||||
on:click={() => ($currentArchive = data.name)}
|
||||
menu={createMenu}
|
||||
|
||||
@@ -252,12 +252,12 @@ if (electron) {
|
||||
onClick: openElectronFile,
|
||||
});
|
||||
|
||||
// registerCommand({
|
||||
// id: 'file.openArchive',
|
||||
// category: 'File',
|
||||
// name: 'Open DB Model/Archive',
|
||||
// onClick: openArchiveFolder,
|
||||
// });
|
||||
registerCommand({
|
||||
id: 'file.openArchive',
|
||||
category: 'File',
|
||||
name: 'Open DB Model/Archive',
|
||||
onClick: openArchiveFolder,
|
||||
});
|
||||
}
|
||||
|
||||
registerCommand({
|
||||
|
||||
Reference in New Issue
Block a user