Merge pull request 'release/0.6.2' (#5) from release/0.6.2 into master
Reviewed-on: Ray/bookmark-manager-r4#5
This commit is contained in:
commit
de42bc7f66
312
AddBatchPageForm.cs
Normal file
312
AddBatchPageForm.cs
Normal file
@ -0,0 +1,312 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.ComponentModel;
|
||||
using System.Threading.Tasks;
|
||||
using System.Windows.Forms;
|
||||
using BookmarkManager.Services;
|
||||
using bzit.bomg.Models;
|
||||
using RyzStudio.Windows.Forms;
|
||||
using RyzStudio.Windows.ThemedForms;
|
||||
|
||||
namespace FizzyLauncher
|
||||
{
|
||||
public class AddBatchPageForm : Form
|
||||
{
|
||||
private System.Windows.Forms.Label label1;
|
||||
|
||||
|
||||
private readonly WebProvider _webProvider;
|
||||
private string _rootPath;
|
||||
private bool _isBusy = false;
|
||||
private THorizontalSeparator tHorizontalSeparator3;
|
||||
private ThButton button3;
|
||||
private ThProgressBar progressBar2;
|
||||
private RyzStudio.Windows.ThemedForms.Composite.DialogFooter dialogFooter1;
|
||||
private ThToolbarMemoBox memoBox1;
|
||||
private List<BookmarkModel> _result = new List<BookmarkModel>();
|
||||
private bool _requestCancel = false;
|
||||
|
||||
|
||||
public AddBatchPageForm(string rootPath)
|
||||
{
|
||||
InitializeComponent();
|
||||
|
||||
UISetup.Dialog(this);
|
||||
|
||||
_result = new List<BookmarkModel>();
|
||||
|
||||
_webProvider = new WebProvider();
|
||||
_webProvider.IgnoreSSL = true;
|
||||
|
||||
_rootPath = rootPath;
|
||||
}
|
||||
|
||||
private void InitializeComponent()
|
||||
{
|
||||
label1 = new Label();
|
||||
tHorizontalSeparator3 = new THorizontalSeparator();
|
||||
button3 = new ThButton();
|
||||
progressBar2 = new ThProgressBar();
|
||||
dialogFooter1 = new RyzStudio.Windows.ThemedForms.Composite.DialogFooter();
|
||||
memoBox1 = new ThToolbarMemoBox();
|
||||
SuspendLayout();
|
||||
//
|
||||
// label1
|
||||
//
|
||||
label1.AutoSize = true;
|
||||
label1.BackColor = System.Drawing.Color.Transparent;
|
||||
label1.ForeColor = System.Drawing.SystemColors.ControlText;
|
||||
label1.Location = new System.Drawing.Point(10, 20);
|
||||
label1.Margin = new Padding(0);
|
||||
label1.Name = "label1";
|
||||
label1.Padding = new Padding(0, 8, 0, 0);
|
||||
label1.Size = new System.Drawing.Size(185, 23);
|
||||
label1.TabIndex = 153;
|
||||
label1.Text = "Add pages (one URL on each line)";
|
||||
label1.TextAlign = System.Drawing.ContentAlignment.MiddleLeft;
|
||||
//
|
||||
// tHorizontalSeparator3
|
||||
//
|
||||
tHorizontalSeparator3.Anchor = AnchorStyles.Bottom | AnchorStyles.Left | AnchorStyles.Right;
|
||||
tHorizontalSeparator3.AutoScrollMargin = new System.Drawing.Size(0, 0);
|
||||
tHorizontalSeparator3.AutoScrollMinSize = new System.Drawing.Size(0, 0);
|
||||
tHorizontalSeparator3.BackColor = System.Drawing.Color.Transparent;
|
||||
tHorizontalSeparator3.Location = new System.Drawing.Point(10, 321);
|
||||
tHorizontalSeparator3.Margin = new Padding(0, 10, 0, 0);
|
||||
tHorizontalSeparator3.MaximumSize = new System.Drawing.Size(4920, 2);
|
||||
tHorizontalSeparator3.MinimumSize = new System.Drawing.Size(0, 22);
|
||||
tHorizontalSeparator3.Name = "tHorizontalSeparator3";
|
||||
tHorizontalSeparator3.Size = new System.Drawing.Size(424, 22);
|
||||
tHorizontalSeparator3.TabIndex = 207;
|
||||
tHorizontalSeparator3.TabStop = false;
|
||||
//
|
||||
// button3
|
||||
//
|
||||
button3.ActiveImage = null;
|
||||
button3.Anchor = AnchorStyles.Bottom | AnchorStyles.Right;
|
||||
button3.BackColor = System.Drawing.Color.Transparent;
|
||||
button3.EnableMenuOnClick = false;
|
||||
button3.EnableReactiveVisual = true;
|
||||
button3.HoverImage = null;
|
||||
button3.IdleImage = null;
|
||||
button3.LabelText = "&Add Pages";
|
||||
button3.Location = new System.Drawing.Point(306, 393);
|
||||
button3.Name = "button3";
|
||||
button3.Size = new System.Drawing.Size(128, 32);
|
||||
button3.TabIndex = 209;
|
||||
button3.TabStop = false;
|
||||
button3.MouseClick += button3_MouseClick;
|
||||
//
|
||||
// progressBar2
|
||||
//
|
||||
progressBar2.Anchor = AnchorStyles.Bottom | AnchorStyles.Left | AnchorStyles.Right;
|
||||
progressBar2.BackColor = System.Drawing.Color.Transparent;
|
||||
progressBar2.BarColour = System.Drawing.Color.FromArgb(79, 193, 203);
|
||||
progressBar2.BarTextColour = System.Drawing.Color.Black;
|
||||
progressBar2.EnableReactiveVisual = false;
|
||||
progressBar2.Font = new System.Drawing.Font("Segoe UI", 9F);
|
||||
progressBar2.Location = new System.Drawing.Point(10, 353);
|
||||
progressBar2.Maximum = 100;
|
||||
progressBar2.Minimum = 0;
|
||||
progressBar2.Name = "progressBar2";
|
||||
progressBar2.ProgressText = "50/100";
|
||||
progressBar2.ShowProgressText = true;
|
||||
progressBar2.Size = new System.Drawing.Size(424, 20);
|
||||
progressBar2.TabIndex = 210;
|
||||
progressBar2.TabStop = false;
|
||||
progressBar2.Value = 50;
|
||||
//
|
||||
// dialogFooter1
|
||||
//
|
||||
dialogFooter1.BackColor = System.Drawing.Color.FromArgb(240, 240, 240);
|
||||
dialogFooter1.Button1Text = "&Close";
|
||||
dialogFooter1.Dialog = this;
|
||||
dialogFooter1.Dock = DockStyle.Bottom;
|
||||
dialogFooter1.IsBusy = false;
|
||||
dialogFooter1.Location = new System.Drawing.Point(0, 437);
|
||||
dialogFooter1.Name = "dialogFooter1";
|
||||
dialogFooter1.Size = new System.Drawing.Size(444, 84);
|
||||
//
|
||||
// memoBox1
|
||||
//
|
||||
memoBox1.AllowDrop = true;
|
||||
memoBox1.Anchor = AnchorStyles.Top | AnchorStyles.Bottom | AnchorStyles.Left | AnchorStyles.Right;
|
||||
memoBox1.BackColor = System.Drawing.Color.Transparent;
|
||||
memoBox1.ClearedValue = "";
|
||||
memoBox1.EnableReactiveVisual = true;
|
||||
memoBox1.Font = new System.Drawing.Font("Segoe UI", 9F);
|
||||
memoBox1.Location = new System.Drawing.Point(10, 53);
|
||||
memoBox1.Name = "memoBox1";
|
||||
memoBox1.ReadOnly = false;
|
||||
memoBox1.ScrollBars = ScrollBars.Vertical;
|
||||
memoBox1.Size = new System.Drawing.Size(424, 258);
|
||||
memoBox1.TabIndex = 211;
|
||||
memoBox1.TabStop = false;
|
||||
memoBox1.WordWrap = false;
|
||||
//
|
||||
// AddBatchPageForm
|
||||
//
|
||||
AutoScaleDimensions = new System.Drawing.SizeF(7F, 15F);
|
||||
AutoScaleMode = AutoScaleMode.Font;
|
||||
BackColor = System.Drawing.Color.White;
|
||||
ClientSize = new System.Drawing.Size(444, 521);
|
||||
Controls.Add(memoBox1);
|
||||
Controls.Add(dialogFooter1);
|
||||
Controls.Add(progressBar2);
|
||||
Controls.Add(button3);
|
||||
Controls.Add(tHorizontalSeparator3);
|
||||
Controls.Add(label1);
|
||||
KeyPreview = true;
|
||||
MinimumSize = new System.Drawing.Size(460, 560);
|
||||
Name = "AddBatchPageForm";
|
||||
Text = "Add Pages (Batch)";
|
||||
ResumeLayout(false);
|
||||
PerformLayout();
|
||||
}
|
||||
|
||||
protected override void OnLoad(EventArgs e)
|
||||
{
|
||||
base.OnLoad(e);
|
||||
|
||||
memoBox1.Text = string.Empty;
|
||||
|
||||
progressBar2.Minimum = 0;
|
||||
progressBar2.Value = 0;
|
||||
progressBar2.Maximum = memoBox1.Lines?.Length ?? 0;
|
||||
|
||||
memoBox1.Focus();
|
||||
}
|
||||
|
||||
protected override void OnClosing(CancelEventArgs e)
|
||||
{
|
||||
base.OnClosing(e);
|
||||
|
||||
if (this.IsBusy)
|
||||
{
|
||||
e.Cancel = true;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
public List<BookmarkModel> Result
|
||||
{
|
||||
get => _result;
|
||||
private set => _result = value;
|
||||
}
|
||||
|
||||
|
||||
protected bool IsBusy
|
||||
{
|
||||
get => _isBusy;
|
||||
set
|
||||
{
|
||||
_isBusy = value;
|
||||
|
||||
UIControl.SetEnable(memoBox1, !this.IsBusy);
|
||||
UIControl.Invoke(button3, (x) =>
|
||||
{
|
||||
button3.LabelText = (this.IsBusy ? "&Stop" : "&Add Pages");
|
||||
});
|
||||
|
||||
dialogFooter1.IsBusy = _isBusy;
|
||||
}
|
||||
}
|
||||
|
||||
private async void button3_MouseClick(object sender, MouseEventArgs e)
|
||||
{
|
||||
await Task.Run(async () =>
|
||||
{
|
||||
if (this.IsBusy)
|
||||
{
|
||||
_requestCancel = true;
|
||||
return;
|
||||
}
|
||||
|
||||
this.IsBusy = true;
|
||||
|
||||
this.Result = new List<BookmarkModel>();
|
||||
|
||||
progressBar2.Minimum = 0;
|
||||
progressBar2.Value = 0;
|
||||
progressBar2.Maximum = memoBox1.Lines?.Length ?? 0;
|
||||
|
||||
foreach (var item in memoBox1.Lines ?? new string[0])
|
||||
{
|
||||
progressBar2.Value++;
|
||||
|
||||
if (string.IsNullOrWhiteSpace(item))
|
||||
{
|
||||
continue;
|
||||
}
|
||||
|
||||
var newModel = new BookmarkModel();
|
||||
newModel.Address = item;
|
||||
newModel.Path = _rootPath;
|
||||
|
||||
if (_requestCancel)
|
||||
{
|
||||
break;
|
||||
}
|
||||
|
||||
newModel = await UpdateBookmark(newModel, true, true);
|
||||
if (newModel == null)
|
||||
{
|
||||
continue;
|
||||
}
|
||||
|
||||
if (_requestCancel)
|
||||
{
|
||||
break;
|
||||
}
|
||||
|
||||
this.Result.Add(newModel);
|
||||
}
|
||||
|
||||
//_requestCancel = false;
|
||||
|
||||
this.IsBusy = false;
|
||||
|
||||
if (!_requestCancel)
|
||||
{
|
||||
this.DialogResult = DialogResult.OK;
|
||||
|
||||
UIControl.Close(this);
|
||||
}
|
||||
|
||||
_requestCancel = false;
|
||||
});
|
||||
}
|
||||
|
||||
private async Task<BookmarkModel> UpdateBookmark(BookmarkModel model, bool updateTitle, bool updateDescription)
|
||||
{
|
||||
if (string.IsNullOrWhiteSpace(model.Address))
|
||||
{
|
||||
return null;
|
||||
}
|
||||
|
||||
if (!model.Address.StartsWith("http://", StringComparison.CurrentCultureIgnoreCase) && !model.Address.StartsWith("https://", StringComparison.CurrentCultureIgnoreCase))
|
||||
{
|
||||
model.Address = "http://" + model.Address;
|
||||
}
|
||||
|
||||
var document = await _webProvider.RetrieveHtmlDocument(model.Address);
|
||||
if (document == null)
|
||||
{
|
||||
return null;
|
||||
}
|
||||
|
||||
if (updateTitle)
|
||||
{
|
||||
model.Title = _webProvider.ParseTitle(document);
|
||||
}
|
||||
|
||||
if (updateDescription)
|
||||
{
|
||||
model.Description = _webProvider.ParseDescription(document);
|
||||
}
|
||||
|
||||
return model;
|
||||
}
|
||||
|
||||
}
|
||||
}
|
120
AddBatchPageForm.resx
Normal file
120
AddBatchPageForm.resx
Normal file
@ -0,0 +1,120 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<root>
|
||||
<!--
|
||||
Microsoft ResX Schema
|
||||
|
||||
Version 2.0
|
||||
|
||||
The primary goals of this format is to allow a simple XML format
|
||||
that is mostly human readable. The generation and parsing of the
|
||||
various data types are done through the TypeConverter classes
|
||||
associated with the data types.
|
||||
|
||||
Example:
|
||||
|
||||
... ado.net/XML headers & schema ...
|
||||
<resheader name="resmimetype">text/microsoft-resx</resheader>
|
||||
<resheader name="version">2.0</resheader>
|
||||
<resheader name="reader">System.Resources.ResXResourceReader, System.Windows.Forms, ...</resheader>
|
||||
<resheader name="writer">System.Resources.ResXResourceWriter, System.Windows.Forms, ...</resheader>
|
||||
<data name="Name1"><value>this is my long string</value><comment>this is a comment</comment></data>
|
||||
<data name="Color1" type="System.Drawing.Color, System.Drawing">Blue</data>
|
||||
<data name="Bitmap1" mimetype="application/x-microsoft.net.object.binary.base64">
|
||||
<value>[base64 mime encoded serialized .NET Framework object]</value>
|
||||
</data>
|
||||
<data name="Icon1" type="System.Drawing.Icon, System.Drawing" mimetype="application/x-microsoft.net.object.bytearray.base64">
|
||||
<value>[base64 mime encoded string representing a byte array form of the .NET Framework object]</value>
|
||||
<comment>This is a comment</comment>
|
||||
</data>
|
||||
|
||||
There are any number of "resheader" rows that contain simple
|
||||
name/value pairs.
|
||||
|
||||
Each data row contains a name, and value. The row also contains a
|
||||
type or mimetype. Type corresponds to a .NET class that support
|
||||
text/value conversion through the TypeConverter architecture.
|
||||
Classes that don't support this are serialized and stored with the
|
||||
mimetype set.
|
||||
|
||||
The mimetype is used for serialized objects, and tells the
|
||||
ResXResourceReader how to depersist the object. This is currently not
|
||||
extensible. For a given mimetype the value must be set accordingly:
|
||||
|
||||
Note - application/x-microsoft.net.object.binary.base64 is the format
|
||||
that the ResXResourceWriter will generate, however the reader can
|
||||
read any of the formats listed below.
|
||||
|
||||
mimetype: application/x-microsoft.net.object.binary.base64
|
||||
value : The object must be serialized with
|
||||
: System.Runtime.Serialization.Formatters.Binary.BinaryFormatter
|
||||
: and then encoded with base64 encoding.
|
||||
|
||||
mimetype: application/x-microsoft.net.object.soap.base64
|
||||
value : The object must be serialized with
|
||||
: System.Runtime.Serialization.Formatters.Soap.SoapFormatter
|
||||
: and then encoded with base64 encoding.
|
||||
|
||||
mimetype: application/x-microsoft.net.object.bytearray.base64
|
||||
value : The object must be serialized into a byte array
|
||||
: using a System.ComponentModel.TypeConverter
|
||||
: and then encoded with base64 encoding.
|
||||
-->
|
||||
<xsd:schema id="root" xmlns="" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:msdata="urn:schemas-microsoft-com:xml-msdata">
|
||||
<xsd:import namespace="http://www.w3.org/XML/1998/namespace" />
|
||||
<xsd:element name="root" msdata:IsDataSet="true">
|
||||
<xsd:complexType>
|
||||
<xsd:choice maxOccurs="unbounded">
|
||||
<xsd:element name="metadata">
|
||||
<xsd:complexType>
|
||||
<xsd:sequence>
|
||||
<xsd:element name="value" type="xsd:string" minOccurs="0" />
|
||||
</xsd:sequence>
|
||||
<xsd:attribute name="name" use="required" type="xsd:string" />
|
||||
<xsd:attribute name="type" type="xsd:string" />
|
||||
<xsd:attribute name="mimetype" type="xsd:string" />
|
||||
<xsd:attribute ref="xml:space" />
|
||||
</xsd:complexType>
|
||||
</xsd:element>
|
||||
<xsd:element name="assembly">
|
||||
<xsd:complexType>
|
||||
<xsd:attribute name="alias" type="xsd:string" />
|
||||
<xsd:attribute name="name" type="xsd:string" />
|
||||
</xsd:complexType>
|
||||
</xsd:element>
|
||||
<xsd:element name="data">
|
||||
<xsd:complexType>
|
||||
<xsd:sequence>
|
||||
<xsd:element name="value" type="xsd:string" minOccurs="0" msdata:Ordinal="1" />
|
||||
<xsd:element name="comment" type="xsd:string" minOccurs="0" msdata:Ordinal="2" />
|
||||
</xsd:sequence>
|
||||
<xsd:attribute name="name" type="xsd:string" use="required" msdata:Ordinal="1" />
|
||||
<xsd:attribute name="type" type="xsd:string" msdata:Ordinal="3" />
|
||||
<xsd:attribute name="mimetype" type="xsd:string" msdata:Ordinal="4" />
|
||||
<xsd:attribute ref="xml:space" />
|
||||
</xsd:complexType>
|
||||
</xsd:element>
|
||||
<xsd:element name="resheader">
|
||||
<xsd:complexType>
|
||||
<xsd:sequence>
|
||||
<xsd:element name="value" type="xsd:string" minOccurs="0" msdata:Ordinal="1" />
|
||||
</xsd:sequence>
|
||||
<xsd:attribute name="name" type="xsd:string" use="required" />
|
||||
</xsd:complexType>
|
||||
</xsd:element>
|
||||
</xsd:choice>
|
||||
</xsd:complexType>
|
||||
</xsd:element>
|
||||
</xsd:schema>
|
||||
<resheader name="resmimetype">
|
||||
<value>text/microsoft-resx</value>
|
||||
</resheader>
|
||||
<resheader name="version">
|
||||
<value>2.0</value>
|
||||
</resheader>
|
||||
<resheader name="reader">
|
||||
<value>System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
|
||||
</resheader>
|
||||
<resheader name="writer">
|
||||
<value>System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
|
||||
</resheader>
|
||||
</root>
|
@ -14,7 +14,7 @@
|
||||
<Copyright>Ray Lam</Copyright>
|
||||
<AssemblyVersion>1.0.0.0</AssemblyVersion>
|
||||
<FileVersion>1.0.0.0</FileVersion>
|
||||
<Version>0.6.1.0249</Version>
|
||||
<Version>0.6.2.092</Version>
|
||||
<PackageId>bukkubuddy</PackageId>
|
||||
<RunAnalyzersDuringLiveAnalysis>True</RunAnalyzersDuringLiveAnalysis>
|
||||
<SupportedOSPlatformVersion>8.0</SupportedOSPlatformVersion>
|
||||
@ -106,6 +106,9 @@
|
||||
<AutoGen>True</AutoGen>
|
||||
<DependentUpon>AppResource.resx</DependentUpon>
|
||||
</Compile>
|
||||
<Compile Update="AddBatchPageForm.cs">
|
||||
<SubType>Form</SubType>
|
||||
</Compile>
|
||||
<Compile Update="UpdateIconsForm.cs" />
|
||||
<Compile Update="FindForm.cs" />
|
||||
<Compile Update="EditBookmarkForm.cs" />
|
||||
|
@ -3,6 +3,7 @@ using System.ComponentModel;
|
||||
using System.Drawing;
|
||||
using System.Threading.Tasks;
|
||||
using System.Windows.Forms;
|
||||
using System.Xml;
|
||||
using BookmarkManager.Services;
|
||||
using bzit.bomg.Models;
|
||||
using RyzStudio.Windows.Forms;
|
||||
@ -407,14 +408,14 @@ namespace FizzyLauncher
|
||||
|
||||
if (updateDescription)
|
||||
{
|
||||
textBox3.Text = _webProvider.ParseMetaDescription(document);
|
||||
textBox3.Text = _webProvider.ParseDescription(document);
|
||||
}
|
||||
|
||||
if (updateIcon)
|
||||
{
|
||||
try
|
||||
{
|
||||
pictureBox1.Image = await _webProvider.RetrieveImage(document);
|
||||
pictureBox1.Image = await _webProvider.RetrieveImage(url, document);
|
||||
if (pictureBox1.Image != null)
|
||||
{
|
||||
if (pictureBox1.Image.Width > 16)
|
||||
|
82
MainForm.Designer.cs
generated
82
MainForm.Designer.cs
generated
@ -71,6 +71,7 @@ namespace FizzyLauncher
|
||||
sortToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem();
|
||||
folderContextMenu = new System.Windows.Forms.ContextMenuStrip(components);
|
||||
addPageToolStripMenuItem1 = new System.Windows.Forms.ToolStripMenuItem();
|
||||
toolStripMenuItem10 = new System.Windows.Forms.ToolStripMenuItem();
|
||||
addFolderToolStripMenuItem1 = new System.Windows.Forms.ToolStripMenuItem();
|
||||
toolStripMenuItem4 = new System.Windows.Forms.ToolStripSeparator();
|
||||
openAllToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem();
|
||||
@ -90,6 +91,7 @@ namespace FizzyLauncher
|
||||
moveUpToolStripMenuItem1 = new System.Windows.Forms.ToolStripMenuItem();
|
||||
moveDownToolStripMenuItem1 = new System.Windows.Forms.ToolStripMenuItem();
|
||||
treeView1 = new RyzStudio.Windows.Forms.BookmarkTreeView();
|
||||
toolStripMenuItem11 = new System.Windows.Forms.ToolStripMenuItem();
|
||||
menuStrip1.SuspendLayout();
|
||||
rootContextMenu.SuspendLayout();
|
||||
folderContextMenu.SuspendLayout();
|
||||
@ -193,7 +195,7 @@ namespace FizzyLauncher
|
||||
findToolStripMenuItem.ImageScaling = System.Windows.Forms.ToolStripItemImageScaling.None;
|
||||
findToolStripMenuItem.Name = "findToolStripMenuItem";
|
||||
findToolStripMenuItem.ShortcutKeys = System.Windows.Forms.Keys.Control | System.Windows.Forms.Keys.F;
|
||||
findToolStripMenuItem.Size = new System.Drawing.Size(180, 22);
|
||||
findToolStripMenuItem.Size = new System.Drawing.Size(137, 22);
|
||||
findToolStripMenuItem.Text = "&Find";
|
||||
findToolStripMenuItem.Click += findToolStripMenuItem_Click;
|
||||
//
|
||||
@ -207,26 +209,26 @@ namespace FizzyLauncher
|
||||
// expandAllToolStripMenuItem
|
||||
//
|
||||
expandAllToolStripMenuItem.Name = "expandAllToolStripMenuItem";
|
||||
expandAllToolStripMenuItem.Size = new System.Drawing.Size(180, 22);
|
||||
expandAllToolStripMenuItem.Size = new System.Drawing.Size(152, 22);
|
||||
expandAllToolStripMenuItem.Text = "&Expand All";
|
||||
expandAllToolStripMenuItem.Click += expandAllToolStripMenuItem_Click;
|
||||
//
|
||||
// collapseAllToolStripMenuItem
|
||||
//
|
||||
collapseAllToolStripMenuItem.Name = "collapseAllToolStripMenuItem";
|
||||
collapseAllToolStripMenuItem.Size = new System.Drawing.Size(180, 22);
|
||||
collapseAllToolStripMenuItem.Size = new System.Drawing.Size(152, 22);
|
||||
collapseAllToolStripMenuItem.Text = "&Collapse All";
|
||||
collapseAllToolStripMenuItem.Click += collapseAllToolStripMenuItem_Click;
|
||||
//
|
||||
// toolStripSeparator1
|
||||
//
|
||||
toolStripSeparator1.Name = "toolStripSeparator1";
|
||||
toolStripSeparator1.Size = new System.Drawing.Size(177, 6);
|
||||
toolStripSeparator1.Size = new System.Drawing.Size(149, 6);
|
||||
//
|
||||
// alwaysOnTopToolStripMenuItem
|
||||
//
|
||||
alwaysOnTopToolStripMenuItem.Name = "alwaysOnTopToolStripMenuItem";
|
||||
alwaysOnTopToolStripMenuItem.Size = new System.Drawing.Size(180, 22);
|
||||
alwaysOnTopToolStripMenuItem.Size = new System.Drawing.Size(152, 22);
|
||||
alwaysOnTopToolStripMenuItem.Text = "Always On &Top";
|
||||
alwaysOnTopToolStripMenuItem.Click += alwaysOnTopToolStripMenuItem_Click;
|
||||
//
|
||||
@ -240,21 +242,21 @@ namespace FizzyLauncher
|
||||
// toolStripMenuItem9
|
||||
//
|
||||
toolStripMenuItem9.Name = "toolStripMenuItem9";
|
||||
toolStripMenuItem9.Size = new System.Drawing.Size(180, 22);
|
||||
toolStripMenuItem9.Size = new System.Drawing.Size(168, 22);
|
||||
toolStripMenuItem9.Text = "Update &Icons";
|
||||
toolStripMenuItem9.Click += toolStripMenuItem9_Click;
|
||||
//
|
||||
// toolStripSeparator2
|
||||
//
|
||||
toolStripSeparator2.Name = "toolStripSeparator2";
|
||||
toolStripSeparator2.Size = new System.Drawing.Size(177, 6);
|
||||
toolStripSeparator2.Size = new System.Drawing.Size(165, 6);
|
||||
//
|
||||
// optionsToolStripMenuItem
|
||||
//
|
||||
optionsToolStripMenuItem.ImageScaling = System.Windows.Forms.ToolStripItemImageScaling.None;
|
||||
optionsToolStripMenuItem.Name = "optionsToolStripMenuItem";
|
||||
optionsToolStripMenuItem.ShortcutKeys = System.Windows.Forms.Keys.Control | System.Windows.Forms.Keys.F12;
|
||||
optionsToolStripMenuItem.Size = new System.Drawing.Size(180, 22);
|
||||
optionsToolStripMenuItem.Size = new System.Drawing.Size(168, 22);
|
||||
optionsToolStripMenuItem.Text = "&Options";
|
||||
optionsToolStripMenuItem.Click += optionsToolStripMenuItem_Click;
|
||||
//
|
||||
@ -270,19 +272,19 @@ namespace FizzyLauncher
|
||||
viewHelpToolStripMenuItem1.ImageScaling = System.Windows.Forms.ToolStripItemImageScaling.None;
|
||||
viewHelpToolStripMenuItem1.Name = "viewHelpToolStripMenuItem1";
|
||||
viewHelpToolStripMenuItem1.ShortcutKeys = System.Windows.Forms.Keys.F1;
|
||||
viewHelpToolStripMenuItem1.Size = new System.Drawing.Size(180, 22);
|
||||
viewHelpToolStripMenuItem1.Size = new System.Drawing.Size(146, 22);
|
||||
viewHelpToolStripMenuItem1.Text = "&View Help";
|
||||
viewHelpToolStripMenuItem1.Click += viewHelpToolStripMenuItem1_Click;
|
||||
//
|
||||
// toolStripMenuItem16
|
||||
//
|
||||
toolStripMenuItem16.Name = "toolStripMenuItem16";
|
||||
toolStripMenuItem16.Size = new System.Drawing.Size(177, 6);
|
||||
toolStripMenuItem16.Size = new System.Drawing.Size(143, 6);
|
||||
//
|
||||
// aboutToolStripMenuItem1
|
||||
//
|
||||
aboutToolStripMenuItem1.Name = "aboutToolStripMenuItem1";
|
||||
aboutToolStripMenuItem1.Size = new System.Drawing.Size(180, 22);
|
||||
aboutToolStripMenuItem1.Size = new System.Drawing.Size(146, 22);
|
||||
aboutToolStripMenuItem1.Text = "&About";
|
||||
aboutToolStripMenuItem1.Click += aboutToolStripMenuItem1_Click;
|
||||
//
|
||||
@ -294,85 +296,92 @@ namespace FizzyLauncher
|
||||
//
|
||||
// rootContextMenu
|
||||
//
|
||||
rootContextMenu.Items.AddRange(new System.Windows.Forms.ToolStripItem[] { addPageToolStripMenuItem, addFolderToolStripMenuItem, toolStripMenuItem2, editToolStripMenuItem, toolStripMenuItem3, sortToolStripMenuItem });
|
||||
rootContextMenu.Items.AddRange(new System.Windows.Forms.ToolStripItem[] { addPageToolStripMenuItem, toolStripMenuItem11, addFolderToolStripMenuItem, toolStripMenuItem2, editToolStripMenuItem, toolStripMenuItem3, sortToolStripMenuItem });
|
||||
rootContextMenu.Name = "rootContextMenu";
|
||||
rootContextMenu.Size = new System.Drawing.Size(133, 104);
|
||||
rootContextMenu.Size = new System.Drawing.Size(181, 148);
|
||||
//
|
||||
// addPageToolStripMenuItem
|
||||
//
|
||||
addPageToolStripMenuItem.Name = "addPageToolStripMenuItem";
|
||||
addPageToolStripMenuItem.Size = new System.Drawing.Size(132, 22);
|
||||
addPageToolStripMenuItem.Size = new System.Drawing.Size(180, 22);
|
||||
addPageToolStripMenuItem.Text = "Add &Page";
|
||||
addPageToolStripMenuItem.Click += addPageToolStripMenuItem_Click;
|
||||
//
|
||||
// addFolderToolStripMenuItem
|
||||
//
|
||||
addFolderToolStripMenuItem.Name = "addFolderToolStripMenuItem";
|
||||
addFolderToolStripMenuItem.Size = new System.Drawing.Size(132, 22);
|
||||
addFolderToolStripMenuItem.Size = new System.Drawing.Size(180, 22);
|
||||
addFolderToolStripMenuItem.Text = "Add &Folder";
|
||||
addFolderToolStripMenuItem.Click += addFolderToolStripMenuItem_Click;
|
||||
//
|
||||
// toolStripMenuItem2
|
||||
//
|
||||
toolStripMenuItem2.Name = "toolStripMenuItem2";
|
||||
toolStripMenuItem2.Size = new System.Drawing.Size(129, 6);
|
||||
toolStripMenuItem2.Size = new System.Drawing.Size(177, 6);
|
||||
//
|
||||
// editToolStripMenuItem
|
||||
//
|
||||
editToolStripMenuItem.Name = "editToolStripMenuItem";
|
||||
editToolStripMenuItem.Size = new System.Drawing.Size(132, 22);
|
||||
editToolStripMenuItem.Size = new System.Drawing.Size(180, 22);
|
||||
editToolStripMenuItem.Text = "&Edit";
|
||||
editToolStripMenuItem.Click += editToolStripMenuItem_Click;
|
||||
//
|
||||
// toolStripMenuItem3
|
||||
//
|
||||
toolStripMenuItem3.Name = "toolStripMenuItem3";
|
||||
toolStripMenuItem3.Size = new System.Drawing.Size(129, 6);
|
||||
toolStripMenuItem3.Size = new System.Drawing.Size(177, 6);
|
||||
//
|
||||
// sortToolStripMenuItem
|
||||
//
|
||||
sortToolStripMenuItem.Name = "sortToolStripMenuItem";
|
||||
sortToolStripMenuItem.Size = new System.Drawing.Size(132, 22);
|
||||
sortToolStripMenuItem.Size = new System.Drawing.Size(180, 22);
|
||||
sortToolStripMenuItem.Text = "&Sort";
|
||||
sortToolStripMenuItem.Click += sortToolStripMenuItem_Click;
|
||||
//
|
||||
// folderContextMenu
|
||||
//
|
||||
folderContextMenu.Items.AddRange(new System.Windows.Forms.ToolStripItem[] { addPageToolStripMenuItem1, addFolderToolStripMenuItem1, toolStripMenuItem4, openAllToolStripMenuItem, editToolStripMenuItem1, deleteToolStripMenuItem, toolStripMenuItem5, sortToolStripMenuItem1, toolStripMenuItem6, moveUpToolStripMenuItem, moveDownToolStripMenuItem });
|
||||
folderContextMenu.Items.AddRange(new System.Windows.Forms.ToolStripItem[] { addPageToolStripMenuItem1, toolStripMenuItem10, addFolderToolStripMenuItem1, toolStripMenuItem4, openAllToolStripMenuItem, editToolStripMenuItem1, deleteToolStripMenuItem, toolStripMenuItem5, sortToolStripMenuItem1, toolStripMenuItem6, moveUpToolStripMenuItem, moveDownToolStripMenuItem });
|
||||
folderContextMenu.Name = "folderContextMenu";
|
||||
folderContextMenu.Size = new System.Drawing.Size(139, 198);
|
||||
folderContextMenu.Size = new System.Drawing.Size(167, 220);
|
||||
//
|
||||
// addPageToolStripMenuItem1
|
||||
//
|
||||
addPageToolStripMenuItem1.Name = "addPageToolStripMenuItem1";
|
||||
addPageToolStripMenuItem1.Size = new System.Drawing.Size(138, 22);
|
||||
addPageToolStripMenuItem1.Size = new System.Drawing.Size(166, 22);
|
||||
addPageToolStripMenuItem1.Text = "Add &Page";
|
||||
addPageToolStripMenuItem1.Click += addPageToolStripMenuItem1_Click;
|
||||
//
|
||||
// toolStripMenuItem10
|
||||
//
|
||||
toolStripMenuItem10.Name = "toolStripMenuItem10";
|
||||
toolStripMenuItem10.Size = new System.Drawing.Size(166, 22);
|
||||
toolStripMenuItem10.Text = "Add Page (&Batch)";
|
||||
toolStripMenuItem10.Click += toolStripMenuItem10_Click;
|
||||
//
|
||||
// addFolderToolStripMenuItem1
|
||||
//
|
||||
addFolderToolStripMenuItem1.Name = "addFolderToolStripMenuItem1";
|
||||
addFolderToolStripMenuItem1.Size = new System.Drawing.Size(138, 22);
|
||||
addFolderToolStripMenuItem1.Size = new System.Drawing.Size(166, 22);
|
||||
addFolderToolStripMenuItem1.Text = "Add &Folder";
|
||||
addFolderToolStripMenuItem1.Click += addFolderToolStripMenuItem1_Click;
|
||||
//
|
||||
// toolStripMenuItem4
|
||||
//
|
||||
toolStripMenuItem4.Name = "toolStripMenuItem4";
|
||||
toolStripMenuItem4.Size = new System.Drawing.Size(135, 6);
|
||||
toolStripMenuItem4.Size = new System.Drawing.Size(163, 6);
|
||||
//
|
||||
// openAllToolStripMenuItem
|
||||
//
|
||||
openAllToolStripMenuItem.Image = BookmarkManager.AppResource.bookmark;
|
||||
openAllToolStripMenuItem.Name = "openAllToolStripMenuItem";
|
||||
openAllToolStripMenuItem.Size = new System.Drawing.Size(138, 22);
|
||||
openAllToolStripMenuItem.Size = new System.Drawing.Size(166, 22);
|
||||
openAllToolStripMenuItem.Text = "&Open All";
|
||||
openAllToolStripMenuItem.Click += openAllToolStripMenuItem_Click;
|
||||
//
|
||||
// editToolStripMenuItem1
|
||||
//
|
||||
editToolStripMenuItem1.Name = "editToolStripMenuItem1";
|
||||
editToolStripMenuItem1.Size = new System.Drawing.Size(138, 22);
|
||||
editToolStripMenuItem1.Size = new System.Drawing.Size(166, 22);
|
||||
editToolStripMenuItem1.Text = "&Edit";
|
||||
editToolStripMenuItem1.Click += editToolStripMenuItem1_Click;
|
||||
//
|
||||
@ -380,32 +389,32 @@ namespace FizzyLauncher
|
||||
//
|
||||
deleteToolStripMenuItem.Image = BookmarkManager.AppResource.trash;
|
||||
deleteToolStripMenuItem.Name = "deleteToolStripMenuItem";
|
||||
deleteToolStripMenuItem.Size = new System.Drawing.Size(138, 22);
|
||||
deleteToolStripMenuItem.Size = new System.Drawing.Size(166, 22);
|
||||
deleteToolStripMenuItem.Text = "&Delete";
|
||||
deleteToolStripMenuItem.Click += deleteToolStripMenuItem_Click;
|
||||
//
|
||||
// toolStripMenuItem5
|
||||
//
|
||||
toolStripMenuItem5.Name = "toolStripMenuItem5";
|
||||
toolStripMenuItem5.Size = new System.Drawing.Size(135, 6);
|
||||
toolStripMenuItem5.Size = new System.Drawing.Size(163, 6);
|
||||
//
|
||||
// sortToolStripMenuItem1
|
||||
//
|
||||
sortToolStripMenuItem1.Name = "sortToolStripMenuItem1";
|
||||
sortToolStripMenuItem1.Size = new System.Drawing.Size(138, 22);
|
||||
sortToolStripMenuItem1.Size = new System.Drawing.Size(166, 22);
|
||||
sortToolStripMenuItem1.Text = "&Sort";
|
||||
sortToolStripMenuItem1.Click += sortToolStripMenuItem1_Click;
|
||||
//
|
||||
// toolStripMenuItem6
|
||||
//
|
||||
toolStripMenuItem6.Name = "toolStripMenuItem6";
|
||||
toolStripMenuItem6.Size = new System.Drawing.Size(135, 6);
|
||||
toolStripMenuItem6.Size = new System.Drawing.Size(163, 6);
|
||||
//
|
||||
// moveUpToolStripMenuItem
|
||||
//
|
||||
moveUpToolStripMenuItem.Image = BookmarkManager.AppResource.arrow_up_circle;
|
||||
moveUpToolStripMenuItem.Name = "moveUpToolStripMenuItem";
|
||||
moveUpToolStripMenuItem.Size = new System.Drawing.Size(138, 22);
|
||||
moveUpToolStripMenuItem.Size = new System.Drawing.Size(166, 22);
|
||||
moveUpToolStripMenuItem.Text = "Move &Up";
|
||||
moveUpToolStripMenuItem.Click += moveUpToolStripMenuItem_Click;
|
||||
//
|
||||
@ -413,7 +422,7 @@ namespace FizzyLauncher
|
||||
//
|
||||
moveDownToolStripMenuItem.Image = BookmarkManager.AppResource.arrow_down_circle;
|
||||
moveDownToolStripMenuItem.Name = "moveDownToolStripMenuItem";
|
||||
moveDownToolStripMenuItem.Size = new System.Drawing.Size(138, 22);
|
||||
moveDownToolStripMenuItem.Size = new System.Drawing.Size(166, 22);
|
||||
moveDownToolStripMenuItem.Text = "Move &Down";
|
||||
moveDownToolStripMenuItem.Click += moveDownToolStripMenuItem_Click;
|
||||
//
|
||||
@ -482,6 +491,13 @@ namespace FizzyLauncher
|
||||
treeView1.Size = new System.Drawing.Size(300, 556);
|
||||
treeView1.TabIndex = 5;
|
||||
//
|
||||
// toolStripMenuItem11
|
||||
//
|
||||
toolStripMenuItem11.Name = "toolStripMenuItem11";
|
||||
toolStripMenuItem11.Size = new System.Drawing.Size(180, 22);
|
||||
toolStripMenuItem11.Text = "Add Page (&Batch)";
|
||||
toolStripMenuItem11.Click += toolStripMenuItem11_Click;
|
||||
//
|
||||
// MainForm
|
||||
//
|
||||
AutoScaleDimensions = new System.Drawing.SizeF(96F, 96F);
|
||||
@ -563,6 +579,8 @@ namespace FizzyLauncher
|
||||
private System.Windows.Forms.ToolStripMenuItem toolStripMenuItem9;
|
||||
private System.Windows.Forms.ToolStripSeparator toolStripSeparator2;
|
||||
private RyzStudio.Windows.Forms.BookmarkTreeView treeView1;
|
||||
private System.Windows.Forms.ToolStripMenuItem toolStripMenuItem10;
|
||||
private System.Windows.Forms.ToolStripMenuItem toolStripMenuItem11;
|
||||
}
|
||||
}
|
||||
|
||||
|
40
MainForm.cs
40
MainForm.cs
@ -394,6 +394,36 @@ namespace FizzyLauncher
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Add page (batch)
|
||||
/// </summary>
|
||||
/// <param name="sender"></param>
|
||||
/// <param name="e"></param>
|
||||
private void toolStripMenuItem11_Click(object sender, EventArgs e)
|
||||
{
|
||||
if (this.IsBusy)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
var nodeType = treeView1.GetNodeType();
|
||||
if ((nodeType != NodeType.Root) && (nodeType != NodeType.Folder))
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
var nodePath = treeView1.GetNodePath();
|
||||
|
||||
var form = new AddBatchPageForm(nodePath);
|
||||
if (form.ShowDialog() == DialogResult.OK)
|
||||
{
|
||||
foreach (var item in form.Result)
|
||||
{
|
||||
treeView1.AddNode(item);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Add folder
|
||||
/// </summary>
|
||||
@ -457,6 +487,16 @@ namespace FizzyLauncher
|
||||
addPageToolStripMenuItem_Click(sender, e);
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Add page (batch)
|
||||
/// </summary>
|
||||
/// <param name="sender"></param>
|
||||
/// <param name="e"></param>
|
||||
private void toolStripMenuItem10_Click(object sender, EventArgs e)
|
||||
{
|
||||
toolStripMenuItem11_Click(this, e);
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Add folder
|
||||
/// </summary>
|
||||
|
@ -1,5 +1,7 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Drawing;
|
||||
using System.Linq;
|
||||
using System.Net;
|
||||
using System.Threading.Tasks;
|
||||
using HtmlAgilityPack;
|
||||
@ -148,7 +150,7 @@ namespace BookmarkManager.Services
|
||||
return result;
|
||||
}
|
||||
|
||||
public async Task<Image> RetrieveImage(HtmlAgilityPack.HtmlDocument document)
|
||||
public async Task<Image> RetrieveImage(string url, HtmlAgilityPack.HtmlDocument document)
|
||||
{
|
||||
var iconUrl = this.ParseFavicon(document);
|
||||
if (string.IsNullOrWhiteSpace(iconUrl))
|
||||
@ -156,6 +158,18 @@ namespace BookmarkManager.Services
|
||||
return null;
|
||||
}
|
||||
|
||||
try
|
||||
{
|
||||
var baseUri = new Uri(url);
|
||||
var absoluteUri = new Uri(baseUri, iconUrl);
|
||||
|
||||
iconUrl = absoluteUri.AbsoluteUri;
|
||||
}
|
||||
catch
|
||||
{
|
||||
return null;
|
||||
}
|
||||
|
||||
return await this.RetrieveImage(iconUrl);
|
||||
}
|
||||
|
||||
@ -163,132 +177,102 @@ namespace BookmarkManager.Services
|
||||
{
|
||||
string result = null;
|
||||
|
||||
result = ParseTagValue(document, "//title", string.Empty)?.Trim();
|
||||
// Find basic title
|
||||
result = FindNodeValue(document, "//title", string.Empty)?.Trim();
|
||||
if (!string.IsNullOrWhiteSpace(result))
|
||||
{
|
||||
return result;
|
||||
}
|
||||
|
||||
result = ParseTagValue_Attr(document, "//meta[@property='og:title']", "content", string.Empty)?.Trim();
|
||||
if (!string.IsNullOrWhiteSpace(result))
|
||||
// Find title from extended meta
|
||||
var patternList = new List<string>()
|
||||
{
|
||||
return result;
|
||||
"//meta[@property='og:title']",
|
||||
"//meta[@property='og:site_name']",
|
||||
"//meta[@name='twitter:title']",
|
||||
"//meta[@itemprop='name']"
|
||||
};
|
||||
|
||||
foreach (var item in patternList)
|
||||
{
|
||||
result = FindNodeAttrValue(document, item, "content", string.Empty)?.Trim();
|
||||
if (string.IsNullOrWhiteSpace(result))
|
||||
{
|
||||
continue;
|
||||
}
|
||||
|
||||
result = ParseTagValue_Attr(document, "//meta[@name='twitter:title']", "content", string.Empty)?.Trim();
|
||||
if (!string.IsNullOrWhiteSpace(result))
|
||||
{
|
||||
return result;
|
||||
}
|
||||
|
||||
result = ParseTagValue_Attr(document, "//meta[@property='og:site_name']", "content", string.Empty)?.Trim();
|
||||
if (!string.IsNullOrWhiteSpace(result))
|
||||
{
|
||||
return result;
|
||||
}
|
||||
|
||||
result = ParseTagValue_Attr(document, "//meta[@itemprop='name']", "content", string.Empty)?.Trim();
|
||||
if (!string.IsNullOrWhiteSpace(result))
|
||||
{
|
||||
return result;
|
||||
}
|
||||
|
||||
return string.Empty;
|
||||
}
|
||||
|
||||
public string ParseMetaDescription(HtmlAgilityPack.HtmlDocument document)
|
||||
public string ParseDescription(HtmlAgilityPack.HtmlDocument document)
|
||||
{
|
||||
string result = null;
|
||||
var patternList = new List<string>()
|
||||
{
|
||||
"//meta[@name='description']",
|
||||
"//meta[@property='og:description']",
|
||||
"//meta[@name='twitter:description']",
|
||||
"//meta[@itemprop='description']",
|
||||
};
|
||||
|
||||
result = ParseTagValue_Attr(document, "//meta[@name='description']", "content", string.Empty)?.Trim();
|
||||
if (!string.IsNullOrWhiteSpace(result))
|
||||
foreach (var item in patternList)
|
||||
{
|
||||
return result;
|
||||
}
|
||||
|
||||
result = ParseTagValue_Attr(document, "//meta[@property='og:description']", "content", string.Empty)?.Trim();
|
||||
if (!string.IsNullOrWhiteSpace(result))
|
||||
var result = FindNodeAttrValue(document, item, "content", string.Empty)?.Trim();
|
||||
if (string.IsNullOrWhiteSpace(result))
|
||||
{
|
||||
return result;
|
||||
}
|
||||
|
||||
result = ParseTagValue_Attr(document, "//meta[@name='twitter:description']", "content", string.Empty)?.Trim();
|
||||
if (!string.IsNullOrWhiteSpace(result))
|
||||
{
|
||||
return result;
|
||||
}
|
||||
|
||||
result = ParseTagValue_Attr(document, "//meta[@property='og:description']", "content", string.Empty)?.Trim();
|
||||
if (!string.IsNullOrWhiteSpace(result))
|
||||
{
|
||||
return result;
|
||||
}
|
||||
|
||||
result = ParseTagValue_Attr(document, "//meta[@itemprop='description']", "content", string.Empty)?.Trim();
|
||||
if (!string.IsNullOrWhiteSpace(result))
|
||||
{
|
||||
return result;
|
||||
continue;
|
||||
}
|
||||
|
||||
return result;
|
||||
}
|
||||
|
||||
return string.Empty;
|
||||
}
|
||||
|
||||
public string ParseFavicon(HtmlAgilityPack.HtmlDocument document)
|
||||
{
|
||||
string result = null;
|
||||
|
||||
result = ParseTagValue_Attr(document, "//link[translate(@rel, 'ABCDEFGHIJKLMNOPQRSTUVWXYZ', 'abcdefghijklmnopqrstuvwxyz') = 'shortcut icon']", "href", string.Empty)?.Trim();
|
||||
// Find link-rel that contains word
|
||||
result = FindNodeAttrValue_ContainsWord(document, "link", "rel", "href", "icon");
|
||||
if (!string.IsNullOrWhiteSpace(result))
|
||||
{
|
||||
return result;
|
||||
}
|
||||
|
||||
result = ParseTagValue_Attr(document, "//link[translate(@rel, 'ABCDEFGHIJKLMNOPQRSTUVWXYZ', 'abcdefghijklmnopqrstuvwxyz') = 'icon']", "href", string.Empty)?.Trim();
|
||||
// Find link-rel contains apple-icon
|
||||
var matchPatterns = new List<string>() { "apple-touch-icon", "apple-touch-icon-precomposed" };
|
||||
result = FindNodeAttrValue_Equals(document, "link", "rel", "href", matchPatterns);
|
||||
if (!string.IsNullOrWhiteSpace(result))
|
||||
{
|
||||
return result;
|
||||
}
|
||||
|
||||
result = ParseTagValue_Attr(document, "//link[translate(@rel, 'ABCDEFGHIJKLMNOPQRSTUVWXYZ', 'abcdefghijklmnopqrstuvwxyz') = 'apple-touch-icon']", "href", string.Empty)?.Trim();
|
||||
if (!string.IsNullOrWhiteSpace(result))
|
||||
// Find favicon from extended meta
|
||||
var patternList = new List<string>()
|
||||
{
|
||||
"//meta[@property='og:image']",
|
||||
"//meta[@name='twitter:image']",
|
||||
"//meta[@itemprop='image']"
|
||||
};
|
||||
|
||||
foreach (var item in patternList)
|
||||
{
|
||||
result = FindNodeAttrValue(document, item, "content", string.Empty)?.Trim();
|
||||
if (string.IsNullOrWhiteSpace(result))
|
||||
{
|
||||
continue;
|
||||
}
|
||||
|
||||
return result;
|
||||
}
|
||||
|
||||
result = ParseTagValue_Attr(document, "//link[translate(@rel, 'ABCDEFGHIJKLMNOPQRSTUVWXYZ', 'abcdefghijklmnopqrstuvwxyz') = 'apple-touch-icon-precomposed']", "href", string.Empty)?.Trim();
|
||||
if (!string.IsNullOrWhiteSpace(result))
|
||||
{
|
||||
return result;
|
||||
return string.Empty;
|
||||
}
|
||||
|
||||
result = ParseTagValue_Attr(document, "//meta[translate(@property, 'ABCDEFGHIJKLMNOPQRSTUVWXYZ', 'abcdefghijklmnopqrstuvwxyz') = 'og:image']", "content", string.Empty)?.Trim();
|
||||
if (!string.IsNullOrWhiteSpace(result))
|
||||
{
|
||||
return result;
|
||||
}
|
||||
|
||||
result = ParseTagValue_Attr(document, "//meta[translate(@name, 'ABCDEFGHIJKLMNOPQRSTUVWXYZ', 'abcdefghijklmnopqrstuvwxyz') = 'twitter:image']", "content", string.Empty)?.Trim();
|
||||
if (!string.IsNullOrWhiteSpace(result))
|
||||
{
|
||||
return result;
|
||||
}
|
||||
|
||||
result = ParseTagValue_Attr(document, "//meta[translate(@property, 'ABCDEFGHIJKLMNOPQRSTUVWXYZ', 'abcdefghijklmnopqrstuvwxyz') = 'og:image']", "content", string.Empty)?.Trim();
|
||||
if (!string.IsNullOrWhiteSpace(result))
|
||||
{
|
||||
return result;
|
||||
}
|
||||
|
||||
result = ParseTagValue_Attr(document, "//meta[translate(@itemprop, 'ABCDEFGHIJKLMNOPQRSTUVWXYZ', 'abcdefghijklmnopqrstuvwxyz') = 'image']", "content", string.Empty)?.Trim();
|
||||
if (!string.IsNullOrWhiteSpace(result))
|
||||
{
|
||||
return result;
|
||||
}
|
||||
|
||||
return "/favicon.ico";
|
||||
}
|
||||
|
||||
private string ParseTagValue(HtmlAgilityPack.HtmlDocument document, string xPath, string defaultValue = "")
|
||||
private string FindNodeValue(HtmlAgilityPack.HtmlDocument document, string xPath, string defaultValue = "")
|
||||
{
|
||||
var hnc = document.DocumentNode.SelectNodes(xPath);
|
||||
if (hnc == null)
|
||||
@ -320,7 +304,7 @@ namespace BookmarkManager.Services
|
||||
return defaultValue;
|
||||
}
|
||||
|
||||
private string ParseTagValue_Attr(HtmlAgilityPack.HtmlDocument document, string xPath, string attr, string defaultValue = "")
|
||||
private string FindNodeAttrValue(HtmlAgilityPack.HtmlDocument document, string xPath, string attr, string defaultValue = "")
|
||||
{
|
||||
var hnc = document.DocumentNode.SelectNodes(xPath);
|
||||
if (hnc == null)
|
||||
@ -351,5 +335,93 @@ namespace BookmarkManager.Services
|
||||
return defaultValue;
|
||||
}
|
||||
|
||||
private List<HtmlNode> FindNode(HtmlAgilityPack.HtmlDocument document, string nodeName, string attrName)
|
||||
{
|
||||
var xPath = (string.IsNullOrWhiteSpace(attrName) ? $"//{nodeName}" : $"//{nodeName}[@{attrName}]");
|
||||
var hnc = document.DocumentNode.SelectNodes(xPath);
|
||||
if (hnc == null)
|
||||
{
|
||||
return new List<HtmlNode>();
|
||||
}
|
||||
|
||||
if (hnc.Count <= 0)
|
||||
{
|
||||
return new List<HtmlNode>();
|
||||
}
|
||||
|
||||
return hnc.ToList();
|
||||
}
|
||||
|
||||
private string FindNodeAttrValue_ContainsWord(HtmlAgilityPack.HtmlDocument document, string nodeName, string attrName, string returnAttrName, string matchEqualList, string defaultValue = "")
|
||||
{
|
||||
var linkNodes = FindNode(document, nodeName, attrName);
|
||||
foreach (var item in linkNodes)
|
||||
{
|
||||
var relValue = item.Attributes[attrName].Value?.Trim() ?? string.Empty;
|
||||
if (!ContainsWord(relValue, matchEqualList))
|
||||
{
|
||||
continue;
|
||||
}
|
||||
|
||||
var hrefValue = item.Attributes[returnAttrName].Value?.Trim() ?? string.Empty;
|
||||
if (string.IsNullOrWhiteSpace(hrefValue))
|
||||
{
|
||||
continue;
|
||||
}
|
||||
|
||||
return System.Web.HttpUtility.HtmlDecode(hrefValue);
|
||||
}
|
||||
|
||||
return defaultValue;
|
||||
}
|
||||
|
||||
private string FindNodeAttrValue_Equals(HtmlAgilityPack.HtmlDocument document, string nodeName, string attrName, string returnAttrName, List<string> matchValueList, string defaultValue = "")
|
||||
{
|
||||
var linkNodes = FindNode(document, nodeName, attrName);
|
||||
foreach (var item in linkNodes)
|
||||
{
|
||||
var relValue = item.Attributes[attrName].Value?.Trim() ?? string.Empty;
|
||||
if (!matchValueList.Contains(relValue?.ToLower() ?? string.Empty))
|
||||
{
|
||||
continue;
|
||||
}
|
||||
|
||||
var hrefValue = item.Attributes[returnAttrName].Value?.Trim() ?? string.Empty;
|
||||
if (string.IsNullOrWhiteSpace(hrefValue))
|
||||
{
|
||||
continue;
|
||||
}
|
||||
|
||||
return System.Web.HttpUtility.HtmlDecode(hrefValue);
|
||||
}
|
||||
|
||||
return defaultValue;
|
||||
}
|
||||
|
||||
private bool ContainsWord(string haystack, string needle)
|
||||
{
|
||||
haystack = haystack?.Trim() ?? string.Empty;
|
||||
|
||||
if (!haystack.Contains(" "))
|
||||
{
|
||||
return haystack.Equals(needle, StringComparison.CurrentCultureIgnoreCase);
|
||||
}
|
||||
|
||||
foreach (var item in haystack.Split(" "))
|
||||
{
|
||||
if (string.IsNullOrWhiteSpace(item))
|
||||
{
|
||||
continue;
|
||||
}
|
||||
|
||||
if (item.Equals(needle, StringComparison.CurrentCultureIgnoreCase))
|
||||
{
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
}
|
||||
}
|
@ -360,7 +360,7 @@ namespace FizzyLauncher
|
||||
|
||||
try
|
||||
{
|
||||
var image = await _webProvider.RetrieveImage(document);
|
||||
var image = await _webProvider.RetrieveImage(item.Value.Address, document);
|
||||
if (image != null)
|
||||
{
|
||||
if (image.Width > 16)
|
||||
|
@ -2,7 +2,7 @@
|
||||
; SEE THE DOCUMENTATION FOR DETAILS ON CREATING INNO SETUP SCRIPT FILES!
|
||||
|
||||
#define MyAppName "BukkuBuddy Bookmark Manager"
|
||||
#define MyAppVersion "0.6.0.716"
|
||||
#define MyAppVersion "0.6.2.092"
|
||||
#define MyAppPublisher "Hi, I'm Ray"
|
||||
#define MyAppURL "https://www.hiimray.co.uk/software-bookmark-manager"
|
||||
#define MyAppExeName "bukkubuddy.exe"
|
||||
|
Loading…
Reference in New Issue
Block a user