package gregtech.common.gui;

import cpw.mods.fml.relauncher.Side;
import cpw.mods.fml.relauncher.SideOnly;
import gregtech.api.gui.GT_ContainerMetaTile_Machine;
import gregtech.api.interfaces.tileentity.IGregTechTileEntity;
import gregtech.common.tileentities.boilers.GT_MetaTileEntity_Boiler;
import java.util.Iterator;
import java.util.List;
import net.minecraft.entity.player.InventoryPlayer;
import net.minecraft.inventory.ICrafting;
import net.minecraft.inventory.Slot;
import net.minecraftforge.fluids.FluidStack;

public class GT_Container_Boiler
  extends GT_ContainerMetaTile_Machine
{
  public GT_Container_Boiler(InventoryPlayer aInventoryPlayer, IGregTechTileEntity aTileEntity, int aSteamCapacity)
  {
    super(aInventoryPlayer, aTileEntity);
    this.mSteamCapacity = aSteamCapacity;
  }
  
  public void addSlots(InventoryPlayer aInventoryPlayer)
  {
    addSlotToContainer(new Slot(this.mTileEntity, 2, 116, 62));
    addSlotToContainer(new Slot(this.mTileEntity, 0, 44, 26));
    addSlotToContainer(new Slot(this.mTileEntity, 1, 44, 62));
    addSlotToContainer(new Slot(this.mTileEntity, 3, 116, 26));
  }
  
  public int getSlotCount()
  {
    return 4;
  }
  
  public int getShiftClickSlotCount()
  {
    return 1;
  }
  
  public int mWaterAmount = 0;
  public int mSteamAmount = 0;
  public int mProcessingEnergy = 0;
  public int mTemperature = 2;
  private final int mSteamCapacity;
  
  public void detectAndSendChanges()
  {
    super.detectAndSendChanges();
    if ((this.mTileEntity.isClientSide()) || (this.mTileEntity.getMetaTileEntity() == null)) {
      return;
    }
    this.mTemperature = ((GT_MetaTileEntity_Boiler)this.mTileEntity.getMetaTileEntity()).mTemperature;
    this.mProcessingEnergy = ((GT_MetaTileEntity_Boiler)this.mTileEntity.getMetaTileEntity()).mProcessingEnergy;
    this.mSteamAmount = (((GT_MetaTileEntity_Boiler)this.mTileEntity.getMetaTileEntity()).mSteam == null ? 0 : ((GT_MetaTileEntity_Boiler)this.mTileEntity.getMetaTileEntity()).mSteam.amount);
    this.mWaterAmount = (((GT_MetaTileEntity_Boiler)this.mTileEntity.getMetaTileEntity()).mFluid == null ? 0 : ((GT_MetaTileEntity_Boiler)this.mTileEntity.getMetaTileEntity()).mFluid.amount);
    
    this.mTemperature = Math.min(54, Math.max(0, this.mTemperature * 54 / (((GT_MetaTileEntity_Boiler)this.mTileEntity.getMetaTileEntity()).maxProgresstime() - 10)));
    this.mSteamAmount = Math.min(54, Math.max(0, this.mSteamAmount * 54 / (this.mSteamCapacity - 100)));
    this.mWaterAmount = Math.min(54, Math.max(0, this.mWaterAmount * 54 / 15900));
    this.mProcessingEnergy = Math.min(14, Math.max(this.mProcessingEnergy > 0 ? 1 : 0, this.mProcessingEnergy * 14 / 1000));
    
    Iterator var2 = this.crafters.iterator();
    while (var2.hasNext())
    {
      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);
    }
  }
  
  @SideOnly(Side.CLIENT)
  public void updateProgressBar(int par1, 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;
    }
  }
}



/* Location:           F:\Torrent\minecraft\jd-gui-0.3.6.windows\gregtech_1.7.10-5.07.07-dev.jar

 * Qualified Name:     gregtech.common.gui.GT_Container_Boiler

 * JD-Core Version:    0.7.0.1

 */