mirror of
https://github.com/CHOMPStation2/CHOMPStation2.git
synced 2025-12-12 19:22:56 +00:00
* Added pickup verb to all items
* Added "Toggle Open" verb to all closets and crates * Added "Toggle Lock" verb to all lockable closets * Modified the cloning computer's UI slightly, makes more sense, added a little delay when scanning to improve user feedback when trying to clone several braindead bodies. git-svn-id: http://tgstation13.googlecode.com/svn/trunk@3712 316c924e-a436-60f5-8080-3fe189b3f50e
This commit is contained in:
@@ -308,6 +308,16 @@
|
|||||||
var/armor = list(melee = 0, bullet = 0, laser = 0,energy = 0, bomb = 0, bio = 0, rad = 0)
|
var/armor = list(melee = 0, bullet = 0, laser = 0,energy = 0, bomb = 0, bio = 0, rad = 0)
|
||||||
var/list/allowed = null //suit storage stuff.
|
var/list/allowed = null //suit storage stuff.
|
||||||
|
|
||||||
|
/obj/item/verb/verb_pickup()
|
||||||
|
set src in oview(1)
|
||||||
|
set category = "Object"
|
||||||
|
set name = "Pickup"
|
||||||
|
|
||||||
|
if(!usr.canmove || usr.stat || usr.restrained())
|
||||||
|
return
|
||||||
|
|
||||||
|
src.attack_hand(usr)
|
||||||
|
|
||||||
/obj/item/device
|
/obj/item/device
|
||||||
icon = 'device.dmi'
|
icon = 'device.dmi'
|
||||||
|
|
||||||
|
|||||||
@@ -83,70 +83,54 @@
|
|||||||
req_access = list(access_heads) //Only used for record deletion right now.
|
req_access = list(access_heads) //Only used for record deletion right now.
|
||||||
var/obj/machinery/dna_scannernew/scanner = null //Linked scanner. For scanning.
|
var/obj/machinery/dna_scannernew/scanner = null //Linked scanner. For scanning.
|
||||||
var/obj/machinery/clonepod/pod1 = null //Linked cloning pod.
|
var/obj/machinery/clonepod/pod1 = null //Linked cloning pod.
|
||||||
var/temp = "Initializing System..."
|
var/temp = ""
|
||||||
|
var/scantemp = "Scanner unoccupied"
|
||||||
var/menu = 1 //Which menu screen to display
|
var/menu = 1 //Which menu screen to display
|
||||||
var/list/records = list()
|
var/list/records = list()
|
||||||
var/datum/data/record/active_record = null
|
var/datum/data/record/active_record = null
|
||||||
var/obj/item/weapon/disk/data/diskette = null //Mostly so the geneticist can steal everything.
|
var/obj/item/weapon/disk/data/diskette = null //Mostly so the geneticist can steal everything.
|
||||||
|
var/loading = 0 // Nice loading text
|
||||||
|
|
||||||
/obj/machinery/computer/cloning/New()
|
/obj/machinery/computer/cloning/New()
|
||||||
..()
|
..()
|
||||||
spawn(5)
|
spawn(5)
|
||||||
updatemodules()
|
updatemodules()
|
||||||
/*src.scanner = findscanner()//locate(/obj/machinery/dna_scannernew, get_step(src, WEST))
|
|
||||||
src.pod1 = findcloner()//locate(/obj/machinery/clonepod, get_step(src, EAST))
|
|
||||||
world << "SEARCHING FOR MACHEIN"
|
|
||||||
src.temp = ""
|
|
||||||
if (isnull(src.scanner))
|
|
||||||
src.temp += " <font color=red>SCNR-ERROR</font>"
|
|
||||||
if (isnull(src.pod1))
|
|
||||||
src.temp += " <font color=red>POD1-ERROR</font>"
|
|
||||||
else
|
|
||||||
src.pod1.connected = src
|
|
||||||
|
|
||||||
if (src.temp == "")
|
|
||||||
src.temp = "System ready."*/
|
|
||||||
return
|
return
|
||||||
return
|
return
|
||||||
|
|
||||||
/obj/machinery/computer/cloning/proc/updatemodules()
|
/obj/machinery/computer/cloning/proc/updatemodules()
|
||||||
//world << "UPDATING MODULES"
|
src.scanner = findscanner()
|
||||||
src.scanner = findscanner()//locate(/obj/machinery/dna_scannernew, get_step(src, WEST))
|
src.pod1 = findcloner()
|
||||||
src.pod1 = findcloner()//locate(/obj/machinery/clonepod, get_step(src, EAST))
|
|
||||||
//world << "SEARCHING FOR MACHEIN"
|
|
||||||
//src.temp = ""
|
|
||||||
//if (isnull(src.scanner))
|
|
||||||
// src.temp += " <font color=red>SCNR-ERROR</font>"
|
|
||||||
if (!isnull(src.pod1))
|
|
||||||
src.pod1.connected = src
|
|
||||||
// src.temp += " <font color=red>POD1-ERROR</font>"
|
|
||||||
//else
|
|
||||||
|
|
||||||
//if (src.temp == "")
|
if (!isnull(src.pod1))
|
||||||
// src.temp = "System ready."
|
src.pod1.connected = src // Some variable the pod needs
|
||||||
|
|
||||||
/obj/machinery/computer/cloning/proc/findscanner()
|
/obj/machinery/computer/cloning/proc/findscanner()
|
||||||
//..()
|
|
||||||
//world << "SEARCHING FOR SCANNER"
|
|
||||||
var/obj/machinery/dna_scannernew/scannerf = null
|
var/obj/machinery/dna_scannernew/scannerf = null
|
||||||
|
|
||||||
|
// Loop through every direction
|
||||||
for(dir in list(NORTH,EAST,SOUTH,WEST))
|
for(dir in list(NORTH,EAST,SOUTH,WEST))
|
||||||
//world << "SEARCHING IN [dir]"
|
|
||||||
|
// Try to find a scanner in that direction
|
||||||
scannerf = locate(/obj/machinery/dna_scannernew, get_step(src, dir))
|
scannerf = locate(/obj/machinery/dna_scannernew, get_step(src, dir))
|
||||||
|
|
||||||
|
// If found, then we break, and return the scanner
|
||||||
if (!isnull(scannerf))
|
if (!isnull(scannerf))
|
||||||
//world << "FOUND"
|
|
||||||
break
|
break
|
||||||
|
|
||||||
|
// If no scanner was found, it will return null
|
||||||
return scannerf
|
return scannerf
|
||||||
|
|
||||||
/obj/machinery/computer/cloning/proc/findcloner()
|
/obj/machinery/computer/cloning/proc/findcloner()
|
||||||
//..()
|
|
||||||
//world << "SEARCHING FOR POD"
|
|
||||||
var/obj/machinery/clonepod/podf = null
|
var/obj/machinery/clonepod/podf = null
|
||||||
|
|
||||||
for(dir in list(NORTH,EAST,SOUTH,WEST))
|
for(dir in list(NORTH,EAST,SOUTH,WEST))
|
||||||
//world << "SEARCHING IN [dir]"
|
|
||||||
podf = locate(/obj/machinery/clonepod, get_step(src, dir))
|
podf = locate(/obj/machinery/clonepod, get_step(src, dir))
|
||||||
|
|
||||||
if (!isnull(podf))
|
if (!isnull(podf))
|
||||||
//world << "FOUND"
|
|
||||||
break
|
break
|
||||||
|
|
||||||
return podf
|
return podf
|
||||||
|
|
||||||
/obj/machinery/computer/cloning/attackby(obj/item/W as obj, mob/user as mob)
|
/obj/machinery/computer/cloning/attackby(obj/item/W as obj, mob/user as mob)
|
||||||
@@ -184,6 +168,7 @@
|
|||||||
|
|
||||||
switch(src.menu)
|
switch(src.menu)
|
||||||
if(1)
|
if(1)
|
||||||
|
// Modules
|
||||||
dat += "<h4>Modules</h4>"
|
dat += "<h4>Modules</h4>"
|
||||||
//dat += "<a href='byond://?src=\ref[src];relmodules=1'>Reload Modules</a>"
|
//dat += "<a href='byond://?src=\ref[src];relmodules=1'>Reload Modules</a>"
|
||||||
if (isnull(src.scanner))
|
if (isnull(src.scanner))
|
||||||
@@ -195,18 +180,27 @@
|
|||||||
else
|
else
|
||||||
dat += " <font color=green>Pod-Found!</font><br>"
|
dat += " <font color=green>Pod-Found!</font><br>"
|
||||||
|
|
||||||
|
// Scanner
|
||||||
dat += "<h4>Scanner Functions</h4>"
|
dat += "<h4>Scanner Functions</h4>"
|
||||||
|
|
||||||
|
if(loading)
|
||||||
|
dat += "<b>Scanning...</b><br>"
|
||||||
|
else
|
||||||
|
dat += "<b>[scantemp]</b><br>"
|
||||||
|
|
||||||
if (isnull(src.scanner))
|
if (isnull(src.scanner))
|
||||||
dat += "No scanner connected!"
|
dat += "No scanner connected!<br>"
|
||||||
else
|
else
|
||||||
if (src.scanner.occupant)
|
if (src.scanner.occupant)
|
||||||
dat += "<a href='byond://?src=\ref[src];scan=1'>Scan - [src.scanner.occupant]</a>"
|
if(scantemp == "Scanner unoccupied") scantemp = "" // Stupid check to remove the text
|
||||||
|
|
||||||
|
dat += "<a href='byond://?src=\ref[src];scan=1'>Scan - [src.scanner.occupant]</a><br>"
|
||||||
else
|
else
|
||||||
dat += "Scanner unoccupied"
|
scantemp = "Scanner unoccupied"
|
||||||
|
|
||||||
dat += "<br>Lock status: <a href='byond://?src=\ref[src];lock=1'>[src.scanner.locked ? "Locked" : "Unlocked"]</a>"
|
dat += "Lock status: <a href='byond://?src=\ref[src];lock=1'>[src.scanner.locked ? "Locked" : "Unlocked"]</a><br>"
|
||||||
|
|
||||||
|
// Database
|
||||||
dat += "<h4>Database Functions</h4>"
|
dat += "<h4>Database Functions</h4>"
|
||||||
dat += "<a href='byond://?src=\ref[src];menu=2'>View Records</a><br>"
|
dat += "<a href='byond://?src=\ref[src];menu=2'>View Records</a><br>"
|
||||||
if (src.diskette)
|
if (src.diskette)
|
||||||
@@ -268,8 +262,21 @@
|
|||||||
if(..())
|
if(..())
|
||||||
return
|
return
|
||||||
|
|
||||||
|
if(loading)
|
||||||
|
return
|
||||||
|
|
||||||
if ((href_list["scan"]) && (!isnull(src.scanner)))
|
if ((href_list["scan"]) && (!isnull(src.scanner)))
|
||||||
src.scan_mob(src.scanner.occupant)
|
scantemp = ""
|
||||||
|
|
||||||
|
loading = 1
|
||||||
|
src.updateUsrDialog()
|
||||||
|
|
||||||
|
spawn(20)
|
||||||
|
src.scan_mob(src.scanner.occupant)
|
||||||
|
|
||||||
|
loading = 0
|
||||||
|
src.updateUsrDialog()
|
||||||
|
|
||||||
|
|
||||||
//No locking an open scanner.
|
//No locking an open scanner.
|
||||||
else if ((href_list["lock"]) && (!isnull(src.scanner)))
|
else if ((href_list["lock"]) && (!isnull(src.scanner)))
|
||||||
@@ -380,22 +387,22 @@
|
|||||||
|
|
||||||
/obj/machinery/computer/cloning/proc/scan_mob(mob/living/carbon/human/subject as mob)
|
/obj/machinery/computer/cloning/proc/scan_mob(mob/living/carbon/human/subject as mob)
|
||||||
if ((isnull(subject)) || (!(ishuman(subject))) || (!subject.dna))
|
if ((isnull(subject)) || (!(ishuman(subject))) || (!subject.dna))
|
||||||
src.temp = "Error: Unable to locate valid genetic data."
|
scantemp = "Error: Unable to locate valid genetic data."
|
||||||
return
|
return
|
||||||
if (subject.brain_op_stage == 4.0)
|
if (subject.brain_op_stage == 4.0)
|
||||||
src.temp = "Error: No signs of intelligence detected."
|
scantemp = "Error: No signs of intelligence detected."
|
||||||
return
|
return
|
||||||
if (subject.suiciding == 1)
|
if (subject.suiciding == 1)
|
||||||
src.temp = "Error: Subject's brain is not responding to scanning stimuli."
|
scantemp = "Error: Subject's brain is not responding to scanning stimuli."
|
||||||
return
|
return
|
||||||
if ((!subject.ckey) || (!subject.client))
|
if ((!subject.ckey) || (!subject.client))
|
||||||
src.temp = "Error: Mental interface failure."
|
scantemp = "Error: Mental interface failure."
|
||||||
return
|
return
|
||||||
if (NOCLONE in subject.mutations)
|
if (NOCLONE in subject.mutations)
|
||||||
src.temp = "Error: Mental interface failure."
|
scantemp = "Error: Mental interface failure."
|
||||||
return
|
return
|
||||||
if (!isnull(find_record(subject.ckey)))
|
if (!isnull(find_record(subject.ckey)))
|
||||||
src.temp = "Subject already in database."
|
scantemp = "Subject already in database."
|
||||||
return
|
return
|
||||||
|
|
||||||
subject.dna.check_integrity()
|
subject.dna.check_integrity()
|
||||||
@@ -428,7 +435,7 @@
|
|||||||
R.fields["mind"] = "\ref[subject.mind]"
|
R.fields["mind"] = "\ref[subject.mind]"
|
||||||
|
|
||||||
src.records += R
|
src.records += R
|
||||||
src.temp = "Subject successfully scanned."
|
scantemp = "Subject successfully scanned."
|
||||||
|
|
||||||
//Find a specific record by key.
|
//Find a specific record by key.
|
||||||
/obj/machinery/computer/cloning/proc/find_record(var/find_key)
|
/obj/machinery/computer/cloning/proc/find_record(var/find_key)
|
||||||
|
|||||||
@@ -216,3 +216,13 @@
|
|||||||
|
|
||||||
if(!src.toggle())
|
if(!src.toggle())
|
||||||
usr << "\blue It won't budge!"
|
usr << "\blue It won't budge!"
|
||||||
|
|
||||||
|
/obj/structure/closet/verb/verb_toggleopen()
|
||||||
|
set src in oview(1)
|
||||||
|
set category = "Object"
|
||||||
|
set name = "Toggle Open"
|
||||||
|
|
||||||
|
if(!usr.canmove || usr.stat || usr.restrained())
|
||||||
|
return
|
||||||
|
|
||||||
|
src.attack_hand(usr)
|
||||||
|
|||||||
@@ -24,6 +24,19 @@
|
|||||||
src.req_access += pick(get_all_accesses())
|
src.req_access += pick(get_all_accesses())
|
||||||
..()
|
..()
|
||||||
|
|
||||||
|
/obj/structure/closet/secure_closet/proc/togglelock(mob/user as mob)
|
||||||
|
if(src.allowed(user))
|
||||||
|
src.locked = !src.locked
|
||||||
|
for(var/mob/O in viewers(user, 3))
|
||||||
|
if((O.client && !( O.blinded )))
|
||||||
|
O << "\blue The locker has been [src.locked ? null : "un"]locked by [user]."
|
||||||
|
if(src.locked)
|
||||||
|
src.icon_state = src.icon_locked
|
||||||
|
else
|
||||||
|
src.icon_state = src.icon_closed
|
||||||
|
else
|
||||||
|
user << "\red Access Denied"
|
||||||
|
|
||||||
/obj/structure/closet/secure_closet/attackby(obj/item/weapon/W as obj, mob/user as mob)
|
/obj/structure/closet/secure_closet/attackby(obj/item/weapon/W as obj, mob/user as mob)
|
||||||
if(src.opened)
|
if(src.opened)
|
||||||
if(istype(W, /obj/item/weapon/grab))
|
if(istype(W, /obj/item/weapon/grab))
|
||||||
@@ -54,19 +67,8 @@
|
|||||||
else
|
else
|
||||||
for(var/mob/O in viewers(user, 3))
|
for(var/mob/O in viewers(user, 3))
|
||||||
O.show_message("\blue The locker has been broken by [user] with an electromagnetic card!", 1, "You hear a faint electrical spark.", 2)
|
O.show_message("\blue The locker has been broken by [user] with an electromagnetic card!", 1, "You hear a faint electrical spark.", 2)
|
||||||
else if(src.allowed(user))
|
|
||||||
src.locked = !src.locked
|
|
||||||
for(var/mob/O in viewers(user, 3))
|
|
||||||
if((O.client && !( O.blinded )))
|
|
||||||
O << "\blue The locker has been [src.locked ? null : "un"]locked by [user]."
|
|
||||||
if(src.locked)
|
|
||||||
src.icon_state = src.icon_locked
|
|
||||||
else
|
|
||||||
src.icon_state = src.icon_closed
|
|
||||||
|
|
||||||
else
|
else
|
||||||
user << "\red Access Denied"
|
togglelock(user)
|
||||||
return
|
|
||||||
|
|
||||||
/obj/structure/closet/secure_closet/relaymove(mob/user as mob)
|
/obj/structure/closet/secure_closet/relaymove(mob/user as mob)
|
||||||
if(user.stat)
|
if(user.stat)
|
||||||
@@ -97,3 +99,15 @@
|
|||||||
|
|
||||||
/obj/structure/closet/secure_closet/attack_paw(mob/user as mob)
|
/obj/structure/closet/secure_closet/attack_paw(mob/user as mob)
|
||||||
return src.attack_hand(user)
|
return src.attack_hand(user)
|
||||||
|
|
||||||
|
/obj/structure/closet/secure_closet/verb/verb_togglelock()
|
||||||
|
set src in oview(1) // Can only use it from one square distance
|
||||||
|
set category = "Object"
|
||||||
|
set name = "Toggle Lock"
|
||||||
|
|
||||||
|
if(!usr.canmove || usr.stat || usr.restrained()) // Don't use it if you're not able to! Checks for stuns, ghost and restrain
|
||||||
|
return
|
||||||
|
|
||||||
|
if(!opened) // If we let him lock it while it's open, it will close without the items inside going with it
|
||||||
|
togglelock(usr)
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user