diff --git a/CreamInstaller/Components/ContextMenuItem.cs b/CreamInstaller/Components/ContextMenuItem.cs
index f22506a..daf74e1 100644
--- a/CreamInstaller/Components/ContextMenuItem.cs
+++ b/CreamInstaller/Components/ContextMenuItem.cs
@@ -39,19 +39,19 @@ internal class ContextMenuItem : ToolStripMenuItem
image = IconGrabber.GetFileExplorerImage();
break;
case "SteamDB":
- image = await HttpClientManager.GetImageFromUrl("https://steamdb.info/favicon.ico");
+ image = await HttpClientManager.GetImageFromUrl(IconGrabber.GetDomainFaviconUrl("steamdb.info"));
break;
case "Steam Store":
- image = await HttpClientManager.GetImageFromUrl("https://store.steampowered.com/favicon.ico");
+ image = await HttpClientManager.GetImageFromUrl(IconGrabber.GetDomainFaviconUrl("store.steampowered.com"));
break;
case "Steam Community":
- image = await HttpClientManager.GetImageFromUrl("https://steamcommunity.com/favicon.ico");
+ image = await HttpClientManager.GetImageFromUrl(IconGrabber.GetDomainFaviconUrl("steamcommunity.com"));
break;
case "ScreamDB":
- image = await HttpClientManager.GetImageFromUrl("https://scream-db.web.app/favicon.ico");
+ image = await HttpClientManager.GetImageFromUrl(IconGrabber.GetDomainFaviconUrl("scream-db.web.app"));
break;
case "Epic Games":
- image = await HttpClientManager.GetImageFromUrl("https://www.epicgames.com/favicon.ico");
+ image = await HttpClientManager.GetImageFromUrl(IconGrabber.GetDomainFaviconUrl("epicgames.com"));
break;
default:
return;
@@ -64,10 +64,10 @@ internal class ContextMenuItem : ToolStripMenuItem
}
}).ConfigureAwait(false);
- private static async Task TryImageIdentifierInfo(ContextMenuItem item, (string id, string iconUrl, bool sub) imageIdentifierInfo, Action onFail = null) => await Task.Run(async () =>
+ private static async Task TryImageIdentifierInfo(ContextMenuItem item, (string id, string iconUrl) imageIdentifierInfo, Action onFail = null) => await Task.Run(async () =>
{
- (string id, string iconUrl, bool sub) = imageIdentifierInfo;
- string imageIdentifier = sub ? "SubIcon_" + id : "Icon_" + id;
+ (string id, string iconUrl) = imageIdentifierInfo;
+ string imageIdentifier = "Icon_" + id;
if (images.TryGetValue(imageIdentifier, out Image image) && image is not null) item.Image = image;
else
{
@@ -99,12 +99,12 @@ internal class ContextMenuItem : ToolStripMenuItem
internal ContextMenuItem(string text, string imageIdentifier, EventHandler onClick = null)
: this(text, onClick) => _ = TryImageIdentifier(this, imageIdentifier);
- internal ContextMenuItem(string text, (string id, string iconUrl, bool sub) imageIdentifierInfo, EventHandler onClick = null)
+ internal ContextMenuItem(string text, (string id, string iconUrl) imageIdentifierInfo, EventHandler onClick = null)
: this(text, onClick) => _ = TryImageIdentifierInfo(this, imageIdentifierInfo);
- internal ContextMenuItem(string text, (string id, string iconUrl, bool sub) imageIdentifierInfo, string imageIdentifierFallback, EventHandler onClick = null)
+ internal ContextMenuItem(string text, (string id, string iconUrl) imageIdentifierInfo, string imageIdentifierFallback, EventHandler onClick = null)
: this(text, onClick) => _ = TryImageIdentifierInfo(this, imageIdentifierInfo, async () => await TryImageIdentifier(this, imageIdentifierFallback));
- internal ContextMenuItem(string text, (string id, string iconUrl, bool sub) imageIdentifierInfo, (string id, string iconUrl, bool sub) imageIdentifierInfoFallback, EventHandler onClick = null)
+ internal ContextMenuItem(string text, (string id, string iconUrl) imageIdentifierInfo, (string id, string iconUrl) imageIdentifierInfoFallback, EventHandler onClick = null)
: this(text, onClick) => _ = TryImageIdentifierInfo(this, imageIdentifierInfo, async () => await TryImageIdentifierInfo(this, imageIdentifierInfoFallback));
}
\ No newline at end of file
diff --git a/CreamInstaller/CreamInstaller.csproj b/CreamInstaller/CreamInstaller.csproj
index b5745d2..c777c84 100644
--- a/CreamInstaller/CreamInstaller.csproj
+++ b/CreamInstaller/CreamInstaller.csproj
@@ -5,7 +5,7 @@
True
Resources\ini.ico
true
- 3.5.3.0
+ 3.5.3.1
Resources\ini.ico
LICENSE
2021, pointfeev (https://github.com/pointfeev)
diff --git a/CreamInstaller/Forms/SelectForm.cs b/CreamInstaller/Forms/SelectForm.cs
index 54c81fb..5d22873 100644
--- a/CreamInstaller/Forms/SelectForm.cs
+++ b/CreamInstaller/Forms/SelectForm.cs
@@ -231,6 +231,7 @@ internal partial class SelectForm : CustomForm
selection.IconUrl = IconGrabber.SteamAppImagesPath + @$"\{appId}\{appInfo?.Value?.GetChild("common")?.GetChild("icon")}.jpg";
selection.SubIconUrl = appData?.header_image ?? IconGrabber.SteamAppImagesPath + @$"\{appId}\{appInfo?.Value?.GetChild("common")?.GetChild("clienticon")}.ico";
selection.Publisher = appData?.publishers[0] ?? appInfo?.Value?.GetChild("extended")?.GetChild("publisher")?.ToString();
+ selection.WebsiteUrl = appData?.website;
if (Program.Canceled) return;
Program.Invoke(selectionTreeView, delegate
@@ -607,9 +608,9 @@ internal partial class SelectForm : CustomForm
if (id == "ParadoxLauncher")
header = new(node.Text, "Paradox Launcher");
else if (selection is not null)
- header = new(node.Text, (id, selection.IconUrl, false));
+ header = new(node.Text, (id, selection.IconUrl));
else if (dlc is not null && dlcParentSelection is not null)
- header = new(node.Text, (id, dlc.Value.app.icon, false), (id, dlcParentSelection.IconUrl, false));
+ header = new(node.Text, (id, dlc.Value.app.icon), (id, dlcParentSelection.IconUrl));
contextMenuStrip.Items.Add(header ?? new ContextMenuItem(node.Text));
string appInfoVDF = $@"{SteamCMD.AppInfoPath}\{id}.vdf";
string appInfoJSON = $@"{SteamCMD.AppInfoPath}\{id}.json";
@@ -702,7 +703,7 @@ internal partial class SelectForm : CustomForm
{
contextMenuStrip.Items.Add(new ContextMenuItem("Open Steam Store", "Steam Store",
new EventHandler((sender, e) => Diagnostics.OpenUrlInInternetBrowser(selection.ProductUrl))));
- contextMenuStrip.Items.Add(new ContextMenuItem("Open Steam Community", (id, selection.SubIconUrl, true), "Steam Community",
+ contextMenuStrip.Items.Add(new ContextMenuItem("Open Steam Community", ("Sub_" + id, selection.SubIconUrl), "Steam Community",
new EventHandler((sender, e) => Diagnostics.OpenUrlInInternetBrowser("https://steamcommunity.com/app/" + id))));
}
else if (selection.IsEpic)
@@ -715,6 +716,11 @@ internal partial class SelectForm : CustomForm
}
}
}
+ if (selection is not null && selection.WebsiteUrl is not null)
+ {
+ contextMenuStrip.Items.Add(new ContextMenuItem("Open Official Website", ("Web_" + id, IconGrabber.GetDomainFaviconUrl(selection.WebsiteUrl)),
+ new EventHandler((sender, e) => Diagnostics.OpenUrlInInternetBrowser(selection.WebsiteUrl))));
+ }
contextMenuStrip.Show(selectionTreeView, e.Location);
};
OnLoad(forceProvideChoices: true);
diff --git a/CreamInstaller/ProgramSelection.cs b/CreamInstaller/ProgramSelection.cs
index 6679878..4937eb8 100644
--- a/CreamInstaller/ProgramSelection.cs
+++ b/CreamInstaller/ProgramSelection.cs
@@ -27,6 +27,8 @@ internal class ProgramSelection
internal string Publisher;
+ internal string WebsiteUrl;
+
internal string RootDirectory;
internal List DllDirectories;
diff --git a/CreamInstaller/Steam/AppDetails.cs b/CreamInstaller/Steam/AppDetails.cs
index bc09a6f..534295a 100644
--- a/CreamInstaller/Steam/AppDetails.cs
+++ b/CreamInstaller/Steam/AppDetails.cs
@@ -7,20 +7,6 @@ using System.Collections.Generic;
namespace CreamInstaller.Steam;
-public class Category
-{
- public int id { get; set; }
-
- public string description { get; set; }
-}
-
-public class Genre
-{
- public string id { get; set; }
-
- public string description { get; set; }
-}
-
public class AppData
{
public string type { get; set; }
@@ -40,10 +26,6 @@ public class AppData
public List publishers { get; set; }
public List packages { get; set; }
-
- public List categories { get; set; }
-
- public List genres { get; set; }
}
public class AppDetails
diff --git a/CreamInstaller/Utility/IconGrabber.cs b/CreamInstaller/Utility/IconGrabber.cs
index 2a15de4..ef3fb7d 100644
--- a/CreamInstaller/Utility/IconGrabber.cs
+++ b/CreamInstaller/Utility/IconGrabber.cs
@@ -14,6 +14,10 @@ internal static class IconGrabber
internal const string SteamAppImagesPath = "https://cdn.cloudflare.steamstatic.com/steamcommunity/public/images/apps/";
+ internal const string GoogleFaviconsApiUrl = "https://www.google.com/s2/favicons";
+
+ internal static string GetDomainFaviconUrl(string domain, int size = 16) => GoogleFaviconsApiUrl + $"?domain={domain}&sz={size}";
+
internal static Image GetFileIconImage(string path) => File.Exists(path) ? Icon.ExtractAssociatedIcon(path).ToBitmap() : null;
internal static Image GetNotepadImage() => GetFileIconImage(Diagnostics.GetNotepadPath());