| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112 | 
							- /*
 
-  * CTransferResources.cpp, part of VCMI engine
 
-  *
 
-  * Authors: listed in file AUTHORS in main folder
 
-  *
 
-  * License: GNU General Public License v2.0 or later
 
-  * Full text of license available in license.txt file, in main folder
 
-  *
 
-  */
 
- #include "StdInc.h"
 
- #include "CTransferResources.h"
 
- #include "../../gui/CGuiHandler.h"
 
- #include "../../gui/Shortcut.h"
 
- #include "../../widgets/Buttons.h"
 
- #include "../../widgets/TextControls.h"
 
- #include "../../CGameInfo.h"
 
- #include "../../CPlayerInterface.h"
 
- #include "../../../CCallback.h"
 
- #include "../../../lib/texts/CGeneralTextHandler.h"
 
- #include "../../../lib/texts/MetaString.h"
 
- CTransferResources::CTransferResources(const IMarket * market, const CGHeroInstance * hero)
 
- 	: CMarketBase(market, hero)
 
- 	, CResourcesSelling([this](const std::shared_ptr<CTradeableItem> & heroSlot){CTransferResources::onSlotClickPressed(heroSlot, bidTradePanel);})
 
- 	, CMarketSlider([this](int newVal){CMarketSlider::onOfferSliderMoved(newVal);})
 
- 	, CMarketTraderText(Point(28, 48))
 
- {
 
- 	OBJECT_CONSTRUCTION;
 
- 	labels.emplace_back(std::make_shared<CLabel>(titlePos.x, titlePos.y, FONT_BIG, ETextAlignment::CENTER, Colors::YELLOW, CGI->generaltexth->allTexts[158]));
 
- 	labels.emplace_back(std::make_shared<CLabel>(445, 56, FONT_SMALL, ETextAlignment::CENTER, Colors::WHITE, CGI->generaltexth->allTexts[169]));
 
- 	deal = std::make_shared<CButton>(dealButtonPosWithSlider, AnimationPath::builtin("TPMRKB.DEF"),
 
- 		CGI->generaltexth->zelp[595], [this](){CTransferResources::makeDeal();}, EShortcut::MARKET_DEAL);
 
- 	// Player's resources
 
- 	assert(bidTradePanel);
 
- 	bidTradePanel->moveTo(pos.topLeft() + Point(40, 183));
 
- 	// Players panel
 
- 	offerTradePanel = std::make_shared<PlayersPanel>([this](const std::shared_ptr<CTradeableItem> & heroSlot)
 
- 		{
 
- 			CTransferResources::onSlotClickPressed(heroSlot, offerTradePanel);
 
- 		});
 
- 	offerTradePanel->moveTo(pos.topLeft() + Point(333, 84));
 
- 	CMarketBase::update();
 
- 	CTransferResources::deselect();
 
- }
 
- void CTransferResources::deselect()
 
- {
 
- 	CMarketBase::deselect();
 
- 	CMarketSlider::deselect();
 
- 	CMarketTraderText::deselect();
 
- }
 
- void CTransferResources::makeDeal()
 
- {
 
- 	if(auto toTrade = offerSlider->getValue(); toTrade != 0)
 
- 	{
 
- 		LOCPLINT->cb->trade(market, EMarketMode::RESOURCE_PLAYER, GameResID(bidTradePanel->getSelectedItemId()),
 
- 			PlayerColor(offerTradePanel->getSelectedItemId()), toTrade, hero);
 
- 		CMarketTraderText::makeDeal();
 
- 		deselect();
 
- 	}
 
- }
 
- CMarketBase::MarketShowcasesParams CTransferResources::getShowcasesParams() const
 
- {
 
- 	if(bidTradePanel->isHighlighted() && offerTradePanel->isHighlighted())
 
- 		return MarketShowcasesParams
 
- 		{
 
- 			ShowcaseParams {std::to_string(offerSlider->getValue()), bidTradePanel->getSelectedItemId()},
 
- 			ShowcaseParams {CGI->generaltexth->capColors[offerTradePanel->getSelectedItemId()], offerTradePanel->getSelectedItemId()}
 
- 		};
 
- 	else
 
- 		return MarketShowcasesParams {std::nullopt, std::nullopt};
 
- }
 
- void CTransferResources::highlightingChanged()
 
- {
 
- 	if(bidTradePanel->isHighlighted() && offerTradePanel->isHighlighted())
 
- 	{
 
- 		offerSlider->setAmount(LOCPLINT->cb->getResourceAmount(GameResID(bidTradePanel->getSelectedItemId())));
 
- 		offerSlider->scrollTo(0);
 
- 		offerSlider->block(false);
 
- 		maxAmount->block(false);
 
- 		deal->block(!LOCPLINT->makingTurn);
 
- 	}
 
- 	CMarketBase::highlightingChanged();
 
- 	CMarketTraderText::highlightingChanged();
 
- }
 
- std::string CTransferResources::getTraderText()
 
- {
 
- 	if(bidTradePanel->isHighlighted() && offerTradePanel->isHighlighted())
 
- 	{
 
- 		MetaString message = MetaString::createFromTextID("core.genrltxt.165");
 
- 		message.replaceName(GameResID(bidTradePanel->getSelectedItemId()));
 
- 		message.replaceName(PlayerColor(offerTradePanel->getSelectedItemId()));
 
- 		return message.toString();
 
- 	}
 
- 	else
 
- 	{
 
- 		return madeTransaction ? CGI->generaltexth->allTexts[166] : CGI->generaltexth->allTexts[167];
 
- 	}
 
- }
 
 
  |