|  | @@ -31,15 +31,13 @@
 | 
	
		
			
				|  |  |   *
 | 
	
		
			
				|  |  |   */
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -CArtPlace::CArtPlace(Point position, const CArtifactInstance * Art):
 | 
	
		
			
				|  |  | -	locked(false), picked(false), marked(false), ourArt(Art)
 | 
	
		
			
				|  |  | +CHeroArtPlace::CHeroArtPlace(Point position, const CArtifactInstance * Art): CArtPlace(position, Art),
 | 
	
		
			
				|  |  | +	locked(false), picked(false), marked(false)
 | 
	
		
			
				|  |  |  {
 | 
	
		
			
				|  |  | -	pos += position;
 | 
	
		
			
				|  |  | -	pos.w = pos.h = 44;
 | 
	
		
			
				|  |  |  	createImage();
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -void CArtPlace::createImage()
 | 
	
		
			
				|  |  | +void CHeroArtPlace::createImage()
 | 
	
		
			
				|  |  |  {
 | 
	
		
			
				|  |  |  	OBJ_CONSTRUCTION_CAPTURING_ALL;
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -57,7 +55,7 @@ void CArtPlace::createImage()
 | 
	
		
			
				|  |  |  	selection->disable();
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -void CArtPlace::lockSlot(bool on)
 | 
	
		
			
				|  |  | +void CHeroArtPlace::lockSlot(bool on)
 | 
	
		
			
				|  |  |  {
 | 
	
		
			
				|  |  |  	if (locked == on)
 | 
	
		
			
				|  |  |  		return;
 | 
	
	
		
			
				|  | @@ -70,7 +68,7 @@ void CArtPlace::lockSlot(bool on)
 | 
	
		
			
				|  |  |  		image->setFrame(ourArt->artType->iconIndex);
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -void CArtPlace::pickSlot(bool on)
 | 
	
		
			
				|  |  | +void CHeroArtPlace::pickSlot(bool on)
 | 
	
		
			
				|  |  |  {
 | 
	
		
			
				|  |  |  	if (picked == on)
 | 
	
		
			
				|  |  |  		return;
 | 
	
	
		
			
				|  | @@ -82,7 +80,7 @@ void CArtPlace::pickSlot(bool on)
 | 
	
		
			
				|  |  |  		image->enable();
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -void CArtPlace::selectSlot(bool on)
 | 
	
		
			
				|  |  | +void CHeroArtPlace::selectSlot(bool on)
 | 
	
		
			
				|  |  |  {
 | 
	
		
			
				|  |  |  	if (marked == on)
 | 
	
		
			
				|  |  |  		return;
 | 
	
	
		
			
				|  | @@ -94,7 +92,7 @@ void CArtPlace::selectSlot(bool on)
 | 
	
		
			
				|  |  |  		selection->disable();
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -void CArtPlace::clickLeft(tribool down, bool previousState)
 | 
	
		
			
				|  |  | +void CHeroArtPlace::clickLeft(tribool down, bool previousState)
 | 
	
		
			
				|  |  |  {
 | 
	
		
			
				|  |  |  	//LRClickableAreaWTextComp::clickLeft(down);
 | 
	
		
			
				|  |  |  	bool inBackpack = slotID >= GameConstants::BACKPACK_START,
 | 
	
	
		
			
				|  | @@ -211,7 +209,7 @@ void CArtPlace::clickLeft(tribool down, bool previousState)
 | 
	
		
			
				|  |  |  	}
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -bool CArtPlace::askToAssemble(const CArtifactInstance *art, ArtifactPosition slot,
 | 
	
		
			
				|  |  | +bool CHeroArtPlace::askToAssemble(const CArtifactInstance *art, ArtifactPosition slot,
 | 
	
		
			
				|  |  |                                const CGHeroInstance *hero)
 | 
	
		
			
				|  |  |  {
 | 
	
		
			
				|  |  |  	assert(art != nullptr);
 | 
	
	
		
			
				|  | @@ -239,7 +237,7 @@ bool CArtPlace::askToAssemble(const CArtifactInstance *art, ArtifactPosition slo
 | 
	
		
			
				|  |  |  	return false;
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -void CArtPlace::clickRight(tribool down, bool previousState)
 | 
	
		
			
				|  |  | +void CHeroArtPlace::clickRight(tribool down, bool previousState)
 | 
	
		
			
				|  |  |  {
 | 
	
		
			
				|  |  |  	if(down && ourArt && !locked && text.size() && !picked)  //if there is no description or it's a lock, do nothing ;]
 | 
	
		
			
				|  |  |  	{
 | 
	
	
		
			
				|  | @@ -277,7 +275,7 @@ void CArtPlace::clickRight(tribool down, bool previousState)
 | 
	
		
			
				|  |  |  /**
 | 
	
		
			
				|  |  |   * Selects artifact slot so that the containing artifact looks like it's picked up.
 | 
	
		
			
				|  |  |   */
 | 
	
		
			
				|  |  | -void CArtPlace::select ()
 | 
	
		
			
				|  |  | +void CHeroArtPlace::select ()
 | 
	
		
			
				|  |  |  {
 | 
	
		
			
				|  |  |  	if (locked)
 | 
	
		
			
				|  |  |  		return;
 | 
	
	
		
			
				|  | @@ -288,7 +286,7 @@ void CArtPlace::select ()
 | 
	
		
			
				|  |  |  	{
 | 
	
		
			
				|  |  |  		for(int i = 0; i < GameConstants::BACKPACK_START; i++)
 | 
	
		
			
				|  |  |  		{
 | 
	
		
			
				|  |  | -			CArtPlace * ap = ourOwner->getArtPlace(i);
 | 
	
		
			
				|  |  | +			CHeroArtPlace * ap = ourOwner->getArtPlace(i);
 | 
	
		
			
				|  |  |  			if(nullptr != ap)//getArtPlace may return null
 | 
	
		
			
				|  |  |  				ap->pickSlot(ourArt->isPart(ap->ourArt));
 | 
	
		
			
				|  |  |  		}
 | 
	
	
		
			
				|  | @@ -308,7 +306,7 @@ void CArtPlace::select ()
 | 
	
		
			
				|  |  |  /**
 | 
	
		
			
				|  |  |   * Deselects the artifact slot.
 | 
	
		
			
				|  |  |   */
 | 
	
		
			
				|  |  | -void CArtPlace::deselect ()
 | 
	
		
			
				|  |  | +void CHeroArtPlace::deselect ()
 | 
	
		
			
				|  |  |  {
 | 
	
		
			
				|  |  |  	pickSlot(false);
 | 
	
		
			
				|  |  |  	if(ourArt && ourArt->canBeDisassembled()) //combined art returned to its slot -> restore locks
 | 
	
	
		
			
				|  | @@ -333,7 +331,7 @@ void CArtPlace::deselect ()
 | 
	
		
			
				|  |  |  	ourOwner->safeRedraw();
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -void CArtPlace::showAll(SDL_Surface * to)
 | 
	
		
			
				|  |  | +void CHeroArtPlace::showAll(SDL_Surface * to)
 | 
	
		
			
				|  |  |  {
 | 
	
		
			
				|  |  |  	if (ourArt && !picked && ourArt == ourOwner->curHero->getArt(slotID, false)) //last condition is needed for disassembling -> artifact may be gone, but we don't know yet TODO: real, nice solution
 | 
	
		
			
				|  |  |  	{
 | 
	
	
		
			
				|  | @@ -358,7 +356,7 @@ void CArtPlace::showAll(SDL_Surface * to)
 | 
	
		
			
				|  |  |  	}
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -bool CArtPlace::fitsHere(const CArtifactInstance * art) const
 | 
	
		
			
				|  |  | +bool CHeroArtPlace::fitsHere(const CArtifactInstance * art) const
 | 
	
		
			
				|  |  |  {
 | 
	
		
			
				|  |  |  	// You can place 'no artifact' anywhere.
 | 
	
		
			
				|  |  |  	if(!art)
 | 
	
	
		
			
				|  | @@ -371,12 +369,12 @@ bool CArtPlace::fitsHere(const CArtifactInstance * art) const
 | 
	
		
			
				|  |  |  	return art->canBePutAt(ArtifactLocation(ourOwner->curHero, slotID), true);
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -void CArtPlace::setMeAsDest(bool backpackAsVoid /*= true*/)
 | 
	
		
			
				|  |  | +void CHeroArtPlace::setMeAsDest(bool backpackAsVoid /*= true*/)
 | 
	
		
			
				|  |  |  {
 | 
	
		
			
				|  |  |  	ourOwner->commonInfo->dst.setTo(this, backpackAsVoid);
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -void CArtPlace::setArtifact(const CArtifactInstance *art)
 | 
	
		
			
				|  |  | +void CHeroArtPlace::setArtifact(const CArtifactInstance *art)
 | 
	
		
			
				|  |  |  {
 | 
	
		
			
				|  |  |  	baseType = -1; //by default we don't store any component
 | 
	
		
			
				|  |  |  	ourArt = art;
 | 
	
	
		
			
				|  | @@ -544,7 +542,7 @@ void CArtifactsOfHero::unmarkLocalSlots(bool withRedraw /*= true*/)
 | 
	
		
			
				|  |  |  {
 | 
	
		
			
				|  |  |  	for(auto p : artWorn)
 | 
	
		
			
				|  |  |  		p.second->selectSlot(false);
 | 
	
		
			
				|  |  | -	for(CArtPlace *place : backpack)
 | 
	
		
			
				|  |  | +	for(CHeroArtPlace *place : backpack)
 | 
	
		
			
				|  |  |  		place->selectSlot(false);
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	if(withRedraw)
 | 
	
	
		
			
				|  | @@ -554,7 +552,7 @@ void CArtifactsOfHero::unmarkLocalSlots(bool withRedraw /*= true*/)
 | 
	
		
			
				|  |  |  /**
 | 
	
		
			
				|  |  |   * Assigns an artifacts to an artifact place depending on it's new slot ID.
 | 
	
		
			
				|  |  |   */
 | 
	
		
			
				|  |  | -void CArtifactsOfHero::setSlotData(CArtPlace* artPlace, ArtifactPosition slotID)
 | 
	
		
			
				|  |  | +void CArtifactsOfHero::setSlotData(CHeroArtPlace* artPlace, ArtifactPosition slotID)
 | 
	
		
			
				|  |  |  {
 | 
	
		
			
				|  |  |  	if(!artPlace && slotID >= GameConstants::BACKPACK_START) //spurious call from artifactMoved in attempt to update hidden backpack slot
 | 
	
		
			
				|  |  |  	{
 | 
	
	
		
			
				|  | @@ -576,14 +574,14 @@ void CArtifactsOfHero::setSlotData(CArtPlace* artPlace, ArtifactPosition slotID)
 | 
	
		
			
				|  |  |  /**
 | 
	
		
			
				|  |  |   * Makes given artifact slot appear as empty with a certain slot ID.
 | 
	
		
			
				|  |  |   */
 | 
	
		
			
				|  |  | -void CArtifactsOfHero::eraseSlotData (CArtPlace* artPlace, ArtifactPosition slotID)
 | 
	
		
			
				|  |  | +void CArtifactsOfHero::eraseSlotData (CHeroArtPlace* artPlace, ArtifactPosition slotID)
 | 
	
		
			
				|  |  |  {
 | 
	
		
			
				|  |  |  	artPlace->pickSlot(false);
 | 
	
		
			
				|  |  |  	artPlace->slotID = slotID;
 | 
	
		
			
				|  |  |  	artPlace->setArtifact(nullptr);
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -CArtifactsOfHero::CArtifactsOfHero(std::map<ArtifactPosition, CArtPlace *> ArtWorn, std::vector<CArtPlace *> Backpack,
 | 
	
		
			
				|  |  | +CArtifactsOfHero::CArtifactsOfHero(std::map<ArtifactPosition, CHeroArtPlace *> ArtWorn, std::vector<CHeroArtPlace *> Backpack,
 | 
	
		
			
				|  |  |  	CButton *leftScroll, CButton *rightScroll, bool createCommonPart):
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	curHero(nullptr),
 | 
	
	
		
			
				|  | @@ -642,7 +640,7 @@ CArtifactsOfHero::CArtifactsOfHero(const Point& position, bool createCommonPart
 | 
	
		
			
				|  |  |  	// Create slots for worn artifacts.
 | 
	
		
			
				|  |  |  	for (size_t g = 0; g < GameConstants::BACKPACK_START ; g++)
 | 
	
		
			
				|  |  |  	{
 | 
	
		
			
				|  |  | -		artWorn[ArtifactPosition(g)] = new CArtPlace(slotPos[g]);
 | 
	
		
			
				|  |  | +		artWorn[ArtifactPosition(g)] = new CHeroArtPlace(slotPos[g]);
 | 
	
		
			
				|  |  |  		artWorn[ArtifactPosition(g)]->ourOwner = this;
 | 
	
		
			
				|  |  |  		eraseSlotData(artWorn[ArtifactPosition(g)], ArtifactPosition(g));
 | 
	
		
			
				|  |  |  	}
 | 
	
	
		
			
				|  | @@ -650,7 +648,7 @@ CArtifactsOfHero::CArtifactsOfHero(const Point& position, bool createCommonPart
 | 
	
		
			
				|  |  |  	// Create slots for the backpack.
 | 
	
		
			
				|  |  |  	for(size_t s=0; s<5; ++s)
 | 
	
		
			
				|  |  |  	{
 | 
	
		
			
				|  |  | -		auto add = new CArtPlace(Point(403 + 46 * s, 365));
 | 
	
		
			
				|  |  | +		auto add = new CHeroArtPlace(Point(403 + 46 * s, 365));
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  		add->ourOwner = this;
 | 
	
		
			
				|  |  |  		eraseSlotData(add, ArtifactPosition(GameConstants::BACKPACK_START + s));
 | 
	
	
		
			
				|  | @@ -750,7 +748,7 @@ void CArtifactsOfHero::artifactMoved(const ArtifactLocation &src, const Artifact
 | 
	
		
			
				|  |  |  		assert(dst.slot >= GameConstants::BACKPACK_START);
 | 
	
		
			
				|  |  |  		commonInfo->reset();
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -		CArtPlace *ap = nullptr;
 | 
	
		
			
				|  |  | +		CHeroArtPlace *ap = nullptr;
 | 
	
		
			
				|  |  |  		for(CArtifactsOfHero *aoh : commonInfo->participants)
 | 
	
		
			
				|  |  |  		{
 | 
	
		
			
				|  |  |  			if(dst.isHolder(aoh->curHero))
 | 
	
	
		
			
				|  | @@ -815,7 +813,7 @@ void CArtifactsOfHero::artifactRemoved(const ArtifactLocation &al)
 | 
	
		
			
				|  |  |  	}
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -CArtPlace * CArtifactsOfHero::getArtPlace(int slot)
 | 
	
		
			
				|  |  | +CHeroArtPlace * CArtifactsOfHero::getArtPlace(int slot)
 | 
	
		
			
				|  |  |  {
 | 
	
		
			
				|  |  |  	if(slot < GameConstants::BACKPACK_START)
 | 
	
		
			
				|  |  |  	{
 | 
	
	
		
			
				|  | @@ -829,7 +827,7 @@ CArtPlace * CArtifactsOfHero::getArtPlace(int slot)
 | 
	
		
			
				|  |  |  	}
 | 
	
		
			
				|  |  |  	else
 | 
	
		
			
				|  |  |  	{
 | 
	
		
			
				|  |  | -		for(CArtPlace *ap : backpack)
 | 
	
		
			
				|  |  | +		for(CHeroArtPlace *ap : backpack)
 | 
	
		
			
				|  |  |  			if(ap->slotID == slot)
 | 
	
		
			
				|  |  |  				return ap;
 | 
	
		
			
				|  |  |  		return nullptr;
 | 
	
	
		
			
				|  | @@ -919,7 +917,7 @@ CArtifactsOfHero::SCommonPart::Artpos::Artpos()
 | 
	
		
			
				|  |  |  	clear();
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -void CArtifactsOfHero::SCommonPart::Artpos::setTo(const CArtPlace *place, bool dontTakeBackpack)
 | 
	
		
			
				|  |  | +void CArtifactsOfHero::SCommonPart::Artpos::setTo(const CHeroArtPlace *place, bool dontTakeBackpack)
 | 
	
		
			
				|  |  |  {
 | 
	
		
			
				|  |  |  	slotID = place->slotID;
 | 
	
		
			
				|  |  |  	AOH = place->ourOwner;
 | 
	
	
		
			
				|  | @@ -945,3 +943,85 @@ bool CArtifactsOfHero::SCommonPart::Artpos::valid()
 | 
	
		
			
				|  |  |  	assert(AOH && art);
 | 
	
		
			
				|  |  |  	return art == AOH->curHero->getArt(slotID);
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +CArtPlace::CArtPlace(Point position, const CArtifactInstance * Art) : ourArt(Art)
 | 
	
		
			
				|  |  | +{
 | 
	
		
			
				|  |  | +	pos += position;
 | 
	
		
			
				|  |  | +	pos.w = pos.h = 44;
 | 
	
		
			
				|  |  | +}
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +void CArtPlace::clickLeft(tribool down, bool previousState)
 | 
	
		
			
				|  |  | +{
 | 
	
		
			
				|  |  | +	LRClickableAreaWTextComp::clickLeft(down, previousState);
 | 
	
		
			
				|  |  | +}
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +void CArtPlace::clickRight(tribool down, bool previousState)
 | 
	
		
			
				|  |  | +{
 | 
	
		
			
				|  |  | +	LRClickableAreaWTextComp::clickRight(down, previousState);
 | 
	
		
			
				|  |  | +}
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +CCommanderArtPlace::CCommanderArtPlace(Point position, const CArtifactInstance * Art) : CArtPlace(position, Art)
 | 
	
		
			
				|  |  | +{
 | 
	
		
			
				|  |  | +	createImage();
 | 
	
		
			
				|  |  | +	setArtifact(Art);
 | 
	
		
			
				|  |  | +}
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +void CCommanderArtPlace::clickLeft(tribool down, bool previousState)
 | 
	
		
			
				|  |  | +{
 | 
	
		
			
				|  |  | +	if(ourArt && text.size())
 | 
	
		
			
				|  |  | +		CArtPlace::clickLeft(down, previousState);	
 | 
	
		
			
				|  |  | +}
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +void CCommanderArtPlace::clickRight(tribool down, bool previousState)
 | 
	
		
			
				|  |  | +{
 | 
	
		
			
				|  |  | +	if (down && ourArt && text.size())
 | 
	
		
			
				|  |  | +		CArtPlace::clickRight(down, previousState);
 | 
	
		
			
				|  |  | +}
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +void CCommanderArtPlace::createImage()
 | 
	
		
			
				|  |  | +{
 | 
	
		
			
				|  |  | +	OBJ_CONSTRUCTION_CAPTURING_ALL;
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	int graphic = 0;
 | 
	
		
			
				|  |  | +	if (ourArt)
 | 
	
		
			
				|  |  | +		graphic = ourArt->artType->iconIndex;
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	image = new CAnimImage("artifact", graphic);
 | 
	
		
			
				|  |  | +	if (!ourArt)
 | 
	
		
			
				|  |  | +		image->disable();
 | 
	
		
			
				|  |  | +}
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +void CCommanderArtPlace::setArtifact(const CArtifactInstance * art)
 | 
	
		
			
				|  |  | +{
 | 
	
		
			
				|  |  | +	baseType = -1; //by default we don't store any component
 | 
	
		
			
				|  |  | +	ourArt = art;
 | 
	
		
			
				|  |  | +	if (!art)
 | 
	
		
			
				|  |  | +	{
 | 
	
		
			
				|  |  | +		image->disable();
 | 
	
		
			
				|  |  | +		text = std::string();
 | 
	
		
			
				|  |  | +		return;
 | 
	
		
			
				|  |  | +	}
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	image->enable();
 | 
	
		
			
				|  |  | +	image->setFrame(art->artType->iconIndex);
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	text = art->getEffectiveDescription();
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	if (art->artType->id == ArtifactID::SPELL_SCROLL)
 | 
	
		
			
				|  |  | +	{
 | 
	
		
			
				|  |  | +		int spellID = art->getGivenSpellID();
 | 
	
		
			
				|  |  | +		if (spellID >= 0)
 | 
	
		
			
				|  |  | +		{
 | 
	
		
			
				|  |  | +			//add spell component info (used to provide a pic in r-click popup)
 | 
	
		
			
				|  |  | +			baseType = CComponent::spell;
 | 
	
		
			
				|  |  | +			type = spellID;
 | 
	
		
			
				|  |  | +			bonusValue = 0;
 | 
	
		
			
				|  |  | +		}
 | 
	
		
			
				|  |  | +	}
 | 
	
		
			
				|  |  | +	else
 | 
	
		
			
				|  |  | +	{
 | 
	
		
			
				|  |  | +		baseType = CComponent::artifact;
 | 
	
		
			
				|  |  | +		type = art->artType->id;
 | 
	
		
			
				|  |  | +		bonusValue = 0;
 | 
	
		
			
				|  |  | +	}
 | 
	
		
			
				|  |  | +}
 |