mirror of
https://github.com/TES3MP/openmw-tes3mp.git
synced 2025-03-03 13:19:40 +00:00
Update barter offer for all items when another item is added (Fixes #1935)
This commit is contained in:
parent
a7c0e07d78
commit
0f99a959eb
3 changed files with 30 additions and 14 deletions
|
@ -278,14 +278,14 @@ namespace MWGui
|
||||||
if (item.mType == ItemStack::Type_Barter)
|
if (item.mType == ItemStack::Type_Barter)
|
||||||
{
|
{
|
||||||
// this was an item borrowed to us by the merchant
|
// this was an item borrowed to us by the merchant
|
||||||
MWBase::Environment::get().getWindowManager()->getTradeWindow()->returnItem(mSelectedItem, count);
|
|
||||||
mTradeModel->returnItemBorrowedToUs(mSelectedItem, count);
|
mTradeModel->returnItemBorrowedToUs(mSelectedItem, count);
|
||||||
|
MWBase::Environment::get().getWindowManager()->getTradeWindow()->returnItem(mSelectedItem, count);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
// borrow item to the merchant
|
// borrow item to the merchant
|
||||||
MWBase::Environment::get().getWindowManager()->getTradeWindow()->borrowItem(mSelectedItem, count);
|
|
||||||
mTradeModel->borrowItemFromUs(mSelectedItem, count);
|
mTradeModel->borrowItemFromUs(mSelectedItem, count);
|
||||||
|
MWBase::Environment::get().getWindowManager()->getTradeWindow()->borrowItem(mSelectedItem, count);
|
||||||
}
|
}
|
||||||
|
|
||||||
mItemView->update();
|
mItemView->update();
|
||||||
|
|
|
@ -480,24 +480,38 @@ namespace MWGui
|
||||||
mMerchantGold->setCaptionWithReplacing("#{sSellerGold} " + boost::lexical_cast<std::string>(getMerchantGold()));
|
mMerchantGold->setCaptionWithReplacing("#{sSellerGold} " + boost::lexical_cast<std::string>(getMerchantGold()));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void TradeWindow::updateOffer()
|
||||||
|
{
|
||||||
|
TradeItemModel* playerTradeModel = MWBase::Environment::get().getWindowManager()->getInventoryWindow()->getTradeModel();
|
||||||
|
|
||||||
|
int merchantOffer = 0;
|
||||||
|
|
||||||
|
std::vector<ItemStack> playerBorrowed = playerTradeModel->getItemsBorrowedToUs();
|
||||||
|
for (std::vector<ItemStack>::const_iterator it = playerBorrowed.begin(); it != playerBorrowed.end(); ++it)
|
||||||
|
{
|
||||||
|
merchantOffer -= MWBase::Environment::get().getMechanicsManager()->getBarterOffer(mPtr, getEffectiveValue(it->mBase, it->mCount), true);
|
||||||
|
}
|
||||||
|
|
||||||
|
std::vector<ItemStack> merchantBorrowed = mTradeModel->getItemsBorrowedToUs();
|
||||||
|
for (std::vector<ItemStack>::const_iterator it = merchantBorrowed.begin(); it != merchantBorrowed.end(); ++it)
|
||||||
|
{
|
||||||
|
merchantOffer += MWBase::Environment::get().getMechanicsManager()->getBarterOffer(mPtr, getEffectiveValue(it->mBase, it->mCount), false);
|
||||||
|
}
|
||||||
|
|
||||||
|
int diff = merchantOffer - mCurrentMerchantOffer;
|
||||||
|
mCurrentMerchantOffer = merchantOffer;
|
||||||
|
mCurrentBalance += diff;
|
||||||
|
updateLabels();
|
||||||
|
}
|
||||||
|
|
||||||
void TradeWindow::sellToNpc(const MWWorld::Ptr& item, int count, bool boughtItem)
|
void TradeWindow::sellToNpc(const MWWorld::Ptr& item, int count, bool boughtItem)
|
||||||
{
|
{
|
||||||
int diff = MWBase::Environment::get().getMechanicsManager()->getBarterOffer(mPtr, getEffectiveValue(item, count), boughtItem);
|
updateOffer();
|
||||||
|
|
||||||
mCurrentBalance += diff;
|
|
||||||
mCurrentMerchantOffer += diff;
|
|
||||||
|
|
||||||
updateLabels();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void TradeWindow::buyFromNpc(const MWWorld::Ptr& item, int count, bool soldItem)
|
void TradeWindow::buyFromNpc(const MWWorld::Ptr& item, int count, bool soldItem)
|
||||||
{
|
{
|
||||||
int diff = MWBase::Environment::get().getMechanicsManager()->getBarterOffer(mPtr, getEffectiveValue(item, count), !soldItem);
|
updateOffer();
|
||||||
|
|
||||||
mCurrentBalance -= diff;
|
|
||||||
mCurrentMerchantOffer -= diff;
|
|
||||||
|
|
||||||
updateLabels();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void TradeWindow::onReferenceUnavailable()
|
void TradeWindow::onReferenceUnavailable()
|
||||||
|
|
|
@ -72,6 +72,8 @@ namespace MWGui
|
||||||
void sellToNpc(const MWWorld::Ptr& item, int count, bool boughtItem); ///< only used for adjusting the gold balance
|
void sellToNpc(const MWWorld::Ptr& item, int count, bool boughtItem); ///< only used for adjusting the gold balance
|
||||||
void buyFromNpc(const MWWorld::Ptr& item, int count, bool soldItem); ///< only used for adjusting the gold balance
|
void buyFromNpc(const MWWorld::Ptr& item, int count, bool soldItem); ///< only used for adjusting the gold balance
|
||||||
|
|
||||||
|
void updateOffer();
|
||||||
|
|
||||||
void onItemSelected (int index);
|
void onItemSelected (int index);
|
||||||
void sellItem (MyGUI::Widget* sender, int count);
|
void sellItem (MyGUI::Widget* sender, int count);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue