// • ▌ ▄ ·.  ▄▄▄·  ▄▄ • ▪   ▄▄· ▄▄▄▄·  ▄▄▄·  ▐▄▄▄  ▄▄▄ .
// ·██ ▐███▪▐█ ▀█ ▐█ ▀ ▪██ ▐█ ▌▪▐█ ▀█▪▐█ ▀█ •█▌ ▐█▐▌·
// ▐█ ▌▐▌▐█·▄█▀▀█ ▄█ ▀█▄▐█·██ ▄▄▐█▀▀█▄▄█▀▀█ ▐█▐ ▐▌▐▀▀▀
// ██ ██▌▐█▌▐█ ▪▐▌▐█▄▪▐█▐█▌▐███▌██▄▪▐█▐█ ▪▐▌██▐ █▌▐█▄▄▌
// ▀▀  █▪▀▀▀ ▀  ▀ ·▀▀▀▀ ▀▀▀·▀▀▀ ·▀▀▀▀  ▀  ▀ ▀▀  █▪ ▀▀▀
//      Magicbane Emulator Project © 2013 - 2022
//                www.magicbane.com


package engine.devcmd.cmds;

import engine.Enum.ModType;
import engine.devcmd.AbstractDevCmd;
import engine.gameManager.PowersManager;
import engine.net.ItemProductionManager;
import engine.objects.*;
import engine.powers.effectmodifiers.AbstractEffectModifier;
import engine.powers.poweractions.AbstractPowerAction;
import org.pmw.tinylog.Logger;

public class AuditFailedItemsCmd extends AbstractDevCmd {

    public AuditFailedItemsCmd() {
        super("faileditems");
    }

    @Override
    protected void _doCmd(PlayerCharacter pcSender, String[] words,
                          AbstractGameObject target) {


        if (ItemProductionManager.FailedItems.isEmpty())
            return;

        Logger.info("Auditing Item production Failed Items");

        String newLine = "\r\n";
        String auditFailedItem = "Failed Item Name | Prefix | Suffix | NPC | Contract  | Player | ";

        for (ProducedItem failedItem : ItemProductionManager.FailedItems) {

            String npcName = "";
            String playerName = "";
            String contractName = "";

            String prefix = "";
            String suffix = "";
            String itemName = "";
            NPC npc = NPC.getFromCache(failedItem.getNpcUID());

            if (npc == null) {
                npcName = "null";
                contractName = "null";
            } else {
                npcName = npc.getName();
                if (npc.getContract() != null)
                    contractName = npc.getContract().getName();
            }

            PlayerCharacter roller = PlayerCharacter.getFromCache(failedItem.getPlayerID());

            if (roller == null)
                playerName = "null";
            else
                playerName = roller.getName();

            ItemBase ib = ItemBase.getItemBase(failedItem.getItemBaseID());

            if (ib != null) {
                itemName = ib.getName();
            }

            if (failedItem.isRandom() == false) {
                if (failedItem.getPrefix().isEmpty() == false) {
                    AbstractPowerAction pa = PowersManager.getPowerActionByIDString(failedItem.getPrefix());
                    if (pa != null) {
                        for (AbstractEffectModifier aem : pa.getEffectsBase().getModifiers()) {
                            if (aem.modType.equals(ModType.ItemName)) {
                                prefix = aem.getString1();
                                break;
                            }
                        }
                    }

                }

                if (failedItem.getSuffix().isEmpty() == false) {
                    AbstractPowerAction pa = PowersManager.getPowerActionByIDString(failedItem.getSuffix());
                    if (pa != null) {
                        for (AbstractEffectModifier aem : pa.getEffectsBase().getModifiers()) {
                            if (aem.modType.equals(ModType.ItemName)) {
                                suffix = aem.getString1();
                                break;
                            }
                        }
                    }

                }

            } else {
                prefix = "random";
            }


            auditFailedItem += newLine;
            auditFailedItem += itemName + " | " + prefix + " | " + suffix + " | " + failedItem.getNpcUID() + ":" + npcName + " | " + contractName + " | " + failedItem.getPlayerID() + ":" + playerName;

        }
        Logger.info(auditFailedItem);
        ItemProductionManager.FailedItems.clear();


    }


    @Override
    protected String _getUsageString() {
        return "' /bounds'";
    }

    @Override
    protected String _getHelpString() {
        return "Audits all the mobs in a zone.";

    }

}