197 lines
6.3 KiB
C#
197 lines
6.3 KiB
C#
using System;
|
|
using System.ComponentModel;
|
|
using System.Diagnostics;
|
|
using System.IO;
|
|
using System.Threading;
|
|
using System.Threading.Tasks;
|
|
using System.Timers;
|
|
using System.Windows;
|
|
using System.Windows.Controls;
|
|
using System.Windows.Data;
|
|
using System.Windows.Documents;
|
|
using System.Windows.Input;
|
|
using System.Windows.Media;
|
|
using System.Windows.Media.Imaging;
|
|
using System.Windows.Navigation;
|
|
using System.Windows.Shapes;
|
|
using NLog;
|
|
using NLog.Targets.Wrappers;
|
|
using Sandbox;
|
|
using Torch.API;
|
|
using Torch.API.Managers;
|
|
using Torch.Server.Managers;
|
|
using Torch.Server.Views;
|
|
using MessageBoxResult = System.Windows.MessageBoxResult;
|
|
|
|
namespace Torch.Server
|
|
{
|
|
/// <summary>
|
|
/// Interaction logic for TorchUI.xaml
|
|
/// </summary>
|
|
public partial class TorchUI : Window
|
|
{
|
|
private TorchServer _server;
|
|
private TorchConfig _config;
|
|
|
|
private bool _autoscrollLog = true;
|
|
|
|
public TorchUI(TorchServer server)
|
|
{
|
|
WindowStartupLocation = WindowStartupLocation.Manual;
|
|
_config = (TorchConfig)server.Config;
|
|
Width = _config.WindowWidth;
|
|
Height = _config.WindowHeight;
|
|
_server = server;
|
|
//TODO: data binding for whole server
|
|
DataContext = server;
|
|
InitializeComponent();
|
|
|
|
AttachConsole();
|
|
|
|
//Left = _config.WindowPosition.X;
|
|
//Top = _config.WindowPosition.Y;
|
|
//Width = _config.WindowSize.X;
|
|
//Height = _config.WindowSize.Y;
|
|
|
|
Chat.BindServer(server);
|
|
PlayerList.BindServer(server);
|
|
Plugins.BindServer(server);
|
|
LoadConfig((TorchConfig)server.Config);
|
|
|
|
Themes.uiSource = this;
|
|
Themes.SetConfig(_config);
|
|
Title = $"{_config.InstanceName} - Torch {server.TorchVersion}, SE {server.GameVersion}";
|
|
|
|
Loaded += TorchUI_Loaded;
|
|
}
|
|
|
|
private void TorchUI_Loaded(object sender, RoutedEventArgs e)
|
|
{
|
|
var scrollViewer = FindDescendant<ScrollViewer>(ConsoleText);
|
|
scrollViewer.ScrollChanged += ConsoleText_OnScrollChanged;
|
|
}
|
|
|
|
private void AttachConsole()
|
|
{
|
|
const string target = "wpf";
|
|
var doc = LogManager.Configuration.FindTargetByName<FlowDocumentTarget>(target)?.Document;
|
|
if (doc == null)
|
|
{
|
|
var wrapped = LogManager.Configuration.FindTargetByName<WrapperTargetBase>(target);
|
|
doc = (wrapped?.WrappedTarget as FlowDocumentTarget)?.Document;
|
|
}
|
|
ConsoleText.FontSize = _config.FontSize;
|
|
ConsoleText.Document = doc ?? new FlowDocument(new Paragraph(new Run("No target!")));
|
|
ConsoleText.TextChanged += ConsoleText_OnTextChanged;
|
|
}
|
|
|
|
public static T FindDescendant<T>(DependencyObject obj) where T : DependencyObject
|
|
{
|
|
if (obj == null) return default(T);
|
|
int numberChildren = VisualTreeHelper.GetChildrenCount(obj);
|
|
if (numberChildren == 0) return default(T);
|
|
|
|
for (int i = 0; i < numberChildren; i++)
|
|
{
|
|
DependencyObject child = VisualTreeHelper.GetChild(obj, i);
|
|
if (child is T)
|
|
{
|
|
return (T)child;
|
|
}
|
|
}
|
|
|
|
for (int i = 0; i < numberChildren; i++)
|
|
{
|
|
DependencyObject child = VisualTreeHelper.GetChild(obj, i);
|
|
var potentialMatch = FindDescendant<T>(child);
|
|
if (potentialMatch != default(T))
|
|
{
|
|
return potentialMatch;
|
|
}
|
|
}
|
|
|
|
return default(T);
|
|
}
|
|
|
|
private void ConsoleText_OnTextChanged(object sender, TextChangedEventArgs args)
|
|
{
|
|
var textBox = (RichTextBox) sender;
|
|
if (_autoscrollLog)
|
|
ConsoleText.ScrollToEnd();
|
|
}
|
|
|
|
private void ConsoleText_OnScrollChanged(object sender, ScrollChangedEventArgs e)
|
|
{
|
|
var scrollViewer = (ScrollViewer) sender;
|
|
if (e.ExtentHeightChange == 0)
|
|
{
|
|
// User change.
|
|
_autoscrollLog = scrollViewer.VerticalOffset == scrollViewer.ScrollableHeight;
|
|
}
|
|
}
|
|
|
|
public void LoadConfig(TorchConfig config)
|
|
{
|
|
if (!Directory.Exists(config.InstancePath))
|
|
return;
|
|
|
|
_config = config;
|
|
Dispatcher.Invoke(() =>
|
|
{
|
|
EntityManagerTab.IsEnabled = _config.EntityManagerEnabled;
|
|
if (_config.EntityManagerEnabled)
|
|
{
|
|
EntityManagerTab.Content = new EntitiesControl();
|
|
}
|
|
});
|
|
}
|
|
|
|
private void BtnStart_Click(object sender, RoutedEventArgs e)
|
|
{
|
|
_server.DedicatedInstance.SaveConfig();
|
|
Task.Run(() => _server.Start());
|
|
}
|
|
|
|
private void BtnStop_Click(object sender, RoutedEventArgs e)
|
|
{
|
|
var result = MessageBox.Show("Are you sure you want to stop the server?", "Stop Server", MessageBoxButton.YesNo);
|
|
|
|
if (result == MessageBoxResult.Yes)
|
|
_server.Invoke(() => _server.Stop());
|
|
}
|
|
|
|
protected override void OnClosing(CancelEventArgs e)
|
|
{
|
|
// Can't save here or you'll persist all the command line arguments
|
|
//
|
|
//var newSize = new Point((int)Width, (int)Height);
|
|
//_config.WindowSize = newSize;
|
|
//var newPos = new Point((int)Left, (int)Top);
|
|
//_config.WindowPosition = newPos;
|
|
|
|
//_config.Save(); //you idiot
|
|
|
|
if (_server?.State == ServerState.Running)
|
|
_server.Stop();
|
|
|
|
Process.GetCurrentProcess().Kill();
|
|
}
|
|
|
|
private void BtnRestart_Click(object sender, RoutedEventArgs e)
|
|
{
|
|
//MySandboxGame.Static.Invoke(MySandboxGame.ReloadDedicatedServerSession); use i
|
|
}
|
|
|
|
private void InstancePathBox_OnLostKeyboardFocus(object sender, KeyboardFocusChangedEventArgs e)
|
|
{
|
|
var name = ((TextBox)sender).Text;
|
|
|
|
if (!Directory.Exists(name))
|
|
return;
|
|
|
|
_config.InstancePath = name;
|
|
_server.Managers.GetManager<InstanceManager>().LoadInstance(_config.InstancePath);
|
|
}
|
|
}
|
|
}
|