// --------------------------------------------------------------------------------------------------------------------
//
// This file is part of the HandBrake source code - It may be used under the terms of the GNU General Public License.
//
//
// Interaction logic for LogView.xaml
//
// --------------------------------------------------------------------------------------------------------------------
namespace HandBrakeWPF.Views
{
using System;
using System.Diagnostics;
using System.Windows;
using System.Windows.Controls;
using Caliburn.Micro;
using HandBrakeWPF.Services.Logging.EventArgs;
using HandBrakeWPF.Utilities;
using HandBrakeWPF.ViewModels;
///
/// Interaction logic for LogView.xaml
///
public partial class LogView : Window
{
private DelayedActionProcessor delayProcessor = new DelayedActionProcessor();
///
/// Initializes a new instance of the class.
///
public LogView()
{
this.InitializeComponent();
this.DataContextChanged += this.LogView_DataContextChanged;
}
///
/// The log view_ data context changed.
///
///
/// The sender.
///
///
/// The e.
///
private void LogView_DataContextChanged(object sender, DependencyPropertyChangedEventArgs e)
{
LogViewModel vm = e.NewValue as LogViewModel;
if (vm != null)
{
this.logText.AppendText(vm.ActivityLog);
vm.LogMessageReceived += this.Vm_LogMessageReceived;
}
}
///
/// The vm_ log message received.
///
///
/// The sender.
///
///
/// The e.
///
private void Vm_LogMessageReceived(object sender, LogEventArgs e)
{
try
{
if (e == null)
{
Caliburn.Micro.Execute.OnUIThread(
() =>
{
LogViewModel vm = this.DataContext as LogViewModel;
if (vm != null)
{
this.logText.Clear();
this.logText.AppendText(vm.ActivityLog);
}
else
{
Debug.WriteLine("Failed to Reset Log correctly.");
}
});
}
else
{
// This works better than Data Binding because of the scroll.
this.logText.AppendText(Environment.NewLine + e.Log.Content);
if (this.AutoScroll.IsChecked)
{
delayProcessor.PerformTask(() => Execute.OnUIThreadAsync(() => this.logText.ScrollToEnd()), 100);
}
}
}
catch (Exception exc)
{
Debug.WriteLine(exc);
}
}
///
/// Hide the Toolbar Endplate.
///
///
/// The sender.
///
///
/// The e.
///
private void ToolBarLoaded(object sender, RoutedEventArgs e)
{
ToolBar toolBar = sender as ToolBar;
if (toolBar != null)
{
var overflowGrid = toolBar.Template.FindName("OverflowGrid", toolBar) as FrameworkElement;
if (overflowGrid != null)
{
overflowGrid.Visibility = Visibility.Collapsed;
}
}
}
}
}