patch
This commit is contained in:
Binary file not shown.
@@ -167,7 +167,7 @@ namespace DiscordBot
|
|||||||
bool isExtracting = true;
|
bool isExtracting = true;
|
||||||
Console_Utilities.ProgressBar bar = new Console_Utilities.ProgressBar(100, "");
|
Console_Utilities.ProgressBar bar = new Console_Utilities.ProgressBar(100, "");
|
||||||
|
|
||||||
IProgress<double> extractProgress = new Progress<double>(value =>
|
IProgress<float> extractProgress = new Progress<float>(value =>
|
||||||
{
|
{
|
||||||
proc = value;
|
proc = value;
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -11,6 +11,12 @@
|
|||||||
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|AnyCPU'">
|
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|AnyCPU'">
|
||||||
<Optimize>False</Optimize>
|
<Optimize>False</Optimize>
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
|
<ItemGroup>
|
||||||
|
<AvaloniaXaml Remove="bin\**" />
|
||||||
|
<Compile Remove="bin\**" />
|
||||||
|
<EmbeddedResource Remove="bin\**" />
|
||||||
|
<None Remove="bin\**" />
|
||||||
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<None Remove=".gitignore" />
|
<None Remove=".gitignore" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
|||||||
@@ -2,10 +2,20 @@
|
|||||||
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
|
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
|
||||||
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
|
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
|
||||||
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
|
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
|
||||||
mc:Ignorable="d" d:DesignWidth="800" d:DesignHeight="450"
|
mc:Ignorable="d" d:DesignWidth="800" d:DesignHeight="500"
|
||||||
x:Class="DiscordBotGUI.MainWindow"
|
x:Class="DiscordBotGUI.MainWindow"
|
||||||
Title="DiscordBotGUI">
|
Title="DiscordBotGUI">
|
||||||
|
|
||||||
<StackPanel Margin="10">
|
<StackPanel Margin="10">
|
||||||
|
<Menu>
|
||||||
|
<!--
|
||||||
|
<MenuItem Header="Settings" x:Name="settings"/>
|
||||||
|
-->
|
||||||
|
<MenuItem Header="Plugins">
|
||||||
|
<MenuItem Header="Commands" x:Class="DiscordBotGUI.MainWindow" x:Name="commandsSettingMenuItem" />
|
||||||
|
<MenuItem Header="Events" x:Class="DiscordBotGUI.MainWindow" x:Name="eventsSettingMenuItem" />
|
||||||
|
</MenuItem>
|
||||||
|
</Menu>
|
||||||
<Label x:Class="DiscordBotGUI.MainWindow" x:Name="label1" Content="Discord Token" />
|
<Label x:Class="DiscordBotGUI.MainWindow" x:Name="label1" Content="Discord Token" />
|
||||||
<TextBox x:Class="DiscordBotGUI.MainWindow" x:Name="textBox1" IsReadOnly="True" TextAlignment="Center" Text=""/>
|
<TextBox x:Class="DiscordBotGUI.MainWindow" x:Name="textBox1" IsReadOnly="True" TextAlignment="Center" Text=""/>
|
||||||
<Label x:Class="DiscordBotGUI.MainWindow" x:Name="label2" Content="Bot Prefix" />
|
<Label x:Class="DiscordBotGUI.MainWindow" x:Name="label2" Content="Bot Prefix" />
|
||||||
@@ -15,7 +25,7 @@
|
|||||||
<TextBox x:Class="DiscordBotGUI.MainWindow" x:Name="textBox3" Width="250" TextAlignment="Center" HorizontalAlignment="Left" IsReadOnly="False" Text=""/>
|
<TextBox x:Class="DiscordBotGUI.MainWindow" x:Name="textBox3" Width="250" TextAlignment="Center" HorizontalAlignment="Left" IsReadOnly="False" Text=""/>
|
||||||
<Label x:Class="DiscordBotGUI.MainWindow" x:Name="label4" Content="" Foreground="Red" Margin="10"/>
|
<Label x:Class="DiscordBotGUI.MainWindow" x:Name="label4" Content="" Foreground="Red" Margin="10"/>
|
||||||
<Button x:Class="DiscordBotGUI.MainWindow" x:Name="button1" HorizontalAlignment="Center" VerticalAlignment="Bottom" Padding="10" HorizontalContentAlignment="Center" VerticalContentAlignment="Center" Width="200" Content="Start Bot" Margin="0,75,0,0" />
|
<Button x:Class="DiscordBotGUI.MainWindow" x:Name="button1" HorizontalAlignment="Center" VerticalAlignment="Bottom" Padding="10" HorizontalContentAlignment="Center" VerticalContentAlignment="Center" Width="200" Content="Start Bot" Margin="0,75,0,0" />
|
||||||
<Button x:Class="DiscordBotGUI.MainWindow" x:Name="button2" HorizontalAlignment="Center" VerticalAlignment="Bottom" Padding="10" HorizontalContentAlignment="Center" VerticalContentAlignment="Center" Width="200" Content="Exit" Margin="0,15,0,0" />
|
|
||||||
</StackPanel>
|
</StackPanel>
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -6,6 +6,7 @@ using PluginManager.Others;
|
|||||||
using System.IO;
|
using System.IO;
|
||||||
using System;
|
using System;
|
||||||
using System.Diagnostics;
|
using System.Diagnostics;
|
||||||
|
using DiscordBotGUI.Settings;
|
||||||
|
|
||||||
namespace DiscordBotGUI
|
namespace DiscordBotGUI
|
||||||
{
|
{
|
||||||
@@ -20,6 +21,7 @@ namespace DiscordBotGUI
|
|||||||
|
|
||||||
private void LoadElements()
|
private void LoadElements()
|
||||||
{
|
{
|
||||||
|
textBox3.Watermark = "Insert start arguments";
|
||||||
button1.Click += async (sender, e) =>
|
button1.Click += async (sender, e) =>
|
||||||
{
|
{
|
||||||
|
|
||||||
@@ -41,10 +43,8 @@ namespace DiscordBotGUI
|
|||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
button2.Click += (sender, e) =>
|
commandsSettingMenuItem.Click += (sender, e) => new Commands().ShowDialog(this);
|
||||||
{
|
eventsSettingMenuItem.Click += (sender, e) => new Events().ShowDialog(this);
|
||||||
Close();
|
|
||||||
};
|
|
||||||
|
|
||||||
string folder = $"{Functions.dataFolder}DiscordBotCore.data";
|
string folder = $"{Functions.dataFolder}DiscordBotCore.data";
|
||||||
Directory.CreateDirectory(Functions.dataFolder);
|
Directory.CreateDirectory(Functions.dataFolder);
|
||||||
@@ -56,6 +56,8 @@ namespace DiscordBotGUI
|
|||||||
{
|
{
|
||||||
textBox1.IsReadOnly = false;
|
textBox1.IsReadOnly = false;
|
||||||
textBox2.IsReadOnly = false;
|
textBox2.IsReadOnly = false;
|
||||||
|
textBox1.Watermark = "Insert Bot Token Here";
|
||||||
|
textBox2.Watermark = "Insert Bot Prefix Here";
|
||||||
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@@ -64,10 +66,12 @@ namespace DiscordBotGUI
|
|||||||
textBox2.Text = botPrefix;
|
textBox2.Text = botPrefix;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
catch (Exception ex)
|
catch
|
||||||
{
|
{
|
||||||
textBox1.IsReadOnly = false;
|
textBox1.IsReadOnly = false;
|
||||||
textBox2.IsReadOnly = false;
|
textBox2.IsReadOnly = false;
|
||||||
|
textBox1.Watermark = "Insert Bot Token Here";
|
||||||
|
textBox2.Watermark = "Insert Bot Prefix Here";
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
18
DiscordBotGUI/Settings/Commands.axaml
Normal file
18
DiscordBotGUI/Settings/Commands.axaml
Normal file
@@ -0,0 +1,18 @@
|
|||||||
|
<Window xmlns="https://github.com/avaloniaui"
|
||||||
|
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
|
||||||
|
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
|
||||||
|
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
|
||||||
|
mc:Ignorable="d" d:DesignWidth="800" d:DesignHeight="450"
|
||||||
|
x:Class="DiscordBotGUI.Settings.Commands"
|
||||||
|
Title="Commands">
|
||||||
|
<StackPanel x:Class="DiscordBotGUI.Settings.Commands" x:Name="stackpanel1" Margin="10">
|
||||||
|
<Label Content="Installed Commands" />
|
||||||
|
<TextBox x:Class="DiscordBotGUI.Settings.Commands" x:Name="textbox1" TextAlignment="Left" IsReadOnly="True" />
|
||||||
|
<Label Content="Install another command" />
|
||||||
|
<ComboBox x:Class="DiscordBotGUI.Settings.Commands" x:Name="comboBox1" HorizontalAlignment="Left" VerticalAlignment="Top" Margin="0,10" Padding="200,0" />
|
||||||
|
<Button x:Class="DiscordBotGUI.Settings.Commands" x:Name="button1" HorizontalAlignment="Left" Content="Install" />
|
||||||
|
<ProgressBar x:Class="DiscordBotGUI.Settings.Commands" x:Name="progressBar1" HorizontalAlignment="Left" Margin="0,10" />
|
||||||
|
<Label x:Class="DiscordBotGUI.Settings.Commands" x:Name="label1" Content="" HorizontalAlignment="Left" Margin="0,10" />
|
||||||
|
</StackPanel>
|
||||||
|
|
||||||
|
</Window>
|
||||||
119
DiscordBotGUI/Settings/Commands.axaml.cs
Normal file
119
DiscordBotGUI/Settings/Commands.axaml.cs
Normal file
@@ -0,0 +1,119 @@
|
|||||||
|
using Avalonia;
|
||||||
|
using Avalonia.Controls;
|
||||||
|
using Avalonia.Markup.Xaml;
|
||||||
|
|
||||||
|
using PluginManager.Others;
|
||||||
|
|
||||||
|
using System.Linq;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
using System;
|
||||||
|
|
||||||
|
namespace DiscordBotGUI.Settings
|
||||||
|
{
|
||||||
|
public partial class Commands : Window
|
||||||
|
{
|
||||||
|
List<string> commands = new List<string>();
|
||||||
|
public Commands()
|
||||||
|
{
|
||||||
|
InitializeComponent();
|
||||||
|
LoadData();
|
||||||
|
LoadComboBox();
|
||||||
|
|
||||||
|
button1.Click += async (sender, e) =>
|
||||||
|
{
|
||||||
|
await Download();
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
private void LoadData()
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
var files = System.IO.Directory.EnumerateFiles("./Data/Plugins/Commands/");
|
||||||
|
if (files == null || files.Count() < 1) return;
|
||||||
|
foreach (var file in files)
|
||||||
|
textbox1.Text += file + "\n";
|
||||||
|
}
|
||||||
|
catch { }
|
||||||
|
}
|
||||||
|
|
||||||
|
private async void LoadComboBox()
|
||||||
|
{
|
||||||
|
commands = await PluginManager.Online.ServerCom.ReadTextFromFile("https://sethdiscordbot.000webhostapp.com/Storage/Discord%20Bot/Plugins");
|
||||||
|
if (commands == null) return;
|
||||||
|
string[] plugins = commands.ToArray();
|
||||||
|
string OS;
|
||||||
|
var OSG = Functions.GetOperatingSystem();
|
||||||
|
if (OSG == PluginManager.Others.OperatingSystem.WINDOWS) OS = "Windows";
|
||||||
|
else if (OSG == PluginManager.Others.OperatingSystem.LINUX) OS = "Linux";
|
||||||
|
else OS = "MAC_OS";
|
||||||
|
List<string> data = new List<string>();
|
||||||
|
for (int i = 0; i < plugins.Length; i++)
|
||||||
|
{
|
||||||
|
if (!plugins[i].Contains(OS) || !plugins[i].Contains("Commands"))
|
||||||
|
continue;
|
||||||
|
|
||||||
|
string[] info = plugins[i].Split(',');
|
||||||
|
data.Add($"{info[0]} - {info[1]} - {info[2]}");
|
||||||
|
}
|
||||||
|
|
||||||
|
comboBox1.Items = data;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
private async Task Download()
|
||||||
|
{
|
||||||
|
if (comboBox1 == null || comboBox1.SelectedIndex == -1 || comboBox1.SelectedItem == null)
|
||||||
|
return;
|
||||||
|
string? pluginName = comboBox1?.SelectedItem?.ToString()?.Split('-')[0].Trim();
|
||||||
|
|
||||||
|
if (pluginName == null) return;
|
||||||
|
string? URL = (from s in commands
|
||||||
|
where s.StartsWith(pluginName)
|
||||||
|
select s.Split(',')[3].Trim()).FirstOrDefault();
|
||||||
|
|
||||||
|
if (URL == null) return;
|
||||||
|
|
||||||
|
|
||||||
|
IProgress<float> progress = new Progress<float>(value =>
|
||||||
|
{
|
||||||
|
label1.Content = $"Downloading {pluginName} {MathF.Round(value, 2)}%";
|
||||||
|
if (value == 1f)
|
||||||
|
label1.Content = "Successfully Downloaded " + pluginName;
|
||||||
|
progressBar1.Value = value;
|
||||||
|
});
|
||||||
|
|
||||||
|
await PluginManager.Online.ServerCom.DownloadFileAsync(URL, "./Data/Plugins/Commands/" + pluginName + ".dll", progress);
|
||||||
|
string? requirements = (from s in commands
|
||||||
|
where s.StartsWith(pluginName) && s.Split(',').Length == 6
|
||||||
|
select s.Split(',')[5].Trim()).FirstOrDefault();
|
||||||
|
|
||||||
|
if (requirements == null) return;
|
||||||
|
List<string> req = await PluginManager.Online.ServerCom.ReadTextFromFile(requirements);
|
||||||
|
if (req == null) return;
|
||||||
|
|
||||||
|
foreach (var requirement in req)
|
||||||
|
{
|
||||||
|
string[] info = requirement.Split(',');
|
||||||
|
pluginName = info[1];
|
||||||
|
progress.Report(0);
|
||||||
|
await PluginManager.Online.ServerCom.DownloadFileAsync(info[0], $"./{info[1]}", progress);
|
||||||
|
|
||||||
|
await Task.Delay(1000);
|
||||||
|
|
||||||
|
if (info[0].EndsWith(".zip"))
|
||||||
|
{
|
||||||
|
await Functions.ExtractArchive("./" + info[1], "./", progress);
|
||||||
|
await Task.Delay(1000);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
progress.Report(100f);
|
||||||
|
label1.Content = "Downloaded";
|
||||||
|
progressBar1.Value = 100;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
17
DiscordBotGUI/Settings/Events.axaml
Normal file
17
DiscordBotGUI/Settings/Events.axaml
Normal file
@@ -0,0 +1,17 @@
|
|||||||
|
<Window xmlns="https://github.com/avaloniaui"
|
||||||
|
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
|
||||||
|
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
|
||||||
|
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
|
||||||
|
mc:Ignorable="d" d:DesignWidth="800" d:DesignHeight="450"
|
||||||
|
x:Class="DiscordBotGUI.Settings.Events"
|
||||||
|
Title="Events">
|
||||||
|
<StackPanel Margin="10">
|
||||||
|
<Label Content="Installed Events" />
|
||||||
|
<TextBox x:Class="DiscordBotGUI.Settings.Events" x:Name="textbox1" TextAlignment="Left" IsReadOnly="True" />
|
||||||
|
<Label Content="Install another Events" />
|
||||||
|
<ComboBox x:Class="DiscordBotGUI.Settings.Events" x:Name="comboBox1" HorizontalAlignment="Left" VerticalAlignment="Top" Margin="0,10" Padding="200,0" />
|
||||||
|
<Button x:Class="DiscordBotGUI.Settings.Events" x:Name="button1" HorizontalAlignment="Left" Content="Install" />
|
||||||
|
<ProgressBar x:Class="DiscordBotGUI.Settings.Events" x:Name="progressBar1" HorizontalAlignment="Left" Margin="0,10" />
|
||||||
|
<Label x:Class="DiscordBotGUI.Settings.Events" x:Name="label1" Content="" HorizontalAlignment="Left" Margin="0,10" />
|
||||||
|
</StackPanel>
|
||||||
|
</Window>
|
||||||
119
DiscordBotGUI/Settings/Events.axaml.cs
Normal file
119
DiscordBotGUI/Settings/Events.axaml.cs
Normal file
@@ -0,0 +1,119 @@
|
|||||||
|
using Avalonia;
|
||||||
|
using Avalonia.Controls;
|
||||||
|
using Avalonia.Markup.Xaml;
|
||||||
|
|
||||||
|
using PluginManager.Others;
|
||||||
|
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Reflection.Emit;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
|
||||||
|
using static PluginManager.Others.Console_Utilities;
|
||||||
|
|
||||||
|
namespace DiscordBotGUI.Settings
|
||||||
|
{
|
||||||
|
public partial class Events : Window
|
||||||
|
{
|
||||||
|
List<string> events = new List<string>();
|
||||||
|
public Events()
|
||||||
|
{
|
||||||
|
InitializeComponent();
|
||||||
|
LoadData();
|
||||||
|
LoadComboBox();
|
||||||
|
button1.Click += async (sender, e) =>
|
||||||
|
{
|
||||||
|
await Download();
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
private void LoadData()
|
||||||
|
{
|
||||||
|
//Read components from Commands Folder:
|
||||||
|
//textbox1 = new TextBox();
|
||||||
|
try
|
||||||
|
{
|
||||||
|
textbox1.IsReadOnly = false;
|
||||||
|
var files = System.IO.Directory.EnumerateFiles("./Data/Plugins/Events/");
|
||||||
|
if (files == null || files.Count() < 1) return;
|
||||||
|
foreach (var file in files)
|
||||||
|
textbox1.Text += file + "\n";
|
||||||
|
}
|
||||||
|
catch { }
|
||||||
|
}
|
||||||
|
private async void LoadComboBox()
|
||||||
|
{
|
||||||
|
events = await PluginManager.Online.ServerCom.ReadTextFromFile("https://sethdiscordbot.000webhostapp.com/Storage/Discord%20Bot/Plugins");
|
||||||
|
if (events == null) return;
|
||||||
|
string[] plugins = events.ToArray();
|
||||||
|
string OS;
|
||||||
|
var OSG = Functions.GetOperatingSystem();
|
||||||
|
if (OSG == PluginManager.Others.OperatingSystem.WINDOWS) OS = "Windows";
|
||||||
|
else if (OSG == PluginManager.Others.OperatingSystem.LINUX) OS = "Linux";
|
||||||
|
else OS = "MAC_OS";
|
||||||
|
List<string> data = new List<string>();
|
||||||
|
for (int i = 0; i < plugins.Length; i++)
|
||||||
|
{
|
||||||
|
if (!plugins[i].Contains(OS) || !plugins[i].Contains("Event"))
|
||||||
|
continue;
|
||||||
|
|
||||||
|
string[] info = plugins[i].Split(',');
|
||||||
|
data.Add($"{info[0]} - {info[1]} - {info[2]}");
|
||||||
|
}
|
||||||
|
|
||||||
|
comboBox1.Items = data;
|
||||||
|
}
|
||||||
|
private async Task Download()
|
||||||
|
{
|
||||||
|
if (comboBox1 == null || comboBox1.SelectedIndex == -1 || comboBox1.SelectedItem == null)
|
||||||
|
return;
|
||||||
|
string? pluginName = comboBox1?.SelectedItem?.ToString()?.Split('-')[0].Trim();
|
||||||
|
|
||||||
|
if (pluginName == null) return;
|
||||||
|
string? URL = (from s in events
|
||||||
|
where s.StartsWith(pluginName)
|
||||||
|
select s.Split(',')[3].Trim()).FirstOrDefault();
|
||||||
|
|
||||||
|
if (URL == null) return;
|
||||||
|
|
||||||
|
|
||||||
|
IProgress<float> progress = new Progress<float>(value =>
|
||||||
|
{
|
||||||
|
label1.Content = $"Downloading {pluginName} {MathF.Round(value, 2)}%";
|
||||||
|
if (value == 1f)
|
||||||
|
label1.Content = "Successfully Downloaded " + pluginName;
|
||||||
|
progressBar1.Value = value;
|
||||||
|
});
|
||||||
|
|
||||||
|
await PluginManager.Online.ServerCom.DownloadFileAsync(URL, "./Data/Plugins/Events/" + pluginName + ".dll", progress);
|
||||||
|
string? requirements = (from s in events
|
||||||
|
where s.StartsWith(pluginName) && s.Split(',').Length == 6
|
||||||
|
select s.Split(',')[5].Trim()).FirstOrDefault();
|
||||||
|
|
||||||
|
if (requirements == null) return;
|
||||||
|
List<string> req = await PluginManager.Online.ServerCom.ReadTextFromFile(requirements);
|
||||||
|
if (req == null) return;
|
||||||
|
|
||||||
|
foreach (var requirement in req)
|
||||||
|
{
|
||||||
|
string[] info = requirement.Split(',');
|
||||||
|
pluginName = info[1];
|
||||||
|
progress.Report(0);
|
||||||
|
await PluginManager.Online.ServerCom.DownloadFileAsync(info[0], $"./{info[1]}", progress);
|
||||||
|
|
||||||
|
await Task.Delay(1000);
|
||||||
|
|
||||||
|
if (info[0].EndsWith(".zip"))
|
||||||
|
{
|
||||||
|
await Functions.ExtractArchive("./" + info[1], "./", progress);
|
||||||
|
await Task.Delay(1000);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
label1.Content = "";
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -244,7 +244,7 @@ namespace PluginManager.Others
|
|||||||
/// <param name="zip">The zip location</param>
|
/// <param name="zip">The zip location</param>
|
||||||
/// <param name="folder">The target location</param>
|
/// <param name="folder">The target location</param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
public static async Task ExtractArchive(string zip, string folder, IProgress<double> progress)
|
public static async Task ExtractArchive(string zip, string folder, IProgress<float> progress)
|
||||||
{
|
{
|
||||||
if (!Directory.Exists(folder))
|
if (!Directory.Exists(folder))
|
||||||
Directory.CreateDirectory(folder);
|
Directory.CreateDirectory(folder);
|
||||||
@@ -270,7 +270,7 @@ namespace PluginManager.Others
|
|||||||
}
|
}
|
||||||
|
|
||||||
await Task.Delay(10);
|
await Task.Delay(10);
|
||||||
progress.Report((double)currentZIPFile / totalZIPFiles * 100);
|
progress.Report((float)currentZIPFile / totalZIPFiles * 100);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user