diff --git a/.github/labeler.yml b/.github/labeler.yml
new file mode 100644
index 0000000000000..daaffa28fdba8
--- /dev/null
+++ b/.github/labeler.yml
@@ -0,0 +1,37 @@
+'TGUI':
+ - 'tgui/**'
+
+'Звук':
+ - '**/*.ogg'
+
+'Спрайты':
+ - '**/*.dmi'
+ - '**/*.png'
+
+'Изменение Карты':
+ - '**/*.dmm'
+
+'НЕ МОДУЛЬНО':
+ - all: ['code/**']
+ - branches-ignore:
+ - 'translate'
+
+'Частичная модульность':
+ - all: ['code/**', modular_bandastation/**]
+
+'Перевод':
+ branches:
+ - 'translate'
+
+'Инструменты':
+ - '.gihub/workflows/**'
+ - 'tools/**'
+
+'Изменение конфига':
+ - 'config/**'
+
+'Документация':
+ - '**/*.md'
+
+'SQL':
+ - 'SQL/**'
diff --git a/.github/workflows/label.yml b/.github/workflows/label.yml
new file mode 100644
index 0000000000000..374a6f59dee34
--- /dev/null
+++ b/.github/workflows/label.yml
@@ -0,0 +1,13 @@
+name: "Label"
+
+on:
+- pull_request_target
+
+jobs:
+ labeler:
+ runs-on: ubuntu-latest
+ steps:
+ - uses: actions/labeler@v4
+ with:
+ repo-token: "${{ secrets.GITHUB_TOKEN }}"
+ sync-labels: true
diff --git a/code/__HELPERS/game.dm b/code/__HELPERS/game.dm
index aa953760bce71..9d72d7c432041 100644
--- a/code/__HELPERS/game.dm
+++ b/code/__HELPERS/game.dm
@@ -235,7 +235,7 @@
if(!SSticker.IsRoundInProgress() || QDELETED(character))
return
var/area/player_area = get_area(character)
- deadchat_broadcast(" has arrived at the station at [player_area.name].", "[character.real_name] ([rank])", follow_target = character, message_type=DEADCHAT_ARRIVALRATTLE)
+ deadchat_broadcast(" прибыл на станцию у [player_area.name].", "[character.real_name] ([job_title_ru(rank)])", follow_target = character, message_type=DEADCHAT_ARRIVALRATTLE)
if(!character.mind)
return
if(!GLOB.announcement_systems.len)
diff --git a/code/__HELPERS/roundend.dm b/code/__HELPERS/roundend.dm
index ed8d882393b5c..df04d20c5e2cb 100644
--- a/code/__HELPERS/roundend.dm
+++ b/code/__HELPERS/roundend.dm
@@ -47,7 +47,7 @@ GLOBAL_LIST_INIT(achievements_unlocked, list())
var/mob/living/carbon/human/H = L
category = "humans"
if(H.mind)
- mob_data["job"] = H.mind.assigned_role.title
+ mob_data["job"] = job_title_ru(H.mind.assigned_role.title)
else
mob_data["job"] = "Unknown"
mob_data["species"] = H.dna.species.name
@@ -685,8 +685,8 @@ GLOBAL_LIST_INIT(achievements_unlocked, list())
/proc/printplayer(datum/mind/ply, fleecheck)
var/jobtext = ""
if(!is_unassigned_job(ply.assigned_role))
- jobtext = " the [ply.assigned_role.title]"
- var/text = "[ply.key] was [ply.name][jobtext] and"
+ jobtext = ", [job_title_ru(ply.assigned_role.title)],"
+ var/text = "[ply.key] был [ply.name][jobtext] and"
if(ply.current)
if(ply.current.stat == DEAD)
text += " [span_redtext("died")]"
diff --git a/code/controllers/subsystem/blackbox.dm b/code/controllers/subsystem/blackbox.dm
index bb4f3802d89b1..be70843f930ec 100644
--- a/code/controllers/subsystem/blackbox.dm
+++ b/code/controllers/subsystem/blackbox.dm
@@ -325,7 +325,7 @@ Versioning
if(!did_they_suicide && !first_death.len)
first_death["name"] = "[(L.real_name == L.name) ? L.real_name : "[L.real_name] as [L.name]"]"
first_death["role"] = null
- first_death["role"] = L.mind.assigned_role.title
+ first_death["role"] = job_title_ru(L.mind.assigned_role.title)
first_death["area"] = "[AREACOORD(L)]"
first_death["damage"] = "[L.getBruteLoss()]/[L.getFireLoss()]/[L.getToxLoss()]/[L.getOxyLoss()]"
first_death["last_words"] = L.last_words
@@ -339,7 +339,7 @@ Versioning
"}, list(
"name" = L.real_name,
"key" = L.ckey,
- "job" = L.mind.assigned_role.title,
+ "job" = job_title_ru(L.mind.assigned_role.title),
"special" = L.mind.special_role,
"pod" = get_area_name(L, TRUE),
"laname" = L.lastattacker,
diff --git a/code/datums/memory/_memory.dm b/code/datums/memory/_memory.dm
index 08a694616a336..1d4301769024f 100644
--- a/code/datums/memory/_memory.dm
+++ b/code/datums/memory/_memory.dm
@@ -388,11 +388,11 @@
else if(ishuman(character))
// This can slip into memories involving monkey humans.
- return "the unfamiliar person"
+ return "неизвестная персона"
if(istype(character, /datum/mind))
var/datum/mind/character_mind = character
- return "\the [LOWER_TEXT(initial(character_mind.assigned_role.title))]"
+ return "[LOWER_TEXT(job_title_ru(initial(character_mind.assigned_role.title)))]"
// Generic result - mobs get "the guy", objs / turfs get "a thing"
return ismob(character) ? "\the [character]" : "\a [character]"
diff --git a/code/game/gamemodes/objective.dm b/code/game/gamemodes/objective.dm
index c73dda284d97a..467eeea067a81 100644
--- a/code/game/gamemodes/objective.dm
+++ b/code/game/gamemodes/objective.dm
@@ -230,7 +230,7 @@ GLOBAL_LIST(admin_objective_list) //Prefilled admin assignable objective list
/datum/objective/assassinate/update_explanation_text()
..()
if(target?.current)
- explanation_text = "Убейте [target.name], [!target_role_type ? target.assigned_role.title : target.special_role]."
+ explanation_text = "Убейте [target.name], [!target_role_type ? job_title_ru(target.assigned_role.title) : target.special_role]."
else
explanation_text = "Свободная задача."
@@ -280,7 +280,7 @@ GLOBAL_LIST(admin_objective_list) //Prefilled admin assignable objective list
/datum/objective/mutiny/update_explanation_text()
..()
if(target?.current)
- explanation_text = "Убейте или отправьте в изгнание [target.name], [!target_role_type ? target.assigned_role.title : target.special_role]."
+ explanation_text = "Убейте или отправьте в изгнание [target.name], [!target_role_type ? job_title_ru(target.assigned_role.title) : target.special_role]."
else
explanation_text = "Свободная задача."
@@ -302,7 +302,7 @@ GLOBAL_LIST(admin_objective_list) //Prefilled admin assignable objective list
/datum/objective/maroon/update_explanation_text()
if(target?.current)
- explanation_text = "Не дайте [target.name], [!target_role_type ? target.assigned_role.title : target.special_role], эвакуироватся живым со станции."
+ explanation_text = "Не дайте [target.name], [!target_role_type ? job_title_ru(target.assigned_role.title) : target.special_role], эвакуироватся живым со станции."
else
explanation_text = "Свободная задача."
@@ -333,7 +333,7 @@ GLOBAL_LIST(admin_objective_list) //Prefilled admin assignable objective list
/datum/objective/debrain/update_explanation_text()
..()
if(target?.current)
- explanation_text = "Украдите мозг [target.name], [!target_role_type ? target.assigned_role.title : target.special_role]."
+ explanation_text = "Украдите мозг [target.name], [!target_role_type ? job_title_ru(target.assigned_role.title) : target.special_role]."
else
explanation_text = "Свободная задача."
@@ -359,7 +359,7 @@ GLOBAL_LIST(admin_objective_list) //Prefilled admin assignable objective list
/datum/objective/protect/update_explanation_text()
..()
if(target?.current)
- explanation_text = "Защитите [target.name], [!target_role_type ? target.assigned_role.title : target.special_role]."
+ explanation_text = "Защитите [target.name], [!target_role_type ? job_title_ru(target.assigned_role.title) : target.special_role]."
else
explanation_text = "Свободная задача."
@@ -384,7 +384,7 @@ GLOBAL_LIST(admin_objective_list) //Prefilled admin assignable objective list
/datum/objective/jailbreak/update_explanation_text()
..()
if(target?.current)
- explanation_text = "Удостоверьтесь, что [target.name], [!target_role_type ? target.assigned_role.title : target.special_role], сбежит живым и вне заключения."
+ explanation_text = "Удостоверьтесь, что [target.name], [!target_role_type ? job_title_ru(target.assigned_role.title) : target.special_role], сбежит живым и вне заключения."
else
explanation_text = "Свободная задача."
@@ -400,7 +400,7 @@ GLOBAL_LIST(admin_objective_list) //Prefilled admin assignable objective list
/datum/objective/jailbreak/detain/update_explanation_text()
..()
if(target?.current)
- explanation_text = "Удостоверьтесь, что [target.name], [!target_role_type ? target.assigned_role.title : target.special_role], доставлен на ЦК живым и в заключении."
+ explanation_text = "Удостоверьтесь, что [target.name], [!target_role_type ? job_title_ru(target.assigned_role.title) : target.special_role], доставлен на ЦК живым и в заключении."
else
explanation_text = "Свободная задача."
@@ -527,7 +527,7 @@ GLOBAL_LIST(admin_objective_list) //Prefilled admin assignable objective list
/datum/objective/escape/escape_with_identity/update_explanation_text()
if(target?.current)
target_real_name = target.current.real_name
- explanation_text = "Сбегите на эвакуационном шаттле или челноке под личиной [target_real_name], [target.assigned_role.title]"
+ explanation_text = "Сбегите на эвакуационном шаттле или челноке под личиной [target_real_name], [job_title_ru(target.assigned_role.title)]"
var/mob/living/carbon/human/H
if(ishuman(target.current))
H = target.current
diff --git a/code/game/machinery/announcement_system.dm b/code/game/machinery/announcement_system.dm
index 7e30566430b0f..bb08161e404c9 100644
--- a/code/game/machinery/announcement_system.dm
+++ b/code/game/machinery/announcement_system.dm
@@ -75,7 +75,7 @@ GLOBAL_LIST_EMPTY(announcement_systems)
/obj/machinery/announcement_system/proc/CompileText(str, user, rank) //replaces user-given variables with actual thingies.
str = replacetext(str, "%PERSON", "[user]")
- str = replacetext(str, "%RANK", "[rank]")
+ str = replacetext(str, "%RANK", "[job_title_ru(rank)]")
return str
/obj/machinery/announcement_system/proc/announce(message_type, user, rank, list/channels)
@@ -98,7 +98,7 @@ GLOBAL_LIST_EMPTY(announcement_systems)
if (!is_operational)
return
- broadcast("Officer [officer.real_name] has been assigned to [department].", list(RADIO_CHANNEL_SECURITY))
+ broadcast("Офицер [officer.real_name] был назначен к отделу: [department].", list(RADIO_CHANNEL_SECURITY))
/// Sends a message to the appropriate channels.
/obj/machinery/announcement_system/proc/broadcast(message, list/channels)
diff --git a/code/game/objects/items/mail.dm b/code/game/objects/items/mail.dm
index 2aec478162445..3a2cbf0637afd 100644
--- a/code/game/objects/items/mail.dm
+++ b/code/game/objects/items/mail.dm
@@ -167,7 +167,7 @@
/// Accepts a mind to initialize goodies for a piece of mail.
/obj/item/mail/proc/initialize_for_recipient(datum/mind/recipient)
- name = "[initial(name)] for [recipient.name] ([recipient.assigned_role.title])"
+ name = "[initial(name)] для [recipient.name], ([job_title_ru(recipient.assigned_role.title)])"
recipient_ref = WEAKREF(recipient)
var/mob/living/body = recipient.current
diff --git a/code/modules/admin/antag_panel.dm b/code/modules/admin/antag_panel.dm
index 877bebffe9509..91948ab3faae1 100644
--- a/code/modules/admin/antag_panel.dm
+++ b/code/modules/admin/antag_panel.dm
@@ -97,7 +97,7 @@ GLOBAL_VAR(antag_prototypes)
var/out = "[name][(current && (current.real_name != name))?" (as [current.real_name])":""]
"
out += "Mind currently owned by key: [key] [active?"(synced)":"(not synced)"]
"
- out += "Assigned role: [assigned_role.title]. Edit
"
+ out += "Assigned role: [job_title_ru(assigned_role.title)]. Edit
"
out += "Faction and special role: [special_role]
"
out += "Show Teams
"
diff --git a/code/modules/admin/topic.dm b/code/modules/admin/topic.dm
index 13f5b3544b2a0..e5f6c8b5f4260 100644
--- a/code/modules/admin/topic.dm
+++ b/code/modules/admin/topic.dm
@@ -793,7 +793,7 @@
//Job + antagonist
if(subject.mind)
- special_role_description = "Role: [subject.mind.assigned_role.title]; Antagonist: "
+ special_role_description = "Role: [job_title_ru(subject.mind.assigned_role.title)]; Antagonist: "
if(subject.mind.antag_datums)
var/iterable = 0
diff --git a/code/modules/antagonists/cult/cult_objectives.dm b/code/modules/antagonists/cult/cult_objectives.dm
index d290b212ab22f..4f6a8b7cf7267 100644
--- a/code/modules/antagonists/cult/cult_objectives.dm
+++ b/code/modules/antagonists/cult/cult_objectives.dm
@@ -78,7 +78,7 @@
/datum/objective/sacrifice/update_explanation_text()
if(target)
- explanation_text = "Sacrifice [target], the [target.assigned_role.title] via invoking an Offer rune with [target.p_them()] on it and three acolytes around it."
+ explanation_text = "Sacrifice [target], [job_title_ru(target.assigned_role.title)], via invoking an Offer rune with [target.p_them()] on it and three acolytes around it."
else
explanation_text = "The veil has already been weakened here, proceed to the final objective."
diff --git a/code/modules/antagonists/obsessed/obsessed.dm b/code/modules/antagonists/obsessed/obsessed.dm
index 7316102e2ce09..aeeab3988e6ad 100644
--- a/code/modules/antagonists/obsessed/obsessed.dm
+++ b/code/modules/antagonists/obsessed/obsessed.dm
@@ -167,7 +167,7 @@
/datum/objective/assassinate/obsessed/update_explanation_text()
..()
if(target?.current)
- explanation_text = "Murder [target.name], the [!target_role_type ? target.assigned_role.title : target.special_role]."
+ explanation_text = "Убейте [target.name], [!target_role_type ? job_title_ru(target.assigned_role.title) : target.special_role]."
else
message_admins("WARNING! [ADMIN_LOOKUPFLW(owner)] obsessed objectives forged without an obsession!")
explanation_text = "Free Objective"
@@ -179,7 +179,7 @@
..()
old = find_coworker(target)
if(target?.current && old)
- explanation_text = "Murder [target.name], [old]'s coworker."
+ explanation_text = "Убейте [target.name], коллегу [old]."
else
explanation_text = "Free Objective"
@@ -217,7 +217,7 @@
var/datum/antagonist/obsessed/creeper = owner.has_antag_datum(/datum/antagonist/obsessed)
if(target?.current && creeper)
creeper.trauma.attachedobsessedobj = src
- explanation_text = "Spend [DisplayTimeText(timer)] around [target.name] while they're alive."
+ explanation_text = "Проведите [DisplayTimeText(timer)] возле [target.name], пока они живы."
else
explanation_text = "Free Objective"
@@ -235,7 +235,7 @@
hugs_needed = rand(4,6)
var/datum/antagonist/obsessed/creeper = owner.has_antag_datum(/datum/antagonist/obsessed)
if(target?.current && creeper)
- explanation_text = "Hug [target.name] [hugs_needed] times while they're alive."
+ explanation_text = "Обнимите [target.name] [hugs_needed] раз, пока они живы."
else
explanation_text = "Free Objective"
@@ -251,7 +251,7 @@
/datum/objective/polaroid/update_explanation_text()
..()
if(target?.current)
- explanation_text = "Take a photo of [target.name] while they're alive, and keep it in your bag."
+ explanation_text = "Сделайте фото [target.name], пока они живы, и храните фотографию у себя."
else
explanation_text = "Free Objective"
@@ -275,6 +275,6 @@
/datum/objective/steal/heirloom_thief/update_explanation_text()
..()
if(steal_target)
- explanation_text = "Steal [target.name]'s family heirloom, [steal_target] they cherish."
+ explanation_text = "Украдите семейную реликвию, [steal_target], которая чтится у [target.name]."
else
explanation_text = "Free Objective"
diff --git a/code/modules/antagonists/paradox_clone/paradox_clone.dm b/code/modules/antagonists/paradox_clone/paradox_clone.dm
index e809e8cecbf00..b51d02fd7c026 100644
--- a/code/modules/antagonists/paradox_clone/paradox_clone.dm
+++ b/code/modules/antagonists/paradox_clone/paradox_clone.dm
@@ -94,7 +94,7 @@
if(!target?.current)
explanation_text = "Free Objective"
CRASH("WARNING! [ADMIN_LOOKUPFLW(owner)] paradox clone objectives forged without an original!")
- explanation_text = "Murder and replace [target.name], the [!target_role_type ? target.assigned_role.title : target.special_role]. Remember, your mission is to blend in, do not kill anyone else unless you have to!"
+ explanation_text = "Murder and replace [target.name], [!target_role_type ? job_title_ru(target.assigned_role.title) : target.special_role]. Remember, your mission is to blend in, do not kill anyone else unless you have to!"
///Static bluespace stream used in its ghost poll icon.
/obj/effect/bluespace_stream
diff --git a/code/modules/antagonists/traitor/objectives/assassination.dm b/code/modules/antagonists/traitor/objectives/assassination.dm
index 639ea50eb6c21..0282ff63bde77 100644
--- a/code/modules/antagonists/traitor/objectives/assassination.dm
+++ b/code/modules/antagonists/traitor/objectives/assassination.dm
@@ -158,7 +158,7 @@
var/datum/mind/target_mind = pick(possible_targets)
set_target(target_mind.current)
replace_in_name("%TARGET%", target.real_name)
- replace_in_name("%JOB TITLE%", target_mind.assigned_role.title)
+ replace_in_name("%JOB TITLE%", job_title_ru(target_mind.assigned_role.title))
RegisterSignal(target, COMSIG_LIVING_DEATH, PROC_REF(on_target_death))
return TRUE
diff --git a/code/modules/antagonists/traitor/objectives/demoralise_assault.dm b/code/modules/antagonists/traitor/objectives/demoralise_assault.dm
index 13b87edd6ae73..2914065d7c2d7 100644
--- a/code/modules/antagonists/traitor/objectives/demoralise_assault.dm
+++ b/code/modules/antagonists/traitor/objectives/demoralise_assault.dm
@@ -102,7 +102,7 @@
set_target(target_mind.current)
replace_in_name("%TARGET%", target.real_name)
- replace_in_name("%JOB TITLE%", target_mind.assigned_role.title)
+ replace_in_name("%JOB TITLE%", job_title_ru(target_mind.assigned_role.title))
attacks_required = rand(min_attacks_required, max_attacks_required)
replace_in_name("%COUNT%", attacks_required)
diff --git a/code/modules/antagonists/traitor/objectives/destroy_heirloom.dm b/code/modules/antagonists/traitor/objectives/destroy_heirloom.dm
index b2b44d4c91581..d1172d06bb654 100644
--- a/code/modules/antagonists/traitor/objectives/destroy_heirloom.dm
+++ b/code/modules/antagonists/traitor/objectives/destroy_heirloom.dm
@@ -144,7 +144,7 @@
target_item = quirk.heirloom.resolve()
AddComponent(/datum/component/traitor_objective_register, target_item, succeed_signals = list(COMSIG_QDELETING))
replace_in_name("%TARGET%", target_mind.name)
- replace_in_name("%JOB TITLE%", target_mind.assigned_role.title)
+ replace_in_name("%JOB TITLE%", job_title_ru(target_mind.assigned_role.title))
replace_in_name("%ITEM%", target_item.name)
return TRUE
diff --git a/code/modules/antagonists/traitor/objectives/eyesnatching.dm b/code/modules/antagonists/traitor/objectives/eyesnatching.dm
index c438b62b24e4f..4f3c84999569e 100644
--- a/code/modules/antagonists/traitor/objectives/eyesnatching.dm
+++ b/code/modules/antagonists/traitor/objectives/eyesnatching.dm
@@ -105,7 +105,7 @@
set_target(target_mind.current)
replace_in_name("%TARGET%", target_mind.name)
- replace_in_name("%JOB TITLE%", target_mind.assigned_role.title)
+ replace_in_name("%JOB TITLE%", job_title_ru(target_mind.assigned_role.title))
RegisterSignal(target, COMSIG_CARBON_LOSE_ORGAN, PROC_REF(check_eye_removal))
AddComponent(/datum/component/traitor_objective_register, target, fail_signals = list(COMSIG_QDELETING))
return TRUE
diff --git a/code/modules/antagonists/traitor/objectives/infect.dm b/code/modules/antagonists/traitor/objectives/infect.dm
index 17b2c1da2e74c..43e20215c59ee 100644
--- a/code/modules/antagonists/traitor/objectives/infect.dm
+++ b/code/modules/antagonists/traitor/objectives/infect.dm
@@ -123,7 +123,7 @@
var/datum/mind/target_mind = pick(possible_targets)
set_target(target_mind.current)
replace_in_name("%TARGET%", target.real_name)
- replace_in_name("%JOB TITLE%", target_mind.assigned_role.title)
+ replace_in_name("%JOB TITLE%", job_title_ru(target_mind.assigned_role.title))
RegisterSignal(target, COMSIG_LIVING_DEATH, PROC_REF(on_target_death))
return TRUE
diff --git a/code/modules/antagonists/traitor/objectives/kidnapping.dm b/code/modules/antagonists/traitor/objectives/kidnapping.dm
index ea349b7d10e7e..1a00f8e539346 100644
--- a/code/modules/antagonists/traitor/objectives/kidnapping.dm
+++ b/code/modules/antagonists/traitor/objectives/kidnapping.dm
@@ -169,7 +169,7 @@
dropoff_area = pick(possible_areas)
replace_in_name("%TARGET%", target_mind.name)
- replace_in_name("%JOB TITLE%", target_mind.assigned_role.title)
+ replace_in_name("%JOB TITLE%", job_title_ru(target_mind.assigned_role.title))
replace_in_name("%AREA%", initial(dropoff_area.name))
replace_in_name("%TC%", alive_bonus)
return TRUE
diff --git a/code/modules/jobs/job_types/_job.dm b/code/modules/jobs/job_types/_job.dm
index e78b1703ebe23..fbea013fc5ec6 100644
--- a/code/modules/jobs/job_types/_job.dm
+++ b/code/modules/jobs/job_types/_job.dm
@@ -289,7 +289,7 @@
/datum/job/proc/get_spawn_message_information()
SHOULD_CALL_PARENT(TRUE)
var/list/info = list()
- info += "Ваша роль на станции: [title].\n"
+ info += "Ваша роль на станции: [job_title_ru(title)].\n"
var/related_policy = get_policy(title)
var/radio_info = get_radio_information()
if(related_policy)
diff --git a/code/modules/mob/living/silicon/silicon_say.dm b/code/modules/mob/living/silicon/silicon_say.dm
index 9310211aa0e6d..882105ced5889 100644
--- a/code/modules/mob/living/silicon/silicon_say.dm
+++ b/code/modules/mob/living/silicon/silicon_say.dm
@@ -9,7 +9,7 @@
designation = trim_left(player.designation + " " + player.job)
if(HAS_TRAIT(mind, TRAIT_DISPLAY_JOB_IN_BINARY))
- designation = mind.assigned_role.title
+ designation = job_title_ru(mind.assigned_role.title)
if(isAI(src))
// AIs are loud and ugly
diff --git a/code/modules/mob/mob_helpers.dm b/code/modules/mob/mob_helpers.dm
index a6a1c58c7eddf..d44cc164d7fe5 100644
--- a/code/modules/mob/mob_helpers.dm
+++ b/code/modules/mob/mob_helpers.dm
@@ -365,7 +365,7 @@
message_admins("[key_name_admin(usr)] has offered control of ([ADMIN_LOOKUPFLW(M)]) to ghosts")
var/poll_message = "Do you want to play as [span_danger(M.real_name)]?"
if(M.mind)
- poll_message = "[poll_message] Job: [span_notice(M.mind.assigned_role.title)]."
+ poll_message = "[poll_message] Job: [span_notice(job_title_ru(M.mind.assigned_role.title))]."
if(M.mind.special_role)
poll_message = "[poll_message] Status: [span_boldnotice(M.mind.special_role)]."
else
diff --git a/code/modules/projectiles/projectile/magic.dm b/code/modules/projectiles/projectile/magic.dm
index 23930f3cca7d0..fe3b55281e0ea 100644
--- a/code/modules/projectiles/projectile/magic.dm
+++ b/code/modules/projectiles/projectile/magic.dm
@@ -364,7 +364,7 @@
var/datum/brain_trauma/special/imaginary_friend/trapped_owner/trauma = target.gain_trauma(/datum/brain_trauma/special/imaginary_friend/trapped_owner)
var/poll_message = "Do you want to play as [span_danger(target.real_name)]?"
if(target.mind)
- poll_message = "[poll_message] Job:[span_notice(target.mind.assigned_role.title)]."
+ poll_message = "[poll_message] Job:[span_notice(job_title_ru(target.mind.assigned_role.title))]."
if(target.mind && target.mind.special_role)
poll_message = "[poll_message] Status:[span_boldnotice(target.mind.special_role)]."
else if(target.mind)
diff --git a/icons/_nanomaps/Birdshot Station_nanomap_z1.png b/icons/_nanomaps/Birdshot Station_nanomap_z1.png
index c8452273dc255..03d2d7b2b6404 100644
Binary files a/icons/_nanomaps/Birdshot Station_nanomap_z1.png and b/icons/_nanomaps/Birdshot Station_nanomap_z1.png differ
diff --git a/icons/_nanomaps/Delta Station_nanomap_z1.png b/icons/_nanomaps/Delta Station_nanomap_z1.png
index f6885baa91090..5e77d6fe6cdd8 100644
Binary files a/icons/_nanomaps/Delta Station_nanomap_z1.png and b/icons/_nanomaps/Delta Station_nanomap_z1.png differ
diff --git a/icons/_nanomaps/Ice Box Station_nanomap_z2.png b/icons/_nanomaps/Ice Box Station_nanomap_z2.png
index 3c49ceda94579..347ab214bba9a 100644
Binary files a/icons/_nanomaps/Ice Box Station_nanomap_z2.png and b/icons/_nanomaps/Ice Box Station_nanomap_z2.png differ
diff --git a/icons/_nanomaps/Ice Box Station_nanomap_z3.png b/icons/_nanomaps/Ice Box Station_nanomap_z3.png
index 841350e7a2e98..40dc72e43cb61 100644
Binary files a/icons/_nanomaps/Ice Box Station_nanomap_z3.png and b/icons/_nanomaps/Ice Box Station_nanomap_z3.png differ
diff --git a/icons/_nanomaps/Meta Station_nanomap_z1.png b/icons/_nanomaps/Meta Station_nanomap_z1.png
index 20b2cc6407063..67fb4ed4edc0a 100644
Binary files a/icons/_nanomaps/Meta Station_nanomap_z1.png and b/icons/_nanomaps/Meta Station_nanomap_z1.png differ
diff --git a/icons/_nanomaps/NorthStar_nanomap_z1.png b/icons/_nanomaps/NorthStar_nanomap_z1.png
index d584a3b224c0a..4ef2ba9cee81c 100644
Binary files a/icons/_nanomaps/NorthStar_nanomap_z1.png and b/icons/_nanomaps/NorthStar_nanomap_z1.png differ
diff --git a/icons/_nanomaps/NorthStar_nanomap_z2.png b/icons/_nanomaps/NorthStar_nanomap_z2.png
index 3bc00a5f419e6..04bbf32256e2f 100644
Binary files a/icons/_nanomaps/NorthStar_nanomap_z2.png and b/icons/_nanomaps/NorthStar_nanomap_z2.png differ
diff --git a/icons/_nanomaps/NorthStar_nanomap_z3.png b/icons/_nanomaps/NorthStar_nanomap_z3.png
index f21a86dde97b8..64e55f85ed27f 100644
Binary files a/icons/_nanomaps/NorthStar_nanomap_z3.png and b/icons/_nanomaps/NorthStar_nanomap_z3.png differ
diff --git a/icons/_nanomaps/NorthStar_nanomap_z4.png b/icons/_nanomaps/NorthStar_nanomap_z4.png
index 0012c1914d5cb..5608cac3defa8 100644
Binary files a/icons/_nanomaps/NorthStar_nanomap_z4.png and b/icons/_nanomaps/NorthStar_nanomap_z4.png differ
diff --git a/icons/_nanomaps/Tramstation_nanomap_z1.png b/icons/_nanomaps/Tramstation_nanomap_z1.png
index b75e29c26bedf..a823333a26b89 100644
Binary files a/icons/_nanomaps/Tramstation_nanomap_z1.png and b/icons/_nanomaps/Tramstation_nanomap_z1.png differ
diff --git a/icons/_nanomaps/Tramstation_nanomap_z2.png b/icons/_nanomaps/Tramstation_nanomap_z2.png
index 059cd24ec8c2e..5cc48c959c337 100644
Binary files a/icons/_nanomaps/Tramstation_nanomap_z2.png and b/icons/_nanomaps/Tramstation_nanomap_z2.png differ