Refactor of hideout skill gains from area completion
This commit is contained in:
parent
bfec553768
commit
f5eb96ed48
@ -118,86 +118,46 @@ export class HideoutHelper
|
|||||||
return (productive as Production).Progress !== undefined || (productive as Production).RecipeId !== undefined;
|
return (productive as Production).Progress !== undefined || (productive as Production).RecipeId !== undefined;
|
||||||
}
|
}
|
||||||
|
|
||||||
// BALIST0N, I got bad news for you
|
/**
|
||||||
// we do need to implement these after all
|
* Apply bonus to player profile given after completing hideout upgrades
|
||||||
// ...
|
* @param pmcData Profile to add bonus to
|
||||||
// with that I mean manual implementation
|
* @param bonus Bonus to add to profile
|
||||||
// RIP, GL whoever is going to do this
|
*/
|
||||||
public applyPlayerUpgradesBonuses(pmcData: IPmcData, bonus: StageBonus): void
|
public applyPlayerUpgradesBonuses(pmcData: IPmcData, bonus: StageBonus): void
|
||||||
{
|
{
|
||||||
|
// Handle additional changes some bonuses need before being added
|
||||||
switch (bonus.type)
|
switch (bonus.type)
|
||||||
{
|
{
|
||||||
case "StashSize":
|
case "StashSize": {
|
||||||
// TODO: bonus should only have type/templateId
|
// Find stash item and adjust tpl to new tpl from bonus
|
||||||
for (const item in pmcData.Inventory.items)
|
const stashItem = pmcData.Inventory.items.find(x => x._id === pmcData.Inventory.stash);
|
||||||
|
if (!stashItem)
|
||||||
{
|
{
|
||||||
if (pmcData.Inventory.items[item]._id === pmcData.Inventory.stash)
|
this.logger.warning(`Unable to apply StashSize bonus, stash with id: ${pmcData.Inventory.stash} not found`);
|
||||||
{
|
|
||||||
pmcData.Inventory.items[item]._tpl = bonus.templateId;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
stashItem._tpl = bonus.templateId;
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
case "MaximumEnergyReserve":
|
case "MaximumEnergyReserve":
|
||||||
pmcData.Health.Energy.Maximum += 10;
|
// Amend max energy in profile
|
||||||
|
pmcData.Health.Energy.Maximum += bonus.value;
|
||||||
break;
|
break;
|
||||||
case "EnergyRegeneration":
|
|
||||||
case "HydrationRegeneration":
|
|
||||||
case "HealthRegeneration":
|
|
||||||
case "DebuffEndDelay":
|
|
||||||
case "QuestMoneyReward":
|
|
||||||
case "ExperienceRate":
|
|
||||||
case "SkillGroupLevelingBoost":
|
|
||||||
this.applySkillXPBoost(pmcData, bonus);
|
|
||||||
break;
|
|
||||||
case "ScavCooldownTimer":
|
|
||||||
case "InsuranceReturnTime":
|
|
||||||
case "RagfairCommission":
|
|
||||||
case "FuelConsumption":
|
|
||||||
// These skill is being applied automatically on the RagfairController, InsuranceController, ProfileController, HideoutController
|
|
||||||
// ScavCooldownTimer, InsuranceReturnTime, RagfairCommission, FuelConsumption
|
|
||||||
break;
|
|
||||||
case "AdditionalSlots":
|
|
||||||
// Some of these are also implemented on the HideoutController
|
|
||||||
break;
|
|
||||||
case "UnlockWeaponModification":
|
|
||||||
case "RepairArmorBonus":
|
|
||||||
case "RepairWeaponBonus":
|
|
||||||
case "UnlockArmorRepair":
|
|
||||||
case "UnlockWeaponRepair":
|
|
||||||
case "TextBonus":
|
case "TextBonus":
|
||||||
// TODO: remove properties, only needs id/icon/type
|
//Delete values before they're added to profile
|
||||||
|
delete bonus.value;
|
||||||
|
delete bonus.passive;
|
||||||
|
delete bonus.production;
|
||||||
|
delete bonus.visible;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Add bonus to player bonuses array in profile
|
||||||
|
// EnergyRegeneration, HealthRegeneration, RagfairCommission, ScavCooldownTimer, SkillGroupLevelingBoost, ExperienceRate, QuestMoneyReward etc
|
||||||
|
this.logger.debug(`Adding bonus: ${bonus.type} to profile, value: ${bonus.value}`);
|
||||||
pmcData.Bonuses.push(bonus);
|
pmcData.Bonuses.push(bonus);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* TODO:
|
|
||||||
* After looking at the skills there doesnt seem to be a configuration per skill to boost
|
|
||||||
* the XP gain PER skill. I THINK you should be able to put the variable "SkillProgress" (just like health has it)
|
|
||||||
* and be able to tune the skill gain PER skill, but I havent tested it and Im not sure!
|
|
||||||
* @param pmcData
|
|
||||||
* @param bonus
|
|
||||||
*/
|
|
||||||
protected applySkillXPBoost(pmcData: IPmcData, bonus: StageBonus): void
|
|
||||||
{
|
|
||||||
const skillGroupType = bonus.skillType;
|
|
||||||
if (skillGroupType)
|
|
||||||
{
|
|
||||||
switch (skillGroupType)
|
|
||||||
{
|
|
||||||
case "Physical":
|
|
||||||
case "Mental":
|
|
||||||
case "Combat":
|
|
||||||
case "Practical":
|
|
||||||
case "Special":
|
|
||||||
default:
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Process a players hideout, update areas that use resources + increment production timers
|
* Process a players hideout, update areas that use resources + increment production timers
|
||||||
* @param sessionID Session id
|
* @param sessionID Session id
|
||||||
|
Loading…
Reference in New Issue
Block a user