#include "../bot_command.h" void bot_command_spell_max_thresholds(Client* c, const Seperator* sep) { if (helper_command_alias_fail(c, "bot_command_spell_max_thresholds", sep->arg[0], "spellmaxthresholds")) { return; } if (helper_is_help_or_usage(sep->arg[1])) { std::vector description = { "Controls at what target HP % the bot will start casting different spell types" }; std::vector notes = { "- All pet types are based off the pet's owner's setting", "- Any remaining types use the owner's setting when a pet is the target", "- All Heals, Cures, Buffs (DS and resists included) are based off the target's setting, not the caster", "- e.g., BotA is healing BotB using BotB's settings", }; std::vector example_format = { fmt::format( "{} [Type Shortname] [value] [actionable]" , sep->arg[0] ), fmt::format( "{} [Type ID] [value] [actionable]" , sep->arg[0] ) }; std::vector examples_one = { "To set all bots to start snaring at 99%:", fmt::format( "{} {} 99 spawned", sep->arg[0], c->GetSpellTypeShortNameByID(BotSpellTypes::Snare) ), fmt::format( "{} {} 99 spawned", sep->arg[0], BotSpellTypes::Snare ) }; std::vector examples_two = { "To set bot Enchbot to start casting Debuffs at 99%:", fmt::format( "{} {} 99 byname Enchbot", sep->arg[0], c->GetSpellTypeShortNameByID(BotSpellTypes::Debuff) ), fmt::format( "{} {} 99 byname Enchbot", sep->arg[0], BotSpellTypes::Debuff ) }; std::vector examples_three = { "To check the current Nuke max threshold on all bots:", fmt::format( "{} {} current spawned", sep->arg[0], c->GetSpellTypeShortNameByID(BotSpellTypes::Nuke) ), fmt::format( "{} {} current spawned", sep->arg[0], BotSpellTypes::Nuke ) }; std::vector actionables = { "target, byname, ownergroup, ownerraid, targetgroup, namesgroup, healrotationtargets, mmr, byclass, byrace, spawned" }; std::vector options = { }; std::vector options_one = { }; std::vector options_two = { }; std::vector options_three = { }; std::string popup_text = c->SendCommandHelpWindow( c, description, notes, example_format, examples_one, examples_two, examples_three, actionables, options, options_one, options_two, options_three ); popup_text = DialogueWindow::Table(popup_text); c->SendPopupToClient(sep->arg[0], popup_text.c_str()); c->SendSpellTypePrompts(); if (RuleB(Bots, SendClassRaceOnHelp)) { c->Message( Chat::Yellow, fmt::format( "Use {} for information about race/class IDs.", Saylink::Silent("^classracelist") ).c_str() ); } return; } std::string arg1 = sep->arg[1]; std::string arg2 = sep->arg[2]; int ab_arg = 2; bool current_check = false; uint16 spellType = 0; uint32 typeValue = 0; // String/Int type checks if (sep->IsNumber(1)) { spellType = atoi(sep->arg[1]); if (spellType < BotSpellTypes::START || spellType > BotSpellTypes::END) { c->Message(Chat::Yellow, "You must choose a valid spell type. Spell types range from %i to %i", BotSpellTypes::START, BotSpellTypes::END); return; } } else { if (c->GetSpellTypeIDByShortName(arg1) != UINT16_MAX) { spellType = c->GetSpellTypeIDByShortName(arg1); } else { c->Message( Chat::Yellow, fmt::format( "Incorrect argument, use {} for information regarding this command.", Saylink::Silent( fmt::format("{} help", sep->arg[0]) ) ).c_str() ); return; } } if (sep->IsNumber(2)) { typeValue = atoi(sep->arg[2]); ++ab_arg; if (typeValue < 0 || typeValue > 100) { c->Message(Chat::Yellow, "You must enter a value between 0-100 (0%% to 100%% of health)."); return; } } else if (!arg2.compare("current")) { ++ab_arg; current_check = true; } else { c->Message( Chat::Yellow, fmt::format( "Incorrect argument, use {} for information regarding this command.", Saylink::Silent( fmt::format("{} help", sep->arg[0]) ) ).c_str() ); return; } const int ab_mask = ActionableBots::ABM_Type1; std::string class_race_arg = sep->arg[ab_arg]; bool class_race_check = false; if (!class_race_arg.compare("byclass") || !class_race_arg.compare("byrace")) { class_race_check = true; } std::list sbl; if (ActionableBots::PopulateSBL(c, sep->arg[ab_arg], sbl, ab_mask, !class_race_check ? sep->arg[ab_arg + 1] : nullptr, class_race_check ? atoi(sep->arg[ab_arg + 1]) : 0) == ActionableBots::ABT_None) { return; } sbl.remove(nullptr); Bot* first_found = nullptr; int success_count = 0; for (auto my_bot : sbl) { if (my_bot->BotPassiveCheck()) { continue; } if (!first_found) { first_found = my_bot; } if (current_check) { c->Message( Chat::Green, fmt::format( "{} says, 'My [{}] maximum threshold is currently [{}%%].'", my_bot->GetCleanName(), c->GetSpellTypeNameByID(spellType), my_bot->GetSpellMaxThreshold(spellType) ).c_str() ); } else { my_bot->SetSpellMaxThreshold(spellType, typeValue); ++success_count; } } if (!current_check) { if (success_count == 1 && first_found) { c->Message( Chat::Green, fmt::format( "{} says, 'My [{}] maximum threshold was set to [{}%%].'", first_found->GetCleanName(), c->GetSpellTypeNameByID(spellType), first_found->GetSpellMaxThreshold(spellType) ).c_str() ); } else { c->Message( Chat::Green, fmt::format( "{} of your bots set their [{}] maximum threshold to [{}%%].", success_count, c->GetSpellTypeNameByID(spellType), typeValue ).c_str() ); } } }