mirror of
https://github.com/EQEmu/Server.git
synced 2026-05-31 04:56:20 +00:00
[Commands] Add #viewcurrencies Command. (#1844)
* [Commands] Add #viewcurrencies Command. - Add #viewcurrencies command to view your or your target's currencies (Money, Crystals, Alternate Currency, LDoN, and PVP). - Add GetLDoNThemeName() helper method. * Update viewcurrencies.cpp * Cleanup name of map method. * Cleanup.
This commit is contained in:
@@ -0,0 +1,137 @@
|
||||
#include "../client.h"
|
||||
|
||||
void command_viewcurrencies(Client *c, const Seperator *sep)
|
||||
{
|
||||
Client *target = c;
|
||||
if (c->GetTarget() && c->GetTarget()->IsClient()) {
|
||||
target = c->GetTarget()->CastToClient();
|
||||
}
|
||||
|
||||
auto target_string = (
|
||||
c == target ?
|
||||
"Yourself" :
|
||||
fmt::format(
|
||||
"{} ({})",
|
||||
target->GetCleanName(),
|
||||
target->GetID()
|
||||
)
|
||||
);
|
||||
|
||||
auto platinum = (
|
||||
target->GetMoney(3, 0) +
|
||||
target->GetMoney(3, 1) +
|
||||
target->GetMoney(3, 2) +
|
||||
target->GetMoney(3, 3)
|
||||
);
|
||||
|
||||
auto gold = (
|
||||
target->GetMoney(2, 0) +
|
||||
target->GetMoney(2, 1) +
|
||||
target->GetMoney(2, 2)
|
||||
);
|
||||
|
||||
auto silver = (
|
||||
target->GetMoney(1, 0) +
|
||||
target->GetMoney(1, 1) +
|
||||
target->GetMoney(1, 2)
|
||||
);
|
||||
|
||||
auto copper = (
|
||||
target->GetMoney(0, 0) +
|
||||
target->GetMoney(0, 1) +
|
||||
target->GetMoney(0, 2)
|
||||
);
|
||||
|
||||
if (
|
||||
platinum ||
|
||||
gold ||
|
||||
silver ||
|
||||
copper
|
||||
) {
|
||||
c->Message(
|
||||
Chat::White,
|
||||
fmt::format(
|
||||
"Money for {} | {}",
|
||||
target_string,
|
||||
ConvertMoneyToString(
|
||||
platinum,
|
||||
gold,
|
||||
silver,
|
||||
copper
|
||||
)
|
||||
).c_str()
|
||||
);
|
||||
}
|
||||
|
||||
auto ebon_crystals = target->GetEbonCrystals();
|
||||
if (ebon_crystals) {
|
||||
c->Message(
|
||||
Chat::White,
|
||||
fmt::format(
|
||||
"{} for {} | {}",
|
||||
database.CreateItemLink(RuleI(Zone, EbonCrystalItemID)),
|
||||
target_string,
|
||||
ebon_crystals
|
||||
).c_str()
|
||||
);
|
||||
}
|
||||
|
||||
auto radiant_crystals = target->GetRadiantCrystals();
|
||||
if (radiant_crystals) {
|
||||
c->Message(
|
||||
Chat::White,
|
||||
fmt::format(
|
||||
"{} for {} | {}",
|
||||
database.CreateItemLink(RuleI(Zone, RadiantCrystalItemID)),
|
||||
target_string,
|
||||
radiant_crystals
|
||||
).c_str()
|
||||
);
|
||||
}
|
||||
|
||||
for (const auto& alternate_currency : zone->AlternateCurrencies) {
|
||||
auto currency_value = target->GetAlternateCurrencyValue(alternate_currency.id);
|
||||
if (currency_value) {
|
||||
c->Message(
|
||||
Chat::White,
|
||||
fmt::format(
|
||||
"{} for {} | {}",
|
||||
database.CreateItemLink(alternate_currency.item_id),
|
||||
target_string,
|
||||
currency_value
|
||||
).c_str()
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
for (
|
||||
uint32 ldon_currency_id = LDoNThemes::GUK;
|
||||
ldon_currency_id <= LDoNThemes::TAK;
|
||||
ldon_currency_id++
|
||||
) {
|
||||
auto ldon_currency_value = target->GetLDoNPointsTheme(ldon_currency_id);
|
||||
if (ldon_currency_value) {
|
||||
c->Message(
|
||||
Chat::White,
|
||||
fmt::format(
|
||||
"{} for {} | {}",
|
||||
EQ::constants::GetLDoNThemeName(ldon_currency_id),
|
||||
target_string,
|
||||
ldon_currency_value
|
||||
).c_str()
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
auto pvp_points = target->GetPVPPoints();
|
||||
if (pvp_points) {
|
||||
c->Message(
|
||||
Chat::White,
|
||||
fmt::format(
|
||||
"PVP Points for {} | {}",
|
||||
target_string,
|
||||
pvp_points
|
||||
).c_str()
|
||||
);
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user