|
|
@@ -378,7 +378,7 @@ void CQuest::getRolloverText(MetaString &ms, bool onHover) const
|
|
|
}
|
|
|
}
|
|
|
|
|
|
-void CQuest::getCompletionText(MetaString &iwText, std::vector<Component> &components, bool isCustom, const CGHeroInstance * h) const
|
|
|
+void CQuest::getCompletionText(MetaString &iwText) const
|
|
|
{
|
|
|
iwText.appendRawString(completedText);
|
|
|
switch(missionType)
|
|
|
@@ -567,11 +567,17 @@ void CGSeerHut::init(CRandomGenerator & rand)
|
|
|
seerName = VLC->generaltexth->translate(seerNameID);
|
|
|
quest->textOption = rand.nextInt(2);
|
|
|
quest->completedOption = rand.nextInt(1, 3);
|
|
|
+
|
|
|
+ configuration.canRefuse = true;
|
|
|
+ configuration.visitMode = Rewardable::EVisitMode::VISIT_ONCE;
|
|
|
+ configuration.selectMode = Rewardable::ESelectMode::SELECT_PLAYER;
|
|
|
}
|
|
|
|
|
|
void CGSeerHut::initObj(CRandomGenerator & rand)
|
|
|
{
|
|
|
init(rand);
|
|
|
+
|
|
|
+ CRewardableObject::initObj(rand);
|
|
|
|
|
|
quest->progress = CQuest::NOT_ACTIVE;
|
|
|
if(quest->missionType)
|
|
|
@@ -590,6 +596,10 @@ void CGSeerHut::initObj(CRandomGenerator & rand)
|
|
|
quest->progress = CQuest::COMPLETE;
|
|
|
quest->firstVisitText = VLC->generaltexth->seerEmpty[quest->completedOption];
|
|
|
}
|
|
|
+
|
|
|
+ quest->getCompletionText(configuration.onSelect);
|
|
|
+ for(auto & i : configuration.info)
|
|
|
+ quest->getCompletionText(i.message);
|
|
|
}
|
|
|
|
|
|
void CGSeerHut::getRolloverText(MetaString &text, bool onHover) const
|
|
|
@@ -649,44 +659,6 @@ void IQuestObject::afterAddToMapCommon(CMap * map) const
|
|
|
map->addNewQuestInstance(quest);
|
|
|
}
|
|
|
|
|
|
-void CGSeerHut::getCompletionText(MetaString &text, std::vector<Component> &components, bool isCustom, const CGHeroInstance * h) const
|
|
|
-{
|
|
|
- quest->getCompletionText (text, components, isCustom, h);
|
|
|
- switch(rewardType)
|
|
|
- {
|
|
|
- case EXPERIENCE:
|
|
|
- components.emplace_back(Component::EComponentType::EXPERIENCE, 0, static_cast<si32>(h->calculateXp(rVal)), 0);
|
|
|
- break;
|
|
|
- case MANA_POINTS:
|
|
|
- components.emplace_back(Component::EComponentType::PRIM_SKILL, 5, rVal, 0);
|
|
|
- break;
|
|
|
- case MORALE_BONUS:
|
|
|
- components.emplace_back(Component::EComponentType::MORALE, 0, rVal, 0);
|
|
|
- break;
|
|
|
- case LUCK_BONUS:
|
|
|
- components.emplace_back(Component::EComponentType::LUCK, 0, rVal, 0);
|
|
|
- break;
|
|
|
- case RESOURCES:
|
|
|
- components.emplace_back(Component::EComponentType::RESOURCE, rID, rVal, 0);
|
|
|
- break;
|
|
|
- case PRIMARY_SKILL:
|
|
|
- components.emplace_back(Component::EComponentType::PRIM_SKILL, rID, rVal, 0);
|
|
|
- break;
|
|
|
- case SECONDARY_SKILL:
|
|
|
- components.emplace_back(Component::EComponentType::SEC_SKILL, rID, rVal, 0);
|
|
|
- break;
|
|
|
- case ARTIFACT:
|
|
|
- components.emplace_back(Component::EComponentType::ARTIFACT, rID, 0, 0);
|
|
|
- break;
|
|
|
- case SPELL:
|
|
|
- components.emplace_back(Component::EComponentType::SPELL, rID, 0, 0);
|
|
|
- break;
|
|
|
- case CREATURE:
|
|
|
- components.emplace_back(Component::EComponentType::CREATURE, rID, rVal, 0);
|
|
|
- break;
|
|
|
- }
|
|
|
-}
|
|
|
-
|
|
|
void CGSeerHut::setPropertyDer (ui8 what, ui32 val)
|
|
|
{
|
|
|
switch(what)
|
|
|
@@ -699,6 +671,7 @@ void CGSeerHut::setPropertyDer (ui8 what, ui32 val)
|
|
|
|
|
|
void CGSeerHut::newTurn(CRandomGenerator & rand) const
|
|
|
{
|
|
|
+ CRewardableObject::newTurn(rand);
|
|
|
if(quest->lastDay >= 0 && quest->lastDay <= cb->getDate() - 1) //time is up
|
|
|
{
|
|
|
cb->setObjProperty (id, CGSeerHut::OBJPROP_VISITED, CQuest::COMPLETE);
|
|
|
@@ -738,12 +711,7 @@ void CGSeerHut::onHeroVisit(const CGHeroInstance * h) const
|
|
|
}
|
|
|
if(!failRequirements) // propose completion, also on first visit
|
|
|
{
|
|
|
- BlockingDialog bd (true, false);
|
|
|
- bd.player = h->getOwner();
|
|
|
-
|
|
|
- getCompletionText (bd.text, bd.components, isCustom, h);
|
|
|
-
|
|
|
- cb->showBlockingDialog (&bd);
|
|
|
+ CRewardableObject::onHeroVisit(h);
|
|
|
return;
|
|
|
}
|
|
|
}
|
|
|
@@ -788,108 +756,9 @@ int CGSeerHut::checkDirection() const
|
|
|
}
|
|
|
}
|
|
|
|
|
|
-void CGSeerHut::finishQuest(const CGHeroInstance * h, ui32 accept) const
|
|
|
-{
|
|
|
- if (accept)
|
|
|
- {
|
|
|
- switch (quest->missionType)
|
|
|
- {
|
|
|
- case CQuest::MISSION_ART:
|
|
|
- for(auto & elem : quest->m5arts)
|
|
|
- {
|
|
|
- if(h->hasArt(elem))
|
|
|
- {
|
|
|
- cb->removeArtifact(ArtifactLocation(h, h->getArtPos(elem, false)));
|
|
|
- }
|
|
|
- else
|
|
|
- {
|
|
|
- const auto * assembly = h->getAssemblyByConstituent(elem);
|
|
|
- assert(assembly);
|
|
|
- auto parts = assembly->getPartsInfo();
|
|
|
-
|
|
|
- // Remove the assembly
|
|
|
- cb->removeArtifact(ArtifactLocation(h, h->getArtPos(assembly)));
|
|
|
-
|
|
|
- // Disassemble this backpack artifact
|
|
|
- for(const auto & ci : parts)
|
|
|
- {
|
|
|
- if(ci.art->getTypeId() != elem)
|
|
|
- cb->giveHeroNewArtifact(h, ci.art->artType, ArtifactPosition::BACKPACK_START);
|
|
|
- }
|
|
|
- }
|
|
|
- }
|
|
|
- break;
|
|
|
- case CQuest::MISSION_ARMY:
|
|
|
- cb->takeCreatures(h->id, quest->m6creatures);
|
|
|
- break;
|
|
|
- case CQuest::MISSION_RESOURCES:
|
|
|
- for (int i = 0; i < 7; ++i)
|
|
|
- {
|
|
|
- cb->giveResource(h->getOwner(), static_cast<EGameResID>(i), -static_cast<int>(quest->m7resources[i]));
|
|
|
- }
|
|
|
- break;
|
|
|
- default:
|
|
|
- break;
|
|
|
- }
|
|
|
- cb->setObjProperty (id, CGSeerHut::OBJPROP_VISITED, CQuest::COMPLETE); //mission complete
|
|
|
- completeQuest(h); //make sure to remove QuestGuard at the very end
|
|
|
- }
|
|
|
-}
|
|
|
-
|
|
|
-void CGSeerHut::completeQuest (const CGHeroInstance * h) const //reward
|
|
|
+void CGSeerHut::completeQuest() const //reward
|
|
|
{
|
|
|
- switch (rewardType)
|
|
|
- {
|
|
|
- case EXPERIENCE:
|
|
|
- {
|
|
|
- TExpType expVal = h->calculateXp(rVal);
|
|
|
- cb->changePrimSkill(h, PrimarySkill::EXPERIENCE, expVal, false);
|
|
|
- break;
|
|
|
- }
|
|
|
- case MANA_POINTS:
|
|
|
- {
|
|
|
- cb->setManaPoints(h->id, h->mana+rVal);
|
|
|
- break;
|
|
|
- }
|
|
|
- case MORALE_BONUS: case LUCK_BONUS:
|
|
|
- {
|
|
|
- Bonus hb(BonusDuration::ONE_WEEK, (rewardType == 3 ? BonusType::MORALE : BonusType::LUCK),
|
|
|
- BonusSource::OBJECT, rVal, h->id.getNum(), "", -1);
|
|
|
- GiveBonus gb;
|
|
|
- gb.id = h->id.getNum();
|
|
|
- gb.bonus = hb;
|
|
|
- cb->giveHeroBonus(&gb);
|
|
|
- }
|
|
|
- break;
|
|
|
- case RESOURCES:
|
|
|
- cb->giveResource(h->getOwner(), static_cast<EGameResID>(rID), rVal);
|
|
|
- break;
|
|
|
- case PRIMARY_SKILL:
|
|
|
- cb->changePrimSkill(h, static_cast<PrimarySkill>(rID), rVal, false);
|
|
|
- break;
|
|
|
- case SECONDARY_SKILL:
|
|
|
- cb->changeSecSkill(h, SecondarySkill(rID), rVal, false);
|
|
|
- break;
|
|
|
- case ARTIFACT:
|
|
|
- cb->giveHeroNewArtifact(h, VLC->arth->objects[rID],ArtifactPosition::FIRST_AVAILABLE);
|
|
|
- break;
|
|
|
- case SPELL:
|
|
|
- {
|
|
|
- std::set<SpellID> spell;
|
|
|
- spell.insert (SpellID(rID));
|
|
|
- cb->changeSpells(h, true, spell);
|
|
|
- }
|
|
|
- break;
|
|
|
- case CREATURE:
|
|
|
- {
|
|
|
- CCreatureSet creatures;
|
|
|
- creatures.setCreature(SlotID(0), CreatureID(rID), rVal);
|
|
|
- cb->giveCreatures(this, h, creatures, false);
|
|
|
- }
|
|
|
- break;
|
|
|
- default:
|
|
|
- break;
|
|
|
- }
|
|
|
+ cb->setObjProperty(id, CGSeerHut::OBJPROP_VISITED, CQuest::COMPLETE); //mission complete
|
|
|
}
|
|
|
|
|
|
const CGHeroInstance * CGSeerHut::getHeroToKill(bool allowNull) const
|
|
|
@@ -912,7 +781,9 @@ const CGCreature * CGSeerHut::getCreatureToKill(bool allowNull) const
|
|
|
|
|
|
void CGSeerHut::blockingDialogAnswered(const CGHeroInstance *hero, ui32 answer) const
|
|
|
{
|
|
|
- finishQuest(hero, answer);
|
|
|
+ CRewardableObject::blockingDialogAnswered(hero, answer);
|
|
|
+ if(answer)
|
|
|
+ completeQuest();
|
|
|
}
|
|
|
|
|
|
void CGSeerHut::afterAddToMap(CMap* map)
|
|
|
@@ -922,7 +793,7 @@ void CGSeerHut::afterAddToMap(CMap* map)
|
|
|
|
|
|
void CGSeerHut::serializeJsonOptions(JsonSerializeFormat & handler)
|
|
|
{
|
|
|
- static const std::map<ERewardType, std::string> REWARD_MAP =
|
|
|
+ /*static const std::map<ERewardType, std::string> REWARD_MAP =
|
|
|
{
|
|
|
{NOTHING, ""},
|
|
|
{EXPERIENCE, "experience"},
|
|
|
@@ -949,15 +820,16 @@ void CGSeerHut::serializeJsonOptions(JsonSerializeFormat & handler)
|
|
|
{"artifact", ARTIFACT},
|
|
|
{"spell", SPELL},
|
|
|
{"creature", CREATURE}
|
|
|
- };
|
|
|
+ };*/
|
|
|
|
|
|
//quest and reward
|
|
|
quest->serializeJson(handler, "quest");
|
|
|
+ CRewardableObject::serializeJsonOptions(handler);
|
|
|
|
|
|
//only one reward is supported
|
|
|
//todo: full reward format support after CRewardInfo integration
|
|
|
|
|
|
- auto s = handler.enterStruct("reward");
|
|
|
+ /*auto s = handler.enterStruct("reward");
|
|
|
std::string fullIdentifier;
|
|
|
std::string metaTypeName;
|
|
|
std::string scope;
|
|
|
@@ -1079,7 +951,7 @@ void CGSeerHut::serializeJsonOptions(JsonSerializeFormat & handler)
|
|
|
}
|
|
|
}
|
|
|
handler.serializeInt(fullIdentifier, rVal);
|
|
|
- }
|
|
|
+ }*/
|
|
|
}
|
|
|
|
|
|
void CGQuestGuard::init(CRandomGenerator & rand)
|
|
|
@@ -1087,9 +959,13 @@ void CGQuestGuard::init(CRandomGenerator & rand)
|
|
|
blockVisit = true;
|
|
|
quest->textOption = rand.nextInt(3, 5);
|
|
|
quest->completedOption = rand.nextInt(4, 5);
|
|
|
+
|
|
|
+ configuration.info.push_back({});
|
|
|
+ configuration.info.back().visitType = Rewardable::EEventType::EVENT_FIRST_VISIT;
|
|
|
+ configuration.canRefuse = true;
|
|
|
}
|
|
|
|
|
|
-void CGQuestGuard::completeQuest(const CGHeroInstance *h) const
|
|
|
+void CGQuestGuard::completeQuest() const
|
|
|
{
|
|
|
cb->removeObject(this);
|
|
|
}
|