mirror of
https://github.com/crskycode/GARbro.git
synced 2024-11-23 13:45:34 +08:00
download formats db.
This commit is contained in:
parent
ccd4424b1b
commit
1d5d74ce93
@ -41,6 +41,7 @@ namespace GARbro.GUI
|
|||||||
const StringComparison StringIgnoreCase = StringComparison.OrdinalIgnoreCase;
|
const StringComparison StringIgnoreCase = StringComparison.OrdinalIgnoreCase;
|
||||||
|
|
||||||
public static string Name { get { return "GARbro"; } }
|
public static string Name { get { return "GARbro"; } }
|
||||||
|
public static string FormatsDat { get { return "Formats.dat"; } }
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Initial browsing directory.
|
/// Initial browsing directory.
|
||||||
@ -80,12 +81,11 @@ namespace GARbro.GUI
|
|||||||
if (string.IsNullOrEmpty (InitPath))
|
if (string.IsNullOrEmpty (InitPath))
|
||||||
InitPath = Directory.GetCurrentDirectory();
|
InitPath = Directory.GetCurrentDirectory();
|
||||||
|
|
||||||
string formats_dat = "Formats.dat";
|
DeserializeScheme (Path.Combine (FormatCatalog.Instance.DataDirectory, FormatsDat));
|
||||||
DeserializeScheme (Path.Combine (FormatCatalog.Instance.DataDirectory, formats_dat));
|
DeserializeScheme (Path.Combine (GetLocalAppDataFolder(), FormatsDat));
|
||||||
DeserializeScheme (Path.Combine (GetLocalAppDataFolder(), formats_dat));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
string GetLocalAppDataFolder ()
|
public string GetLocalAppDataFolder ()
|
||||||
{
|
{
|
||||||
string local_app_data = Environment.GetFolderPath (Environment.SpecialFolder.LocalApplicationData);
|
string local_app_data = Environment.GetFolderPath (Environment.SpecialFolder.LocalApplicationData);
|
||||||
var attribs = Assembly.GetExecutingAssembly().GetCustomAttributes (typeof(AssemblyCompanyAttribute), false);
|
var attribs = Assembly.GetExecutingAssembly().GetCustomAttributes (typeof(AssemblyCompanyAttribute), false);
|
||||||
@ -93,7 +93,7 @@ namespace GARbro.GUI
|
|||||||
return Path.Combine (local_app_data, company, Name);
|
return Path.Combine (local_app_data, company, Name);
|
||||||
}
|
}
|
||||||
|
|
||||||
void DeserializeScheme (string scheme_file)
|
public void DeserializeScheme (string scheme_file)
|
||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
|
156
GUI/GarUpdate.cs
156
GUI/GarUpdate.cs
@ -34,44 +34,93 @@ using System.Windows.Input;
|
|||||||
using System.Xml;
|
using System.Xml;
|
||||||
using GameRes;
|
using GameRes;
|
||||||
using GARbro.GUI.Strings;
|
using GARbro.GUI.Strings;
|
||||||
|
using System.IO;
|
||||||
|
|
||||||
namespace GARbro.GUI
|
namespace GARbro.GUI
|
||||||
{
|
{
|
||||||
public partial class MainWindow : Window
|
public partial class MainWindow : Window
|
||||||
{
|
{
|
||||||
private readonly BackgroundWorker m_update_checker = new BackgroundWorker();
|
GarUpdate m_updater;
|
||||||
|
|
||||||
private void InitUpdatesChecker ()
|
private void InitUpdatesChecker ()
|
||||||
{
|
{
|
||||||
m_update_checker.DoWork += StartUpdatesCheck;
|
var update_url = App.Resources["UpdateUrl"] as Uri;
|
||||||
m_update_checker.RunWorkerCompleted += UpdatesCheckComplete;
|
m_updater = new GarUpdate (this, update_url);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void CanExecuteUpdate (object sender, CanExecuteRoutedEventArgs e)
|
||||||
|
{
|
||||||
|
e.CanExecute = m_updater.CanExecute (e.Parameter);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Handle "Check for updates" command.
|
/// Handle "Check for updates" command.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
private void CheckUpdatesExec (object sender, ExecutedRoutedEventArgs e)
|
private void CheckUpdatesExec (object sender, ExecutedRoutedEventArgs e)
|
||||||
|
{
|
||||||
|
m_updater.Execute (e.Parameter);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public class GarUpdateInfo
|
||||||
|
{
|
||||||
|
public Version ReleaseVersion { get; set; }
|
||||||
|
public Uri ReleaseUrl { get; set; }
|
||||||
|
public string ReleaseNotes { get; set; }
|
||||||
|
public int FormatsVersion { get; set; }
|
||||||
|
public Uri FormatsUrl { get; set; }
|
||||||
|
public IDictionary<string, Version> Assemblies { get; set; }
|
||||||
|
}
|
||||||
|
|
||||||
|
internal sealed class GarUpdate : ICommand, IDisposable
|
||||||
|
{
|
||||||
|
private readonly MainWindow m_main;
|
||||||
|
private readonly BackgroundWorker m_update_checker = new BackgroundWorker();
|
||||||
|
private readonly Uri m_url;
|
||||||
|
|
||||||
|
const int RequestTimeout = 20000; // milliseconds
|
||||||
|
|
||||||
|
public GarUpdate (MainWindow main, Uri url)
|
||||||
|
{
|
||||||
|
m_main = main;
|
||||||
|
m_url = url;
|
||||||
|
m_update_checker.DoWork += StartUpdatesCheck;
|
||||||
|
m_update_checker.RunWorkerCompleted += UpdatesCheckComplete;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void Execute (object parameter)
|
||||||
{
|
{
|
||||||
if (!m_update_checker.IsBusy)
|
if (!m_update_checker.IsBusy)
|
||||||
m_update_checker.RunWorkerAsync();
|
m_update_checker.RunWorkerAsync();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public bool CanExecute (object parameter)
|
||||||
|
{
|
||||||
|
return !m_update_checker.IsBusy;
|
||||||
|
}
|
||||||
|
|
||||||
|
public event EventHandler CanExecuteChanged;
|
||||||
|
|
||||||
|
void OnCanExecuteChanged ()
|
||||||
|
{
|
||||||
|
var handler = CanExecuteChanged;
|
||||||
|
if (handler != null)
|
||||||
|
handler (this, new EventArgs());
|
||||||
|
}
|
||||||
|
|
||||||
private void StartUpdatesCheck (object sender, DoWorkEventArgs e)
|
private void StartUpdatesCheck (object sender, DoWorkEventArgs e)
|
||||||
{
|
{
|
||||||
var url = m_app.Resources["UpdateUrl"] as Uri;
|
OnCanExecuteChanged();
|
||||||
if (null == url)
|
if (m_url != null)
|
||||||
return;
|
e.Result = Check (m_url);
|
||||||
using (var updater = new GarUpdate (this))
|
|
||||||
{
|
|
||||||
e.Result = updater.Check (url);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void UpdatesCheckComplete (object sender, RunWorkerCompletedEventArgs e)
|
private void UpdatesCheckComplete (object sender, RunWorkerCompletedEventArgs e)
|
||||||
{
|
{
|
||||||
|
OnCanExecuteChanged();
|
||||||
if (e.Error != null)
|
if (e.Error != null)
|
||||||
{
|
{
|
||||||
SetStatusText (string.Format ("{0} {1}", guiStrings.MsgUpdateFailed, e.Error.Message));
|
m_main.SetStatusText (string.Format ("{0} {1}", guiStrings.MsgUpdateFailed, e.Error.Message));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
else if (e.Cancelled)
|
else if (e.Cancelled)
|
||||||
@ -79,7 +128,7 @@ namespace GARbro.GUI
|
|||||||
var result = e.Result as GarUpdateInfo;
|
var result = e.Result as GarUpdateInfo;
|
||||||
if (null == result)
|
if (null == result)
|
||||||
{
|
{
|
||||||
SetStatusText (guiStrings.MsgNoUpdates);
|
m_main.SetStatusText (guiStrings.MsgNoUpdates);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
var app_version = Assembly.GetExecutingAssembly().GetName().Version;
|
var app_version = Assembly.GetExecutingAssembly().GetName().Version;
|
||||||
@ -88,17 +137,44 @@ namespace GARbro.GUI
|
|||||||
bool has_db_update = db_version < result.FormatsVersion && CheckAssemblies (result.Assemblies);
|
bool has_db_update = db_version < result.FormatsVersion && CheckAssemblies (result.Assemblies);
|
||||||
if (!has_app_update && !has_db_update)
|
if (!has_app_update && !has_db_update)
|
||||||
{
|
{
|
||||||
SetStatusText (guiStrings.MsgUpToDate);
|
m_main.SetStatusText (guiStrings.MsgUpToDate);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
var dialog = new UpdateDialog (result, has_app_update, has_db_update);
|
var dialog = new UpdateDialog (result, has_app_update, has_db_update);
|
||||||
dialog.Owner = this;
|
dialog.Owner = m_main;
|
||||||
dialog.FormatsDownload.Click += FormatsDownloadExec;
|
dialog.FormatsDownload.Click += (s, a) => StartFormatsDownload (dialog, result);
|
||||||
dialog.ShowDialog();
|
dialog.ShowDialog();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void FormatsDownloadExec (object sender, RoutedEventArgs e)
|
private void StartFormatsDownload (UpdateDialog dialog, GarUpdateInfo info)
|
||||||
{
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
dialog.FormatsDownload.IsEnabled = false;
|
||||||
|
var app_data_folder = m_main.App.GetLocalAppDataFolder();
|
||||||
|
Directory.CreateDirectory (app_data_folder);
|
||||||
|
var local_formats_dat = Path.Combine (app_data_folder, App.FormatsDat);
|
||||||
|
using (var client = new WebClientEx())
|
||||||
|
using (var tmp_file = new GARbro.Shell.TemporaryFile (app_data_folder, Path.GetRandomFileName()))
|
||||||
|
{
|
||||||
|
client.Timeout = RequestTimeout;
|
||||||
|
// FIXME download blocks GUI thread.
|
||||||
|
client.DownloadFile (info.FormatsUrl, tmp_file.Name);
|
||||||
|
|
||||||
|
m_main.App.DeserializeScheme (tmp_file.Name);
|
||||||
|
if (!GARbro.Shell.File.Rename (tmp_file.Name, local_formats_dat))
|
||||||
|
throw new Win32Exception (GARbro.Shell.File.GetLastError());
|
||||||
|
}
|
||||||
|
dialog.FormatsUpdateText.Text = guiStrings.MsgUpdateComplete;
|
||||||
|
}
|
||||||
|
catch (Exception X)
|
||||||
|
{
|
||||||
|
dialog.FormatsUpdateText.Text = string.Format ("{0}\n{1}", guiStrings.MsgDownloadFailed, X.Message);
|
||||||
|
}
|
||||||
|
finally
|
||||||
|
{
|
||||||
|
dialog.FormatsDownload.Visibility = Visibility.Collapsed;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -117,30 +193,8 @@ namespace GARbro.GUI
|
|||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
public class GarUpdateInfo
|
GarUpdateInfo Check (Uri version_url)
|
||||||
{
|
|
||||||
public Version ReleaseVersion { get; set; }
|
|
||||||
public Uri ReleaseUrl { get; set; }
|
|
||||||
public string ReleaseNotes { get; set; }
|
|
||||||
public int FormatsVersion { get; set; }
|
|
||||||
public Uri FormatsUrl { get; set; }
|
|
||||||
public IDictionary<string, Version> Assemblies { get; set; }
|
|
||||||
}
|
|
||||||
|
|
||||||
internal sealed class GarUpdate : IDisposable
|
|
||||||
{
|
|
||||||
Window m_main;
|
|
||||||
|
|
||||||
const int RequestTimeout = 20000; // milliseconds
|
|
||||||
|
|
||||||
public GarUpdate (Window main)
|
|
||||||
{
|
|
||||||
m_main = main;
|
|
||||||
}
|
|
||||||
|
|
||||||
public GarUpdateInfo Check (Uri version_url)
|
|
||||||
{
|
{
|
||||||
var request = WebRequest.Create (version_url);
|
var request = WebRequest.Create (version_url);
|
||||||
request.Timeout = RequestTimeout;
|
request.Timeout = RequestTimeout;
|
||||||
@ -190,9 +244,33 @@ namespace GARbro.GUI
|
|||||||
{
|
{
|
||||||
if (!m_disposed)
|
if (!m_disposed)
|
||||||
{
|
{
|
||||||
|
m_update_checker.Dispose();
|
||||||
m_disposed = true;
|
m_disposed = true;
|
||||||
}
|
}
|
||||||
GC.SuppressFinalize (this);
|
GC.SuppressFinalize (this);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// WebClient with timeout setting.
|
||||||
|
/// </summary>
|
||||||
|
internal class WebClientEx : WebClient
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// Request timeout, in milliseconds.
|
||||||
|
/// </summary>
|
||||||
|
public int Timeout { get; set; }
|
||||||
|
|
||||||
|
public WebClientEx ()
|
||||||
|
{
|
||||||
|
Timeout = 60000;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected override WebRequest GetWebRequest (Uri uri)
|
||||||
|
{
|
||||||
|
var request = base.GetWebRequest (uri);
|
||||||
|
request.Timeout = Timeout;
|
||||||
|
return request;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -403,7 +403,7 @@
|
|||||||
<CommandBinding Command="{x:Static local:Commands.HideMenuBar}" Executed="HideMenuBarExec" CanExecute="CanExecuteAlways"/>
|
<CommandBinding Command="{x:Static local:Commands.HideMenuBar}" Executed="HideMenuBarExec" CanExecute="CanExecuteAlways"/>
|
||||||
<CommandBinding Command="{x:Static local:Commands.HideToolBar}" Executed="HideToolBarExec" CanExecute="CanExecuteAlways"/>
|
<CommandBinding Command="{x:Static local:Commands.HideToolBar}" Executed="HideToolBarExec" CanExecute="CanExecuteAlways"/>
|
||||||
<CommandBinding Command="{x:Static local:Commands.About}" Executed="AboutExec" CanExecute="CanExecuteAlways"/>
|
<CommandBinding Command="{x:Static local:Commands.About}" Executed="AboutExec" CanExecute="CanExecuteAlways"/>
|
||||||
<CommandBinding Command="{x:Static local:Commands.CheckUpdates}" Executed="CheckUpdatesExec" CanExecute="CanExecuteAlways"/>
|
<CommandBinding Command="{x:Static local:Commands.CheckUpdates}" Executed="CheckUpdatesExec" CanExecute="CanExecuteUpdate"/>
|
||||||
<CommandBinding Command="{x:Static local:Commands.Exit}" Executed="ExitExec" CanExecute="CanExecuteAlways"/>
|
<CommandBinding Command="{x:Static local:Commands.Exit}" Executed="ExitExec" CanExecute="CanExecuteAlways"/>
|
||||||
</Window.CommandBindings>
|
</Window.CommandBindings>
|
||||||
</Window>
|
</Window>
|
||||||
|
@ -54,6 +54,8 @@ namespace GARbro.GUI
|
|||||||
{
|
{
|
||||||
private App m_app;
|
private App m_app;
|
||||||
|
|
||||||
|
public App App { get { return m_app; } }
|
||||||
|
|
||||||
const StringComparison StringIgnoreCase = StringComparison.CurrentCultureIgnoreCase;
|
const StringComparison StringIgnoreCase = StringComparison.CurrentCultureIgnoreCase;
|
||||||
|
|
||||||
public MainWindow()
|
public MainWindow()
|
||||||
|
27
GUI/Strings/guiStrings.Designer.cs
generated
27
GUI/Strings/guiStrings.Designer.cs
generated
@ -663,6 +663,15 @@ namespace GARbro.GUI.Strings {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Looks up a localized string similar to Update download failed..
|
||||||
|
/// </summary>
|
||||||
|
public static string MsgDownloadFailed {
|
||||||
|
get {
|
||||||
|
return ResourceManager.GetString("MsgDownloadFailed", resourceCulture);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Looks up a localized string similar to archive is empty.
|
/// Looks up a localized string similar to archive is empty.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
@ -882,6 +891,15 @@ namespace GARbro.GUI.Strings {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Looks up a localized string similar to Formats database updated..
|
||||||
|
/// </summary>
|
||||||
|
public static string MsgUpdateComplete {
|
||||||
|
get {
|
||||||
|
return ResourceManager.GetString("MsgUpdateComplete", resourceCulture);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Looks up a localized string similar to Update check failed..
|
/// Looks up a localized string similar to Update check failed..
|
||||||
/// </summary>
|
/// </summary>
|
||||||
@ -1210,6 +1228,15 @@ namespace GARbro.GUI.Strings {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Looks up a localized string similar to Application update.
|
||||||
|
/// </summary>
|
||||||
|
public static string TextUpdateTitle {
|
||||||
|
get {
|
||||||
|
return ResourceManager.GetString("TextUpdateTitle", resourceCulture);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Looks up a localized string similar to Visit download page.
|
/// Looks up a localized string similar to Visit download page.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
@ -505,6 +505,10 @@
|
|||||||
<value>Check for updates...</value>
|
<value>Check for updates...</value>
|
||||||
<comment>translation pending</comment>
|
<comment>translation pending</comment>
|
||||||
</data>
|
</data>
|
||||||
|
<data name="MsgDownloadFailed" xml:space="preserve">
|
||||||
|
<value>Update download failed.</value>
|
||||||
|
<comment>translation pending</comment>
|
||||||
|
</data>
|
||||||
<data name="MsgNoUpdates" xml:space="preserve">
|
<data name="MsgNoUpdates" xml:space="preserve">
|
||||||
<value>No updates currently available.</value>
|
<value>No updates currently available.</value>
|
||||||
<comment>translation pending</comment>
|
<comment>translation pending</comment>
|
||||||
@ -513,6 +517,10 @@
|
|||||||
<value>Formats database update available.</value>
|
<value>Formats database update available.</value>
|
||||||
<comment>translation pending</comment>
|
<comment>translation pending</comment>
|
||||||
</data>
|
</data>
|
||||||
|
<data name="MsgUpdateComplete" xml:space="preserve">
|
||||||
|
<value>Formats database updated.</value>
|
||||||
|
<comment>translation pending</comment>
|
||||||
|
</data>
|
||||||
<data name="MsgUpdateFailed" xml:space="preserve">
|
<data name="MsgUpdateFailed" xml:space="preserve">
|
||||||
<value>Update check failed.</value>
|
<value>Update check failed.</value>
|
||||||
<comment>translation pending</comment>
|
<comment>translation pending</comment>
|
||||||
@ -525,6 +533,10 @@
|
|||||||
<value>New version available:</value>
|
<value>New version available:</value>
|
||||||
<comment>translation pending</comment>
|
<comment>translation pending</comment>
|
||||||
</data>
|
</data>
|
||||||
|
<data name="TextUpdateTitle" xml:space="preserve">
|
||||||
|
<value>Application update</value>
|
||||||
|
<comment>translation pending</comment>
|
||||||
|
</data>
|
||||||
<data name="TextVisitPage" xml:space="preserve">
|
<data name="TextVisitPage" xml:space="preserve">
|
||||||
<value>Visit download page</value>
|
<value>Visit download page</value>
|
||||||
<comment>translation pending</comment>
|
<comment>translation pending</comment>
|
||||||
|
@ -512,6 +512,9 @@ Overwrite?</value>
|
|||||||
<data name="MsgUpdateAvailable" xml:space="preserve">
|
<data name="MsgUpdateAvailable" xml:space="preserve">
|
||||||
<value>Formats database update available.</value>
|
<value>Formats database update available.</value>
|
||||||
</data>
|
</data>
|
||||||
|
<data name="MsgUpdateComplete" xml:space="preserve">
|
||||||
|
<value>Formats database updated.</value>
|
||||||
|
</data>
|
||||||
<data name="MsgUpdateFailed" xml:space="preserve">
|
<data name="MsgUpdateFailed" xml:space="preserve">
|
||||||
<value>Update check failed.</value>
|
<value>Update check failed.</value>
|
||||||
</data>
|
</data>
|
||||||
@ -521,7 +524,13 @@ Overwrite?</value>
|
|||||||
<data name="TextNewVersion" xml:space="preserve">
|
<data name="TextNewVersion" xml:space="preserve">
|
||||||
<value>New version available:</value>
|
<value>New version available:</value>
|
||||||
</data>
|
</data>
|
||||||
|
<data name="TextUpdateTitle" xml:space="preserve">
|
||||||
|
<value>Application update</value>
|
||||||
|
</data>
|
||||||
<data name="TextVisitPage" xml:space="preserve">
|
<data name="TextVisitPage" xml:space="preserve">
|
||||||
<value>Visit download page</value>
|
<value>Visit download page</value>
|
||||||
</data>
|
</data>
|
||||||
|
<data name="MsgDownloadFailed" xml:space="preserve">
|
||||||
|
<value>Update download failed.</value>
|
||||||
|
</data>
|
||||||
</root>
|
</root>
|
@ -527,12 +527,18 @@
|
|||||||
<data name="MenuCheckUpdates" xml:space="preserve">
|
<data name="MenuCheckUpdates" xml:space="preserve">
|
||||||
<value>Проверить обновления...</value>
|
<value>Проверить обновления...</value>
|
||||||
</data>
|
</data>
|
||||||
|
<data name="MsgDownloadFailed" xml:space="preserve">
|
||||||
|
<value>Не удалось обновить базу форматов.</value>
|
||||||
|
</data>
|
||||||
<data name="MsgNoUpdates" xml:space="preserve">
|
<data name="MsgNoUpdates" xml:space="preserve">
|
||||||
<value>Обновления недоступны.</value>
|
<value>Обновления недоступны.</value>
|
||||||
</data>
|
</data>
|
||||||
<data name="MsgUpdateAvailable" xml:space="preserve">
|
<data name="MsgUpdateAvailable" xml:space="preserve">
|
||||||
<value>Доступна обновлённая база форматов.</value>
|
<value>Доступна обновлённая база форматов.</value>
|
||||||
</data>
|
</data>
|
||||||
|
<data name="MsgUpdateComplete" xml:space="preserve">
|
||||||
|
<value>База форматов успешно обновлена.</value>
|
||||||
|
</data>
|
||||||
<data name="MsgUpdateFailed" xml:space="preserve">
|
<data name="MsgUpdateFailed" xml:space="preserve">
|
||||||
<value>Сбой проверки обновлений.</value>
|
<value>Сбой проверки обновлений.</value>
|
||||||
</data>
|
</data>
|
||||||
@ -542,6 +548,9 @@
|
|||||||
<data name="TextNewVersion" xml:space="preserve">
|
<data name="TextNewVersion" xml:space="preserve">
|
||||||
<value>Доступна новая версия:</value>
|
<value>Доступна новая версия:</value>
|
||||||
</data>
|
</data>
|
||||||
|
<data name="TextUpdateTitle" xml:space="preserve">
|
||||||
|
<value>Обновление программы</value>
|
||||||
|
</data>
|
||||||
<data name="TextVisitPage" xml:space="preserve">
|
<data name="TextVisitPage" xml:space="preserve">
|
||||||
<value>Перейти на страницу загрузки</value>
|
<value>Перейти на страницу загрузки</value>
|
||||||
</data>
|
</data>
|
||||||
|
@ -517,6 +517,10 @@
|
|||||||
<value>Check for updates...</value>
|
<value>Check for updates...</value>
|
||||||
<comment>translation pending</comment>
|
<comment>translation pending</comment>
|
||||||
</data>
|
</data>
|
||||||
|
<data name="MsgDownloadFailed" xml:space="preserve">
|
||||||
|
<value>Update download failed.</value>
|
||||||
|
<comment>translation pending</comment>
|
||||||
|
</data>
|
||||||
<data name="MsgNoUpdates" xml:space="preserve">
|
<data name="MsgNoUpdates" xml:space="preserve">
|
||||||
<value>No updates currently available.</value>
|
<value>No updates currently available.</value>
|
||||||
<comment>translation pending</comment>
|
<comment>translation pending</comment>
|
||||||
@ -525,6 +529,10 @@
|
|||||||
<value>Formats database update available.</value>
|
<value>Formats database update available.</value>
|
||||||
<comment>translation pending</comment>
|
<comment>translation pending</comment>
|
||||||
</data>
|
</data>
|
||||||
|
<data name="MsgUpdateComplete" xml:space="preserve">
|
||||||
|
<value>Formats database updated.</value>
|
||||||
|
<comment>translation pending</comment>
|
||||||
|
</data>
|
||||||
<data name="MsgUpdateFailed" xml:space="preserve">
|
<data name="MsgUpdateFailed" xml:space="preserve">
|
||||||
<value>Update check failed.</value>
|
<value>Update check failed.</value>
|
||||||
<comment>translation pending</comment>
|
<comment>translation pending</comment>
|
||||||
@ -537,6 +545,10 @@
|
|||||||
<value>New version available:</value>
|
<value>New version available:</value>
|
||||||
<comment>translation pending</comment>
|
<comment>translation pending</comment>
|
||||||
</data>
|
</data>
|
||||||
|
<data name="TextUpdateTitle" xml:space="preserve">
|
||||||
|
<value>Application update</value>
|
||||||
|
<comment>translation pending</comment>
|
||||||
|
</data>
|
||||||
<data name="TextVisitPage" xml:space="preserve">
|
<data name="TextVisitPage" xml:space="preserve">
|
||||||
<value>Visit download page</value>
|
<value>Visit download page</value>
|
||||||
<comment>translation pending</comment>
|
<comment>translation pending</comment>
|
||||||
|
@ -24,7 +24,7 @@ IN THE SOFTWARE.
|
|||||||
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
|
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
|
||||||
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
|
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
|
||||||
xmlns:s="clr-namespace:GARbro.GUI.Strings"
|
xmlns:s="clr-namespace:GARbro.GUI.Strings"
|
||||||
Title="Application update" ShowInTaskbar="False" WindowStartupLocation="CenterOwner"
|
Title="{x:Static s:guiStrings.TextUpdateTitle}" ShowInTaskbar="False" WindowStartupLocation="CenterOwner"
|
||||||
Background="{DynamicResource {x:Static SystemColors.ControlBrushKey}}"
|
Background="{DynamicResource {x:Static SystemColors.ControlBrushKey}}"
|
||||||
SizeToContent="WidthAndHeight" ResizeMode="NoResize">
|
SizeToContent="WidthAndHeight" ResizeMode="NoResize">
|
||||||
<DockPanel>
|
<DockPanel>
|
||||||
@ -34,7 +34,7 @@ IN THE SOFTWARE.
|
|||||||
Margin="10" Width="75" Height="25" Click="Button_Click" IsCancel="True"/>
|
Margin="10" Width="75" Height="25" Click="Button_Click" IsCancel="True"/>
|
||||||
</Border>
|
</Border>
|
||||||
</DockPanel>
|
</DockPanel>
|
||||||
<Image DockPanel.Dock="Left" Source="Images/64x64/actions.png" Width="32" Height="32" Margin="10"
|
<Image DockPanel.Dock="Left" Source="Images/64x64/actions.png" Width="32" Height="32" Margin="10,20"
|
||||||
SnapsToDevicePixels="True" VerticalAlignment="Top" RenderOptions.BitmapScalingMode="HighQuality"/>
|
SnapsToDevicePixels="True" VerticalAlignment="Top" RenderOptions.BitmapScalingMode="HighQuality"/>
|
||||||
<StackPanel DockPanel.Dock="Right" Orientation="Vertical">
|
<StackPanel DockPanel.Dock="Right" Orientation="Vertical">
|
||||||
<StackPanel x:Name="ReleasePane" Orientation="Vertical">
|
<StackPanel x:Name="ReleasePane" Orientation="Vertical">
|
||||||
@ -53,8 +53,8 @@ IN THE SOFTWARE.
|
|||||||
</StackPanel>
|
</StackPanel>
|
||||||
<StackPanel x:Name="FormatsPane" Orientation="Vertical">
|
<StackPanel x:Name="FormatsPane" Orientation="Vertical">
|
||||||
<Separator Visibility="{Binding ElementName=ReleasePane, Path=Visibility}"/>
|
<Separator Visibility="{Binding ElementName=ReleasePane, Path=Visibility}"/>
|
||||||
<TextBlock Text="{x:Static s:guiStrings.MsgUpdateAvailable}" Margin="0,10,10,0"/>
|
<TextBlock x:Name="FormatsUpdateText" Text="{x:Static s:guiStrings.MsgUpdateAvailable}" Margin="0,10,10,10"/>
|
||||||
<Button x:Name="FormatsDownload" Content="{x:Static s:guiStrings.ButtonDownload}" Width="75" Height="25" Margin="0,10,10,10" HorizontalAlignment="Left"/>
|
<Button x:Name="FormatsDownload" Content="{x:Static s:guiStrings.ButtonDownload}" Width="75" Height="25" Margin="0,0,10,10" HorizontalAlignment="Left"/>
|
||||||
</StackPanel>
|
</StackPanel>
|
||||||
</StackPanel>
|
</StackPanel>
|
||||||
</DockPanel>
|
</DockPanel>
|
||||||
|
Loading…
Reference in New Issue
Block a user