fixed problems with linked archives

This commit is contained in:
Jan Prochazka
2021-11-26 18:53:10 +01:00
parent a84c2bdd12
commit 1b6dada408
4 changed files with 23 additions and 15 deletions

View File

@@ -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'),

View File

@@ -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}`;
},
};

View File

@@ -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}

View File

@@ -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({