* Work on Research so far More work on UI... Fix ResearchClient and Protolathe UI stuff. Fix infinite select -> request state -> select -> ... loop Add UI to ResearchClient, etc. Technology Database states, and a bit of work on the research console ui A bit of work on Research Console UI Protolathe sync Stuff that actually does things Protolathe databases yay Alright got my motivation back Yeah, no. It's almost 3 AM already Fix serialization bug again More work on stuff Stuff Adds files for most new components/systems. * Protolathes actually work now * Research. Just Research. * Adds icons from Eris. * Address reviews * Change LatheMenu resize behaviour * Update Content.Client/GameObjects/Components/Research/ResearchConsoleBoundUserInterface.cs Co-Authored-By: Pieter-Jan Briers <pieterjan.briers@gmail.com> * Update Content.Client/Research/ResearchConsoleMenu.cs Co-Authored-By: Pieter-Jan Briers <pieterjan.briers@gmail.com> * Move IoC Resolve out of for loop * Address review * Localize stuff
163 lines
5.9 KiB
C#
163 lines
5.9 KiB
C#
using System.Collections.Generic;
|
|
using Content.Server.GameObjects.Components.Stack;
|
|
using Content.Server.GameObjects.EntitySystems;
|
|
using Content.Shared.GameObjects.Components.Materials;
|
|
using Content.Shared.GameObjects.Components.Research;
|
|
using Content.Shared.Research;
|
|
using Robust.Server.GameObjects.Components.UserInterface;
|
|
using Robust.Server.Interfaces.GameObjects;
|
|
using Robust.Server.Interfaces.Player;
|
|
using Robust.Shared.GameObjects;
|
|
using Robust.Shared.GameObjects.Components.UserInterface;
|
|
using Robust.Shared.Timers;
|
|
using Robust.Shared.Utility;
|
|
using Robust.Shared.ViewVariables;
|
|
|
|
namespace Content.Server.GameObjects.Components.Research
|
|
{
|
|
[RegisterComponent]
|
|
[ComponentReference(typeof(IActivate))]
|
|
public class LatheComponent : SharedLatheComponent, IAttackBy, IActivate
|
|
{
|
|
public const int VolumePerSheet = 3750;
|
|
|
|
private BoundUserInterface _userInterface;
|
|
|
|
[ViewVariables]
|
|
public Queue<LatheRecipePrototype> Queue { get; } = new Queue<LatheRecipePrototype>();
|
|
|
|
[ViewVariables]
|
|
public bool Producing { get; private set; } = false;
|
|
|
|
private LatheRecipePrototype _producingRecipe = null;
|
|
|
|
public override void Initialize()
|
|
{
|
|
base.Initialize();
|
|
_userInterface = Owner.GetComponent<ServerUserInterfaceComponent>().GetBoundUserInterface(LatheUiKey.Key);
|
|
_userInterface.OnReceiveMessage += UserInterfaceOnOnReceiveMessage;
|
|
}
|
|
|
|
private void UserInterfaceOnOnReceiveMessage(ServerBoundUserInterfaceMessage message)
|
|
{
|
|
switch (message.Message)
|
|
{
|
|
case LatheQueueRecipeMessage msg:
|
|
_prototypeManager.TryIndex(msg.ID, out LatheRecipePrototype recipe);
|
|
if (recipe != null)
|
|
for (var i = 0; i < msg.Quantity; i++)
|
|
{
|
|
Queue.Enqueue(recipe);
|
|
_userInterface.SendMessage(new LatheFullQueueMessage(GetIDQueue()));
|
|
}
|
|
break;
|
|
case LatheSyncRequestMessage msg:
|
|
if (!Owner.TryGetComponent(out MaterialStorageComponent storage)) return;
|
|
_userInterface.SendMessage(new LatheFullQueueMessage(GetIDQueue()));
|
|
if (_producingRecipe != null)
|
|
_userInterface.SendMessage(new LatheProducingRecipeMessage(_producingRecipe.ID));
|
|
break;
|
|
|
|
case LatheServerSelectionMessage msg:
|
|
if (!Owner.TryGetComponent(out ResearchClientComponent researchClient)) return;
|
|
researchClient.OpenUserInterface(message.Session);
|
|
break;
|
|
|
|
case LatheServerSyncMessage msg:
|
|
if (!Owner.TryGetComponent(out TechnologyDatabaseComponent database)
|
|
|| !Owner.TryGetComponent(out ProtolatheDatabaseComponent protoDatabase)) return;
|
|
|
|
if(database.SyncWithServer())
|
|
protoDatabase.Sync();
|
|
|
|
break;
|
|
}
|
|
}
|
|
|
|
internal bool Produce(LatheRecipePrototype recipe)
|
|
{
|
|
if (Producing || !CanProduce(recipe) || !Owner.TryGetComponent(out MaterialStorageComponent storage)) return false;
|
|
|
|
_userInterface.SendMessage(new LatheFullQueueMessage(GetIDQueue()));
|
|
|
|
Producing = true;
|
|
_producingRecipe = recipe;
|
|
|
|
foreach (var (material, amount) in recipe.RequiredMaterials)
|
|
{
|
|
// This should always return true, otherwise CanProduce fucked up.
|
|
storage.RemoveMaterial(material, amount);
|
|
}
|
|
|
|
_userInterface.SendMessage(new LatheProducingRecipeMessage(recipe.ID));
|
|
|
|
Timer.Spawn(recipe.CompleteTime, () =>
|
|
{
|
|
Producing = false;
|
|
_producingRecipe = null;
|
|
Owner.EntityManager.SpawnEntityAt(recipe.Result, Owner.Transform.GridPosition);
|
|
_userInterface.SendMessage(new LatheStoppedProducingRecipeMessage());
|
|
});
|
|
|
|
return true;
|
|
}
|
|
|
|
public void OpenUserInterface(IPlayerSession session)
|
|
{
|
|
_userInterface.Open(session);
|
|
}
|
|
|
|
void IActivate.Activate(ActivateEventArgs eventArgs)
|
|
{
|
|
if (!eventArgs.User.TryGetComponent(out IActorComponent actor))
|
|
return;
|
|
|
|
OpenUserInterface(actor.playerSession);
|
|
return;
|
|
}
|
|
bool IAttackBy.AttackBy(AttackByEventArgs eventArgs)
|
|
{
|
|
if (!Owner.TryGetComponent(out MaterialStorageComponent storage)
|
|
|| !eventArgs.AttackWith.TryGetComponent(out MaterialComponent material)) return false;
|
|
|
|
var multiplier = 1;
|
|
|
|
if (eventArgs.AttackWith.TryGetComponent(out StackComponent stack)) multiplier = stack.Count;
|
|
|
|
var totalAmount = 0;
|
|
|
|
// Check if it can insert all materials.
|
|
foreach (var mat in material.MaterialTypes.Values)
|
|
{
|
|
// TODO: Change how MaterialComponent works so this is not hard-coded.
|
|
if (!storage.CanInsertMaterial(mat.ID, VolumePerSheet * multiplier)) return false;
|
|
totalAmount += VolumePerSheet * multiplier;
|
|
}
|
|
|
|
// Check if it can take ALL of the material's volume.
|
|
if (storage.CanTakeAmount(totalAmount)) return false;
|
|
|
|
foreach (var mat in material.MaterialTypes.Values)
|
|
{
|
|
|
|
storage.InsertMaterial(mat.ID, VolumePerSheet * multiplier);
|
|
}
|
|
|
|
eventArgs.AttackWith.Delete();
|
|
|
|
return false;
|
|
}
|
|
|
|
private Queue<string> GetIDQueue()
|
|
{
|
|
var queue = new Queue<string>();
|
|
foreach (var recipePrototype in Queue)
|
|
{
|
|
queue.Enqueue(recipePrototype.ID);
|
|
}
|
|
|
|
return queue;
|
|
}
|
|
}
|
|
}
|