Added Mods

- New Trader Mod; Painter
  - Along with a new weapon attachment mod; Black Core
- Make Val/VSS Great Again
This commit is contained in:
Rage 2025-01-15 20:53:42 -05:00
parent c3fcfb84f8
commit a161750966
109 changed files with 6721 additions and 2 deletions

28
mods/Black Core/meta.ini Normal file
View File

@ -0,0 +1,28 @@
[General]
gameName=spt
modid=0
version=d2025.1.15.0
newestVersion=
category="1,"
nexusFileStatus=1
installationFile=MoxoPixel-BlackCore.zip
repository=Nexus
ignoredVersion=
comments=
notes=
nexusDescription=
url=
hasCustomURL=true
lastNexusQuery=
lastNexusUpdate=
nexusLastModified=2025-01-16T01:49:42Z
nexusCategory=0
converted=false
validated=false
color=@Variant(\0\0\0\x43\0\xff\xff\0\0\0\0\0\0\0\0)
tracked=0
[installedFiles]
1\modid=0
1\fileid=0
size=1

View File

@ -0,0 +1,556 @@
{
"manifest": [
{
"key":"tactical_all_insight_wmx200_retex.bundle",
"dependencyKeys":[]
},
{
"key":"mag_stanag_hk_polymer_mag_556x45_30_retex.bundle",
"dependencyKeys":[]
},
{
"key":"handguard_ar15_dd_ris_ii_fsp_9,5_retex.bundle",
"dependencyKeys":[]
},
{
"key":"scope_all_eotech_exps3_retex.bundle",
"dependencyKeys":[
"scope_all_eotech_exps3_gloss_nrm_retex.bundle",
"scope_all_eotech_exps3_mesh_retex.bundle",
"scope_all_eotech_exps3_tan_textures_retex.bundle",
"scope_all_eotech_xps3_textures_retex.bundle"
]
},
{
"key":"scope_all_eotech_exps3_gloss_nrm_retex.bundle",
"dependencyKeys":[]
},
{
"key":"scope_all_eotech_exps3_tan_textures_retex.bundle",
"dependencyKeys":[]
},
{
"key":"scope_all_eotech_xps3_textures_retex.bundle",
"dependencyKeys":[]
},
{
"key":"scope_all_eotech_exps3_mesh_retex.bundle",
"dependencyKeys":[
"scope_all_eotech_exps3_gloss_nrm_retex.bundle",
"scope_all_eotech_exps3_tan_textures_retex.bundle",
"scope_all_eotech_xps3_textures_retex.bundle"
]
},
{
"key":"tactical_all_holosun_ls321_retex.bundle",
"dependencyKeys":[
"assets/commonassets/physics/physicsmaterials.bundle",
"assets/content/textures/holemanager/glow_particle_bright.bundle",
"assets/standard assets/effects/lightcookies/textures/flashlightcookie.bundle",
"assets/systems/effects/collimator.bundle",
"assets/systems/effects/laserbeam/laser.bundle",
"assets/systems/effects/multiflare/multiflare.bundle",
"assets/systems/effects/nightvision.bundle",
"cubemaps",
"shaders"
]
},
{
"key":"m4a1_black_lines/textures/client_assets.bundle",
"dependencyKeys":[
]
},
{
"key":"m4a1_black_lines/client_assets.bundle",
"dependencyKeys":[
"m4a1_black_lines/textures/client_assets.bundle",
"cubemaps",
"shaders"
]
},
{
"key":"m4a1_black_lines/weapon_colt_m4a1_556x45_container.bundle",
"dependencyKeys":[
"assets/commonassets/physics/physicsmaterials.bundle",
"assets/content/audio/banks/m4a1.bundle",
"assets/content/audio/blendoptions/assets.bundle",
"assets/content/audio/weapons/ak74.bundle",
"assets/content/audio/weapons/generic",
"assets/content/audio/weapons/m4a1.bundle",
"assets/content/weapons/additional_hands/client_assets.bundle",
"assets/content/weapons/animations/simple_animations.bundle",
"assets/content/weapons/animations/spirit_animations.bundle",
"m4a1_black_lines/client_assets.bundle",
"m4a1_black_lines/textures/client_assets.bundle",
"assets/content/weapons/tx15/client_assets.bundle",
"assets/content/weapons/tx15/textures/client_assets.bundle",
"assets/content/weapons/tx15/weapon_lone_star_tx15_designated_marksman_556x45_container.bundle",
"assets/content/weapons/weapon_root_anim_fix.bundle",
"assets/content/weapons/wip/kibas tuning prefabs/muzzlejets_templates/default_assets.bundle",
"assets/systems/effects/heathaze/defaultheathaze.bundle",
"assets/systems/effects/muzzleflash/muzzleflash.bundle",
"assets/systems/effects/smoke.bundle",
"cubemaps",
"shaders"
]
},
{
"key":"ak103_black_lines/textures/client_assets.bundle",
"dependencyKeys":[
]
},
{
"key":"ak103_black_lines/client_assets.bundle",
"dependencyKeys":[
"ak103_black_lines/textures/client_assets.bundle",
"cubemaps",
"shaders"
]
},
{
"key":"ak103_black_lines/weapon_izhmash_ak103_762x39_container.bundle",
"dependencyKeys":[
"assets/commonassets/physics/physicsmaterials.bundle",
"assets/content/audio/banks/ak74.bundle",
"assets/content/audio/banks/akm.bundle",
"assets/content/audio/blendoptions/assets.bundle",
"assets/content/audio/weapons/ak74.bundle",
"assets/content/audio/weapons/akm.bundle",
"assets/content/audio/weapons/generic",
"assets/content/audio/weapons/saiga12.bundle",
"assets/content/items/mods/handguards/handguard_pp-19-01_izhmash_vityaz_std_plastic_textures.bundle",
"assets/content/weapons/additional_hands/client_assets.bundle",
"ak103_black_lines/client_assets.bundle",
"ak103_black_lines/textures/client_assets.bundle",
"assets/content/weapons/ak100/weapon_izhmash_ak104_762x39_container.bundle",
"assets/content/weapons/ak100/weapon_izhmash_ak105_545x39_container.bundle",
"assets/content/weapons/ak74m/textures/client_assets.bundle",
"assets/content/weapons/animations/simple_animations.bundle",
"assets/content/weapons/animations/spirit_animations.bundle",
"assets/content/weapons/pp-19-01/textures/client_assets.bundle",
"assets/content/weapons/weapon_root_anim_fix.bundle",
"assets/content/weapons/wip/kibas tuning prefabs/muzzlejets_templates/default_assets.bundle",
"assets/systems/effects/heathaze/defaultheathaze.bundle",
"assets/systems/effects/muzzleflash/muzzleflash.bundle",
"assets/systems/effects/smoke.bundle",
"cubemaps",
"shaders"
]
},
{
"key":"reciever_ak_akademia_bastion_retex.bundle",
"dependencyKeys":[
"assets/commonassets/physics/physicsmaterials.bundle",
"cubemaps",
"shaders"
]
},
{
"key":"rsass_black/weapon_remington_r11_rsass_762x51_container.bundle",
"dependencyKeys":[
"assets/commonassets/physics/physicsmaterials.bundle",
"assets/content/audio/banks/rsass.bundle",
"assets/content/audio/blendoptions/assets.bundle",
"assets/content/audio/weapons/ak74.bundle",
"assets/content/audio/weapons/generic",
"assets/content/audio/weapons/mpx.bundle",
"assets/content/weapons/additional_hands/client_assets.bundle",
"assets/content/weapons/animations/simple_animations.bundle",
"assets/content/weapons/animations/spirit_animations.bundle",
"rsass_black/client_assets.bundle",
"rsass_black/textures/client_assets.bundle",
"assets/content/weapons/weapon_root_anim_fix.bundle",
"assets/content/weapons/wip/kibas tuning prefabs/muzzlejets_templates/default_assets.bundle",
"assets/systems/effects/heathaze/defaultheathaze.bundle",
"assets/systems/effects/muzzleflash/muzzleflash.bundle",
"assets/systems/effects/smoke.bundle",
"cubemaps",
"shaders"
]
},
{
"key":"rsass_black/client_assets.bundle",
"dependencyKeys":[
"rsass_black/textures/client_assets.bundle",
"cubemaps",
"shaders"
]
},
{
"key":"rsass_black/textures/client_assets.bundle",
"dependencyKeys":[
]
},
{
"key":"mk47_black_lines/textures/client_assets.bundle",
"dependencyKeys":[
]
},
{
"key":"mk47_black_lines/client_assets.bundle",
"dependencyKeys":[
"mk47_black_lines/textures/client_assets.bundle",
"cubemaps",
"shaders"
]
},
{
"key":"mk47_black_lines/weapon_cmmg_mk47_762x39_container.bundle",
"dependencyKeys":[
"assets/commonassets/physics/physicsmaterials.bundle",
"assets/content/audio/banks/mp5.bundle",
"assets/content/audio/blendoptions/assets.bundle",
"assets/content/audio/weapons/ak74.bundle",
"assets/content/audio/weapons/akm/instrumental.bundle",
"assets/content/audio/weapons/generic",
"assets/content/audio/weapons/mp5.bundle",
"assets/content/audio/weapons/mpx.bundle",
"assets/content/weapons/additional_hands/client_assets.bundle",
"assets/content/weapons/animations/simple_animations.bundle",
"assets/content/weapons/animations/spirit_animations.bundle",
"assets/content/weapons/m4a1/client_assets.bundle",
"assets/content/weapons/m4a1/textures/client_assets.bundle",
"mk47_black_lines/client_assets.bundle",
"mk47_black_lines/textures/client_assets.bundle",
"assets/content/weapons/weapon_root_anim_fix.bundle",
"assets/content/weapons/wip/kibas tuning prefabs/muzzlejets_templates/default_assets.bundle",
"assets/systems/effects/heathaze/defaultheathaze.bundle",
"assets/systems/effects/muzzleflash/muzzleflash.bundle",
"assets/systems/effects/smoke.bundle",
"cubemaps",
"shaders"
]
},
{
"key":"reciever_mk47_cmmg_mk47_std_retex.bundle",
"dependencyKeys":[
]
},
{
"key":"tactical_all_wilcox_raptar_es_retex.bundle",
"dependencyKeys":[
"assets/commonassets/physics/physicsmaterials.bundle",
"assets/content/textures/holemanager/glow_particle_bright.bundle",
"assets/standard assets/effects/lightcookies/textures/flashlightcookie.bundle",
"assets/systems/effects/collimator.bundle",
"assets/systems/effects/laserbeam/laser.bundle",
"assets/systems/effects/multiflare/multiflare.bundle",
"assets/systems/effects/nightvision.bundle",
"cubemaps",
"shaders"
]
},
{
"key":"scope_30mm_razor_hd_gen_2_1_6x24_retex.bundle",
"dependencyKeys":[
"assets/commonassets/physics/physicsmaterials.bundle",
"assets/content/textures/holemanager/round_spec_mask.bundle",
"assets/systems/effects/opticsight/opticsightsmasks.bundle",
"cubemaps",
"shaders"
]
},
{
"key":"reciever_ar15_noveske_gen3_retex.bundle",
"dependencyKeys":[
]
},
{
"key":"stock_vepr_molot_vpo-101_std_wood_retex.bundle",
"dependencyKeys":[
]
},
{
"key":"stock_m14_troy_sass_chassis_retex.bundle",
"dependencyKeys":[
]
},
{
"key":"silencer_mount_silencerco_hybrid_46_multi_retex.bundle",
"dependencyKeys":[]
},
{
"key":"mag_aug_steyr_std_556x45_30_retex.bundle",
"dependencyKeys":[]
},
{
"key":"stock_ak_zenit_pt_1_retex.bundle",
"dependencyKeys":[]
},
{
"key":"pistolgrip_ak_magpul_moe_ak_retex.bundle",
"dependencyKeys":[]
},
{
"key":"gas_block_akp_slr_ak_railed_gas_tube_retex.bundle",
"dependencyKeys":[]
},
{
"key":"reciever_ak_texas_weapon_systems_dog_leg_rail_gen_3_retex.bundle",
"dependencyKeys":[]
},
{
"key":"handguard_ar15_precision_reflex_carbon_fiber_delta_gen_3_retex.bundle",
"dependencyKeys":[]
},
{
"key":"helmet_armor_slaap.bundle",
"dependencyKeys":[]
},
{
"key":"reciever_glock_glock_17_std_retex.bundle",
"dependencyKeys":[]
},
{
"key":"reciever_glock_gspc_viper_slide_cut_retex.bundle",
"dependencyKeys":[]
},
{
"key":"m4a1_flame/textures/client_assets.bundle",
"dependencyKeys":[
]
},
{
"key":"m4a1_flame/client_assets.bundle",
"dependencyKeys":[
"m4a1_flame/textures/client_assets.bundle",
"cubemaps",
"shaders"
]
},
{
"key":"m4a1_flame/weapon_colt_m4a1_556x45_container.bundle",
"dependencyKeys":[
"assets/commonassets/physics/physicsmaterials.bundle",
"assets/content/audio/banks/m4a1.bundle",
"assets/content/audio/blendoptions/assets.bundle",
"assets/content/audio/weapons/ak74.bundle",
"assets/content/audio/weapons/generic",
"assets/content/audio/weapons/m4a1.bundle",
"assets/content/weapons/additional_hands/client_assets.bundle",
"assets/content/weapons/animations/simple_animations.bundle",
"assets/content/weapons/animations/spirit_animations.bundle",
"m4a1_flame/client_assets.bundle",
"m4a1_flame/textures/client_assets.bundle",
"assets/content/weapons/tx15/client_assets.bundle",
"assets/content/weapons/tx15/textures/client_assets.bundle",
"assets/content/weapons/tx15/weapon_lone_star_tx15_designated_marksman_556x45_container.bundle",
"assets/content/weapons/weapon_root_anim_fix.bundle",
"assets/content/weapons/wip/kibas tuning prefabs/muzzlejets_templates/default_assets.bundle",
"assets/systems/effects/heathaze/defaultheathaze.bundle",
"assets/systems/effects/muzzleflash/muzzleflash.bundle",
"assets/systems/effects/smoke.bundle",
"cubemaps",
"shaders"
]
},
{
"key":"foregrip_all_bcm_mod_3_new.bundle",
"dependencyKeys":[]
},
{
"key":"mag_ak74_izhmash_6l23_545x39_30_retex.bundle",
"dependencyKeys":[]
},
{
"key":"m4a1_new/textures/client_assets.bundle",
"dependencyKeys":[
]
},
{
"key":"m4a1_new/client_assets.bundle",
"dependencyKeys":[
"m4a1_new/textures/client_assets.bundle",
"cubemaps",
"shaders"
]
},
{
"key":"m4a1_new/weapon_colt_m4a1_556x45_container.bundle",
"dependencyKeys":[
"assets/commonassets/physics/physicsmaterials.bundle",
"assets/content/audio/banks/m4a1.bundle",
"assets/content/audio/blendoptions/assets.bundle",
"assets/content/audio/weapons/ak74.bundle",
"assets/content/audio/weapons/generic",
"assets/content/audio/weapons/m4a1.bundle",
"assets/content/weapons/additional_hands/client_assets.bundle",
"assets/content/weapons/animations/simple_animations.bundle",
"assets/content/weapons/animations/spirit_animations.bundle",
"m4a1_new/client_assets.bundle",
"m4a1_new/textures/client_assets.bundle",
"assets/content/weapons/tx15/client_assets.bundle",
"assets/content/weapons/tx15/textures/client_assets.bundle",
"assets/content/weapons/tx15/weapon_lone_star_tx15_designated_marksman_556x45_container.bundle",
"assets/content/weapons/weapon_root_anim_fix.bundle",
"assets/content/weapons/wip/kibas tuning prefabs/muzzlejets_templates/default_assets.bundle",
"assets/systems/effects/heathaze/defaultheathaze.bundle",
"assets/systems/effects/muzzleflash/muzzleflash.bundle",
"assets/systems/effects/smoke.bundle",
"cubemaps",
"shaders"
]
},
{
"key":"reciever_ar15_vltor_mur-1s_retex.bundle",
"dependencyKeys":[
]
},
{
"key":"mag_ar10_lancer_l7_awm_762x51_20.bundle",
"dependencyKeys":[
]
},
{
"key":"mag_ar10_lancer_l7_awm_762x51_25.bundle",
"dependencyKeys":[
]
},
{
"key":"spear_black/textures/client_assets.bundle",
"dependencyKeys":[
]
},
{
"key":"spear_black/client_assets.bundle",
"dependencyKeys":[
"spear_black/textures/client_assets.bundle",
"cubemaps",
"shaders"
]
},
{
"key":"spear_black/weapon_sig_mcx_spear_68x51_container.bundle",
"dependencyKeys":[
"assets/commonassets/physics/physicsmaterials.bundle",
"assets/content/audio/blendoptions/assets.bundle",
"assets/content/audio/weapons/ak74.bundle",
"assets/content/audio/weapons/generic",
"assets/content/weapons/additional_hands/client_assets.bundle",
"assets/content/weapons/animations/simple_animations.bundle",
"assets/content/weapons/animations/spirit_animations.bundle",
"spear_black/client_assets.bundle",
"spear_black/textures/client_assets.bundle",
"assets/content/weapons/weapon_root_anim_fix.bundle",
"assets/content/weapons/wip/kibas tuning prefabs/muzzlejets_templates/default_assets.bundle",
"assets/systems/effects/heathaze/defaultheathaze.bundle",
"assets/systems/effects/muzzleflash/muzzleflash.bundle",
"assets/systems/effects/smoke.bundle",
"cubemaps",
"shaders"
]
},
{
"key":"spear_black/reciever_mcx_sig_spear_upper.bundle",
"dependencyKeys":[
"assets/commonassets/physics/physicsmaterials.bundle",
"spear_black/client_assets.bundle",
"spear_black/textures/client_assets.bundle",
"cubemaps",
"shaders"
]
},
{
"key":"pistolgrip_ar15_sig_reduced_angle_pistol_grip_ct_retex.bundle",
"dependencyKeys":[
]
},
{
"key":"handguard_mcx_sig_spear_m_lok_retex.bundle",
"dependencyKeys":[]
},
{
"key":"silencer_clutchlok_sig_slx68_mg_qd_suppressor_68x51_retex.bundle",
"dependencyKeys":[]
},
{
"key":"charge_spear_sig_spear_std_retex.bundle",
"dependencyKeys":[]
},
{
"key":"stock_ar15_magpul_moe_sl_k_carbine_ct_retex.bundle",
"dependencyKeys":[]
},
{
"key":"stock_base_sig_low_profile_tube_ct_retex.bundle",
"dependencyKeys":[]
},
{
"key":"balaclava/item_equipment_facecover_balaclava_black.bundle",
"dependencyKeys":[
"balaclava/wildman01head_textures_black.bundle"
]
},
{
"key":"balaclava/wildman01head_textures_black.bundle",
"dependencyKeys":[]
},
{
"key":"glasses/item_equipment_glasses_npp_retex.bundle",
"dependencyKeys":[]
},
{
"key":"rigs/cr_arscpc_retex.bundle",
"dependencyKeys":[]
},
{
"key":"rigs/item_equipment_rig_carriertactec_retex.bundle",
"dependencyKeys":[]
},
{
"key":"rigs/item_equipment_rig_tv110_retex.bundle",
"dependencyKeys":[]
},
{
"key":"rigs/item_equipment_rig_cryeavs_retex.bundle",
"dependencyKeys":[]
},
{
"key":"scope_all_vortex_razor_amg_uh-1_retex.bundle",
"dependencyKeys":[
"assets/commonassets/physics/physicsmaterials.bundle",
"assets/content/textures/holemanager/eotech_spec_mask.bundle",
"cubemaps",
"shaders"
]
},
{
"key":"tactical_all_insight_anpeq15_retex.bundle",
"dependencyKeys":[
"assets/commonassets/physics/physicsmaterials.bundle",
"assets/content/textures/holemanager/glow_particle_bright.bundle",
"assets/standard assets/effects/lightcookies/textures/flashlightcookie.bundle",
"assets/systems/effects/collimator.bundle",
"assets/systems/effects/laserbeam/laser.bundle",
"assets/systems/effects/multiflare/multiflare.bundle",
"assets/systems/effects/nightvision.bundle",
"cubemaps",
"shaders"
]
},
{
"key":"stock_ar15_fab_defense_gl_core_retex.bundle",
"dependencyKeys":[
]
},
{
"key":"scope_30mm_sig_tango6t_1_6x24_retex.bundle",
"dependencyKeys":[
"assets/commonassets/physics/physicsmaterials.bundle",
"assets/content/textures/holemanager/round_spec_mask.bundle",
"assets/systems/effects/opticsight/opticsightsmasks.bundle",
"cubemaps",
"shaders"
]
},
{
"key":"nvg_l3_gpnvg-18_anvis_retex.bundle",
"dependencyKeys":[
"assets/commonassets/physics/physicsmaterials.bundle",
"assets/content/items/equipment/glasses_6b34/glasses_6b34_glass_textures",
"cubemaps",
"shaders"
]
}
]
}

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

View File

@ -0,0 +1,603 @@
{
"ItemPresets": {
"6783f24f861dfacffe36b138": {
"_changeWeaponName": false,
"_encyclopedia": "672e37d19f1683101780773b",
"_id": "6783f24f861dfacffe36b138",
"_items": [
{
"_id": "6783f25b69d649d493cda1fd",
"_tpl": "672e37d19f1683101780773b",
"upd": {
"Repairable": {
"Durability": 100,
"MaxDurability": 100
}
}
},
{
"_id": "6783f26abcf5805ba9248ad7",
"_tpl": "55d4b9964bdc2d1d4e8b456e",
"parentId": "6783f25b69d649d493cda1fd",
"slotId": "mod_pistol_grip"
},
{
"_id": "6783f26d3b2ca6db3f36b858",
"_tpl": "55d4887d4bdc2d962f8b4570",
"parentId": "6783f25b69d649d493cda1fd",
"slotId": "mod_magazine"
},
{
"_id": "6783f2723a07e8c6a8006e9f",
"_tpl": "672e37d1249244ae3a50bb2f",
"parentId": "6783f25b69d649d493cda1fd",
"slotId": "mod_reciever"
},
{
"_id": "6783f29a304ff60a67653ddb",
"_tpl": "55d3632e4bdc2d972f8b4569",
"parentId": "6783f2723a07e8c6a8006e9f",
"slotId": "mod_barrel"
},
{
"_id": "6783f29f017667af4aeda8df",
"_tpl": "544a38634bdc2d58388b4568",
"parentId": "6783f29a304ff60a67653ddb",
"slotId": "mod_muzzle"
},
{
"_id": "6783f2a148624b6f5fe0a317",
"_tpl": "5ae30e795acfc408fb139a0b",
"parentId": "6783f29a304ff60a67653ddb",
"slotId": "mod_gas_block"
},
{
"_id": "6783f2a88b7b6cd3c9225511",
"_tpl": "5ae30db85acfc408fb139a05",
"parentId": "6783f2723a07e8c6a8006e9f",
"slotId": "mod_handguard"
},
{
"_id": "6783f2ad374903cfc652f22f",
"_tpl": "637f57a68d137b27f70c4968",
"parentId": "6783f2a88b7b6cd3c9225511",
"slotId": "mod_handguard"
},
{
"_id": "6783f2aeb598721f40ef1263",
"_tpl": "5ae30bad5acfc400185c2dc4",
"parentId": "6783f2723a07e8c6a8006e9f",
"slotId": "mod_sight_rear"
},
{
"_id": "6783f2af7cf3b743d3d8c1e2",
"_tpl": "5649be884bdc2d79388b4577",
"parentId": "6783f25b69d649d493cda1fd",
"slotId": "mod_stock"
},
{
"_id": "6783f2b54115cf68d3ffa632",
"_tpl": "55d4ae6c4bdc2d8b2f8b456e",
"parentId": "6783f2af7cf3b743d3d8c1e2",
"slotId": "mod_stock_000"
},
{
"_id": "6783f2b66dc7254a0401b1ca",
"_tpl": "55d44fd14bdc2d962f8b456e",
"parentId": "6783f25b69d649d493cda1fd",
"slotId": "mod_charge"
}
],
"_name": "M4A1 Std Painter Edition",
"_parent": "6783f25b69d649d493cda1fd",
"_type": "Preset"
},
"6783f192c8a5270c18aad6b6": {
"_changeWeaponName": false,
"_encyclopedia": "672e37d1ddaf7c656e3a634c",
"_id": "6783f192c8a5270c18aad6b6",
"_items": [
{
"_id": "6783f1a47ef435b43580168c",
"_tpl": "672e37d1ddaf7c656e3a634c",
"upd": {
"Repairable": {
"Durability": 100,
"MaxDurability": 100
}
}
},
{
"_id": "6783f1b85be1b42bf29e4a61",
"_tpl": "55d4b9964bdc2d1d4e8b456e",
"parentId": "6783f1a47ef435b43580168c",
"slotId": "mod_pistol_grip"
},
{
"_id": "6783f1bb8ce2bb9545fae1d8",
"_tpl": "55d4887d4bdc2d962f8b4570",
"parentId": "6783f1a47ef435b43580168c",
"slotId": "mod_magazine"
},
{
"_id": "6783f1c160f9c16d7f779a4d",
"_tpl": "55d355e64bdc2d962f8b4569",
"parentId": "6783f1a47ef435b43580168c",
"slotId": "mod_reciever"
},
{
"_id": "6783f1d493fa264e4493ac2e",
"_tpl": "55d3632e4bdc2d972f8b4569",
"parentId": "6783f1c160f9c16d7f779a4d",
"slotId": "mod_barrel"
},
{
"_id": "6783f1d9be58dbc9b2a069ba",
"_tpl": "544a38634bdc2d58388b4568",
"parentId": "6783f1d493fa264e4493ac2e",
"slotId": "mod_muzzle"
},
{
"_id": "6783f1daae07965124acac83",
"_tpl": "5ae30e795acfc408fb139a0b",
"parentId": "6783f1d493fa264e4493ac2e",
"slotId": "mod_gas_block"
},
{
"_id": "6783f1ddde94724c8bd6ca16",
"_tpl": "5ae30db85acfc408fb139a05",
"parentId": "6783f1c160f9c16d7f779a4d",
"slotId": "mod_handguard"
},
{
"_id": "6783f1e275d0b1ed88572ad0",
"_tpl": "637f57a68d137b27f70c4968",
"parentId": "6783f1ddde94724c8bd6ca16",
"slotId": "mod_handguard"
},
{
"_id": "6783f1e3fbc6c6dbf0aadc86",
"_tpl": "5ae30bad5acfc400185c2dc4",
"parentId": "6783f1c160f9c16d7f779a4d",
"slotId": "mod_sight_rear"
},
{
"_id": "6783f1ec39e6076911b5df9c",
"_tpl": "5649be884bdc2d79388b4577",
"parentId": "6783f1a47ef435b43580168c",
"slotId": "mod_stock"
},
{
"_id": "6783f1f09bad1af82a378d05",
"_tpl": "55d4ae6c4bdc2d8b2f8b456e",
"parentId": "6783f1ec39e6076911b5df9c",
"slotId": "mod_stock_000"
},
{
"_id": "6783f1f235ede9255929f2d4",
"_tpl": "55d44fd14bdc2d962f8b456e",
"parentId": "6783f1a47ef435b43580168c",
"slotId": "mod_charge"
}
],
"_name": "M4A1 Std Flames",
"_parent": "6783f1a47ef435b43580168c",
"_type": "Preset"
},
"6783f0fbb5c5bfbb971871e1": {
"_changeWeaponName": false,
"_encyclopedia": "672e37d1179b7b969b7577cb",
"_id": "6783f0fbb5c5bfbb971871e1",
"_items": [
{
"_id": "6783f10174bf20e471c5c055",
"_tpl": "672e37d1179b7b969b7577cb",
"upd": {
"Repairable": {
"Durability": 100,
"MaxDurability": 100
}
}
},
{
"_id": "6783f11512857c267b254af7",
"_tpl": "55d4b9964bdc2d1d4e8b456e",
"parentId": "6783f10174bf20e471c5c055",
"slotId": "mod_pistol_grip"
},
{
"_id": "6783f11aec8108543017f1e3",
"_tpl": "55d4887d4bdc2d962f8b4570",
"parentId": "6783f10174bf20e471c5c055",
"slotId": "mod_magazine"
},
{
"_id": "6783f1205747a3ea48865e73",
"_tpl": "55d355e64bdc2d962f8b4569",
"parentId": "6783f10174bf20e471c5c055",
"slotId": "mod_reciever"
},
{
"_id": "6783f1350fbe98026207e7ea",
"_tpl": "55d3632e4bdc2d972f8b4569",
"parentId": "6783f1205747a3ea48865e73",
"slotId": "mod_barrel"
},
{
"_id": "6783f13b8484c0c25a66be35",
"_tpl": "544a38634bdc2d58388b4568",
"parentId": "6783f1350fbe98026207e7ea",
"slotId": "mod_muzzle"
},
{
"_id": "6783f13dc1acd3ecae24270f",
"_tpl": "5ae30e795acfc408fb139a0b",
"parentId": "6783f1350fbe98026207e7ea",
"slotId": "mod_gas_block"
},
{
"_id": "6783f1488a3d2dc4157c8758",
"_tpl": "5ae30db85acfc408fb139a05",
"parentId": "6783f1205747a3ea48865e73",
"slotId": "mod_handguard"
},
{
"_id": "6783f151960a80ad5f9745ae",
"_tpl": "637f57a68d137b27f70c4968",
"parentId": "6783f1488a3d2dc4157c8758",
"slotId": "mod_handguard"
},
{
"_id": "6783f154906b450be0b3182f",
"_tpl": "5ae30bad5acfc400185c2dc4",
"parentId": "6783f1205747a3ea48865e73",
"slotId": "mod_sight_rear"
},
{
"_id": "6783f15600d12159f91920f6",
"_tpl": "5649be884bdc2d79388b4577",
"parentId": "6783f10174bf20e471c5c055",
"slotId": "mod_stock"
},
{
"_id": "6783f15bc0fe63d6d241fb9b",
"_tpl": "55d4ae6c4bdc2d8b2f8b456e",
"parentId": "6783f15600d12159f91920f6",
"slotId": "mod_stock_000"
},
{
"_id": "6783f1f861bc1198d4d14f7c",
"_tpl": "55d44fd14bdc2d962f8b456e",
"parentId": "6783f10174bf20e471c5c055",
"slotId": "mod_charge"
}
],
"_name": "M4A1 Std Topo",
"_parent": "6783f10174bf20e471c5c055",
"_type": "Preset"
},
"6783f026a570e11e98538c25": {
"_changeWeaponName": false,
"_encyclopedia": "672e37d1e35a6ec6e6997492",
"_id": "6783f026a570e11e98538c25",
"_items": [
{
"_id": "6783f04c9ff3e61038c7a73b",
"_tpl": "672e37d1e35a6ec6e6997492"
},
{
"_id": "6783f05f37f27dd00e59aa24",
"_tpl": "59c6633186f7740cf0493bb9",
"parentId": "6783f04c9ff3e61038c7a73b",
"slotId": "mod_gas_block"
},
{
"_id": "6783f07124277c3fd1890147",
"_tpl": "5648b1504bdc2d9d488b4584",
"parentId": "6783f05f37f27dd00e59aa24",
"slotId": "mod_handguard"
},
{
"_id": "6783f0741ec1081b46650491",
"_tpl": "5ac72e7d5acfc40016339a02",
"parentId": "6783f04c9ff3e61038c7a73b",
"slotId": "mod_muzzle"
},
{
"_id": "6783f0764bac8452114f4a95",
"_tpl": "5649ade84bdc2d1b2b8b4587",
"parentId": "6783f04c9ff3e61038c7a73b",
"slotId": "mod_pistol_grip"
},
{
"_id": "6783f0770459d79d0f33b9da",
"_tpl": "672e37d10c5f88d8ed0d056a",
"parentId": "6783f04c9ff3e61038c7a73b",
"slotId": "mod_reciever"
},
{
"_id": "6783f07a137b256bffe1cfb1",
"_tpl": "5ac50c185acfc400163398d4",
"parentId": "6783f04c9ff3e61038c7a73b",
"slotId": "mod_stock"
},
{
"_id": "6783f07c8853c5e4efc96806",
"_tpl": "5ac66bea5acfc43b321d4aec",
"parentId": "6783f04c9ff3e61038c7a73b",
"slotId": "mod_magazine"
}
],
"_name": "AK-103 Default Topo",
"_parent": "6783f04c9ff3e61038c7a73b",
"_type": "Preset"
},
"6783ec2851c792b686291cb9": {
"_changeWeaponName": false,
"_encyclopedia": "672e37d17f433cdb29072bc8",
"_id": "6783ec2851c792b686291cb9",
"_items": [
{
"_id": "6783ec33c8d50fdb6b63d3e9",
"_tpl": "672e37d17f433cdb29072bc8",
"upd": {
"FireMode": {
"FireMode": "single"
},
"Repairable": {
"Durability": 100,
"MaxDurability": 100
}
}
},
{
"_id": "657eb3773271d8578610fe2a",
"_tpl": "672e37d1861c12c7e1d94089",
"parentId": "6783ec33c8d50fdb6b63d3e9",
"slotId": "mod_pistol_grip"
},
{
"_id": "657eb3773271d8578610fe2b",
"_tpl": "672e37d19811257c1de39e6d",
"parentId": "6783ec33c8d50fdb6b63d3e9",
"slotId": "mod_magazine"
},
{
"_id": "6783ec4cf0b00cd50d9c2a87",
"_tpl": "672e37d133cc1fb4424ddb4c",
"parentId": "6783ec33c8d50fdb6b63d3e9",
"slotId": "mod_reciever"
},
{
"_id": "6783ec6e1a49dfd7571ae44e",
"_tpl": "5b2389515acfc4771e1be0c0",
"parentId": "6783ec4cf0b00cd50d9c2a87",
"slotId": "mod_scope"
},
{
"_id": "6783ec7588341583da153886",
"_tpl": "67617ec9ea1e82ea5e103054",
"parentId": "6783ec6e1a49dfd7571ae44e",
"slotId": "mod_scope_000"
},
{
"_id": "6783ec85d0fd3275f2ab164a",
"_tpl": "652910565ae2ae97b80fdf35",
"parentId": "6783ec4cf0b00cd50d9c2a87",
"slotId": "mod_barrel"
},
{
"_id": "6783ec955c4560dd83a3c26f",
"_tpl": "6529113b5ae2ae97b80fdf39",
"parentId": "6783ec85d0fd3275f2ab164a",
"slotId": "mod_muzzle"
},
{
"_id": "6783ec9892098902e42933bd",
"_tpl": "672e37d143ba463a1cdcbd7b",
"parentId": "6783ec955c4560dd83a3c26f",
"slotId": "mod_muzzle"
},
{
"_id": "6783ec9ddf30430fd30d48ef",
"_tpl": "652910bc24cbe3c74a05e5b9",
"parentId": "6783ec85d0fd3275f2ab164a",
"slotId": "mod_gas_block"
},
{
"_id": "6783ec9fb358c9d737de5800",
"_tpl": "672e37d1984bc9a10241a9c7",
"parentId": "6783ec4cf0b00cd50d9c2a87",
"slotId": "mod_handguard"
},
{
"_id": "6783eea29163d870c845e6b9",
"_tpl": "6529348224cbe3c74a05e5c4",
"parentId": "6783ec33c8d50fdb6b63d3e9",
"slotId": "mod_stock_000"
},
{
"_id": "6783eea6b0158f1b5bf6ba4e",
"_tpl": "672e37d151b832f3fb8ccbb0",
"parentId": "6783eea29163d870c845e6b9",
"slotId": "mod_stock"
},
{
"_id": "6783eeaa698962dfeeda79a3",
"_tpl": "672e37d1d9a55146e49287d6",
"parentId": "6783eea6b0158f1b5bf6ba4e",
"slotId": "mod_stock_000"
},
{
"_id": "6783eca92713d47b3f369d0b",
"_tpl": "672e37d1906226680c4e28d5",
"parentId": "6783ec33c8d50fdb6b63d3e9",
"slotId": "mod_charge"
}
],
"_name": "SIG SPEAR default black",
"_parent": "6783ec33c8d50fdb6b63d3e9",
"_type": "Preset"
},
"6783e5da52977a05d959ac2f": {
"_changeWeaponName": false,
"_encyclopedia": "672e37d1dd890afba20c10e7",
"_id": "6783e5da52977a05d959ac2f",
"_items": [
{
"_id": "6783e5f4c23d0a4830e3d069",
"_tpl": "672e37d1dd890afba20c10e7",
"upd": {
"Repairable": {
"Durability": 100,
"MaxDurability": 100
}
}
},
{
"_id": "6783e603e6cebbfe9babfb73",
"_tpl": "5cc9bcaed7f00c011c04e179",
"parentId": "6783e5f4c23d0a4830e3d069",
"slotId": "mod_pistol_grip"
},
{
"_id": "6783e60517f08a8301bbd2c5",
"_tpl": "5a3501acc4a282000d72293a",
"parentId": "6783e5f4c23d0a4830e3d069",
"slotId": "mod_magazine"
},
{
"_id": "6783e607810d48f18bc7e606",
"_tpl": "5a33ca0fc4a282000d72292f",
"parentId": "6783e5f4c23d0a4830e3d069",
"slotId": "mod_stock"
},
{
"_id": "6783e60ba048490f25da323e",
"_tpl": "5d44069ca4b9361ebd26fc37",
"parentId": "6783e607810d48f18bc7e606",
"slotId": "mod_stock"
},
{
"_id": "6783e60d0f11531e764dd864",
"_tpl": "5d00ef6dd7ad1a0940739b16",
"parentId": "6783e5f4c23d0a4830e3d069",
"slotId": "mod_handguard"
},
{
"_id": "6783e61457c31046a3d9466b",
"_tpl": "5a34fae7c4a2826c6e06d760",
"parentId": "6783e5f4c23d0a4830e3d069",
"slotId": "mod_barrel"
},
{
"_id": "6783e618cc78902eec1f2c0b",
"_tpl": "5a34fd2bc4a282329a73b4c5",
"parentId": "6783e61457c31046a3d9466b",
"slotId": "mod_muzzle"
},
{
"_id": "6783e61a7bfb5f73bdcef867",
"_tpl": "5a34fbadc4a28200741e230a",
"parentId": "6783e61457c31046a3d9466b",
"slotId": "mod_gas_block"
}
],
"_name": "RSASS Black",
"_parent": "6783e5f4c23d0a4830e3d069",
"_type": "Preset"
},
"6783eb2892780aded22f44d6": {
"_changeWeaponName": false,
"_encyclopedia": "672e37d10b7a12e6a7a50b77",
"_id": "6783eb2892780aded22f44d6",
"_items": [
{
"_id": "6783eb3a05c979d9171196e2",
"_tpl": "672e37d10b7a12e6a7a50b77",
"upd": {
"FireMode": {
"FireMode": "single"
}
}
},
{
"_id": "6783eb482a3ac74d07710776",
"_tpl": "55802f5d4bdc2dac148b458f",
"parentId": "6783eb3a05c979d9171196e2",
"slotId": "mod_pistol_grip"
},
{
"_id": "6783eb4de2e02a031c2d2eb9",
"_tpl": "59d6272486f77466146386ff",
"parentId": "6783eb3a05c979d9171196e2",
"slotId": "mod_magazine"
},
{
"_id": "6783eb54e77a16ac4853c726",
"_tpl": "672e37d1a98e0628807ba29a",
"parentId": "6783eb3a05c979d9171196e2",
"slotId": "mod_reciever"
},
{
"_id": "6783eb6f7e0a5b57278b5d8f",
"_tpl": "60658776f2cb2e02a42ace2b",
"parentId": "6783eb54e77a16ac4853c726",
"slotId": "mod_barrel"
},
{
"_id": "6783eb76f0ceaeb9063cdbf2",
"_tpl": "6065c6e7132d4d12c81fd8e1",
"parentId": "6783eb6f7e0a5b57278b5d8f",
"slotId": "mod_muzzle"
},
{
"_id": "6783eb7901da578da4b2230c",
"_tpl": "6065dc8a132d4d12c81fd8e3",
"parentId": "6783eb6f7e0a5b57278b5d8f",
"slotId": "mod_gas_block"
},
{
"_id": "6783eb7b04cdf6ff2fb14809",
"_tpl": "6065880c132d4d12c81fd8da",
"parentId": "6783eb54e77a16ac4853c726",
"slotId": "mod_handguard"
},
{
"_id": "6783eb7e73028d0ad6ba25a7",
"_tpl": "5bc09a30d4351e00367fb7c8",
"parentId": "6783eb7b04cdf6ff2fb14809",
"slotId": "mod_sight_front"
},
{
"_id": "6783eb801f0133eec60418fd",
"_tpl": "5bc09a18d4351e003562b68e",
"parentId": "6783eb54e77a16ac4853c726",
"slotId": "mod_sight_rear"
},
{
"_id": "6783eb82d4bfe4734f1968e8",
"_tpl": "606587e18900dc2d9a55b65f",
"parentId": "6783eb3a05c979d9171196e2",
"slotId": "mod_stock_001"
},
{
"_id": "6783eb85ede00f4e10fe95fa",
"_tpl": "606587d11246154cad35d635",
"parentId": "6783eb82d4bfe4734f1968e8",
"slotId": "mod_stock_000"
},
{
"_id": "6783eb8781c4dad6d094d7d5",
"_tpl": "606587bd6d0bd7580617bacc",
"parentId": "6783eb3a05c979d9171196e2",
"slotId": "mod_charge"
}
],
"_name": "CMMG MK47 short default black",
"_parent": "6783eb3a05c979d9171196e2",
"_type": "Preset"
}
}
}

File diff suppressed because it is too large Load Diff

View File

@ -0,0 +1,26 @@
{
"name": "Black Core",
"version": "1.1.6",
"main": "src/mod.js",
"license": "University of Illinois/NCSA Open Source License",
"author": "MoxoPixel",
"sptVersion": "3.10.X",
"isBundleMod": true,
"scripts": {
"setup": "npm i",
"build": "node ./build.mjs",
"buildinfo": "node ./build.mjs --verbose"
},
"devDependencies": {
"@types/node": "20.11",
"@typescript-eslint/eslint-plugin": "7.2",
"@typescript-eslint/parser": "7.2",
"archiver": "^6.0",
"eslint": "8.57",
"fs-extra": "11.2",
"ignore": "^5.2",
"tsyringe": "4.8.0",
"typescript": "5.4",
"winston": "3.12"
}
}

View File

@ -0,0 +1,236 @@
import { DependencyContainer } from "tsyringe";
import { IPostDBLoadMod } from "@spt/models/external/IPostDBLoadMod";
import { DatabaseServer } from "@spt/servers/DatabaseServer";
import { ImporterUtil } from "@spt/utils/ImporterUtil";
import { ILogger } from "@spt/models/spt/utils/ILogger";
import { PreSptModLoader } from "@spt/loaders/PreSptModLoader";
import { IDatabaseTables } from "@spt/models/spt/server/IDatabaseTables";
import { JsonUtil } from "@spt/utils/JsonUtil"
interface IHandbookEntry {
Id: string;
ParentId: string;
Price: number;
}
class BlackCore implements IPostDBLoadMod {
private db: IDatabaseTables;
private mydb: any;
private logger: ILogger;
private jsonUtil: JsonUtil;
public postDBLoad(container: DependencyContainer): void {
try {
this.logger = container.resolve<ILogger>("WinstonLogger");
this.jsonUtil = container.resolve<JsonUtil>("JsonUtil");
const databaseServer = container.resolve<DatabaseServer>("DatabaseServer");
const databaseImporter = container.resolve<ImporterUtil>("ImporterUtil");
const modLoader = container.resolve<PreSptModLoader>("PreSptModLoader");
this.db = databaseServer.getTables();
this.mydb = databaseImporter.loadRecursive(`${modLoader.getModPath("MoxoPixel-BlackCore")}database/`);
if (!this.db || !this.mydb) {
throw new Error("Failed to load required databases");
}
const modFolderName = "MoxoPixel-BlackCore";
const traders = {
"painter": "668aaff35fd574b6dcc4a686"
};
for (const newItem in this.mydb.items) {
this.cloneItem(this.mydb.items[newItem].clone, newItem);
this.addCompatibilitiesAndConflicts(this.mydb.items[newItem].clone, newItem);
const newItemLocales = this.mydb.items[newItem].locales;
for (const lang in this.db.locales.global) {
this.db.locales.global[lang][`${newItem} Name`] = newItemLocales.Name;
this.db.locales.global[lang][`${newItem} ShortName`] = newItemLocales.Shortname;
this.db.locales.global[lang][`${newItem} Description`] = newItemLocales.Description;
}
}
for (const trader in traders) this.addTraderAssort(traders[trader]);
for (const preset in this.mydb.globals.ItemPresets) {
this.db.globals.ItemPresets[preset] = this.mydb.globals.ItemPresets[preset];
}
const dbMastering = this.db.globals.config.Mastering;
for (const weapon in dbMastering) {
if (dbMastering[weapon].Name == "M4") dbMastering[weapon].Templates.push("672e37d1179b7b969b7577cb", "672e37d1ddaf7c656e3a634c", "672e37d19f1683101780773b");
if (dbMastering[weapon].Name == "AK74") dbMastering[weapon].Templates.push("672e37d1e35a6ec6e6997492");
if (dbMastering[weapon].Name == "R11SRASS") dbMastering[weapon].Templates.push("672e37d1dd890afba20c10e7");
if (dbMastering[weapon].Name == "MK47") dbMastering[weapon].Templates.push("672e37d10b7a12e6a7a50b77");
if (dbMastering[weapon].Name == "SPEAR") dbMastering[weapon].Templates.push("672e37d17f433cdb29072bc8");
}
const dbQuests = this.db.templates.quests;
for (const M4Quest in dbQuests) {
if (
dbQuests[M4Quest]._id === "5a27bb8386f7741c770d2d0a" ||
dbQuests[M4Quest]._id === "5c0d4c12d09282029f539173" ||
dbQuests[M4Quest]._id === "63a9b229813bba58a50c9ee5" ||
dbQuests[M4Quest]._id === "64e7b9bffd30422ed03dad38" ||
dbQuests[M4Quest]._id === "666314b4d7f171c4c20226c3"
) {
const availableForFinish = dbQuests[M4Quest].conditions.AvailableForFinish;
for (const condition of availableForFinish) {
if (condition.counter && condition.counter.conditions) {
for (const counterCondition of condition.counter.conditions) {
if (counterCondition.weapon) {
counterCondition.weapon.push(
"672e37d1179b7b969b7577cb",
"672e37d1ddaf7c656e3a634c",
"672e37d19f1683101780773b"
);
}
}
}
}
}
}
for (const AKQuest in dbQuests) {
if (
dbQuests[AKQuest]._id === "59c50a9e86f7745fef66f4ff" ||
dbQuests[AKQuest]._id === "61e6e60223374d168a4576a6" ||
dbQuests[AKQuest]._id === "64e7b9bffd30422ed03dad38"
) {
const availableForFinish = dbQuests[AKQuest].conditions.AvailableForFinish;
for (const condition of availableForFinish) {
if (condition.counter && condition.counter.conditions) {
for (const counterCondition of condition.counter.conditions) {
if (counterCondition.weapon) {
counterCondition.weapon.push(
"672e37d1e35a6ec6e6997492"
);
}
}
}
}
}
}
for (const MK47Quest in dbQuests) {
if (
dbQuests[MK47Quest]._id === "64e7b9bffd30422ed03dad38"
) {
const availableForFinish = dbQuests[MK47Quest].conditions.AvailableForFinish;
for (const condition of availableForFinish) {
if (condition.counter && condition.counter.conditions) {
for (const counterCondition of condition.counter.conditions) {
if (counterCondition.weapon) {
counterCondition.weapon.push(
"672e37d10b7a12e6a7a50b77",
"672e37d17f433cdb29072bc8"
);
}
}
}
}
}
}
this.logger.info("------------------------");
this.logger.info("Black Core Loaded");
} catch (error) {
this.logger.error(`Error loading BlackCore mod: ${error.message}`);
}
}
private cloneItem(itemToClone: string, blackCoreID: string): void {
if (!itemToClone || !blackCoreID) {
this.logger.error("Invalid parameters passed to cloneItem");
return;
}
if (!this.mydb.items[blackCoreID]?.enable) {
return;
}
if (!this.db.templates.items[itemToClone]) {
this.logger.error(`Template item ${itemToClone} not found`);
return;
}
if (this.mydb.items[blackCoreID].enable == true) {
let blackCoreItemOut = this.jsonUtil.clone(this.db.templates.items[itemToClone]);
blackCoreItemOut._id = blackCoreID;
blackCoreItemOut = this.compareAndReplace(blackCoreItemOut, this.mydb.items[blackCoreID]["items"]);
const bcCompatibilities: object = (typeof this.mydb.items[blackCoreID].bcCompatibilities == "undefined") ? {} : this.mydb.items[blackCoreID].bcCompatibilities;
const bcConflicts: Array<string> = (typeof this.mydb.items[blackCoreID].bcConflicts == "undefined") ? [] : this.mydb.items[blackCoreID].bcConflicts;
for (const modSlotName in bcCompatibilities) {
for (const slot of blackCoreItemOut._props.Slots) {
if (slot._name === modSlotName) for (const id of bcCompatibilities[modSlotName]) slot._props.filters[0].Filter.push(id);
}
}
blackCoreItemOut._props.ConflictingItems = blackCoreItemOut._props.ConflictingItems.concat(bcConflicts);
this.db.templates.items[blackCoreID] = blackCoreItemOut;
const handbookEntry: IHandbookEntry = {
"Id": blackCoreID,
"ParentId": this.mydb.items[blackCoreID]["handbook"]["ParentId"],
"Price": this.mydb.items[blackCoreID]["handbook"]["Price"]
};
this.db.templates.handbook.Items.push(handbookEntry);
}
}
private compareAndReplace(originalItem: any, attributesToChange: any): any {
for (const key in attributesToChange) {
if ((["boolean", "string", "number"].includes(typeof attributesToChange[key])) || Array.isArray(attributesToChange[key])) {
if (key in originalItem) originalItem[key] = attributesToChange[key];
else this.logger.error("Error finding the attribute: \"" + key + "\", default value is used instead.");
}
else originalItem[key] = this.compareAndReplace(originalItem[key], attributesToChange[key]);
}
return originalItem;
}
private addCompatibilitiesAndConflicts(itemClone: string, blackCoreID: string): void {
for (const item in this.db.templates.items) {
if (item in this.mydb.items) continue;
const slots = (typeof this.db.templates.items[item]._props.Slots === "undefined") ? [] : this.db.templates.items[item]._props.Slots;
const chambers = (typeof this.db.templates.items[item]._props.Chambers === "undefined") ? [] : this.db.templates.items[item]._props.Chambers;
const cartridges = (typeof this.db.templates.items[item]._props.Cartridges === "undefined") ? [] : this.db.templates.items[item]._props.Cartridges;
const combined = slots.concat(chambers, cartridges)
for (const entry of combined) {
for (const id of entry._props.filters[0].Filter) {
if (id === itemClone) entry._props.filters[0].Filter.push(blackCoreID);
}
}
const conflictingItems = (typeof this.db.templates.items[item]._props.ConflictingItems === "undefined") ? [] : this.db.templates.items[item]._props.ConflictingItems;
for (const conflictID of conflictingItems) if (conflictID === itemClone) conflictingItems.push(blackCoreID);
}
}
private addTraderAssort(trader: string): void {
if (!this.db.traders[trader]?.assort || !this.mydb.traders[trader]?.assort) {
this.logger.error(`Invalid trader assort data for trader: ${trader}`);
return;
}
for (const item in this.mydb.traders[trader].assort.items) {
this.db.traders[trader].assort.items.push(this.mydb.traders[trader].assort.items[item]);
}
for (const item in this.mydb.traders[trader].assort.barter_scheme) {
this.db.traders[trader].assort.barter_scheme[item] = this.mydb.traders[trader].assort.barter_scheme[item];
}
for (const item in this.mydb.traders[trader].assort.loyal_level_items) {
this.db.traders[trader].assort.loyal_level_items[item] = this.mydb.traders[trader].assort.loyal_level_items[item];
}
}
}
module.exports = { mod: new BlackCore() }

View File

@ -193,13 +193,13 @@ PmcWaveDistribution = 0.8
## Multiplies wave counts seen in the server's mapConfig.json by this number ## Multiplies wave counts seen in the server's mapConfig.json by this number
# Setting type: Double # Setting type: Double
# Default value: 1.2 # Default value: 1
# Acceptable value range: From 0 to 10 # Acceptable value range: From 0 to 10
ScavWaveQuantity = 1 ScavWaveQuantity = 1
## Multiplies wave counts seen in the server's mapConfig.json by this number ## Multiplies wave counts seen in the server's mapConfig.json by this number
# Setting type: Double # Setting type: Double
# Default value: 1.2 # Default value: 1
# Acceptable value range: From 0 to 10 # Acceptable value range: From 0 to 10
PmcWaveQuantity = 1 PmcWaveQuantity = 1

View File

@ -0,0 +1,31 @@
{
"name": "Make VAL-VSS Great Again",
"version": "1.0.7",
"sptVersion": "3.10.x",
"license": "MIT",
"loadBefore": [],
"loadAfter": [],
"incompatibilities": [],
"isBundleMod": false,
"main": "src/mod.js",
"scripts": {
"setup": "npm i",
"build": "node ./build.mjs",
"buildinfo": "node ./build.mjs --verbose"
},
"devDependencies": {
"@types/node": "20.11",
"@typescript-eslint/eslint-plugin": "7.2",
"@typescript-eslint/parser": "7.2",
"archiver": "^6.0",
"eslint": "8.57",
"fs-extra": "11.2",
"ignore": "^5.2",
"tsyringe": "4.8.0",
"typescript": "5.4",
"winston": "3.12"
},
"author": "z_Hacker228",
"contributors": [],
"license": "MIT"
}

View File

@ -0,0 +1,91 @@
import { DependencyContainer } from "tsyringe";
import { IPostDBLoadMod } from "@spt/models/external/IPostDBLoadMod";
import { IPostAkiLoadMod } from "@spt/models/external/IPostAkiLoadMod";
import { DatabaseServer } from "@spt/servers/DatabaseServer";
import { ILogger } from "@spt/models/spt/utils/ILogger";
import { LogTextColor } from "@spt/models/spt/logging/LogTextColor";
class Mod implements IPostDBLoadMod, IPostAkiLoadMod {
public IPostAkiLoadMod(container: DependencyContainer): void {
const logger = container.resolve<ILogger>("WinstonLogger");
logger.info("Mod: Make VSS Great Again version: 1.0.7 by: Hacker228 loaded");
}
public postDBLoad(container: DependencyContainer): void {
const databaseServer = container.resolve<DatabaseServer>("DatabaseServer");
const tables = databaseServer.getTables();
// Define constant values
const HEAT_FACTOR_BY_SHOT = 2.17;
const HEAT_FACTOR_GUN = 0.98;
const HEAT_FACTOR_AMMO_SP_5 = 1.273;
const HEAT_FACTOR_AMMO_SP_6 = 1.34;
const HEAT_FACTOR_AMMO_PUB_9 = 1.3;
const HEAT_FACTOR_AMMO_SPP = 1.206;
const HEAT_FACTOR_AMMO_BP = 1.55;
// Define item IDs and names to update
const itemsToUpdate = [
{ id: "57838ad32459774a17445cd2", name_gun: "VSS" },
{ id: "57c44b372459772d2b39b8ce", name_gun: "VAL" },
{ id: "651450ce0e00edc794068371", name_gun: "SR-3m" },
{ id: "66fd8da18afded28fc000006", name_gun: "VAL-Shiny" }
];
const ammoToUpdate = [
{ id: "57a0dfb82459774d3078b56c", heatFactor: HEAT_FACTOR_AMMO_SP_5, name_ammo: "SP-5" },
{ id: "57a0e5022459774d1673f889", heatFactor: HEAT_FACTOR_AMMO_SP_6, name_ammo: "SP-6" },
{ id: "61962d879bb3d20b0946d385", heatFactor: HEAT_FACTOR_AMMO_PUB_9, name_ammo: "PUB-9" },
{ id: "5c0d668f86f7747ccb7f13b2", heatFactor: HEAT_FACTOR_AMMO_SPP, name_ammo: "SPP" },
{ id: "5c0d688c86f77413ae3407b2", heatFactor: HEAT_FACTOR_AMMO_SPP, name_ammo: "BP" }
];
// Define delay before starting to log messages in seconds
const initialDelayInSeconds = 3;
// Use setTimeout for initial delay
setTimeout(() => {
// Log an empty line before the first message
const logger = container.resolve<ILogger>("WinstonLogger");
logger.info("");
itemsToUpdate.forEach(({ id, name_gun }) => {
const item = tables.templates.items[id];
if (item) {
// Update properties using constants
item._props.HeatFactorByShot = HEAT_FACTOR_BY_SHOT;
item._props.HeatFactorGun = HEAT_FACTOR_GUN;
// Log message if the item ID is found
logger.logWithColor(`${name_gun} item ID found. Сhanges applied.`, LogTextColor.GREEN);
} else {
// Log message if the item ID is not found
logger.logWithColor(`${name_gun} item ID not found. Changes not applied.`, LogTextColor.RED);
}
});
ammoToUpdate.forEach(({ id, heatFactor, name_ammo }) => {
const ammoItem = tables.templates.items[id];
if (ammoItem) {
// Update ammo properties
ammoItem._props.HeatFactor = heatFactor;
// Log message if the ammo ID is found
logger.logWithColor(`${name_ammo} item ID found. Changes applied.`, LogTextColor.GREEN);
} else {
// Log message if the ammo ID is not found
logger.logWithColor(`${name_ammo} item ID not found. Changes not applied.`, LogTextColor.RED);
}
});
// Log an empty line after all messages
logger.info("");
}, initialDelayInSeconds * 1000); // Convert seconds to milliseconds
}
}
module.exports = { mod: new Mod() };

View File

@ -0,0 +1,31 @@
{
"name": "Make VAL-VSS Great Again",
"version": "1.0.7",
"sptVersion": "3.10.x",
"license": "MIT",
"loadBefore": [],
"loadAfter": [],
"incompatibilities": [],
"isBundleMod": false,
"main": "src/mod.js",
"scripts": {
"setup": "npm i",
"build": "node ./build.mjs",
"buildinfo": "node ./build.mjs --verbose"
},
"devDependencies": {
"@types/node": "20.11",
"@typescript-eslint/eslint-plugin": "7.2",
"@typescript-eslint/parser": "7.2",
"archiver": "^6.0",
"eslint": "8.57",
"fs-extra": "11.2",
"ignore": "^5.2",
"tsyringe": "4.8.0",
"typescript": "5.4",
"winston": "3.12"
},
"author": "z_Hacker228",
"contributors": [],
"license": "MIT"
}

View File

@ -0,0 +1,90 @@
import { DependencyContainer } from "tsyringe";
import { IPostDBLoadMod } from "@spt/models/external/IPostDBLoadMod";
import { IPostAkiLoadMod } from "@spt/models/external/IPostAkiLoadMod";
import { DatabaseServer } from "@spt/servers/DatabaseServer";
import { ILogger } from "@spt/models/spt/utils/ILogger";
import { LogTextColor } from "@spt/models/spt/logging/LogTextColor";
class Mod implements IPostDBLoadMod, IPostAkiLoadMod {
public IPostAkiLoadMod(container: DependencyContainer): void {
const logger = container.resolve<ILogger>("WinstonLogger");
logger.info("Mod: Make VSS Great Again version: 1.0.7 by: Hacker228 loaded");
}
public postDBLoad(container: DependencyContainer): void {
const databaseServer = container.resolve<DatabaseServer>("DatabaseServer");
const tables = databaseServer.getTables();
// Define constant values
const HEAT_FACTOR_BY_SHOT = 2.17;
const HEAT_FACTOR_GUN = 0.98;
const HEAT_FACTOR_AMMO_SP_5 = 1.273;
const HEAT_FACTOR_AMMO_SP_6 = 1.34;
const HEAT_FACTOR_AMMO_PUB_9 = 1.3;
const HEAT_FACTOR_AMMO_SPP = 1.206;
const HEAT_FACTOR_AMMO_BP = 1.55;
// Define item IDs and names to update
const itemsToUpdate = [
{ id: "57838ad32459774a17445cd2", name_gun: "VSS" },
{ id: "57c44b372459772d2b39b8ce", name_gun: "VAL" },
{ id: "651450ce0e00edc794068371", name_gun: "SR-3m" }
];
const ammoToUpdate = [
{ id: "57a0dfb82459774d3078b56c", heatFactor: HEAT_FACTOR_AMMO_SP_5, name_ammo: "SP-5" },
{ id: "57a0e5022459774d1673f889", heatFactor: HEAT_FACTOR_AMMO_SP_6, name_ammo: "SP-6" },
{ id: "61962d879bb3d20b0946d385", heatFactor: HEAT_FACTOR_AMMO_PUB_9, name_ammo: "PUB-9" },
{ id: "5c0d668f86f7747ccb7f13b2", heatFactor: HEAT_FACTOR_AMMO_SPP, name_ammo: "SPP" },
{ id: "5c0d688c86f77413ae3407b2", heatFactor: HEAT_FACTOR_AMMO_SPP, name_ammo: "BP" }
];
// Define delay before starting to log messages in seconds
const initialDelayInSeconds = 3;
// Use setTimeout for initial delay
setTimeout(() => {
// Log an empty line before the first message
const logger = container.resolve<ILogger>("WinstonLogger");
logger.info("");
itemsToUpdate.forEach(({ id, name_gun }) => {
const item = tables.templates.items[id];
if (item) {
// Update properties using constants
item._props.HeatFactorByShot = HEAT_FACTOR_BY_SHOT;
item._props.HeatFactorGun = HEAT_FACTOR_GUN;
// Log message if the item ID is found
logger.logWithColor(`${name_gun} item ID found. Сhanges applied.`, LogTextColor.GREEN);
} else {
// Log message if the item ID is not found
logger.logWithColor(`${name_gun} item ID not found. Changes not applied.`, LogTextColor.RED);
}
});
ammoToUpdate.forEach(({ id, heatFactor, name_ammo }) => {
const ammoItem = tables.templates.items[id];
if (ammoItem) {
// Update ammo properties
ammoItem._props.HeatFactor = heatFactor;
// Log message if the ammo ID is found
logger.logWithColor(`${name_ammo} item ID found. Changes applied.`, LogTextColor.GREEN);
} else {
// Log message if the ammo ID is not found
logger.logWithColor(`${name_ammo} item ID not found. Changes not applied.`, LogTextColor.RED);
}
});
// Log an empty line after all messages
logger.info("");
}, initialDelayInSeconds * 1000); // Convert seconds to milliseconds
}
}
module.exports = { mod: new Mod() };

View File

@ -0,0 +1,28 @@
[General]
gameName=spt
modid=0
version=d2025.1.15.0
newestVersion=
category="1,"
nexusFileStatus=1
installationFile=Make-3M-VAL-VSS- Great-Again.zip
repository=Nexus
ignoredVersion=
comments=
notes=
nexusDescription=
url=
hasCustomURL=true
lastNexusQuery=
lastNexusUpdate=
nexusLastModified=2025-01-16T01:50:38Z
nexusCategory=0
converted=false
validated=false
color=@Variant(\0\0\0\x43\0\xff\xff\0\0\0\0\0\0\0\0)
tracked=0
[installedFiles]
1\modid=0
1\fileid=0
size=1

28
mods/Painter/meta.ini Normal file
View File

@ -0,0 +1,28 @@
[General]
gameName=spt
modid=0
version=d2025.1.15.0
newestVersion=
category="1,"
nexusFileStatus=1
installationFile=MoxoPixel-Painter.zip
repository=Nexus
ignoredVersion=
comments=
notes=
nexusDescription=
url=
hasCustomURL=false
lastNexusQuery=
lastNexusUpdate=
nexusLastModified=2025-01-16T01:48:28Z
nexusCategory=0
converted=false
validated=false
color=@Variant(\0\0\0\x43\0\xff\xff\0\0\0\0\0\0\0\0)
tracked=0
[installedFiles]
1\modid=0
1\fileid=0
size=1

View File

@ -0,0 +1,21 @@
{
"manifest":
[
{
"key": "mysterybox.bundle",
"dependencyKeys": [
"cubemaps",
"shaders",
"assets/commonassets/physics/physicsmaterials.bundle"
]
},
{
"key": "mysterybox_2.bundle",
"dependencyKeys": [
"cubemaps",
"shaders",
"assets/commonassets/physics/physicsmaterials.bundle"
]
}
]
}

Binary file not shown.

Binary file not shown.

View File

@ -0,0 +1,5 @@
{
"enableRepeatableQuests": true,
"//": "DO NOT TURN OFF LOOT BOXES IF YOU HAVE ONE OF PAINTERS LOOT BOXES IN YOUR STASH",
"enableLootBoxes": true
}

View File

@ -0,0 +1,145 @@
{
"items": [
{
"_id": "672e2804a0529208b4e10e18",
"_tpl": "5c0a840b86f7742ffa4f2482",
"parentId": "hideout",
"slotId": "hideout",
"upd": {
"UnlimitedCount": true,
"StackObjectsCount": 2
}
},
{
"_id": "672e284a363b798192b802af",
"_tpl": "54527ac44bdc2d36668b4567",
"parentId": "hideout",
"slotId": "hideout",
"upd": {
"UnlimitedCount": true,
"StackObjectsCount": 9999999,
"BuyRestrictionMax": 180,
"BuyRestrictionCurrent": 0
}
},
{
"_id": "672e289bb4096716fcb918a7",
"_tpl": "5a6086ea4f39f99cd479502f",
"parentId": "hideout",
"slotId": "hideout",
"upd": {
"UnlimitedCount": true,
"StackObjectsCount": 9999999,
"BuyRestrictionMax": 90,
"BuyRestrictionCurrent": 0
}
},
{
"_id": "668ff5bde41a0cce3b142464",
"_tpl": "668ff5bde41a0cce3b142464",
"parentId": "hideout",
"slotId": "hideout",
"upd": {
"UnlimitedCount": false,
"StackObjectsCount": 999
}
},
{
"_id": "668ff5bde41a0cce3b142465",
"_tpl": "668ff5bde41a0cce3b142464",
"parentId": "hideout",
"slotId": "hideout",
"upd": {
"UnlimitedCount": false,
"StackObjectsCount": 999
}
},
{
"_id": "6699546547ad52e0fccf6da9",
"_tpl": "6699546547ad52e0fccf6da9",
"parentId": "hideout",
"slotId": "hideout",
"upd": {
"UnlimitedCount": false,
"StackObjectsCount": 999
}
},
{
"_id": "6699546547ad52e0fccf6da0",
"_tpl": "6699546547ad52e0fccf6da9",
"parentId": "hideout",
"slotId": "hideout",
"upd": {
"UnlimitedCount": false,
"StackObjectsCount": 999
}
}
],
"barter_scheme": {
"672e2804a0529208b4e10e18": [
[
{
"count": 17500000,
"_tpl": "5449016a4bdc2d6f028b456f"
}
]
],
"672e284a363b798192b802af": [
[
{
"count": 680,
"_tpl": "5449016a4bdc2d6f028b456f"
}
]
],
"672e289bb4096716fcb918a7": [
[
{
"count": 980,
"_tpl": "5449016a4bdc2d6f028b456f"
}
]
],
"668ff5bde41a0cce3b142464": [
[
{
"count": 500000,
"_tpl": "5449016a4bdc2d6f028b456f"
}
]
],
"668ff5bde41a0cce3b142465": [
[
{
"count": 60,
"_tpl": "5d235b4d86f7742e017bc88a"
}
]
],
"6699546547ad52e0fccf6da9": [
[
{
"count": 400000,
"_tpl": "5449016a4bdc2d6f028b456f"
}
]
],
"6699546547ad52e0fccf6da0": [
[
{
"count": 50,
"_tpl": "5d235b4d86f7742e017bc88a"
}
]
]
},
"loyal_level_items": {
"672e2804a0529208b4e10e18": 4,
"672e284a363b798192b802af": 4,
"672e289bb4096716fcb918a7": 4,
"668ff5bde41a0cce3b142464": 2,
"668ff5bde41a0cce3b142465": 4,
"6699546547ad52e0fccf6da9": 2,
"6699546547ad52e0fccf6da0": 4
}
}

View File

@ -0,0 +1,123 @@
{
"_id": "668aaff35fd574b6dcc4a686",
"working": true,
"availableInRaid": false,
"items_buy": {
"category": [
"5448ecbe4bdc2d60728b4568"
],
"id_list": []
},
"items_buy_prohibited": {},
"customization_seller": false,
"name": "Ivan Samoylov",
"surname": "Unknown",
"nickname": "Painter",
"location": "Tarkov Suburbs",
"avatar": "/files/trader/avatar/painter.jpg",
"balance_rub": 5000000,
"balance_dol": 0,
"balance_eur": 0,
"unlockedByDefault": true,
"discount": 0,
"discount_end": 0,
"buyer_up": false,
"currency": "RUB",
"nextResupply": 1631489718,
"repair": {
"availability": false,
"quality": "0",
"excluded_id_list": [],
"excluded_category": [],
"currency": "5449016a4bdc2d6f028b456f",
"currency_coefficient": 1,
"price_rate": 1
},
"insurance": {
"availability": false,
"min_payment": 0,
"min_return_hour": 0,
"max_return_hour": 0,
"max_storage_time": 99,
"excluded_category": []
},
"isCanTransferItems": false,
"gridHeight": 300,
"loyaltyLevels": [{
"minLevel": 1,
"minSalesSum": 0,
"minStanding": 0,
"buy_price_coef": 48,
"repair_price_coef": 0,
"insurance_price_coef": 0,
"exchange_price_coef": 0,
"heal_price_coef": 0
},
{
"minLevel": 9,
"minSalesSum": 500000,
"minStanding": 0.04,
"buy_price_coef": 48,
"repair_price_coef": 0,
"insurance_price_coef": 0,
"exchange_price_coef": 0,
"heal_price_coef": 0
},
{
"minLevel": 20,
"minSalesSum": 1300000,
"minStanding": 0.1,
"buy_price_coef": 48,
"repair_price_coef": 0,
"insurance_price_coef": 0,
"exchange_price_coef": 0,
"heal_price_coef": 0
},
{
"minLevel": 28,
"minSalesSum": 3000000,
"minStanding": 0.14,
"buy_price_coef": 48,
"repair_price_coef": 0,
"insurance_price_coef": 0,
"exchange_price_coef": 0,
"heal_price_coef": 0
}
],
"prohibitedTransferableItems": {
"category": [],
"id_list": []
},
"sell_category": [
"5b5f78dc86f77409407a7f8e",
"5b5f71b386f774093f2ecf11",
"5b5f71c186f77409407a7ec0",
"5b5f71de86f774093f2ecf13",
"5b5f724186f77447ed5636ad",
"5b5f736886f774094242f193",
"5b5f73ec86f774093e6cb4fd",
"5b5f74cc86f77447ec5d770a",
"5b5f750686f774093e6cb503",
"5b5f751486f77447ec5d770c",
"5b5f752e86f774093e6cb505",
"5b5f754a86f774094242f19b",
"5b5f755f86f77447ec5d770e",
"5b5f757486f774093e6cb507",
"5b5f75b986f77447ec5d7710",
"5b5f75c686f774094242f19f",
"5b5f75e486f77447ec5d7712",
"5b5f760586f774093e6cb509",
"5b5f761f86f774094242f1a1",
"5b5f764186f77447ec5d7714",
"5b47574386f77428ca22b33e",
"5b47574386f77428ca22b341",
"5b47574386f77428ca22b345",
"5b47574386f77428ca22b2ef",
"5b47574386f77428ca22b343"
],
"sell_modifier_for_prohibited_items": 0,
"transferableItems": {
"category": [],
"id_list": []
}
}

View File

@ -0,0 +1,53 @@
{
"painter_1 name": "Taped Up",
"painter_1 description": "I need your help in enhancing the tactical efficiency of PMCs across Tarkov. Find various types of tape, including duct tape and insulating tape, so I can craft specialized magazines. These taped magazines not only allow PMCs to easily identify their loaded ammunition but also assist them in quickly locating dropped magazines during intense firefights. The Tarkov area is a dangerous place, and every advantage counts.",
"painter_1 note": "Some people are scared of anybody who runs free.",
"painter_1 failMessageText": "",
"painter_1 successMessageText": "Nice work finding all the tape. This will get my shop running smoothly again. Here's a little something for your trouble. I appreciate your help.",
"painter_1 location": "any",
"672e31c3262af62a8eb157cd": "Find and handover duct tape",
"672e31d7701987cf15698b30": "Find and handover insulating tape",
"painter_2 name": "Topographics",
"painter_2 description": "I need you to find some topographic maps, I can use them to create templates for some really good looking paints.",
"painter_2 failMessageText": "",
"painter_2 successMessageText": "Perfect. I'll get to work on these paints right away. They will look crisp.",
"672e323797a187aabc88ca4a": "Find and handover topographic maps",
"painter_3 name": "Dig Deep",
"painter_3 description": "In the gritty aftermath of a merciless SCAV raid on my workshop, those ruthless scavengers made off with a cache of weapons I had poured my blood, sweat, and tears into. I've managed to uncover their haunting whereabouts, and now it's time to make them rue the day they crossed me. Venture into their den, deliver a resounding message, and ensure they never dare to pull such audacious moves again. It's payback time in Tarkov, and vengeance is the only currency they'll understand.",
"painter_3 failMessageText": "",
"painter_3 successMessageText": "Thank you. I owe you one.",
"672e3295e4287b00f37700c1": "Eliminate 10 Scavs on Customs",
"painter_4 name": "Workshop Refurbishment",
"painter_4 description": "The echoes of my workshop's destruction still resonate, but with your help, I can start the journey towards rebuilding. I've managed to salvage some essential tools and materials, but I need more to bring my workshop back to life. Your task is to scour the outskirts of Tarkov for valuable resources. Search for industrial supplies, rare metals, and electronic components. Beware of the dangers lurking in the shadows, as scavengers and rival factions may try to hinder your progress. Once you've gathered the necessary materials, bring them back to me so we can begin the workshop's refurbishment.",
"painter_4 failMessageText": "",
"painter_4 successMessageText": "You've done it! With these materials, I can finally begin the process of refurbishing my workshop. As a token of my gratitude, take this reward.",
"painter_4 location": "any",
"672e32c9be76a4ab7682ece9": "Find and handover toolset",
"672e32d8386445826a2adfee": "Find and handover bolts",
"672e32e7eb649d0132dfc0db": "Find and handover screw nuts",
"painter_5 name": "Radio Silence",
"painter_5 description": "With my workshop running smoothly again, I need to find a more secured way to communicate with my contacts in the field. I've heard rumors of a powerful radio transmitter that can reach all corners of Tarkov. This transmitter will allow me to send and receive critical information, ensuring that my operations run smoothly. Your task is to locate the radio transmitter and bring it back to me. Be cautious, as rival factions may try to intercept the transmitter and prevent you from completing your mission. Once you've secured the transmitter, return to me so we can establish a secure line of communication.",
"painter_5 failMessageText": "",
"painter_5 successMessageText": "Great! With this radio transmitter, I can now communicate with my contacts in the field without any interruptions. Here's a little something for your efforts. I appreciate your help.",
"painter_5 location": "any",
"672e33074cd02462a61760a2": "Find and handover COFDM Wireless Signal Transmitter",
"painter_6 name": "Dangerous Waters",
"painter_6 description": "A group of PMCs has been causing chaos in the Tarkov area, disrupting the fragile balance of power. They've been targeting innocent civilians, looting valuable resources, and spreading fear throughout the region. It's time to put an end to their reign of terror and restore peace to the land. Your mission is to eliminate the rogue PMCs and bring justice to those who have suffered at their hands. Be prepared for a fierce battle, as these rogue PMCs are well-equipped and highly trained. Once you've neutralized the threat, return to me so we can celebrate the victory and honor the fallen. My intel says they are currently operating in the Shoreline area.",
"painter_6 failMessageText": "",
"painter_6 successMessageText": "Nice. Now, go and get some rest. You've earned it.",
"672e334a39064994fc3bd86f": "Eliminate 15 PMCs on Shoreline",
"painter_7 name": "Born Free",
"painter_7 description": "I need you to find an insane amount of gun powder and plexiglass. I have a special project in mind and I need these materials to make it happen. Good luck!",
"painter_7 failMessageText": "",
"painter_7 successMessageText": "Good.",
"painter_7 location": "any",
"672e33753bc2b4d394df066d": "Find and handover Gunpowder Kite",
"672e338893682a2593697a37": "Find and handover Gunpowder Eagle",
"672e339460bf295e1f0771b5": "Find and handover Gunpowder Hawk",
"672e339f6a58d92a168c9845": "Find and handover Piece of plexiglass",
"painter_8 name": "Shrink Wrap",
"painter_8 description": "So... I heard some PMCs are pissed about your involvment with my gambling business. They say that WE ripped them off. I don't know why they invlolve you in the dicussion but here we are. Maybe because you provided me with the resuources to build it up? Who knows but you should get ready to defend yourself. It's time to get bloody creative.",
"painter_8 failMessageText": "",
"painter_8 successMessageText": "This is... What did I just witness? Anyways... Now I can start selling the ammunition you salvaged from the PMCs.",
"672e33c986ff5b896eb503cd": "Eliminate 100 PMC"
}

View File

@ -0,0 +1,53 @@
{
"painter_1 name": "Aufgeklebt",
"painter_1 description": "Ich brauche deine Hilfe, um die taktische Effizienz von PMCs in ganz Tarkov zu verbessern. Finde verschiedene Arten von Klebeband, darunter auch Isolierband, damit ich spezielle Magazine herstellen kann. Diese verklebten Magazine ermöglichen es PMCs nicht nur, ihre geladene Munition leicht zu identifizieren, sondern helfen ihnen auch dabei, bei heftigen Feuergefechten schnell heruntergefallene Magazine zu finden. Das Gebiet von Tarkov ist ein gefährlicher Ort und jeder Vorteil zählt.",
"painter_1 note": "Manche Menschen haben Angst vor jedem, der frei herumläuft.",
"painter_1 failMessageText": "",
"painter_1 successMessageText": "Gute Arbeit, das ganze Klebeband zu finden. Damit läuft mein Laden wieder reibungslos. Hier ist eine Kleinigkeit für Ihre Mühe. Ich weiß Ihre Hilfe zu schätzen.",
"painter_1 location": "any",
"672e31c3262af62a8eb157cd": "Klebeband finden und übergeben",
"672e31d7701987cf15698b30": "Isolierband finden und übergeben",
"painter_2 name": "Topographie",
"painter_2 description": "Du musst für mich ein paar topografische Karten finden, ich kann sie verwenden, um Vorlagen für ein paar richtig gut aussehende Gemälde zu erstellen.",
"painter_2 failMessageText": "",
"painter_2 successMessageText": "Perfekt. Ich werde mich sofort an die Arbeit mit diesen Farben machen. Sie werden so gut aussehen.",
"672e323797a187aabc88ca4a": "Topografische Karten finden und weitergeben",
"painter_3 name": "Graben Sie Tief",
"painter_3 description": "Nach einem gnadenlosen SCAV-Überfall auf meine Werkstatt haben diese skrupellosen Plünderer einen Waffenvorrat erbeutet, in den ich mein ganzes Herzblut gesteckt hatte. Ich habe es geschafft, ihren geheimnisvollen Aufenthaltsort aufzudecken, und jetzt ist es an der Zeit, sie den Tag bereuen zu lassen, an dem sie mir in die Quere gekommen sind. Wage dich in ihre Höhle, überbringe eine klare Botschaft und stelle sicher, dass sie nie wieder so dreiste Aktionen durchführen. In Tarkov ist Vergeltung angesagt, und Rache ist die einzige Währung, die sie verstehen.",
"painter_3 failMessageText": "",
"painter_3 successMessageText": "Danke. Ich schulde dir was.",
"672e3295e4287b00f37700c1": "Eliminiere 10 Scavs beim Customs",
"painter_4 name": "Werkstattsanierung",
"painter_4 description": "Die Echos der Zerstörung meiner Werkstatt sind noch immer zu spüren, aber mit deiner Hilfe kann ich mit dem Wiederaufbau beginnen. Ich konnte einige wichtige Werkzeuge und Materialien retten, aber ich brauche noch mehr, um meine Werkstatt wieder zum Leben zu erwecken. Deine Aufgabe ist es, die Außenbezirke von Tarkov nach wertvollen Ressourcen abzusuchen. Suche nach Industriebedarf, seltenen Metallen und elektronischen Bauteilen. Hüte dich vor den Gefahren, die im Schatten lauern, denn Plünderer und rivalisierende Fraktionen könnten versuchen, deinen Fortschritt zu behindern. Sobald du die notwendigen Materialien gesammelt hast, bring sie zu mir zurück, damit wir mit der Renovierung der Werkstatt beginnen können.",
"painter_4 failMessageText": "",
"painter_4 successMessageText": "Ihr habt es geschafft! Mit diesen Materialien kann ich endlich mit der Renovierung meiner Werkstatt beginnen. Als Zeichen meiner Dankbarkeit nehmt diese Belohnung an.",
"painter_4 location": "any",
"672e32c9be76a4ab7682ece9": "Toolset finden und übergeben",
"672e32d8386445826a2adfee": "Bolzen finden und übergeben",
"672e32e7eb649d0132dfc0db": "Schraubenmuttern finden und übergeben",
"painter_5 name": "Funkstille",
"painter_5 description": "Da meine Werkstatt wieder reibungslos läuft, muss ich einen sichereren Weg finden, um mit meinen Kontakten vor Ort zu kommunizieren. Ich habe Gerüchte über einen leistungsstarken Funksender gehört, der alle Ecken von Tarkov erreichen kann. Mit diesem Sender kann ich wichtige Informationen senden und empfangen und so sicherstellen, dass meine Abläufe reibungslos ablaufen. Ihre Aufgabe ist es, den Funksender zu finden und ihn mir zurückzubringen. Seien Sie vorsichtig, da rivalisierende Fraktionen versuchen könnten, den Sender abzufangen und Sie daran zu hindern, Ihre Mission abzuschließen. Sobald Sie den Sender gesichert haben, kehren Sie zu mir zurück, damit wir eine sichere Kommunikationslinie einrichten können.",
"painter_5 failMessageText": "",
"painter_5 successMessageText": "Großartig! Mit diesem Funksender kann ich jetzt ohne Unterbrechungen mit meinen Kontakten vor Ort kommunizieren. Hier ist eine kleine Belohnung für Ihre Bemühungen. Ich weiß Ihre Hilfe zu schätzen.",
"painter_5 location": "any",
"672e33074cd02462a61760a2": "COFDM-Funksignalsender finden und übergeben",
"painter_6 name": "Gefährliche Gewässer",
"painter_6 description": "Eine Gruppe von PMCs hat in der Gegend von Tarkov Chaos verursacht und das fragile Kräftegleichgewicht gestört. Sie haben unschuldige Zivilisten ins Visier genommen, wertvolle Ressourcen geplündert und in der gesamten Region Angst verbreitet. Es ist Zeit, ihrer Schreckensherrschaft ein Ende zu setzen und den Frieden im Land wiederherzustellen. Ihre Mission ist es, die abtrünnigen PMCs zu eliminieren und denjenigen Gerechtigkeit widerfahren zu lassen, die unter ihnen gelitten haben. Machen Sie sich auf einen erbitterten Kampf gefasst, denn diese abtrünnigen PMCs sind gut ausgerüstet und bestens ausgebildet. Sobald Sie die Bedrohung neutralisiert haben, kehren Sie zu mir zurück, damit wir den Sieg feiern und die Gefallenen ehren können. Meine Informationen besagen, dass sie derzeit in der Gegend von Shoreline operieren.",
"painter_6 failMessageText": "",
"painter_6 successMessageText": "Schön. Jetzt geh und ruh dich aus. Du hast es dir verdient.",
"672e334a39064994fc3bd86f": "Eliminiere 15 PMCs an der Shoreline",
"painter_7 name": "Frei Geboren",
"painter_7 description": "Du musst für mich eine unglaubliche Menge Schießpulver und Plexiglas finden. Ich habe ein besonderes Projekt im Sinn und brauche diese Materialien, um es umzusetzen. Viel Glück!",
"painter_7 failMessageText": "",
"painter_7 successMessageText": "Gut.",
"painter_7 location": "any",
"672e33753bc2b4d394df066d": "Finde und übergebe den Gunpowder Kite",
"672e338893682a2593697a37": "Finde und übergebe Gunpowder Eagle",
"672e339460bf295e1f0771b5": "Finde und übergebe Gunpowder Hawk",
"672e339f6a58d92a168c9845": "Finden und übergeben Stück Plexiglas",
"painter_8 name": "Schrumpffolie",
"painter_8 description": "Also ... ich habe gehört, dass einige PMCs sauer über Ihre Beteiligung an meinem Glücksspielgeschäft sind. Sie sagen, dass WIR sie betrogen haben. Ich weiß nicht, warum sie Sie in die Diskussion verwickeln, aber so ist es nun einmal. Vielleicht, weil Sie mir die Ressourcen zur Verfügung gestellt haben, um es aufzubauen? Wer weiß, aber Sie sollten sich darauf vorbereiten, sich zu verteidigen. Es ist Zeit, verdammt kreativ zu werden.",
"painter_8 failMessageText": "",
"painter_8 successMessageText": "Das ist... Was habe ich gerade gesehen? Wie auch immer... Jetzt kann ich anfangen, die Munition zu verkaufen, die Sie von den PMCs geborgen haben.",
"672e33c986ff5b896eb503cd": "Eliminiere 100 PMC"
}

View File

@ -0,0 +1,56 @@
{
"painter_1 name": "Заклеим скотчем",
"painter_1 description": "Мне нужна ваша помощь в повышении тактической эффективности ЧВК по всему Таркову. Найдите различные типы лент, в том числе клейкую ленту и изоленту, чтобы я мог создавать специализированные магазины. Эти заклеенные лентой магазины не только позволяют ЧВК легко идентифицировать заряженные боеприпасы, но также помогают им быстро находить упавшие магазины во время интенсивных перестрелок. Район Таркова — опасное место, и каждое преимущество имеет значение.",
"painter_1 note": "Некоторые люди бояться,когда за ними бежат.",
"painter_1 failMessageText": "",
"painter_1 successMessageText": "Хорошая работа, вы нашли все ленты. Благодаря этому, мой магазин снова будет работать бесперебойно. Вот кое-что в качестве вашей награды. Я ценю вашу помощь.",
"painter_1 location": "Любая локация",
"672e31c3262af62a8eb157cd": "Найти и отдать скотч",
"672e31d7701987cf15698b30": "Найти и передать изоленту",
"painter_2 name": "Топография",
"painter_2 description": "Мне нужно чтобы вы нашли материалы топографической разведки, я могу использовать их для создания лучших шаблонов одежды, и отлично выглядящих штанов.",
"painter_2 failMessageText": "",
"painter_2 successMessageText": "Прекрасно,я сейчас же займусь штанами. Они будут выглядеть достаточно свежо.",
"672e323797a187aabc88ca4a": "Найти и передать карты топографической разведки",
"painter_3 name": "Копай глубже",
"painter_3 description": "После беспощадного рейда диких на мою мастерскую, эти безжалостные мусорщики скрылись с кейсом с оружием, за которое я пролил свою кровь, пот и слезы. Мне удалось выяснить их текущее местонахождение, и теперь пришло время заставить их сожалеть о том дне, когда они перешли мне дорогу. Отправляйтесь в их логово, донесите громкое послание и убедитесь, что они никогда больше не осмелятся предпринять такие смелые шаги. В Таркове пришло время расплаты, и месть — единственная валюта, которую они поймут.",
"painter_3 failMessageText": "",
"painter_3 successMessageText": "Спасибо. Я твой должник",
"painter_3 location": "Таможня",
"672e3295e4287b00f37700c1": "Уничтожить диких на Таможне",
"painter_4 name": "Ремонт Мастерской",
"painter_4 description": "Эхо разрушения моей мастерской все еще звучит, но с вашей помощью я могу начать путь к восстановлению. Мне удалось спасти некоторые необходимые инструменты и материалы, но мне нужно больше, чтобы вернуть мою мастерскую к жизни. Ваша задача — обыскать окрестности Таркова в поисках ценных ресурсов. Поиск промышленных материалов, редких металлов и электронных компонентов. Остерегайтесь опасностей, скрывающихся в тени, поскольку дикие и конкурирующие фракции могут попытаться помешать вашему прогрессу. Как только вы соберете необходимые материалы, верните их мне, чтобы мы могли начать ремонт мастерской.",
"painter_4 failMessageText": "",
"painter_4 successMessageText": "Вы сделали это! С помощью этих материалов я наконец могу начать процесс ремонта своей мастерской. В знак моей благодарности примите эту награду.",
"painter_4 location": "Любая локация",
"672e32c9be76a4ab7682ece9": "Найти и передать инструменты",
"672e32d8386445826a2adfee": "Найти и передать болты",
"672e32e7eb649d0132dfc0db": "Найти и передать гайки",
"painter_5 name": "Радиомолчание",
"painter_5 description": "Поскольку моя мастерская снова работает гладко, мне нужно найти более безопасный способ общения со своими контактами на местах. До меня дошли слухи о мощном радиопередатчике, способном достичь всех уголков Таркова. Этот передатчик позволит мне отправлять и получать важную информацию, гарантируя бесперебойную работу моих операций. Ваша задача — найти радиопередатчик и принести его мне. Будьте осторожны, так как соперничающие группировки могут попытаться перехватить передатчик и помешать вам выполнить миссию. Как только вы закрепите передатчик, вернитесь ко мне, чтобы мы могли установить безопасную линию связи.",
"painter_5 failMessageText": "",
"painter_5 successMessageText": "Отлично! С помощью этого радиопередатчика я теперь могу без перебоев общаться со своими контактами в полевых условиях. Вот кое-что за ваши усилия. Я ценю вашу помощь.",
"painter_5 location": "Любая локация",
"672e33074cd02462a61760a2": "Найти и передать военный COFDM беспроводной передатчик сигналов SG-C10",
"painter_6 name": "Опасные воды",
"painter_6 description": "Группа ЧВК сеет хаос в районе Таркова, нарушая хрупкий баланс сил. Они нападают на невинных мирных жителей, грабят ценные ресурсы и сеют страх по всему региону. Пришло время положить конец их террору и восстановить мир на земле. Ваша миссия — ликвидировать мошеннические ЧВК и восстановить справедливость для тех, кто пострадал от их рук. Будьте готовы к ожесточенному бою, ведь эти мошеннические ЧВК хорошо оснащены и хорошо обучены. Как только вы нейтрализуете угрозу, вернитесь ко мне, чтобы мы могли отпраздновать победу и почтить память павших. По моим данным, в настоящее время они действуют в районе Берега.",
"painter_6 failMessageText": "",
"painter_6 successMessageText": "Хорошо. Теперь ты можешь отдохнуть, ты это заслужил.",
"painter_6 location": "Берег",
"672e334a39064994fc3bd86f": "Уничтожьте 15 ЧВК В районе Берега",
"painter_7 name": "Свободнорожденный",
"painter_7 description": "Мне нужно, чтобы ты нашел некоторое количество пороха и оргстекла. У меня есть специальный проект, и мне нужны эти материалы, чтобы воплотить его в жизнь. Удачи!",
"painter_7 failMessageText": "",
"painter_7 successMessageText": "Хорошо.",
"painter_7 location": "Любая локация",
"672e33753bc2b4d394df066d": "Найти и передать оружейный порох Коршун",
"672e338893682a2593697a37": "Найти и передать оружейный порох Орёл",
"672e339460bf295e1f0771b5": "Найти и передать оружейный порох Ястреб",
"672e339f6a58d92a168c9845": "Найти и передать оргстекло",
"painter_8 name": "Термоукладка",
"painter_8 description": "Итак... Я слышал, что некоторые ЧВК недовольны вашим вмешательством в мой игорный бизнес. Они говорят, что МЫ их обворовали. Я не знаю, почему они вовлекают вас в дискуссию, но мы здесь. Может быть, потому, что вы предоставили мне ресурсы для его создания? Кто знает, но вам следует быть готовым защитить себя. Пришло время проявить чертовски творческий подход. Покажите им,чего вы стоите!",
"painter_8 failMessageText": "",
"painter_8 successMessageText": "Это... Что я только что стал свидетелем? В любом случае... Теперь я могу начать продавать боеприпасы, которые вы украли у ЧВК.",
"painter_8 location": "Любая локация",
"672e33c986ff5b896eb503cd": "Уничтожить 100 ЧВК по всей территории Таркова"
}

View File

@ -0,0 +1,960 @@
{
"668aacd1dee3de3ce276fdef": {
"QuestName": "Taped Up",
"_id": "668aacd1dee3de3ce276fdef",
"canShowNotificationsInGame": true,
"changeQuestMessageText": "painter_1 changeQuestMessageText",
"conditions": {
"AvailableForFinish": [
{
"conditionType": "HandoverItem",
"dogtagLevel": 0,
"dynamicLocale": false,
"globalQuestCounterId": "",
"id": "672e31c3262af62a8eb157cd",
"index": 0,
"maxDurability": 100,
"minDurability": 0,
"onlyFoundInRaid": true,
"parentId": "",
"target": ["57347c1124597737fb1379e3"],
"value": "3",
"visibilityConditions": []
},
{
"conditionType": "HandoverItem",
"dogtagLevel": 0,
"dynamicLocale": false,
"globalQuestCounterId": "",
"id": "672e31d7701987cf15698b30",
"index": 1,
"maxDurability": 100,
"minDurability": 0,
"onlyFoundInRaid": true,
"parentId": "",
"target": ["5734795124597738002c6176"],
"value": "3",
"visibilityConditions": []
}
],
"AvailableForStart": [
{
"compareMethod": ">=",
"conditionType": "Level",
"dynamicLocale": false,
"globalQuestCounterId": "",
"id": "672e31eeb489152e7707cb72",
"index": 0,
"parentId": "",
"value": 1,
"visibilityConditions": []
}
],
"Fail": []
},
"declinePlayerMessage": "painter_1 declinePlayerMessage",
"description": "painter_1 description",
"failMessageText": "painter_1 failMessageText",
"image": "/files/quest/icon/painter_1_thumbnail.png",
"instantComplete": false,
"isKey": false,
"location": "any",
"name": "painter_1 name",
"note": "painter_1 note",
"restartable": false,
"rewards": {
"Fail": [],
"Started": [],
"Success": [
{
"id": "672e320f0ed0c138d60be692",
"index": 0,
"type": "Experience",
"value": "2500"
},
{
"id": "672e321a311745b947c86297",
"index": 1,
"target": "668aaff35fd574b6dcc4a686",
"type": "TraderStanding",
"value": "0.02"
},
{
"findInRaid": true,
"id": "672e322347a9f6b4122f26c1",
"index": 2,
"items": [
{
"_id": "672e322618e2333119497dc9",
"_tpl": "5449016a4bdc2d6f028b456f",
"upd": {
"StackObjectsCount": 21000
}
}
],
"target": "672e322618e2333119497dc9",
"type": "Item",
"value": "20500"
}
]
},
"secretQuest": false,
"side": "Pmc",
"startedMessageText": "painter_1 startedMessageText",
"successMessageText": "painter_1 successMessageText",
"traderId": "668aaff35fd574b6dcc4a686",
"type": "PickUp"
},
"668aace8ff74aecfbcfbe9e6": {
"QuestName": "Topographics",
"_id": "668aace8ff74aecfbcfbe9e6",
"canShowNotificationsInGame": true,
"changeQuestMessageText": "painter_2 changeQuestMessageText",
"conditions": {
"AvailableForFinish": [
{
"conditionType": "HandoverItem",
"dogtagLevel": 0,
"dynamicLocale": false,
"globalQuestCounterId": "",
"id": "672e323797a187aabc88ca4a",
"index": 1,
"maxDurability": 100,
"minDurability": 0,
"onlyFoundInRaid": true,
"parentId": "",
"target": ["62a0a124de7ac81993580542"],
"value": "1",
"visibilityConditions": []
}
],
"AvailableForStart": [
{
"availableAfter": 0,
"conditionType": "Quest",
"dynamicLocale": false,
"globalQuestCounterId": "",
"id": "672e324934b8ff780512ec50",
"index": 1,
"parentId": "",
"status": [4],
"target": "668aacd1dee3de3ce276fdef",
"visibilityConditions": []
}
],
"Fail": []
},
"declinePlayerMessage": "painter_2 declinePlayerMessage",
"description": "painter_2 description",
"failMessageText": "painter_2 failMessageText",
"image": "/files/quest/icon/painter_2_thumbnail.png",
"instantComplete": false,
"isKey": false,
"location": "any",
"name": "painter_2 name",
"note": "painter_2 note",
"restartable": false,
"rewards": {
"Fail": [],
"Started": [],
"Success": [
{
"id": "672e3258a638ea171fc6a0b6",
"index": 0,
"type": "Experience",
"value": "6500"
},
{
"findInRaid": true,
"id": "672e325a9f4a5085cc20a7ec",
"index": 1,
"items": [
{
"_id": "672e325c7c1121e5395d35cd",
"_tpl": "5449016a4bdc2d6f028b456f",
"upd": {
"StackObjectsCount": 35500
}
}
],
"target": "672e325c7c1121e5395d35cd",
"type": "Item",
"value": "35500"
},
{
"id": "672e3263804e6e913647b594",
"index": 2,
"target": "668aaff35fd574b6dcc4a686",
"type": "TraderStanding",
"value": "0.02"
}
]
},
"secretQuest": false,
"side": "Pmc",
"startedMessageText": "painter_2 description",
"successMessageText": "painter_2 successMessageText",
"traderId": "668aaff35fd574b6dcc4a686",
"type": "PickUp"
},
"668aad1d97c0b19780ebf9c2": {
"QuestName": "Dig Deep",
"_id": "668aad1d97c0b19780ebf9c2",
"canShowNotificationsInGame": true,
"changeQuestMessageText": "painter_3 changeQuestMessageText",
"conditions": {
"AvailableForFinish": [
{
"conditionType": "CounterCreator",
"counter": {
"conditions": [
{
"compareMethod": ">=",
"conditionType": "Kills",
"id": "672e326e957ba4b27be8a570",
"target": "Savage",
"value": "1"
},
{
"conditionType": "Location",
"id": "672e327ba37230a48fc86c5f",
"target": ["bigmap"]
}
],
"id": "672e3285d8846577b4de301c"
},
"doNotResetIfCounterCompleted": false,
"dynamicLocale": false,
"globalQuestCounterId": "",
"id": "672e3295e4287b00f37700c1",
"index": 1,
"oneSessionOnly": false,
"parentId": "",
"type": "Elimination",
"value": "10",
"visibilityConditions": []
}
],
"AvailableForStart": [
{
"availableAfter": 0,
"conditionType": "Quest",
"dynamicLocale": false,
"globalQuestCounterId": "",
"id": "672e32a15f33429ec9dd1864",
"index": 1,
"parentId": "",
"status": [4],
"target": "668aace8ff74aecfbcfbe9e6",
"visibilityConditions": []
}
],
"Fail": []
},
"declinePlayerMessage": "painter_3 declinePlayerMessage",
"description": "painter_3 description",
"failMessageText": "painter_3 failMessageText",
"image": "/files/quest/icon/painter_3_thumbnail.png",
"instantComplete": false,
"isKey": false,
"location": "56f40101d2720b2a4d8b45d6",
"name": "painter_3 name",
"note": "painter_3 note",
"restartable": false,
"rewards": {
"Fail": [],
"Started": [],
"Success": [
{
"id": "672e32ac9fc5610c6495993a",
"index": 0,
"type": "Experience",
"value": "6500"
},
{
"id": "672e32aeaa0ec3f416123e5e",
"index": 1,
"target": "668aaff35fd574b6dcc4a686",
"type": "TraderStanding",
"value": "0.02"
},
{
"findInRaid": true,
"id": "672e32affeac239b74d81f71",
"index": 2,
"items": [
{
"_id": "672e32b1b37629655d837d0a",
"_tpl": "5449016a4bdc2d6f028b456f",
"upd": {
"StackObjectsCount": 39000
}
}
],
"target": "672e32b1b37629655d837d0a",
"type": "Item",
"value": "39500"
},
{
"findInRaid": true,
"id": "672e32b93e3c3479564195ec",
"index": 3,
"items": [
{
"_id": "672e32bb2333f51f9c6c08c4",
"_tpl": "5d403f9186f7743cac3f229b",
"upd": {
"StackObjectsCount": 3
}
}
],
"target": "672e32bb2333f51f9c6c08c4",
"type": "Item",
"value": "3"
}
]
},
"secretQuest": false,
"side": "Pmc",
"startedMessageText": "painter_3 description",
"successMessageText": "painter_3 successMessageText",
"traderId": "668aaff35fd574b6dcc4a686",
"type": "Elimination"
},
"668aad2b0f0c52ff9b51625d": {
"QuestName": "Workshop Refurbishment",
"_id": "668aad2b0f0c52ff9b51625d",
"canShowNotificationsInGame": true,
"changeQuestMessageText": "painter_4 changeQuestMessageText",
"conditions": {
"AvailableForFinish": [
{
"conditionType": "HandoverItem",
"dogtagLevel": 0,
"dynamicLocale": false,
"globalQuestCounterId": "",
"id": "672e32c9be76a4ab7682ece9",
"index": 0,
"maxDurability": 100,
"minDurability": 0,
"onlyFoundInRaid": true,
"parentId": "",
"target": ["590c2e1186f77425357b6124"],
"value": "1",
"visibilityConditions": []
},
{
"conditionType": "HandoverItem",
"dogtagLevel": 0,
"dynamicLocale": false,
"globalQuestCounterId": "",
"id": "672e32d8386445826a2adfee",
"index": 1,
"maxDurability": 100,
"minDurability": 0,
"onlyFoundInRaid": true,
"parentId": "",
"target": ["57347c5b245977448d35f6e1"],
"value": "3",
"visibilityConditions": []
},
{
"conditionType": "HandoverItem",
"dogtagLevel": 0,
"dynamicLocale": false,
"globalQuestCounterId": "",
"id": "672e32e7eb649d0132dfc0db",
"index": 2,
"maxDurability": 100,
"minDurability": 0,
"onlyFoundInRaid": true,
"parentId": "",
"target": ["57347c77245977448d35f6e2"],
"value": "3",
"visibilityConditions": []
}
],
"AvailableForStart": [
{
"availableAfter": 0,
"conditionType": "Quest",
"dynamicLocale": false,
"globalQuestCounterId": "",
"id": "672e32f318a4d0481537902d",
"index": 1,
"parentId": "",
"status": [4],
"target": "668aad1d97c0b19780ebf9c2",
"visibilityConditions": []
}
],
"Fail": []
},
"declinePlayerMessage": "painter_4 declinePlayerMessage",
"description": "painter_4 description",
"failMessageText": "painter_4 failMessageText",
"image": "/files/quest/icon/painter_4_thumbnail.png",
"instantComplete": false,
"isKey": false,
"location": "any",
"name": "painter_4 name",
"note": "painter_4 note",
"restartable": false,
"rewards": {
"Fail": [],
"Started": [],
"Success": [
{
"id": "672e32f713d2c32fd0ab716b",
"index": 0,
"type": "Experience",
"value": "2500"
},
{
"findInRaid": true,
"id": "672e32f8f7a6c399a761a62f",
"index": 1,
"items": [
{
"_id": "672e32f908b40ed46e9aa44a",
"_tpl": "5c05308086f7746b2101e90b",
"upd": {
"StackObjectsCount": 1
}
}
],
"target": "672e32f908b40ed46e9aa44a",
"type": "Item",
"value": "1"
},
{
"id": "672e32fe9bd3504432668960",
"index": 2,
"target": "668aaff35fd574b6dcc4a686",
"type": "TraderStanding",
"value": "0.03"
}
]
},
"secretQuest": false,
"side": "Pmc",
"startedMessageText": "painter_4 startedMessageText",
"successMessageText": "painter_4 successMessageText",
"traderId": "668aaff35fd574b6dcc4a686",
"type": "PickUp"
},
"668aad328a1b4ad3818169cf": {
"QuestName": "Radio Silence",
"_id": "668aad328a1b4ad3818169cf",
"canShowNotificationsInGame": true,
"changeQuestMessageText": "painter_5 changeQuestMessageText",
"conditions": {
"AvailableForFinish": [
{
"conditionType": "HandoverItem",
"dogtagLevel": 0,
"dynamicLocale": false,
"globalQuestCounterId": "",
"id": "672e33074cd02462a61760a2",
"index": 0,
"maxDurability": 100,
"minDurability": 0,
"onlyFoundInRaid": true,
"parentId": "",
"target": ["5c052f6886f7746b1e3db148"],
"value": "1",
"visibilityConditions": []
}
],
"AvailableForStart": [
{
"availableAfter": 0,
"conditionType": "Quest",
"dynamicLocale": false,
"globalQuestCounterId": "",
"id": "672e33139f6ec10a5d314e75",
"index": 1,
"parentId": "",
"status": [4],
"target": "668aad2b0f0c52ff9b51625d",
"visibilityConditions": []
}
],
"Fail": []
},
"declinePlayerMessage": "painter_5 declinePlayerMessage",
"description": "painter_5 description",
"failMessageText": "painter_5 failMessageText",
"image": "/files/quest/icon/painter_5_thumbnail.png",
"instantComplete": false,
"isKey": false,
"location": "any",
"name": "painter_5 name",
"note": "painter_5 note",
"restartable": false,
"rewards": {
"Fail": [],
"Started": [],
"Success": [
{
"id": "672e331a18ecf91f7135cfbc",
"index": 0,
"type": "Experience",
"value": "2500"
},
{
"findInRaid": true,
"id": "672e331ca9ec1a9b0ff50961",
"index": 1,
"items": [
{
"_id": "672e331de1cb340521837424",
"_tpl": "5e2aedd986f7746d404f3aa4",
"upd": {
"StackObjectsCount": 3
}
}
],
"target": "672e331de1cb340521837424",
"type": "Item",
"value": "1"
},
{
"findInRaid": true,
"id": "672e33236d76f0037ade6462",
"index": 2,
"items": [
{
"_id": "672e332433dd94c340abaf64",
"_tpl": "5449016a4bdc2d6f028b456f",
"upd": {
"StackObjectsCount": 51000
}
}
],
"target": "672e332433dd94c340abaf64",
"type": "Item",
"value": "50500"
},
{
"id": "672e332b978a9cce93f8aba0",
"index": 3,
"target": "668aaff35fd574b6dcc4a686",
"type": "TraderStanding",
"value": "0.03"
}
]
},
"secretQuest": false,
"side": "Pmc",
"startedMessageText": "painter_5 startedMessageText",
"successMessageText": "painter_5 successMessageText",
"traderId": "668aaff35fd574b6dcc4a686",
"type": "PickUp"
},
"668aad49a21e4d37c83d4ffc": {
"QuestName": "Dangerous Waters",
"_id": "668aad49a21e4d37c83d4ffc",
"canShowNotificationsInGame": true,
"changeQuestMessageText": "painter_6 changeQuestMessageText",
"conditions": {
"AvailableForFinish": [
{
"conditionType": "CounterCreator",
"counter": {
"conditions": [
{
"compareMethod": ">=",
"conditionType": "Kills",
"id": "672e3337719c01963ea93651",
"target": "AnyPmc",
"value": "1"
},
{
"conditionType": "Location",
"id": "672e333bec632da64d734e2d",
"target": ["Shoreline"]
}
],
"id": "672e33405decb9faa41db3ca"
},
"doNotResetIfCounterCompleted": false,
"dynamicLocale": false,
"globalQuestCounterId": "",
"id": "672e334a39064994fc3bd86f",
"index": 1,
"oneSessionOnly": false,
"parentId": "",
"type": "Elimination",
"value": "15",
"visibilityConditions": []
}
],
"AvailableForStart": [
{
"availableAfter": 0,
"conditionType": "Quest",
"dynamicLocale": false,
"globalQuestCounterId": "",
"id": "672e33594fd1e90a00dc344e",
"index": 1,
"parentId": "",
"status": [4],
"target": "668aad328a1b4ad3818169cf",
"visibilityConditions": []
}
],
"Fail": []
},
"declinePlayerMessage": "painter_6 declinePlayerMessage",
"description": "painter_6 description",
"failMessageText": "painter_6 failMessageText",
"image": "/files/quest/icon/painter_6_thumbnail.png",
"instantComplete": false,
"isKey": false,
"location": "5704e554d2720bac5b8b456e",
"name": "painter_6 name",
"note": "painter_6 note",
"restartable": false,
"rewards": {
"Fail": [],
"Started": [],
"Success": [
{
"id": "672e335d2f242b0ba98b196d",
"index": 0,
"type": "Experience",
"value": "6500"
},
{
"id": "672e33605cc6a53650006991",
"index": 1,
"target": "668aaff35fd574b6dcc4a686",
"type": "TraderStanding",
"value": "0.04"
},
{
"findInRaid": true,
"id": "672e3362123bcde9f627012d",
"index": 2,
"items": [
{
"_id": "672e3363e49a3c871e52b94c",
"_tpl": "5449016a4bdc2d6f028b456f",
"upd": {
"StackObjectsCount": 80000
}
}
],
"target": "672e3363e49a3c871e52b94c",
"type": "Item",
"value": "80000"
},
{
"findInRaid": true,
"id": "672e33688da7b757361b0fc3",
"index": 3,
"items": [
{
"_id": "672e33699042e3aae2094982",
"_tpl": "5d1b376e86f774252519444e",
"upd": {
"StackObjectsCount": 1
}
}
],
"target": "672e33699042e3aae2094982",
"type": "Item",
"value": "1"
}
]
},
"secretQuest": false,
"side": "Pmc",
"startedMessageText": "painter_6 description",
"successMessageText": "painter_6 successMessageText",
"traderId": "668aaff35fd574b6dcc4a686",
"type": "Elimination"
},
"668aad3c3ff8f5b258e3a65b": {
"QuestName": "Born Free",
"_id": "668aad3c3ff8f5b258e3a65b",
"canShowNotificationsInGame": true,
"changeQuestMessageText": "painter_7 changeQuestMessageText",
"conditions": {
"AvailableForFinish": [
{
"conditionType": "HandoverItem",
"dogtagLevel": 0,
"dynamicLocale": false,
"globalQuestCounterId": "",
"id": "672e33753bc2b4d394df066d",
"index": 0,
"maxDurability": 100,
"minDurability": 0,
"onlyFoundInRaid": true,
"parentId": "",
"target": ["590c5a7286f7747884343aea"],
"value": "7",
"visibilityConditions": []
},
{
"conditionType": "HandoverItem",
"dogtagLevel": 0,
"dynamicLocale": false,
"globalQuestCounterId": "",
"id": "672e338893682a2593697a37",
"index": 1,
"maxDurability": 100,
"minDurability": 0,
"onlyFoundInRaid": true,
"parentId": "",
"target": ["5d6fc78386f77449d825f9dc"],
"value": "7",
"visibilityConditions": []
},
{
"conditionType": "HandoverItem",
"dogtagLevel": 0,
"dynamicLocale": false,
"globalQuestCounterId": "",
"id": "672e339460bf295e1f0771b5",
"index": 2,
"maxDurability": 100,
"minDurability": 0,
"onlyFoundInRaid": true,
"parentId": "",
"target": ["5d6fc87386f77449db3db94e"],
"value": "7",
"visibilityConditions": []
},
{
"conditionType": "HandoverItem",
"dogtagLevel": 0,
"dynamicLocale": false,
"globalQuestCounterId": "",
"id": "672e339f6a58d92a168c9845",
"index": 3,
"maxDurability": 100,
"minDurability": 0,
"onlyFoundInRaid": true,
"parentId": "",
"target": ["59e366c186f7741778269d85"],
"value": "7",
"visibilityConditions": []
}
],
"AvailableForStart": [
{
"availableAfter": 0,
"conditionType": "Quest",
"dynamicLocale": false,
"globalQuestCounterId": "",
"id": "672e33a8cd1e9476551db9ea",
"index": 1,
"parentId": "",
"status": [4],
"target": "668aad49a21e4d37c83d4ffc",
"visibilityConditions": []
}
],
"Fail": []
},
"declinePlayerMessage": "painter_7 declinePlayerMessage",
"description": "painter_7 description",
"failMessageText": "painter_7 failMessageText",
"image": "/files/quest/icon/painter_7_thumbnail.png",
"instantComplete": false,
"isKey": false,
"location": "any",
"name": "painter_7 name",
"note": "painter_7 note",
"restartable": false,
"rewards": {
"Fail": [],
"Started": [],
"Success": [
{
"id": "672e33acba7dc114726c9ccc",
"index": 0,
"type": "Experience",
"value": "2500"
},
{
"findInRaid": true,
"id": "672e33ad3e0a2d403e1ae5b4",
"index": 1,
"items": [
{
"_id": "672e33ad2bd6d0ddc2311ea2",
"_tpl": "5449016a4bdc2d6f028b456f",
"upd": {
"StackObjectsCount": 110000
}
}
],
"target": "672e33ad2bd6d0ddc2311ea2",
"type": "Item",
"value": "110000"
},
{
"id": "672e33b369515ce7af7df6ff",
"index": 2,
"items": [
{
"_id": "672e2804a0529208b4e10e18",
"_tpl": "5c0a840b86f7742ffa4f2482"
}
],
"loyaltyLevel": 4,
"target": "672e2804a0529208b4e10e18",
"traderId": "668aaff35fd574b6dcc4a686",
"type": "AssortmentUnlock"
},
{
"id": "672e33b879e2d665bfa01bcc",
"index": 3,
"target": "668aaff35fd574b6dcc4a686",
"type": "TraderStanding",
"value": "0.04"
}
]
},
"secretQuest": false,
"side": "Pmc",
"startedMessageText": "painter_7 startedMessageText",
"successMessageText": "painter_7 successMessageText",
"traderId": "668aaff35fd574b6dcc4a686",
"type": "PickUp"
},
"668c18eb12542b3c3ff6e20f": {
"QuestName": "Shrink Wrap",
"_id": "668c18eb12542b3c3ff6e20f",
"canShowNotificationsInGame": true,
"changeQuestMessageText": "painter_8 changeQuestMessageText",
"conditions": {
"AvailableForFinish": [
{
"conditionType": "CounterCreator",
"counter": {
"conditions": [
{
"compareMethod": ">=",
"conditionType": "Kills",
"id": "672e33c211d2133aed1ccd66",
"target": "AnyPmc",
"value": "1"
}
],
"id": "672e33c4c2f8b0ce34a78768"
},
"doNotResetIfCounterCompleted": false,
"dynamicLocale": false,
"globalQuestCounterId": "",
"id": "672e33c986ff5b896eb503cd",
"index": 1,
"oneSessionOnly": false,
"parentId": "",
"type": "Elimination",
"value": "100",
"visibilityConditions": []
}
],
"AvailableForStart": [
{
"availableAfter": 0,
"conditionType": "Quest",
"dynamicLocale": false,
"globalQuestCounterId": "",
"id": "6748f226384e5edc1e86a07a",
"index": 1,
"parentId": "",
"status": [4],
"target": "668aad3c3ff8f5b258e3a65b",
"visibilityConditions": []
}
],
"Fail": []
},
"declinePlayerMessage": "painter_8 declinePlayerMessage",
"description": "painter_8 description",
"failMessageText": "painter_8 failMessageText",
"image": "/files/quest/icon/painter_8_thumbnail.png",
"instantComplete": false,
"isKey": false,
"location": "any",
"name": "painter_8 name",
"note": "painter_8 note",
"restartable": false,
"rewards": {
"Fail": [],
"Started": [],
"Success": [
{
"id": "672e33d7328feb52bd28d5d9",
"index": 0,
"type": "Experience",
"value": "6500"
},
{
"id": "672e33d832bdd4504eee296f",
"index": 1,
"target": "668aaff35fd574b6dcc4a686",
"type": "TraderStanding",
"value": "0.04"
},
{
"findInRaid": true,
"id": "672e33da4a034853ff35fdbb",
"index": 2,
"items": [
{
"_id": "672e33db64495f03c3642ee2",
"_tpl": "5449016a4bdc2d6f028b456f",
"upd": {
"StackObjectsCount": 120000
}
}
],
"target": "672e33db64495f03c3642ee2",
"type": "Item",
"value": "120000"
},
{
"id": "672e33e1d44cac74b631eec5",
"index": 3,
"items": [
{
"_id": "672e284a363b798192b802af",
"_tpl": "54527ac44bdc2d36668b4567"
}
],
"loyaltyLevel": 4,
"target": "672e284a363b798192b802af",
"traderId": "668aaff35fd574b6dcc4a686",
"type": "AssortmentUnlock"
},
{
"id": "672e33e5031e7626d247b917",
"index": 4,
"items": [
{
"_id": "672e289bb4096716fcb918a7",
"_tpl": "5a6086ea4f39f99cd479502f"
}
],
"loyaltyLevel": 4,
"target": "672e289bb4096716fcb918a7",
"traderId": "668aaff35fd574b6dcc4a686",
"type": "AssortmentUnlock"
}
]
},
"secretQuest": false,
"side": "Pmc",
"startedMessageText": "painter_8 description",
"successMessageText": "painter_8 successMessageText",
"traderId": "668aaff35fd574b6dcc4a686",
"type": "Elimination"
}
}

View File

@ -0,0 +1,26 @@
{
"name": "Painter - Trader",
"version": "1.1.3",
"main": "src/mod.js",
"license": "MIT",
"author": "MoxoPixel",
"sptVersion": "3.10.X",
"isBundleMod": true,
"scripts": {
"setup": "npm i",
"build": "node ./build.mjs",
"buildinfo": "node ./build.mjs --verbose"
},
"devDependencies": {
"@types/node": "20.11",
"@typescript-eslint/eslint-plugin": "7.2",
"@typescript-eslint/parser": "7.2",
"archiver": "^6.0",
"eslint": "8.57",
"fs-extra": "11.2",
"ignore": "^5.2",
"tsyringe": "4.8.0",
"typescript": "5.4",
"winston": "3.12"
}
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 37 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 299 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 320 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 381 KiB

Some files were not shown because too many files have changed in this diff Show More