give a list of affected factions
This commit is contained in:
parent
df6b5bf10d
commit
2f07a8f2a9
@ -5,34 +5,56 @@ using Newtonsoft.Json.Linq;
|
|||||||
namespace EDJournal {
|
namespace EDJournal {
|
||||||
public class MissionCompletedEntry : Entry {
|
public class MissionCompletedEntry : Entry {
|
||||||
private Dictionary<string, string> influences = new Dictionary<string, string>();
|
private Dictionary<string, string> influences = new Dictionary<string, string>();
|
||||||
|
private List<string> affected = new List<string>();
|
||||||
private string readable_name = null;
|
private string readable_name = null;
|
||||||
private bool readable_name_generated = false;
|
private bool readable_name_generated = false;
|
||||||
private string name = null;
|
|
||||||
private string commodity = null;
|
|
||||||
private int count = 0;
|
|
||||||
private int donated = 0;
|
|
||||||
private int id = 0;
|
|
||||||
|
|
||||||
protected override void Initialise() {
|
protected override void Initialise() {
|
||||||
id = JSON.Value<int?>("MissionID") ?? 0;
|
MissionID = JSON.Value<int?>("MissionID") ?? 0;
|
||||||
name = JSON.Value<string>("Name");
|
Name = JSON.Value<string>("Name");
|
||||||
if (JSON.ContainsKey("Commodity_Localised")) {
|
if (JSON.ContainsKey("Commodity_Localised")) {
|
||||||
commodity = JSON.Value<string>("Commodity_Localised");
|
Commodity = JSON.Value<string>("Commodity_Localised");
|
||||||
}
|
}
|
||||||
if (JSON.ContainsKey("Count")) {
|
if (JSON.ContainsKey("Count")) {
|
||||||
count = JSON.Value<int>("Count");
|
Count = JSON.Value<int>("Count");
|
||||||
}
|
}
|
||||||
if (JSON.ContainsKey("Donated")) {
|
if (JSON.ContainsKey("Donated")) {
|
||||||
donated = JSON.Value<int>("Donated");
|
Donated = JSON.Value<int>("Donated");
|
||||||
}
|
}
|
||||||
|
|
||||||
MakeHumanReadableName();
|
MakeHumanReadableName();
|
||||||
|
BuildInfluenceList();
|
||||||
}
|
}
|
||||||
|
|
||||||
public string Name => name;
|
private void BuildInfluenceList() {
|
||||||
public string Commodity => commodity;
|
influences.Clear();
|
||||||
public int Count => count;
|
affected.Clear();
|
||||||
public int MissionID => id;
|
|
||||||
|
var effects = JSON.Value<JArray>("FactionEffects");
|
||||||
|
foreach (var effect in effects.Children<JObject>()) {
|
||||||
|
string faction = effect.Value<string>("Faction");
|
||||||
|
affected.Add(faction);
|
||||||
|
|
||||||
|
var influence = effect.Value<JArray>("Influence");
|
||||||
|
if (influence == null || influence.Count == 0) {
|
||||||
|
// No influence reward, happens sometimes, but we have to accept it
|
||||||
|
influences.Add(faction, "");
|
||||||
|
} else {
|
||||||
|
foreach (var infl in influence.Children<JObject>()) {
|
||||||
|
infl.TryGetValue("Influence", out JToken result);
|
||||||
|
if (result != null && result.Type == JTokenType.String) {
|
||||||
|
influences.Add(faction, result.ToString());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public string Name { get; set; }
|
||||||
|
public string Commodity { get; set; }
|
||||||
|
public int Count { get; set; }
|
||||||
|
public int Donated { get; set; }
|
||||||
|
public int MissionID { get; set; }
|
||||||
|
|
||||||
private void MakeHumanReadableName() {
|
private void MakeHumanReadableName() {
|
||||||
if (readable_name != null || Name == null) {
|
if (readable_name != null || Name == null) {
|
||||||
@ -60,12 +82,12 @@ namespace EDJournal {
|
|||||||
builder.Append(readable);
|
builder.Append(readable);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (count > 0 && commodity != null) {
|
if (Count > 0 && Commodity != null) {
|
||||||
builder.AppendFormat(" ({0} {1})", count, commodity);
|
builder.AppendFormat(" ({0} {1})", Count, Commodity);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (donated > 0) {
|
if (Donated > 0) {
|
||||||
builder.AppendFormat(" ({0})", Credits.FormatCredits(donated));
|
builder.AppendFormat(" ({0})", Credits.FormatCredits(Donated));
|
||||||
}
|
}
|
||||||
|
|
||||||
readable_name = builder.ToString().Trim();
|
readable_name = builder.ToString().Trim();
|
||||||
@ -85,33 +107,13 @@ namespace EDJournal {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public string[] AffectedFactions => affected.ToArray();
|
||||||
|
|
||||||
public string GetInfluenceForFaction(string faction) {
|
public string GetInfluenceForFaction(string faction) {
|
||||||
if (influences.ContainsKey(faction)) {
|
if (influences.ContainsKey(faction)) {
|
||||||
return influences[faction];
|
return influences[faction];
|
||||||
}
|
}
|
||||||
|
|
||||||
var effects = JSON.Value<JArray>("FactionEffects");
|
|
||||||
foreach (var effect in effects.Children<JObject>()) {
|
|
||||||
if (effect.GetValue("Faction").ToString() != faction) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
var influence = effect.Value<JArray>("Influence");
|
|
||||||
if (influence == null || influence.Count == 0) {
|
|
||||||
// No influence reward, happens on courier missions sometimes.
|
|
||||||
// There is always one point of rep, even if the mission won't state it
|
|
||||||
influences.Add(faction, "+");
|
|
||||||
}
|
|
||||||
|
|
||||||
foreach (var infl in influence.Children<JObject>()) {
|
|
||||||
infl.TryGetValue("Influence", out JToken result);
|
|
||||||
if (result != null && result.Type == JTokenType.String) {
|
|
||||||
influences.Add(faction, result.ToString());
|
|
||||||
return result.ToString();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return "";
|
return "";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user