package gtPlusPlus.xmod.gregtech.api.gui;

import java.util.Iterator;

import cpw.mods.fml.relauncher.Side;
import cpw.mods.fml.relauncher.SideOnly;

import net.minecraft.entity.player.InventoryPlayer;
import net.minecraft.inventory.ICrafting;
import net.minecraft.inventory.Slot;

import gregtech.api.gui.GT_ContainerMetaTile_Machine;
import gregtech.api.interfaces.tileentity.IGregTechTileEntity;

import gtPlusPlus.xmod.gregtech.api.metatileentity.implementations.base.generators.GregtechMetaBoilerBase;

public class CONTAINER_SteamCondenser extends GT_ContainerMetaTile_Machine
{
	public CONTAINER_SteamCondenser(final InventoryPlayer aInventoryPlayer, final IGregTechTileEntity aTileEntity)
	{
		super(aInventoryPlayer, aTileEntity);
	}

	@Override
	public void addSlots(final InventoryPlayer aInventoryPlayer)
	{
		this.addSlotToContainer(new Slot(this.mTileEntity, 2, 116, 62));
		this.addSlotToContainer(new Slot(this.mTileEntity, 0, 44, 26));
		this.addSlotToContainer(new Slot(this.mTileEntity, 1, 44, 62));
		this.addSlotToContainer(new Slot(this.mTileEntity, 3, 116, 26));
	}

	@Override
	public int getSlotCount()
	{
		return 4;
	}

	@Override
	public int getShiftClickSlotCount()
	{
		return 1;
	}

	public int mWaterAmount = 0;
	public int mSteamAmount = 0;
	public int mProcessingEnergy = 0;
	public int mTemperature = 2;
	public long mTickingTime = ((GregtechMetaBoilerBase)this.mTileEntity.getMetaTileEntity()).RI;

	@Override
	public void detectAndSendChanges()
	{
		super.detectAndSendChanges();
		if ((this.mTileEntity.isClientSide()) || (this.mTileEntity.getMetaTileEntity() == null)) {
			return;
		}
		int steamCapacity = ((GregtechMetaBoilerBase)this.mTileEntity.getMetaTileEntity()).getSteamCapacity();
		int waterCapacity = ((GregtechMetaBoilerBase)this.mTileEntity.getMetaTileEntity()).getCapacity();
		this.mTemperature = ((GregtechMetaBoilerBase)this.mTileEntity.getMetaTileEntity()).mTemperature;
		this.mProcessingEnergy = ((GregtechMetaBoilerBase)this.mTileEntity.getMetaTileEntity()).mProcessingEnergy;
		this.mSteamAmount = (((GregtechMetaBoilerBase)this.mTileEntity.getMetaTileEntity()).mSteam == null ? 0 : ((GregtechMetaBoilerBase)this.mTileEntity.getMetaTileEntity()).mSteam.amount);
		this.mWaterAmount = (((GregtechMetaBoilerBase)this.mTileEntity.getMetaTileEntity()).mFluid == null ? 0 : ((GregtechMetaBoilerBase)this.mTileEntity.getMetaTileEntity()).mFluid.amount);
		this.mTickingTime = ((GregtechMetaBoilerBase)this.mTileEntity.getMetaTileEntity()).RI;

		this.mTemperature = Math.min(54, Math.max(0, (this.mTemperature * 54) / (((GregtechMetaBoilerBase)this.mTileEntity.getMetaTileEntity()).maxProgresstime() - 10)));
		this.mSteamAmount = Math.min(54, Math.max(0, (this.mSteamAmount * 54) / (steamCapacity - 100)));
		this.mWaterAmount = Math.min(54, Math.max(0, (this.mWaterAmount * 54) / (waterCapacity - 100)));
		this.mProcessingEnergy = Math.min(14, Math.max(this.mProcessingEnergy > 0 ? 1 : 0, (this.mProcessingEnergy * 14) / 1000));

		final Iterator var2 = this.crafters.iterator();
		while (var2.hasNext())
		{
			final ICrafting var1 = (ICrafting)var2.next();
			var1.sendProgressBarUpdate(this, 100, this.mTemperature);
			var1.sendProgressBarUpdate(this, 101, this.mProcessingEnergy);
			var1.sendProgressBarUpdate(this, 102, this.mSteamAmount);
			var1.sendProgressBarUpdate(this, 103, this.mWaterAmount);
		}
	}

	@Override
	@SideOnly(Side.CLIENT)
	public void updateProgressBar(final int par1, final int par2)
	{
		super.updateProgressBar(par1, par2);
		switch (par1)
		{
		case 100:
			this.mTemperature = par2; break;
		case 101:
			this.mProcessingEnergy = par2; break;
		case 102:
			this.mSteamAmount = par2; break;
		case 103:
			this.mWaterAmount = par2;
		}
	}
}