Re-style the installer

This commit is contained in:
Eric Reed 2013-03-01 10:21:27 -05:00
parent 6cb135f89c
commit a486ff5443
2 changed files with 57 additions and 18 deletions

View File

@ -3,14 +3,56 @@
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:Code="clr-namespace:MediaBrowser.Installer.Code" x:Class="MediaBrowser.Installer.MainWindow" xmlns:Code="clr-namespace:MediaBrowser.Installer.Code" x:Class="MediaBrowser.Installer.MainWindow"
Title="Install Media Browser Server" Height="383.481" Width="663.057" ResizeMode="NoResize" WindowStyle="None"> Title="Install Media Browser Server" Height="383.481" Width="663.057" ResizeMode="NoResize" WindowStyle="None">
<Border BorderBrush="DarkGray" BorderThickness="2"> <Border BorderBrush="DarkGray" BorderThickness="2" Margin="0,0,0,0">
<Grid Margin="0,0,0,2"> <Grid Margin="-2,0,0,-14">
<Image x:Name="imgLogo" HorizontalAlignment="Center" Height="172" Margin="10,10,57,0" VerticalAlignment="Top" Width="590" Source="Code/Images/mb3logo800.png" Opacity="0.5"/> <Image x:Name="imgLogo" HorizontalAlignment="Center" Height="172" Margin="10,10,57,0" VerticalAlignment="Top" Width="590" Source="Code/Images/mb3logo800.png" Opacity="0.5"/>
<ProgressBar x:Name="prgProgress" HorizontalAlignment="Left" Height="11" Margin="52,320,0,0" VerticalAlignment="Top" Width="460"/> <Grid HorizontalAlignment="Left" Height="153" Margin="0,173,0,0" VerticalAlignment="Top" Width="659" Background="Gray">
<Code:DownloadAnimation x:Name="dlAnimation" HorizontalAlignment="Left" Margin="26,97,0,0" VerticalAlignment="Top" Height="196" Width="574" RenderTransformOrigin="0.5,0.5"/> <TextBlock x:Name="lblStatus" HorizontalAlignment="Left" Margin="12,14,0,18" Width="637" FontSize="36" Foreground="#FFE6D7D7" Text="Status" TextWrapping="WrapWithOverflow"/>
<Button x:Name="btnCancel" Content="Cancel" HorizontalAlignment="Left" Margin="547,309,0,0" VerticalAlignment="Top" Width="79" FontSize="14" Click="btnCancel_Click"/> <Rectangle Fill="#FF49494B" HorizontalAlignment="Left" Height="13" Stroke="Black" VerticalAlignment="Bottom" Width="659"/>
<Label x:Name="lblStatus" Content="Status" HorizontalAlignment="Left" Margin="52,264,0,0" VerticalAlignment="Top" Width="574" FontSize="14" FontWeight="Bold"/> <Rectangle x:Name="rectProgress" Fill="#FF0A0ABF" HorizontalAlignment="Left" Height="13" Stroke="Black" VerticalAlignment="Bottom" Width="0"/>
</Grid>
<Button x:Name="btnCancel" Content="Cancel" HorizontalAlignment="Left" Margin="552,336,0,0" Width="97" FontSize="14" Click="btnCancel_Click" Height="31" VerticalAlignment="Top"/>
</Grid> </Grid>
</Border> </Border>
<Window.Resources>
<!--Metro Button-->
<Style TargetType="{x:Type Button}" BasedOn="{x:Null}">
<Setter Property="Background" Value="Transparent"/>
<Setter Property="Foreground" Value="#222222"/>
<Setter Property="FontSize" Value="16"/>
<Setter Property="Padding" Value="10,5,10,5"/>
<Setter Property="BorderBrush" Value="#222222"/>
<Setter Property="BorderThickness" Value="2"/>
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="{x:Type Button}">
<!-- We use Grid as a root because it is easy to add more elements to customize the button -->
<Grid x:Name="Grid">
<Border x:Name="Border" Background="{TemplateBinding Background}" BorderBrush="{TemplateBinding BorderBrush}" BorderThickness="{TemplateBinding BorderThickness}" Padding="{TemplateBinding Padding}"/>
<!-- Content Presenter is where the text content etc is placed by the control -->
<!-- The bindings are useful so that the control can be parameterized without editing the template -->
<ContentPresenter HorizontalAlignment="{TemplateBinding HorizontalContentAlignment}" Margin="{TemplateBinding Padding}" VerticalAlignment="{TemplateBinding VerticalContentAlignment}" RecognizesAccessKey="True"/>
</Grid>
<!--Each state sets a brush on the Border in the template -->
<ControlTemplate.Triggers>
<Trigger Property="IsPressed" Value="true">
<Setter Property="Background" Value="#222222" TargetName="Border"/>
<Setter Property="BorderBrush" Value="#222222" TargetName="Border"/>
<Setter Property="Foreground" Value="White"/>
<Setter Property="FontSize" Value="16"/>
</Trigger>
<Trigger Property="IsEnabled" Value="true"/>
<Trigger Property="IsEnabled" Value="false">
<Setter Property="BorderBrush" Value="#7f222222" TargetName="Border"/>
<Setter Property="Foreground" Value="#7f222222"/>
</Trigger>
</ControlTemplate.Triggers>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
</Window.Resources>
</Window> </Window>

View File

@ -105,10 +105,7 @@ namespace MediaBrowser.Installer
/// <returns></returns> /// <returns></returns>
protected async Task DoInstall() protected async Task DoInstall()
{ {
lblStatus.Content = string.Format("Downloading {0}...", FriendlyName); lblStatus.Text = string.Format("Downloading {0}...", FriendlyName);
dlAnimation.StartAnimation();
prgProgress.Value = 0;
prgProgress.Visibility = Visibility.Visible;
// Determine Package version // Determine Package version
var version = await GetPackageVersion(); var version = await GetPackageVersion();
@ -116,7 +113,7 @@ namespace MediaBrowser.Installer
// Now try and shut down the server if that is what we are installing and it is running // Now try and shut down the server if that is what we are installing and it is running
if (PackageName == "MBServer" && Process.GetProcessesByName("mediabrowser.serverapplication").Length != 0) if (PackageName == "MBServer" && Process.GetProcessesByName("mediabrowser.serverapplication").Length != 0)
{ {
lblStatus.Content = "Shutting Down Media Browser Server..."; lblStatus.Text = "Shutting Down Media Browser Server...";
using (var client = new WebClient()) using (var client = new WebClient())
{ {
try try
@ -139,7 +136,7 @@ namespace MediaBrowser.Installer
var processes = Process.GetProcessesByName("mediabrowser.ui"); var processes = Process.GetProcessesByName("mediabrowser.ui");
if (processes.Length > 0) if (processes.Length > 0)
{ {
lblStatus.Content = "Shutting Down Media Browser Theater..."; lblStatus.Text = "Shutting Down Media Browser Theater...";
try try
{ {
processes[0].Kill(); processes[0].Kill();
@ -155,7 +152,7 @@ namespace MediaBrowser.Installer
// Download // Download
string archive = null; string archive = null;
lblStatus.Content = string.Format("Downloading {0} (version {1})...", FriendlyName, version.versionStr); lblStatus.Text = string.Format("Downloading {0} (version {1})...", FriendlyName, version.versionStr);
try try
{ {
archive = await DownloadPackage(version); archive = await DownloadPackage(version);
@ -165,13 +162,10 @@ namespace MediaBrowser.Installer
SystemClose("Error Downloading Package - " + e.GetType().FullName + "\n\n" + e.Message); SystemClose("Error Downloading Package - " + e.GetType().FullName + "\n\n" + e.Message);
} }
dlAnimation.StopAnimation();
prgProgress.Visibility = btnCancel.Visibility = Visibility.Hidden;
if (archive == null) return; //we canceled or had an error that was already reported if (archive == null) return; //we canceled or had an error that was already reported
// Extract // Extract
lblStatus.Content = "Extracting Package..."; lblStatus.Text = "Extracting Package...";
try try
{ {
ExtractPackage(archive); ExtractPackage(archive);
@ -267,7 +261,7 @@ namespace MediaBrowser.Installer
void DownloadProgressChanged(object sender, DownloadProgressChangedEventArgs e) void DownloadProgressChanged(object sender, DownloadProgressChangedEventArgs e)
{ {
prgProgress.Value = e.ProgressPercentage; rectProgress.Width = (660 * e.ProgressPercentage)/100f;
} }
/// <summary> /// <summary>
@ -277,6 +271,9 @@ namespace MediaBrowser.Installer
/// <param name="archive"></param> /// <param name="archive"></param>
protected void ExtractPackage(string archive) protected void ExtractPackage(string archive)
{ {
// Delete old content of system
var systemDir = Path.Combine(RootPath, "system");
if (Directory.Exists(systemDir)) Directory.Delete(systemDir, true);
using (var fileStream = System.IO.File.OpenRead(archive)) using (var fileStream = System.IO.File.OpenRead(archive))
{ {
using (var zipFile = ZipFile.Read(fileStream)) using (var zipFile = ZipFile.Read(fileStream))