From 5c5d58985b11f5810d7131e0a0f6f3f54a72a695 Mon Sep 17 00:00:00 2001 From: axel7083 <42176370+axel7083@users.noreply.github.com> Date: Tue, 6 Feb 2024 18:53:15 +0100 Subject: [PATCH] feat: add statusbar item highlight property (#5773) * feat: add statusbar item important property Signed-off-by: axel7083 <42176370+axel7083@users.noreply.github.com> * feat: add statusbar item important property Signed-off-by: axel7083 <42176370+axel7083@users.noreply.github.com> * refactor: rename important to highlight Signed-off-by: axel7083 <42176370+axel7083@users.noreply.github.com> --------- Signed-off-by: axel7083 <42176370+axel7083@users.noreply.github.com> --- packages/main/src/plugin/index.ts | 1 + .../src/plugin/statusbar/statusbar-item.ts | 10 +++++++ .../plugin/statusbar/statusbar-registry.ts | 4 +++ .../src/lib/statusbar/StatusBarItem.spec.ts | 28 +++++++++++++++++++ .../src/lib/statusbar/StatusBarItem.svelte | 5 +++- 5 files changed, 47 insertions(+), 1 deletion(-) diff --git a/packages/main/src/plugin/index.ts b/packages/main/src/plugin/index.ts index 459eeeabbd4cf..0de9dafdce31c 100644 --- a/packages/main/src/plugin/index.ts +++ b/packages/main/src/plugin/index.ts @@ -570,6 +570,7 @@ export class PluginSystem { true, 'update', undefined, + true, ); }); diff --git a/packages/main/src/plugin/statusbar/statusbar-item.ts b/packages/main/src/plugin/statusbar/statusbar-item.ts index faa8658b39bc3..d39d248e3851f 100644 --- a/packages/main/src/plugin/statusbar/statusbar-item.ts +++ b/packages/main/src/plugin/statusbar/statusbar-item.ts @@ -34,6 +34,7 @@ export class StatusBarItemImpl implements StatusBarItem { private isVisible = false; private _iconClass: string | { active: string; inactive: string } | undefined; private _enabled = true; + private _highlight = false; private _command: string | undefined; // eslint-disable-next-line @typescript-eslint/no-explicit-any @@ -48,6 +49,15 @@ export class StatusBarItemImpl implements StatusBarItem { this._id = StatusBarItemImpl.nextId(); } + public get highlight(): boolean { + return this._highlight; + } + + public set highlight(highlight: boolean) { + this._highlight = highlight; + this.update(); + } + public get alignment(): StatusBarAlignment { return this._alignment; } diff --git a/packages/main/src/plugin/statusbar/statusbar-registry.ts b/packages/main/src/plugin/statusbar/statusbar-registry.ts index 0733b62708729..0bb6f3c3d0ee0 100644 --- a/packages/main/src/plugin/statusbar/statusbar-registry.ts +++ b/packages/main/src/plugin/statusbar/statusbar-registry.ts @@ -30,6 +30,7 @@ export interface StatusBarEntry { command?: string; // eslint-disable-next-line @typescript-eslint/no-explicit-any commandArgs?: any[]; + highlight?: boolean; } export interface StatusBarEntryDescriptor { @@ -62,6 +63,7 @@ export class StatusBarRegistry implements IDisposable { command: string | undefined, // eslint-disable-next-line @typescript-eslint/no-explicit-any commandArgs: any[] | undefined, + highlight?: boolean, ) { const existingEntry = this.entries.get(entryId); if (existingEntry && (existingEntry.alignLeft !== alignLeft || existingEntry.priority !== priority)) { @@ -80,6 +82,7 @@ export class StatusBarRegistry implements IDisposable { enabled: enabled, command: command, commandArgs: commandArgs, + highlight: highlight, }; const entryDescriptor: StatusBarEntryDescriptor = { @@ -97,6 +100,7 @@ export class StatusBarRegistry implements IDisposable { entryToUpdate.enabled = enabled; entryToUpdate.command = command; entryToUpdate.commandArgs = commandArgs; + entryToUpdate.highlight = highlight; } this.apiSender.send(STATUS_BAR_UPDATED_EVENT_NAME, undefined); diff --git a/packages/renderer/src/lib/statusbar/StatusBarItem.spec.ts b/packages/renderer/src/lib/statusbar/StatusBarItem.spec.ts index bf74005aad3ad..ffd667bed49cf 100644 --- a/packages/renderer/src/lib/statusbar/StatusBarItem.spec.ts +++ b/packages/renderer/src/lib/statusbar/StatusBarItem.spec.ts @@ -19,6 +19,8 @@ import { test, expect } from 'vitest'; import type { StatusBarEntry } from '../../../../main/src/plugin/statusbar/statusbar-registry'; import { iconClass } from './StatusBarItem'; +import { render, screen } from '@testing-library/svelte'; +import StatusBarItem from './StatusBarItem.svelte'; test('check iconClass with font awesome icons', () => { const statusBarEntry: StatusBarEntry = { @@ -49,3 +51,29 @@ test('check iconClass with font awesome icons and spinning', () => { const icon = iconClass(statusBarEntry); expect(icon).toBe('fas fa-sync animate-spin'); }); + +test('expect dot not rendered', async () => { + const statusBarEntry: StatusBarEntry = { + enabled: true, + activeIconClass: '${podman}', + highlight: false, + }; + + render(StatusBarItem, { entry: statusBarEntry }); + + const dot = screen.queryByRole('status'); + expect(dot).toBeNull(); +}); + +test('expect dot rendered', () => { + const statusBarEntry: StatusBarEntry = { + enabled: true, + activeIconClass: '${podman}', + highlight: true, + }; + + render(StatusBarItem, { entry: statusBarEntry }); + + const dot = screen.getByRole('status'); + expect(dot).toBeDefined(); +}); diff --git a/packages/renderer/src/lib/statusbar/StatusBarItem.svelte b/packages/renderer/src/lib/statusbar/StatusBarItem.svelte index cb1a972049247..4f240a411257f 100644 --- a/packages/renderer/src/lib/statusbar/StatusBarItem.svelte +++ b/packages/renderer/src/lib/statusbar/StatusBarItem.svelte @@ -35,7 +35,7 @@ async function executeCommand(entry: StatusBarEntry) { on:click="{() => { executeCommand(entry); }}" - class="{opacity(entry)} px-1 flex items-center {hoverBackground(entry)} {hoverCursor(entry)}" + class="{opacity(entry)} px-1 flex items-center {hoverBackground(entry)} {hoverCursor(entry)} relative inline-block" title="{tooltipText(entry)}"> {#if iconClass(entry)} @@ -43,4 +43,7 @@ async function executeCommand(entry: StatusBarEntry) { {#if entry.text} {entry.text} {/if} + {#if entry.highlight} + + {/if}