diff --git a/code/__DEFINES/~doppler_defines/traits/declarations.dm b/code/__DEFINES/~doppler_defines/traits/declarations.dm index bc7cf5f9b9340..8ee2c0d8e7f75 100644 --- a/code/__DEFINES/~doppler_defines/traits/declarations.dm +++ b/code/__DEFINES/~doppler_defines/traits/declarations.dm @@ -1,3 +1,2 @@ /// The trait that determines if someone has the system shock quirk. #define TRAIT_SYSTEM_SHOCK "trait_system_shock" - diff --git a/code/modules/paperwork/paperwork.dm b/code/modules/paperwork/paperwork.dm index 2acedcf00f093..9c88bb61a68c2 100644 --- a/code/modules/paperwork/paperwork.dm +++ b/code/modules/paperwork/paperwork.dm @@ -61,6 +61,10 @@ add_stamp() return TRUE +/obj/item/paperwork/examine(mob/user) // DOPPLER EDIT - paperwork has more description, modifying examine to fake the standard extended examine text + . = ..() + . += span_notice("This item could be examined further...") + /obj/item/paperwork/examine_more(mob/user) . = ..() diff --git a/modular_doppler/epic_loot/code/_basetype.dm b/modular_doppler/epic_loot/code/_basetype.dm new file mode 100644 index 0000000000000..48a1a91349a38 --- /dev/null +++ b/modular_doppler/epic_loot/code/_basetype.dm @@ -0,0 +1,83 @@ +/obj/structure/maintenance_loot_structure + name = "abandoned crate" + icon = 'modular_doppler/epic_loot/icons/loot_structures.dmi' + density = TRUE + anchored = TRUE + layer = BELOW_OBJ_LAYER + obj_flags = CAN_BE_HIT + pass_flags_self = LETPASSTHROW|LETPASSCLICKS + max_integrity = 200 + + /// What storage datum we use + var/storage_datum_to_use = /datum/storage/maintenance_loot_structure + /// Weighted list of the loot that can spawn in this + var/list/loot_weighted_list = list( + /obj/effect/spawner/random/maintenance = 1, + ) + /// This one is going to be weird, a string of dice to use when rolling number of contents + var/loot_spawn_dice_string = "2d4+1" + +/obj/structure/maintenance_loot_structure/Initialize(mapload) + . = ..() + create_storage(storage_type = storage_datum_to_use) + make_contents() + +/obj/structure/maintenance_loot_structure/examine(mob/user) + . = ..() + . += span_engradio("It might have other things you're looking for if you look again later?") + return . + +// Since it doesn't want to play nice for whatever reason +/obj/structure/maintenance_loot_structure/attack_hand(mob/living/user) + if(!user.can_perform_action(src, NEED_HANDS)) + return ..() + atom_storage.open_storage(user) + return TRUE + +/// Fills random contents into this structure's inventory, starting a loop to respawn loot if the container is empty later +/obj/structure/maintenance_loot_structure/proc/make_contents() + var/refill_check_time = rand(15 MINUTES, 30 MINUTES) + spawn_loot() + addtimer(CALLBACK(src, PROC_REF(make_contents)), refill_check_time) + +/// Spawns a random amount of loot into the structure, random numbers based on the amount of storage slots inside it +/obj/structure/maintenance_loot_structure/proc/spawn_loot() + if(length(contents)) + for(var/obj/thing in contents) + qdel(thing) + var/random_loot_amount = roll(loot_spawn_dice_string) + for(var/loot_spawn in 1 to random_loot_amount) + var/obj/new_loot = pick_weight(loot_weighted_list) + new new_loot(src) + Shake(2, 2, 1 SECONDS) + +/datum/storage/maintenance_loot_structure + max_slots = 9 + max_specific_storage = WEIGHT_CLASS_GIGANTIC + max_total_storage = WEIGHT_CLASS_BULKY * 6 + numerical_stacking = FALSE + rustle_sound = FALSE + screen_max_columns = 3 + /// What sound this makes when people open it's storage + var/opening_sound = 'modular_doppler/epic_loot/sound/plastic.mp3' + +/datum/storage/maintenance_loot_structure/open_storage(mob/to_show) + . = ..() + if(!.) + return + playsound(parent, opening_sound, 50, TRUE) + +// Loot items basetype, for convenience +/obj/item/epic_loot + name = "epic loot!!!!!" + desc = "Unknown purpose, unknown maker, unknown value. The only thing I know for real: There will be loot." + icon = 'modular_doppler/epic_loot/icons/epic_loot.dmi' + lefthand_file = 'icons/mob/inhands/items_lefthand.dmi' + righthand_file = 'icons/mob/inhands/items_righthand.dmi' + inhand_icon_state = "binoculars" + w_class = WEIGHT_CLASS_SMALL + +/obj/item/epic_loot/examine(mob/user) + . = ..() + . += span_engradio("You should probably sell or recycle this.") + return . diff --git a/modular_doppler/epic_loot/code/loot_items/components.dm b/modular_doppler/epic_loot/code/loot_items/components.dm new file mode 100644 index 0000000000000..116507d6923e8 --- /dev/null +++ b/modular_doppler/epic_loot/code/loot_items/components.dm @@ -0,0 +1,214 @@ +/datum/export/epic_loot_components + cost = PAYCHECK_COMMAND + unit_name = "low value salvage" + export_types = list( + /obj/item/epic_loot/grenade_fuze, + /obj/item/epic_loot/nail_box, + /obj/item/epic_loot/cold_weld, + /obj/item/epic_loot/signal_amp, + /obj/item/epic_loot/fuel_conditioner, + ) + +/datum/export/epic_loot_components_super + cost = PAYCHECK_COMMAND * 2 + unit_name = "salvage" + export_types = list( + /obj/item/epic_loot/water_filter, + /obj/item/epic_loot/thermometer, + /obj/item/epic_loot/current_converter, + /obj/item/epic_loot/electric_motor, + ) + +/datum/export/epic_loot_components_super_super + cost = PAYCHECK_COMMAND * 3 + unit_name = "high value salvage" + export_types = list( + /obj/item/epic_loot/thermal_camera, + /obj/item/epic_loot/shuttle_gyro, + /obj/item/epic_loot/phased_array, + /obj/item/epic_loot/shuttle_battery, + ) + +// Grenade fuze, an old design from an old time past. You can still make a pretty good grenade with it though +/obj/item/epic_loot/grenade_fuze + name = "grenade fuze" + desc = "Just the fuze of a grenade, missing the explosive and arguably most important half of the grenade." + icon_state = "fuze" + inhand_icon_state = "pen" + drop_sound = 'sound/items/handling/component_drop.ogg' + pickup_sound = 'sound/items/handling/component_pickup.ogg' + custom_materials = list( + /datum/material/titanium = HALF_SHEET_MATERIAL_AMOUNT, + /datum/material/plasma = HALF_SHEET_MATERIAL_AMOUNT, + ) + +// The filter part of a water filter machine, though these machines are insanely rare due to modern synthesis technology +/obj/item/epic_loot/water_filter + name = "water filter cartridge" + desc = "A blue polymer tube filled with filter medium for use in an industrial water filtration unit." + icon_state = "water_filter" + inhand_icon_state = "miniFE" + drop_sound = 'sound/items/handling/tools/weldingtool_drop.ogg' + pickup_sound = 'sound/items/handling/tools/weldingtool_pickup.ogg' + custom_materials = list( + /datum/material/iron = SHEET_MATERIAL_AMOUNT * 3, + /datum/material/titanium = HALF_SHEET_MATERIAL_AMOUNT, + ) + +// Analog thermometer, how to tell temperature before gas analyzers were cool +/obj/item/epic_loot/thermometer + name = "analog thermometer" + desc = "An outdated, and likely broken, analog thermometer." + icon_state = "thermometer" + inhand_icon_state = "razor" + drop_sound = 'sound/items/handling/tools/multitool_drop.ogg' + pickup_sound = 'sound/items/handling/tools/multitool_pickup.ogg' + custom_materials = list( + /datum/material/iron = SHEET_MATERIAL_AMOUNT, + /datum/material/silver = HALF_SHEET_MATERIAL_AMOUNT, + ) + +// A box of nails, impossible tech on a space station +/obj/item/epic_loot/nail_box + name = "box of nails" + desc = "A pristine box of nails, a method of keeping things together that we... can't really use here, in a space station." + icon_state = "nails" + inhand_icon_state = "rubberducky" + drop_sound = 'sound/items/handling/ammobox_drop.ogg' + pickup_sound = 'sound/items/handling/ammobox_pickup.ogg' + custom_materials = list( + /datum/material/iron = SHEET_MATERIAL_AMOUNT, + /datum/material/cardboard = SHEET_MATERIAL_AMOUNT, + ) + +// Used for joining together plastics, ideally. +/obj/item/epic_loot/cold_weld + name = "tube of cold weld" + desc = "A tube of cold weld, used to join together plastics, usually for repair." + icon_state = "cold_weld" + inhand_icon_state = "razor" + drop_sound = 'sound/items/handling/component_drop.ogg' + pickup_sound = 'sound/items/handling/component_pickup.ogg' + custom_materials = list( + /datum/material/plastic = HALF_SHEET_MATERIAL_AMOUNT, + ) + +// An electronic motor +/obj/item/epic_loot/electric_motor + name = "electric motor" + desc = "An electrically driven motor for industrial applications." + icon_state = "motor" + inhand_icon_state = "miniFE" + w_class = WEIGHT_CLASS_NORMAL + drop_sound = 'sound/items/handling/cardboard_box/cardboardbox_drop.ogg' + pickup_sound = 'sound/items/handling/cardboard_box/cardboardbox_pickup.ogg' + custom_materials = list( + /datum/material/plastic = SHEET_MATERIAL_AMOUNT, + /datum/material/iron = HALF_SHEET_MATERIAL_AMOUNT, + /datum/material/silver = HALF_SHEET_MATERIAL_AMOUNT, + ) + +// Current converters, these change one rating of current into another in a mostly safe manner +/obj/item/epic_loot/current_converter + name = "current converter" + desc = "A device for regulating electric current that passes through it." + icon_state = "current_converter" + inhand_icon_state = "miniFE" + w_class = WEIGHT_CLASS_NORMAL + drop_sound = 'sound/items/handling/tools/weldingtool_drop.ogg' + pickup_sound = 'sound/items/handling/tools/weldingtool_pickup.ogg' + custom_materials = list( + /datum/material/plastic = SHEET_MATERIAL_AMOUNT * 2, + /datum/material/silver = SHEET_MATERIAL_AMOUNT, + /datum/material/gold = SHEET_MATERIAL_AMOUNT, + ) + +// Signal amplifiers, used to take a faint signal and return it stronger than before +/obj/item/epic_loot/signal_amp + name = "signal amplifier" + desc = "A device for taking weakened input signals and strengthening them for use or listening." + icon_state = "signal_amp" + drop_sound = 'sound/items/handling/component_drop.ogg' + pickup_sound = 'sound/items/handling/component_pickup.ogg' + custom_materials = list( + /datum/material/iron = SHEET_MATERIAL_AMOUNT, + /datum/material/silver = HALF_SHEET_MATERIAL_AMOUNT, + /datum/material/gold = HALF_SHEET_MATERIAL_AMOUNT, + ) + +// Thermal camera modules +/obj/item/epic_loot/thermal_camera + name = "thermal camera module" + desc = "An infrared sensing device used for the production of thermal camera systems." + icon_state = "thermal" + drop_sound = 'sound/items/handling/component_drop.ogg' + pickup_sound = 'sound/items/handling/component_pickup.ogg' + custom_materials = list( + /datum/material/plastic = SHEET_MATERIAL_AMOUNT, + /datum/material/plasma = HALF_SHEET_MATERIAL_AMOUNT, + /datum/material/gold = HALF_SHEET_MATERIAL_AMOUNT, + ) + +// Shuttle gyroscopes, AKA how a shuttle realizes which way it's pointing +/obj/item/epic_loot/shuttle_gyro + name = "shuttle gyroscope" + desc = "A bulky device used by shuttles and other space faring vessels to find the direction they are facing." + icon_state = "shuttle_gyro" + inhand_icon_state = "miniFE" + w_class = WEIGHT_CLASS_BULKY + drop_sound = 'sound/items/handling/ammobox_drop.ogg' + pickup_sound = 'sound/items/handling/ammobox_pickup.ogg' + custom_materials = list( + /datum/material/plastic = SHEET_MATERIAL_AMOUNT * 3, + /datum/material/titanium = SHEET_MATERIAL_AMOUNT * 5, + /datum/material/silver = SHEET_MATERIAL_AMOUNT * 4, + /datum/material/gold = SHEET_MATERIAL_AMOUNT * 4 + ) + +/obj/item/epic_loot/shuttle_gyro/Initialize(mapload) + . = ..() + AddComponent(/datum/component/two_handed, require_twohands = TRUE) + +// Phased array elements, combine a bunch together to get god's strongest radar, or whatever else you can think of +/obj/item/epic_loot/phased_array + name = "phased array element" + desc = "An element of a larger phased array. These combine together to produce sensing and scanning devices used on most common space-faring vessels." + icon_state = "phased_array" + inhand_icon_state = "blankplaque" + w_class = WEIGHT_CLASS_NORMAL + drop_sound = 'sound/items/handling/ammobox_drop.ogg' + pickup_sound = 'sound/items/handling/ammobox_pickup.ogg' + custom_materials = list( + /datum/material/plastic = SHEET_MATERIAL_AMOUNT * 2, + /datum/material/silver = SHEET_MATERIAL_AMOUNT, + /datum/material/gold = SHEET_MATERIAL_AMOUNT, + ) + +// Shuttle batteries, used to power electronics while the engines are off +/obj/item/epic_loot/shuttle_battery + name = "shuttle battery" + desc = "A massive shuttle-grade battery, used to keep the electronics of space-faring vessel powered while the main engines are de-activated." + icon_state = "ship_battery" + inhand_icon_state = "blankplaque" + w_class = WEIGHT_CLASS_BULKY + drop_sound = 'sound/items/handling/cardboard_box/cardboardbox_drop.ogg' + pickup_sound = 'sound/items/handling/cardboard_box/cardboardbox_pickup.ogg' + custom_materials = list( + /datum/material/plastic = SHEET_MATERIAL_AMOUNT * 10, + /datum/material/silver = SHEET_MATERIAL_AMOUNT * 4, + /datum/material/gold = SHEET_MATERIAL_AMOUNT * 4, + ) + +/obj/item/epic_loot/shuttle_battery/Initialize(mapload) + . = ..() + AddComponent(/datum/component/two_handed, require_twohands = TRUE) + +// Industrial fuel conditioner, used to keep most fuel-burning machines within regulations for waste emissions +/obj/item/epic_loot/fuel_conditioner + name = "fuel conditioner" + desc = "A plastic container of fuel conditioner for industrial size plasma generators. \ + Any generator that would need this is either much too large or much too old to be seen around here." + icon_state = "fuel_conditioner" + w_class = WEIGHT_CLASS_NORMAL + drop_sound = 'sound/items/handling/cardboard_box/cardboardbox_drop.ogg' + pickup_sound = 'sound/items/handling/cardboard_box/cardboardbox_pickup.ogg' diff --git a/modular_doppler/epic_loot/code/loot_items/electronics.dm b/modular_doppler/epic_loot/code/loot_items/electronics.dm new file mode 100644 index 0000000000000..5719a1ed842e6 --- /dev/null +++ b/modular_doppler/epic_loot/code/loot_items/electronics.dm @@ -0,0 +1,143 @@ +/datum/export/epic_loot_electronics + cost = PAYCHECK_COMMAND + unit_name = "electronic salvage" + export_types = list( + /obj/item/epic_loot/device_fan, + /obj/item/epic_loot/display_broken, + /obj/item/epic_loot/civilian_circuit, + /obj/item/epic_loot/processor, + /obj/item/epic_loot/disk_drive, + ) + +/datum/export/epic_loot_electronics_super + cost = PAYCHECK_COMMAND * 2 + unit_name = "high value electronic salvage" + export_types = list( + /obj/item/epic_loot/display, + /obj/item/epic_loot/graphics, + /obj/item/epic_loot/military_circuit, + /obj/item/epic_loot/power_supply, + ) + +// Computer fans +/obj/item/epic_loot/device_fan + name = "device fan" + desc = "An electronics cooling fan, used to keep computers and the like at reasonable temperatures while working." + icon_state = "device_fan" + drop_sound = 'sound/items/handling/ammobox_drop.ogg' + pickup_sound = 'sound/items/handling/ammobox_pickup.ogg' + custom_materials = list( + /datum/material/plastic = SMALL_MATERIAL_AMOUNT * 9, + /datum/material/gold = SMALL_MATERIAL_AMOUNT, + ) + +// A display of some sort, this one probably still works +/obj/item/epic_loot/display + name = "display" + desc = "An electronic display, used in any number of machines to display information to users." + icon_state = "display" + w_class = WEIGHT_CLASS_NORMAL + drop_sound = 'sound/items/handling/ammobox_drop.ogg' + pickup_sound = 'sound/items/handling/ammobox_pickup.ogg' + custom_materials = list( + /datum/material/plastic = SMALL_MATERIAL_AMOUNT * 5, + /datum/material/glass = SMALL_MATERIAL_AMOUNT * 4, + /datum/material/gold = SMALL_MATERIAL_AMOUNT, + ) + +// A display of some sort, this one for sure does not work +/obj/item/epic_loot/display_broken + name = "broken display" + desc = "An electronic display, used in any number of machines to display information to users. This one is broken." + icon_state = "display_broken" + w_class = WEIGHT_CLASS_NORMAL + drop_sound = 'sound/items/handling/ammobox_drop.ogg' + pickup_sound = 'sound/items/handling/ammobox_pickup.ogg' + custom_materials = list( + /datum/material/plastic = SMALL_MATERIAL_AMOUNT * 5, + /datum/material/glass = SMALL_MATERIAL_AMOUNT * 4, + /datum/material/gold = SMALL_MATERIAL_AMOUNT, + ) + +// Martian made very high quality no scam 质量非常高 +/obj/item/epic_loot/graphics + name = "graphics processor" + desc = "A large processor card for the handling of computer generated graphics." + icon_state = "graphics" + w_class = WEIGHT_CLASS_NORMAL + drop_sound = 'sound/items/handling/ammobox_drop.ogg' + pickup_sound = 'sound/items/handling/ammobox_pickup.ogg' + custom_materials = list( + /datum/material/plastic = SMALL_MATERIAL_AMOUNT * 8, + /datum/material/silver = SMALL_MATERIAL_AMOUNT * 2, + /datum/material/gold = SMALL_MATERIAL_AMOUNT * 2, + ) + +// A military general-use circuit board +/obj/item/epic_loot/military_circuit + name = "military-grade circuit board" + desc = "A small circuit board commonly seen used by military-grade electronics." + icon_state = "circuit_military" + drop_sound = 'sound/items/handling/component_drop.ogg' + pickup_sound = 'sound/items/handling/component_pickup.ogg' + custom_materials = list( + /datum/material/plastic = SMALL_MATERIAL_AMOUNT * 6, + /datum/material/titanium = SMALL_MATERIAL_AMOUNT * 2, + /datum/material/silver = SMALL_MATERIAL_AMOUNT * 2, + /datum/material/gold = SMALL_MATERIAL_AMOUNT * 2, + ) + +// A civilian general-use circuit board +/obj/item/epic_loot/civilian_circuit + name = "general-purpose circuit board" + desc = "A small circuit board commonly seen used by general-purpose electronics." + icon_state = "civilian_circuit" + drop_sound = 'sound/items/handling/component_drop.ogg' + pickup_sound = 'sound/items/handling/component_pickup.ogg' + custom_materials = list( + /datum/material/plastic = SMALL_MATERIAL_AMOUNT * 6, + /datum/material/silver = SMALL_MATERIAL_AMOUNT * 2, + /datum/material/gold = SMALL_MATERIAL_AMOUNT * 2, + ) + +// A computer processor unit +/obj/item/epic_loot/processor + name = "processor core" + desc = "The processing core of a computer, the small chip responsible for all of the inner workings of most devices." + icon_state = "processor" + inhand_icon_state = "razor" + drop_sound = 'sound/items/handling/component_drop.ogg' + pickup_sound = 'sound/items/handling/component_pickup.ogg' + custom_materials = list( + /datum/material/plastic = SMALL_MATERIAL_AMOUNT * 3, + /datum/material/silver = SMALL_MATERIAL_AMOUNT, + /datum/material/gold = SMALL_MATERIAL_AMOUNT, + ) + +// A computer power supply +/obj/item/epic_loot/power_supply + name = "computer power supply" + desc = "A computer power supply, used to provide regulated electric power to other components of a computer." + icon_state = "psu" + w_class = WEIGHT_CLASS_NORMAL + drop_sound = 'sound/items/handling/ammobox_drop.ogg' + pickup_sound = 'sound/items/handling/ammobox_pickup.ogg' + custom_materials = list( + /datum/material/plastic = SMALL_MATERIAL_AMOUNT * 8, + /datum/material/silver = SMALL_MATERIAL_AMOUNT * 2, + /datum/material/gold = SMALL_MATERIAL_AMOUNT * 2, + ) + +// A drive for reading data from data disks in computers +/obj/item/epic_loot/disk_drive + name = "hard-disk reader" + desc = "A device for reading and writing data to hard-disks, one of the most common data storage media on the frontier." + icon_state = "disk_drive" + w_class = WEIGHT_CLASS_NORMAL + drop_sound = 'sound/items/handling/ammobox_drop.ogg' + pickup_sound = 'sound/items/handling/ammobox_pickup.ogg' + custom_materials = list( + /datum/material/plastic = SMALL_MATERIAL_AMOUNT * 8, + /datum/material/silver = SMALL_MATERIAL_AMOUNT * 2, + /datum/material/gold = SMALL_MATERIAL_AMOUNT * 2, + ) diff --git a/modular_doppler/epic_loot/code/loot_items/medical.dm b/modular_doppler/epic_loot/code/loot_items/medical.dm new file mode 100644 index 0000000000000..d645cc4160f0a --- /dev/null +++ b/modular_doppler/epic_loot/code/loot_items/medical.dm @@ -0,0 +1,46 @@ +/datum/export/epic_loot_super_med_tools + cost = PAYCHECK_COMMAND * 5 + unit_name = "high value medical salvage" + export_types = list( + /obj/item/epic_loot/vein_finder, + /obj/item/epic_loot/eye_scope, + ) + +// Vein finder, uses strong LED lights to reveal veins in someone's body. Perhaps the name "LEDX" rings a bell +/obj/item/epic_loot/vein_finder + name = "medical vein locator" + desc = "A small device with a number of high intensity lights on one side. Used by medical professionals to locate veins in someone's body." + icon_state = "vein_finder" + inhand_icon_state = "headset" + drop_sound = 'sound/items/handling/component_drop.ogg' + pickup_sound = 'sound/items/handling/component_pickup.ogg' + custom_materials = list( + /datum/material/plastic = SMALL_MATERIAL_AMOUNT * 8, + /datum/material/silver = SMALL_MATERIAL_AMOUNT * 2, + /datum/material/gold = SMALL_MATERIAL_AMOUNT * 2, + ) + +/obj/item/epic_loot/vein_finder/afterattack(atom/target, mob/user, proximity_flag) + . = ..() + if(!proximity_flag) + return + if(!ishuman(target)) + return + user.visible_message( + "[user] determines that [target] does, in fact, have veins.", + "You determine that [target] does, in fact, have veins." + ) + new /obj/effect/temp_visual/medical_holosign(get_turf(target), user) + +// Eyescope, a now rare device that was used to check the eyes of patients before the universal health scanner became common +/obj/item/epic_loot/eye_scope + name = "medical eye-scope" + desc = "An outdated device used to examine a patient's eyes. Rare now due to the outbreak of the universal health scanner." + icon_state = "eyescope" + inhand_icon_state = "zippo" + drop_sound = 'sound/items/handling/component_drop.ogg' + pickup_sound = 'sound/items/handling/component_pickup.ogg' + custom_materials = list( + /datum/material/plastic = SMALL_MATERIAL_AMOUNT * 8, + /datum/material/glass = SMALL_MATERIAL_AMOUNT * 2, + ) diff --git a/modular_doppler/epic_loot/code/loot_items/valuables.dm b/modular_doppler/epic_loot/code/loot_items/valuables.dm new file mode 100644 index 0000000000000..fb209e9a6485e --- /dev/null +++ b/modular_doppler/epic_loot/code/loot_items/valuables.dm @@ -0,0 +1,159 @@ +/datum/export/epic_loot_valuables + cost = PAYCHECK_COMMAND * 3 + unit_name = "recovered valuables" + export_types = list( + /obj/item/epic_loot/press_pass, + /obj/item/epic_loot/hdd, + /obj/item/epic_loot/slim_diary, + /obj/item/epic_loot/plasma_explosive, + /obj/item/epic_loot/silver_chainlet, + ) + +/datum/export/epic_loot_valuables_super + cost = PAYCHECK_COMMAND * 4 + unit_name = "recovered high valuables" + export_types = list( + /obj/item/epic_loot/ssd, + /obj/item/epic_loot/military_flash, + /obj/item/epic_loot/diary, + /obj/item/epic_loot/corpo_folder, + /obj/item/epic_loot/intel_folder, + /obj/item/epic_loot/gold_chainlet, + ) + +// An old press pass, perhaps of an unlucky soul who was reporting on the incident that made this place abandoned in the first place +/obj/item/epic_loot/press_pass + name = "expired visitor pass" + desc = "An old lanyard with an expired visitor pass stuck to it. Most of the text has worn off, you can't tell who it was for or who it was issued by." + icon_state = "press_pass" + drop_sound = 'sound/items/handling/disk_drop.ogg' + pickup_sound = 'sound/items/handling/disk_pickup.ogg' + w_class = WEIGHT_CLASS_NORMAL + custom_materials = list( + /datum/material/plastic = SMALL_MATERIAL_AMOUNT * 8, + ) + +// A computer SSD +/obj/item/epic_loot/ssd + name = "solid-state drive" + desc = "A solid-state drive for computers, may even contain some still-valuable information on it!" + icon_state = "ssd" + inhand_icon_state = "razor" + drop_sound = 'sound/items/handling/disk_drop.ogg' + pickup_sound = 'sound/items/handling/disk_pickup.ogg' + custom_materials = list( + /datum/material/plastic = SMALL_MATERIAL_AMOUNT * 8, + /datum/material/silver = SMALL_MATERIAL_AMOUNT * 2, + ) + +// A computer hard drive +/obj/item/epic_loot/hdd + name = "hard drive" + desc = "A hard drive for computers, may even contain some still-valuable information on it!" + icon_state = "hard_disk" + inhand_icon_state = "razor" + drop_sound = 'sound/items/handling/disk_drop.ogg' + pickup_sound = 'sound/items/handling/disk_pickup.ogg' + w_class = WEIGHT_CLASS_NORMAL + custom_materials = list( + /datum/material/plastic = SMALL_MATERIAL_AMOUNT * 8, + /datum/material/silver = SMALL_MATERIAL_AMOUNT * 2, + ) + +// Military-grade flash drives, made for use specifically with military computers +/obj/item/epic_loot/military_flash + name = "military flash drive" + desc = "A military-grade flash drive for use in matching military-grade computer systems. Might even contain some still-valuable information on it!" + icon_state = "military_flash" + inhand_icon_state = "razor" + drop_sound = 'sound/items/handling/disk_drop.ogg' + pickup_sound = 'sound/items/handling/disk_pickup.ogg' + custom_materials = list( + /datum/material/plastic = SMALL_MATERIAL_AMOUNT * 8, + /datum/material/silver = SMALL_MATERIAL_AMOUNT * 2, + ) + +// Someone's personal diary, or bootleg captain's log, whatever +/obj/item/epic_loot/diary + name = "sealed diary" + desc = "An old, apparently well-kept diary with unknown information inside. May hold important data on the location it was found in." + icon_state = "diary" + drop_sound = 'sound/items/handling/book_drop.ogg' + pickup_sound = 'sound/items/handling/book_pickup.ogg' + w_class = WEIGHT_CLASS_NORMAL + custom_materials = list( + /datum/material/plastic = SMALL_MATERIAL_AMOUNT * 8, + ) + +// A slimmer version of the regular diary +/obj/item/epic_loot/slim_diary + name = "sealed slim diary" + desc = "An old, apparently well-kept diary with unknown information inside. May hold important data on the location it was found in." + icon_state = "slim_diary" + drop_sound = 'sound/items/handling/book_drop.ogg' + pickup_sound = 'sound/items/handling/book_pickup.ogg' + custom_materials = list( + /datum/material/plastic = SMALL_MATERIAL_AMOUNT * 8, + ) + +// Straight up, a brick of plasma-cringe explosive, keep away from fire +/obj/item/epic_loot/plasma_explosive + name = "brick of plasma-based explosive" + desc = "A really quite dangerous brick of a plasma-based explosive. Usually, a demolition charge or something of the sort, but, it's still a bomb." + icon_state = "plasma_explosive" + drop_sound = 'sound/items/handling/cardboard_box/cardboardbox_drop.ogg' + pickup_sound = 'sound/items/handling/cardboard_box/cardboardbox_pickup.ogg' + w_class = WEIGHT_CLASS_NORMAL + custom_materials = list( + /datum/material/plasma = SHEET_MATERIAL_AMOUNT * 3, + ) + +/obj/item/epic_loot/plasma_explosive/Initialize(mapload) + . = ..() + AddComponent(/datum/component/explodable, 0, 1, 3, 5, 5) + +// A folder from some corporation with likely valuable data inside +/obj/item/epic_loot/corpo_folder + name = "corporate data folder" + desc = "A blue folder with no label of who it's from. What is labeled, however, is the series of marks of confidential or trade secret information inside." + icon_state = "nt_folders" + drop_sound = 'sound/items/handling/book_drop.ogg' + pickup_sound = 'sound/items/handling/book_pickup.ogg' + w_class = WEIGHT_CLASS_NORMAL + custom_materials = list( + /datum/material/plastic = SMALL_MATERIAL_AMOUNT * 8, + ) + +// Brown unlabeled folder of doom, may contain government secrets +/obj/item/epic_loot/intel_folder + name = "intelligence folder" + desc = "A an unmarked, unassuming folder for documents. What is labeled, however, is the series of marks of confidential or trade secret information inside." + icon_state = "documents" + drop_sound = 'sound/items/handling/book_drop.ogg' + pickup_sound = 'sound/items/handling/book_pickup.ogg' + w_class = WEIGHT_CLASS_NORMAL + custom_materials = list( + /datum/material/plastic = SMALL_MATERIAL_AMOUNT * 8, + ) + +// A small chainlet made of silver +/obj/item/epic_loot/silver_chainlet + name = "silver chainlet" + desc = "A small chainlet for decorating clothing or other items, made from silver." + icon_state = "silver_chain" + drop_sound = 'sound/items/handling/disk_drop.ogg' + pickup_sound = 'sound/items/handling/disk_pickup.ogg' + custom_materials = list( + /datum/material/silver = SHEET_MATERIAL_AMOUNT, + ) + +// A small chainlet made of gold +/obj/item/epic_loot/gold_chainlet + name = "gold chainlet" + desc = "A small chainlet for decorating clothing or other items, made from gold." + icon_state = "gold_chain" + drop_sound = 'sound/items/handling/disk_drop.ogg' + pickup_sound = 'sound/items/handling/disk_pickup.ogg' + custom_materials = list( + /datum/material/gold = SHEET_MATERIAL_AMOUNT, + ) diff --git a/modular_doppler/epic_loot/code/loot_structures/ammo_box.dm b/modular_doppler/epic_loot/code/loot_structures/ammo_box.dm new file mode 100644 index 0000000000000..d9d5f0f21e060 --- /dev/null +++ b/modular_doppler/epic_loot/code/loot_structures/ammo_box.dm @@ -0,0 +1,34 @@ +/datum/storage/maintenance_loot_structure/ammo_box + max_slots = 6 + max_specific_storage = WEIGHT_CLASS_NORMAL + max_total_storage = WEIGHT_CLASS_NORMAL * 6 + screen_max_columns = 3 + opening_sound = 'modular_doppler/epic_loot/sound/wood_crate_3.mp3' + +/obj/structure/maintenance_loot_structure/ammo_box + name = "small shipping crate" + desc = "A small reinforced box used for shipping small items in." + icon_state = "ammo_box" + storage_datum_to_use = /datum/storage/maintenance_loot_structure/ammo_box + loot_spawn_dice_string = "1d10-4" + loot_weighted_list = list( + /obj/effect/spawner/random/epic_loot/random_engineering = 1, + /obj/effect/spawner/random/epic_loot/random_provisions = 1, + /obj/effect/spawner/random/epic_loot/random_other_military_loot = 1, + ) + +/obj/structure/maintenance_loot_structure/ammo_box/super_evil + icon_state = "cache" + +/obj/structure/maintenance_loot_structure/ammo_box/random + icon_state = "ammo_box_random" + /// The different icon states we can swap to when initializing + var/list/random_icon_states = list( + "ammo_box", + "cache", + ) + +/obj/structure/maintenance_loot_structure/ammo_box/random/Initialize(mapload) + . = ..() + icon_state = pick(random_icon_states) + update_appearance() diff --git a/modular_doppler/epic_loot/code/loot_structures/computer_tower.dm b/modular_doppler/epic_loot/code/loot_structures/computer_tower.dm new file mode 100644 index 0000000000000..b53491ae61b63 --- /dev/null +++ b/modular_doppler/epic_loot/code/loot_structures/computer_tower.dm @@ -0,0 +1,36 @@ +/datum/storage/maintenance_loot_structure/computer + max_slots = 4 + max_specific_storage = WEIGHT_CLASS_NORMAL + max_total_storage = WEIGHT_CLASS_NORMAL * 4 + screen_max_columns = 2 + opening_sound = 'modular_doppler/epic_loot/sound/plastic.mp3' + +/obj/structure/maintenance_loot_structure/computer_tower + name = "computer tower" + desc = "A compact computer unit, missing it's monitor. May still contain valuable components inside." + icon_state = "alienware" + storage_datum_to_use = /datum/storage/maintenance_loot_structure/computer + loot_spawn_dice_string = "1d7-3" + loot_weighted_list = list( + /obj/effect/spawner/random/epic_loot/random_computer_parts = 1, + ) + +/obj/structure/maintenance_loot_structure/computer_tower/white + icon_state = "alienware_honeycrisp" + +/obj/structure/maintenance_loot_structure/computer_tower/eighties + icon_state = "alienware_tan_man" + +/obj/structure/maintenance_loot_structure/computer_tower/random + icon_state = "alienware_random" + /// The different icon states we can swap to when initializing + var/list/random_icon_states = list( + "alienware", + "alienware_honeycrisp", + "alienware_tan_man", + ) + +/obj/structure/maintenance_loot_structure/computer_tower/random/Initialize(mapload) + . = ..() + icon_state = pick(random_icon_states) + update_appearance() diff --git a/modular_doppler/epic_loot/code/loot_structures/files.dm b/modular_doppler/epic_loot/code/loot_structures/files.dm new file mode 100644 index 0000000000000..5a0557ffcdd6f --- /dev/null +++ b/modular_doppler/epic_loot/code/loot_structures/files.dm @@ -0,0 +1,32 @@ +/datum/storage/maintenance_loot_structure/file_cabinet + max_slots = 6 + max_specific_storage = WEIGHT_CLASS_NORMAL + max_total_storage = WEIGHT_CLASS_NORMAL * 6 + screen_max_columns = 2 + opening_sound = 'modular_doppler/epic_loot/sound/cabinet.mp3' + +/obj/structure/maintenance_loot_structure/file_cabinet + name = "filing cabinet" + desc = "A large filing cabinet, it even comes with terrible sounding unlubricated rails!" + icon_state = "files" + storage_datum_to_use = /datum/storage/maintenance_loot_structure/file_cabinet + loot_spawn_dice_string = "1d10-4" + loot_weighted_list = list( + /obj/effect/spawner/random/epic_loot/random_documents = 9, + ) + +/obj/structure/maintenance_loot_structure/file_cabinet/white + icon_state = "files_clean" + +/obj/structure/maintenance_loot_structure/file_cabinet/random + icon_state = "files_random" + /// The different icon states we can swap to when initializing + var/list/random_icon_states = list( + "files", + "files_clean", + ) + +/obj/structure/maintenance_loot_structure/file_cabinet/random/Initialize(mapload) + . = ..() + icon_state = pick(random_icon_states) + update_appearance() diff --git a/modular_doppler/epic_loot/code/loot_structures/grenade_box.dm b/modular_doppler/epic_loot/code/loot_structures/grenade_box.dm new file mode 100644 index 0000000000000..df773672fec76 --- /dev/null +++ b/modular_doppler/epic_loot/code/loot_structures/grenade_box.dm @@ -0,0 +1,34 @@ +/datum/storage/maintenance_loot_structure/grenade_box + max_slots = 4 + max_specific_storage = WEIGHT_CLASS_NORMAL + max_total_storage = WEIGHT_CLASS_NORMAL * 4 + screen_max_columns = 2 + opening_sound = 'modular_doppler/epic_loot/sound/wood_crate_2.mp3' + +/obj/structure/maintenance_loot_structure/grenade_box + name = "small shipping crate" + desc = "A reinforced shipping crate for the transport of small items." + icon_state = "grenade_box" + storage_datum_to_use = /datum/storage/maintenance_loot_structure/grenade_box + loot_spawn_dice_string = "1d6-2" + loot_weighted_list = list( + /obj/effect/spawner/random/epic_loot/random_engineering = 1, + /obj/effect/spawner/random/epic_loot/random_provisions = 1, + /obj/effect/spawner/random/epic_loot/random_other_military_loot = 1, + ) + +/obj/structure/maintenance_loot_structure/grenade_box/evil + icon_state = "grenade_box_evil" + +/obj/structure/maintenance_loot_structure/grenade_box/random + icon_state = "grenade_box_random" + /// The different icon states we can swap to when initializing + var/list/random_icon_states = list( + "grenade_box", + "grenade_box_evil", + ) + +/obj/structure/maintenance_loot_structure/grenade_box/random/Initialize(mapload) + . = ..() + icon_state = pick(random_icon_states) + update_appearance() diff --git a/modular_doppler/epic_loot/code/loot_structures/gun_case.dm b/modular_doppler/epic_loot/code/loot_structures/gun_case.dm new file mode 100644 index 0000000000000..fa7d384e057bd --- /dev/null +++ b/modular_doppler/epic_loot/code/loot_structures/gun_case.dm @@ -0,0 +1,34 @@ +/datum/storage/maintenance_loot_structure/gun_box + max_slots = 4 + max_specific_storage = WEIGHT_CLASS_BULKY + max_total_storage = WEIGHT_CLASS_BULKY * 4 + screen_max_columns = 4 + opening_sound = 'modular_doppler/epic_loot/sound/wood_crate_3.mp3' + +/obj/structure/maintenance_loot_structure/gun_box + name = "shipping crate" + desc = "A reinforced shipping crate foor the transport of larger items." + icon_state = "guncrate" + storage_datum_to_use = /datum/storage/maintenance_loot_structure/gun_box + loot_spawn_dice_string = "1d7-3" + loot_weighted_list = list( + /obj/effect/spawner/random/epic_loot/random_engineering = 1, + /obj/effect/spawner/random/epic_loot/random_provisions = 1, + /obj/effect/spawner/random/epic_loot/random_other_military_loot = 1, + ) + +/obj/structure/maintenance_loot_structure/gun_box/evil + icon_state = "guncrate_dark" + +/obj/structure/maintenance_loot_structure/gun_box/random + icon_state = "guncrate_random" + /// The different icon states we can swap to when initializing + var/list/random_icon_states = list( + "guncrate", + "guncrate_dark", + ) + +/obj/structure/maintenance_loot_structure/gun_box/random/Initialize(mapload) + . = ..() + icon_state = pick(random_icon_states) + update_appearance() diff --git a/modular_doppler/epic_loot/code/loot_structures/large_crate.dm b/modular_doppler/epic_loot/code/loot_structures/large_crate.dm new file mode 100644 index 0000000000000..1164a42b17a7f --- /dev/null +++ b/modular_doppler/epic_loot/code/loot_structures/large_crate.dm @@ -0,0 +1,63 @@ +/datum/storage/maintenance_loot_structure/large_crate + max_slots = 16 + max_specific_storage = WEIGHT_CLASS_BULKY + max_total_storage = WEIGHT_CLASS_BULKY * 16 + screen_max_columns = 4 + opening_sound = 'modular_doppler/epic_loot/sound/wood_crate_3.mp3' + +/obj/structure/maintenance_loot_structure/large_crate + name = "provision transport crate" + desc = "A large crate for transporting equally large amounts of food supplies around." + icon_state = "foodcrate" + storage_datum_to_use = /datum/storage/maintenance_loot_structure/large_crate + loot_spawn_dice_string = "4d5-4" + loot_weighted_list = list( + /obj/effect/spawner/random/epic_loot/random_provisions = 1, + ) + +/obj/structure/maintenance_loot_structure/large_crate/medical + name = "medical transport crate" + desc = "A large crate for transporting equally large amounts of medical supplies around." + icon_state = "medcrate" + loot_weighted_list = list( + /obj/effect/spawner/random/epic_loot/medical_everything = 1, + ) + +/obj/structure/maintenance_loot_structure/large_crate/medical/airdrop + icon_state = "supplydrop" + +/obj/structure/maintenance_loot_structure/large_crate/engineering + name = "engineering transport crate" + desc = "A large crate for transporting equally large amounts of tools and components around." + icon_state = "toolcrate" + loot_weighted_list = list( + /obj/effect/spawner/random/epic_loot/random_engineering = 1, + ) + +/obj/structure/maintenance_loot_structure/large_crate/engineering/airdrop + icon_state = "supplydrop_yellow" + +/obj/structure/maintenance_loot_structure/large_crate/military + name = "reinforced transport crate" + desc = "A large crate for transporting equally large amounts of militar." + icon_state = "supplydrop_green" + loot_weighted_list = list( + /obj/effect/spawner/random/epic_loot/random_engineering = 1, + /obj/effect/spawner/random/epic_loot/random_provisions = 1, + /obj/effect/spawner/random/epic_loot/random_other_military_loot = 1, + /obj/effect/spawner/random/epic_loot/medical_everything = 1, + ) + +/obj/effect/spawner/random/epic_loot/random_supply_crate + name = "random supply crate spawner" + desc = "Automagically transforms into a random supply crate, hopefully filled with goodies." + icon = 'modular_doppler/epic_loot/icons/loot_structures.dmi' + icon_state = "crate_random" + loot = list( + /obj/structure/maintenance_loot_structure/large_crate, + /obj/structure/maintenance_loot_structure/large_crate/medical, + /obj/structure/maintenance_loot_structure/large_crate/medical/airdrop, + /obj/structure/maintenance_loot_structure/large_crate/engineering, + /obj/structure/maintenance_loot_structure/large_crate/engineering/airdrop, + /obj/structure/maintenance_loot_structure/large_crate/military, + ) diff --git a/modular_doppler/epic_loot/code/loot_structures/medbox.dm b/modular_doppler/epic_loot/code/loot_structures/medbox.dm new file mode 100644 index 0000000000000..40ffab841a33d --- /dev/null +++ b/modular_doppler/epic_loot/code/loot_structures/medbox.dm @@ -0,0 +1,36 @@ +/datum/storage/maintenance_loot_structure/medical_box + max_slots = 6 + max_specific_storage = WEIGHT_CLASS_BULKY + max_total_storage = WEIGHT_CLASS_BULKY * 6 + screen_max_columns = 3 + opening_sound = 'modular_doppler/epic_loot/sound/plastic.mp3' + +/obj/structure/maintenance_loot_structure/medbox + name = "emergency medical box" + desc = "A large, atmos-sealed plastic container for holding emergency medical supplies." + icon_state = "medbox" + storage_datum_to_use = /datum/storage/maintenance_loot_structure/medical_box + loot_spawn_dice_string = "1d8-2" + loot_weighted_list = list( + /obj/effect/spawner/random/epic_loot/medical_everything = 1, + ) + +/obj/structure/maintenance_loot_structure/medbox/bleu + icon_state = "medbox_blue" + +/obj/structure/maintenance_loot_structure/medbox/red + icon_state = "medbox_red" + +/obj/structure/maintenance_loot_structure/medbox/random + icon_state = "medbox_random" + /// The different icon states we can swap to when initializing + var/list/random_icon_states = list( + "medbox", + "medbox_blue", + "medbox_red", + ) + +/obj/structure/maintenance_loot_structure/medbox/random/Initialize(mapload) + . = ..() + icon_state = pick(random_icon_states) + update_appearance() diff --git a/modular_doppler/epic_loot/code/loot_structures/military_case.dm b/modular_doppler/epic_loot/code/loot_structures/military_case.dm new file mode 100644 index 0000000000000..0b26b90cf3e74 --- /dev/null +++ b/modular_doppler/epic_loot/code/loot_structures/military_case.dm @@ -0,0 +1,38 @@ +/datum/storage/maintenance_loot_structure/military_case + max_slots = 8 + max_specific_storage = WEIGHT_CLASS_BULKY + max_total_storage = WEIGHT_CLASS_BULKY * 8 + screen_max_columns = 4 + opening_sound = 'modular_doppler/epic_loot/sound/wood_crate_3.mp3' + +/obj/structure/maintenance_loot_structure/military_case + name = "large shipping crate" + desc = "A reinforced shipping crate for the transport of larger items." + icon_state = "military_crate" + storage_datum_to_use = /datum/storage/maintenance_loot_structure/military_case + loot_spawn_dice_string = "1d10-2" + loot_weighted_list = list( + /obj/effect/spawner/random/epic_loot/random_engineering = 1, + /obj/effect/spawner/random/epic_loot/random_provisions = 1, + /obj/effect/spawner/random/epic_loot/random_other_military_loot = 1, + ) + +/obj/structure/maintenance_loot_structure/military_case/evil + icon_state = "guncrate_dark" + +/obj/structure/maintenance_loot_structure/military_case/super_evil + icon_state = "larpbox" + +/obj/structure/maintenance_loot_structure/military_case/random + icon_state = "military_crate_random" + /// The different icon states we can swap to when initializing + var/list/random_icon_states = list( + "military_crate", + "military_crate_dark", + "larpbox", + ) + +/obj/structure/maintenance_loot_structure/military_case/random/Initialize(mapload) + . = ..() + icon_state = pick(random_icon_states) + update_appearance() diff --git a/modular_doppler/epic_loot/code/loot_structures/register.dm b/modular_doppler/epic_loot/code/loot_structures/register.dm new file mode 100644 index 0000000000000..0013d6d7761a3 --- /dev/null +++ b/modular_doppler/epic_loot/code/loot_structures/register.dm @@ -0,0 +1,42 @@ +/datum/storage/maintenance_loot_structure/register + max_slots = 2 + max_specific_storage = WEIGHT_CLASS_NORMAL + max_total_storage = WEIGHT_CLASS_NORMAL * 2 + screen_max_columns = 2 + opening_sound = 'modular_doppler/epic_loot/sound/wood_crate_2.mp3' + +/obj/structure/maintenance_loot_structure/register + name = "credits register" + desc = "A compact computing unit to handle transfers of credits between accounts. May still contain currency left behind!" + icon_state = "register_small" + storage_datum_to_use = /datum/storage/maintenance_loot_structure/register + loot_spawn_dice_string = "1d3-1" + loot_weighted_list = list( + /obj/effect/spawner/random/entertainment/coin = 1, + /obj/effect/spawner/random/entertainment/money_small = 2, + /obj/effect/spawner/random/entertainment/money = 1, + ) + +/obj/structure/maintenance_loot_structure/register/white + icon_state = "register_small_clean" + +/obj/structure/maintenance_loot_structure/register/big + icon_state = "register_big" + +/obj/structure/maintenance_loot_structure/register/big_white + icon_state = "register_big_clean" + +/obj/structure/maintenance_loot_structure/register/random + icon_state = "register_random" + /// The different icon states we can swap to when initializing + var/list/random_icon_states = list( + "register_small", + "register_small_clean", + "register_big", + "register_big_clean", + ) + +/obj/structure/maintenance_loot_structure/register/random/Initialize(mapload) + . = ..() + icon_state = pick(random_icon_states) + update_appearance() diff --git a/modular_doppler/epic_loot/code/loot_structures/safe.dm b/modular_doppler/epic_loot/code/loot_structures/safe.dm new file mode 100644 index 0000000000000..2b5342e028805 --- /dev/null +++ b/modular_doppler/epic_loot/code/loot_structures/safe.dm @@ -0,0 +1,32 @@ +/datum/storage/maintenance_loot_structure/desk_safe + max_slots = 2 + max_specific_storage = WEIGHT_CLASS_NORMAL + max_total_storage = WEIGHT_CLASS_NORMAL * 2 + screen_max_columns = 1 + opening_sound = 'modular_doppler/epic_loot/sound/wood_crate_3.mp3' + +/obj/structure/maintenance_loot_structure/desk_safe + name = "compact safe" + desc = "A not-so-secure safe meant to fit around or under desks." + icon_state = "safe" + storage_datum_to_use = /datum/storage/maintenance_loot_structure/desk_safe + loot_spawn_dice_string = "1d3-1" + loot_weighted_list = list( + /obj/effect/spawner/random/epic_loot/random_strongbox_loot = 1, + ) + +/obj/structure/maintenance_loot_structure/desk_safe/bleu + icon_state = "safe_blue" + +/obj/structure/maintenance_loot_structure/desk_safe/random + icon_state = "safe_random" + /// The different icon states we can swap to when initializing + var/list/random_icon_states = list( + "safe", + "safe_blue", + ) + +/obj/structure/maintenance_loot_structure/desk_safe/random/Initialize(mapload) + . = ..() + icon_state = pick(random_icon_states) + update_appearance() diff --git a/modular_doppler/epic_loot/code/loot_structures/toolbox.dm b/modular_doppler/epic_loot/code/loot_structures/toolbox.dm new file mode 100644 index 0000000000000..43e2babff2852 --- /dev/null +++ b/modular_doppler/epic_loot/code/loot_structures/toolbox.dm @@ -0,0 +1,38 @@ +/datum/storage/maintenance_loot_structure/toolbox + max_slots = 6 + max_specific_storage = WEIGHT_CLASS_BULKY + max_total_storage = WEIGHT_CLASS_BULKY * 6 + screen_max_columns = 3 + opening_sound = 'modular_doppler/epic_loot/sound/wood_crate_1.mp3' + +/obj/structure/maintenance_loot_structure/toolbox + name = "heavy toolbox" + desc = "An industrial grade toolbox, for when you need to carry a LOT of things to a job. \ + It's previous owner has smartly attached this one pretty firmly to whatever surface it's on, \ + to prevent theft." + icon_state = "toolbox" + storage_datum_to_use = /datum/storage/maintenance_loot_structure/toolbox + loot_spawn_dice_string = "1d8-2" + loot_weighted_list = list( + /obj/effect/spawner/random/epic_loot/random_engineering = 1, + ) + +/obj/structure/maintenance_loot_structure/toolbox/yellow + icon_state = "toolbox_yellow" + +/obj/structure/maintenance_loot_structure/toolbox/red + icon_state = "toolbox_red" + +/obj/structure/maintenance_loot_structure/toolbox/random + icon_state = "toolbox_random" + /// The different icon states we can swap to when initializing + var/list/random_icon_states = list( + "toolbox", + "toolbox_yellow", + "toolbox_red", + ) + +/obj/structure/maintenance_loot_structure/toolbox/random/Initialize(mapload) + . = ..() + icon_state = pick(random_icon_states) + update_appearance() diff --git a/modular_doppler/epic_loot/code/loot_structures/wall_jackets.dm b/modular_doppler/epic_loot/code/loot_structures/wall_jackets.dm new file mode 100644 index 0000000000000..3b3bfd24b0802 --- /dev/null +++ b/modular_doppler/epic_loot/code/loot_structures/wall_jackets.dm @@ -0,0 +1,67 @@ +/datum/storage/maintenance_loot_structure/jacket + max_slots = 2 + max_specific_storage = WEIGHT_CLASS_NORMAL + max_total_storage = WEIGHT_CLASS_NORMAL * 4 + screen_max_columns = 2 + opening_sound = 'sound/items/handling/cloth_pickup.ogg' + +/obj/structure/maintenance_loot_structure/wall_jacket + name = "hanging jacket" + desc = "Someone's old, now abandoned jacket. Maybe there's still stuff in the pockets?" + icon_state = "jacket_green" + density = FALSE + storage_datum_to_use = /datum/storage/maintenance_loot_structure/jacket + loot_spawn_dice_string = "1d3-1" + loot_weighted_list = list( + /obj/effect/spawner/random/epic_loot/pocket_sized_items = 1, + ) + +MAPPING_DIRECTIONAL_HELPERS(/obj/structure/maintenance_loot_structure/wall_jacket, 28) + +/obj/structure/maintenance_loot_structure/wall_jacket/Initialize(mapload) + . = ..() + find_and_hang_on_wall() + +/obj/structure/maintenance_loot_structure/wall_jacket/yellow + icon_state = "jacket_yellow" + +MAPPING_DIRECTIONAL_HELPERS(/obj/structure/maintenance_loot_structure/wall_jacket/yellow, 28) + +/obj/structure/maintenance_loot_structure/wall_jacket/blue + icon_state = "jacket_blue" + +MAPPING_DIRECTIONAL_HELPERS(/obj/structure/maintenance_loot_structure/wall_jacket/blue, 28) + +/obj/structure/maintenance_loot_structure/wall_jacket/police + icon_state = "jacket_police" + +MAPPING_DIRECTIONAL_HELPERS(/obj/structure/maintenance_loot_structure/wall_jacket/police, 28) + +/obj/structure/maintenance_loot_structure/wall_jacket/black + icon_state = "jacket_black" + +MAPPING_DIRECTIONAL_HELPERS(/obj/structure/maintenance_loot_structure/wall_jacket/black, 28) + +/obj/structure/maintenance_loot_structure/wall_jacket/military + icon_state = "jacket_military" + +MAPPING_DIRECTIONAL_HELPERS(/obj/structure/maintenance_loot_structure/wall_jacket/military, 28) + +/obj/structure/maintenance_loot_structure/wall_jacket/random + icon_state = "jacket_random" + /// The different icon states we can swap to when initializing + var/list/random_icon_states = list( + "jacket_green", + "jacket_yellow", + "jacket_blue", + "jacket_police", + "jacket_black", + "jacket_military", + ) + +MAPPING_DIRECTIONAL_HELPERS(/obj/structure/maintenance_loot_structure/wall_jacket/random, 28) + +/obj/structure/maintenance_loot_structure/wall_jacket/random/Initialize(mapload) + . = ..() + icon_state = pick(random_icon_states) + update_appearance() diff --git a/modular_doppler/epic_loot/code/random_spawners_real.dm b/modular_doppler/epic_loot/code/random_spawners_real.dm new file mode 100644 index 0000000000000..eab701f4a1391 --- /dev/null +++ b/modular_doppler/epic_loot/code/random_spawners_real.dm @@ -0,0 +1,690 @@ +/obj/effect/spawner/random/epic_loot + name = "extraction loot spawner" + desc = "Gods please let there be nobody extract camping." + icon = 'modular_doppler/epic_loot/icons/epic_loot.dmi' + icon_state = null + +// Jacket pocket contents + +// Actual pocket items spawner + +/obj/effect/spawner/random/epic_loot/pocket_sized_items + name = "random pocket sized items" + icon_state = "random_pocket_valuable" + loot = list( + /obj/effect/spawner/random/epic_loot/pocket_valuable = 1, + /obj/effect/spawner/random/epic_loot/pocket_medical = 1, + /obj/effect/spawner/random/epic_loot/pocket_da_money = 1, + ) + +// Chainlet, good or not good, call it + +/obj/effect/spawner/random/epic_loot/pocket_valuable + name = "random pocket valuable" + icon_state = "random_chain" + loot = list( + /obj/item/epic_loot/silver_chainlet = 3, + /obj/item/epic_loot/press_pass = 2, + /obj/item/epic_loot/military_flash = 2, + /obj/item/epic_loot/slim_diary = 2, + /obj/item/epic_loot/gold_chainlet = 1, + ) + +// Pocket meds + +/obj/effect/spawner/random/epic_loot/pocket_medical + name = "random pocket medical item" + icon_state = "random_med_stack" + loot = list( + /obj/item/storage/pill_bottle/iron = 2, + /obj/item/storage/pill_bottle/painkiller = 2, + /obj/item/storage/pill_bottle/ondansetron = 1, + /obj/item/stack/medical/bandage = 2, + /obj/item/stack/medical/bandage/makeshift = 2, + /obj/item/stack/medical/aloe = 2, + /obj/item/stack/medical/ointment/red_sun = 1, + /obj/item/stack/medical/bruise_pack = 1, + /obj/item/stack/medical/gauze/sterilized = 1, + ) + +// Pocket da money + +/obj/effect/spawner/random/epic_loot/pocket_da_money + name = "random pocket money" + icon_state = "random_pocket_valuable" + loot = list( + /obj/effect/spawner/random/entertainment/money_small = 2, + /obj/effect/spawner/random/entertainment/money = 1, + /obj/effect/spawner/random/entertainment/cigarette_pack = 1, + /obj/effect/spawner/random/entertainment/cigarette = 2, + /obj/effect/spawner/random/entertainment/wallet_lighter = 2, + ) + +// Medical related spawners + +// The medical everything spawner + +/obj/effect/spawner/random/epic_loot/medical_everything + name = "random medical anything" + icon_state = "random_med_stack" + loot = list( + /obj/effect/spawner/random/epic_loot/medical_stack_item = 2, + /obj/effect/spawner/random/epic_loot/medical_stack_item_advanced = 1, + /obj/effect/spawner/random/epic_loot/chemical = 1, + /obj/effect/spawner/random/epic_loot/medical_tools = 2, + /obj/effect/spawner/random/epic_loot/medkit = 1, + /obj/effect/spawner/random/epic_loot/medpens = 2, + /obj/effect/spawner/random/epic_loot/medpens_combat_based_redpilled = 1, + ) + +// Basic healing items + +/obj/effect/spawner/random/epic_loot/medical_stack_item + name = "random medical item" + icon_state = "random_med_stack" + loot = list( + /obj/item/stack/medical/bruise_pack = 3, + /obj/item/stack/medical/gauze = 3, + /obj/item/stack/medical/gauze/sterilized = 2, + /obj/item/stack/medical/suture/emergency = 3, + /obj/item/stack/medical/suture/coagulant = 2, + /obj/item/stack/medical/suture/bloody = 1, + /obj/item/stack/medical/ointment = 3, + /obj/item/stack/medical/ointment/red_sun = 2, + /obj/item/stack/medical/mesh = 2, + /obj/item/stack/medical/aloe = 2, + /obj/item/stack/medical/bone_gel/one = 2, + /obj/item/stack/medical/bone_gel = 1, + /obj/item/stack/medical/bandage/makeshift = 3, + /obj/item/stack/medical/bandage = 2, + /obj/item/stack/sticky_tape/surgical = 2, + /obj/item/reagent_containers/blood/random = 1, + /obj/item/stack/medical/wound_recovery/robofoam = 2, + // Pill bottles + /obj/item/storage/pill_bottle/iron = 2, + /obj/item/storage/pill_bottle/potassiodide = 2, + /obj/item/storage/pill_bottle/painkiller = 2, + /obj/item/storage/pill_bottle/probital = 2, + /obj/item/storage/pill_bottle/happinesspsych = 1, + /obj/item/storage/pill_bottle/lsdpsych = 1, + /obj/item/storage/pill_bottle/mannitol = 2, + /obj/item/storage/pill_bottle/multiver = 2, + /obj/item/storage/pill_bottle/mutadone = 1, + /obj/item/storage/pill_bottle/neurine = 1, + /obj/item/storage/pill_bottle/ondansetron = 1, + /obj/item/storage/pill_bottle/psicodine = 1, + /obj/item/storage/pill_bottle/sansufentanyl = 1, + ) + +// More advanced healing items + +/obj/effect/spawner/random/epic_loot/medical_stack_item_advanced + name = "random advanced medical item" + icon_state = "random_med_stack_adv" + loot = list( + /obj/item/stack/medical/gauze/sterilized = 2, + /obj/item/stack/medical/suture = 3, + /obj/item/stack/medical/suture/coagulant = 3, + /obj/item/stack/medical/suture/bloody = 2, + /obj/item/stack/medical/suture/medicated = 1, + /obj/item/stack/medical/ointment/red_sun = 3, + /obj/item/stack/medical/mesh = 3, + /obj/item/stack/medical/mesh/bloody = 2, + /obj/item/stack/medical/mesh/advanced = 1, + /obj/item/stack/medical/aloe = 2, + /obj/item/stack/medical/bone_gel = 2, + /obj/item/stack/medical/bandage = 2, + /obj/item/stack/sticky_tape/surgical = 2, + /obj/item/stack/medical/poultice = 1, + /obj/item/stack/medical/wound_recovery = 1, + /obj/item/stack/medical/wound_recovery/rapid_coagulant = 1, + /obj/item/reagent_containers/blood/random = 2, + /obj/item/stack/medical/wound_recovery/robofoam = 3, + /obj/item/stack/medical/wound_recovery/robofoam_super = 2, + // Medigels + /obj/item/reagent_containers/medigel/libital = 2, + /obj/item/reagent_containers/medigel/aiuri = 2, + /obj/item/reagent_containers/medigel/sterilizine = 2, + /obj/item/reagent_containers/medigel/synthflesh = 1, + // Pill bottles + /obj/item/storage/pill_bottle/iron = 2, + /obj/item/storage/pill_bottle/potassiodide = 2, + /obj/item/storage/pill_bottle/painkiller = 2, + /obj/item/storage/pill_bottle/probital = 2, + /obj/item/storage/pill_bottle/happinesspsych = 1, + /obj/item/storage/pill_bottle/lsdpsych = 1, + /obj/item/storage/pill_bottle/mannitol = 2, + /obj/item/storage/pill_bottle/multiver = 2, + /obj/item/storage/pill_bottle/mutadone = 1, + /obj/item/storage/pill_bottle/neurine = 1, + /obj/item/storage/pill_bottle/ondansetron = 1, + /obj/item/storage/pill_bottle/psicodine = 1, + /obj/item/storage/pill_bottle/sansufentanyl = 1, + ) + +// Chems and whatnot + +/obj/effect/spawner/random/epic_loot/chemical + name = "random chemical" + icon_state = "random_med_stack_adv" + loot = list( + // Chemjaks + /obj/item/reagent_containers/cup/bottle/epinephrine = 1, + /obj/item/reagent_containers/cup/bottle/morphine = 2, + /obj/item/reagent_containers/cup/bottle/mannitol = 1, + /obj/item/reagent_containers/cup/bottle/multiver = 2, + /obj/item/reagent_containers/cup/bottle/ammoniated_mercury = 2, + /obj/item/reagent_containers/cup/bottle/syriniver = 2, + /obj/item/reagent_containers/cup/bottle/synaptizine = 2, + /obj/item/reagent_containers/cup/bottle/fentanyl = 2, + /obj/item/reagent_containers/cup/bottle/formaldehyde = 1, + /obj/item/reagent_containers/cup/bottle/diphenhydramine = 1, + /obj/item/reagent_containers/cup/bottle/potass_iodide = 2, + /obj/item/reagent_containers/cup/bottle/salglu_solution = 3, + /obj/item/reagent_containers/cup/bottle/atropine = 2, + /obj/item/reagent_containers/cup/bottle/capsaicin = 2, + /obj/item/reagent_containers/cup/bottle/fentanyl = 1, + /obj/item/reagent_containers/cup/bottle/leadacetate = 1, + /obj/item/reagent_containers/cup/bottle/thermite = 1, + /obj/item/reagent_containers/cup/bottle/ethanol = 2, + /obj/item/reagent_containers/syringe = 2, + // Medigels + /obj/item/reagent_containers/medigel/libital = 2, + /obj/item/reagent_containers/medigel/aiuri = 2, + /obj/item/reagent_containers/medigel/sterilizine = 2, + /obj/item/reagent_containers/medigel/synthflesh = 1, + ) + +// Medical tools spawner + +/obj/effect/spawner/random/epic_loot/medical_tools + name = "random medical tools" + icon_state = "random_med_tools" + loot = list( + /obj/item/bonesetter = 2, + /obj/item/cautery = 2, + /obj/item/cautery/cruel = 1, + /obj/item/clothing/neck/stethoscope = 2, + /obj/item/flashlight/pen = 2, + /obj/item/flashlight/pen/paramedic = 2, + /obj/item/healthanalyzer = 1, + /obj/item/healthanalyzer/simple = 2, + /obj/item/healthanalyzer/simple/disease = 2, + /obj/item/hemostat = 2, + /obj/item/storage/box/bandages = 1, + /obj/item/bodybag = 2, + /obj/item/blood_filter = 2, + /obj/item/circular_saw = 2, + /obj/item/clothing/gloves/latex/nitrile = 2, + /obj/item/clothing/mask/surgical = 2, + /obj/item/retractor = 2, + /obj/item/scalpel = 2, + /obj/item/shears = 1, + /obj/item/surgical_drapes = 2, + /obj/item/surgicaldrill = 2, + /obj/item/epic_loot/vein_finder = 1, + /obj/item/epic_loot/eye_scope = 1, + /obj/item/reagent_containers/dropper = 2, + /obj/item/reagent_containers/cup/beaker = 2, + /obj/item/reagent_containers/cup/beaker/large = 1, + /obj/item/reagent_containers/cup/bottle = 2, + /obj/item/reagent_containers/cup/tube = 2, + /obj/item/reagent_containers/syringe = 2, + /obj/item/defibrillator = 1, + /obj/item/defibrillator/loaded = 1, + /obj/item/emergency_bed = 2, + /obj/item/storage/epic_loot_medical_case = 1, + ) + +// Random medkits + +/obj/effect/spawner/random/epic_loot/medkit + name = "random medkit" + icon_state = "random_medkit" + loot = list( + /obj/item/storage/medkit/civil_defense/stocked = 2, + /obj/item/storage/medkit/civil_defense/comfort/stocked = 2, + /obj/item/storage/medkit/frontier/stocked = 2, + /obj/item/storage/medkit/combat_surgeon/stocked = 2, + /obj/item/storage/medkit/robotic_repair/stocked = 2, + /obj/item/storage/medkit/robotic_repair/preemo/stocked = 1, + /obj/item/storage/backpack/duffelbag/deforest_medkit/stocked = 1, + /obj/item/storage/backpack/duffelbag/deforest_surgical/stocked = 1, + /obj/item/storage/epic_loot_medpen_case = 2, + ) + +// Random medpens for healing yourself + +/obj/effect/spawner/random/epic_loot/medpens + name = "random autoinjectors" + icon_state = "random_medpen_spawner" + loot = list( + /obj/item/reagent_containers/hypospray/medipen/deforest/occuisate = 2, + /obj/item/reagent_containers/hypospray/medipen/deforest/adrenaline = 2, + /obj/item/reagent_containers/hypospray/medipen/deforest/morpital = 3, + /obj/item/reagent_containers/hypospray/medipen/deforest/lipital = 3, + /obj/item/reagent_containers/hypospray/medipen/deforest/meridine = 3, + /obj/item/reagent_containers/hypospray/medipen/deforest/synephrine = 2, + /obj/item/reagent_containers/hypospray/medipen/deforest/calopine = 3, + /obj/item/reagent_containers/hypospray/medipen/deforest/coagulants = 2, + /obj/item/reagent_containers/hypospray/medipen/deforest/krotozine = 1, + /obj/item/reagent_containers/hypospray/medipen/deforest/lepoturi = 2, + /obj/item/reagent_containers/hypospray/medipen/deforest/psifinil = 2, + /obj/item/reagent_containers/hypospray/medipen/deforest/halobinin = 2, + ) + +// Random medpens for fighting other people + +/obj/effect/spawner/random/epic_loot/medpens_combat_based_redpilled + name = "random combat autoinjectors" + icon_state = "random_medpen_advanced" + loot = list( + /obj/item/reagent_containers/hypospray/medipen/deforest/adrenaline = 3, + /obj/item/reagent_containers/hypospray/medipen/deforest/morpital = 2, + /obj/item/reagent_containers/hypospray/medipen/deforest/lipital = 2, + /obj/item/reagent_containers/hypospray/medipen/deforest/synephrine = 3, + /obj/item/reagent_containers/hypospray/medipen/deforest/calopine = 2, + /obj/item/reagent_containers/hypospray/medipen/deforest/coagulants = 2, + /obj/item/reagent_containers/hypospray/medipen/deforest/krotozine = 3, + /obj/item/reagent_containers/hypospray/medipen/deforest/lepoturi = 2, + /obj/item/reagent_containers/hypospray/medipen/deforest/twitch = 1, + /obj/item/reagent_containers/hypospray/medipen/deforest/demoneye = 1, + /obj/item/reagent_containers/hypospray/medipen/deforest/aranepaine = 2, + /obj/item/reagent_containers/hypospray/medipen/deforest/pentibinin = 2, + /obj/item/reagent_containers/hypospray/medipen/deforest/synalvipitol = 2, + ) + +// Tool and supply spawners + +/obj/effect/spawner/random/epic_loot/random_engineering + name = "random engineering thing" + icon_state = "random_component" + loot = list( + /obj/effect/spawner/random/epic_loot/random_components = 1, + /obj/effect/spawner/random/epic_loot/random_computer_parts = 1, + /obj/effect/spawner/random/epic_loot/random_tools = 1, + /obj/effect/spawner/random/epic_loot/random_construction = 1, + ) + +// Sellable components + +/obj/effect/spawner/random/epic_loot/random_components + name = "random components" + icon_state = "random_component" + loot = list( + /obj/item/epic_loot/water_filter = 2, + /obj/item/epic_loot/thermometer = 2, + /obj/item/epic_loot/nail_box = 2, + /obj/item/epic_loot/cold_weld = 2, + /obj/item/epic_loot/electric_motor = 1, + /obj/item/epic_loot/current_converter = 1, + /obj/item/epic_loot/signal_amp = 1, + /obj/item/epic_loot/thermal_camera = 1, + /obj/item/epic_loot/shuttle_gyro = 1, + /obj/item/epic_loot/phased_array = 1, + /obj/item/epic_loot/shuttle_battery = 1, + /obj/item/epic_loot/fuel_conditioner = 2, + /obj/item/epic_loot/display = 1, + /obj/item/epic_loot/display_broken = 2, + /obj/item/epic_loot/civilian_circuit = 2, + ) + +// Random computer parts + +/obj/effect/spawner/random/epic_loot/random_computer_parts + name = "random computer parts" + icon_state = "random_electronic_part" + loot = list( + /obj/item/epic_loot/signal_amp = 2, + /obj/item/epic_loot/device_fan = 2, + /obj/item/epic_loot/graphics = 1, + /obj/item/epic_loot/military_circuit = 1, + /obj/item/epic_loot/civilian_circuit = 2, + /obj/item/epic_loot/processor = 2, + /obj/item/epic_loot/power_supply = 2, + /obj/item/epic_loot/disk_drive = 2, + /obj/item/epic_loot/ssd = 1, + /obj/item/epic_loot/hdd = 1, + /obj/item/epic_loot/military_flash = 1, + ) + +// Random tools + +/obj/effect/spawner/random/epic_loot/random_tools + name = "random tools and supplies" + icon_state = "random_tool" + loot = list( + // Wrench + /obj/item/wrench = 3, + /obj/item/wrench/bolter = 2, + /obj/item/wrench/caravan = 1, + /obj/item/wrench/combat = 1, + // Screwdriver + /obj/item/screwdriver = 3, + /obj/item/screwdriver/omni_drill = 2, + /obj/item/screwdriver/caravan = 1, + // Crowbar + /obj/item/crowbar = 3, + /obj/item/crowbar/large/doorforcer = 2, + /obj/item/crowbar/red/caravan = 1, + /obj/item/fireaxe/metal_h2_axe = 1, + // Wirecutters + /obj/item/wirecutters = 3, + /obj/item/wirecutters/caravan = 1, + // Welder + /obj/item/weldingtool = 3, + /obj/item/weldingtool/largetank = 3, + /obj/item/weldingtool/arc_welder = 2, + /obj/item/weldingtool/experimental = 1, + // Multitool + /obj/item/multitool = 2, + /obj/item/multitool/ai_detect = 1, + // Rapid whatever tools + /obj/item/pipe_dispenser = 1, + /obj/item/construction/rcd = 1, + /obj/item/construction/rtd = 1, + // Misc tools and related items + /obj/item/stack/cable_coil = 3, + /obj/item/flashlight = 2, + /obj/item/flashlight/flare = 3, + /obj/item/grenade/chem_grenade/metalfoam = 2, + /obj/item/geiger_counter = 2, + /obj/item/analyzer = 2, + // Various methods of insulation + /obj/item/clothing/gloves/color/yellow = 2, + /obj/item/clothing/gloves/chief_engineer = 1, + /obj/item/clothing/gloves/atmos = 1, + // Misc utility clothing + /obj/item/clothing/gloves/tinkerer = 1, + /obj/item/clothing/head/utility/welding = 2, + /obj/item/clothing/head/utility/hardhat/welding = 1, + /obj/item/clothing/glasses/meson = 3, + /obj/item/clothing/glasses/meson/engine = 2, + /obj/item/storage/belt/utility = 2, + /obj/item/clothing/shoes/magboots = 2, + // Tapes + /obj/item/stack/sticky_tape = 2, + /obj/item/stack/sticky_tape/super = 1, + // Cells + /obj/item/stock_parts/power_store/cell/upgraded = 1, + /obj/item/stock_parts/power_store/cell/crap = 2, + /obj/item/stock_parts/power_store/battery/upgraded = 1, + /obj/item/stock_parts/power_store/battery/crap = 2, + // Masks + /obj/item/clothing/mask/gas = 3, + /obj/item/clothing/mask/gas/welding = 2, + /obj/item/clothing/mask/gas/atmos/frontier_colonist = 2, + // Air tanks + /obj/item/tank/internals/nitrogen/belt = 1, + /obj/item/tank/internals/emergency_oxygen/engi = 2, + /obj/item/tank/internals/emergency_oxygen/double = 1, + // stuff + /obj/item/storage/epic_loot_cooler = 1, + /obj/item/storage/epic_loot_money_case = 1, + // Robofoam is a tool, right? + /obj/item/stack/medical/wound_recovery/robofoam = 2, + /obj/item/stack/medical/wound_recovery/robofoam_super = 1, + ) + +// Random construction stuff + +/obj/effect/spawner/random/epic_loot/random_construction + name = "random constructions" + icon_state = "random_tool" + loot = list( + // Sheets + /obj/item/stack/sheet/iron/twenty = 2, + /obj/item/stack/sheet/iron/ten = 3, + /obj/item/stack/sheet/glass/fifty = 1, + /obj/item/stack/sheet/plastic/five = 3, + /obj/item/stack/sheet/plastic_wall_panel/ten = 2, + /obj/item/stack/rods/twentyfive = 2, + /obj/item/stack/sheet/tinumium/three = 2, + /obj/item/stack/sheet/mineral/silver = 2, + /obj/item/stack/sheet/mineral/gold = 2, + /obj/item/stack/sheet/mineral/plasma/five = 2, + // Flatpack machines + /obj/item/flatpacked_machine = 1, + /obj/item/flatpacked_machine/airlock_kit = 2, + /obj/item/flatpacked_machine/airlock_kit_manual = 2, + /obj/item/flatpacked_machine/arc_furnace = 1, + /obj/item/flatpacked_machine/co2_cracker = 2, + /obj/item/flatpacked_machine/frontier_griddle = 1, + /obj/item/flatpacked_machine/frontier_range = 1, + /obj/item/flatpacked_machine/fuel_generator = 1, + /obj/item/flatpacked_machine/gps_beacon = 2, + /obj/item/flatpacked_machine/hydro_synth = 1, + /obj/item/flatpacked_machine/large_station_battery = 1, + /obj/item/flatpacked_machine/macrowave = 1, + /obj/item/flatpacked_machine/ore_silo = 1, + /obj/item/flatpacked_machine/ore_thumper = 1, + /obj/item/flatpacked_machine/organics_printer = 2, + /obj/item/flatpacked_machine/organics_ration_printer = 2, + /obj/item/flatpacked_machine/recycler = 2, + /obj/item/flatpacked_machine/rtg = 2, + /obj/item/flatpacked_machine/shutter_kit = 1, + /obj/item/flatpacked_machine/solar = 2, + /obj/item/flatpacked_machine/solar_tracker = 1, + /obj/item/flatpacked_machine/station_battery = 1, + /obj/item/flatpacked_machine/stirling_generator = 1, + /obj/item/flatpacked_machine/sustenance_machine = 2, + /obj/item/flatpacked_machine/thermomachine = 1, + /obj/item/flatpacked_machine/water_synth = 2, + /obj/item/flatpacked_machine/wind_turbine = 2, + /obj/item/folded_navigation_gigabeacon = 1, + /obj/item/wallframe/cell_charger_multi = 2, + /obj/item/wallframe/frontier_medstation = 1, + /obj/item/wallframe/wall_heater = 2, + /obj/item/wallframe/digital_clock = 1, + // Other things + /obj/item/door_seal = 2, + ) + +// Things from a safe + +// Documents and whatnot + +/obj/effect/spawner/random/epic_loot/random_documents + name = "random documents" + icon_state = "random_documents" + loot = list( + /obj/item/folder/white = 2, + /obj/item/folder/red = 2, + /obj/item/folder/blue = 2, + /obj/item/folder/ancient_paperwork = 2, + /obj/item/epic_loot/intel_folder = 2, + /obj/item/epic_loot/corpo_folder = 2, + /obj/item/epic_loot/slim_diary = 2, + /obj/item/epic_loot/diary = 2, + /obj/item/computer_disk/maintenance = 2, + /obj/item/computer_disk/black_market = 1, + /obj/item/computer_disk/virus = 1, + /obj/item/clipboard = 2, + /obj/item/pen/fountain/captain = 1, + /obj/item/pen/fountain = 2, + /obj/item/pen/screwdriver = 1, + /obj/item/pen/red = 2, + /obj/item/pen/blue = 2, + /obj/item/pen/fourcolor = 2, + /obj/item/pen/survival = 1, + /obj/item/storage/epic_loot_docs_case = 1, + /obj/item/book/granter/crafting_recipe/dusting/smoothbore_disabler_prime = 1, + /obj/item/book/granter/crafting_recipe/dusting/laser_musket_prime = 1, + /obj/item/book/granter/crafting_recipe/dusting/pipegun_prime = 1, + /obj/item/book/granter/crafting_recipe/death_sandwich = 1, + /obj/item/book/granter/crafting_recipe/trash_cannon = 1, + /obj/item/book/granter/crafting_recipe/donk_secret_recipe = 1, + ) + +// Stuff that comes in strongboxes specifically + +/obj/effect/spawner/random/epic_loot/random_strongbox_loot + name = "random strongbox loot" + icon_state = "random_strongbox_loot" + loot = list( + /obj/item/epic_loot/ssd = 1, + /obj/item/epic_loot/hdd = 1, + /obj/effect/spawner/random/epic_loot/pocket_valuable = 2, + /obj/effect/spawner/random/epic_loot/random_documents = 2, + ) + +// Unsorted yeah + +// "Military" loot + +/obj/effect/spawner/random/epic_loot/random_other_military_loot + name = "random military loot" + desc = "Automagically transforms into some kind of misc. military loot item." + icon_state = "random_loot_military" + loot = list( + /obj/item/clothing/mask/gas/sechailer = 3, + /obj/item/clothing/mask/gas = 2, + /obj/item/clothing/mask/gas/atmos/frontier_colonist = 2, + /obj/item/folder/ancient_paperwork = 2, + /obj/item/epic_loot/intel_folder = 3, + /obj/item/epic_loot/slim_diary = 3, + /obj/item/epic_loot/ssd = 2, + /obj/item/epic_loot/hdd = 2, + /obj/item/epic_loot/military_flash = 2, + /obj/item/computer_disk/maintenance = 2, + /obj/item/computer_disk/black_market = 1, + /obj/item/epic_loot/plasma_explosive = 1, + /obj/item/epic_loot/grenade_fuze = 3, + /obj/item/epic_loot/signal_amp = 3, + /obj/item/epic_loot/thermal_camera = 2, + /obj/item/epic_loot/shuttle_gyro = 2, + /obj/item/epic_loot/phased_array = 2, + /obj/item/epic_loot/shuttle_battery = 2, + /obj/item/epic_loot/military_circuit = 3, + /obj/item/storage/epic_loot_medpen_case = 2, + /obj/item/storage/epic_loot_docs_case = 2, + /obj/item/storage/epic_loot_org_pouch = 2, + ) + +// Random food for transport +/obj/effect/spawner/random/epic_loot/random_provisions + name = "random provisions" + icon_state = "random_food" + loot = list( + /obj/item/food/sustenance_bar = 3, + /obj/item/food/sustenance_bar/cheese = 2, + /obj/item/food/sustenance_bar/mint = 2, + /obj/item/food/sustenance_bar/neapolitan = 2, + /obj/item/food/vendor_snacks/mothmallow = 1, + /obj/item/food/vendor_snacks/moth_bag = 3, + /obj/item/food/vendor_snacks/moth_bag/cheesecake = 2, + /obj/item/food/vendor_snacks/moth_bag/cheesecake/honey = 2, + /obj/item/food/vendor_snacks/moth_bag/fuel_jack = 3, + /obj/item/food/vendor_tray_meal/side/cornbread = 2, + /obj/item/food/vendor_tray_meal/side/moffin = 2, + /obj/item/food/vendor_tray_meal/side/roasted_seeds = 2, + /obj/item/food/brain_pate = 2, + /obj/item/food/branrequests = 3, + /obj/item/food/breadslice/corn = 2, + /obj/item/food/breadslice/reispan = 2, + /obj/item/food/breadslice/plain = 2, + /obj/item/food/breadslice/root = 2, + /obj/item/food/butter = 3, + /obj/item/food/candy = 3, + /obj/item/food/canned/beans = 3, + /obj/item/food/canned/peaches = 3, + /obj/item/food/canned/tomatoes = 3, + /obj/item/food/canned/chap = 3, + /obj/item/food/canned/desert_snails = 2, + /obj/item/food/canned/envirochow = 1, + /obj/item/food/canned/jellyfish = 2, + /obj/item/food/canned/larvae = 2, + /obj/item/food/canned/pine_nuts = 2, + /obj/item/food/canned/squid_ink = 1, + /obj/item/food/cheese/firm_cheese_slice = 2, + /obj/item/food/cheese/firm_cheese = 1, + /obj/item/food/chocolatebar = 2, + /obj/item/food/cnds/random = 3, + /obj/item/food/colonial_course/pljeskavica = 1, + /obj/item/food/colonial_course/nachos = 1, + /obj/item/food/colonial_course/blins = 1, + /obj/item/food/cornchips/random = 2, + /obj/item/food/peanuts/random = 2, + /obj/item/food/ready_donk = 1, + /obj/item/food/ready_donk/donkhiladas = 1, + /obj/item/food/ready_donk/donkrange_chicken = 1, + /obj/item/food/ready_donk/mac_n_cheese = 1, + /obj/item/food/ready_donk/nachos_grandes = 1, + /obj/item/food/ready_donk/country_chicken = 1, + /obj/item/food/ready_donk/salisbury_steak = 1, + /obj/item/food/semki = 3, + /obj/item/food/spacers_sidekick = 2, + /obj/item/food/sticko/random = 3, + // Ingredients + /obj/item/reagent_containers/cup/glass/bottle/juice/limejuice = 2, + /obj/item/reagent_containers/cup/glass/bottle/juice/orangejuice = 2, + /obj/item/reagent_containers/cup/glass/bottle/juice/pineapplejuice = 2, + /obj/item/reagent_containers/condiment/milk = 1, + /obj/item/reagent_containers/condiment/sugar/small_ration = 2, + /obj/item/reagent_containers/condiment/flour/small_ration = 2, + /obj/item/reagent_containers/condiment/small_ration_korta_flour = 2, + /obj/item/reagent_containers/condiment/cherryjelly = 1, + /obj/item/reagent_containers/condiment/rice/small_ration = 2, + /obj/item/reagent_containers/condiment/soymilk/small_ration = 2, + /obj/item/reagent_containers/condiment/cornmeal = 1, + /obj/item/reagent_containers/condiment/grounding_solution = 1, + /obj/item/reagent_containers/condiment/bbqsauce = 2, + /obj/item/reagent_containers/condiment/chocolate = 1, + /obj/item/reagent_containers/condiment/coconut_milk = 2, + /obj/item/reagent_containers/condiment/curry_powder = 2, + /obj/item/reagent_containers/condiment/dashi_concentrate = 1, + /obj/item/reagent_containers/condiment/donksauce = 1, + /obj/item/reagent_containers/condiment/vegetable_oil = 2, + /obj/item/reagent_containers/condiment/worcestershire = 1, + /obj/item/reagent_containers/condiment/enzyme = 1, + /obj/item/reagent_containers/condiment/honey = 1, + /obj/item/reagent_containers/condiment/hotsauce = 1, + /obj/item/reagent_containers/condiment/ketchup = 1, + /obj/item/reagent_containers/condiment/mayonnaise = 1, + /obj/item/reagent_containers/condiment/peanut_butter = 1, + /obj/item/reagent_containers/condiment/protein = 1, + /obj/item/reagent_containers/condiment/red_bay = 2, + /obj/item/reagent_containers/condiment/vinegar = 1, + /obj/item/reagent_containers/condiment/coldsauce = 1, + /obj/item/storage/box/spaceman_ration/meats = 1, + /obj/item/storage/box/spaceman_ration/meats/lizard = 1, + /obj/item/storage/box/spaceman_ration/meats/fish = 1, + /obj/item/storage/box/spaceman_ration/plants = 2, + /obj/item/storage/box/spaceman_ration/plants/alternate = 2, + /obj/item/storage/box/spaceman_ration/plants/lizard = 2, + /obj/item/storage/box/spaceman_ration/plants/mothic = 2, + /obj/item/storage/box/papersack/ration_bread_slice = 1, + /obj/item/storage/box/colonial_rations = 1, + // Da cooler + /obj/item/storage/epic_loot_cooler = 2, + ) + +// Da money + +/obj/effect/spawner/random/entertainment/money/one + spawn_loot_count = 1 + +/obj/effect/spawner/random/entertainment/money_small/one + spawn_loot_count = 1 + +// Maint structure spawner + +/obj/effect/spawner/random/epic_loot/random_maint_loot_structure + name = "random maintenance loot structure" + desc = "Automagically transforms into a random loot structure that spawns in maint." + icon = 'modular_doppler/epic_loot/icons/loot_structures.dmi' + icon_state = "random_maint_structure" + loot = list( + /obj/structure/maintenance_loot_structure/ammo_box/random, + /obj/structure/maintenance_loot_structure/computer_tower/random, + /obj/structure/maintenance_loot_structure/file_cabinet/random, + /obj/structure/maintenance_loot_structure/grenade_box/random, + /obj/structure/maintenance_loot_structure/gun_box/random, + /obj/effect/spawner/random/epic_loot/random_supply_crate, + /obj/structure/maintenance_loot_structure/medbox/random, + /obj/structure/maintenance_loot_structure/military_case/random, + /obj/structure/maintenance_loot_structure/register/random, + /obj/structure/maintenance_loot_structure/desk_safe/random, + /obj/structure/maintenance_loot_structure/toolbox/random, + /obj/structure/maintenance_loot_structure/wall_jacket/random, + ) diff --git a/modular_doppler/epic_loot/code/storage_containers/containers.dm b/modular_doppler/epic_loot/code/storage_containers/containers.dm new file mode 100644 index 0000000000000..682315b83a58b --- /dev/null +++ b/modular_doppler/epic_loot/code/storage_containers/containers.dm @@ -0,0 +1,232 @@ +/obj/item/storage/epic_loot_medpen_case + name = "autoinjector case" + desc = "A semi-rigid case for holding a large number of autoinjectors inside of." + icon = 'modular_doppler/epic_loot/icons/storage_items.dmi' + icon_state = "pencase" + equip_sound = 'sound/items/equip/toolbelt_equip.ogg' + pickup_sound = 'sound/items/handling/cloth_pickup.ogg' + drop_sound = 'sound/items/handling/cloth_drop.ogg' + storage_type = /datum/storage/maintenance_loot_structure/epic_loot_medpen_case + slot_flags = ITEM_SLOT_POCKETS + w_class = WEIGHT_CLASS_BULKY + +/datum/storage/maintenance_loot_structure/epic_loot_medpen_case + max_slots = 6 + max_specific_storage = WEIGHT_CLASS_SMALL + max_total_storage = WEIGHT_CLASS_SMALL * 6 + numerical_stacking = TRUE + opening_sound = 'sound/items/zip/un_zip.ogg' + +/datum/storage/maintenance_loot_structure/epic_loot_medpen_case/New() + . = ..() + + can_hold = typecacheof(list( + /obj/item/dnainjector, + /obj/item/hypospray, + /obj/item/implant, + /obj/item/implantcase, + /obj/item/implanter, + /obj/item/lazarus_injector, + /obj/item/reagent_containers/hypospray, + /obj/item/reagent_containers/medigel, + /obj/item/reagent_containers/pill, + /obj/item/storage/pill_bottle, + )) + +/obj/item/storage/epic_loot_docs_case + name = "documents case" + desc = "A large pouch conveniently shaped to hold all of the valueable paperwork in the galaxy." + icon = 'modular_doppler/epic_loot/icons/storage_items.dmi' + icon_state = "documents" + equip_sound = 'sound/items/equip/toolbelt_equip.ogg' + pickup_sound = 'sound/items/handling/cloth_pickup.ogg' + drop_sound = 'sound/items/handling/cloth_drop.ogg' + storage_type = /datum/storage/maintenance_loot_structure/epic_loot_docs_case + slot_flags = ITEM_SLOT_POCKETS + w_class = WEIGHT_CLASS_BULKY + +/datum/storage/maintenance_loot_structure/epic_loot_docs_case + max_slots = 4 + max_specific_storage = WEIGHT_CLASS_BULKY + max_total_storage = WEIGHT_CLASS_BULKY * 4 + screen_max_columns = 2 + numerical_stacking = TRUE + opening_sound = 'sound/items/handling/cloth_pickup.ogg' + +/datum/storage/maintenance_loot_structure/epic_loot_docs_case/New() + . = ..() + + can_hold = typecacheof(list( + /obj/item/folder, + /obj/item/epic_loot/intel_folder, + /obj/item/epic_loot/corpo_folder, + /obj/item/epic_loot/slim_diary, + /obj/item/epic_loot/diary, + /obj/item/computer_disk, + /obj/item/paper, + /obj/item/photo, + /obj/item/documents, + /obj/item/paperwork, + /obj/item/clipboard, + )) + +/obj/item/storage/epic_loot_org_pouch + name = "organizational pouch" + desc = "A pouch with every possible type of pocket and organizer stuck into it, to hold all of the small stuff you could think of." + icon = 'modular_doppler/epic_loot/icons/storage_items.dmi' + icon_state = "sick" + equip_sound = 'sound/items/equip/toolbelt_equip.ogg' + pickup_sound = 'sound/items/handling/cloth_pickup.ogg' + drop_sound = 'sound/items/handling/cloth_drop.ogg' + storage_type = /datum/storage/maintenance_loot_structure/epic_loot_org_pouch + slot_flags = ITEM_SLOT_POCKETS + w_class = WEIGHT_CLASS_BULKY + +/datum/storage/maintenance_loot_structure/epic_loot_org_pouch + max_slots = 4 + max_specific_storage = WEIGHT_CLASS_SMALL + max_total_storage = WEIGHT_CLASS_SMALL * 4 + screen_max_columns = 2 + numerical_stacking = TRUE + opening_sound = 'sound/items/zip/un_zip.ogg' + +/obj/item/storage/epic_loot_cooler + name = "compact cooler" + desc = "A wonder in food storage technology, it's a blue bag that you can put food in." + icon = 'modular_doppler/epic_loot/icons/storage_items.dmi' + icon_state = "cooler" + lefthand_file = 'icons/mob/inhands/equipment/toolbox_lefthand.dmi' + righthand_file = 'icons/mob/inhands/equipment/toolbox_righthand.dmi' + inhand_icon_state = "toolbox_blue" + drop_sound = 'sound/items/handling/ammobox_drop.ogg' + pickup_sound = 'sound/items/handling/ammobox_pickup.ogg' + storage_type = /datum/storage/maintenance_loot_structure/epic_loot_cooler + w_class = WEIGHT_CLASS_BULKY + +/datum/storage/maintenance_loot_structure/epic_loot_cooler + max_slots = 12 + max_specific_storage = WEIGHT_CLASS_BULKY + max_total_storage = WEIGHT_CLASS_BULKY * 12 + screen_max_columns = 4 + numerical_stacking = FALSE + opening_sound = 'sound/items/zip/un_zip.ogg' + +/datum/storage/maintenance_loot_structure/epic_loot_cooler/New() + . = ..() + + can_hold = typecacheof(list( + /obj/item/food, + /obj/item/reagent_containers/condiment, + /obj/item/reagent_containers/cup, + )) + +/obj/item/storage/epic_loot_money_case + name = "money case" + desc = "A heavy duty case for the transportation of (bribe) money." + icon = 'modular_doppler/epic_loot/icons/storage_items.dmi' + icon_state = "money_case" + lefthand_file = 'icons/mob/inhands/equipment/briefcase_lefthand.dmi' + righthand_file = 'icons/mob/inhands/equipment/briefcase_righthand.dmi' + inhand_icon_state = "lockbox" + drop_sound = 'sound/items/handling/ammobox_drop.ogg' + pickup_sound = 'sound/items/handling/ammobox_pickup.ogg' + storage_type = /datum/storage/maintenance_loot_structure/epic_loot_the_money + w_class = WEIGHT_CLASS_BULKY + +/datum/storage/maintenance_loot_structure/epic_loot_the_money + max_slots = 6 + max_specific_storage = WEIGHT_CLASS_NORMAL + max_total_storage = WEIGHT_CLASS_NORMAL * 6 + screen_max_columns = 2 + numerical_stacking = FALSE + opening_sound = 'modular_doppler/epic_loot/sound/wood_crate_1.mp3' + +/datum/storage/maintenance_loot_structure/epic_loot_the_money/New() + . = ..() + + can_hold = typecacheof(list( + /obj/item/stack/spacecash, + /obj/item/coin, + )) + +/obj/item/storage/epic_loot_medical_case + name = "medical case" + desc = "A heavy duty case for the transportation of medical supplies." + icon = 'modular_doppler/epic_loot/icons/storage_items.dmi' + icon_state = "medical" + lefthand_file = 'icons/mob/inhands/equipment/briefcase_lefthand.dmi' + righthand_file = 'icons/mob/inhands/equipment/briefcase_righthand.dmi' + inhand_icon_state = "bitrunning" + drop_sound = 'sound/items/handling/ammobox_drop.ogg' + pickup_sound = 'sound/items/handling/ammobox_pickup.ogg' + storage_type = /datum/storage/maintenance_loot_structure/epic_loot_medkit + w_class = WEIGHT_CLASS_BULKY + +/datum/storage/maintenance_loot_structure/epic_loot_medkit + max_slots = 21 + max_specific_storage = WEIGHT_CLASS_BULKY + max_total_storage = WEIGHT_CLASS_BULKY * 21 + screen_max_columns = 7 + numerical_stacking = FALSE + opening_sound = 'modular_doppler/epic_loot/sound/wood_crate_1.mp3' + +/datum/storage/maintenance_loot_structure/epic_loot_medkit/New() + . = ..() + + can_hold = typecacheof(list( + /obj/item/blood_filter, + /obj/item/bonesetter, + /obj/item/cautery, + /obj/item/circular_saw, + /obj/item/clothing/glasses, + /obj/item/clothing/gloves, + /obj/item/clothing/neck/stethoscope, + /obj/item/clothing/mask/breath, + /obj/item/clothing/mask/muzzle, + /obj/item/clothing/mask/surgical, + /obj/item/clothing/suit/toggle/labcoat/hospitalgown, + /obj/item/construction/plumbing, + /obj/item/dnainjector, + /obj/item/extinguisher/mini, + /obj/item/flashlight/pen, + /obj/item/geiger_counter, + /obj/item/gun/syringe/syndicate, + /obj/item/healthanalyzer, + /obj/item/hemostat, + /obj/item/holosign_creator/medical, + /obj/item/hypospray, + /obj/item/implant, + /obj/item/implantcase, + /obj/item/implanter, + /obj/item/lazarus_injector, + /obj/item/lighter, + /obj/item/pinpointer/crew, + /obj/item/plunger, + /obj/item/radio, + /obj/item/reagent_containers/blood, + /obj/item/reagent_containers/dropper, + /obj/item/reagent_containers/cup/beaker, + /obj/item/reagent_containers/cup/bottle, + /obj/item/reagent_containers/cup/tube, + /obj/item/reagent_containers/hypospray, + /obj/item/reagent_containers/medigel, + /obj/item/reagent_containers/pill, + /obj/item/reagent_containers/spray, + /obj/item/reagent_containers/syringe, + /obj/item/retractor, + /obj/item/scalpel, + /obj/item/shears, + /obj/item/stack/medical, + /obj/item/stack/sticky_tape, + /obj/item/stamp, + /obj/item/sensor_device, + /obj/item/storage/fancy/cigarettes, + /obj/item/storage/pill_bottle, + /obj/item/surgical_drapes, + /obj/item/surgicaldrill, + /obj/item/tank/internals/emergency_oxygen, + /obj/item/wrench/medical, + /obj/item/emergency_bed, + /obj/item/storage/box/bandages, + /obj/item/bodybag, + )) diff --git a/modular_doppler/epic_loot/code/where_they_spawn.dm b/modular_doppler/epic_loot/code/where_they_spawn.dm new file mode 100644 index 0000000000000..2d981ae7598d3 --- /dev/null +++ b/modular_doppler/epic_loot/code/where_they_spawn.dm @@ -0,0 +1,42 @@ +/obj/effect/spawner/random/trash/box + loot = list( + /obj/structure/closet/cardboard = 9, + /obj/structure/closet/cardboard/metal = 1, + /obj/effect/spawner/random/epic_loot/random_maint_loot_structure = 3, + ) + +/obj/effect/spawner/random/structure/crate + loot = list( + /obj/effect/spawner/random/epic_loot/random_maint_loot_structure = 1000, + /obj/effect/spawner/random/structure/crate_loot = 744, + /obj/structure/closet/crate/trashcart/filled = 75, + /obj/effect/spawner/random/trash/moisture_trap = 50, + /obj/effect/spawner/random/trash/hobo_squat = 30, + /obj/structure/closet/mini_fridge = 35, + /obj/effect/spawner/random/trash/mess = 30, + /obj/item/kirbyplants/fern = 20, + /obj/structure/closet/crate/decorations = 15, + /obj/effect/decal/remains/human/smokey/maintenance = 7, + /obj/structure/destructible/cult/pants_altar = 1, + ) + +/obj/effect/spawner/random/structure/crate_loot + loot = list( + /obj/effect/spawner/random/epic_loot/random_maint_loot_structure = 30, + /obj/effect/spawner/random/structure/closet_empty/crate/with_loot = 15, + /obj/effect/spawner/random/structure/closet_empty/crate = 4, + /obj/structure/closet/crate/secure/loot = 1, + ) + +/obj/effect/spawner/random/structure/closet_maintenance + loot = list( + /obj/effect/spawner/random/epic_loot/random_maint_loot_structure = 15, + /obj/effect/spawner/random/structure/closet_empty = 10, + /obj/structure/closet/emcloset = 2, + /obj/structure/closet/firecloset = 2, + /obj/structure/closet/toolcloset = 2, + /obj/structure/closet/l3closet = 1, + /obj/structure/closet/radiation = 1, + /obj/structure/closet/bombcloset = 1, + /obj/structure/closet/mini_fridge/grimy = 1, + ) diff --git a/modular_doppler/epic_loot/icons/epic_loot.dmi b/modular_doppler/epic_loot/icons/epic_loot.dmi new file mode 100644 index 0000000000000..e05a53aefdea6 Binary files /dev/null and b/modular_doppler/epic_loot/icons/epic_loot.dmi differ diff --git a/modular_doppler/epic_loot/icons/loot_structures.dmi b/modular_doppler/epic_loot/icons/loot_structures.dmi new file mode 100644 index 0000000000000..213c69849cfef Binary files /dev/null and b/modular_doppler/epic_loot/icons/loot_structures.dmi differ diff --git a/modular_doppler/epic_loot/icons/storage_items.dmi b/modular_doppler/epic_loot/icons/storage_items.dmi new file mode 100644 index 0000000000000..04e6db41d6708 Binary files /dev/null and b/modular_doppler/epic_loot/icons/storage_items.dmi differ diff --git a/modular_doppler/epic_loot/sound/attributions.txt b/modular_doppler/epic_loot/sound/attributions.txt new file mode 100644 index 0000000000000..6aee04bdec393 --- /dev/null +++ b/modular_doppler/epic_loot/sound/attributions.txt @@ -0,0 +1 @@ +The sounds in this folder are all from https://pixabay.com/users/38928062/ as of the time of writing this comment diff --git a/modular_doppler/epic_loot/sound/cabinet.mp3 b/modular_doppler/epic_loot/sound/cabinet.mp3 new file mode 100644 index 0000000000000..b2380969d783d Binary files /dev/null and b/modular_doppler/epic_loot/sound/cabinet.mp3 differ diff --git a/modular_doppler/epic_loot/sound/plastic.mp3 b/modular_doppler/epic_loot/sound/plastic.mp3 new file mode 100644 index 0000000000000..469ff97a2fdde Binary files /dev/null and b/modular_doppler/epic_loot/sound/plastic.mp3 differ diff --git a/modular_doppler/epic_loot/sound/wood_crate_1.mp3 b/modular_doppler/epic_loot/sound/wood_crate_1.mp3 new file mode 100644 index 0000000000000..3fdf354ae0b07 Binary files /dev/null and b/modular_doppler/epic_loot/sound/wood_crate_1.mp3 differ diff --git a/modular_doppler/epic_loot/sound/wood_crate_2.mp3 b/modular_doppler/epic_loot/sound/wood_crate_2.mp3 new file mode 100644 index 0000000000000..01fa391d6cccc Binary files /dev/null and b/modular_doppler/epic_loot/sound/wood_crate_2.mp3 differ diff --git a/modular_doppler/epic_loot/sound/wood_crate_3.mp3 b/modular_doppler/epic_loot/sound/wood_crate_3.mp3 new file mode 100644 index 0000000000000..aa3d9954f8266 Binary files /dev/null and b/modular_doppler/epic_loot/sound/wood_crate_3.mp3 differ diff --git a/modular_doppler/objects_and_structures/code/structure.dm b/modular_doppler/objects_and_structures/code/structure.dm deleted file mode 100644 index 8ebda2b81ed2f..0000000000000 --- a/modular_doppler/objects_and_structures/code/structure.dm +++ /dev/null @@ -1,16 +0,0 @@ -/obj/effect/spawner/random/structure/crate - name = "crate spawner" - icon_state = "crate_secure" - loot = list( - /obj/effect/spawner/random/structure/crate_loot = 495, - /obj/structure/trash_pile = 250, - /obj/structure/closet/crate/trashcart/filled = 75, - /obj/effect/spawner/random/trash/moisture_trap = 50, - /obj/effect/spawner/random/trash/hobo_squat = 30, - /obj/structure/closet/mini_fridge = 35, - /obj/effect/spawner/random/trash/mess = 30, - /obj/item/kirbyplants/fern = 20, - /obj/structure/closet/crate/decorations = 15, - /obj/effect/decal/remains/human/smokey/maintenance = 7, - /obj/structure/destructible/cult/pants_altar = 1, - ) diff --git a/modular_doppler/objects_and_structures/code/trash_pile.dm b/modular_doppler/objects_and_structures/code/trash_pile.dm deleted file mode 100644 index 8e38a9bc46796..0000000000000 --- a/modular_doppler/objects_and_structures/code/trash_pile.dm +++ /dev/null @@ -1,138 +0,0 @@ -/obj/structure/trash_pile - name = "trash pile" - desc = "A heap of garbage, but maybe there's something interesting inside?" - icon = 'modular_doppler/objects_and_structures/icons/trash_piles.dmi' - icon_state = "randompile" - density = TRUE - anchored = TRUE - layer = TABLE_LAYER - obj_flags = CAN_BE_HIT - pass_flags = LETPASSTHROW - - max_integrity = 50 - - var/hide_person_time = 30 - var/hide_item_time = 15 - - var/list/searchedby = list()// Characters that have searched this trashpile, with values of searched time. - -/obj/structure/trash_pile/Initialize(mapload) - . = ..() - icon_state = pick( - "pile1", - "pile2", - "pilechair", - "piletable", - "pilevending", - "brtrashpile", - "microwavepile", - "rackpile", - "boxfort", - "trashbag", - "brokecomp", - ) - -/obj/structure/trash_pile/proc/do_search(mob/user) - if(contents.len) // There's something hidden - var/atom/hidden_atom = contents[contents.len] // Get the most recent hidden thing - if(istype(hidden_atom, /mob/living)) - var/mob/living/hidden_mob = hidden_atom - balloon_alert(user, "someone is inside!") - eject_mob(hidden_mob) - else if (istype(hidden_atom, /obj/item)) - var/obj/item/hidden_item = hidden_atom - balloon_alert(user, "found something!") - hidden_item.forceMove(src.loc) - else - // You already searched this one bruh - if(user.ckey in searchedby) - balloon_alert(user, "already searched!") - // You found an item! - else - produce_alpha_item() - balloon_alert(user, "found something!") - searchedby += user.ckey - -/obj/structure/trash_pile/attack_hand(mob/user) - // Human mob - if(ishuman(user)) - var/mob/living/carbon/human/human_user = user - human_user.visible_message("[user] searches through \the [src].", span_notice("You search through \the [src].")) - // Do the searching - if(do_after(user, rand(4 SECONDS, 6 SECONDS), target = src)) - if(src.loc) // Let's check if the pile still exists - do_search(user) - else - return ..() - -// Random lists -/obj/structure/trash_pile/proc/produce_alpha_item() - var/lootspawn = pick_weight(GLOB.maintenance_loot) - while(islist(lootspawn)) - lootspawn = pick_weight(lootspawn) - var/obj/item/hidden_item = new lootspawn(get_turf(src)) - return hidden_item - -/obj/structure/trash_pile/mouse_drop_receive(atom/dropping, mob/user, params) - if(user == dropping && iscarbon(dropping)) - var/mob/living/dropped_mob = dropping - if(dropped_mob.mobility_flags & MOBILITY_MOVE) - dive_in_pile(user) - return - -/obj/structure/trash_pile/proc/eject_mob(mob/living/hidden_mob) - hidden_mob.forceMove(src.loc) - playsound(hidden_mob.loc, 'sound/machines/chime.ogg', 50, FALSE, -5) - hidden_mob.do_alert_animation(hidden_mob) - -/obj/structure/trash_pile/proc/do_dive(mob/user) - if(contents.len) - for(var/mob/hidden_mob in contents) - balloon_alert(user, "already someone inside!") - eject_mob(hidden_mob) - return FALSE - return TRUE - -/obj/structure/trash_pile/proc/dive_in_pile(mob/user) - user.visible_message(span_warning("[user] starts diving into [src]."), \ - span_notice("You start diving into [src]...")) - var/adjusted_dive_time = hide_person_time - if(HAS_TRAIT(user, TRAIT_RESTRAINED)) // hiding takes twice as long when restrained. - adjusted_dive_time *= 2 - - if(do_after(user, adjusted_dive_time, user)) - if(src.loc) // Checking if structure has been destroyed - if(do_dive(user)) - user.forceMove(src) - -/obj/structure/trash_pile/proc/can_hide_item(obj/item/hidden_item) - if(contents.len > 10) - return FALSE - return TRUE - -/obj/structure/trash_pile/attackby(obj/item/hidden_item, mob/living/user, params) - if(!user.combat_mode) - if(can_hide_item(hidden_item)) - balloon_alert(user, "hiding item...") - if(do_after(user, hide_item_time, user)) - if(src.loc) - if(user.transferItemToLoc(hidden_item, src)) - balloon_alert(user, "item hidden") - else - balloon_alert(user, "it's stuck to your hand!") - else - balloon_alert(user, "it's full!") - return - - . = ..() - -/obj/structure/trash_pile/Destroy() - for(var/atom/movable/pile_contents in src) - pile_contents.forceMove(src.loc) - return ..() - -/obj/structure/trash_pile/container_resist_act(mob/user) - user.forceMove(src.loc) - -/obj/structure/trash_pile/relaymove(mob/user) - container_resist_act(user) diff --git a/tgstation.dme b/tgstation.dme index e19b6041b1bcd..a6a8905e39b7c 100644 --- a/tgstation.dme +++ b/tgstation.dme @@ -6653,6 +6653,26 @@ #include "modular_doppler\emotes\code\overlay_emotes\overlay_emotes.dm" #include "modular_doppler\enterprise_resource_planning\code\breasts.dm" #include "modular_doppler\enterprise_resource_planning\code\erp_prefs.dm" +#include "modular_doppler\epic_loot\code\_basetype.dm" +#include "modular_doppler\epic_loot\code\random_spawners_real.dm" +#include "modular_doppler\epic_loot\code\where_they_spawn.dm" +#include "modular_doppler\epic_loot\code\loot_items\components.dm" +#include "modular_doppler\epic_loot\code\loot_items\electronics.dm" +#include "modular_doppler\epic_loot\code\loot_items\medical.dm" +#include "modular_doppler\epic_loot\code\loot_items\valuables.dm" +#include "modular_doppler\epic_loot\code\loot_structures\ammo_box.dm" +#include "modular_doppler\epic_loot\code\loot_structures\computer_tower.dm" +#include "modular_doppler\epic_loot\code\loot_structures\files.dm" +#include "modular_doppler\epic_loot\code\loot_structures\grenade_box.dm" +#include "modular_doppler\epic_loot\code\loot_structures\gun_case.dm" +#include "modular_doppler\epic_loot\code\loot_structures\large_crate.dm" +#include "modular_doppler\epic_loot\code\loot_structures\medbox.dm" +#include "modular_doppler\epic_loot\code\loot_structures\military_case.dm" +#include "modular_doppler\epic_loot\code\loot_structures\register.dm" +#include "modular_doppler\epic_loot\code\loot_structures\safe.dm" +#include "modular_doppler\epic_loot\code\loot_structures\toolbox.dm" +#include "modular_doppler\epic_loot\code\loot_structures\wall_jackets.dm" +#include "modular_doppler\epic_loot\code\storage_containers\containers.dm" #include "modular_doppler\examinemore\code\examine_more.dm" #include "modular_doppler\face_mouse_preferences\code\face_mouse_pref.dm" #include "modular_doppler\flavortext_and_records\code\defines.dm" @@ -7142,9 +7162,7 @@ #include "modular_doppler\objects_and_structures\code\icemoon_tiles.dm" #include "modular_doppler\objects_and_structures\code\mannequin.dm" #include "modular_doppler\objects_and_structures\code\sauna_oven.dm" -#include "modular_doppler\objects_and_structures\code\structure.dm" #include "modular_doppler\objects_and_structures\code\towel_bins.dm" -#include "modular_doppler\objects_and_structures\code\trash_pile.dm" #include "modular_doppler\objects_and_structures\code\watercloset.dm" #include "modular_doppler\pixel_shift\living.dm" #include "modular_doppler\pixel_shift\living_movement.dm"