001package net.tnemc.item.bukkit.platform.impl;
002/*
003 * The New Item Library
004 * Copyright (C) 2022 - 2025 Daniel "creatorfromhell" Vidmar
005 *
006 * This program is free software; you can redistribute it and/or
007 * modify it under the terms of the GNU Lesser General Public
008 * License as published by the Free Software Foundation; either
009 * version 3 of the License, or (at your option) any later version.
010 *
011 * This program is distributed in the hope that it will be useful,
012 * but WITHOUT ANY WARRANTY; without even the implied warranty of
013 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
014 * Lesser General Public License for more details.
015 *
016 * You should have received a copy of the GNU Lesser General Public License
017 * along with this program; if not, write to the Free Software Foundation,
018 * Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
019 */
020
021import net.tnemc.item.bukkit.BukkitItemStack;
022import net.tnemc.item.component.impl.MaxDamageComponent;
023import net.tnemc.item.providers.VersionUtil;
024import org.bukkit.inventory.ItemStack;
025import org.bukkit.inventory.meta.Damageable;
026
027import java.util.Optional;
028
029/**
030 * BukkitMaxDamageComponent
031 *
032 * @author creatorfromhell
033 * @since 0.2.0.0
034 */
035public class BukkitMaxDamageComponent extends MaxDamageComponent<BukkitItemStack, ItemStack> {
036
037  public BukkitMaxDamageComponent() {
038
039  }
040
041  public BukkitMaxDamageComponent(final int maxDamage) {
042
043    super(maxDamage);
044  }
045
046  /**
047   * @param version the version being used when this check is called.
048   *
049   * @return true if this check is enabled for the version, otherwise false
050   * @since 0.2.0.0
051   */
052  @Override
053  public boolean enabled(final String version) {
054
055    return VersionUtil.isOneThirteen(version);
056  }
057
058  /**
059   * @param serialized the serialized item stack to use
060   * @param item       the item that we should use to apply this applicator to.
061   *
062   * @return the updated item.
063   * @since 0.2.0.0
064   */
065  @Override
066  public ItemStack apply(final BukkitItemStack serialized, final ItemStack item) {
067
068    final Optional<BukkitMaxDamageComponent> componentOptional = serialized.component(identifier());
069
070    if(componentOptional.isPresent()) {
071
072      if(item.hasItemMeta() && item.getItemMeta() instanceof final Damageable meta) {
073
074        meta.setMaxDamage(componentOptional.get().maxDamage);
075        item.setItemMeta(meta);
076      }
077    }
078    return item;
079  }
080
081  /**
082   * @param item       the item that we should use to deserialize.
083   * @param serialized the serialized item stack we should use to apply this deserializer to
084   *
085   * @return the updated serialized item.
086   * @since 0.2.0.0
087   */
088  @Override
089  public BukkitItemStack serialize(final ItemStack item, final BukkitItemStack serialized) {
090
091    if(item.hasItemMeta() && item.getItemMeta() instanceof final Damageable meta) {
092
093      this.maxDamage = meta.getMaxDamage();
094    }
095
096    serialized.applyComponent(this);
097    return serialized;
098  }
099
100  /**
101   * Checks if this component applies to the specified item.
102   *
103   * @param item The item to check against.
104   *
105   * @return True if this component applies to the item, false otherwise.
106   * @since 0.2.0.0
107   */
108  @Override
109  public boolean appliesTo(final ItemStack item) {
110
111    return item.hasItemMeta() && item.getItemMeta() instanceof Damageable;
112  }
113}