Ignore default Windows icons in UI better

This commit is contained in:
Daniel 2024-04-18 13:50:47 +02:00
parent cdabffafcd
commit e957b90b13
2 changed files with 20 additions and 5 deletions
desktop/angular
projects/safing/portmaster-api/src/lib
src/app/shared/app-icon

View file

@ -50,7 +50,7 @@ export interface TagDescription {
}
export interface Icon {
Type: 'database' | 'path' | 'api';
Type: '' | 'database' | 'path' | 'api';
Source: '' | 'user' | 'import' | 'core' | 'ui';
Value: string;
}

View file

@ -40,7 +40,7 @@ export interface IDandName {
// Some icons we don't want to show on the UI.
// Note that this works on a best effort basis and might
// start breaking with updates to the built-in icons...
const iconsToIngore = [
const iconBlobsToIgnore = [
'',
'',
'',
@ -48,6 +48,15 @@ const iconsToIngore = [
'',
'',
];
const iconIDsToIgnore = [
"a27898ddfa4e0481b62c69faa196919a738fcade",
"5a3eea8bcd08b9336ce9c5083f26185164268ee9",
"573393d6ad238d255b20dc1c1b303c95debe6965",
"d459b2cb23c27cc31ccab5025533048d5d8301bf",
"d35a0d91ebfda81df5286f68ec5ddb1d6ad6b850",
"cc33187385498384f1b648e23be5ef1a2e9f5f71",
];
const profilesToIgnore = ['local/_unidentified', 'local/_unsolicited'];
@ -86,7 +95,7 @@ export class AppIconComponent implements OnInit, OnDestroy {
this._profile = p || null;
if (this.initDone) {
this.updateView();
this.updateView(true);
}
}
get profile(): IDandName | null | undefined {
@ -125,7 +134,7 @@ export class AppIconComponent implements OnInit, OnDestroy {
}
this.requestedAnimationFrame = requestAnimationFrame(() => {
this.__updateView();
this.__updateView(skipIcon);
})
}
@ -266,7 +275,13 @@ export class AppIconComponent implements OnInit, OnDestroy {
)
.subscribe({
next: (icon) => {
if (iconsToIngore.some((i) => i === icon)) {
if (iconBlobsToIgnore.some((i) => i === icon)) {
icon = '';
} else if (iconIDsToIgnore.some((i) => icon.includes(i))) {
// TODO: This just checks if the value (blob, URL, etc.) contains
// the SHA1 sum of the icon, which is used in the URL of api icon types.
// This is very unlikely to have false positivies, but this could still
// be done a lot cleaner.
icon = '';
}
if (icon !== '') {