Skip to content

Commit

Permalink
feat(notifications): adjust wording and add activity bar badge
Browse files Browse the repository at this point in the history
- Remove description from the notifications panel - unneeded. It is obvious the panel is for notifications.
- Make hover text the full title of the notification in case user side bar width isn't enough to display the full title.
- Add a badge to the Q activity bar icon indicating how many notifications you have. Also adds this as (#) to the panel title.
  • Loading branch information
hayemaxi committed Nov 14, 2024
1 parent ed1b4b1 commit 5661ec0
Showing 1 changed file with 31 additions and 7 deletions.
38 changes: 31 additions & 7 deletions packages/core/src/notifications/panelNode.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@
*/

import * as vscode from 'vscode'
import * as nls from 'vscode-nls'
import { ResourceTreeDataProvider, TreeNode } from '../shared/treeview/resourceTreeDataProvider'
import { Command, Commands } from '../shared/vscode/commands2'
import { Icon, getIcon } from '../shared/icons'
Expand All @@ -18,13 +19,16 @@ import { openUrl } from '../shared/utilities/vsCodeUtils'
import { telemetry } from '../shared/telemetry/telemetry'
import { globals } from '../shared'

const localize = nls.loadMessageBundle()
const logger = getLogger('notifications')

/**
* Controls the "Notifications" side panel/tree in each extension. It takes purely UX actions
* and does not determine what notifications to dispaly or how to fetch and store them.
*/
export class NotificationsNode implements TreeNode {
public static readonly title = localize('AWS.notifications.title', 'Notifications')

public readonly id = 'notifications'
public readonly resource = this
public provider?: ResourceTreeDataProvider
Expand All @@ -37,6 +41,7 @@ export class NotificationsNode implements TreeNode {
private readonly showContextStr: contextKey
private readonly startUpNodeContext: string
private readonly emergencyNodeContext: string
private view: vscode.TreeView<TreeNode> | undefined

static #instance: NotificationsNode

Expand Down Expand Up @@ -65,16 +70,31 @@ export class NotificationsNode implements TreeNode {
}

public getTreeItem() {
const item = new vscode.TreeItem('Notifications')
const item = new vscode.TreeItem(NotificationsNode.title)
item.collapsibleState = vscode.TreeItemCollapsibleState.Collapsed
item.contextValue = 'notifications'

return item
}

public refresh(): void {
const hasNotifications = this.startUpNotifications.length > 0 || this.emergencyNotifications.length > 0
void setContext(this.showContextStr, hasNotifications)
if (!this.view) {
throw new ToolkitError('NotificationsNode: TreeView accessed without being registered.')
}

const totalNotifications = this.notificationCount()
if (totalNotifications > 0) {
this.view.badge = {
tooltip: `${totalNotifications} notification${totalNotifications > 1 ? 's' : ''}`,
value: totalNotifications,
}
this.view.title = `${NotificationsNode.title} (${totalNotifications})`
void setContext(this.showContextStr, true)
} else {
this.view.badge = undefined
this.view.title = NotificationsNode.title
void setContext(this.showContextStr, false)
}

this.provider?.refresh()
}
Expand All @@ -88,11 +108,12 @@ export class NotificationsNode implements TreeNode {
})
: (getIcon('vscode-question') as Icon)

const title = n.uiRenderInstructions.content['en-US'].title
return this.openNotificationCmd.build(n).asTreeNode({
label: n.uiRenderInstructions.content['en-US'].title,
label: title,
tooltip: title,
iconPath: icon,
contextValue: type === 'startUp' ? this.startUpNodeContext : this.emergencyNodeContext,
tooltip: 'Click to open',
})
}

Expand Down Expand Up @@ -130,6 +151,10 @@ export class NotificationsNode implements TreeNode {
return vscode.commands.executeCommand(this.focusCmdStr)
}

private notificationCount() {
return this.startUpNotifications.length + this.emergencyNotifications.length
}

/**
* Fired when a notification is clicked on in the panel. It will run any rendering
* instructions included in the notification. See {@link ToolkitNotification.uiRenderInstructions}.
Expand Down Expand Up @@ -275,14 +300,13 @@ export class NotificationsNode implements TreeNode {
}

registerView(context: vscode.ExtensionContext) {
const view = registerToolView(
this.view = registerToolView(
{
nodes: [this],
view: isAmazonQ() ? 'aws.amazonq.notifications' : 'aws.toolkit.notifications',
refreshCommands: [(provider: ResourceTreeDataProvider) => this.registerProvider(provider)],
},
context
)
view.message = `New feature announcements and emergency notifications for ${isAmazonQ() ? 'Amazon Q' : 'AWS Toolkit'} will appear here.`
}
}

0 comments on commit 5661ec0

Please sign in to comment.