/client/proc/admin_memo()
set name = "Memo"
set category = "Server"
if(!check_rights(R_SERVER))
return
if(!SSdbcore.IsConnected())
to_chat(src, "Failed to establish database connection.")
return
var/memotask = input(usr,"Choose task.","Memo") in list("Show","Write","Edit","Remove")
if(!memotask)
return
admin_memo_output(memotask)
/client/proc/admin_memo_output(task, checkrights = 1, silent = 0)
if(checkrights && !check_rights(R_SERVER))
return
if(!task)
return
if(!SSdbcore.IsConnected())
to_chat(src, "Failed to establish database connection.")
return
switch(task)
if("Write")
var/datum/db_query/query_memocheck = SSdbcore.NewQuery(
"SELECT ckey FROM memo WHERE ckey=:ckey",
list("ckey" = ckey)
)
if(!query_memocheck.warn_execute())
qdel(query_memocheck)
return
if(query_memocheck.NextRow())
to_chat(src, "You already have set a memo.")
qdel(query_memocheck)
return
qdel(query_memocheck)
var/memotext = input(src, "Write your Memo", "Memo") as message
if(!memotext)
return
var/datum/db_query/query_memoadd = SSdbcore.NewQuery(
"INSERT INTO memo (ckey, memotext, timestamp) VALUES (:ckey, :memotext, NOW())",
list(
"ckey" = ckey,
"memotext" = memotext
)
)
if(!query_memoadd.warn_execute())
qdel(query_memoadd)
return
log_admin("[key_name(src)] has set a memo: [memotext]")
message_admins("[key_name_admin(src)] has set a memo:
[memotext]")
qdel(query_memoadd)
if("Edit")
var/datum/db_query/query_memolist = SSdbcore.NewQuery("SELECT ckey FROM memo")
if(!query_memolist.warn_execute())
qdel(query_memolist)
return
var/list/memolist = list()
while(query_memolist.NextRow())
var/lkey = query_memolist.item[1]
memolist += "[lkey]"
qdel(query_memolist)
if(!length(memolist))
to_chat(src, "No memos found in database.")
return
var/target_ckey = input(src, "Select whose memo to edit", "Select memo") as null|anything in memolist
if(!target_ckey)
return
var/datum/db_query/query_memofind = SSdbcore.NewQuery(
"SELECT memotext FROM memo WHERE ckey=:ckey",
list("ckey" = target_ckey)
)
if(!query_memofind.warn_execute())
qdel(query_memofind)
return
if(query_memofind.NextRow())
var/old_memo = query_memofind.item[1]
var/new_memo = input("Input new memo", "New Memo", "[old_memo]", null) as message
if(!new_memo)
qdel(query_memofind)
return
var/edit_text = "Edited by [target_ckey] on [SQLtime()] from
[old_memo]
to
[new_memo]