diff --git a/code/modules/reagents/reagent_containers/rags.dm b/code/modules/reagents/reagent_containers/rags.dm
index 8d44a2a406..414208d0bf 100644
--- a/code/modules/reagents/reagent_containers/rags.dm
+++ b/code/modules/reagents/reagent_containers/rags.dm
@@ -5,7 +5,7 @@
icon = 'icons/obj/toy.dmi'
icon_state = "rag"
item_flags = NOBLUDGEON
- reagent_flags = OPENCONTAINER
+ reagent_flags = REFILLABLE | DRAINABLE
amount_per_transfer_from_this = 5
possible_transfer_amounts = list()
volume = 5
@@ -23,7 +23,7 @@
/obj/item/reagent_containers/rag/examine(mob/user)
. = ..()
if(reagents.total_volume)
- . += "Alt-Click to squeeze the liquids out of it."
+ . += "It's soaked. Alt-Click to squeeze it dry, and perhaps gather the liquids into another held open container."
/obj/item/reagent_containers/rag/afterattack(atom/A as obj|turf|area, mob/user,proximity)
. = ..()
@@ -85,15 +85,26 @@
/obj/item/reagent_containers/rag/AltClick(mob/user)
. = ..()
if(reagents.total_volume && user.canUseTopic(src, BE_CLOSE))
- to_chat(user, "You start squeezing the liquids out of \the [src]...")
+ to_chat(user, "You start squeezing \the [src] dry...")
if(do_after(user, action_speed, TRUE, src))
- to_chat(user, "You squeeze \the [src] dry.")
- var/atom/react_loc = get_turf(src)
- if(ismob(react_loc))
- react_loc = react_loc.loc
- if(react_loc)
- reagents.reaction(react_loc, TOUCH)
- reagents.clear_reagents()
+ var/msg = "You squeeze \the [src]"
+ var/obj/item/target
+ if(Adjacent(user)) //Allows the user to drain the reagents into a beaker if adjacent (no telepathy).
+ for(var/obj/item/I in user.held_items)
+ if(I == src)
+ continue
+ if(I.is_open_container() && !I.reagents.holder_full())
+ target = I
+ break
+ if(!target)
+ msg += " dry"
+ reagents.reaction(get_turf(src), TOUCH)
+ reagents.clear_reagents()
+ else
+ msg += "'s liquids into \the [target]"
+ reagents.trans_to(target, reagents.total_volume)
+ to_chat(user, "[msg].")
+
/obj/item/reagent_containers/rag/towel
name = "towel"