Merge pull request #155 from SilverSokolova/main
Allow buying/crafting more than 1000 items at once [skip ci]
This commit is contained in:
commit
157eb7c141
@ -4,7 +4,11 @@
|
|||||||
// Disables the crafting timer if true.
|
// Disables the crafting timer if true.
|
||||||
"disableTimer" : false,
|
"disableTimer" : false,
|
||||||
|
|
||||||
// This is only used if the crafting timer is enabled.
|
// This is only used if the crafting timer is enabled.
|
||||||
// This is how many crafts are ran when the crafting timer wraps.
|
// This is how many crafts are ran when the crafting timer wraps.
|
||||||
"craftCount" : 1
|
"craftCount" : 1,
|
||||||
} }
|
|
||||||
|
// This is how many of any item can be crafted at once.
|
||||||
|
// This is also used by merchants.
|
||||||
|
"maxSpinCount" : 9999
|
||||||
|
} }
|
||||||
|
@ -42,6 +42,7 @@ CraftingPane::CraftingPane(WorldClientPtr worldClient, PlayerPtr player, Json co
|
|||||||
jsonMerge(assets->fetchJson(baseConfig), settings));
|
jsonMerge(assets->fetchJson(baseConfig), settings));
|
||||||
|
|
||||||
m_filter = StringSet::from(jsonToStringList(m_settings.get("filter", JsonArray())));
|
m_filter = StringSet::from(jsonToStringList(m_settings.get("filter", JsonArray())));
|
||||||
|
m_maxSpinCount = m_settings.getUInt("maxSpinCount", 1000);
|
||||||
|
|
||||||
GuiReader reader;
|
GuiReader reader;
|
||||||
reader.registerCallback("spinCount.up", [=](Widget*) {
|
reader.registerCallback("spinCount.up", [=](Widget*) {
|
||||||
@ -752,14 +753,14 @@ List<ItemRecipe> CraftingPane::determineRecipes() {
|
|||||||
|
|
||||||
int CraftingPane::maxCraft() {
|
int CraftingPane::maxCraft() {
|
||||||
if (m_player->isAdmin())
|
if (m_player->isAdmin())
|
||||||
return 1000;
|
return m_maxSpinCount;
|
||||||
auto itemDb = Root::singleton().itemDatabase();
|
auto itemDb = Root::singleton().itemDatabase();
|
||||||
int res = 0;
|
int res = 0;
|
||||||
if (m_guiList->selectedItem() != NPos && m_guiList->selectedItem() < m_recipes.size()) {
|
if (m_guiList->selectedItem() != NPos && m_guiList->selectedItem() < m_recipes.size()) {
|
||||||
HashMap<ItemDescriptor, uint64_t> normalizedBag = m_player->inventory()->availableItems();
|
HashMap<ItemDescriptor, uint64_t> normalizedBag = m_player->inventory()->availableItems();
|
||||||
auto selectedRecipe = recipeFromSelectedWidget();
|
auto selectedRecipe = recipeFromSelectedWidget();
|
||||||
res = itemDb->maxCraftableInBag(normalizedBag, m_player->inventory()->availableCurrencies(), selectedRecipe);
|
res = itemDb->maxCraftableInBag(normalizedBag, m_player->inventory()->availableCurrencies(), selectedRecipe);
|
||||||
res = std::min(res, 1000);
|
res = std::min(res, m_maxSpinCount);
|
||||||
}
|
}
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
@ -69,6 +69,8 @@ private:
|
|||||||
|
|
||||||
StringSet m_filter;
|
StringSet m_filter;
|
||||||
|
|
||||||
|
int m_maxSpinCount;
|
||||||
|
|
||||||
int m_recipeAutorefreshCooldown;
|
int m_recipeAutorefreshCooldown;
|
||||||
|
|
||||||
HashMap<ItemDescriptor, ItemPtr> m_itemCache;
|
HashMap<ItemDescriptor, ItemPtr> m_itemCache;
|
||||||
|
@ -38,6 +38,8 @@ MerchantPane::MerchantPane(
|
|||||||
|
|
||||||
m_itemBag = make_shared<ItemBag>(m_settings.getUInt("sellContainerSize"));
|
m_itemBag = make_shared<ItemBag>(m_settings.getUInt("sellContainerSize"));
|
||||||
|
|
||||||
|
m_maxBuyCount = m_settings.getUInt("maxSpinCount", assets->json("/interface/windowconfig/crafting.config:default").getUInt("maxSpinCount", 1000));
|
||||||
|
|
||||||
GuiReader reader;
|
GuiReader reader;
|
||||||
reader.registerCallback("spinCount.up", [=](Widget*) {
|
reader.registerCallback("spinCount.up", [=](Widget*) {
|
||||||
if (m_selectedIndex != NPos) {
|
if (m_selectedIndex != NPos) {
|
||||||
@ -360,8 +362,8 @@ int MerchantPane::maxBuyCount() {
|
|||||||
auto assets = Root::singleton().assets();
|
auto assets = Root::singleton().assets();
|
||||||
auto unitPrice = selected->data().toUInt();
|
auto unitPrice = selected->data().toUInt();
|
||||||
if (unitPrice == 0)
|
if (unitPrice == 0)
|
||||||
return 1000;
|
return m_maxBuyCount;
|
||||||
return min(1000, (int)floor(m_player->currency("money") / unitPrice));
|
return min(m_maxBuyCount, (int)floor(m_player->currency("money") / unitPrice));
|
||||||
} else {
|
} else {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -76,6 +76,7 @@ private:
|
|||||||
ItemBagPtr m_itemBag;
|
ItemBagPtr m_itemBag;
|
||||||
|
|
||||||
int m_buyCount;
|
int m_buyCount;
|
||||||
|
int m_maxBuyCount;
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user