Migrate loot generation code to use per-map static data - ONLY WORKS WITH CUSTOMS (other maps to follow later)
This commit is contained in:
parent
a4bb5a2f60
commit
57557d6063
4
.gitattributes
vendored
4
.gitattributes
vendored
@ -66,5 +66,7 @@ project/assets/database/locations/factory4_day/looseLoot.json filter=lfs diff=lf
|
||||
project/assets/database/locations/factory4_night/looseLoot.json filter=lfs diff=lfs merge=lfs -text
|
||||
project/assets/database/locations/rezervbase/looseLoot.json filter=lfs diff=lfs merge=lfs -text
|
||||
project/assets/database/locations/bigmap/looseLoot.json filter=lfs diff=lfs merge=lfs -text
|
||||
project/assets/database/locations/bigmap/staticLoot.json filter=lfs diff=lfs merge=lfs -text
|
||||
project/assets/database/locations/bigmap/staticContainers.json filter=lfs diff=lfs merge=lfs -text
|
||||
project/assets/database/locations/bigmap/staticAmmo.json filter=lfs diff=lfs merge=lfs -text
|
||||
project/assets/database/locations/laboratory/looseLoot.json filter=lfs diff=lfs merge=lfs -text
|
||||
project/assets/database/loot/* filter=lfs diff=lfs merge=lfs -text
|
||||
|
@ -1,3 +1,3 @@
|
||||
version https://git-lfs.github.com/spec/v1
|
||||
oid sha256:8119714bab047ba5b2b58d930883216aa98b1cc89ca9fa7ebc94beb5094e963a
|
||||
size 13263529
|
||||
oid sha256:84f24d7eee9ab77f42f857bfccfc3b699af87b30adc874381239d369ca76a237
|
||||
size 2050049
|
||||
|
1
project/assets/database/locations/bigmap/staticAmmo.json
Normal file
1
project/assets/database/locations/bigmap/staticAmmo.json
Normal file
@ -0,0 +1 @@
|
||||
{"Caliber1143x23ACP":[{"tpl":"5efb0d4f4bc50b58e81710f3","relativeProbability":16},{"tpl":"5efb0fc6aeb21837e749c801","relativeProbability":16},{"tpl":"5e81f423763d9f754677bf2e","relativeProbability":135},{"tpl":"5ea2a8e200685063ec28c05a","relativeProbability":19},{"tpl":"5efb0cabfb3e451d70735af5","relativeProbability":16}],"Caliber127x55":[{"tpl":"5cadf6eeae921500134b2799","relativeProbability":28},{"tpl":"5cadf6e5ae921500113bb973","relativeProbability":58},{"tpl":"5cadf6ddae9215051e1c23b2","relativeProbability":40}],"Caliber12g":[{"tpl":"5d6e68c4a4b9361b93413f79","relativeProbability":39},{"tpl":"5d6e6869a4b9361c140bcfde","relativeProbability":18},{"tpl":"5c0d591486f7744c505b416f","relativeProbability":42},{"tpl":"560d5e524bdc2d25448b4571","relativeProbability":132},{"tpl":"5d6e68a8a4b9360b6c0d54e2","relativeProbability":32},{"tpl":"5d6e68e6a4b9361c140bcfe0","relativeProbability":10},{"tpl":"64b8ee384b75259c590fa89b","relativeProbability":30},{"tpl":"5d6e67fba4b9361bc73bc779","relativeProbability":4},{"tpl":"5d6e6891a4b9361bd473feea","relativeProbability":35},{"tpl":"5d6e68dea4b9361bcc29e659","relativeProbability":8},{"tpl":"5d6e6911a4b9361bd5780d52","relativeProbability":12},{"tpl":"58820d1224597753c90aeb13","relativeProbability":26},{"tpl":"5d6e68d1a4b93622fe60e845","relativeProbability":20},{"tpl":"5d6e689ca4b9361bc8618956","relativeProbability":18},{"tpl":"5d6e6806a4b936088465b17e","relativeProbability":39},{"tpl":"5d6e6772a4b936088465b17c","relativeProbability":6},{"tpl":"5d6e68b3a4b9361bca7e50b5","relativeProbability":14}],"Caliber20g":[{"tpl":"5d6e6a42a4b9364f07165f52","relativeProbability":21},{"tpl":"5a38ebd9c4a282000d722a5b","relativeProbability":98},{"tpl":"5d6e695fa4b936359b35d852","relativeProbability":31},{"tpl":"5d6e69b9a4b9361bc8618958","relativeProbability":37},{"tpl":"5d6e6a05a4b93618084f58d0","relativeProbability":47},{"tpl":"5d6e69c7a4b9360b6c0d54e4","relativeProbability":18},{"tpl":"5d6e6a53a4b9361bd473feec","relativeProbability":20},{"tpl":"5d6e6a5fa4b93614ec501745","relativeProbability":19}],"Caliber23x75":[{"tpl":"5f647f31b6238e5dd066e196","relativeProbability":29},{"tpl":"5e85a9f4add9fe03027d9bf1","relativeProbability":10},{"tpl":"5e85a9a6eacf8c039e4e2ac1","relativeProbability":39},{"tpl":"5e85aa1a988a8701445df1f5","relativeProbability":27}],"Caliber26x75":[{"tpl":"62389bc9423ed1685422dc57","relativeProbability":10},{"tpl":"62389aaba63f32501b1b444f","relativeProbability":56},{"tpl":"62389be94d5d474bf712e709","relativeProbability":14},{"tpl":"62389ba9a63f32501b1b4451","relativeProbability":3}],"Caliber366TKM":[{"tpl":"59e655cb86f77411dc52a77b","relativeProbability":68},{"tpl":"59e6658b86f77411d949b250","relativeProbability":27},{"tpl":"59e6542b86f77411dc52a77a","relativeProbability":27},{"tpl":"5f0596629e22f464da6bbdd9","relativeProbability":12}],"Caliber40mmRU":[{"tpl":"5656eb674bdc2d35148b457c","relativeProbability":95}],"Caliber40x46":[{"tpl":"5ede4739e0350d05467f73e8","relativeProbability":23},{"tpl":"5ede47405b097655935d7d16","relativeProbability":1},{"tpl":"5ede475b549eed7c6d5c18fb","relativeProbability":28},{"tpl":"5ede475339ee016e8c534742","relativeProbability":38},{"tpl":"5f0c892565703e5c461894e9","relativeProbability":39},{"tpl":"5ede474b0c226a66f5402622","relativeProbability":11}],"Caliber46x30":[{"tpl":"5ba26812d4351e003201fef1","relativeProbability":43},{"tpl":"64b6979341772715af0f9c39","relativeProbability":102},{"tpl":"5ba2678ad4351e44f824b344","relativeProbability":50},{"tpl":"5ba26835d4351e0035628ff5","relativeProbability":37},{"tpl":"5ba26844d4351e00334c9475","relativeProbability":7}],"Caliber545x39":[{"tpl":"56dff3afd2720bba668b4567","relativeProbability":351},{"tpl":"56dff4a2d2720bbd668b456a","relativeProbability":148},{"tpl":"56dff338d2720bbd668b4569","relativeProbability":245},{"tpl":"56dfef82d2720bbd668b4567","relativeProbability":50},{"tpl":"5c0d5e4486f77478390952fe","relativeProbability":33},{"tpl":"56dff061d2720bb5668b4567","relativeProbability":72},{"tpl":"56dff216d2720bbd668b4568","relativeProbability":59},{"tpl":"56dff0bed2720bb0668b4567","relativeProbability":139},{"tpl":"56dff2ced2720bb4668b4567","relativeProbability":227},{"tpl":"56dff026d2720bb8668b4567","relativeProbability":59},{"tpl":"61962b617c6c7b169525f168","relativeProbability":31},{"tpl":"56dff4ecd2720b5f5a8b4568","relativeProbability":182},{"tpl":"56dff421d2720b5f5a8b4567","relativeProbability":58}],"Caliber556x45NATO":[{"tpl":"59e6920f86f77411d82aa167","relativeProbability":144},{"tpl":"59e6918f86f7746c9f75e849","relativeProbability":28},{"tpl":"59e68f6f86f7746c9f75e846","relativeProbability":50},{"tpl":"59e6906286f7746c9f75e847","relativeProbability":40},{"tpl":"54527ac44bdc2d36668b4567","relativeProbability":26},{"tpl":"59e6927d86f77411da468256","relativeProbability":64},{"tpl":"54527a984bdc2d4e668b4567","relativeProbability":42},{"tpl":"5c0d5ae286f7741e46554302","relativeProbability":21},{"tpl":"59e690b686f7746c9f75e848","relativeProbability":20},{"tpl":"60194943740c5d77f6705eea","relativeProbability":26},{"tpl":"601949593ae8f707c4608daa","relativeProbability":11}],"Caliber57x28":[{"tpl":"5cc80f79e4a949033c7343b2","relativeProbability":50},{"tpl":"5cc80f67e4a949035e43bbba","relativeProbability":48},{"tpl":"5cc80f8fe4a949033b0224a2","relativeProbability":84},{"tpl":"5cc86840d7f00c002412c56c","relativeProbability":6},{"tpl":"5cc86832d7f00c000d3a6e6c","relativeProbability":18},{"tpl":"5cc80f53e4a949000e1ea4f8","relativeProbability":31},{"tpl":"5cc80f38e4a949001152b560","relativeProbability":27}],"Caliber762x25TT":[{"tpl":"5736026a245977644601dc61","relativeProbability":111},{"tpl":"5735ff5c245977640e39ba7e","relativeProbability":118},{"tpl":"573601b42459776410737435","relativeProbability":57},{"tpl":"573602322459776445391df1","relativeProbability":2}],"Caliber762x35":[{"tpl":"5fd20ff893a8961fc660a954","relativeProbability":25},{"tpl":"64b8725c4b75259c590fa899","relativeProbability":29},{"tpl":"619636be6db0f2477964e710","relativeProbability":20},{"tpl":"6196365d58ef8c428c287da1","relativeProbability":27},{"tpl":"5fbe3ffdf8b6a877a729ea82","relativeProbability":34},{"tpl":"6196364158ef8c428c287d9f","relativeProbability":7}],"Caliber762x39":[{"tpl":"64b7af734b75259c590fa895","relativeProbability":80},{"tpl":"59e4d3d286f774176a36250a","relativeProbability":54},{"tpl":"64b7af5a8532cf95ee0a0dbd","relativeProbability":130},{"tpl":"5656d7c34bdc2d9d198b4587","relativeProbability":283},{"tpl":"64b7af434b75259c590fa893","relativeProbability":84},{"tpl":"59e4cf5286f7741778269d8a","relativeProbability":83},{"tpl":"601aa3d2b2bcb34913271e6d","relativeProbability":25},{"tpl":"59e0d99486f7744a32234762","relativeProbability":60},{"tpl":"59e4d24686f7741776641ac7","relativeProbability":4}],"Caliber762x51":[{"tpl":"5e023e53d4353e3302577c4c","relativeProbability":187},{"tpl":"5e023e88277cce2b522ff2b1","relativeProbability":27},{"tpl":"5a6086ea4f39f99cd479502f","relativeProbability":22},{"tpl":"58dd3ad986f77403051cba8f","relativeProbability":59},{"tpl":"5a608bf24f39f98ffc77720e","relativeProbability":34},{"tpl":"5e023e6e34d52a55c3304f71","relativeProbability":12},{"tpl":"5efb0c1bd79ff02a1f5e68d9","relativeProbability":1}],"Caliber762x54R":[{"tpl":"59e77a2386f7742ee578960a","relativeProbability":30},{"tpl":"64b8f7c241772715af0f9c3d","relativeProbability":65},{"tpl":"5887431f2459777e1612938f","relativeProbability":90},{"tpl":"5e023d48186a883be655e551","relativeProbability":8},{"tpl":"5e023cf8186a883be655e54f","relativeProbability":36},{"tpl":"64b8f7968532cf95ee0a0dbf","relativeProbability":74},{"tpl":"64b8f7b5389d7ffd620ccba2","relativeProbability":43},{"tpl":"5e023d34e8a400319a28ed44","relativeProbability":22},{"tpl":"560d61e84bdc2da74d8b4571","relativeProbability":7}],"Caliber86x70":[{"tpl":"5fc382a9d724d907e2077dab","relativeProbability":5},{"tpl":"5fc382c1016cce60e8341b20","relativeProbability":20},{"tpl":"5fc275cf85fd526b824a571a","relativeProbability":6},{"tpl":"5fc382b6d6fa9c00c571bbc3","relativeProbability":6}],"Caliber9x18PM":[{"tpl":"573719762459775a626ccbc1","relativeProbability":400},{"tpl":"57371b192459775a9f58a5e0","relativeProbability":72},{"tpl":"573719df2459775a626ccbc2","relativeProbability":134},{"tpl":"57371aab2459775a77142f22","relativeProbability":54},{"tpl":"5737201124597760fc4431f1","relativeProbability":66},{"tpl":"57372140245977611f70ee91","relativeProbability":153},{"tpl":"573718ba2459775a75491131","relativeProbability":82},{"tpl":"5737218f245977612125ba51","relativeProbability":140},{"tpl":"57371f8d24597761006c6a81","relativeProbability":14},{"tpl":"57371e4124597760ff7b25f1","relativeProbability":68},{"tpl":"5737207f24597760ff7b25f2","relativeProbability":46},{"tpl":"57371f2b24597761224311f1","relativeProbability":12},{"tpl":"573720e02459776143012541","relativeProbability":3},{"tpl":"57371eb62459776125652ac1","relativeProbability":1}],"Caliber9x19PARA":[{"tpl":"56d59d3ad2720bdb418b4577","relativeProbability":396},{"tpl":"64b7bbb74b75259c590fa897","relativeProbability":338},{"tpl":"5c0d56a986f774449d5de529","relativeProbability":64},{"tpl":"5c3df7d588a4501f290594e5","relativeProbability":31},{"tpl":"58864a4f2459770fcc257101","relativeProbability":50},{"tpl":"5efb0da7a29a85116f6ea05f","relativeProbability":11},{"tpl":"5a3c16fe86f77452b62de32a","relativeProbability":46},{"tpl":"5c925fa22e221601da359b7b","relativeProbability":21},{"tpl":"5efb0e16aeb21837e749c7ff","relativeProbability":17}],"Caliber9x21":[{"tpl":"5a26ac0ec4a28200741e1e18","relativeProbability":28},{"tpl":"5a26abfac4a28232980eabff","relativeProbability":75},{"tpl":"5a269f97c4a282000b151807","relativeProbability":45},{"tpl":"5a26ac06c4a282000c5a90a8","relativeProbability":77},{"tpl":"6576f93989f0062e741ba952","relativeProbability":4},{"tpl":"6576f4708ca9c4381d16cd9d","relativeProbability":5}],"Caliber9x33R":[{"tpl":"62330c18744e5e31df12f516","relativeProbability":13},{"tpl":"62330bfadc5883093563729b","relativeProbability":29},{"tpl":"62330b3ed4dc74626d570b95","relativeProbability":57},{"tpl":"62330c40bdd19b369e1e53d1","relativeProbability":9}],"Caliber9x39":[{"tpl":"5c0d668f86f7747ccb7f13b2","relativeProbability":39},{"tpl":"5c0d688c86f77413ae3407b2","relativeProbability":31},{"tpl":"6576f96220d53a5b8f3e395e","relativeProbability":35},{"tpl":"57a0e5022459774d1673f889","relativeProbability":54},{"tpl":"57a0dfb82459774d3078b56c","relativeProbability":31},{"tpl":"61962d879bb3d20b0946d385","relativeProbability":20}]}
|
File diff suppressed because one or more lines are too long
1
project/assets/database/locations/bigmap/staticLoot.json
Normal file
1
project/assets/database/locations/bigmap/staticLoot.json
Normal file
File diff suppressed because one or more lines are too long
@ -1,3 +0,0 @@
|
||||
version https://git-lfs.github.com/spec/v1
|
||||
oid sha256:daba4299e6909cf23a15c61c5aa341aff477ce3961ef8dc5aca673a1c4fffc41
|
||||
size 11187
|
@ -1,3 +0,0 @@
|
||||
version https://git-lfs.github.com/spec/v1
|
||||
oid sha256:b7610b04229abf18d26f7a3400600c9a58fc4c937c9ef6ee19320fae03f71eba
|
||||
size 2747359
|
@ -1,3 +0,0 @@
|
||||
version https://git-lfs.github.com/spec/v1
|
||||
oid sha256:39df320dd9a3aaee099c72dfad123af8b56ed21f104959083db2fff495c2bec9
|
||||
size 720507
|
@ -102,7 +102,7 @@ export class LocationController
|
||||
this.raidTimeAdjustmentService.makeAdjustmentsToMap(raidAdjustments, locationBaseClone);
|
||||
}
|
||||
|
||||
const staticAmmoDist = this.jsonUtil.clone(db.loot.staticAmmo);
|
||||
const staticAmmoDist = this.jsonUtil.clone(location.staticAmmo);
|
||||
|
||||
// Create containers and add loot to them
|
||||
const staticLoot = this.locationGenerator.generateStaticContainers(locationBaseClone, staticAmmoDist);
|
||||
|
@ -3,16 +3,18 @@ import { inject, injectable } from "tsyringe";
|
||||
import { ContainerHelper } from "@spt-aki/helpers/ContainerHelper";
|
||||
import { ItemHelper } from "@spt-aki/helpers/ItemHelper";
|
||||
import { PresetHelper } from "@spt-aki/helpers/PresetHelper";
|
||||
import { IContainerMinMax, IStaticContainer } from "@spt-aki/models/eft/common/ILocation";
|
||||
import { ILocationBase } from "@spt-aki/models/eft/common/ILocationBase";
|
||||
import { ILooseLoot, Spawnpoint, SpawnpointTemplate, SpawnpointsForced } from "@spt-aki/models/eft/common/ILooseLoot";
|
||||
import { Item } from "@spt-aki/models/eft/common/tables/IItem";
|
||||
import {
|
||||
IContainerMinMax,
|
||||
ILocation,
|
||||
IStaticAmmoDetails,
|
||||
IStaticContainer,
|
||||
IStaticContainerData,
|
||||
IStaticForcedProps,
|
||||
IStaticLootDetails,
|
||||
} from "@spt-aki/models/eft/common/tables/ILootBase";
|
||||
} from "@spt-aki/models/eft/common/ILocation";
|
||||
import { ILocationBase } from "@spt-aki/models/eft/common/ILocationBase";
|
||||
import { ILooseLoot, Spawnpoint, SpawnpointTemplate, SpawnpointsForced } from "@spt-aki/models/eft/common/ILooseLoot";
|
||||
import { Item } from "@spt-aki/models/eft/common/tables/IItem";
|
||||
import { BaseClasses } from "@spt-aki/models/enums/BaseClasses";
|
||||
import { ConfigTypes } from "@spt-aki/models/enums/ConfigTypes";
|
||||
import { Money } from "@spt-aki/models/enums/Money";
|
||||
@ -81,8 +83,9 @@ export class LocationGenerator
|
||||
const locationId = locationBase.Id.toLowerCase();
|
||||
|
||||
const db = this.databaseServer.getTables();
|
||||
const mapData: ILocation = db.locations[locationId];
|
||||
|
||||
const staticWeaponsOnMapClone = this.jsonUtil.clone(db.loot.staticContainers[locationBase.Name]?.staticWeapons);
|
||||
const staticWeaponsOnMapClone = this.jsonUtil.clone(mapData.staticContainers.staticWeapons);
|
||||
if (!staticWeaponsOnMapClone)
|
||||
{
|
||||
this.logger.error(`Unable to find static weapon data for map: ${locationBase.Name}`);
|
||||
@ -91,9 +94,7 @@ export class LocationGenerator
|
||||
// Add mounted weapons to output loot
|
||||
result.push(...staticWeaponsOnMapClone ?? []);
|
||||
|
||||
const allStaticContainersOnMapClone = this.jsonUtil.clone(
|
||||
db.loot.staticContainers[locationBase.Name]?.staticContainers,
|
||||
);
|
||||
const allStaticContainersOnMapClone = this.jsonUtil.clone(mapData.staticContainers.staticContainers);
|
||||
if (!allStaticContainersOnMapClone)
|
||||
{
|
||||
this.logger.error(`Unable to find static container data for map: ${locationBase.Name}`);
|
||||
@ -101,7 +102,7 @@ export class LocationGenerator
|
||||
const staticRandomisableContainersOnMap = this.getRandomisableContainersOnMap(allStaticContainersOnMapClone);
|
||||
|
||||
// Containers that MUST be added to map (quest containers etc)
|
||||
const staticForcedOnMapClone = this.jsonUtil.clone(db.loot.staticContainers[locationBase.Name]?.staticForced);
|
||||
const staticForcedOnMapClone = this.jsonUtil.clone(mapData.staticContainers.staticForced);
|
||||
if (!staticForcedOnMapClone)
|
||||
{
|
||||
this.logger.error(`Unable to find forced static data for map: ${locationBase.Name}`);
|
||||
@ -111,7 +112,7 @@ export class LocationGenerator
|
||||
let staticContainerCount = 0;
|
||||
|
||||
// Find all 100% spawn containers
|
||||
const staticLootDist = db.loot.staticLoot;
|
||||
const staticLootDist = mapData.staticLoot;
|
||||
const guaranteedContainers = this.getGuaranteedContainers(allStaticContainersOnMapClone);
|
||||
staticContainerCount += guaranteedContainers.length;
|
||||
|
||||
|
@ -1,10 +1,10 @@
|
||||
import { inject, injectable } from "tsyringe";
|
||||
|
||||
import { HandbookHelper } from "@spt-aki/helpers/HandbookHelper";
|
||||
import { IStaticAmmoDetails } from "@spt-aki/models/eft/common/ILocation";
|
||||
import { IPmcData } from "@spt-aki/models/eft/common/IPmcData";
|
||||
import { InsuredItem } from "@spt-aki/models/eft/common/tables/IBotBase";
|
||||
import { Item, Location, Repairable } from "@spt-aki/models/eft/common/tables/IItem";
|
||||
import { IStaticAmmoDetails } from "@spt-aki/models/eft/common/tables/ILootBase";
|
||||
import { ITemplateItem } from "@spt-aki/models/eft/common/tables/ITemplateItem";
|
||||
import { BaseClasses } from "@spt-aki/models/enums/BaseClasses";
|
||||
import { EquipmentSlots } from "@spt-aki/models/enums/EquipmentSlots";
|
||||
|
@ -1,11 +1,22 @@
|
||||
import { Exit, ILocationBase } from "@spt-aki/models/eft/common/ILocationBase";
|
||||
import { ILooseLoot } from "@spt-aki/models/eft/common/ILooseLoot";
|
||||
import { Ixyz } from "./Ixyz";
|
||||
import { Item } from "./tables/IItem";
|
||||
|
||||
export interface ILocation
|
||||
{
|
||||
/** Map meta-data */
|
||||
base: ILocationBase;
|
||||
/** Loose loot postions and item weights */
|
||||
looseLoot: ILooseLoot;
|
||||
/** Static loot item weights */
|
||||
staticLoot: Record<string, IStaticLootDetails>;
|
||||
/** Static container postions and item weights */
|
||||
staticContainers: IStaticContainerDetails;
|
||||
staticAmmo: Record<string, IStaticAmmoDetails[]>;
|
||||
/** All possible static containers on map + their assign groupings */
|
||||
statics: IStaticContainer;
|
||||
/** All possible map extracts */
|
||||
allExtracts: Exit[];
|
||||
}
|
||||
|
||||
@ -27,3 +38,77 @@ export interface IContainerData
|
||||
{
|
||||
groupId: string;
|
||||
}
|
||||
|
||||
export interface IStaticLootDetails
|
||||
{
|
||||
itemcountDistribution: ItemCountDistribution[];
|
||||
itemDistribution: ItemDistribution[];
|
||||
}
|
||||
|
||||
export interface ItemCountDistribution
|
||||
{
|
||||
count: number;
|
||||
relativeProbability: number;
|
||||
}
|
||||
|
||||
export interface ItemDistribution
|
||||
{
|
||||
tpl: string;
|
||||
relativeProbability: number;
|
||||
}
|
||||
|
||||
export interface IStaticPropsBase
|
||||
{
|
||||
Id: string;
|
||||
IsContainer: boolean;
|
||||
useGravity: boolean;
|
||||
randomRotation: boolean;
|
||||
Position: Ixyz;
|
||||
Rotation: Ixyz;
|
||||
IsGroupPosition: boolean;
|
||||
IsAlwaysSpawn: boolean;
|
||||
GroupPositions: any[];
|
||||
Root: string;
|
||||
Items: any[];
|
||||
}
|
||||
|
||||
export interface IStaticWeaponProps extends IStaticPropsBase
|
||||
{
|
||||
Items: Item[];
|
||||
}
|
||||
|
||||
export interface IStaticContainerDetails
|
||||
{
|
||||
staticWeapons: IStaticWeaponProps[];
|
||||
staticContainers: IStaticContainerData[];
|
||||
staticForced: IStaticForcedProps[];
|
||||
}
|
||||
|
||||
export interface IStaticContainerData
|
||||
{
|
||||
probability: number;
|
||||
template: IStaticContainerProps;
|
||||
}
|
||||
|
||||
export interface IStaticAmmoDetails
|
||||
{
|
||||
tpl: string;
|
||||
relativeProbability: number;
|
||||
}
|
||||
|
||||
export interface IStaticForcedProps
|
||||
{
|
||||
containerId: string;
|
||||
itemTpl: string;
|
||||
}
|
||||
|
||||
export interface IStaticContainerProps extends IStaticPropsBase
|
||||
{
|
||||
Items: StaticItem[];
|
||||
}
|
||||
|
||||
export interface StaticItem
|
||||
{
|
||||
_id: string;
|
||||
_tpl: string;
|
||||
}
|
||||
|
@ -1,83 +0,0 @@
|
||||
import { Ixyz } from "@spt-aki/models/eft/common/Ixyz";
|
||||
import { Item } from "@spt-aki/models/eft/common/tables/IItem";
|
||||
|
||||
export interface ILootBase
|
||||
{
|
||||
staticAmmo: Record<string, IStaticAmmoDetails[]>;
|
||||
staticContainers: Record<string, IStaticContainerDetails>;
|
||||
staticLoot: Record<string, IStaticLootDetails>;
|
||||
}
|
||||
|
||||
export interface IStaticAmmoDetails
|
||||
{
|
||||
tpl: string;
|
||||
relativeProbability: number;
|
||||
}
|
||||
|
||||
export interface IStaticContainerDetails
|
||||
{
|
||||
staticWeapons: IStaticWeaponProps[];
|
||||
staticContainers: IStaticContainerData[];
|
||||
staticForced: IStaticForcedProps[];
|
||||
}
|
||||
|
||||
export interface IStaticContainerData
|
||||
{
|
||||
probability: number;
|
||||
template: IStaticContainerProps;
|
||||
}
|
||||
|
||||
export interface IStaticPropsBase
|
||||
{
|
||||
Id: string;
|
||||
IsContainer: boolean;
|
||||
useGravity: boolean;
|
||||
randomRotation: boolean;
|
||||
Position: Ixyz;
|
||||
Rotation: Ixyz;
|
||||
IsGroupPosition: boolean;
|
||||
IsAlwaysSpawn: boolean;
|
||||
GroupPositions: any[];
|
||||
Root: string;
|
||||
Items: any[];
|
||||
}
|
||||
|
||||
export interface IStaticWeaponProps extends IStaticPropsBase
|
||||
{
|
||||
Items: Item[];
|
||||
}
|
||||
|
||||
export interface IStaticContainerProps extends IStaticPropsBase
|
||||
{
|
||||
Items: StaticItem[];
|
||||
}
|
||||
|
||||
export interface StaticItem
|
||||
{
|
||||
_id: string;
|
||||
_tpl: string;
|
||||
}
|
||||
|
||||
export interface IStaticForcedProps
|
||||
{
|
||||
containerId: string;
|
||||
itemTpl: string;
|
||||
}
|
||||
|
||||
export interface IStaticLootDetails
|
||||
{
|
||||
itemcountDistribution: ItemCountDistribution[];
|
||||
itemDistribution: ItemDistribution[];
|
||||
}
|
||||
|
||||
export interface ItemCountDistribution
|
||||
{
|
||||
count: number;
|
||||
relativeProbability: number;
|
||||
}
|
||||
|
||||
export interface ItemDistribution
|
||||
{
|
||||
tpl: string;
|
||||
relativeProbability: number;
|
||||
}
|
@ -1,10 +1,10 @@
|
||||
import { ILooseLoot, SpawnpointTemplate } from "@spt-aki/models/eft/common/ILooseLoot";
|
||||
import {
|
||||
IStaticAmmoDetails,
|
||||
IStaticContainerProps,
|
||||
IStaticForcedProps,
|
||||
IStaticLootDetails,
|
||||
} from "@spt-aki/models/eft/common/tables/ILootBase";
|
||||
} from "@spt-aki/models/eft/common/ILocation";
|
||||
import { ILooseLoot, SpawnpointTemplate } from "@spt-aki/models/eft/common/ILooseLoot";
|
||||
|
||||
export interface ILocationGenerator
|
||||
{
|
||||
|
@ -5,7 +5,6 @@ import { IBotCore } from "@spt-aki/models/eft/common/tables/IBotCore";
|
||||
import { IBotType } from "@spt-aki/models/eft/common/tables/IBotType";
|
||||
import { ICustomizationItem } from "@spt-aki/models/eft/common/tables/ICustomizationItem";
|
||||
import { IHandbookBase } from "@spt-aki/models/eft/common/tables/IHandbookBase";
|
||||
import { ILootBase } from "@spt-aki/models/eft/common/tables/ILootBase";
|
||||
import { IMatch } from "@spt-aki/models/eft/common/tables/IMatch";
|
||||
import { IProfileTemplates } from "@spt-aki/models/eft/common/tables/IProfileTemplate";
|
||||
import { IQuest } from "@spt-aki/models/eft/common/tables/IQuest";
|
||||
@ -35,7 +34,6 @@ export interface IDatabaseTables
|
||||
};
|
||||
locales?: ILocaleBase;
|
||||
locations?: ILocations;
|
||||
loot?: ILootBase;
|
||||
match?: IMatch;
|
||||
templates?: {
|
||||
character: string[];
|
||||
|
@ -10,7 +10,6 @@ export class DatabaseServer
|
||||
hideout: undefined,
|
||||
locales: undefined,
|
||||
locations: undefined,
|
||||
loot: undefined,
|
||||
match: undefined,
|
||||
templates: undefined,
|
||||
traders: undefined,
|
||||
|
Loading…
Reference in New Issue
Block a user