From e6dafd940815d9e4e74342bc61564cf898e06b47 Mon Sep 17 00:00:00 2001 From: Alex Weininger Date: Tue, 10 Dec 2024 10:46:13 -0800 Subject: [PATCH] Sort children in tenants view (#985) --- src/tree/tenants/TenantResourceTreeDataProvider.ts | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) diff --git a/src/tree/tenants/TenantResourceTreeDataProvider.ts b/src/tree/tenants/TenantResourceTreeDataProvider.ts index 744e3cb3..2f542a1a 100644 --- a/src/tree/tenants/TenantResourceTreeDataProvider.ts +++ b/src/tree/tenants/TenantResourceTreeDataProvider.ts @@ -4,13 +4,13 @@ *--------------------------------------------------------------------------------------------*/ import { AzureSubscriptionProvider, getConfiguredAuthProviderId } from '@microsoft/vscode-azext-azureauth'; -import { callWithTelemetryAndErrorHandling, IActionContext, nonNullProp, nonNullValueAndProp } from '@microsoft/vscode-azext-utils'; +import { IActionContext, callWithTelemetryAndErrorHandling, nonNullProp, nonNullValueAndProp } from '@microsoft/vscode-azext-utils'; import { ResourceModelBase } from 'api/src'; import * as vscode from 'vscode'; import { TenantResourceProviderManager } from '../../api/ResourceProviderManagers'; import { BranchDataItemCache } from '../BranchDataItemCache'; import { GenericItem } from '../GenericItem'; -import { getAzureSubscriptionProvider, OnGetChildrenBase } from '../OnGetChildrenBase'; +import { OnGetChildrenBase, getAzureSubscriptionProvider } from '../OnGetChildrenBase'; import { ResourceGroupsItem } from '../ResourceGroupsItem'; import { ResourceTreeDataProviderBase } from "../ResourceTreeDataProviderBase"; import { TenantResourceBranchDataProviderManager } from "./TenantResourceBranchDataProviderManager"; @@ -51,10 +51,12 @@ export class TenantResourceTreeDataProvider extends ResourceTreeDataProviderBase const children: ResourceGroupsItem[] = await OnGetChildrenBase(subscriptionProvider); if (children.length === 0) { - const accounts = await vscode.authentication.getAccounts(getConfiguredAuthProviderId()); + const accounts = Array.from((await vscode.authentication.getAccounts(getConfiguredAuthProviderId()))).sort((a, b) => a.label.localeCompare(b.label)); context.telemetry.properties.accountCount = accounts.length.toString(); for (const account of accounts) { - const tenants = await subscriptionProvider.getTenants(account); + const tenants = (await subscriptionProvider.getTenants(account)) + // eslint-disable-next-line @typescript-eslint/no-non-null-assertion + .sort((a, b) => a.displayName!.localeCompare(b.displayName!)); const tenantItems: ResourceGroupsItem[] = []; for await (const tenant of tenants) { const isSignedIn = await subscriptionProvider.isSignedIn(nonNullProp(tenant, 'tenantId'), account);