mirror of
https://github.com/Bubberstation/Bubberstation.git
synced 2026-01-05 06:21:57 +00:00
* Admin Verb Datums MkIII | Now with functional command bar (#82511) * Modular stuffs * Put some admin jump verbs back into the context menu | sorts area jump list again (#82647) ## About The Pull Request See title. ## Why It's Good For The Game Some admins wanted all the jump verbs back, aswell as making them not AGhost you. Also make the Jump To Area verb use a sorted list again * Hey what if admins were allowed to use the player panel (#82682) Re-adds the player panel verb to the verb panel. * Controller Overview UI (#82739) * Fixes a minor spelling mistake on the admin panel/verb list (#82747) ## About The Pull Request Corrects `inisimin` to `invisimin`. This addresses #82728, but only fixes one of the two issues mentioned ## Why It's Good For The Game -1 spelling mistake ## Changelog 🆑 spellcheck: 'inisimin' verb corrected to 'invisimin' /🆑 * Player Panel-age (#82757) * Admin Forced Mob Rename and Preference Update (#82715) --------- Co-authored-by: Zephyr <12817816+ZephyrTFA@users.noreply.github.com> Co-authored-by: Useroth <37159550+Useroth@users.noreply.github.com> Co-authored-by: chel <64568243+iliyaxox@users.noreply.github.com>
133 lines
5.1 KiB
Plaintext
133 lines
5.1 KiB
Plaintext
|
|
ADMIN_VERB(force_random_rotate, R_SERVER, "Trigger 'Random' Map Rotation", "Force a map vote.", ADMIN_CATEGORY_SERVER)
|
|
var/rotate = tgui_alert(user,"Force a random map rotation to trigger?", "Rotate map?", list("Yes", "Cancel"))
|
|
if (rotate != "Yes")
|
|
return
|
|
message_admins("[key_name_admin(user)] is forcing a random map rotation.")
|
|
log_admin("[key_name(user)] is forcing a random map rotation.")
|
|
SSmapping.maprotate()
|
|
|
|
ADMIN_VERB(admin_change_map, R_SERVER, "Change Map", "Set the next map.", ADMIN_CATEGORY_SERVER)
|
|
var/list/maprotatechoices = list()
|
|
for (var/map in config.maplist)
|
|
var/datum/map_config/virtual_map = config.maplist[map]
|
|
var/mapname = virtual_map.map_name
|
|
if (virtual_map == config.defaultmap)
|
|
mapname += " (Default)"
|
|
|
|
if (virtual_map.config_min_users > 0 || virtual_map.config_max_users > 0)
|
|
mapname += " \["
|
|
if (virtual_map.config_min_users > 0)
|
|
mapname += "[virtual_map.config_min_users]"
|
|
else
|
|
mapname += "0"
|
|
mapname += "-"
|
|
if (virtual_map.config_max_users > 0)
|
|
mapname += "[virtual_map.config_max_users]"
|
|
else
|
|
mapname += "inf"
|
|
mapname += "\]"
|
|
|
|
maprotatechoices[mapname] = virtual_map
|
|
var/chosenmap = tgui_input_list(user, "Choose a map to change to", "Change Map", sort_list(maprotatechoices)|"Custom")
|
|
if (isnull(chosenmap))
|
|
return
|
|
|
|
if(chosenmap == "Custom")
|
|
message_admins("[key_name_admin(user)] is changing the map to a custom map")
|
|
log_admin("[key_name(user)] is changing the map to a custom map")
|
|
var/datum/map_config/virtual_map = new
|
|
|
|
var/map_file = input(user, "Pick file:", "Map File") as null|file
|
|
if(isnull(map_file))
|
|
return
|
|
|
|
if(copytext("[map_file]", -4) != ".dmm")//4 == length(".dmm")
|
|
to_chat(user, span_warning("Filename must end in '.dmm': [map_file]"))
|
|
return
|
|
|
|
if(fexists("_maps/custom/[map_file]"))
|
|
fdel("_maps/custom/[map_file]")
|
|
if(!fcopy(map_file, "_maps/custom/[map_file]"))
|
|
return
|
|
// This is to make sure the map works so the server does not start without a map.
|
|
var/datum/parsed_map/M = new (map_file)
|
|
if(!M)
|
|
to_chat(user, span_warning("Map '[map_file]' failed to parse properly."))
|
|
return
|
|
|
|
if(!M.bounds)
|
|
to_chat(user, span_warning("Map '[map_file]' has non-existant bounds."))
|
|
qdel(M)
|
|
return
|
|
|
|
qdel(M)
|
|
var/config_file = null
|
|
var/list/json_value = list()
|
|
var/config = tgui_alert(user,"Would you like to upload an additional config for this map?", "Map Config", list("Yes", "No"))
|
|
if(config == "Yes")
|
|
config_file = input(user, "Pick file:", "Config JSON File") as null|file
|
|
if(isnull(config_file))
|
|
return
|
|
if(copytext("[config_file]", -5) != ".json")
|
|
to_chat(src, span_warning("Filename must end in '.json': [config_file]"))
|
|
return
|
|
if(fexists("data/custom_map_json/[config_file]"))
|
|
fdel("data/custom_map_json/[config_file]")
|
|
if(!fcopy(config_file, "data/custom_map_json/[config_file]"))
|
|
return
|
|
if (virtual_map.LoadConfig("data/custom_map_json/[config_file]", TRUE) != TRUE)
|
|
to_chat(src, span_warning("Failed to load config: [config_file]. Check that the fields are filled out correctly. \"map_path\": \"custom\" and \"map_file\": \"your_map_name.dmm\""))
|
|
return
|
|
json_value = list(
|
|
"version" = MAP_CURRENT_VERSION,
|
|
"map_name" = virtual_map.map_name,
|
|
"map_path" = virtual_map.map_path,
|
|
"map_file" = virtual_map.map_file,
|
|
"shuttles" = virtual_map.shuttles,
|
|
"traits" = virtual_map.traits,
|
|
"job_changes" = virtual_map.job_changes,
|
|
"library_areas" = virtual_map.library_areas,
|
|
)
|
|
else
|
|
virtual_map = load_map_config()
|
|
virtual_map.map_name = input(user, "Choose the name for the map", "Map Name") as null|text
|
|
if(isnull(virtual_map.map_name))
|
|
virtual_map.map_name = "Custom"
|
|
|
|
var/shuttles = tgui_alert(user,"Do you want to modify the shuttles?", "Map Shuttles", list("Yes", "No"))
|
|
if(shuttles == "Yes")
|
|
for(var/s in virtual_map.shuttles)
|
|
var/shuttle = input(user, s, "Map Shuttles") as null|text
|
|
if(!shuttle)
|
|
continue
|
|
if(!SSmapping.shuttle_templates[shuttle])
|
|
to_chat(user, span_warning("No such shuttle as '[shuttle]' exists, using default."))
|
|
continue
|
|
virtual_map.shuttles[s] = shuttle
|
|
|
|
json_value = list(
|
|
"version" = MAP_CURRENT_VERSION,
|
|
"map_name" = virtual_map.map_name,
|
|
"map_path" = CUSTOM_MAP_PATH,
|
|
"map_file" = "[map_file]",
|
|
"shuttles" = virtual_map.shuttles,
|
|
)
|
|
|
|
// If the file isn't removed text2file will just append.
|
|
if(fexists(PATH_TO_NEXT_MAP_JSON))
|
|
fdel(PATH_TO_NEXT_MAP_JSON)
|
|
text2file(json_encode(json_value), PATH_TO_NEXT_MAP_JSON)
|
|
|
|
if(SSmapping.changemap(virtual_map))
|
|
message_admins("[key_name_admin(user)] has changed the map to [virtual_map.map_name]")
|
|
SSmapping.map_force_chosen = TRUE
|
|
fdel("data/custom_map_json/[config_file]")
|
|
else
|
|
var/datum/map_config/virtual_map = maprotatechoices[chosenmap]
|
|
message_admins("[key_name_admin(user)] is changing the map to [virtual_map.map_name]")
|
|
log_admin("[key_name(user)] is changing the map to [virtual_map.map_name]")
|
|
if (SSmapping.changemap(virtual_map))
|
|
message_admins("[key_name_admin(user)] has changed the map to [virtual_map.map_name]")
|
|
SSmapping.map_force_chosen = TRUE
|