blob: 0c27ed57925133e5e474011d3d008480302ac47e [file] [log] [blame] [raw]
package li.cil.oc.common.item
import java.util
import cpw.mods.fml.relauncher.{Side, SideOnly}
import li.cil.oc.client.KeyBindings
import li.cil.oc.util.{ItemCosts, Rarity, Tooltip}
import li.cil.oc.{Localization, Settings, api}
import net.minecraft.entity.Entity
import net.minecraft.entity.player.EntityPlayer
import net.minecraft.item.ItemStack
import net.minecraft.world.World
import org.lwjgl.input
trait Delegate {
type Icon = net.minecraft.util.IIcon
type IconRegister = net.minecraft.client.renderer.texture.IIconRegister
val parent: Delegator
def unlocalizedName = getClass.getSimpleName
protected def tooltipName = Option(unlocalizedName)
protected def tooltipData = Seq.empty[Any]
var showInItemList = true
val itemId = parent.add(this)
private var _icon: Option[Icon] = None
def maxStackSize = 64
def createItemStack(amount: Int = 1) = new ItemStack(parent, amount, itemId)
// ----------------------------------------------------------------------- //
def onItemUseFirst(stack: ItemStack, player: EntityPlayer, world: World, x: Int, y: Int, z: Int, side: Int, hitX: Float, hitY: Float, hitZ: Float): Boolean = false
def onItemUse(stack: ItemStack, player: EntityPlayer, world: World, x: Int, y: Int, z: Int, side: Int, hitX: Float, hitY: Float, hitZ: Float): Boolean = false
def onItemRightClick(stack: ItemStack, world: World, player: EntityPlayer): ItemStack = {
if (player.isSneaking) {
if (stack.hasTagCompound && stack.getTagCompound.hasKey(Settings.namespace + "data")) {
stack.setTagCompound(null)
player.swingItem()
}
}
stack
}
def update(stack: ItemStack, world: World, player: Entity, slot: Int, selected: Boolean) {}
// ----------------------------------------------------------------------- //
def rarity = Rarity.byTier(tierFromDriver)
protected def tierFromDriver = {
val stack = createItemStack()
api.Driver.driverFor(stack) match {
case driver: api.driver.Item => driver.tier(stack)
case _ => 0
}
}
def color(stack: ItemStack, pass: Int) = 0xFFFFFF
def displayName(stack: ItemStack): Option[String] = None
@SideOnly(Side.CLIENT)
def tooltipLines(stack: ItemStack, player: EntityPlayer, tooltip: java.util.List[String], advanced: Boolean) {
if (tooltipName.isDefined) {
tooltip.addAll(Tooltip.get(tooltipName.get, tooltipData: _*))
tooltipExtended(stack, tooltip)
}
tooltipCosts(stack, tooltip)
}
// For stuff that goes to the normal 'extended' tooltip, before the costs.
protected def tooltipExtended(stack: ItemStack, tooltip: java.util.List[String]) {}
protected def tooltipCosts(stack: ItemStack, tooltip: java.util.List[String]) {
if (ItemCosts.hasCosts(stack)) {
if (KeyBindings.showMaterialCosts) {
ItemCosts.addTooltip(stack, tooltip.asInstanceOf[util.List[String]])
}
else {
tooltip.add(Localization.localizeImmediately(
Settings.namespace + "tooltip.MaterialCosts",
input.Keyboard.getKeyName(KeyBindings.materialCosts.getKeyCode)))
}
}
if (stack.hasTagCompound && stack.getTagCompound.hasKey(Settings.namespace + "data")) {
val data = stack.getTagCompound.getCompoundTag(Settings.namespace + "data")
if (data.hasKey("node") && data.getCompoundTag("node").hasKey("address")) {
tooltip.add("§8" + data.getCompoundTag("node").getString("address").substring(0, 13) + "...§7")
}
}
}
def isDamageable = false
def damage(stack: ItemStack) = 0
def maxDamage(stack: ItemStack) = 0
@SideOnly(Side.CLIENT)
def icon: Option[Icon] = _icon
@SideOnly(Side.CLIENT)
protected def icon_=(value: Icon) = _icon = Option(value)
@SideOnly(Side.CLIENT)
def icon(stack: ItemStack, pass: Int): Option[Icon] = icon
@SideOnly(Side.CLIENT)
def registerIcons(iconRegister: IconRegister) {
icon = iconRegister.registerIcon(Settings.resourceDomain + ":" + unlocalizedName)
}
// ----------------------------------------------------------------------- //
def equals(stack: ItemStack) =
stack != null && stack.getItem == parent && parent.subItem(stack).exists(_ == this)
}