Update air filters to correctly calculate time they were being used since last hideout update tick
This commit is contained in:
parent
9b45d40c2b
commit
099e2cd6f3
@ -32,6 +32,7 @@ import { TimeUtil } from "@spt-aki/utils/TimeUtil";
|
|||||||
export class HideoutHelper
|
export class HideoutHelper
|
||||||
{
|
{
|
||||||
public static bitcoinFarm = "5d5c205bd582a50d042a3c0e";
|
public static bitcoinFarm = "5d5c205bd582a50d042a3c0e";
|
||||||
|
public static bitcoinProductionId = "5d5c205bd582a50d042a3c0e";
|
||||||
public static waterCollector = "5d5589c1f934db045e6c5492";
|
public static waterCollector = "5d5589c1f934db045e6c5492";
|
||||||
public static bitcoin = "59faff1d86f7746c51718c9c";
|
public static bitcoin = "59faff1d86f7746c51718c9c";
|
||||||
public static expeditionaryFuelTank = "5d1b371186f774253763a656";
|
public static expeditionaryFuelTank = "5d1b371186f774253763a656";
|
||||||
@ -400,7 +401,7 @@ export class HideoutHelper
|
|||||||
case HideoutAreas.AIR_FILTERING:
|
case HideoutAreas.AIR_FILTERING:
|
||||||
if (hideoutProperties.isGeneratorOn)
|
if (hideoutProperties.isGeneratorOn)
|
||||||
{
|
{
|
||||||
this.updateAirFilters(area, pmcData);
|
this.updateAirFilters(area, pmcData, hideoutProperties.isGeneratorOn);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -677,7 +678,7 @@ export class HideoutHelper
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
protected updateAirFilters(airFilterArea: HideoutArea, pmcData: IPmcData): void
|
protected updateAirFilters(airFilterArea: HideoutArea, pmcData: IPmcData, isGeneratorOn: boolean): void
|
||||||
{
|
{
|
||||||
// 300 resources last 20 hrs, 300/20/60/60 = 0.00416
|
// 300 resources last 20 hrs, 300/20/60/60 = 0.00416
|
||||||
/* 10-10-2021 from WIKI (https://escapefromtarkov.fandom.com/wiki/FP-100_filter_absorber)
|
/* 10-10-2021 from WIKI (https://escapefromtarkov.fandom.com/wiki/FP-100_filter_absorber)
|
||||||
@ -685,7 +686,8 @@ export class HideoutHelper
|
|||||||
300/17.64694/60/60 = 0.004722
|
300/17.64694/60/60 = 0.004722
|
||||||
*/
|
*/
|
||||||
let filterDrainRate = this.databaseServer.getTables().hideout.settings.airFilterUnitFlowRate
|
let filterDrainRate = this.databaseServer.getTables().hideout.settings.airFilterUnitFlowRate
|
||||||
* this.hideoutConfig.runIntervalSeconds;
|
* this.getTimeElapsedSinceLastServerTick(pmcData, isGeneratorOn);
|
||||||
|
|
||||||
// Hideout management resource consumption bonus:
|
// Hideout management resource consumption bonus:
|
||||||
const hideoutManagementConsumptionBonus = 1.0 - this.getHideoutManagementConsumptionBonus(pmcData);
|
const hideoutManagementConsumptionBonus = 1.0 - this.getHideoutManagementConsumptionBonus(pmcData);
|
||||||
filterDrainRate *= hideoutManagementConsumptionBonus;
|
filterDrainRate *= hideoutManagementConsumptionBonus;
|
||||||
@ -727,21 +729,19 @@ export class HideoutHelper
|
|||||||
this.logger.debug(`Air filter: ${resourceValue} filter left on slot ${i + 1}`);
|
this.logger.debug(`Air filter: ${resourceValue} filter left on slot ${i + 1}`);
|
||||||
break; // Break here to avoid updating all filters
|
break; // Break here to avoid updating all filters
|
||||||
}
|
}
|
||||||
else
|
|
||||||
{
|
|
||||||
delete airFilterArea.slots[i].item;
|
delete airFilterArea.slots[i].item;
|
||||||
// Update remaining resources to be subtracted
|
// Update remaining resources to be subtracted
|
||||||
filterDrainRate = Math.abs(resourceValue);
|
filterDrainRate = Math.abs(resourceValue);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
protected updateBitcoinFarm(pmcData: IPmcData, btcFarmCGs: number, isGeneratorOn: boolean): Production
|
protected updateBitcoinFarm(pmcData: IPmcData, btcFarmCGs: number, isGeneratorOn: boolean): Production
|
||||||
{
|
{
|
||||||
const btcProd = pmcData.Hideout.Production[HideoutHelper.bitcoinFarm];
|
const btcProd = pmcData.Hideout.Production[HideoutHelper.bitcoinFarm];
|
||||||
const bitcoinProdData = this.databaseServer.getTables().hideout.production.find((p) =>
|
const bitcoinProdData = this.databaseServer.getTables().hideout.production.find((p) =>
|
||||||
p._id === "5d5c205bd582a50d042a3c0e"
|
p._id === HideoutHelper.bitcoinProductionId
|
||||||
);
|
);
|
||||||
const coinSlotCount = this.getBTCSlots(pmcData);
|
const coinSlotCount = this.getBTCSlots(pmcData);
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user