195 lines
7.5 KiB
C#
195 lines
7.5 KiB
C#
using System.Linq;
|
|
using Content.Client._NF.Salvage.UI; // Frontier
|
|
using Content.Client.Stylesheets;
|
|
using Content.Shared.CCVar;
|
|
using Content.Shared.Procedural;
|
|
using Content.Shared.Salvage.Expeditions;
|
|
using Content.Shared.Salvage.Expeditions.Modifiers;
|
|
using JetBrains.Annotations;
|
|
using Robust.Client.UserInterface;
|
|
using Robust.Client.UserInterface.Controls;
|
|
using Robust.Shared.Configuration;
|
|
using Robust.Shared.Prototypes;
|
|
|
|
namespace Content.Client.Salvage.UI;
|
|
|
|
[UsedImplicitly]
|
|
public sealed class SalvageExpeditionConsoleBoundUserInterface : BoundUserInterface
|
|
{
|
|
[ViewVariables]
|
|
private SalvageExpeditionWindow? _window; // Frontier: OfferingWindow<SalvageExpeditionWindow
|
|
|
|
// [Dependency] private readonly IConfigurationManager _cfgManager = default!; // Frontier: warning suppression
|
|
[Dependency] private readonly IEntityManager _entManager = default!;
|
|
[Dependency] private readonly ILogManager _logManager = default!;
|
|
[Dependency] private readonly IPrototypeManager _protoManager = default!;
|
|
|
|
private readonly ISawmill _sawmill;
|
|
|
|
public SalvageExpeditionConsoleBoundUserInterface(EntityUid owner, Enum uiKey) : base(owner, uiKey)
|
|
{
|
|
IoCManager.InjectDependencies(this);
|
|
_sawmill = _logManager.GetSawmill("salvage.expedition.console");
|
|
}
|
|
|
|
protected override void Open()
|
|
{
|
|
base.Open();
|
|
_window = this.CreateWindowCenteredLeft<SalvageExpeditionWindow>(); // Frontier: OfferingWindow<SalvageExpeditionWindow
|
|
_window.Title = Loc.GetString("salvage-expedition-window-title");
|
|
_window.OnFinishPressed += () => SendMessage(new FinishSalvageMessage()); // Frontier
|
|
}
|
|
|
|
protected override void UpdateState(BoundUserInterfaceState state)
|
|
{
|
|
base.UpdateState(state);
|
|
|
|
if (state is not SalvageExpeditionConsoleState current || _window == null)
|
|
return;
|
|
|
|
_window.Progression = null;
|
|
_window.Cooldown = current.CooldownTime;
|
|
_window.NextOffer = current.NextOffer;
|
|
_window.Claimed = current.Claimed;
|
|
_window.SetFinishDisabled(!current.CanFinish); // Frontier
|
|
_window.ClearOptions();
|
|
var salvage = _entManager.System<SalvageSystem>();
|
|
|
|
for (var i = 0; i < current.Missions.Count; i++)
|
|
{
|
|
var missionParams = current.Missions[i];
|
|
|
|
var offering = new OfferingWindowOption();
|
|
offering.Title = Loc.GetString($"salvage-expedition-type-{missionParams.MissionType}");
|
|
|
|
var difficultyId = missionParams.Difficulty; // Frontier: Moderate<missionParams.Difficulty
|
|
var difficultyProto = _protoManager.Index<SalvageDifficultyPrototype>(difficultyId);
|
|
// TODO: Selectable difficulty soon.
|
|
var mission = salvage.GetMission(missionParams.MissionType, difficultyProto, missionParams.Seed); // Frontier: add missionParams.MissionType
|
|
|
|
// Difficulty
|
|
// Details
|
|
offering.AddContent(new Label()
|
|
{
|
|
Text = Loc.GetString("salvage-expedition-window-difficulty")
|
|
});
|
|
|
|
var difficultyColor = difficultyProto.Color;
|
|
|
|
offering.AddContent(new Label
|
|
{
|
|
Text = Loc.GetString($"salvage-expedition-difficulty-{missionParams.Difficulty}"), // Frontier: parameterize loc string
|
|
FontColorOverride = difficultyColor,
|
|
HorizontalAlignment = Control.HAlignment.Left,
|
|
Margin = new Thickness(0f, 0f, 0f, 5f),
|
|
});
|
|
|
|
offering.AddContent(new Label
|
|
{
|
|
Text = Loc.GetString("salvage-expedition-difficulty-players"),
|
|
HorizontalAlignment = Control.HAlignment.Left,
|
|
});
|
|
|
|
offering.AddContent(new Label
|
|
{
|
|
Text = difficultyProto.RecommendedPlayers.ToString(),
|
|
FontColorOverride = StyleNano.NanoGold,
|
|
HorizontalAlignment = Control.HAlignment.Left,
|
|
Margin = new Thickness(0f, 0f, 0f, 5f),
|
|
});
|
|
|
|
// Details
|
|
offering.AddContent(new Label
|
|
{
|
|
Text = Loc.GetString("salvage-expedition-window-hostiles")
|
|
});
|
|
|
|
var faction = mission.Faction;
|
|
|
|
offering.AddContent(new Label
|
|
{
|
|
Text = string.IsNullOrWhiteSpace(Loc.GetString(_protoManager.Index<SalvageFactionPrototype>(faction).Description))
|
|
? LogAndReturnDefaultFactionDescription(faction)
|
|
: Loc.GetString(_protoManager.Index<SalvageFactionPrototype>(faction).Description),
|
|
FontColorOverride = StyleNano.NanoGold,
|
|
HorizontalAlignment = Control.HAlignment.Left,
|
|
Margin = new Thickness(0f, 0f, 0f, 5f),
|
|
});
|
|
|
|
string LogAndReturnDefaultFactionDescription(string faction)
|
|
{
|
|
_sawmill.Error($"Description is null or white space for SalvageFactionPrototype: {faction}");
|
|
return Loc.GetString(_protoManager.Index<SalvageFactionPrototype>(faction).ID);
|
|
}
|
|
|
|
|
|
// Duration
|
|
offering.AddContent(new Label
|
|
{
|
|
Text = Loc.GetString("salvage-expedition-window-duration")
|
|
});
|
|
|
|
offering.AddContent(new Label
|
|
{
|
|
Text = mission.Duration.ToString(),
|
|
FontColorOverride = StyleNano.NanoGold,
|
|
HorizontalAlignment = Control.HAlignment.Left,
|
|
Margin = new Thickness(0f, 0f, 0f, 5f),
|
|
});
|
|
|
|
// Biome
|
|
offering.AddContent(new Label
|
|
{
|
|
Text = Loc.GetString("salvage-expedition-window-biome")
|
|
});
|
|
|
|
var biome = mission.Biome;
|
|
|
|
offering.AddContent(new Label
|
|
{
|
|
Text = string.IsNullOrWhiteSpace(Loc.GetString(_protoManager.Index<SalvageBiomeModPrototype>(biome).Description))
|
|
? LogAndReturnDefaultBiomDescription(biome)
|
|
: Loc.GetString(_protoManager.Index<SalvageBiomeModPrototype>(biome).Description),
|
|
FontColorOverride = StyleNano.NanoGold,
|
|
HorizontalAlignment = Control.HAlignment.Left,
|
|
Margin = new Thickness(0f, 0f, 0f, 5f),
|
|
});
|
|
|
|
string LogAndReturnDefaultBiomDescription(string biome)
|
|
{
|
|
_sawmill.Error($"Description is null or white space for SalvageBiomeModPrototype: {biome}");
|
|
return Loc.GetString(_protoManager.Index<SalvageBiomeModPrototype>(biome).ID);
|
|
}
|
|
|
|
// Modifiers
|
|
offering.AddContent(new Label
|
|
{
|
|
Text = Loc.GetString("salvage-expedition-window-modifiers")
|
|
});
|
|
|
|
var mods = mission.Modifiers;
|
|
|
|
offering.AddContent(new Label
|
|
{
|
|
Text = string.Join("\n", mods.Select(o => "- " + o)).TrimEnd(),
|
|
FontColorOverride = StyleNano.NanoGold,
|
|
HorizontalAlignment = Control.HAlignment.Left,
|
|
Margin = new Thickness(0f, 0f, 0f, 5f),
|
|
});
|
|
|
|
offering.ClaimPressed += args =>
|
|
{
|
|
SendMessage(new ClaimSalvageMessage()
|
|
{
|
|
Index = missionParams.Index,
|
|
});
|
|
};
|
|
|
|
offering.Claimed = current.ActiveMission == missionParams.Index;
|
|
offering.Disabled = current.Claimed || current.Cooldown;
|
|
|
|
_window.AddOption(offering);
|
|
}
|
|
}
|
|
}
|