Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Languages #6

Merged
merged 76 commits into from
May 8, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
76 commits
Select commit Hold shift + click to select a range
da76123
Fixes for universal speakers (no more walls speaking GC)
Mnemotechnician Mar 20, 2024
a95f105
Fixes for universal speakers (no more walls speaking GC)
Mnemotechnician Mar 20, 2024
728e9b1
Fixes for universal speakers (no more walls speaking GC)
Mnemotechnician Mar 20, 2024
113826b
Revert "Fixes for universal speakers (no more walls speaking GC)"
FoxxoTrystan Mar 24, 2024
6bdc514
Fixes for universal speakers (no more walls speaking GC)
Mnemotechnician Mar 20, 2024
3d86f02
Port
FoxxoTrystan Mar 24, 2024
bf80a15
Missing Default Langauges (Only Harpies duh)
FoxxoTrystan Mar 25, 2024
c65c1d3
Animals SPEAKS!
FoxxoTrystan Mar 25, 2024
c61e061
Apply suggestions from code review
Mnemotechnician Mar 30, 2024
0b7dd07
Did what the review suggested
Mnemotechnician Mar 30, 2024
54b15c1
Merge remote-tracking branch 'upstream/master' into Languages
FoxxoTrystan Mar 31, 2024
f3b2daa
abstract + yml changes
FoxxoTrystan Mar 31, 2024
381eea1
Split translator comps into separate files and pray it compiles
Mnemotechnician Apr 7, 2024
6f841fb
Refactor RadioReceiveEvent
Mnemotechnician Apr 7, 2024
cdb786c
Refactor ChatSystem & add comments
Mnemotechnician Apr 7, 2024
f9dcd71
Clean up using directives after jetbrains rider messed em up
Mnemotechnician Apr 7, 2024
4bc2c46
Merge branch 'master' into Languages
FoxxoTrystan Apr 8, 2024
076bfc3
Merge branch 'Simple-Station:master' into Languages
FoxxoTrystan Apr 24, 2024
7dff567
Tiny Fixes/Requests
FoxxoTrystan Apr 24, 2024
a0d8c08
Added the most basic of syndicate flavor
Eagle-0 Apr 25, 2024
d14461e
Synths real
Eagle-0 Apr 25, 2024
55794de
Updated Door Sprites, syndicate Dropship, Saltern, Captains Cape
Arkyfloof Apr 26, 2024
4c3724d
Fixed traitors, new synth sounds, Urist update
Eagle-0 Apr 26, 2024
e819a63
Mechs real, Synth balance, Terragov Preset
Eagle-0 Apr 27, 2024
ec92c56
Changed cargo gifts, no more centcomm, urist shuttles
Eagle-0 Apr 28, 2024
937a4d9
Resolved Test
FoxxoTrystan Apr 29, 2024
21dd8dd
Update LanguageMenuUIController.cs
FoxxoTrystan Apr 29, 2024
f6d46f8
Added new Shuttle for the Terragov faction
Reese1243 Apr 29, 2024
1baab28
added a new shuttle for the TerraGov faction
Reese1243 Apr 29, 2024
c1287b8
Fixed some announcements, centcom name change, atmosia fake
Eagle-0 Apr 29, 2024
ba7d807
Delete TerraGovernor.yml
Reese1243 Apr 30, 2024
1618f20
SyndieSaltern
VMSolidus Apr 30, 2024
c10d283
Merge pull request #3 from Eagle-0/saltern-updates
Eagle-0 Apr 30, 2024
0983aa7
Update LanguageMenuUIController.cs
FoxxoTrystan May 1, 2024
b3ad259
Merge branch 'Simple-Station:master' into Languages
FoxxoTrystan May 1, 2024
041ef46
Update LanguageMenuUIController.cs
FoxxoTrystan May 1, 2024
7452487
Update LanguageMenuUIController.cs
FoxxoTrystan May 1, 2024
2b3a807
Merge branch 'Languages' of https://github.com/FoxxoTrystan/Einstein-…
FoxxoTrystan May 1, 2024
a938832
Update LanguageMenuUIController.cs
FoxxoTrystan May 1, 2024
e66df36
Update LanguageMenuUIController.cs
FoxxoTrystan May 1, 2024
c507898
Added terragov shuttle
Reese1243 May 1, 2024
70987a9
Merge pull request #4 from Eagle-0/Blitz
Reese1243 May 1, 2024
5ce48b2
Reverting
FoxxoTrystan May 1, 2024
d5d51b6
Uhh, test, if this works accept it
Arkyfloof May 1, 2024
b47718d
Merge pull request #5 from Eagle-0/arky
Arkyfloof May 1, 2024
52c4566
swapped the Shuttle Consoles and Communications consoles to the syndi…
Reese1243 May 1, 2024
d2ca520
Mons are real, Total Catgirl removal
Eagle-0 May 1, 2024
d873884
Edited Terragov shuttle
Reese1243 May 1, 2024
8af1830
Changed Antag role timers to match Wizards Den
Reese1243 May 1, 2024
5300226
Changed Antag role timers to match Wizards Den
Reese1243 May 1, 2024
93e7218
Merge branch 'Blitz' of https://github.com/Eagle-0/Syndicate-Station …
Reese1243 May 1, 2024
873ab05
Merge branch 'master' into Blitz
Reese1243 May 2, 2024
a7fefa4
New SOM guns, broken clothing :sob:
Eagle-0 May 2, 2024
b5a6013
Fixed LoneOps time requirement to be the same as NukeOps
Reese1243 May 3, 2024
a4ecd2b
Merge branch 'master' of https://github.com/Eagle-0/Syndicate-Station
Eagle-0 May 3, 2024
875cf7b
Update LanguageMenuUIController.cs
FoxxoTrystan May 3, 2024
5201873
Merge branch 'master' into Languages
FoxxoTrystan May 3, 2024
96e1c0a
Update LanguageMenuUIController.cs
FoxxoTrystan May 3, 2024
7c2621b
Merge branch 'Languages' of https://github.com/FoxxoTrystan/Einstein-…
FoxxoTrystan May 3, 2024
5023cc4
Update LanguageMenuUIController.cs
FoxxoTrystan May 3, 2024
38060c9
Finally Fixing it
VMSolidus May 3, 2024
9f6ee28
Update LanguageMenuUIController.cs
FoxxoTrystan May 3, 2024
54dee4f
Update LanguageMenuUIController.cs
FoxxoTrystan May 3, 2024
b75939c
Fixed SOM gear
Eagle-0 May 3, 2024
87a0a87
Merge branch 'master' into Languages
FoxxoTrystan May 5, 2024
d935e80
Added HoP drip, new Terragov uplink items
Eagle-0 May 5, 2024
6234be8
UI Better and Test!
FoxxoTrystan May 6, 2024
ec9116a
Oops
FoxxoTrystan May 6, 2024
afdb7ce
Merge branch 'master' into Languages
FoxxoTrystan May 6, 2024
932bc29
SPACE!
FoxxoTrystan May 6, 2024
90f3588
Merge branch 'Languages' of https://github.com/FoxxoTrystan/Einstein-…
FoxxoTrystan May 6, 2024
f2adcee
Merge branch 'master' into Languages
FoxxoTrystan May 6, 2024
f5e8bca
Revert "Merge branch 'master' into Languages"
FoxxoTrystan May 6, 2024
c25d2ec
Update Resources/Prototypes/Entities/Objects/Devices/translator_impla…
FoxxoTrystan May 7, 2024
566d861
Update Resources/Prototypes/Entities/Objects/Devices/translator_impla…
FoxxoTrystan May 7, 2024
146c32f
Merge branch 'master' into Languages
FoxxoTrystan May 7, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions Content.Client/Input/ContentContexts.cs
Original file line number Diff line number Diff line change
Expand Up @@ -55,6 +55,7 @@ public static void SetupContexts(IInputContextContainer contexts)
human.AddFunction(ContentKeyFunctions.UseItemInHand);
human.AddFunction(ContentKeyFunctions.AltUseItemInHand);
human.AddFunction(ContentKeyFunctions.OpenCharacterMenu);
human.AddFunction(ContentKeyFunctions.OpenLanguageMenu);
human.AddFunction(ContentKeyFunctions.ActivateItemInWorld);
human.AddFunction(ContentKeyFunctions.ThrowItemInHand);
human.AddFunction(ContentKeyFunctions.AltActivateItemInWorld);
Expand Down
18 changes: 18 additions & 0 deletions Content.Client/Language/LanguageMenuWindow.xaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
<DefaultWindow xmlns="https://spacestation14.io"
xmlns:ui="clr-namespace:Content.Client.UserInterface.Controls"
Title="{Loc language-menu-window-title}"
SetSize="300 300">
<BoxContainer Orientation="Vertical" SeparationOverride="4" MinWidth="150">
<PanelContainer Name="CurrentLanguageContainer" Access="Public" StyleClasses="PdaBorderRect">
<Label Name="CurrentLanguageLabel" Access="Public" Text="Current Language:" HorizontalExpand="True"></Label>
</PanelContainer>

<ui:HLine></ui:HLine>

<ScrollContainer HorizontalExpand="True" VerticalExpand="True" HScrollEnabled="False" VScrollEnabled="True" MinHeight="50">
<BoxContainer Name="OptionsList" Access="Public" HorizontalExpand="True" SeparationOverride="2" Orientation="Vertical">
<!-- The rest here is generated programmatically -->
</BoxContainer>
</ScrollContainer>
</BoxContainer>
</DefaultWindow>
121 changes: 121 additions & 0 deletions Content.Client/Language/LanguageMenuWindow.xaml.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,121 @@
using Content.Client.Language.Systems;
using Content.Shared.Language;
using Content.Shared.Language.Systems;
using Robust.Client.AutoGenerated;
using Robust.Client.UserInterface.Controls;
using Robust.Client.UserInterface.CustomControls;
using Robust.Client.UserInterface.XAML;
using Robust.Shared.Console;
using Robust.Shared.Utility;
using static Content.Shared.Language.Systems.SharedLanguageSystem;

namespace Content.Client.Language;

[GenerateTypedNameReferences]
public sealed partial class LanguageMenuWindow : DefaultWindow
{
private readonly LanguageSystem _clientLanguageSystem;
private readonly List<EntryState> _entries = new();

public LanguageMenuWindow()
{
RobustXamlLoader.Load(this);
_clientLanguageSystem = IoCManager.Resolve<IEntitySystemManager>().GetEntitySystem<LanguageSystem>();
}

public void UpdateState(string currentLanguage, List<string> spokenLanguages)
{
var langName = Loc.GetString($"language-{currentLanguage}-name");
CurrentLanguageLabel.Text = Loc.GetString("language-menu-current-language", ("language", langName));

OptionsList.RemoveAllChildren();
_entries.Clear();

foreach (var language in spokenLanguages)
{
AddLanguageEntry(language);
}

// Disable the button for the currently chosen language
foreach (var entry in _entries)
{
if (entry.button != null)
entry.button.Disabled = entry.language == currentLanguage;
}
}

private void AddLanguageEntry(string language)
{
var proto = _clientLanguageSystem.GetLanguage(language);
var state = new EntryState { language = language };

var container = new BoxContainer();
container.Orientation = BoxContainer.LayoutOrientation.Vertical;

// Create and add a header with the name and the button to select the language
{
var header = new BoxContainer();
header.Orientation = BoxContainer.LayoutOrientation.Horizontal;

header.Orientation = BoxContainer.LayoutOrientation.Horizontal;
header.HorizontalExpand = true;
header.SeparationOverride = 2;

var name = new Label();
name.Text = proto?.Name ?? "<error>";
name.MinWidth = 50;
name.HorizontalExpand = true;

var button = new Button();
button.Text = "Choose";
button.OnPressed += _ => OnLanguageChosen(language);
state.button = button;

header.AddChild(name);
header.AddChild(button);

container.AddChild(header);
}

// Create and add a collapsible description
{
var body = new CollapsibleBody();
body.HorizontalExpand = true;
body.Margin = new Thickness(4f, 4f);

var description = new RichTextLabel();
description.SetMessage(proto?.Description ?? "<error>");
description.HorizontalExpand = true;

body.AddChild(description);

var collapser = new Collapsible(Loc.GetString("language-menu-description-header"), body);
collapser.Orientation = BoxContainer.LayoutOrientation.Vertical;
collapser.HorizontalExpand = true;

container.AddChild(collapser);
}

// Before adding, wrap the new container in a PanelContainer to give it a distinct look
var wrapper = new PanelContainer();
wrapper.StyleClasses.Add("PdaBorderRect");

wrapper.AddChild(container);
OptionsList.AddChild(wrapper);

_entries.Add(state);
}

private void OnLanguageChosen(string id)
{
var proto = _clientLanguageSystem.GetLanguage(id);
if (proto != null)
_clientLanguageSystem.RequestSetLanguage(proto);
}

private struct EntryState
{
public string language;
public Button? button;
}
}
67 changes: 67 additions & 0 deletions Content.Client/Language/Systems/LanguageSystem.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,67 @@
using Content.Shared.Language;
using Content.Shared.Language.Events;
using Content.Shared.Language.Systems;
using Robust.Shared.Console;

namespace Content.Client.Language.Systems;

/// <summary>
/// Client-side language system.
/// </summary>
/// <remarks>
/// Unlike the server, the client is not aware of other entities' languages; it's only notified about the entity that it posesses.
/// Due to that, this system stores such information in a static manner.
/// </remarks>
public sealed class LanguageSystem : SharedLanguageSystem
{
/// <summary>
/// The current language of the entity currently possessed by the player.
/// </summary>
public string CurrentLanguage { get; private set; } = default!;
/// <summary>
/// The list of languages the currently possessed entity can speak.
/// </summary>
public List<string> SpokenLanguages { get; private set; } = new();
/// <summary>
/// The list of languages the currently possessed entity can understand.
/// </summary>
public List<string> UnderstoodLanguages { get; private set; } = new();

[Dependency] private readonly IConsoleHost _consoleHost = default!;

public override void Initialize()
{
SubscribeNetworkEvent<LanguagesUpdatedMessage>(OnLanguagesUpdated);
}

/// <summary>
/// Sends a network request to the server to update this system's state.
/// The server may ignore the said request if the player is not possessing an entity.
/// </summary>
public void RequestStateUpdate()
{
RaiseNetworkEvent(new RequestLanguagesMessage());
}

public void RequestSetLanguage(LanguagePrototype language)
{
// May cause some minor desync...
if (language.ID == CurrentLanguage)
return;

// (This is dumb. This is very dumb. It should be a message instead.)
// TODO Change this, soonish
_consoleHost.ExecuteCommand("languageselect " + language.ID);

// So to reduce the probability of desync, we replicate the change locally too
if (SpokenLanguages.Contains(language.ID))
CurrentLanguage = language.ID;
}

private void OnLanguagesUpdated(LanguagesUpdatedMessage message)
{
CurrentLanguage = message.CurrentLanguage;
SpokenLanguages = message.Spoken;
UnderstoodLanguages = message.Understood;
}
}
8 changes: 8 additions & 0 deletions Content.Client/Language/Systems/TranslatorImplanterSystem.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
using Content.Shared.Language.Systems;

namespace Content.Client.Language.Systems;

public sealed class TranslatorImplanterSystem : SharedTranslatorImplanterSystem
{

}
1 change: 1 addition & 0 deletions Content.Client/Options/UI/Tabs/KeyRebindTab.xaml.cs
Original file line number Diff line number Diff line change
Expand Up @@ -212,6 +212,7 @@ void AddCheckBox(string checkBoxName, bool currentState, Action<BaseButton.Butto
AddButton(ContentKeyFunctions.OpenCraftingMenu);
AddButton(ContentKeyFunctions.OpenGuidebook);
AddButton(ContentKeyFunctions.OpenInventoryMenu);
AddButton(ContentKeyFunctions.OpenLanguageMenu);
AddButton(ContentKeyFunctions.OpenAHelp);
AddButton(ContentKeyFunctions.OpenActionsMenu);
AddButton(ContentKeyFunctions.OpenEntitySpawnWindow);
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
using Content.Shared.Chat;
using Content.Shared.Input;
using Robust.Client.UserInterface;
using Robust.Client.UserInterface.Controls;

namespace Content.Client.UserInterface.Systems.Chat.Controls;
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,107 @@
using Content.Client.Language;
using Content.Client.Gameplay;
using Content.Client.UserInterface.Controls;
using Content.Shared.Input;
using Content.Shared.Language.Events;
using Robust.Client.UserInterface.Controllers;
using Robust.Client.UserInterface.Controls;
using Robust.Shared.Input.Binding;
using Robust.Shared.Utility;
using static Robust.Client.UserInterface.Controls.BaseButton;
using JetBrains.Annotations;

namespace Content.Client.UserInterface.Systems.Language;

[UsedImplicitly]
public sealed class LanguageMenuUIController : UIController, IOnStateEntered<GameplayState>, IOnStateExited<GameplayState>
{
public LanguageMenuWindow? _languageWindow;
private MenuButton? LanguageButton => UIManager.GetActiveUIWidgetOrNull<MenuBar.Widgets.GameTopMenuBar>()?.LanguageButton;

public override void Initialize()
{
SubscribeNetworkEvent((LanguagesUpdatedMessage message, EntitySessionEventArgs args) => _languageWindow?.UpdateState(message.CurrentLanguage, message.Spoken));
}

public void OnStateEntered(GameplayState state)
{
DebugTools.Assert(_languageWindow == null);

_languageWindow = UIManager.CreateWindow<LanguageMenuWindow>();
LayoutContainer.SetAnchorPreset(_languageWindow, LayoutContainer.LayoutPreset.CenterTop);

CommandBinds.Builder.Bind(ContentKeyFunctions.OpenLanguageMenu, InputCmdHandler.FromDelegate(_ => ToggleWindow())).Register<LanguageMenuUIController>();
}

public void OnStateExited(GameplayState state)
{
if (_languageWindow != null)
{
_languageWindow.Dispose();
_languageWindow = null;
}

CommandBinds.Unregister<LanguageMenuUIController>();
}

public void UnloadButton()
{
if (LanguageButton == null)
{
return;
}

LanguageButton.OnPressed -= LanguageButtonPressed;
}

public void LoadButton()
{
if (LanguageButton == null)
{
return;
}

LanguageButton.OnPressed += LanguageButtonPressed;

if (_languageWindow == null)
{
return;
}

_languageWindow.OnClose += DeactivateButton;
_languageWindow.OnOpen += ActivateButton;
}

private void DeactivateButton() => LanguageButton!.Pressed = false;
private void ActivateButton() => LanguageButton!.Pressed = true;

private void LanguageButtonPressed(ButtonEventArgs args)
{
ToggleWindow();
}

private void CloseWindow()
{
_languageWindow?.Close();
}

private void ToggleWindow()
{
if (_languageWindow == null)
return;

if (LanguageButton != null)
{
LanguageButton.SetClickPressed(!_languageWindow.IsOpen);
}

if (_languageWindow.IsOpen)
{
CloseWindow();
}
else
{
_languageWindow.Open();
}
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@
using Content.Client.UserInterface.Systems.MenuBar.Widgets;
using Content.Client.UserInterface.Systems.Sandbox;
using Robust.Client.UserInterface.Controllers;
using Content.Client.UserInterface.Systems.Language;

namespace Content.Client.UserInterface.Systems.MenuBar;

Expand All @@ -22,6 +23,7 @@ public sealed class GameTopMenuBarUIController : UIController
[Dependency] private readonly ActionUIController _action = default!;
[Dependency] private readonly SandboxUIController _sandbox = default!;
[Dependency] private readonly GuidebookUIController _guidebook = default!;
[Dependency] private readonly LanguageMenuUIController _language = default!;

private GameTopMenuBar? GameTopMenuBar => UIManager.GetActiveUIWidgetOrNull<GameTopMenuBar>();

Expand All @@ -44,6 +46,7 @@ public void UnloadButtons()
_ahelp.UnloadButton();
_action.UnloadButton();
_sandbox.UnloadButton();
_language.UnloadButton();
}

public void LoadButtons()
Expand All @@ -56,5 +59,6 @@ public void LoadButtons()
_ahelp.LoadButton();
_action.LoadButton();
_sandbox.LoadButton();
_language.LoadButton();
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -63,6 +63,16 @@
HorizontalExpand="True"
AppendStyleClass="{x:Static style:StyleBase.ButtonSquare}"
/>
<ui:MenuButton
Name="LanguageButton"
Access="Internal"
Icon="{xe:Tex '/Textures/Interface/language.png'}"
BoundKey = "{x:Static is:ContentKeyFunctions.OpenLanguageMenu}"
ToolTip="Open the Language Menu"
MinSize="42 64"
HorizontalExpand="True"
AppendStyleClass="{x:Static style:StyleBase.ButtonSquare}"
/>
<ui:MenuButton
Name="AdminButton"
Access="Internal"
Expand Down
Loading
Loading