2021-07-09 11:03:30 +02:00
|
|
|
|
using System;
|
|
|
|
|
using System.Text;
|
|
|
|
|
using System.Windows;
|
|
|
|
|
using System.Windows.Controls;
|
|
|
|
|
using System.Windows.Input;
|
|
|
|
|
using Ookii.Dialogs.Wpf;
|
2021-08-25 16:36:57 +02:00
|
|
|
|
using EDJournal;
|
2021-11-10 21:24:39 +01:00
|
|
|
|
using EliteBGS.BGS;
|
|
|
|
|
using EliteBGS.Util;
|
|
|
|
|
using EliteBGS.UI;
|
|
|
|
|
using EliteBGS.EDDB;
|
2021-08-25 16:36:57 +02:00
|
|
|
|
|
2021-11-10 21:24:39 +01:00
|
|
|
|
namespace EliteBGS {
|
2021-07-09 11:03:30 +02:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Interaction logic for MainWindow.xaml
|
|
|
|
|
/// </summary>
|
|
|
|
|
public partial class MainWindow : Window {
|
|
|
|
|
private PlayerJournal journal = null;
|
|
|
|
|
private Report report = new Report();
|
|
|
|
|
private Config config = new Config();
|
2021-07-09 14:40:27 +02:00
|
|
|
|
private API api = null;
|
2021-07-09 11:03:30 +02:00
|
|
|
|
|
2021-07-29 21:07:53 +02:00
|
|
|
|
private PopulatedSystems systems_db = null;
|
|
|
|
|
private Stations stations_db = null;
|
|
|
|
|
|
2021-07-09 11:03:30 +02:00
|
|
|
|
public Config Config => config;
|
|
|
|
|
|
|
|
|
|
public Report Report => report;
|
|
|
|
|
|
|
|
|
|
public MainWindow() {
|
|
|
|
|
InitializeComponent();
|
|
|
|
|
|
|
|
|
|
try {
|
|
|
|
|
config.LoadGlobal();
|
|
|
|
|
} catch (Exception) {
|
|
|
|
|
/* ignored */
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
report.OnLog += Report_OnLog;
|
|
|
|
|
|
2022-01-06 16:24:20 +01:00
|
|
|
|
LogType.Items.Add(new NonaDiscordLog());
|
|
|
|
|
LogType.Items.Add(new GenericDiscordLog());
|
|
|
|
|
LogType.SelectedIndex = 0;
|
|
|
|
|
|
2021-07-09 14:40:27 +02:00
|
|
|
|
api = new API(config.ConfigPath);
|
2021-07-09 11:03:30 +02:00
|
|
|
|
journal = new PlayerJournal(config.Global.JournalLocation);
|
|
|
|
|
|
|
|
|
|
// Set both to now
|
|
|
|
|
startdate.SelectedDate = DateTime.Now;
|
|
|
|
|
enddate.SelectedDate = DateTime.Now;
|
|
|
|
|
journallocation.Text = Config.Global.JournalLocation;
|
|
|
|
|
useeddb.IsChecked = Config.Global.UseEDDB;
|
|
|
|
|
|
|
|
|
|
try {
|
|
|
|
|
config.LoadObjectives(Report);
|
|
|
|
|
RefreshObjectives();
|
2021-07-09 14:40:27 +02:00
|
|
|
|
} catch (Exception e) {
|
|
|
|
|
Log(e.Message);
|
|
|
|
|
}
|
2021-07-09 11:03:30 +02:00
|
|
|
|
|
2021-07-13 17:46:06 +02:00
|
|
|
|
api.SystemsAvailable += Api_SystemsAvailable;
|
2021-07-29 21:07:53 +02:00
|
|
|
|
api.StationsAvailable += Api_StationsAvailable;
|
2021-07-13 17:46:06 +02:00
|
|
|
|
|
2021-07-09 14:40:27 +02:00
|
|
|
|
try {
|
2021-08-01 15:26:33 +02:00
|
|
|
|
api.CheckDatabases();
|
2021-07-13 17:46:06 +02:00
|
|
|
|
} catch (Exception e) {
|
|
|
|
|
Log(e.Message);
|
|
|
|
|
}
|
|
|
|
|
}
|
2021-07-09 14:40:27 +02:00
|
|
|
|
|
2021-07-29 21:07:53 +02:00
|
|
|
|
private void Api_StationsAvailable() {
|
|
|
|
|
try {
|
|
|
|
|
stations_db = api.MakeStations();
|
|
|
|
|
} catch (Exception e) {
|
|
|
|
|
Log(e.Message);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2021-07-13 17:46:06 +02:00
|
|
|
|
private void Api_SystemsAvailable() {
|
|
|
|
|
try {
|
2021-07-29 21:07:53 +02:00
|
|
|
|
systems_db = api.MakePopulatedSystems();
|
2021-07-13 17:46:06 +02:00
|
|
|
|
system.Provider = new SystemSuggestionProvider(systems_db);
|
2021-07-09 14:40:27 +02:00
|
|
|
|
} catch (Exception e) {
|
|
|
|
|
Log(e.Message);
|
2021-07-09 11:03:30 +02:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void Report_OnLog(string message) {
|
|
|
|
|
StringBuilder builder = new StringBuilder();
|
|
|
|
|
|
|
|
|
|
builder.Append(DateTime.Now.ToString());
|
|
|
|
|
builder.Append(": ");
|
|
|
|
|
builder.Append(message);
|
|
|
|
|
builder.Append("\n");
|
|
|
|
|
|
|
|
|
|
log.AppendText(builder.ToString());
|
|
|
|
|
}
|
|
|
|
|
|
2021-07-09 14:40:27 +02:00
|
|
|
|
private void Log(string message) {
|
|
|
|
|
Report_OnLog(message);
|
|
|
|
|
}
|
|
|
|
|
|
2021-07-09 11:03:30 +02:00
|
|
|
|
private void RefreshObjectives() {
|
|
|
|
|
entries.Items.Clear();
|
|
|
|
|
|
|
|
|
|
if (report.Objectives == null) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
2022-01-09 11:13:01 +01:00
|
|
|
|
foreach (Objective obj in report.Objectives) {
|
|
|
|
|
entries.Items.Add(obj);
|
|
|
|
|
obj.IsExpanded = obj.ManuallyAdded;
|
|
|
|
|
obj.IsEnabled = obj.ManuallyAdded;
|
2021-07-09 11:03:30 +02:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void ParseJournal_Click(object sender, RoutedEventArgs e) {
|
2022-01-06 16:40:55 +01:00
|
|
|
|
try {
|
|
|
|
|
journal.Open(); // Load all files
|
|
|
|
|
var start = startdate.SelectedDate ?? DateTime.Now;
|
|
|
|
|
var end = startdate.SelectedDate ?? DateTime.Now;
|
|
|
|
|
report.Scan(journal, start, end);
|
|
|
|
|
RefreshObjectives();
|
|
|
|
|
} catch (Exception exception) {
|
|
|
|
|
Log("Something went terribly wrong while parsing the E:D player journal.");
|
|
|
|
|
Log("Please send this to CMDR Hekateh:");
|
|
|
|
|
Log(exception.ToString());
|
|
|
|
|
}
|
2021-07-09 11:03:30 +02:00
|
|
|
|
}
|
|
|
|
|
|
2021-07-09 11:24:46 +02:00
|
|
|
|
private void AddObjective() {
|
2021-07-09 11:03:30 +02:00
|
|
|
|
Objective objective = new Objective {
|
|
|
|
|
System = system.Text,
|
|
|
|
|
Faction = faction.Text,
|
2022-01-09 11:13:01 +01:00
|
|
|
|
Station = station.Text,
|
|
|
|
|
ManuallyAdded = true,
|
2021-07-09 11:03:30 +02:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
if (!objective.IsValid) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (report.AddObjective(objective)) {
|
|
|
|
|
RefreshObjectives();
|
|
|
|
|
config.SaveObjectives(Report);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2021-07-09 11:24:46 +02:00
|
|
|
|
private void AddFilter_Click(object sender, RoutedEventArgs e) {
|
|
|
|
|
AddObjective();
|
|
|
|
|
}
|
|
|
|
|
|
2021-07-09 11:03:30 +02:00
|
|
|
|
private void GenerateDiscord_Click(object sender, RoutedEventArgs e) {
|
2022-01-06 16:40:55 +01:00
|
|
|
|
try {
|
|
|
|
|
IDiscordLogGenerator discord = LogType.SelectedItem as IDiscordLogGenerator;
|
|
|
|
|
string report = discord.GenerateDiscordLog(Report);
|
2021-07-09 11:03:30 +02:00
|
|
|
|
|
2022-01-06 16:40:55 +01:00
|
|
|
|
DiscordLog.Text = report;
|
2022-01-06 16:42:39 +01:00
|
|
|
|
} catch (Exception exception) {
|
2022-01-06 16:40:55 +01:00
|
|
|
|
Log("Something went terribly wrong while generating the Discord log.");
|
|
|
|
|
Log("Please send this to CMDR Hekateh:");
|
2022-01-06 16:42:39 +01:00
|
|
|
|
Log(exception.ToString());
|
2022-01-06 16:40:55 +01:00
|
|
|
|
}
|
2021-07-09 11:03:30 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void RemoveCurrentObjective() {
|
|
|
|
|
if (entries.SelectedItem == null) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
2022-01-09 11:13:01 +01:00
|
|
|
|
object obj = entries.SelectedItem;
|
2021-07-09 11:03:30 +02:00
|
|
|
|
bool removed = false;
|
|
|
|
|
|
|
|
|
|
if (obj.GetType() == typeof(Objective)) {
|
|
|
|
|
removed = report.Objectives.Remove(obj as Objective);
|
|
|
|
|
} else if (obj.GetType() == typeof(LogEntry) ||
|
|
|
|
|
obj.GetType().IsSubclassOf(typeof(LogEntry))) {
|
2022-01-09 11:13:01 +01:00
|
|
|
|
foreach (Objective parent in report.Objectives) {
|
|
|
|
|
if (parent.LogEntries.Remove(obj as LogEntry)) {
|
|
|
|
|
removed = true;
|
|
|
|
|
}
|
|
|
|
|
}
|
2021-07-09 11:03:30 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (removed) {
|
|
|
|
|
RefreshObjectives();
|
|
|
|
|
config.SaveObjectives(Report);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void entries_KeyUp(object sender, KeyEventArgs e) {
|
|
|
|
|
if (e.Key == Key.Delete) {
|
|
|
|
|
RemoveCurrentObjective();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void browsejournallocation_Click(object sender, RoutedEventArgs e) {
|
|
|
|
|
var dialog = new VistaFolderBrowserDialog();
|
|
|
|
|
|
|
|
|
|
if ((bool)!dialog.ShowDialog()) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Config.Global.JournalLocation = dialog.SelectedPath;
|
|
|
|
|
journallocation.Text = Config.Global.JournalLocation;
|
|
|
|
|
journal = new PlayerJournal(config.Global.JournalLocation);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void useeddb_Click(object sender, RoutedEventArgs e) {
|
|
|
|
|
Config.Global.UseEDDB = (bool)useeddb.IsChecked;
|
|
|
|
|
}
|
2021-07-09 11:24:46 +02:00
|
|
|
|
|
|
|
|
|
private void Filter_KeyDown(object sender, KeyEventArgs e) {
|
|
|
|
|
if (e.Key == Key.Enter) {
|
|
|
|
|
AddObjective();
|
|
|
|
|
}
|
|
|
|
|
}
|
2021-07-29 21:07:53 +02:00
|
|
|
|
|
|
|
|
|
private void station_GotFocus(object sender, RoutedEventArgs e) {
|
|
|
|
|
try {
|
|
|
|
|
if (stations_db == null || systems_db == null) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var sys = system.Text;
|
|
|
|
|
if (sys == null || sys.Length <= 0) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
int system_id = systems_db.ToId(sys);
|
|
|
|
|
station.Provider = new StationSuggestionProvider(stations_db, system_id);
|
|
|
|
|
} catch (Exception exc) {
|
2022-01-06 16:40:55 +01:00
|
|
|
|
Log(exc.ToString());
|
2021-07-29 21:07:53 +02:00
|
|
|
|
}
|
|
|
|
|
}
|
2021-08-01 15:26:33 +02:00
|
|
|
|
|
|
|
|
|
private void DownloadData_Click(object sender, RoutedEventArgs e) {
|
|
|
|
|
if (!Config.Global.UseEDDB) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
2021-08-13 09:30:06 +02:00
|
|
|
|
ProgressDialog dialog = new ProgressDialog(api);
|
|
|
|
|
dialog.StartDownload();
|
|
|
|
|
dialog.ShowDialog();
|
2021-08-01 15:26:33 +02:00
|
|
|
|
}
|
2021-09-28 14:14:16 +02:00
|
|
|
|
|
|
|
|
|
private void AddCombatZone_Click(object sender, RoutedEventArgs e) {
|
|
|
|
|
if (entries.SelectedItem == null) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
2022-01-10 08:03:51 +01:00
|
|
|
|
var obj = entries.SelectedItem;
|
2021-09-28 14:14:16 +02:00
|
|
|
|
|
|
|
|
|
if (obj.GetType() != typeof(Objective)) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Objective objective = obj as Objective;
|
|
|
|
|
|
|
|
|
|
CombatZoneDialog dialog = new CombatZoneDialog() { Owner = this };
|
|
|
|
|
|
|
|
|
|
if (!(dialog.ShowDialog() ?? false)) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
2022-01-10 08:03:51 +01:00
|
|
|
|
CombatZone zone = new CombatZone {
|
|
|
|
|
ManuallyAdded = true,
|
|
|
|
|
Faction = objective.Faction,
|
|
|
|
|
System = objective.System,
|
|
|
|
|
Station = objective.Station,
|
2021-09-28 14:14:16 +02:00
|
|
|
|
|
2022-01-10 08:03:51 +01:00
|
|
|
|
Grade = dialog.Grade,
|
|
|
|
|
Type = dialog.Type,
|
|
|
|
|
Amount = dialog.Amount
|
|
|
|
|
};
|
2021-09-28 14:14:16 +02:00
|
|
|
|
|
|
|
|
|
objective.LogEntries.Add(zone);
|
|
|
|
|
RefreshObjectives();
|
|
|
|
|
}
|
2022-01-12 17:29:58 +01:00
|
|
|
|
|
|
|
|
|
private void AdjustProfit_Click(object sender, RoutedEventArgs e) {
|
|
|
|
|
if (entries.SelectedItem == null || entries.SelectedItem.GetType() != typeof(SellCargo)) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
SellCargo sell = entries.SelectedItem as SellCargo;
|
|
|
|
|
AdjustProfitWindow adjust = new AdjustProfitWindow() { Owner = this };
|
|
|
|
|
|
|
|
|
|
adjust.Profit.Text = sell.Profit.ToString();
|
|
|
|
|
|
|
|
|
|
if (!(adjust.ShowDialog() ?? false)) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (int.TryParse(adjust.Profit.Text, out int newprofit)) {
|
|
|
|
|
sell.Profit = newprofit;
|
|
|
|
|
RefreshObjectives();
|
|
|
|
|
}
|
|
|
|
|
}
|
2021-07-09 11:03:30 +02:00
|
|
|
|
}
|
|
|
|
|
}
|