diff --git a/code/game/dna/dna_modifier.dm b/code/game/dna/dna_modifier.dm
index fd88c04978..f2bbbab1dc 100644
--- a/code/game/dna/dna_modifier.dm
+++ b/code/game/dna/dna_modifier.dm
@@ -721,7 +721,7 @@
// Cooldown
injector_ready = FALSE
- addtimer(CALLBACK(src, PROC_REF(injector_cooldown_finish)), 30 SECONDS)
+ addtimer(CALLBACK(src, PROC_REF(injector_cooldown_finish)), 5 SECONDS)
// Create it
var/datum/transhuman/body_record/buf = buffers[buffer_id] // Traitgenes Use bodyrecords
diff --git a/code/game/objects/items/devices/scanners/gene.dm b/code/game/objects/items/devices/scanners/gene.dm
index 12a42414c3..368b8a0944 100644
--- a/code/game/objects/items/devices/scanners/gene.dm
+++ b/code/game/objects/items/devices/scanners/gene.dm
@@ -1,6 +1,6 @@
/obj/item/gene_scanner
name = "DNA identifier"
- desc = "The GenePeeper 3000, scans and identifies traits enabled by a subject's genetics. Can also scan limbs and organs to identify their dna. Decades of genetic research in your pocket, today! "
+ desc = "The GenePeeper 3000, scans and identifies traits enabled by a subject's genetics. Can also scan limbs, organs, and DNA injectors. Decades of genetic research in your pocket, today! "
icon = 'icons/obj/device_alt.dmi'
icon_state = "health"
flags = NOBLUDGEON
@@ -12,7 +12,7 @@
/obj/item/gene_scanner/afterattack(atom/movable/AM, mob/user, proximity)
if(!proximity)
return
- if(!ismob(AM) && !istype(AM,/obj/item/organ))
+ if(!ismob(AM) && !istype(AM,/obj/item/organ) && !istype(AM,/obj/item/dnainjector))
return
to_chat(user,span_boldnotice("You assesses \the [AM]'s genetic traits."))
@@ -25,6 +25,7 @@
/obj/item/gene_scanner/proc/scan_genes(atom/movable/AM,mob/user)
var/obj/item/organ/O = AM
var/mob/living/L = AM
+ var/obj/item/dnainjector/I = AM
var/output = ""
// Actually do the scan
@@ -70,15 +71,16 @@
for(var/datum/gene/G in GLOB.dna_genes)
if(!L.dna.GetSEState(G.block))
continue
+ var/dna_val = L.dna.GetSEValue(G.block)
if(istype(G,/datum/gene/trait))
var/datum/gene/trait/TG = G
if(ishuman(L))
- output += span_info("-[TG.linked_trait.name]") + span_warning((TG.has_conflict(H.species.traits) ? " (Suppressed)" : "")) + "
"
+ output += span_info("-\[[EncodeDNABlock(dna_val)]\]:[TG.linked_trait.name]") + span_warning((TG.has_conflict(H.species.traits) ? " (Suppressed)" : "")) + "
"
else
- output += span_info("-[TG.linked_trait.name]") + "
"
+ output += span_info("-\[[EncodeDNABlock(dna_val)]\]:[TG.linked_trait.name]") + "
"
output += span_infoplain(" [TG.linked_trait.desc]") + "
"
else
- output += span_info("-[G.name]") + "
"
+ output += span_info("-\[[EncodeDNABlock(dna_val)]\]:[G.name]") + "
"
output += span_infoplain(" [G.desc]") + "
"
else if(istype(O)) // Organs
@@ -90,4 +92,23 @@
output += span_infoplain("Unique enzymes: [O.data.unique_enzymes]") + "
"
output += span_infoplain("Bloodtype: [O.data.b_type]") + "
"
+ else if(istype(I)) // Dna injectors
+ if(I.buf?.dna)
+ output += span_infoplain("Unique enzymes: [I.buf.dna.unique_enzymes != "" ? I.buf.dna.unique_enzymes : "STRIPPED" ]") + "
"
+ output += span_infoplain("Bloodtype: [I.buf.dna.b_type]") + "
"
+ output += span_boldnotice("Detected genes:") + "
"
+ for(var/datum/gene/G in GLOB.dna_genes)
+ if(!I.buf.dna.GetSEState(G.block))
+ continue
+ var/dna_val = I.buf.dna.GetSEValue(G.block)
+ if(istype(G,/datum/gene/trait))
+ var/datum/gene/trait/TG = G
+ output += span_info("-\[[EncodeDNABlock(dna_val)]\]:[TG.linked_trait.name]") + "
"
+ output += span_infoplain(" [TG.linked_trait.desc]") + "
"
+ else
+ output += span_info("-\[[EncodeDNABlock(dna_val)]\]:[G.name]") + "
"
+ output += span_infoplain(" [G.desc]") + "
"
+ else
+ output += span_danger("ERR - Invalid sequencing data.")
+
to_chat(user,output)