From 12b2c15ebc5a844c813addaa232081a3cea68347 Mon Sep 17 00:00:00 2001 From: lzk <124214523+lzk228@users.noreply.github.com> Date: Wed, 27 Sep 2023 19:07:05 +0200 Subject: [PATCH 1/7] Rename dinnerware vendor (#1457) --- .../ru-RU/prototypes/catalog/fills/crates/vending-crates.ftl | 4 ++-- .../ru-RU/ss14-ru/prototypes/catalog/fills/crates/vending.ftl | 4 ++-- .../objects/specific/service/vending_machine_restock.ftl | 4 ++-- .../entities/structures/machines/vending_machines.ftl | 2 +- 4 files changed, 7 insertions(+), 7 deletions(-) diff --git a/Resources/Locale/ru-RU/prototypes/catalog/fills/crates/vending-crates.ftl b/Resources/Locale/ru-RU/prototypes/catalog/fills/crates/vending-crates.ftl index dd5577ef7b5527..76962e83d06551 100644 --- a/Resources/Locale/ru-RU/prototypes/catalog/fills/crates/vending-crates.ftl +++ b/Resources/Locale/ru-RU/prototypes/catalog/fills/crates/vending-crates.ftl @@ -2,8 +2,8 @@ ent-CrateVendingMachineRestockBoozeFilled = ящик пополнения Алк .desc = Содержит набор пополнения торгомата АлкоМат. ent-CrateVendingMachineRestockClothesFilled = ящик пополнения одежды .desc = Содержит несколько наборов пополнения торгоматов, ОдеждоМата и ТеатроШкафа. -ent-CrateVendingMachineRestockDinnerwareFilled = ящик пополнения Кухонно-пластальная поварская утварь - .desc = Содержит набор пополнения торгомата Кухонно-пластальная поварская утварь. +ent-CrateVendingMachineRestockDinnerwareFilled = ящик пополнения ПосудоМат + .desc = Содержит набор пополнения торгомата ПосудоМат. ent-CrateVendingMachineRestockEngineeringFilled = ящик пополнения ИнжеМат .desc = Содержит набор пополнения торгомата ИнжеМат. Он же может пополнить торгомат ТвоИнструменты. ent-CrateVendingMachineRestockGamesFilled = ящик пополнения Безобидные развлечения diff --git a/Resources/Locale/ru-RU/ss14-ru/prototypes/catalog/fills/crates/vending.ftl b/Resources/Locale/ru-RU/ss14-ru/prototypes/catalog/fills/crates/vending.ftl index 831924067947ec..1603c812bb350e 100644 --- a/Resources/Locale/ru-RU/ss14-ru/prototypes/catalog/fills/crates/vending.ftl +++ b/Resources/Locale/ru-RU/ss14-ru/prototypes/catalog/fills/crates/vending.ftl @@ -2,8 +2,8 @@ ent-CrateVendingMachineRestockBoozeFilled = ящик пополнения Алк .desc = Содержит набор пополнения торгомата АлкоМат. ent-CrateVendingMachineRestockClothesFilled = ящик пополнения одежды .desc = Содержит несколько наборов пополнения торгоматов, ОдеждоМата и ТеатроШкафа. -ent-CrateVendingMachineRestockDinnerwareFilled = ящик пополнения Кухонно-пластальная поварская утварь - .desc = Содержит набор пополнения торгомата Кухонно-пластальная поварская утварь. +ent-CrateVendingMachineRestockDinnerwareFilled = ящик пополнения ПосудоМат + .desc = Содержит набор пополнения торгомата ПосудоМат. ent-CrateVendingMachineRestockEngineeringFilled = ящик пополнения ИнжеМат .desc = Содержит набор пополнения торгомата ИнжеМат. Он же может пополнить торгомат ТвоИнструменты. ent-CrateVendingMachineRestockGamesFilled = ящик пополнения Безобидные развлечения diff --git a/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/objects/specific/service/vending_machine_restock.ftl b/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/objects/specific/service/vending_machine_restock.ftl index 8262ae9a58bd99..028dea2950d282 100644 --- a/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/objects/specific/service/vending_machine_restock.ftl +++ b/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/objects/specific/service/vending_machine_restock.ftl @@ -8,8 +8,8 @@ ent-VendingMachineRestockClothes = набор пополнения Одеждо .desc = Пришло время переступить порог моды! Поместите в слот для пополнения ОдеждоМата, чтобы начать. ent-VendingMachineRestockCostumes = набор пополнения ТеатроШкаф .desc = Паноптикум сотрудников Nanotrasen пестрит в красочной трагикомедии. Присоединяйтесь к ним и вы! Загрузите это в ближайший торгомат ТеатроШкаф. -ent-VendingMachineRestockDinnerware = набор пополнения Кухонно-пластальная поварская утварь - .desc = На этой кухне всегда жарко! Поместите в слот для пополнения Кухонно-пластальной поварской утвари, чтобы начать. +ent-VendingMachineRestockDinnerware = набор пополнения ПосудоМат + .desc = На этой кухне всегда жарко! Поместите в слот для пополнения ПосудоМата, чтобы начать. ent-VendingMachineRestockDiscountDans = набор пополнения Дискаунтер Дэна .desc = Коробка, набитая солью и крахмалом. Зачем терпеть качество, когда есть количество? Дискаунтер Дэна! ent-VendingMachineRestockDonut = набор пополнения Пончики Монкинс diff --git a/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/structures/machines/vending_machines.ftl b/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/structures/machines/vending_machines.ftl index 743ff6db15605f..d808fd628b0b22 100644 --- a/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/structures/machines/vending_machines.ftl +++ b/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/structures/machines/vending_machines.ftl @@ -44,7 +44,7 @@ ent-VendingMachineMagivend = МагМазин .desc = Магический торговый автомат. ent-VendingMachineCola = Прохладительные напитки Робаст .desc = Автомат прохладительных напитков, предоставленный компанией Робаст Индастриз, ООО. -ent-VendingMachineDinnerware = Кухонно-пластальная поварская утварь +ent-VendingMachineDinnerware = ПосудоМат .desc = Поставщик оборудования для кухонь и ресторанов. ent-VendingMachineDiscount = Дискаунтер Дэна .desc = Торговый автомат с закусками из печально известной франшизы "Дискаунтер Дэна". From fcd1ca166bd6567d89fd4b4db46057550dd058a4 Mon Sep 17 00:00:00 2001 From: lapatison <100279397+lapatison@users.noreply.github.com> Date: Wed, 27 Sep 2023 20:16:41 +0300 Subject: [PATCH 2/7] Translation fixes (#1463) --- .../components/solution-transfer-component.ftl | 10 +++++----- .../ru-RU/fluids/components/spillable-component.ftl | 4 ++-- .../entities/structures/doors/airlocks/external.ftl | 2 +- .../entities/structures/doors/airlocks/shuttle.ftl | 2 +- Resources/Locale/ru-RU/verbs/verb-system.ftl | 2 +- .../Locale/ru-RU/wieldable/wieldable-component.ftl | 2 +- 6 files changed, 11 insertions(+), 11 deletions(-) diff --git a/Resources/Locale/ru-RU/chemistry/components/solution-transfer-component.ftl b/Resources/Locale/ru-RU/chemistry/components/solution-transfer-component.ftl index 8697ee96ec1165..92241d736713c5 100644 --- a/Resources/Locale/ru-RU/chemistry/components/solution-transfer-component.ftl +++ b/Resources/Locale/ru-RU/chemistry/components/solution-transfer-component.ftl @@ -1,8 +1,8 @@ ### Solution transfer component -comp-solution-transfer-fill-normal = Вы перемещаете { $amount }ед. из { $owner } в { $target }. -comp-solution-transfer-fill-fully = Вы наполняете { $target } до краёв, переместив { $amount }ед. из { $owner }. -comp-solution-transfer-transfer-solution = Вы перемещаете { $amount }ед. в { $target }. +comp-solution-transfer-fill-normal = Вы перемещаете { $amount } ед. из { $owner } в { $target }. +comp-solution-transfer-fill-fully = Вы наполняете { $target } до краёв, переместив { $amount } ед. из { $owner }. +comp-solution-transfer-transfer-solution = Вы перемещаете { $amount } ед. в { $target }. ## Displayed when trying to transfer to a solution, but either the giver is empty or the taker is full @@ -12,8 +12,8 @@ comp-solution-transfer-is-full = { $target } полон! ## Displayed in change transfer amount verb's name comp-solution-transfer-verb-custom-amount = Своё кол-во -comp-solution-transfer-verb-amount = { $amount }ед. +comp-solution-transfer-verb-amount = { $amount } ед. ## Displayed after you successfully change a solution's amount using the BUI -comp-solution-transfer-set-amount = Перемещаемое количество установлено на { $amount }ед. +comp-solution-transfer-set-amount = Перемещаемое количество установлено на { $amount } ед. diff --git a/Resources/Locale/ru-RU/fluids/components/spillable-component.ftl b/Resources/Locale/ru-RU/fluids/components/spillable-component.ftl index 60ee0c64ea53da..46a93cc9659ec3 100644 --- a/Resources/Locale/ru-RU/fluids/components/spillable-component.ftl +++ b/Resources/Locale/ru-RU/fluids/components/spillable-component.ftl @@ -1,9 +1,9 @@ ## SpillTargetVerb -spill-target-verb-get-data-text = Выплеснуть содержимое +spill-target-verb-get-data-text = Выплеснуть spill-target-verb-activate-cannot-drain-message = Вы не можете ничего выплеснуть из { $owner }! spill-target-verb-activate-is-empty-message = В { $owner } пусто! -spill-melee-hit-attacker = Вы выплёскиваете { $amount }ед. содержимого { $spillable } на { $target }! +spill-melee-hit-attacker = Вы выплёскиваете { $amount } ед. содержимого { $spillable } на { $target }! spill-melee-hit-others = { CAPITALIZE($attacker) } выплёскивает содержимое { $spillable } на { $target }! spill-land-spilled-on-other = { CAPITALIZE($spillable) } выплёскивает своё содержимое на { $target }! spill-examine-is-spillable = Этот контейнер можно выплеснуть. diff --git a/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/structures/doors/airlocks/external.ftl b/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/structures/doors/airlocks/external.ftl index 5dc6b8183c4736..b0e0e16cddbdb7 100644 --- a/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/structures/doors/airlocks/external.ftl +++ b/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/structures/doors/airlocks/external.ftl @@ -2,5 +2,5 @@ ent-AirlockExternal = { ent-Airlock } .desc = Он открывается, он закрывается, он может раздавить вас, а за ним лишь космос. Активируется вручную. .suffix = Внешний ent-AirlockExternalGlass = { ent-AirlockExternal } - .suffix = Стеклянный, Внешний + .suffix = Внешний, Стеклянный .desc = { ent-AirlockExternal.desc } diff --git a/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/structures/doors/airlocks/shuttle.ftl b/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/structures/doors/airlocks/shuttle.ftl index 67143c194039da..5c691c963ad3a1 100644 --- a/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/structures/doors/airlocks/shuttle.ftl +++ b/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/structures/doors/airlocks/shuttle.ftl @@ -3,7 +3,7 @@ ent-AirlockShuttle = стыковочный шлюз .suffix = Стыковочный ent-AirlockGlassShuttle = стыковочный шлюз .desc = Необходим для соединения двух космических кораблей вместе. - .suffix = Стеклянный, Стыковочный + .suffix = Стыковочный, Стеклянный ent-AirlockShuttleAssembly = каркас стыковочного шлюза .desc = Незавершенная конструкция, необходимая для соединения двух космических кораблей вместе. .suffix = Стыковочный diff --git a/Resources/Locale/ru-RU/verbs/verb-system.ftl b/Resources/Locale/ru-RU/verbs/verb-system.ftl index b6bdf9f742896c..db0726f501d300 100644 --- a/Resources/Locale/ru-RU/verbs/verb-system.ftl +++ b/Resources/Locale/ru-RU/verbs/verb-system.ftl @@ -16,7 +16,7 @@ verb-categories-unbuckle = Отстегнуть verb-categories-rotate = Повернуть verb-categories-smite = Покарать verb-categories-tricks = Трюки -verb-categories-transfer = Установить значение перемещения +verb-categories-transfer = Перемещаемое кол-во verb-categories-split = Разделить verb-categories-instrument-style = Стиль инструмента verb-categories-channel-select = Каналы diff --git a/Resources/Locale/ru-RU/wieldable/wieldable-component.ftl b/Resources/Locale/ru-RU/wieldable/wieldable-component.ftl index 16e4d6a91c246c..c89710287a2ac9 100644 --- a/Resources/Locale/ru-RU/wieldable/wieldable-component.ftl +++ b/Resources/Locale/ru-RU/wieldable/wieldable-component.ftl @@ -8,7 +8,7 @@ wieldable-component-successful-wield-other = { $user } берёт { $item } в wieldable-component-failed-wield-other = { $user } берёт { $item } в одну руку. wieldable-component-no-hands = Вам не хватает рук! wieldable-component-not-enough-free-hands = - Чтобы использовать { $item } вам понадобится { $number } { $number -> + Чтобы использовать { $item } вам понадобится ещё { $number } { $number -> [one] свободная рука [few] свободные руки *[other] свободных рук From 642b16c0ca18c85630b1fc15c44c58289e02be07 Mon Sep 17 00:00:00 2001 From: Morb <14136326+Morb0@users.noreply.github.com> Date: Thu, 28 Sep 2023 16:31:07 +0300 Subject: [PATCH 3/7] [Resprite] Syndicate airlock (#1466) --- .../Airlocks/Glass/syndicate.rsi/assembly.png | Bin 952 -> 670 bytes .../Glass/syndicate.rsi/bolted_open_unlit.png | Bin 0 -> 157 bytes .../Glass/syndicate.rsi/bolted_unlit.png | Bin 144 -> 196 bytes .../Airlocks/Glass/syndicate.rsi/closed.png | Bin 1238 -> 715 bytes .../Glass/syndicate.rsi/closed_unlit.png | Bin 144 -> 196 bytes .../Airlocks/Glass/syndicate.rsi/closing.png | Bin 2553 -> 1811 bytes .../Glass/syndicate.rsi/closing_unlit.png | Bin 432 -> 578 bytes .../Glass/syndicate.rsi/deny_unlit.png | Bin 321 -> 398 bytes .../syndicate.rsi/emergency_open_unlit.png | Bin 0 -> 156 bytes .../Glass/syndicate.rsi/emergency_unlit.png | Bin 588 -> 197 bytes .../Airlocks/Glass/syndicate.rsi/meta.json | 40 +++++++++--------- .../Airlocks/Glass/syndicate.rsi/open.png | Bin 346 -> 403 bytes .../Glass/syndicate.rsi/open_unlit.png | Bin 0 -> 155 bytes .../Airlocks/Glass/syndicate.rsi/opening.png | Bin 2605 -> 1805 bytes .../Glass/syndicate.rsi/opening_unlit.png | Bin 284 -> 601 bytes .../Glass/syndicate.rsi/panel_closed.png | Bin 0 -> 96 bytes .../Glass/syndicate.rsi/panel_closing.png | Bin 445 -> 323 bytes .../Glass/syndicate.rsi/panel_open.png | Bin 315 -> 210 bytes .../Glass/syndicate.rsi/panel_opening.png | Bin 470 -> 316 bytes .../Airlocks/Glass/syndicate.rsi/sparks.png | Bin 697 -> 897 bytes .../Glass/syndicate.rsi/sparks_broken.png | Bin 183 -> 272 bytes .../Glass/syndicate.rsi/sparks_damaged.png | Bin 184 -> 259 bytes .../Glass/syndicate.rsi/sparks_open.png | Bin 175 -> 226 bytes .../Airlocks/Glass/syndicate.rsi/welded.png | Bin 296 -> 321 bytes .../Standard/syndicate.rsi/assembly.png | Bin 945 -> 663 bytes .../syndicate.rsi/bolted_open_unlit.png | Bin 0 -> 157 bytes .../Standard/syndicate.rsi/bolted_unlit.png | Bin 144 -> 196 bytes .../Standard/syndicate.rsi/closed.png | Bin 503 -> 685 bytes .../Standard/syndicate.rsi/closed_unlit.png | Bin 144 -> 196 bytes .../Standard/syndicate.rsi/closing.png | Bin 1149 -> 1801 bytes .../Standard/syndicate.rsi/closing_unlit.png | Bin 432 -> 578 bytes .../Standard/syndicate.rsi/deny_unlit.png | Bin 321 -> 398 bytes .../syndicate.rsi/emergency_open_unlit.png | Bin 0 -> 156 bytes .../syndicate.rsi/emergency_unlit.png | Bin 588 -> 197 bytes .../Airlocks/Standard/syndicate.rsi/meta.json | 40 +++++++++--------- .../Airlocks/Standard/syndicate.rsi/open.png | Bin 239 -> 380 bytes .../Standard/syndicate.rsi/open_unlit.png | Bin 0 -> 155 bytes .../Standard/syndicate.rsi/opening.png | Bin 1158 -> 1811 bytes .../Standard/syndicate.rsi/opening_unlit.png | Bin 284 -> 601 bytes .../Standard/syndicate.rsi/panel_closed.png | Bin 0 -> 96 bytes .../Standard/syndicate.rsi/panel_closing.png | Bin 445 -> 323 bytes .../Standard/syndicate.rsi/panel_open.png | Bin 315 -> 210 bytes .../Standard/syndicate.rsi/panel_opening.png | Bin 470 -> 316 bytes .../Standard/syndicate.rsi/sparks.png | Bin 697 -> 897 bytes .../Standard/syndicate.rsi/sparks_broken.png | Bin 183 -> 272 bytes .../Standard/syndicate.rsi/sparks_damaged.png | Bin 184 -> 259 bytes .../Standard/syndicate.rsi/sparks_open.png | Bin 175 -> 226 bytes .../Standard/syndicate.rsi/welded.png | Bin 296 -> 321 bytes 48 files changed, 42 insertions(+), 38 deletions(-) create mode 100644 Resources/Textures/Structures/Doors/Airlocks/Glass/syndicate.rsi/bolted_open_unlit.png create mode 100644 Resources/Textures/Structures/Doors/Airlocks/Glass/syndicate.rsi/emergency_open_unlit.png create mode 100644 Resources/Textures/Structures/Doors/Airlocks/Glass/syndicate.rsi/open_unlit.png create mode 100644 Resources/Textures/Structures/Doors/Airlocks/Glass/syndicate.rsi/panel_closed.png create mode 100644 Resources/Textures/Structures/Doors/Airlocks/Standard/syndicate.rsi/bolted_open_unlit.png create mode 100644 Resources/Textures/Structures/Doors/Airlocks/Standard/syndicate.rsi/emergency_open_unlit.png create mode 100644 Resources/Textures/Structures/Doors/Airlocks/Standard/syndicate.rsi/open_unlit.png create mode 100644 Resources/Textures/Structures/Doors/Airlocks/Standard/syndicate.rsi/panel_closed.png diff --git a/Resources/Textures/Structures/Doors/Airlocks/Glass/syndicate.rsi/assembly.png b/Resources/Textures/Structures/Doors/Airlocks/Glass/syndicate.rsi/assembly.png index da1739bb279ebc611aaf6e03d031e6940313bad1..77b917578c551b99c3e3b9efd26355c340a25a45 100644 GIT binary patch delta 646 zcmV;10(t$o2c89xBYyw^b5ch_0Itp)=>Px%SV=@dR9J=0SIutIKo}gCjS`bo3Q>&_ zjw*_jN)V}yh`1sS@J@Mzz5vgFdg!HBIG~){$W)3d)rYo+AS_$Km9nI$j=~|VS#Rvk z+DQX*+MjQ~nH{gz-)ejN?dkaE7^=`8>aqUW*HaAu_V(LTet&#XPL_uNz~*L2SpYEO zp_C#Bf@t)`)fo&@g%<`eNEKG0D9th$dg#`-X96gt83d?daQ90oj)((q+V9|3jDxfV zTO+U2J^d_6S&3R+7)EV_kf?8vzqBy{jJ)xx^&l<1)3Xl%bR-Jqz!Qpy&G6*zmGeUk zHlH;fWg+IlyMMv=Hj5OXzj&d!}0u0CpQY*lp}2&MBP%Mt|<~?1^=Bl$rd(xtwb=EOa1F z{vq1E7X~=Ixzhl^G|j1HSuy)nq2$0a^zA$Cg9Un4FK>`Ld;@< zU<0^u0RV4rhiH8(z#dZ=biM?$3dw~I`ww*MmH*@(SO&7vOExF12i5^;J+MsWql(0O z;QHjaftCye>Su85uSh+v>(3+bTZRl26F21v!d+)j4 zd%eWg@8zCzzH`3cch8^i{Ep`0)zK7WFmi1eHdWO?F7Yk=8GlZmKEp9+-EI#l1Oh?w zO+*7Z4FI4J#>XE*eSKXz07{IJ73Keg?%xThDk)wwESyNfq_#vAg|d${7loEq_E=iM z<#Nh8MTfU++qwFa=LyDs=l~zw*xfnB0FmpJ^BpN`am_zXzW{(%#X-gT&2Zx}AE3vd zV(g)$hAUU=O@EMFj4JwzEd-&~ybrXBy#(aXW~SlzrEv#sGb!}HGhns%n9S=2f#3p& z#pBS?VS!1P6S@=p8VbpcJDSwQOZtj~pnC{8kc%QumB$=H)ekF$)A1PZb8v)=NCVw+!SBP()XHTKDEg|Y8fjrCu zcpO6Cf2oK!`yex5wH_vpF-20~t`)->ToKsWJ)mS0A`%HRbxlKaS4zzVlulOJ1(%5E z49EdzW+58UWIX_Y6bZmLc#1U4TGHuwHV^}IlL0ClcapmB^2j#0v-7sy0EQYP=n8bu zv%eF3p?^3;eD8BcOrfRZ2+!OUw7tQb>@|R)9hUMoz*6SA&gl#^8@fRFb(`9tv3esZ zw&1^(hBLn7Xk&w(QW)f zyO&wPA-4Hr%4z^Pky}e&DflW<+5;W-Q3q33aE>bHB(UUtZK65!8JzkOao4GFo{ zY{K5&BQP=XfRW~q3F3VC95<~>iRgleoJw-^J@)7+V_Oq|Kj4!M!WF^3?nPGh z482?dOI`Z@kRwOmVrX_Bv~j5zcO^cVavTZV{hR^=fWHI5l00OpV=Djv002ovPDHLk FV1l$g!Giz* diff --git a/Resources/Textures/Structures/Doors/Airlocks/Glass/syndicate.rsi/bolted_open_unlit.png b/Resources/Textures/Structures/Doors/Airlocks/Glass/syndicate.rsi/bolted_open_unlit.png new file mode 100644 index 0000000000000000000000000000000000000000..cc49407c5f4ca1d69374f25001381d24ef5a4669 GIT binary patch literal 157 zcmeAS@N?(olHy`uVBq!ia0vp^3LwnE1|*BCs=fdz#^NA%Cx&(BWL^R};hrvzArY-_ z&u!#wFyL{ysIQ&W6f*BXshY>sk1HjWgcY6yY;bldT)*p`T?YjGIVdH!y87<7>wDKd zWK3XKV#>8qyTNI~wSAlkl|{zeS#4ruEE(fU&I%~!@BJeWw1UCY)z4*}Q$iB}=EpYU literal 0 HcmV?d00001 diff --git a/Resources/Textures/Structures/Doors/Airlocks/Glass/syndicate.rsi/bolted_unlit.png b/Resources/Textures/Structures/Doors/Airlocks/Glass/syndicate.rsi/bolted_unlit.png index 6857f2a24154b06497367e4b2474465b750393e2..c6b550c603d94fa07d266b7a57a09358e695fcbd 100644 GIT binary patch delta 168 zcmbQhc!Y6+NGZx^prw85kJqJY5_^B3hFZBv=)W%6d<_NyE*JN&Jh({9EJH=6DY=+^Lq-rITX$xcTZr{Y(&bs=`+rN|X7K3leJLSSu3uB(Sv(LWVsy})2yOqBrw^w<)fWedF4eYDtOE9f< SIJBAp2s~Z=T-G@yGywqX4KOzV diff --git a/Resources/Textures/Structures/Doors/Airlocks/Glass/syndicate.rsi/closed.png b/Resources/Textures/Structures/Doors/Airlocks/Glass/syndicate.rsi/closed.png index 1c0787f2fdd54213dcd092e7da686530b5bccc99..09f222d308187ef37f36ee86ae3af7b35650e5df 100644 GIT binary patch delta 679 zcmV;Y0$Bal3CjhLFn%!h9Qkes}4a7s@h7a1d*VkV!?(L zd_w;vpU@xR8(2i$bPFpsY)X_(6saT877+wY)EW^pM0J40#1qfM6FW^L&dM`4*XQ`; z+P+hG^my+tCJ257(1m@=R>o${Bj*wTpqD;u+eW2Q))oMSx_=pCpp;^t|AEgb98!f_ zvT`%~7e0K>(c9b(1qd+43z>9Y&$Ftnf%+CcbQD8ZPr(35zCO> zm_84u0$kSxkbka$Eb>KQ*DeDnqbCF`s`ylpYXFEBX>qB{NZX%8euZ2E$>LKLV-Wx- zr3eE3Q}DX*Ifu_FfQbW^Wkow+UbrPIX15?n!Xed3O@wF0(raKA2mn0$@e>Z4{sn!_ zcr(YkjBgTWwj(z>~knbY|l?*AYNP{kY$h<`)q>Dt$sryv0A)VHux-%`en zc7Y)G+MTg`c&J5w;+>|(GPE6tlfQ~q-y%i0t{b!81V#>+lAm~|k^Nb#Hx?j6cjYSL zn1J`UE3ru)<|MpXUkeA6V*kr`bOILJK>}_m`+gDkfX_L4tImIN4kY^lUF5Z1c`@yN zU|Ep+fq$YP<JMe00&j8buCe*1-AkQPXR8#zMrhgaC?d$QZ-<@lg|ivMW|W?tWF{ zlmJR;>PnVGES!8=gd6$&fN4?6t5c1qqQZV4ij>PHpJkzI0<%8FvLIZE1n_aeXoA|^ z`@rW<0ET#7+cp;P;Ot{ufPlC>8jVIOsoU)WP#~Z0^W+v5^?5#T?mtJvFC(@NkP`p^ N002ovPDHLkV1kwWKPvzL delta 1206 zcmV;n1WEhL1=b0WFn<69XF*Lt006O%3;baP00009a7bBm000id000id0mpBsWB>pJ zYe_^wR9Hu?mrZC~RTRh1dwG*-n8akp%!Da+!cf!1MH&mCc4fLqT!^Sh3PMpgHG;e1 zqFq=-T7spxw2LY(6rrFCTR}u4C?Yf^pfpv9BgITVrkTmS`F}_z=C$+Dd(OP`=H||O z&5Y>}?%eb4$2tFZKi_D>!^1TYjE;^%B9TB7a=9GkwHj4D5;RSNU@%Db(9jSpE-sQy z0ywy3SyZU&I!sPZLP&Jz4~MA?SR6^+B)?i_oU0 zr)wO%TrN|Chks!hhSLuFuz+?zA1p!}8yl;s!FzjqZL2|{P@ue30T1(mun28rWP~P~ zonpsSDn+(TG#Vubtq9o82ZO$JbmkWPxpzN3bMVEPSh92^=+*B2lwvv^=@W7Cpi*{Q1TKHfqxDEz61L^2DJbDubukn9G0;N zjERr{`K_kjIR5@hYB^9SWUXS+w2C>?^A+XcbR+rCpMmt9q{ZpkSKmHwS2;0BfQp#c z%tk&Ps+R9nFt>}_2K}H9PWWtB5h%h<0KT!ctGn;k=6XJadA+y+4_^zAFDW(QIs%9Y z9u>h;n19g)D$MJeohYf_B;aV zbefXeS%AnRDDnYubpJsW5{`g_f7dSu(P_&{Gc-_21 zMmX3fuEA9>*Yjaj#7k?duwT?i?Y7LvfyaUS%YUG+OJb0cSH693e0*HIl_=chgN20! zs+WB=O#ucMiW}G24#40T6jL^vrDqklMd)lnwC((VfhXkh@-qDP{5*X9@V6%xxWnU4(T$Aeg0(KI9$&@3GZ=y zHGkH?y&_y&%fkje0ocKleqTq7)__rl%=)@rTgP(^2w$h6aabL?ejO%!KA1mTS8yzI z)A8kc4sdX^IrjoZc!4`)aBvV36BF>`(W9DpcRRa4 z##sYXD@nK{=K5)u;8>1Z^oN0%UDAN&TYnrz@>)P&Ao_I054>|%JmWN00+E&2p*^s) zv^0Aymv?+QBXD)!DCO9g3%OsP*5tl`hSH^Mzfzm4EGS z!*Kkmp4je?p@Uw*=h>N8PEv)0GXnT|gr?l!zz zGd8b$|5N$bRLSDt>X&ibpXD+;{VYe?{$nDe3c%5nUqnUq5eNjf{xw6?HK8I0@fv|v zz~K1TOvgWnXs{y;pzaJVGZx^prw85kJqJY5_^B3hFZBv=dK#THg`?T`SQP>r(Z%sqAy^Tcs9qM)FcDNL#Z5}?c0ifI5mXqW!UUzdVTNnXD5M9 OVeoYIb6Mw<&;$Ss4?~v# delta 115 zcmX@YIDv73N=~?^i(^Pc>)W#%IU525njgwUM9!J3&GGJm&ABHw?-X_%dcEh6S4COV z(W_$r;w6O^t&jXxue0i`!q&a^HzS>{>-~I^mb~XzY4K61m&;~<)@J~LI-g6t5m!W* T7FfLd2I70V`njxgN@xNAUmrBB diff --git a/Resources/Textures/Structures/Doors/Airlocks/Glass/syndicate.rsi/closing.png b/Resources/Textures/Structures/Doors/Airlocks/Glass/syndicate.rsi/closing.png index 7894a1f34c3826bfda5f045e2a4db4754926ccbb..002320c6fd74b792ebe23bca8f498453e3ae7614 100644 GIT binary patch literal 1811 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 P00000NkvXXu0mjfIKTVU diff --git a/Resources/Textures/Structures/Doors/Airlocks/Glass/syndicate.rsi/closing_unlit.png b/Resources/Textures/Structures/Doors/Airlocks/Glass/syndicate.rsi/closing_unlit.png index 2a71f76d5d0c792fe84b136920ab32a386dfc7a5..09946a77e6e43f586d750031b818034f862a3853 100644 GIT binary patch literal 578 zcmeAS@N?(olHy`uVBq!ia0vp^4nUm1!3HGP9xZtRq!^2X+?^QKos)S9WdHGWaSW-L z^Y+%>tlI$$M?dbj`!K_Ev$+1fOI{`3at_X#3!4|#*@>G>39$OXc;)PgwaYR-Chd|i zk?21rFDn$tUpP@GUUR|cXcnXI^SX7owVJ?edhb|^Ts5VPmg`4`QJKmC*`L~=O2j!xkZev%)kFVC_8obg7o3} zVn&GvN{SA=-d@JOM|5orgLL{%59e8bIOnA0ZK~Pi;hZxk^|^eL5)fPp4f`m*vEc2x ze_Q?bt?|AdWOljjPHg(>A77p*@mAW;>aDgYUKbE9KKIZ17l%^{tk;@+yR>!6*_b7Y z*Ooutt-oBo+xHOPrtG_ndOQ#ByDb5m5G<`E2m&v47GJ%w)9Teluew=h)=tXZBj>MV zulMaqw~30x+4sKbVJFS17|)e{QZrti_WCcw=E?i-ot%AU&8)jW+ZS{ILCMt6rQYqI zV{7kLzUoUR&i(je0cL#ec*0}-@j8|{(iQzwzWT#=l!&5f jT;0h840aHhFykh_!rG~;5AeP$1@S#y{an^LB{Ts5_a?jl diff --git a/Resources/Textures/Structures/Doors/Airlocks/Glass/syndicate.rsi/deny_unlit.png b/Resources/Textures/Structures/Doors/Airlocks/Glass/syndicate.rsi/deny_unlit.png index 7c56263f83958a17893b3db0b04ce3078c15cea0..6486ac5ca8302bf36350effa9d0444d3dad491b6 100644 GIT binary patch literal 398 zcmeAS@N?(olHy`uVBq!ia0vp^4nUm1!3HGP9xZtRq!^2X+?^QKos)S9WP5nJIEGZr zd3(z+yV*hF*vI4Dx!Zka8cCdaGUwpRM!vsdKWl!9$#R{YvT$=S6PuA`YR=20&1++4 zIq~Y3Kls0092~D zr)R2U?!UWIqJP@7zrPIjFzTH?J@ehF!(Nj<73~WvJ@Mw(*T+ut9WvUq4_yEKcHP{{ z(td~B>+9t&mpd5B>F%Fi+au1;z|f%h`XBoo`DMa)vy?nP#oxYfVLEAvx#`Kz8+VrF zy!dB-pJ^pm<@C_y-%I1p>0isR&&mt)s@2Ub{(9rUU;Q-<+jm49{Tc3Af9AmdW5+JZ zgB;D)TGNnP_=)ie^CNe=1Dh;x;TbZ%z1lzVbEa*5x0l` zFLCLtQfk)goBm*9Wqa5)W5IyH?gg7O+Vq@#{gzqI_j{ICbSF<}<0|vo?Y_6yOll7; z+AsO(r`@v>Kf7}$KR*umYV~i&zP&s*_xJv-=38t1deYzEyLbMqy6^o$Z`IbavsGXD zr!(F8`6z;|L6RYjVFqIYc7~Z}LvrZvRZ(vk567Q>-*~3QX2MKG<^wzo#tdf|3@{iQ zO7s8d*3Gv+{xi?r|HRuDl15mS!8LAhWr_IppL3FmClFnFq60fUCY M)78&qol`;+0G5h<`v3p{ diff --git a/Resources/Textures/Structures/Doors/Airlocks/Glass/syndicate.rsi/emergency_open_unlit.png b/Resources/Textures/Structures/Doors/Airlocks/Glass/syndicate.rsi/emergency_open_unlit.png new file mode 100644 index 0000000000000000000000000000000000000000..e5dfd04206ce4cfbd5675df818602c66b7f0a1c4 GIT binary patch literal 156 zcmeAS@N?(olHy`uVBq!ia0vp^3P9|@!3HF&`%2dVDaPU;cPEB*=VV?2IbohIjv*P1 zZ_gPD9#9ZDaN)qlO^QvD|D~+N`KKQE__`_igzW|GVa_0h!==iT!_->2)9VRbPNkVeoYIb6Mw<&;$UsmQDNs literal 588 zcmV-S0<-;zP)EX>4Tx04R}tkv&MmKpe$iQ?*4Z4t5Z6$WV2$AS$ApR-p(LLaorMgUO{|(4-+r zad8w}3l4rPRvlcNb#-tR1i=pwM<*vm7b)?7X`w}o2gm(*ckglc4iIW3rdb_hfTr7K zG9DAtnN>0H3ISaRVg@5Jvy3@OO2Bh`-NVP%yC~1{KKJM7QL`2Ud?N8IGfbO!gLrDw zHaPDShgm^ZiO-2gO}ZfQBiEG%zj4mHEbz>*nM%$Rhl#~}8!K(h3Z_OpNgPo%o$`fr zgH_I3oV8MgHSft^7|QA^%Uq{9h&UFp1PLM(R8T|-HlnoZq*zGOe$2x^;QA$UDdZ}G zkz)a6Xpmh$_#gc4*2+zcHN#J&iAq7)K38aGjOH1{N)-j{YiSY zrA3Z_-fiIGx}_<5z~v6m|76If>`H!`LM{iqpV2pEfWBLxd#%x1b04Py{D4^000SaNLh0L z01FcU01FcV0GgZ_00007bV*G`2j&6>2?sl(`5Ny4002lyL_t(&-tEhw4S+xZ1i>Rg zVKDSSX1wu5uHqeAsuO21tGLhX=rOL>LR+6 zF2T!a>%uE&(+w2XR%j6x4h}Mc(eCoZguMkU%ZhB<#`8Q3!}!_*n})+m6Uu*fEGiR#`CLO)XS@S8g==Mm!k=XT0000< KMNUMnLSTaV|D$^V delta 307 zcmV-30nGlB1KI+RFn<69XF*Lt006O%3;baP00009a7bBm000id000id0mpBsWB>pF z?@2^KR9Hvtm%R$ZAQXj-OQ0nPEo5`cb9L*B^fmf;fewKdGIY?PX^y!{kdF20;0HJU zWVk1K;!PT@^&(crag=CxxcNWQ;IiiXxDg@yzNao9ZQHu&x_?f{d7f#SA8W0Mmz|w* z1jOb@i7|$HBmhQ4aEQR$hVUYsfSg9GCM-jMQpyc-&TdhC&;;l5np90a(@j2OC|ArY-_ z&#&ffaA07$xRX0~0i*i@CavX6LNboY>sjj9`W4$}J`c;;#63yHbCSwm9fmKDL+ven zojoksT^dU7O;f(~HekQ#zA%Q6+?xeV6TaFW;8kenb&uqVy#%y?!PC{xWt~$(695tj BF#G@j literal 0 HcmV?d00001 diff --git a/Resources/Textures/Structures/Doors/Airlocks/Glass/syndicate.rsi/opening.png b/Resources/Textures/Structures/Doors/Airlocks/Glass/syndicate.rsi/opening.png index 37004d384a21376763da42bff07efd1a08de7d3d..373da01419442806a72c0b066a912fa6ccb5aa7d 100644 GIT binary patch literal 1805 zcmV+o2lDudP)Px*$4Nv%RCt{2T+eURMi_m&a=LLgtA;4srP&Atq(ve~5I{)jr9x_Z>!Cex;1A=( zv4;pz)QWPWm8x7CsRaTOjl@bNR1gt1q(;On5r*{OwRddKXU~jh>`2*n^7_ZTH{XoM zKeFe0ui0_ixrBddv9$Mz-)?=1X&hz@``G(0AO#=?=H6O4-Bk`t&Q$({G!%;XEMGo z4Qxvce?>|6(kTj{G zYMMCS^~yk+2JsO}67hjYW-u&LLlpoV$3ed@J{!x6p68+GIoT%~)&LB8K&@5_p8%?8 zkJTbwjjCYNni|}X$^*JK4eKai3^?ep0N{()Z_spyx4?73i@(|40RY^vs<<)x8Me2# z!=6+dKgPXg?VbOG>-YPZij^bF+w&Y;AME>md>UOz4K*nAfM7Cmar%YOZ0uy`I8Jts z%hKfL71ba$GzTKO_ty5?H*X3NKkhzBY|BEHS4M+y4~UAm8n(g>tBQ8J9qD>HLGkuH z2iIS}uK+-+)!J9pAk_n8EC0CrB%XN^Mif!>g*nH%1&M@k-2y(M~)Z z1d}f-D!l3%GV%ekgCZMQYI`V%?%{a`V;K!$QWOB{bs1X>5nC$DhT?%uT*z>*3(oTs63=In)iSwBAzKtWVkP%iJdET@VVd&2f_foy-C z@5xgT_3D=gmE`lwajIxp4gz5M9U#jJE9xBtNNTZwfi2x=u2L7xyy-2ad-4>ry?Ovx zxO64Kt3w$^-SD!wl- z;$~%>*90epF!H?09|n|?5-Yb_ac*9dTL++`1t0>z3iRHbAk5@xZ)(w`0h!*k|Fj4s|ufE922mC^Vpw5;TT`yp|UjJ4?-D%C^PsL z06hKk))D|RE1U;eb~P|;0Mp>{hrYld2*wHHl?PyiTSN=MJOxac6Iot;kP#}v7@_zr zAlsjpwWegfdLDlsJ4{B41!Vj4d{3T&yjRcTm*Z5|VgbPS-+h}nAmhnX$nxrgvIBk{ zoHAN|`uVoFJ+8|VkC#iGE5eyqi#=gS1E9;37Zt_|G|f%vh^-IM|QNPnJ(GWjiF=+Eo-&B#dK?ct9itvlwt%uR3P4%J2j!0wr3B!hR30etKSKxQe?yV= z0j4b}Dj8C**Nt;iIwI=>^my_VXs_P;P%+F+>!4p;#2;KAPj(m$E6 viuL(3gS9}u6Wo8>Pw?^V@gj8C6E^+_`}xoY91D`800000NkvXXu0mjfL=;Ve literal 2605 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 P00000NkvXXu0mjf$)Ebt diff --git a/Resources/Textures/Structures/Doors/Airlocks/Glass/syndicate.rsi/opening_unlit.png b/Resources/Textures/Structures/Doors/Airlocks/Glass/syndicate.rsi/opening_unlit.png index 84933bd5ed9cd40a972aee792b227f9aec95f233..d50675650ce76c08ea3a9f8e4ddfe45a389a547c 100644 GIT binary patch literal 601 zcmV-f0;c_mP)Px%6G=otRCt{2+&^#HKpe*LuWiKG$ukR!x2U$dH7|gnLzRIcuaAMD%FuxqkZj0Q zO!2~EWvS$$%82;W0Zd%?NXW@&BJq3{rn}!G8!VrHhe1R{L_|d70(q_`{=QAV0&H0K z0DOWR;Lb}QT-CJ6&~X_c9mn_ms|f&$`G90NyLMU6CWEsBuwmWnUrqQFg|`5GCZi2u z&s9C!41Sw|J|braz$eHT^8wFUF?!C5(PBP0{07@{N`{NS2#Sb^h{&Zn+zNl&CSeys zfX)8X#D@Z43B^w@EzUW%%66W^a<~iOigo;J{AE5Tnwm#ML_|bH4UTX)y)T?i`Rcy$Tqx}Kx9RO3W{#?o|po^gP35bY@h+HfWUTzKR-s;I8 zb84@?ycMn1x2e-)wYJJ<9mRWYs1IjgeT@uZ52w1)| z$P$VUL7og}*RTIa;E8&D+nRP+o|-5jA|fIpA|fIpA|fIpBJ%Nh05{ttg64Yi$JBfE z<^F)1Z4$YzZOZY(OEVu}I*uP#tmE!0n;Du=_UfnO__4YtppDw59I$_%;O-@Z&GqDu n`M+1c>(BcHx$D}d8~}d-!jgGu-aMRW00000NkvXXu0mjf!dW4O literal 284 zcmeAS@N?(olHy`uVBq!ia0vp^2|(X)s_s z#KIwr!I-V$V11^#dUpKLjjy-9DY|#Kuw+Jjzzl{&rWQ^CH3uAwt;hGhNWR~>|B3$l qhyP2a-~C|qG6v`^C}^l(vC57yE3)EC^YOwKkf5ilpUXO@geCx+nr^EA diff --git a/Resources/Textures/Structures/Doors/Airlocks/Glass/syndicate.rsi/panel_closed.png b/Resources/Textures/Structures/Doors/Airlocks/Glass/syndicate.rsi/panel_closed.png new file mode 100644 index 0000000000000000000000000000000000000000..7244b37f5c785d78eee7767f9a4aa6bef3263b07 GIT binary patch literal 96 zcmeAS@N?(olHy`uVBq!ia0vp^3LwnE1|*BCs=fdz#^NA%Cx&(BWL^R}Ql2i3ArY-_ n4>B?Wc})uc*XMaSfSB*u1QZw;-5D2j067evu6{1-oD!M!(o^&?k4d<-P8u`Wf#+^>dYJo3Ks;>CRVBvCrMUp`i@$>j=SeS){?XD_A)M?{pa^>t4QWuDg6Hgfo_&qlD{NvPB$lqtv|?Y MPgg&ebxsLQ07#95K>z>% literal 445 zcmeAS@N?(olHy`uVBq!ia0vp^2|(qk=b{5eiK-()1~xQ&@cMV`(mao8yQ?TZq;#^Y}m${ zacWZ!Yev-i>$j948lYsxftl|YY`yljZkp{(pFL*+-lj#WWzI6YweB*{ESZG)8eLCP zH-4D=_wruJUKQWqugks*3w-~bxAmsS_S>R@6K&4#1!`fty>^f8^xkc+O+xqazTJA; z{=7~2>uGDRIhyR%SJ)ONH}BrkKUz=f@~-S!d-avVtb5`KJrkcF_ZOUaf4N)v?bouY zpX0AZna`Cr-@$dKByUdGcPkF5{Og%j`&-%%FXZlavSVWw{8-KzzB@7SM0TXvt!o+A zif+H$q2jsc@9*!WwR0M*e5Y<-(ETyu&`qBj{lx9nl5Os{*Qk05m8bu?%XoF&`KQ?? l*%zfe7FQS8+W~`WRsIyAi(3!btSA5lf~TvW%Q~loCIEIM%9sEE diff --git a/Resources/Textures/Structures/Doors/Airlocks/Glass/syndicate.rsi/panel_open.png b/Resources/Textures/Structures/Doors/Airlocks/Glass/syndicate.rsi/panel_open.png index 24eb2aedc2248aeb772b38f63ff992254e7aaec0..49e318c243ce17b022f9ac568ea12dd2e987c2c5 100644 GIT binary patch delta 183 zcmdnZbcu0-ay+Lhm;c&_*R9t# zbZSU*xIf|P|5dzi{(t3-{HMJ6;?;{LEGi<8C3dX2D**%s68mKD9{up>pHh#2#0M7( iF1LdkV7qxN7#RHg^ky$qi>U`XjKR~@&t;ucLK6U_Xi3Ka delta 289 zcmV++0p9-70lNZ_BYyz`Nkl&w1%H06;bx zeV@A>Z5$8!UIWaG;pzFE_Os%#P{eipy8)C^td>UrR?8zzmig2TF~-QcP%^!VWL+q^ zjUxFu|~ZR^!J;C?(7YpnpB+JN_8aJ5*FY&KYHrP{> nl?SD|O`I*n*&5`5z@O#|ruj(R?nWe}00000NkvXXu0mjfBE^G; diff --git a/Resources/Textures/Structures/Doors/Airlocks/Glass/syndicate.rsi/panel_opening.png b/Resources/Textures/Structures/Doors/Airlocks/Glass/syndicate.rsi/panel_opening.png index fc90acd637a6369812fc809489dd2961fe64b1ca..a0f494310cffae872231d4d1bd8d3a3fe6351ea6 100644 GIT binary patch literal 316 zcmeAS@N?(olHy`uVBq!ia0vp^4nUm1!3HGP9xZtRq!^2X+?^QKos)S9L76$Jc_$X}Q;HFPof9`=@%?bJfGiFBSFl<|iB3)>u6M zGMUFyI-oZ_Q2cR6$Biw=Z^+HxWWHcK&*`fx_U^OHoxVEo_rEzcAM}k?au3u59=};B zDk!MG{dPsojg|M9=S5)BM)RR{Gvx8^n{t%B;GBSVgdELKP z|JH413wa!Q@2Av-jjQj!zqZ#jVc&}6{n6rfj$plDqT&Aw(XUo>y1xc3X8{R#y85}S Ib4q9e01|J5XaE2J literal 470 zcmeAS@N?(olHy`uVBq!ia0vp^2|(R_5RoDx&OEP+E*gAHf&mPbH>ZE8FCH9e&*rpCoP%1 zIy_fR`1DT4EhW}ImG2+Fy>#^EcBOlIu{N4r8M|lHdv8DdMa^XX`Q)41s%D;5@l3t_ z>U!DiCu(!NfiicFek|lsbn*16WPNgF)9u86nlDcO+<9uZb*sRm>zlTKo#3wDtk_cV zGUiQg0fX*;t18(yxo?DbZh3Nv5#oCg`Gddm{r7*~nV;{o)~0;#=kiD}oLj`YgzrYV zCx61j+EYJuRBRcZ$AIaEWtlPx&J4r-ARCt{2+&ydCKo|$`za-a5XrWNN*m;G330>MqbW@;%$CM@+Txx|b387!2 zQ@%yX7!lGTHMAd~t-TdHWGNwF2oAOvjV)xE zL9qs4YWY|LE&?G&gRBeELiWHB+vQH)?N=_=00<%w;q5r-Fq#`x6IRP`*I5G_RrB&X zAWeAK%RCJhxn(bM%jWGOf6gD5#I~&ZNs#gz5hVLwh#R6rG~%|R;1fa!iI$k` zFn^lMAl=RFv;H}L=oe{ioWj#SwY@?2P0aiNq%Z@fPn-;oyZY=XjEBAb@V|LryDbd; zJaUj?O#szF_f6;s(9OODbyf#(#R&MfeF-6i5JCtcBo?aQ8vEM|+)|zfMT$&DT|#*M zfO04AE@c~YQr8a<(N{G`ptfyRtd`+gEyJDsazC<+l-K7~oCXa3#Hw9KZPa((=+juW z>vGo*2zFZKN)qKx-W6*JM6Dxm?Ew(OUUWJb2$?A=v3|fhYrtw5?nc$bQnoP{E*IO8 zQMrH$@aIKPTmXUIMO0!Jo+qTD?tY(d4b}G|>Kl-dHV{GxAqkV1>@ck#K7E0M--(oM3v-T6o|50rvB z?(X|$_9K~q!b>Jme`5^XKVF&j%`2QtMsN-@c!MQ;uYX{&xPXV-MV4h*a7^*H)mTo% z^duKBlw8QrI7#Az6a!+!k42gRM*{jVXw(2^)BtAG0A@rO5W6r+TTo*dR0c>itn&u= ziYhf*#29dhKzXbye)sb`x`T#9jF|@skRQx^J~1)&r}u;k?=m8#VH_qLszE1c7I|*U z-vi17+kNaSpCz%9yQ#rS&sN2x0`#dRVZ$Zo3 z(YozxD(tDJ*Nd^#9ngM11*`#hZL|qqUX-aA#5S}G^!n=WLLU@GQ4~c{6dSK|xP5Tx z!-H@vnhtn%y49-Lc3NyR!WG{&^FjpmIbAy+o5nPrx)V}}E%fz`bB+BtcI@^)8^rTf zBx((Ky3EXU1aLM2IGxVm^KA+58-UdY;QHA(FXNaPN!aD?zV8}<6&DioA6qwm%&S`B zG(?rf)v;@BC^IYu=$f%ZGhhqXw5SF!qXsa;V!%*uXSl{qZh&O*G5ePMUQntINQ83i z$upoRb}H)fv5TKDu*ZP$-hvmY3!Atq6ENBh(WYFFM67|7l05p#?E1nmayZKasmvEs z4%uF#@2=U$hCc&#<3^>qaoRUjD5t(Q@!@5>eLn%YPa&y@Wk6F&Jf;Amr=S&p`TF~H zKQmyzZBbK@-3j_NfaCqFrZteLVgLD`ViBgsl+FQ!832*%0DhkaTq4i015y-4Q4~c{ f6h%=KHvsSpwHV1KmpgiI00000NkvXXu0mjf++aJ5 diff --git a/Resources/Textures/Structures/Doors/Airlocks/Glass/syndicate.rsi/sparks_broken.png b/Resources/Textures/Structures/Doors/Airlocks/Glass/syndicate.rsi/sparks_broken.png index fb5d774588ae44eab5608571cb6aafad7375e158..ad6e6cbae401ad7ea80138e3aaaffa0ce4d77e31 100644 GIT binary patch delta 257 zcmdnaIDu(`czpr~8v_HwqZ#EEK#H+A$lZxy-8q?;K+Y*o7srr_Id5+p@*P&-VGXzz zw?X~QL94G)DM^l!+WSQJo2NcbmYj01hY_flf&bIrJ!w|Vb5*Sh{@wfh&RTcY(jY~@ zh~K%t7$4B4qc3QRPg67AVm3M!M w`Z;a-A^Oe!*okrl$Ix8?!b~6sA;6!5taYY~7z^f{2nPvzy85}Sb4q9e0KG+NhyVZp delta 168 zcmbQhw4HH+c)bH7GXn#|{a+7!ffQSSPlzj!{{P?DoLkTh$YLxB@(X5gcy=QV$cguK zaSV}=e0$K4ugO7x;lRza6LVH%{NeY1{4(zemy^z$Ed|Hcd%ssHO22$clb_{UbJ4~O z=0q+Yov59jOZM|G)%1~O%W_wo5M{OY7ISx5#_s8%irPFpx)V5ZcX&?GuVngui&@}X S-79yXT@0SCelF{r5}E-1&^%}W diff --git a/Resources/Textures/Structures/Doors/Airlocks/Glass/syndicate.rsi/sparks_damaged.png b/Resources/Textures/Structures/Doors/Airlocks/Glass/syndicate.rsi/sparks_damaged.png index f16a028dee5bbe41a7f4e35f686043e8a112ce4e..695b8f38751a7c56bb0332b96f1d84301cfefd82 100644 GIT binary patch literal 259 zcmeAS@N?(olHy`uVBq!ia0vp^4nUm1!3HGP9xZtRq!^2X+?^QKos)S9G4{rzpz`ks5R zc8Kj0TlDhL_0ls<+m>BecJBCnMo!+|^)G6iL2hGUxS_C1`a}Jn)bAqiq~t4wq~UYF}^n1GcxvX& dN}IerjGt7Q1>7HnEC$-e;OXk;vd$@?2>`@EK-2&L diff --git a/Resources/Textures/Structures/Doors/Airlocks/Glass/syndicate.rsi/sparks_open.png b/Resources/Textures/Structures/Doors/Airlocks/Glass/syndicate.rsi/sparks_open.png index 630eabb976ecf11fa59ba29f03502b02bde399aa..fb8ba8d034ce6c5609043f1303ca6f2387f04671 100644 GIT binary patch literal 226 zcmeAS@N?(olHy`uVBq!ia0vp^4nUm1!3HGP9xZtRq!^2X+?^QKos)S9aO`53>y@>X S#eB6ZNTsK%pUXO@geCx&TTm?k literal 175 zcmeAS@N?(olHy`uVBq!ia0vp^2|(0onej0>J{1B!2;OQb$4nuFf3k0002{NklP9E9_SUA24GbPz9?-y&kZm-0lQ2U=+nk21Bj3rpx=Sh0Kk3) sg#kq9|C+GYx*w>j+Y9b5@GK&L7oS37kyCv}u>b%707*qoM6N<$f_#mD^#A|> delta 269 zcmV+o0rLLA0;mFzB!BNoL_t(|oYj{x4udcZMSrVqOqdNM7B0XLHfHbKA-84W0I;(J zCJ!O_N2;HSWO<%5b^zoJEX!gGaL3n-QrC61fn;4*wm#k_G(h}n TBOLz#0000Px%QAtEWR9J<@SJ7(QFcdv5${H^%gfhor z3WW_e7=hN%AK1(OW1q0U8fBlbm(uq^RtSaUA$##i;t&+5nvQzQ9y~j;BFVDjvI7R) zEBT(Idu2&>&dx73>-#lq;XZeB_RaTi4gj2;Uu;BwQOqIWHl=4&mc3t8qkjh_lk6-EJFtkFr)2$64DW zB(puTrOgRQ$xQ?{0%eGVG7e;id3MzyW<#`hqy^KtG0;`>SuKJBw}o3MG9Y5m?O@RD z)IuniAzh?e0e^#T2f=iXU^?Ghgq(g6S^*+)QCW2G2+1DNwh|zVs2gckj3p>5Lf-wN zm?@#Ve9}{ z%>V%JAC?GyHZWLoczpK?MjPsjPFl+A-ch+l_!KBz0vV>S!qiu|6+blsxAlJoDDMN5 z(n@!}eRz;t1DtbEN)d+PUO~m%udb~WAc|1=>m=7+O3RR`AkI$LPVL)NK&#cVCeW>s zqF*r`2mr*t9qSkTZV$8BO!D60v;Vrf0APD&_xt^wLBrt?fO$`^8po;fdtUXIT#f?( Ze*whEEp6tI81(=E002ovPDHLkV1m` z#fZPC4gi$H^z>6`ZMCEwpoY=2iqcK!|1CmeRb|eykeGy7p-PhpbscG26awuWb##Ht z<;<%T72X@&&-yQ3i=6z_3CX#s2P>)$qOEt%Poyni&c7_Y0e~*mMU|#qaO=6`pvRZu zA=nekVP3oz0v{pDt~jGJRMZL#*__X{xCX)EXi zf;kY2$Dyak0kbYA^ovpssqwa&8gN*oysm%c70G4pr82Tc?gZUKXaj9glxT?nWcENY z=4wg-{yqMIGa!XIB=RZ9mf;%R9I%_}$aic&3fRr)Hh(uqNfy(?0nA}C({=@=@m2m5 zD$B&INeU>zI)KL^`16+rfAt56!0_;Cq8Ljg1?D^(f3pYjAsh~I5<^=@UrNgblrC2K zf)yeffqcNoL?dB??hXK?hy&j7^JHMzkuJx}{utN}n4!UXi1g)`hu&akXTIAE=H_-V zmKkC2cz-W=gK-FZKNrm~g+PrXJS%fx|A;r)2LN+7BuaKbB6D3AH3A*xK9GOiop!J` zRg*S`-{+arJ^vIW0=~!w)K#>A@!|cnSG9W~AtNaVZHH4Dbo~>^G0eAcypF%C#?H#h z?W1kYG9cAagcVya)YmtV{_V*L=@`;FkWI@pm490eGRPD*WL%2ZF&b{FH4>`yzadew zc8j8EBqS8&rYhMu|C{+_g;loP$;_AAUjkSOGa&weq$cPGou;Q9}<-eB$3C74i zDbel?o^WK#d@*%4fHu*#Kwl~NDk`)G9F}Un(pO9A#eVlN{cKqo3n`N^2W z(SKG8%&)DhD$NG2SyjkCz6a12wafMZ9Z&+EVWefwz$%lf@d3MOH(8Spa$7l@aA@cZ z%*;IDs5xYuxHPbb_0>4x<+}+^MkzV!o_h9@ljS(z^Lz6;;R>b|I|FfWukjJM{&tJo yBTB|mcQy=1PL8rtjJpz_OvME5e#XE6;1v(J^q0vPSXkQt0000sk1HjWgcY6yY;bldT)*p`T?YjGIVdH!y87<7>wDKd zWK3XKV#>8qyTNI~wSAlkl|{zeS#4ruEE(fU&I%~!@BJeWw1UCY)z4*}Q$iB}=EpYU literal 0 HcmV?d00001 diff --git a/Resources/Textures/Structures/Doors/Airlocks/Standard/syndicate.rsi/bolted_unlit.png b/Resources/Textures/Structures/Doors/Airlocks/Standard/syndicate.rsi/bolted_unlit.png index 6857f2a24154b06497367e4b2474465b750393e2..c6b550c603d94fa07d266b7a57a09358e695fcbd 100644 GIT binary patch delta 168 zcmbQhc!Y6+NGZx^prw85kJqJY5_^B3hFZBv=)W%6d<_NyE*JN&Jh({9EJH=6DY=+^Lq-rITX$xcTZr{Y(&bs=`+rN|X7K3leJLSSu3uB(Sv(LWVsy})2yOqBrw^w<)fWedF4eYDtOE9f< SIJBAp2s~Z=T-G@yGywqX4KOzV diff --git a/Resources/Textures/Structures/Doors/Airlocks/Standard/syndicate.rsi/closed.png b/Resources/Textures/Structures/Doors/Airlocks/Standard/syndicate.rsi/closed.png index a71632a1732a2c29e49c42558bcad4517e05c02d..a00bd64698e0ae5f05fc042b4b9b7dcb384641ad 100644 GIT binary patch delta 672 zcmV;R0$=_21FZ#+8Gi-<0047(dh`GQ00DDSM?wIu&K&6g00L)8L_t(og|(N@ixV*v z$GYrF1b+b7Rg54A(CM^m0{|&E z=NybNT!=r21w%->phvAr%hhF!SO`p?o}~bpIOiS!6%KxFYkx~@4U93Taktwo{But} z#X`vEkP!JE65XW{Aah=J;0I`OSX2`Lw%aX|L{FS5=e|;-k-uL9xQzg%6o8%s!)RUE z>Br+cI|B`aHh+LNrWt@M`NsWTEhwAR902qrZMuxd{T_zV8pCKUL3~sUe^E{V)v-?m zLPF$EeK!Iy#!5+OgE)j@ArK3e1GHK#1c7;LRYzY1QQZAv!Hhp3Tbk*fQN2j9`xMj_ z0f0B(e<0-f6pVOAn~jWQ>-f}YGk^Y>uKy%S&_zWATyy?5S^&ho zS-p7v3;-~jFOBWaRbbLES|F_Hd^TTVHeX7Ry#b2ON2Cc#sTO`8Ig?NoW6aCBI&#|- zcmb%YJ93+24dB!Lj^0VdQTyT1L;20cw>8EI*H%y_dSpIdvU4C70@DZKZb^7Z5g@Gx z0C*=+Re$MK)mEz>_@DBw2M#S~JwPd~UGwcL<1*x&gHnpsYUSObTK(FdO8|_q(vh4& znBewxo+sgH3Sg@Td~-t`o$Wb?D%1n*w$HUpzZbZ!VkTu#kpSX%!>fan{uAKq7Xa6I ze{$vx@bdFQ2gsBi9)rQ4WHgyf0ND5UU2GeNx*4ADYWoip5IwMJ1*q@<0000lB4lG@92^`FiwY953T6TVr3VLDSy?C}B<8eZCVv0`010qNS#tmY3ljhU z3ljkVnw%H_00A;dL_t(IPo0zNmVz)0giE0!EjM8=`2H`tGf9wAJ?@^JA3bLBnWmaJ z=PK{(x_MUZeT6jgAza#P*LBzS5}Fu~Ado;l?!qSknMg=JQ8{2njNVDUr^Ha;FoM$% zrvXAFG3XG`yng{Hkq|%#1sE9+Gl15wKs*EJ_&or<2KZJ)A>>VlyaEWVa6Hp207D$bn`3_*?|AmT`qP$phB1 zqJ%VQSCl<0>({qdD6bGgdf2iaC5lNH(__OYRsUV>O z<;byu5ek$;3qT2*^7GhpOq>UB?1=yzJPPxJ#i=}Ns9=jrX+Sl9L e!WY8&JNE-FKq$`1vsQlq0000GZx^prw85kJqJY5_^B3hFZBv=dK#THg`?T`SQP>r(Z%sqAy^Tcs9qM)FcDNL#Z5}?c0ifI5mXqW!UUzdVTNnXD5M9 OVeoYIb6Mw<&;$Ss4?~v# delta 115 zcmX@YIDv73N=~?^i(^Pc>)W#%IU525njgwUM9!J3&GGJm&ABHw?-X_%dcEh6S4COV z(W_$r;w6O^t&jXxue0i`!q&a^HzS>{>-~I^mb~XzY4K61m&;~<)@J~LI-g6t5m!W* T7FfLd2I70V`njxgN@xNAUmrBB diff --git a/Resources/Textures/Structures/Doors/Airlocks/Standard/syndicate.rsi/closing.png b/Resources/Textures/Structures/Doors/Airlocks/Standard/syndicate.rsi/closing.png index 2c5ddab0b8f38a3b1c5878f97eaee24edde3b1aa..f3b542e4a51c1c008e23b7c775401d4ec9faaa1c 100644 GIT binary patch literal 1801 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 diff --git a/Resources/Textures/Structures/Doors/Airlocks/Standard/syndicate.rsi/deny_unlit.png b/Resources/Textures/Structures/Doors/Airlocks/Standard/syndicate.rsi/deny_unlit.png index 7c56263f83958a17893b3db0b04ce3078c15cea0..6486ac5ca8302bf36350effa9d0444d3dad491b6 100644 GIT binary patch literal 398 zcmeAS@N?(olHy`uVBq!ia0vp^4nUm1!3HGP9xZtRq!^2X+?^QKos)S9WP5nJIEGZr zd3(z+yV*hF*vI4Dx!Zka8cCdaGUwpRM!vsdKWl!9$#R{YvT$=S6PuA`YR=20&1++4 zIq~Y3Kls0092~D zr)R2U?!UWIqJP@7zrPIjFzTH?J@ehF!(Nj<73~WvJ@Mw(*T+ut9WvUq4_yEKcHP{{ z(td~B>+9t&mpd5B>F%Fi+au1;z|f%h`XBoo`DMa)vy?nP#oxYfVLEAvx#`Kz8+VrF zy!dB-pJ^pm<@C_y-%I1p>0isR&&mt)s@2Ub{(9rUU;Q-<+jm49{Tc3Af9AmdW5+JZ zgB;D)TGNnP_=)ie^CNe=1Dh;x;TbZ%z1lzVbEa*5x0l` zFLCLtQfk)goBm*9Wqa5)W5IyH?gg7O+Vq@#{gzqI_j{ICbSF<}<0|vo?Y_6yOll7; z+AsO(r`@v>Kf7}$KR*umYV~i&zP&s*_xJv-=38t1deYzEyLbMqy6^o$Z`IbavsGXD zr!(F8`6z;|L6RYjVFqIYc7~Z}LvrZvRZ(vk567Q>-*~3QX2MKG<^wzo#tdf|3@{iQ zO7s8d*3Gv+{xi?r|HRuDl15mS!8LAhWr_IppL3FmClFnFq60fUCY M)78&qol`;+0G5h<`v3p{ diff --git a/Resources/Textures/Structures/Doors/Airlocks/Standard/syndicate.rsi/emergency_open_unlit.png b/Resources/Textures/Structures/Doors/Airlocks/Standard/syndicate.rsi/emergency_open_unlit.png new file mode 100644 index 0000000000000000000000000000000000000000..e5dfd04206ce4cfbd5675df818602c66b7f0a1c4 GIT binary patch literal 156 zcmeAS@N?(olHy`uVBq!ia0vp^3P9|@!3HF&`%2dVDaPU;cPEB*=VV?2IbohIjv*P1 zZ_gPD9#9ZDaN)qlO^QvD|D~+N`KKQE__`_igzW|GVa_0h!==iT!_->2)9VRbPNkVeoYIb6Mw<&;$UsmQDNs literal 588 zcmV-S0<-;zP)EX>4Tx04R}tkv&MmKpe$iQ?*4Z4t5Z6$WV2$AS$ApR-p(LLaorMgUO{|(4-+r zad8w}3l4rPRvlcNb#-tR1i=pwM<*vm7b)?7X`w}o2gm(*ckglc4iIW3rdb_hfTr7K zG9DAtnN>0H3ISaRVg@5Jvy3@OO2Bh`-NVP%yC~1{KKJM7QL`2Ud?N8IGfbO!gLrDw zHaPDShgm^ZiO-2gO}ZfQBiEG%zj4mHEbz>*nM%$Rhl#~}8!K(h3Z_OpNgPo%o$`fr zgH_I3oV8MgHSft^7|QA^%Uq{9h&UFp1PLM(R8T|-HlnoZq*zGOe$2x^;QA$UDdZ}G zkz)a6Xpmh$_#gc4*2+zcHN#J&iAq7)K38aGjOH1{N)-j{YiSY zrA3Z_-fiIGx}_<5z~v6m|76If>`H!`LM{iqpV2pEfWBLxd#%x1b04Py{D4^000SaNLh0L z01FcU01FcV0GgZ_00007bV*G`2j&6>2?sl(`5Ny4002lyL_t(&-tEhw4S+xZ1i>Rg zVKDSSX84G50T+mHZ~0g;1yiQZ*q?wr3*Wbe+EM za=G?z?d0?B9|RaS?_aVXD8gCb5n0T@z@GrZj8zq` zy+FYbPZ!4!3;(B=9k~t|aJXEQ&klcI|CCSlwAD=yjw`VrIF*GS=z04}@VUgauwP`# zYGg62@tMhd!01VlueJUJzLYfP7bgO^RpLzU%P;*oKc<-Z!+m+VidaEY_UZzV1q`09 KelF{r5}E*hgh%KA diff --git a/Resources/Textures/Structures/Doors/Airlocks/Standard/syndicate.rsi/open_unlit.png b/Resources/Textures/Structures/Doors/Airlocks/Standard/syndicate.rsi/open_unlit.png new file mode 100644 index 0000000000000000000000000000000000000000..4c03a217b742f416fe2fc6da602c24a6475bfd94 GIT binary patch literal 155 zcmeAS@N?(olHy`uVBq!ia0vp^3LwnE1|*BCs=fdz#^NA%Cx&(BWL^R}p`I>|ArY-_ z&#&ffaA07$xRX0~0i*i@CavX6LNboY>sjj9`W4$}J`c;;#63yHbCSwm9fmKDL+ven zojoksT^dU7O;f(~HekQ#zA%Q6+?xeV6TaFW;8kenb&uqVy#%y?!PC{xWt~$(695tj BF#G@j literal 0 HcmV?d00001 diff --git a/Resources/Textures/Structures/Doors/Airlocks/Standard/syndicate.rsi/opening.png b/Resources/Textures/Structures/Doors/Airlocks/Standard/syndicate.rsi/opening.png index 96142da1a64b7bce2cc2d30097689847c96d3680..708de1d80a55adef39647aa71cdd667c3a8046de 100644 GIT binary patch literal 1811 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 diff --git a/Resources/Textures/Structures/Doors/Airlocks/Standard/syndicate.rsi/opening_unlit.png b/Resources/Textures/Structures/Doors/Airlocks/Standard/syndicate.rsi/opening_unlit.png index 84933bd5ed9cd40a972aee792b227f9aec95f233..d50675650ce76c08ea3a9f8e4ddfe45a389a547c 100644 GIT binary patch literal 601 zcmV-f0;c_mP)Px%6G=otRCt{2+&^#HKpe*LuWiKG$ukR!x2U$dH7|gnLzRIcuaAMD%FuxqkZj0Q zO!2~EWvS$$%82;W0Zd%?NXW@&BJq3{rn}!G8!VrHhe1R{L_|d70(q_`{=QAV0&H0K z0DOWR;Lb}QT-CJ6&~X_c9mn_ms|f&$`G90NyLMU6CWEsBuwmWnUrqQFg|`5GCZi2u z&s9C!41Sw|J|braz$eHT^8wFUF?!C5(PBP0{07@{N`{NS2#Sb^h{&Zn+zNl&CSeys zfX)8X#D@Z43B^w@EzUW%%66W^a<~iOigo;J{AE5Tnwm#ML_|bH4UTX)y)T?i`Rcy$Tqx}Kx9RO3W{#?o|po^gP35bY@h+HfWUTzKR-s;I8 zb84@?ycMn1x2e-)wYJJ<9mRWYs1IjgeT@uZ52w1)| z$P$VUL7og}*RTIa;E8&D+nRP+o|-5jA|fIpA|fIpA|fIpBJ%Nh05{ttg64Yi$JBfE z<^F)1Z4$YzZOZY(OEVu}I*uP#tmE!0n;Du=_UfnO__4YtppDw59I$_%;O-@Z&GqDu n`M+1c>(BcHx$D}d8~}d-!jgGu-aMRW00000NkvXXu0mjf!dW4O literal 284 zcmeAS@N?(olHy`uVBq!ia0vp^2|(X)s_s z#KIwr!I-V$V11^#dUpKLjjy-9DY|#Kuw+Jjzzl{&rWQ^CH3uAwt;hGhNWR~>|B3$l qhyP2a-~C|qG6v`^C}^l(vC57yE3)EC^YOwKkf5ilpUXO@geCx+nr^EA diff --git a/Resources/Textures/Structures/Doors/Airlocks/Standard/syndicate.rsi/panel_closed.png b/Resources/Textures/Structures/Doors/Airlocks/Standard/syndicate.rsi/panel_closed.png new file mode 100644 index 0000000000000000000000000000000000000000..7244b37f5c785d78eee7767f9a4aa6bef3263b07 GIT binary patch literal 96 zcmeAS@N?(olHy`uVBq!ia0vp^3LwnE1|*BCs=fdz#^NA%Cx&(BWL^R}Ql2i3ArY-_ n4>B?Wc})uc*XMaSfSB*u1QZw;-5D2j067evu6{1-oD!M!(o^&?k4d<-P8u`Wf#+^>dYJo3Ks;>CRVBvCrMUp`i@$>j=SeS){?XD_A)M?{pa^>t4QWuDg6Hgfo_&qlD{NvPB$lqtv|?Y MPgg&ebxsLQ07#95K>z>% literal 445 zcmeAS@N?(olHy`uVBq!ia0vp^2|(qk=b{5eiK-()1~xQ&@cMV`(mao8yQ?TZq;#^Y}m${ zacWZ!Yev-i>$j948lYsxftl|YY`yljZkp{(pFL*+-lj#WWzI6YweB*{ESZG)8eLCP zH-4D=_wruJUKQWqugks*3w-~bxAmsS_S>R@6K&4#1!`fty>^f8^xkc+O+xqazTJA; z{=7~2>uGDRIhyR%SJ)ONH}BrkKUz=f@~-S!d-avVtb5`KJrkcF_ZOUaf4N)v?bouY zpX0AZna`Cr-@$dKByUdGcPkF5{Og%j`&-%%FXZlavSVWw{8-KzzB@7SM0TXvt!o+A zif+H$q2jsc@9*!WwR0M*e5Y<-(ETyu&`qBj{lx9nl5Os{*Qk05m8bu?%XoF&`KQ?? l*%zfe7FQS8+W~`WRsIyAi(3!btSA5lf~TvW%Q~loCIEIM%9sEE diff --git a/Resources/Textures/Structures/Doors/Airlocks/Standard/syndicate.rsi/panel_open.png b/Resources/Textures/Structures/Doors/Airlocks/Standard/syndicate.rsi/panel_open.png index 24eb2aedc2248aeb772b38f63ff992254e7aaec0..49e318c243ce17b022f9ac568ea12dd2e987c2c5 100644 GIT binary patch delta 183 zcmdnZbcu0-ay+Lhm;c&_*R9t# zbZSU*xIf|P|5dzi{(t3-{HMJ6;?;{LEGi<8C3dX2D**%s68mKD9{up>pHh#2#0M7( iF1LdkV7qxN7#RHg^ky$qi>U`XjKR~@&t;ucLK6U_Xi3Ka delta 289 zcmV++0p9-70lNZ_BYyz`Nkl&w1%H06;bx zeV@A>Z5$8!UIWaG;pzFE_Os%#P{eipy8)C^td>UrR?8zzmig2TF~-QcP%^!VWL+q^ zjUxFu|~ZR^!J;C?(7YpnpB+JN_8aJ5*FY&KYHrP{> nl?SD|O`I*n*&5`5z@O#|ruj(R?nWe}00000NkvXXu0mjfBE^G; diff --git a/Resources/Textures/Structures/Doors/Airlocks/Standard/syndicate.rsi/panel_opening.png b/Resources/Textures/Structures/Doors/Airlocks/Standard/syndicate.rsi/panel_opening.png index fc90acd637a6369812fc809489dd2961fe64b1ca..a0f494310cffae872231d4d1bd8d3a3fe6351ea6 100644 GIT binary patch literal 316 zcmeAS@N?(olHy`uVBq!ia0vp^4nUm1!3HGP9xZtRq!^2X+?^QKos)S9L76$Jc_$X}Q;HFPof9`=@%?bJfGiFBSFl<|iB3)>u6M zGMUFyI-oZ_Q2cR6$Biw=Z^+HxWWHcK&*`fx_U^OHoxVEo_rEzcAM}k?au3u59=};B zDk!MG{dPsojg|M9=S5)BM)RR{Gvx8^n{t%B;GBSVgdELKP z|JH413wa!Q@2Av-jjQj!zqZ#jVc&}6{n6rfj$plDqT&Aw(XUo>y1xc3X8{R#y85}S Ib4q9e01|J5XaE2J literal 470 zcmeAS@N?(olHy`uVBq!ia0vp^2|(R_5RoDx&OEP+E*gAHf&mPbH>ZE8FCH9e&*rpCoP%1 zIy_fR`1DT4EhW}ImG2+Fy>#^EcBOlIu{N4r8M|lHdv8DdMa^XX`Q)41s%D;5@l3t_ z>U!DiCu(!NfiicFek|lsbn*16WPNgF)9u86nlDcO+<9uZb*sRm>zlTKo#3wDtk_cV zGUiQg0fX*;t18(yxo?DbZh3Nv5#oCg`Gddm{r7*~nV;{o)~0;#=kiD}oLj`YgzrYV zCx61j+EYJuRBRcZ$AIaEWtlPx&J4r-ARCt{2+&ydCKo|$`za-a5XrWNN*m;G330>MqbW@;%$CM@+Txx|b387!2 zQ@%yX7!lGTHMAd~t-TdHWGNwF2oAOvjV)xE zL9qs4YWY|LE&?G&gRBeELiWHB+vQH)?N=_=00<%w;q5r-Fq#`x6IRP`*I5G_RrB&X zAWeAK%RCJhxn(bM%jWGOf6gD5#I~&ZNs#gz5hVLwh#R6rG~%|R;1fa!iI$k` zFn^lMAl=RFv;H}L=oe{ioWj#SwY@?2P0aiNq%Z@fPn-;oyZY=XjEBAb@V|LryDbd; zJaUj?O#szF_f6;s(9OODbyf#(#R&MfeF-6i5JCtcBo?aQ8vEM|+)|zfMT$&DT|#*M zfO04AE@c~YQr8a<(N{G`ptfyRtd`+gEyJDsazC<+l-K7~oCXa3#Hw9KZPa((=+juW z>vGo*2zFZKN)qKx-W6*JM6Dxm?Ew(OUUWJb2$?A=v3|fhYrtw5?nc$bQnoP{E*IO8 zQMrH$@aIKPTmXUIMO0!Jo+qTD?tY(d4b}G|>Kl-dHV{GxAqkV1>@ck#K7E0M--(oM3v-T6o|50rvB z?(X|$_9K~q!b>Jme`5^XKVF&j%`2QtMsN-@c!MQ;uYX{&xPXV-MV4h*a7^*H)mTo% z^duKBlw8QrI7#Az6a!+!k42gRM*{jVXw(2^)BtAG0A@rO5W6r+TTo*dR0c>itn&u= ziYhf*#29dhKzXbye)sb`x`T#9jF|@skRQx^J~1)&r}u;k?=m8#VH_qLszE1c7I|*U z-vi17+kNaSpCz%9yQ#rS&sN2x0`#dRVZ$Zo3 z(YozxD(tDJ*Nd^#9ngM11*`#hZL|qqUX-aA#5S}G^!n=WLLU@GQ4~c{6dSK|xP5Tx z!-H@vnhtn%y49-Lc3NyR!WG{&^FjpmIbAy+o5nPrx)V}}E%fz`bB+BtcI@^)8^rTf zBx((Ky3EXU1aLM2IGxVm^KA+58-UdY;QHA(FXNaPN!aD?zV8}<6&DioA6qwm%&S`B zG(?rf)v;@BC^IYu=$f%ZGhhqXw5SF!qXsa;V!%*uXSl{qZh&O*G5ePMUQntINQ83i z$upoRb}H)fv5TKDu*ZP$-hvmY3!Atq6ENBh(WYFFM67|7l05p#?E1nmayZKasmvEs z4%uF#@2=U$hCc&#<3^>qaoRUjD5t(Q@!@5>eLn%YPa&y@Wk6F&Jf;Amr=S&p`TF~H zKQmyzZBbK@-3j_NfaCqFrZteLVgLD`ViBgsl+FQ!832*%0DhkaTq4i015y-4Q4~c{ f6h%=KHvsSpwHV1KmpgiI00000NkvXXu0mjf++aJ5 diff --git a/Resources/Textures/Structures/Doors/Airlocks/Standard/syndicate.rsi/sparks_broken.png b/Resources/Textures/Structures/Doors/Airlocks/Standard/syndicate.rsi/sparks_broken.png index fb5d774588ae44eab5608571cb6aafad7375e158..ad6e6cbae401ad7ea80138e3aaaffa0ce4d77e31 100644 GIT binary patch delta 257 zcmdnaIDu(`czpr~8v_HwqZ#EEK#H+A$lZxy-8q?;K+Y*o7srr_Id5+p@*P&-VGXzz zw?X~QL94G)DM^l!+WSQJo2NcbmYj01hY_flf&bIrJ!w|Vb5*Sh{@wfh&RTcY(jY~@ zh~K%t7$4B4qc3QRPg67AVm3M!M w`Z;a-A^Oe!*okrl$Ix8?!b~6sA;6!5taYY~7z^f{2nPvzy85}Sb4q9e0KG+NhyVZp delta 168 zcmbQhw4HH+c)bH7GXn#|{a+7!ffQSSPlzj!{{P?DoLkTh$YLxB@(X5gcy=QV$cguK zaSV}=e0$K4ugO7x;lRza6LVH%{NeY1{4(zemy^z$Ed|Hcd%ssHO22$clb_{UbJ4~O z=0q+Yov59jOZM|G)%1~O%W_wo5M{OY7ISx5#_s8%irPFpx)V5ZcX&?GuVngui&@}X S-79yXT@0SCelF{r5}E-1&^%}W diff --git a/Resources/Textures/Structures/Doors/Airlocks/Standard/syndicate.rsi/sparks_damaged.png b/Resources/Textures/Structures/Doors/Airlocks/Standard/syndicate.rsi/sparks_damaged.png index f16a028dee5bbe41a7f4e35f686043e8a112ce4e..695b8f38751a7c56bb0332b96f1d84301cfefd82 100644 GIT binary patch literal 259 zcmeAS@N?(olHy`uVBq!ia0vp^4nUm1!3HGP9xZtRq!^2X+?^QKos)S9G4{rzpz`ks5R zc8Kj0TlDhL_0ls<+m>BecJBCnMo!+|^)G6iL2hGUxS_C1`a}Jn)bAqiq~t4wq~UYF}^n1GcxvX& dN}IerjGt7Q1>7HnEC$-e;OXk;vd$@?2>`@EK-2&L diff --git a/Resources/Textures/Structures/Doors/Airlocks/Standard/syndicate.rsi/sparks_open.png b/Resources/Textures/Structures/Doors/Airlocks/Standard/syndicate.rsi/sparks_open.png index 630eabb976ecf11fa59ba29f03502b02bde399aa..fb8ba8d034ce6c5609043f1303ca6f2387f04671 100644 GIT binary patch literal 226 zcmeAS@N?(olHy`uVBq!ia0vp^4nUm1!3HGP9xZtRq!^2X+?^QKos)S9aO`53>y@>X S#eB6ZNTsK%pUXO@geCx&TTm?k literal 175 zcmeAS@N?(olHy`uVBq!ia0vp^2|(0onej0>J{1B!2;OQb$4nuFf3k0002{NklP9E9_SUA24GbPz9?-y&kZm-0lQ2U=+nk21Bj3rpx=Sh0Kk3) sg#kq9|C+GYx*w>j+Y9b5@GK&L7oS37kyCv}u>b%707*qoM6N<$f_#mD^#A|> delta 269 zcmV+o0rLLA0;mFzB!BNoL_t(|oYj{x4udcZMSrVqOqdNM7B0XLHfHbKA-84W0I;(J zCJ!O_N2;HSWO<%5b^zoJEX!gGaL3n-QrC61fn;4*wm#k_G(h}n TBOLz#0000 Date: Fri, 29 Sep 2023 21:21:49 +0300 Subject: [PATCH 4/7] Translate Upstream #1467 (#1469) Co-authored-by: Morb <14136326+Morb0@users.noreply.github.com> --- .../Locale/ru-RU/flavors/flavor-profiles.ftl | 1 + .../Locale/ru-RU/guidebook/chemistry/core.ftl | 1 + .../interaction-popup-component.ftl | 1 + Resources/Locale/ru-RU/markings/reptilian.ftl | 8 +++++++ .../corvax/catalog/fills/items/misc.ftl | 3 +++ .../entities/clothing/head/hats.ftl | 2 ++ .../entities/clothing/head/helmets.ftl | 2 ++ .../entities/clothing/outerclothing/armor.ftl | 2 ++ .../entities/clothing/uniforms/jumpsuits.ftl | 2 ++ .../entities/mobs/player/observer.ftl | 6 +++-- .../entities/objects/consumable/food/meat.ftl | 4 ++++ .../entities/objects/materials/materials.ftl | 6 +++++ .../objects/misc/identification_cards.ftl | 2 ++ .../objects/specific/janitorial/janitor.ftl | 2 +- .../entities/objects/weapons/melee/spear.ftl | 2 ++ .../structures/doors/airlocks/easy_pry.ftl | 24 +++++++++++++++++++ .../ru-RU/weapons/grenades/timer-trigger.ftl | 1 + 17 files changed, 66 insertions(+), 3 deletions(-) create mode 100644 Resources/Locale/ru-RU/ss14-ru/prototypes/corvax/catalog/fills/items/misc.ftl create mode 100644 Resources/Locale/ru-RU/ss14-ru/prototypes/entities/structures/doors/airlocks/easy_pry.ftl diff --git a/Resources/Locale/ru-RU/flavors/flavor-profiles.ftl b/Resources/Locale/ru-RU/flavors/flavor-profiles.ftl index 60da8442010129..005100bfab0ba2 100644 --- a/Resources/Locale/ru-RU/flavors/flavor-profiles.ftl +++ b/Resources/Locale/ru-RU/flavors/flavor-profiles.ftl @@ -153,6 +153,7 @@ flavor-complex-parents = как чьи-то родители flavor-complex-plastic = как пластик flavor-complex-glue = как клей flavor-complex-spaceshroom-cooked = как космический умами +flavor-complex-lost-friendship = как прошедшая дружба ## Generic alcohol/soda taste. This should be replaced with an actual flavor profile. diff --git a/Resources/Locale/ru-RU/guidebook/chemistry/core.ftl b/Resources/Locale/ru-RU/guidebook/chemistry/core.ftl index a1cf2459718552..f22fa78af8f09f 100644 --- a/Resources/Locale/ru-RU/guidebook/chemistry/core.ftl +++ b/Resources/Locale/ru-RU/guidebook/chemistry/core.ftl @@ -10,6 +10,7 @@ guidebook-reagent-name = [bold][color={ $color }]{ CAPITALIZE($name) }[/color][/ guidebook-reagent-recipes-header = Рецепт guidebook-reagent-recipes-reagent-display = [bold]{ $reagent }[/bold] \[{ $ratio }\] guidebook-reagent-recipes-mix = Смешайте +guidebook-reagent-recipes-mix-and-heat = Смешайте при температуре выше { $temperature }К guidebook-reagent-effects-header = Эффекты guidebook-reagent-effects-metabolism-group-rate = [bold]{ $group }[/bold] [color=gray]({ $rate } единиц в секунду)[/color] guidebook-reagent-physical-description = На вид вещество { $description }. diff --git a/Resources/Locale/ru-RU/interaction/interaction-popup-component.ftl b/Resources/Locale/ru-RU/interaction/interaction-popup-component.ftl index 49207eb43120ba..51386d9af6307a 100644 --- a/Resources/Locale/ru-RU/interaction/interaction-popup-component.ftl +++ b/Resources/Locale/ru-RU/interaction/interaction-popup-component.ftl @@ -5,6 +5,7 @@ petting-success-generic = Вы гладите { $target } по голове. petting-success-soft-floofy = Вы гладите { $target } по { POSS-ADJ($target) } мягкой пушистой голове. +petting-success-bingus = Вы гладите { $target } по { POSS-ADJ($target) } маленькой морщинистой голове. petting-success-bird = Вы гладите { $target } по { POSS-ADJ($target) } милой пернатой голове. petting-success-cat = Вы гладите { $target } по { POSS-ADJ($target) } маленькой пушистой голове. petting-success-corrupted-corgi = В порыве самонадеянности, вы гладите { $target } по { POSS-ADJ($target) } маленькой проклятой голове. diff --git a/Resources/Locale/ru-RU/markings/reptilian.ftl b/Resources/Locale/ru-RU/markings/reptilian.ftl index 81c4f8532897d8..a610983ebdd17d 100644 --- a/Resources/Locale/ru-RU/markings/reptilian.ftl +++ b/Resources/Locale/ru-RU/markings/reptilian.ftl @@ -48,3 +48,11 @@ marking-LizardFrillsAxolotl-frills_axolotl = Унатх, воротник (Ак marking-LizardFrillsAxolotl = Унатх, воротник (Аксолотль) marking-LizardFrillsHood-frills_hood = Унатх, воротник (Капюшон) marking-LizardFrillsHood = Унатх, воротник (Капюшон) +marking-LizardHornsArgali-horns_argali = Унатх, рожки (Аргали) +marking-LizardHornsArgali = Унатх, рожки (Аргали) +marking-LizardHornsAyrshire-horns_ayrshire = Унатх, рожки (Айршир) +marking-LizardHornsAyrshire = Унатх, рожки (Айршир) +marking-LizardHornsMyrsore-horns_myrsore = Унатх, рожки (Мирзора) +marking-LizardHornsMyrsore = Унатх, рожки (Мирзора) +marking-LizardHornsBighorn-horns_bighorn = Унатх, рожки (Бигхорн) +marking-LizardHornsBighorn = Унатх, рожки (Бигхорн) diff --git a/Resources/Locale/ru-RU/ss14-ru/prototypes/corvax/catalog/fills/items/misc.ftl b/Resources/Locale/ru-RU/ss14-ru/prototypes/corvax/catalog/fills/items/misc.ftl new file mode 100644 index 00000000000000..db261867132628 --- /dev/null +++ b/Resources/Locale/ru-RU/ss14-ru/prototypes/corvax/catalog/fills/items/misc.ftl @@ -0,0 +1,3 @@ +ent-ClothingShoesBootsJackSecFilled = { ent-ClothingShoesBootsJackSec } + .suffix = Заполненный + .desc = { ent-ClothingShoesBootsJackSec.desc } diff --git a/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/clothing/head/hats.ftl b/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/clothing/head/hats.ftl index 5a6d01de02ff93..e6098fcc2032bc 100644 --- a/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/clothing/head/hats.ftl +++ b/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/clothing/head/hats.ftl @@ -120,3 +120,5 @@ ent-ClothingHeadHatBeretNavyBlue = темно-синий офицерский б .desc = Темно-синий берет сил безопасности Нанотрасена, украшенный серебряным каплевидным щитом с выгравированным мечом, объявляющий миру, что его обладатель является защитником Нанотрасена. ent-ClothingHeadHatCapcap = фуражка капитана .desc = Большая, стильная капитанская фуражка. +ent-ClothingHeadHatGladiator = гладиаторский шлем + .desc = Защищает голову от суровых пепельных ветров и игрушечных копий. diff --git a/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/clothing/head/helmets.ftl b/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/clothing/head/helmets.ftl index 7d2b1294d6423a..c509f674ddb7a6 100644 --- a/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/clothing/head/helmets.ftl +++ b/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/clothing/head/helmets.ftl @@ -51,3 +51,5 @@ ent-ClothingHeadHelmetLing = хитиновый шлем .desc = Раздувает тело генокрада во всепоглощающий массив хитиновый брони. Обеспечивает высокую защиту от физических повреждений, более низкую от других типов. Его вес замедляет движение генокрада, а его поддержание замедляет выработку химических веществ. ent-ClothingHeadHelmetVoidParamed = шлем скафандра парамедика .desc = Шлем от скафандра парамедика. +ent-ClothingHeadHelmetBone = костяной шлем + .desc = Круто выглядящий шлем, сделанный из черепов ваших врагов. diff --git a/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/clothing/outerclothing/armor.ftl b/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/clothing/outerclothing/armor.ftl index 85e90f646907f9..0347db1856cedf 100644 --- a/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/clothing/outerclothing/armor.ftl +++ b/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/clothing/outerclothing/armor.ftl @@ -27,3 +27,5 @@ ent-ClothingOuterArmorCaptainCarapace = панцирь капитана .desc = Бронированный нагрудник, обеспечивающий защиту и при этом обладающий мобильностью и гибкостью. Выдается только лучшим представителям станции. ent-ClothingOuterArmorChangeling = хитиновый панцирь .desc = Раздувает тело генокрада во всепоглощающий массив хитиновый брони. Обеспечивает высокую защиту от физических повреждений, более низкую от других типов. Его вес замедляет движение генокрада, а его поддержание замедляет выработку химических веществ. +ent-ClothingOuterArmorBone = костяной доспех + .desc = Сидит на вас как вторая кожа. diff --git a/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/clothing/uniforms/jumpsuits.ftl b/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/clothing/uniforms/jumpsuits.ftl index a8905105c581b1..868e1c738413a8 100644 --- a/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/clothing/uniforms/jumpsuits.ftl +++ b/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/clothing/uniforms/jumpsuits.ftl @@ -229,3 +229,5 @@ ent-ClothingUniformJumpsuitWeb = паутинный комбинезон .desc = Даёт понять, что вы едины с паутиной. ent-ClothingUniformJumpsuitLoungewear = домашняя одежда .desc = Длинный кусок ткани, который облегает тело, обеспечивая комфорт. +ent-ClothingUniformJumpsuitGladiator = форма гладиатора + .desc = Создана для настоящих гладиаторов (или пеплоходцев). diff --git a/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/mobs/player/observer.ftl b/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/mobs/player/observer.ftl index c97fe1dd7f7416..96ba6227c90e29 100644 --- a/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/mobs/player/observer.ftl +++ b/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/mobs/player/observer.ftl @@ -3,8 +3,10 @@ ent-MobObserver = наблюдатель ent-ActionGhostBoo = Бу! .desc = Пугайте членов своей команды со скуки! ent-ActionToggleLighting = Переключить освещение - .desc = Включите или отключите рендеринг света, чтобы лучше видеть затенённые области. + .desc = Включить или выключить рендеринг света, чтобы лучше видеть затенённые области. ent-ActionToggleFov = Переключить поле зрения .desc = Переключить поле зрения чтобы видеть то же, что и игроки. -ent-ActionToggleGhosts = Переключить призраков +ent-ActionToggleGhosts = Переключить видимость призраков .desc = Переключить видимость других призраков. +ent-ActionToggleGhostHearing = Переключить слышимость призраком + .desc = Переключить между прослушиванием всех сообщений и прослушиванием рации и сообщений поблизости. diff --git a/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/objects/consumable/food/meat.ftl b/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/objects/consumable/food/meat.ftl index e4a832002b05f8..d241faac227d09 100644 --- a/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/objects/consumable/food/meat.ftl +++ b/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/objects/consumable/food/meat.ftl @@ -40,6 +40,8 @@ ent-FoodMeatWheat = мясной комок .desc = Это совсем не похоже на мясо, но и ваши стандарты не так уж и высоки. ent-FoodMeatXeno = сырое ксено мясо .desc = Кусок мяса ксеноса, сочащийся кислотой. +ent-FoodMeatRouny = сырое мясо руни + .desc = Кусок мяса невинного красного друга. ent-FoodMeatTomato = мясо помидора-убийцы .desc = Ломтик от огромного помидора. ent-FoodMeatSalami = салями @@ -70,6 +72,8 @@ ent-FoodMeatCrabCooked = приготовленное мясо краба .desc = Вкусно приготовленное крабовое мясо. ent-FoodMeatGoliathCooked = стейк из голиафа .desc = Вкусный, приготовленный в лаве стейк. +ent-FoodMeatRounyCooked = стейк из руни + .desc = Некоторые убивают, чтобы выжить. Вы же убиваете ради удовольствия. ent-FoodMeatLizardCooked = стейк из ящерицы .desc = Приготовленное, жесткое мясо ящерицы. ent-FoodMeatSpiderlegCooked = приготовленная паучья нога diff --git a/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/objects/materials/materials.ftl b/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/objects/materials/materials.ftl index 5ca0c53c5ada4a..db7c60a2777ee1 100644 --- a/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/objects/materials/materials.ftl +++ b/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/objects/materials/materials.ftl @@ -61,3 +61,9 @@ ent-MaterialWebSilk25 = { ent-MaterialWebSilk } ent-MaterialWebSilk1 = { ent-MaterialWebSilk } .suffix = 1 .desc = { ent-MaterialWebSilk.desc } +ent-MaterialBones = кости + .suffix = Полный + .desc = { ent-MaterialBase.desc } +ent-MaterialBones1 = { ent-MaterialBones } + .suffix = 1 + .desc = { ent-MaterialBones.desc } diff --git a/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/objects/misc/identification_cards.ftl b/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/objects/misc/identification_cards.ftl index 5321812a5f01c9..d14271cbbaa852 100644 --- a/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/objects/misc/identification_cards.ftl +++ b/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/objects/misc/identification_cards.ftl @@ -44,6 +44,8 @@ ent-JanitorIDCard = ID карта уборщика .desc = { ent-IDCardStandard.desc } ent-BartenderIDCard = ID карта бармена .desc = { ent-IDCardStandard.desc } +ent-PunPunIDCard = ID карта Пун Пуна + .desc = { ent-IDCardStandard.desc } ent-ChefIDCard = ID карта шеф-повара .desc = { ent-IDCardStandard.desc } ent-BotanistIDCard = ID карта ботаника diff --git a/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/objects/specific/janitorial/janitor.ftl b/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/objects/specific/janitorial/janitor.ftl index 937394574ce4ce..ead206098c8760 100644 --- a/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/objects/specific/janitorial/janitor.ftl +++ b/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/objects/specific/janitorial/janitor.ftl @@ -11,7 +11,7 @@ ent-WetFloorSign = знак "мокрый пол" .desc = Осторожно! Мокрый пол! ent-WetFloorSignMineExplosive = { ent-WetFloorSign } .desc = { ent-WetFloorSign.desc } - .suffix = Explosive + .suffix = Взрывчатка ent-JanitorialTrolley = тележка уборщика .desc = Это альфа и омега санитарии. ent-FloorDrain = дренаж diff --git a/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/objects/weapons/melee/spear.ftl b/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/objects/weapons/melee/spear.ftl index e2067b4882a5f1..51c378c83c0389 100644 --- a/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/objects/weapons/melee/spear.ftl +++ b/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/objects/weapons/melee/spear.ftl @@ -6,3 +6,5 @@ ent-SpearPlasma = плазменное копьё .desc = Копье с осколком плазменного стекла в качестве наконечника. ent-SpearUranium = урановое копьё .desc = Копье с осколком уранового стекла в качестве наконечника. +ent-SpearBone = костяное копьё + .desc = Копьё, сделанное из костей. diff --git a/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/structures/doors/airlocks/easy_pry.ftl b/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/structures/doors/airlocks/easy_pry.ftl new file mode 100644 index 00000000000000..fa40e8c3296983 --- /dev/null +++ b/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/structures/doors/airlocks/easy_pry.ftl @@ -0,0 +1,24 @@ +ent-AirlockExternalEasyPry = { ent-AirlockExternal } + .desc = Он открывается, он закрывается, он может вас раздавить, и за ним может быть только космос. Должен быть активирован вручную. Имеет вентиль с надписью "ПОВЕРНИТЕ ЧТОБЫ ОТКРЫТЬ". + .suffix = Внешний, Легко открыть +ent-AirlockExternalGlassEasyPry = { ent-AirlockExternalGlass } + .desc = Он открывается, он закрывается, он может вас раздавить, и за ним может быть только космос. Должен быть активирован вручную. Имеет вентиль с надписью "ПОВЕРНИТЕ ЧТОБЫ ОТКРЫТЬ". + .suffix = Внешний, Стеклянный, Легко открыть +ent-AirlockGlassShuttleEasyPry = { ent-AirlockGlassShuttle } + .desc = Необходим для соединения двух космических кораблей вместе. Имеет вентиль с надписью "ПОВЕРНИТЕ ЧТОБЫ ОТКРЫТЬ". + .suffix = Стыковочный, Стеклянный, Легко открыть +ent-AirlockShuttleEasyPry = { ent-AirlockShuttle } + .desc = Необходим для соединения двух космических кораблей вместе. Имеет вентиль с надписью "ПОВЕРНИТЕ ЧТОБЫ ОТКРЫТЬ". + .suffix = Стыковочный, Легко открыть +ent-AirlockExternalEasyPryLocked = { ent-AirlockExternalLocked } + .desc = Он открывается, он закрывается, он может вас раздавить, и за ним может быть только космос. Должен быть активирован вручную. Имеет вентиль с надписью "ПОВЕРНИТЕ ЧТОБЫ ОТКРЫТЬ". + .suffix = Внешний, Легко открыть, Закрытый +ent-AirlockExternalGlassEasyPryLocked = { ent-AirlockExternalGlassLocked } + .desc = Он открывается, он закрывается, он может вас раздавить, и за ним может быть только космос. Должен быть активирован вручную. Имеет вентиль с надписью "ПОВЕРНИТЕ ЧТОБЫ ОТКРЫТЬ". + .suffix = Внешний, Стеклянный, Легко открыть, Закрытый +ent-AirlockGlassShuttleEasyPryLocked = { ent-AirlockExternalGlassShuttleLocked } + .desc = Необходим для соединения двух космических кораблей вместе. Имеет вентиль с надписью "ПОВЕРНИТЕ ЧТОБЫ ОТКРЫТЬ". + .suffix = Стыковочный, Стеклянный, Закрытый, Легко открыть +ent-AirlockShuttleEasyPryLocked = { ent-AirlockExternalShuttleLocked } + .desc = Необходим для соединения двух космических кораблей вместе. Имеет вентиль с надписью "ПОВЕРНИТЕ ЧТОБЫ ОТКРЫТЬ". + .suffix = Стыковочный, Закрытый, Легко открыть diff --git a/Resources/Locale/ru-RU/weapons/grenades/timer-trigger.ftl b/Resources/Locale/ru-RU/weapons/grenades/timer-trigger.ftl index e1e8ce7b757d51..183c608d50c119 100644 --- a/Resources/Locale/ru-RU/weapons/grenades/timer-trigger.ftl +++ b/Resources/Locale/ru-RU/weapons/grenades/timer-trigger.ftl @@ -3,6 +3,7 @@ verb-trigger-timer-set-current = { $time } секунд (сейчас) verb-trigger-timer-cycle = Циклическое переключение задержки examine-trigger-timer = Таймер установлен на { $time } секунд. popup-trigger-timer-set = Таймер установлен на { $time } секунд. +verb-start-detonation = Запутить детонацию verb-toggle-start-on-stick = Переключить автоактивацию popup-start-on-stick-off = Устройство НЕ будет автоматически активировано после установки popup-start-on-stick-on = Устройство будет автоматически активировано после установки From 0e52b7d92bbdd7ec2be38e42062d76e1e239fe72 Mon Sep 17 00:00:00 2001 From: Morb <14136326+Morb0@users.noreply.github.com> Date: Wed, 27 Sep 2023 20:18:18 +0300 Subject: [PATCH 5/7] Cleanup TTS & fix voice preview (#1458) --- .../Corvax/TTS/HumanoidProfileEditor.TTS.cs | 5 +- Content.Client/Corvax/TTS/TTSManager.cs | 22 --- Content.Client/Corvax/TTS/TTSSystem.cs | 182 +++--------------- Content.Client/Entry/EntryPoint.cs | 2 - Content.Client/IoC/ClientContentIoC.cs | 1 - Content.Server/Corvax/TTS/TTSSystem.cs | 20 +- Content.Shared/Corvax/TTS/MsgRequestTTS.cs | 29 --- Content.Shared/Corvax/TTS/PlayTTSEvent.cs | 6 +- .../Corvax/TTS/RequestGlobalTTSEvent.cs | 17 ++ 9 files changed, 56 insertions(+), 228 deletions(-) delete mode 100644 Content.Client/Corvax/TTS/TTSManager.cs delete mode 100644 Content.Shared/Corvax/TTS/MsgRequestTTS.cs create mode 100644 Content.Shared/Corvax/TTS/RequestGlobalTTSEvent.cs diff --git a/Content.Client/Corvax/TTS/HumanoidProfileEditor.TTS.cs b/Content.Client/Corvax/TTS/HumanoidProfileEditor.TTS.cs index 67c984f0223f01..f7bfedf845221c 100644 --- a/Content.Client/Corvax/TTS/HumanoidProfileEditor.TTS.cs +++ b/Content.Client/Corvax/TTS/HumanoidProfileEditor.TTS.cs @@ -9,7 +9,6 @@ namespace Content.Client.Preferences.UI; public sealed partial class HumanoidProfileEditor { - private TTSManager _ttsMgr = default!; private TTSSystem _ttsSys = default!; private List _voiceList = default!; private readonly List _sampleText = new() @@ -22,7 +21,6 @@ public sealed partial class HumanoidProfileEditor private void InitializeVoice() { - _ttsMgr = IoCManager.Resolve(); _ttsSys = _entMan.System(); _voiceList = _prototypeManager .EnumeratePrototypes() @@ -80,7 +78,6 @@ private void PlayTTS() if (_previewDummy is null || Profile is null) return; - _ttsSys.StopAllStreams(); - _ttsMgr.RequestTTS(_previewDummy.Value, _random.Pick(_sampleText), Profile.Voice); + _ttsSys.RequestGlobalTTS(_random.Pick(_sampleText), Profile.Voice); } } diff --git a/Content.Client/Corvax/TTS/TTSManager.cs b/Content.Client/Corvax/TTS/TTSManager.cs deleted file mode 100644 index d129495dcee7c2..00000000000000 --- a/Content.Client/Corvax/TTS/TTSManager.cs +++ /dev/null @@ -1,22 +0,0 @@ -using Content.Shared.Corvax.TTS; -using Robust.Shared.Network; - -namespace Content.Client.Corvax.TTS; - -// ReSharper disable once InconsistentNaming -public sealed class TTSManager -{ - [Dependency] private readonly IClientNetManager _netMgr = default!; - - public void Initialize() - { - _netMgr.RegisterNetMessage(); - } - - // ReSharper disable once InconsistentNaming - public void RequestTTS(EntityUid uid, string text, string voiceId) - { - var msg = new MsgRequestTTS() { Text = text, Uid = uid, VoiceId = voiceId }; - _netMgr.ClientSendMessage(msg); - } -} diff --git a/Content.Client/Corvax/TTS/TTSSystem.cs b/Content.Client/Corvax/TTS/TTSSystem.cs index df21f792be8b89..a053d016fe3048 100644 --- a/Content.Client/Corvax/TTS/TTSSystem.cs +++ b/Content.Client/Corvax/TTS/TTSSystem.cs @@ -1,15 +1,12 @@ -using System.Diagnostics.CodeAnalysis; -using System.IO; -using System.Linq; using Content.Shared.Corvax.CCCVars; using Content.Shared.Corvax.TTS; using Content.Shared.Corvax.TTS.Commands; -using Content.Shared.Physics; -using Robust.Client.Graphics; +using Robust.Client.ResourceManagement; +using Robust.Shared.Audio; using Robust.Shared.Configuration; -using Robust.Shared.Map; -using Robust.Shared.Physics; -using Robust.Shared.Physics.Systems; +using Robust.Shared.ContentPack; +using Robust.Shared.Player; +using Robust.Shared.Utility; namespace Content.Client.Corvax.TTS; @@ -19,24 +16,23 @@ namespace Content.Client.Corvax.TTS; // ReSharper disable once InconsistentNaming public sealed class TTSSystem : EntitySystem { - [Dependency] private readonly IClydeAudio _clyde = default!; - [Dependency] private readonly IEntityManager _entity = default!; - [Dependency] private readonly IEyeManager _eye = default!; [Dependency] private readonly IConfigurationManager _cfg = default!; - [Dependency] private readonly SharedPhysicsSystem _broadPhase = default!; - [Dependency] private readonly SharedTransformSystem _transform = default!; + [Dependency] private readonly IResourceCache _resourceCache = default!; + [Dependency] private readonly SharedAudioSystem _audio = default!; private ISawmill _sawmill = default!; + private readonly MemoryContentRoot _contentRoot = new(); + private static readonly ResPath Prefix = ResPath.Root / "TTS"; + private float _volume = 0.0f; private float _radioVolume = 0.0f; - - private readonly HashSet _currentStreams = new(); - private readonly Dictionary> _entityQueues = new(); + private int _fileIdx = 0; public override void Initialize() { _sawmill = Logger.GetSawmill("tts"); + _resourceCache.AddRoot(Prefix, _contentRoot); _cfg.OnValueChanged(CCCVars.TTSVolume, OnTtsVolumeChanged, true); _cfg.OnValueChanged(CCCVars.TTSRadioVolume, OnTtsRadioVolumeChanged, true); SubscribeNetworkEvent(OnPlayTTS); @@ -48,58 +44,12 @@ public override void Shutdown() base.Shutdown(); _cfg.UnsubValueChanged(CCCVars.TTSVolume, OnTtsVolumeChanged); _cfg.UnsubValueChanged(CCCVars.TTSRadioVolume, OnTtsRadioVolumeChanged); - EndStreams(); + _contentRoot.Dispose(); } - // Little bit of duplication logic from AudioSystem - public override void FrameUpdate(float frameTime) + public void RequestGlobalTTS(string text, string voiceId) { - var streamToRemove = new HashSet(); - - var ourPos = _eye.CurrentEye.Position.Position; - foreach (var stream in _currentStreams) - { - var streamUid = GetEntity(stream.Uid); - if (!stream.Source.IsPlaying || - !_entity.TryGetComponent(streamUid, out var meta) || - Deleted(streamUid, meta) || - !_entity.TryGetComponent(streamUid, out var xform)) - { - stream.Source.Dispose(); - streamToRemove.Add(stream); - continue; - } - - var mapPos = xform.MapPosition; - if (mapPos.MapId != MapId.Nullspace) - { - if (!stream.Source.SetPosition(mapPos.Position)) - { - _sawmill.Warning("Can't set position for audio stream, stop stream."); - stream.Source.StopPlaying(); - } - } - - if (mapPos.MapId == _eye.CurrentMap) - { - var collisionMask = (int) CollisionGroup.Impassable; - var sourceRelative = ourPos - mapPos.Position; - var occlusion = 0f; - if (sourceRelative.Length() > 0) - { - occlusion = _broadPhase.IntersectRayPenetration(mapPos.MapId, - new CollisionRay(mapPos.Position, sourceRelative.Normalized(), collisionMask), - sourceRelative.Length(), streamUid); - } - stream.Source.SetOcclusion(occlusion); - } - } - - foreach (var audioStream in streamToRemove) - { - _currentStreams.Remove(audioStream); - ProcessEntityQueue(GetEntity(audioStream.Uid)); - } + RaiseNetworkEvent(new RequestGlobalTTSEvent(text, voiceId)); } private void OnTtsVolumeChanged(float volume) @@ -114,109 +64,31 @@ private void OnTtsRadioVolumeChanged(float volume) private void OnQueueResetRequest(TtsQueueResetMessage ev) { - EndStreams(); + //EndStreams(); _sawmill.Debug("TTS queue was cleared by request from the server."); } private void OnPlayTTS(PlayTTSEvent ev) { - var volume = (ev.IsRadio ? _radioVolume : _volume) * ev.VolumeModifier; - - if (!TryCreateAudioSource(ev.Data, volume, out var source)) - return; - - var stream = new AudioStream(ev.Uid, source); - AddEntityStreamToQueue(stream); - } + _sawmill.Debug($"Play TTS audio {ev.Data.Length} bytes from {ev.SourceUid} entity"); - public void StopAllStreams() - { - foreach (var stream in _currentStreams) - stream.Source.StopPlaying(); - } + var volume = (ev.IsRadio ? _radioVolume : _volume) * ev.VolumeModifier; - private bool TryCreateAudioSource(byte[] data, float volume, [NotNullWhen(true)] out IClydeAudioSource? source) - { - var dataStream = new MemoryStream(data) { Position = 0 }; - var audioStream = _clyde.LoadAudioOggVorbis(dataStream); - source = _clyde.CreateAudioSource(audioStream); - source?.SetVolume(volume); - return source != null; - } + var filePath = new ResPath($"{_fileIdx++}.ogg"); + _contentRoot.AddOrUpdateFile(filePath, ev.Data); - private void AddEntityStreamToQueue(AudioStream stream) - { - var uid = GetEntity(stream.Uid); - if (_entityQueues.TryGetValue(uid, out var queue)) + var audioParams = AudioParams.Default.WithVolume(volume); + var soundPath = new SoundPathSpecifier(Prefix / filePath, audioParams); + if (ev.SourceUid != null) { - queue.Enqueue(stream); + var sourceUid = GetEntity(ev.SourceUid.Value); + _audio.PlayEntity(soundPath, new EntityUid(), sourceUid); // recipient arg ignored on client } else { - _entityQueues.Add(uid, new Queue(new[] { stream })); - - if (!IsEntityCurrentlyPlayStream(stream.Uid)) - ProcessEntityQueue(uid); - } - } - - private bool IsEntityCurrentlyPlayStream(NetEntity uid) - { - return _currentStreams.Any(s => s.Uid == uid); - } - - private void ProcessEntityQueue(EntityUid uid) - { - if (TryTakeEntityStreamFromQueue(uid, out var stream)) - PlayEntity(stream); - } - - private bool TryTakeEntityStreamFromQueue(EntityUid uid, [NotNullWhen(true)] out AudioStream? stream) - { - if (_entityQueues.TryGetValue(uid, out var queue)) - { - stream = queue.Dequeue(); - if (queue.Count == 0) - _entityQueues.Remove(uid); - return true; + _audio.PlayGlobal(soundPath, Filter.Local(), false); } - stream = null; - return false; - } - - private void PlayEntity(AudioStream stream) - { - if (!_entity.TryGetComponent(GetEntity(stream.Uid), out var xform) || - !stream.Source.SetPosition(_transform.GetWorldPosition(xform))) - return; - - stream.Source.StartPlaying(); - _currentStreams.Add(stream); - } - - public void EndStreams() - { - foreach (var stream in _currentStreams) - { - stream.Source.StopPlaying(); - stream.Source.Dispose(); - } - - _currentStreams.Clear(); - _entityQueues.Clear(); - } - - // ReSharper disable once InconsistentNaming - private sealed class AudioStream - { - public NetEntity Uid { get; } - public IClydeAudioSource Source { get; } - - public AudioStream(NetEntity uid, IClydeAudioSource source) - { - Uid = uid; - Source = source; - } + _contentRoot.RemoveFile(filePath); } } diff --git a/Content.Client/Entry/EntryPoint.cs b/Content.Client/Entry/EntryPoint.cs index 65acdb2d06a094..1014beb666166a 100644 --- a/Content.Client/Entry/EntryPoint.cs +++ b/Content.Client/Entry/EntryPoint.cs @@ -73,7 +73,6 @@ public sealed class EntryPoint : GameClient [Dependency] private readonly ContentLocalizationManager _contentLoc = default!; [Dependency] private readonly SponsorsManager _sponsorsManager = default!; // Corvax-Sponsors [Dependency] private readonly JoinQueueManager _queueManager = default!; // Corvax-Queue - [Dependency] private readonly TTSManager _ttsManager = default!; // Corvax-TTS [Dependency] private readonly DiscordAuthManager _discordAuthManager = default!; // Corvax-DiscordAuth [Dependency] private readonly ContentReplayPlaybackManager _playbackMan = default!; [Dependency] private readonly IResourceManager _resourceManager = default!; @@ -174,7 +173,6 @@ public override void PostInit() _userInterfaceManager.SetDefaultTheme("SS14DefaultTheme"); _sponsorsManager.Initialize(); // Corvax-Sponsors _queueManager.Initialize(); // Corvax-Queue - _ttsManager.Initialize(); // Corvax-TTS _discordAuthManager.Initialize(); // Corvax-DiscordAuth _userInterfaceManager.SetActiveTheme(_configManager.GetCVar(CVars.InterfaceTheme)); _documentParsingManager.Initialize(); diff --git a/Content.Client/IoC/ClientContentIoC.cs b/Content.Client/IoC/ClientContentIoC.cs index aa0d3908ed6083..59d125a81db7cb 100644 --- a/Content.Client/IoC/ClientContentIoC.cs +++ b/Content.Client/IoC/ClientContentIoC.cs @@ -53,7 +53,6 @@ public static void Register() IoCManager.Register(); IoCManager.Register(); // Corvax-Sponsors IoCManager.Register(); // Corvax-Queue - IoCManager.Register(); // Corvax-TTS IoCManager.Register(); // Corvax-DiscordAuth IoCManager.Register(); IoCManager.Register(); diff --git a/Content.Server/Corvax/TTS/TTSSystem.cs b/Content.Server/Corvax/TTS/TTSSystem.cs index 2b66cfd27a245d..0332b54b23f955 100644 --- a/Content.Server/Corvax/TTS/TTSSystem.cs +++ b/Content.Server/Corvax/TTS/TTSSystem.cs @@ -4,9 +4,7 @@ using Content.Shared.Corvax.TTS; using Content.Shared.GameTicking; using Content.Shared.SS220.AnnounceTTS; -using Robust.Server.Player; using Robust.Shared.Configuration; -using Robust.Shared.Network; using Robust.Shared.Player; using Robust.Shared.Prototypes; @@ -17,8 +15,6 @@ public sealed partial class TTSSystem : EntitySystem { [Dependency] private readonly IConfigurationManager _cfg = default!; [Dependency] private readonly IPrototypeManager _prototypeManager = default!; - [Dependency] private readonly IServerNetManager _netMgr = default!; - [Dependency] private readonly IPlayerManager _playerManager = default!; [Dependency] private readonly TTSManager _ttsManager = default!; [Dependency] private readonly SharedTransformSystem _xforms = default!; @@ -40,7 +36,7 @@ public override void Initialize() SubscribeLocalEvent(OnAnnouncementSpoke); SubscribeLocalEvent(OnRoundRestartCleanup); - _netMgr.RegisterNetMessage(OnRequestTTS); + SubscribeNetworkEvent(OnRequestGlobalTTS); } private void OnRadioReceiveEvent(RadioSpokeEvent args) @@ -85,18 +81,18 @@ private void OnRoundRestartCleanup(RoundRestartCleanupEvent ev) _ttsManager.ResetCache(); } - private async void OnRequestTTS(MsgRequestTTS ev) + private async void OnRequestGlobalTTS(RequestGlobalTTSEvent ev, EntitySessionEventArgs args) { if (!_isEnabled || ev.Text.Length > MaxMessageChars || - !_playerManager.TryGetSessionByChannel(ev.MsgChannel, out var session) || !_prototypeManager.TryIndex(ev.VoiceId, out var protoVoice)) return; var soundData = await GenerateTTS(ev.Text, protoVoice.Speaker); - if (soundData is null) return; + if (soundData is null) + return; - RaiseNetworkEvent(new PlayTTSEvent(GetNetEntity(ev.Uid), soundData, false), Filter.SinglePlayer(session)); + RaiseNetworkEvent(new PlayTTSEvent(soundData), Filter.SinglePlayer(args.SenderSession)); } private async void OnEntitySpoke(EntityUid uid, TTSComponent component, EntitySpokeEvent args) @@ -127,7 +123,7 @@ private async void HandleSay(EntityUid uid, string message, string speaker) { var soundData = await GenerateTTS(message, speaker); if (soundData is null) return; - RaiseNetworkEvent(new PlayTTSEvent(GetNetEntity(uid), soundData, false), Filter.Pvs(uid)); + RaiseNetworkEvent(new PlayTTSEvent(soundData, GetNetEntity(uid)), Filter.Pvs(uid)); } private async void HandleWhisper(EntityUid uid, string message, string speaker, bool isRadio) @@ -154,8 +150,8 @@ private async void HandleWhisper(EntityUid uid, string message, string speaker, continue; var ttsEvent = new PlayTTSEvent( - GetNetEntity(uid), soundData, + GetNetEntity(uid), false, WhisperVoiceVolumeModifier * (1f - distance / WhisperVoiceRange)); RaiseNetworkEvent(ttsEvent, session); @@ -170,7 +166,7 @@ private async void HandleRadio(EntityUid[] uids, string message, string speaker) foreach (var uid in uids) { - RaiseNetworkEvent(new PlayTTSEvent(GetNetEntity(uid), soundData, true), Filter.Entities(uid)); + RaiseNetworkEvent(new PlayTTSEvent(soundData, GetNetEntity(uid), true), Filter.Entities(uid)); } } diff --git a/Content.Shared/Corvax/TTS/MsgRequestTTS.cs b/Content.Shared/Corvax/TTS/MsgRequestTTS.cs deleted file mode 100644 index 485de198002ebe..00000000000000 --- a/Content.Shared/Corvax/TTS/MsgRequestTTS.cs +++ /dev/null @@ -1,29 +0,0 @@ -using Lidgren.Network; -using Robust.Shared.Network; -using Robust.Shared.Serialization; - -namespace Content.Shared.Corvax.TTS; - -// ReSharper disable once InconsistentNaming -public sealed class MsgRequestTTS : NetMessage -{ - public override MsgGroups MsgGroup => MsgGroups.Command; - - public EntityUid Uid { get; set; } = EntityUid.Invalid; - public string Text { get; set; } = String.Empty; - public string VoiceId { get; set; } = String.Empty; - - public override void ReadFromBuffer(NetIncomingMessage buffer, IRobustSerializer serializer) - { - Uid = new EntityUid(buffer.ReadInt32()); - Text = buffer.ReadString(); - VoiceId = buffer.ReadString(); - } - - public override void WriteToBuffer(NetOutgoingMessage buffer, IRobustSerializer serializer) - { - buffer.Write((int)Uid); - buffer.Write(Text); - buffer.Write(VoiceId); - } -} diff --git a/Content.Shared/Corvax/TTS/PlayTTSEvent.cs b/Content.Shared/Corvax/TTS/PlayTTSEvent.cs index fb92aaf2dd72f6..18bee32bdfaf15 100644 --- a/Content.Shared/Corvax/TTS/PlayTTSEvent.cs +++ b/Content.Shared/Corvax/TTS/PlayTTSEvent.cs @@ -6,15 +6,15 @@ namespace Content.Shared.Corvax.TTS; // ReSharper disable once InconsistentNaming public sealed class PlayTTSEvent : EntityEventArgs { - public NetEntity Uid { get; } public byte[] Data { get; } + public NetEntity? SourceUid { get; } public bool IsRadio { get; } public float VolumeModifier { get; set; } - public PlayTTSEvent(NetEntity uid, byte[] data, bool isRadio, float volumeModifier = 1f) + public PlayTTSEvent(byte[] data, NetEntity? sourceUid = null, bool isRadio = false, float volumeModifier = 1f) { - Uid = uid; Data = data; + SourceUid = sourceUid; IsRadio = isRadio; VolumeModifier = volumeModifier; } diff --git a/Content.Shared/Corvax/TTS/RequestGlobalTTSEvent.cs b/Content.Shared/Corvax/TTS/RequestGlobalTTSEvent.cs new file mode 100644 index 00000000000000..48a1ca5ca29d7a --- /dev/null +++ b/Content.Shared/Corvax/TTS/RequestGlobalTTSEvent.cs @@ -0,0 +1,17 @@ +using Robust.Shared.Serialization; + +namespace Content.Shared.Corvax.TTS; + +// ReSharper disable once InconsistentNaming +[Serializable, NetSerializable] +public sealed class RequestGlobalTTSEvent : EntityEventArgs +{ + public string Text { get; } + public string VoiceId { get; } + + public RequestGlobalTTSEvent(string text, string voiceId) + { + Text = text; + VoiceId = voiceId; + } +} From 30325a7e30afc862bf5375c78b7888072fc9e205 Mon Sep 17 00:00:00 2001 From: Artur Zhidkov Date: Tue, 3 Oct 2023 17:52:48 +0300 Subject: [PATCH 6/7] Fix build fail --- Content.Client/Corvax/TTS/Commands/TtsQueueResetCommand.cs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Content.Client/Corvax/TTS/Commands/TtsQueueResetCommand.cs b/Content.Client/Corvax/TTS/Commands/TtsQueueResetCommand.cs index d7a57a610bc34d..9cf619136ea6c0 100644 --- a/Content.Client/Corvax/TTS/Commands/TtsQueueResetCommand.cs +++ b/Content.Client/Corvax/TTS/Commands/TtsQueueResetCommand.cs @@ -14,7 +14,7 @@ public sealed class TtsQueueResetCommand : IConsoleCommand public void Execute(IConsoleShell shell, string argStr, string[] args) { var ttsSys = _entitySystemManager.GetEntitySystem(); - ttsSys.EndStreams(); + //ttsSys.EndStreams(); shell.WriteLine("Local TTS queue has been reset."); } From 8d1f9d8ce02fe7ca1629063fd059f51a1cf4f4ab Mon Sep 17 00:00:00 2001 From: lapatison <100279397+lapatison@users.noreply.github.com> Date: Mon, 2 Oct 2023 23:22:46 +0300 Subject: [PATCH 7/7] Translation fixes (#1471) --- .../Locale/ru-RU/administration/managers/admin-manager.ftl | 6 +++--- .../Locale/ru-RU/preferences/ui/humanoid-profile-editor.ftl | 2 +- .../ss14-ru/prototypes/entities/clothing/neck/cloaks.ftl | 2 +- Resources/Locale/ru-RU/weapons/grenades/timer-trigger.ftl | 2 +- 4 files changed, 6 insertions(+), 6 deletions(-) diff --git a/Resources/Locale/ru-RU/administration/managers/admin-manager.ftl b/Resources/Locale/ru-RU/administration/managers/admin-manager.ftl index 04c2ce0e080588..f85203d52d2594 100644 --- a/Resources/Locale/ru-RU/administration/managers/admin-manager.ftl +++ b/Resources/Locale/ru-RU/administration/managers/admin-manager.ftl @@ -1,9 +1,9 @@ -admin-manager-self-de-admin-message = { $exAdminName } убирает админ права с себя. -admin-manager-self-re-admin-message = { $newAdminName } возвращает админ права себе. +admin-manager-self-de-admin-message = { $exAdminName } снимает с себя права админа. +admin-manager-self-re-admin-message = { $newAdminName } возвращает себе права админа. admin-manager-became-normal-player-message = Теперь вы обычный игрок. admin-manager-became-admin-message = Теперь вы администратор. admin-manager-no-longer-admin-message = Вы больше не администратор. admin-manager-admin-permissions-updated-message = Ваши права администратора были обновлены. admin-manager-admin-logout-message = Админ вышел: { $name } -admin-manager-admin-login-message = Админ зашел: { $name } +admin-manager-admin-login-message = Админ зашёл: { $name } admin-manager-admin-data-host-title = Хост diff --git a/Resources/Locale/ru-RU/preferences/ui/humanoid-profile-editor.ftl b/Resources/Locale/ru-RU/preferences/ui/humanoid-profile-editor.ftl index 22033c8360bc10..803478e2cdf049 100644 --- a/Resources/Locale/ru-RU/preferences/ui/humanoid-profile-editor.ftl +++ b/Resources/Locale/ru-RU/preferences/ui/humanoid-profile-editor.ftl @@ -1,4 +1,4 @@ -humanoid-profile-editor-randomize-everything-button = Сгенерировать случайного +humanoid-profile-editor-randomize-everything-button = Случайный персонаж humanoid-profile-editor-name-label = Имя: humanoid-profile-editor-name-random-button = Сгенерировать humanoid-profile-editor-appearance-tab = Внешность diff --git a/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/clothing/neck/cloaks.ftl b/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/clothing/neck/cloaks.ftl index 7fb9eb082652c2..64ff9908e6d898 100644 --- a/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/clothing/neck/cloaks.ftl +++ b/Resources/Locale/ru-RU/ss14-ru/prototypes/entities/clothing/neck/cloaks.ftl @@ -7,7 +7,7 @@ ent-ClothingNeckCloakCe = плащ старшего инженера ent-ClothingCloakCmo = плащ главного врача .desc = Стерильный синий плащ с зеленым крестом, излучающий чувство долга и готовность помогать другим. ent-ClothingNeckCloakRd = плащ научного руководителя - .desc = Белый плащ с фиолетовыми полосами, демонстрирующий ваш статус законодателя передовых технологий. + .desc = Фиолетовый плащ с белыми полосами, демонстрирующий ваш статус законодателя передовых технологий. ent-ClothingNeckCloakQm = плащ квартирмейстера .desc = Прочный коричневый плащ со светоотражающей полосой, хотя и не такой модный, как другие, но демонстрирует ваши навыки управления. ent-ClothingNeckCloakHop = плащ главы персонала diff --git a/Resources/Locale/ru-RU/weapons/grenades/timer-trigger.ftl b/Resources/Locale/ru-RU/weapons/grenades/timer-trigger.ftl index 183c608d50c119..e179dd1cfafbd5 100644 --- a/Resources/Locale/ru-RU/weapons/grenades/timer-trigger.ftl +++ b/Resources/Locale/ru-RU/weapons/grenades/timer-trigger.ftl @@ -3,7 +3,7 @@ verb-trigger-timer-set-current = { $time } секунд (сейчас) verb-trigger-timer-cycle = Циклическое переключение задержки examine-trigger-timer = Таймер установлен на { $time } секунд. popup-trigger-timer-set = Таймер установлен на { $time } секунд. -verb-start-detonation = Запутить детонацию +verb-start-detonation = Запустить детонацию verb-toggle-start-on-stick = Переключить автоактивацию popup-start-on-stick-off = Устройство НЕ будет автоматически активировано после установки popup-start-on-stick-on = Устройство будет автоматически активировано после установки