Merge pull request #1949 from github/nora/rename-expanded-methods

Minor refactoring for expanded things
This commit is contained in:
Nora
2023-01-12 17:00:11 +01:00
committed by GitHub
2 changed files with 29 additions and 17 deletions

View File

@@ -78,24 +78,21 @@ export class DbManager {
public async removeDbItem(dbItem: DbItem): Promise<void> {
await this.dbConfigStore.removeDbItem(dbItem);
// Updating the expanded items takes care of cleaning up
// any non-existent items.
await this.updateExpandedItems(this.getExpandedItems());
await this.removeDbItemFromExpandedState(dbItem);
}
public async updateDbItemExpandedState(
dbItem: DbItem,
itemExpanded: boolean,
): Promise<void> {
const currentExpandedItems = this.getExpandedItems();
public async removeDbItemFromExpandedState(dbItem: DbItem): Promise<void> {
// When collapsing or expanding a list we clean up the expanded state and remove
// all items that don't exist anymore.
const newExpandedItems = updateExpandedItem(
currentExpandedItems,
dbItem,
itemExpanded,
);
await this.updateDbItemExpandedState(dbItem, false);
}
await this.updateExpandedItems(newExpandedItems);
public async addDbItemToExpandedState(dbItem: DbItem): Promise<void> {
// When collapsing or expanding a list we clean up the expanded state and remove
// all items that don't exist anymore.
await this.updateDbItemExpandedState(dbItem, true);
}
public async addNewRemoteRepo(
@@ -142,7 +139,7 @@ export class DbManager {
newDbItem,
);
await this.updateExpandedItems(newExpandedItems);
await this.setExpandedItems(newExpandedItems);
}
public async renameLocalDb(
@@ -214,4 +211,19 @@ export class DbManager {
await this.setExpandedItems(itemsToStore);
}
private async updateDbItemExpandedState(
dbItem: DbItem,
itemExpanded: boolean,
): Promise<void> {
const currentExpandedItems = this.getExpandedItems();
const newExpandedItems = updateExpandedItem(
currentExpandedItems,
dbItem,
itemExpanded,
);
await this.updateExpandedItems(newExpandedItems);
}
}

View File

@@ -386,7 +386,7 @@ export class DbPanel extends DisposableObject {
throw Error("Expected a database item.");
}
await this.dbManager.updateDbItemExpandedState(event.element.dbItem, false);
await this.dbManager.removeDbItemFromExpandedState(event.element.dbItem);
}
private async onDidExpandElement(
@@ -397,7 +397,7 @@ export class DbPanel extends DisposableObject {
throw Error("Expected a database item.");
}
await this.dbManager.updateDbItemExpandedState(event.element.dbItem, true);
await this.dbManager.addDbItemToExpandedState(event.element.dbItem);
}
/**