2013-08-26 18:49:32 -04:00
|
|
|
package mekanism.client.gui;
|
2013-04-12 20:25:21 -04:00
|
|
|
|
2013-12-01 00:03:40 -05:00
|
|
|
import mekanism.api.EnumColor;
|
2013-11-30 23:19:24 -05:00
|
|
|
import mekanism.api.Object3D;
|
2013-04-12 20:25:21 -04:00
|
|
|
import mekanism.common.IElectricChest;
|
|
|
|
import mekanism.common.PacketHandler;
|
2013-06-13 17:37:30 -04:00
|
|
|
import mekanism.common.PacketHandler.Transmission;
|
|
|
|
import mekanism.common.network.PacketElectricChest;
|
|
|
|
import mekanism.common.network.PacketElectricChest.ElectricChestPacketType;
|
2013-08-26 18:49:32 -04:00
|
|
|
import mekanism.common.tileentity.TileEntityElectricChest;
|
2013-08-26 18:57:08 -04:00
|
|
|
import mekanism.common.util.MekanismUtils;
|
|
|
|
import mekanism.common.util.MekanismUtils.ResourceType;
|
2013-04-12 20:25:21 -04:00
|
|
|
import net.minecraft.client.gui.GuiButton;
|
|
|
|
import net.minecraft.client.gui.GuiScreen;
|
|
|
|
import net.minecraft.client.gui.GuiTextField;
|
|
|
|
import net.minecraft.item.ItemStack;
|
2013-08-26 18:49:32 -04:00
|
|
|
|
2013-04-12 20:25:21 -04:00
|
|
|
import org.lwjgl.input.Keyboard;
|
|
|
|
import org.lwjgl.opengl.GL11;
|
|
|
|
|
2013-04-13 10:33:37 -04:00
|
|
|
import cpw.mods.fml.relauncher.Side;
|
|
|
|
import cpw.mods.fml.relauncher.SideOnly;
|
|
|
|
|
|
|
|
@SideOnly(Side.CLIENT)
|
2013-04-12 20:25:21 -04:00
|
|
|
public class GuiPasswordModify extends GuiScreen
|
|
|
|
{
|
|
|
|
public int xSize = 176;
|
|
|
|
public int ySize = 95;
|
|
|
|
|
|
|
|
public TileEntityElectricChest tileEntity;
|
|
|
|
|
|
|
|
public ItemStack itemStack;
|
|
|
|
|
|
|
|
public boolean isBlock;
|
|
|
|
|
|
|
|
public GuiTextField newPasswordField;
|
|
|
|
|
|
|
|
public GuiTextField confirmPasswordField;
|
|
|
|
|
2013-11-30 00:28:02 -05:00
|
|
|
public String displayText = EnumColor.BRIGHT_GREEN + MekanismUtils.localize("gui.password.setPassword");
|
2013-04-12 20:25:21 -04:00
|
|
|
|
|
|
|
public int ticker = 0;
|
|
|
|
|
|
|
|
public GuiPasswordModify(TileEntityElectricChest tileentity)
|
|
|
|
{
|
|
|
|
isBlock = true;
|
|
|
|
tileEntity = tileentity;
|
|
|
|
}
|
|
|
|
|
|
|
|
public GuiPasswordModify(ItemStack itemstack)
|
|
|
|
{
|
|
|
|
isBlock = false;
|
|
|
|
itemStack = itemstack;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void initGui()
|
|
|
|
{
|
|
|
|
super.initGui();
|
|
|
|
|
|
|
|
int guiWidth = (width - xSize) / 2;
|
|
|
|
int guiHeight = (height - ySize) / 2;
|
|
|
|
|
|
|
|
buttonList.clear();
|
2013-11-30 00:28:02 -05:00
|
|
|
buttonList.add(new GuiButton(0, guiWidth + 55, guiHeight + 68, 60, 20, MekanismUtils.localize("gui.confirm")));
|
2013-04-12 20:25:21 -04:00
|
|
|
|
|
|
|
newPasswordField = new GuiTextField(fontRenderer, guiWidth + 60, guiHeight + 34, 80, 12);
|
|
|
|
newPasswordField.setMaxStringLength(12);
|
|
|
|
newPasswordField.setFocused(true);
|
|
|
|
|
|
|
|
confirmPasswordField = new GuiTextField(fontRenderer, guiWidth + 60, guiHeight + 51, 80, 12);
|
|
|
|
confirmPasswordField.setMaxStringLength(12);
|
|
|
|
confirmPasswordField.setFocused(false);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
protected void mouseClicked(int mouseX, int mouseY, int button)
|
|
|
|
{
|
|
|
|
super.mouseClicked(mouseX, mouseY, button);
|
|
|
|
newPasswordField.mouseClicked(mouseX, mouseY, button);
|
|
|
|
confirmPasswordField.mouseClicked(mouseX, mouseY, button);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void keyTyped(char c, int i)
|
|
|
|
{
|
|
|
|
super.keyTyped(c, i);
|
|
|
|
|
|
|
|
if(i == Keyboard.KEY_TAB)
|
|
|
|
{
|
|
|
|
if(!newPasswordField.isFocused() && !confirmPasswordField.isFocused())
|
|
|
|
{
|
|
|
|
newPasswordField.setFocused(true);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
else if(newPasswordField.isFocused() && confirmPasswordField.isFocused())
|
|
|
|
{
|
|
|
|
newPasswordField.setFocused(true);
|
|
|
|
confirmPasswordField.setFocused(false);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
newPasswordField.setFocused(!newPasswordField.isFocused());
|
|
|
|
confirmPasswordField.setFocused(!confirmPasswordField.isFocused());
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else if(i == Keyboard.KEY_RETURN)
|
|
|
|
{
|
|
|
|
tryModify();
|
|
|
|
}
|
|
|
|
|
|
|
|
newPasswordField.textboxKeyTyped(c, i);
|
|
|
|
confirmPasswordField.textboxKeyTyped(c, i);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public boolean doesGuiPauseGame()
|
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void updateScreen()
|
|
|
|
{
|
|
|
|
newPasswordField.updateCursorCounter();
|
|
|
|
|
|
|
|
if(ticker > 0)
|
|
|
|
{
|
|
|
|
ticker--;
|
|
|
|
}
|
|
|
|
else {
|
2013-11-30 00:28:02 -05:00
|
|
|
displayText = EnumColor.BRIGHT_GREEN + MekanismUtils.localize("gui.password.setPassword");
|
2013-04-12 20:25:21 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
protected void actionPerformed(GuiButton guibutton)
|
|
|
|
{
|
|
|
|
if(guibutton.id == 0)
|
|
|
|
{
|
|
|
|
tryModify();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public void tryModify()
|
|
|
|
{
|
|
|
|
if(newPasswordField.getText() == null || newPasswordField.getText().equals("") || confirmPasswordField.getText() == null || confirmPasswordField.getText().equals(""))
|
|
|
|
{
|
2013-11-30 00:28:02 -05:00
|
|
|
displayText = EnumColor.DARK_RED + MekanismUtils.localize("gui.password.fieldsEmpty");
|
2013-04-12 20:25:21 -04:00
|
|
|
ticker = 30;
|
|
|
|
}
|
|
|
|
else if(!newPasswordField.getText().equals(confirmPasswordField.getText()))
|
|
|
|
{
|
2013-11-30 00:28:02 -05:00
|
|
|
displayText = EnumColor.DARK_RED + MekanismUtils.localize("gui.password.notMatching");
|
2013-04-12 20:25:21 -04:00
|
|
|
ticker = 30;
|
|
|
|
}
|
|
|
|
else if(confirmPasswordField.getText().equals(getPassword()))
|
|
|
|
{
|
2013-11-30 00:28:02 -05:00
|
|
|
displayText = EnumColor.DARK_RED + MekanismUtils.localize("gui.password.identical");
|
2013-04-12 20:25:21 -04:00
|
|
|
ticker = 30;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
if(isBlock)
|
|
|
|
{
|
2013-06-14 18:25:09 -04:00
|
|
|
PacketHandler.sendPacket(Transmission.SERVER, new PacketElectricChest().setParams(ElectricChestPacketType.PASSWORD, confirmPasswordField.getText(), true, Object3D.get(tileEntity)));
|
|
|
|
PacketHandler.sendPacket(Transmission.SERVER, new PacketElectricChest().setParams(ElectricChestPacketType.SERVER_OPEN, false, true, Object3D.get(tileEntity)));
|
2013-04-12 20:25:21 -04:00
|
|
|
}
|
|
|
|
else {
|
|
|
|
((IElectricChest)itemStack.getItem()).setPassword(itemStack, confirmPasswordField.getText());
|
2013-06-14 18:25:09 -04:00
|
|
|
PacketHandler.sendPacket(Transmission.SERVER, new PacketElectricChest().setParams(ElectricChestPacketType.PASSWORD, confirmPasswordField.getText(), false));
|
|
|
|
PacketHandler.sendPacket(Transmission.SERVER, new PacketElectricChest().setParams(ElectricChestPacketType.SERVER_OPEN, false, false));
|
2013-04-12 20:25:21 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public String getPassword()
|
|
|
|
{
|
|
|
|
if(isBlock)
|
|
|
|
{
|
|
|
|
return tileEntity.password;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
return ((IElectricChest)itemStack.getItem()).getPassword(itemStack);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
2013-11-26 20:11:26 -05:00
|
|
|
public void drawScreen(int mouseX, int mouseY, float partialTick)
|
2013-04-12 20:25:21 -04:00
|
|
|
{
|
|
|
|
GL11.glColor4f(1.0F, 1.0F, 1.0F, 1.0F);
|
2013-09-28 02:59:47 +01:00
|
|
|
mc.renderEngine.bindTexture(MekanismUtils.getResource(ResourceType.GUI, "GuiPasswordModify.png"));
|
2013-04-12 20:25:21 -04:00
|
|
|
|
|
|
|
int guiWidth = (width - xSize) / 2;
|
|
|
|
int guiHeight = (height - ySize) / 2;
|
|
|
|
|
|
|
|
drawTexturedModalRect(guiWidth, guiHeight, 0, 0, xSize, ySize);
|
2013-11-26 20:11:26 -05:00
|
|
|
|
|
|
|
super.drawScreen(mouseX, mouseY, partialTick);
|
|
|
|
|
2013-11-30 00:28:02 -05:00
|
|
|
fontRenderer.drawString(MekanismUtils.localize("gui.password"), guiWidth + 64, guiHeight + 5, 0x404040);
|
2013-04-12 20:25:21 -04:00
|
|
|
fontRenderer.drawString(displayText, guiWidth + 37, guiHeight + 19, 0x404040);
|
|
|
|
fontRenderer.drawString("Enter:", guiWidth + 27, guiHeight + 37, 0x404040);
|
|
|
|
fontRenderer.drawString("Repeat:", guiWidth + 21, guiHeight + 54, 0x404040);
|
|
|
|
newPasswordField.drawTextBox();
|
|
|
|
confirmPasswordField.drawTextBox();
|
|
|
|
GL11.glBlendFunc(GL11.GL_SRC_ALPHA, GL11.GL_ONE_MINUS_SRC_ALPHA);
|
|
|
|
GL11.glEnable(GL11.GL_CULL_FACE);
|
|
|
|
GL11.glEnable(GL11.GL_ALPHA_TEST);
|
|
|
|
GL11.glEnable(GL11.GL_DEPTH_TEST);
|
|
|
|
}
|
|
|
|
}
|