From f782a1245d8737db2eeaad1939f3fbc17749f4f1 Mon Sep 17 00:00:00 2001 From: Alejandro Alvarez Melucci <163010988+AlejandroAlvarezMelucciDCL@users.noreply.github.com> Date: Fri, 28 Jun 2024 11:05:37 -0300 Subject: [PATCH] chore: re introduce uitext wrapping (#6228) Re-introduced ui text wrap with no-wrap as the default behavior --- scripts/package-lock.json | 14 ++-- scripts/package.json | 2 +- .../ECSComponents/UIText/UiTextHandler.cs | 6 ++ .../DCL/DecentralandProtocol/UiText.gen.cs | 78 +++++++++++++++++-- 4 files changed, 85 insertions(+), 15 deletions(-) diff --git a/scripts/package-lock.json b/scripts/package-lock.json index 06ddd45b22..84ebe85bba 100644 --- a/scripts/package-lock.json +++ b/scripts/package-lock.json @@ -9,7 +9,7 @@ "version": "1.0.0", "license": "Apache-2.0", "dependencies": { - "@dcl/protocol": "^1.0.0-9115457439.commit-926ebd1", + "@dcl/protocol": "^1.0.0-9466805132.commit-365e0bb", "@protobuf-ts/protoc": "^2.8.2", "@types/fs-extra": "^11.0.1", "@types/glob": "^8.0.1", @@ -36,9 +36,9 @@ } }, "node_modules/@dcl/protocol": { - "version": "1.0.0-9115457439.commit-926ebd1", - "resolved": "https://registry.npmjs.org/@dcl/protocol/-/protocol-1.0.0-9115457439.commit-926ebd1.tgz", - "integrity": "sha512-4MA1sx4cpfapP+EDAZdpdaONthoDlv4VMc0CwAKcmhp0vxGgExeEpLkPh6gvNXmkl8z8z3nEcDOX1X95dvCYuA==", + "version": "1.0.0-9466805132.commit-365e0bb", + "resolved": "https://registry.npmjs.org/@dcl/protocol/-/protocol-1.0.0-9466805132.commit-365e0bb.tgz", + "integrity": "sha512-CMO2/JkdMPLJQj+jdT5yqolKFDPkQF2hkS/HEUtsxCzkLoN3H0xXmDUhRuh2LTmBBl401meH/tJ+fQcPyd9xLQ==", "dependencies": { "@dcl/ts-proto": "1.154.0" } @@ -569,9 +569,9 @@ } }, "@dcl/protocol": { - "version": "1.0.0-9115457439.commit-926ebd1", - "resolved": "https://registry.npmjs.org/@dcl/protocol/-/protocol-1.0.0-9115457439.commit-926ebd1.tgz", - "integrity": "sha512-4MA1sx4cpfapP+EDAZdpdaONthoDlv4VMc0CwAKcmhp0vxGgExeEpLkPh6gvNXmkl8z8z3nEcDOX1X95dvCYuA==", + "version": "1.0.0-9466805132.commit-365e0bb", + "resolved": "https://registry.npmjs.org/@dcl/protocol/-/protocol-1.0.0-9466805132.commit-365e0bb.tgz", + "integrity": "sha512-CMO2/JkdMPLJQj+jdT5yqolKFDPkQF2hkS/HEUtsxCzkLoN3H0xXmDUhRuh2LTmBBl401meH/tJ+fQcPyd9xLQ==", "requires": { "@dcl/ts-proto": "1.154.0" } diff --git a/scripts/package.json b/scripts/package.json index 34bf9a475b..662dd18886 100644 --- a/scripts/package.json +++ b/scripts/package.json @@ -16,7 +16,7 @@ "typescript": "^4.2.3" }, "dependencies": { - "@dcl/protocol": "^1.0.0-9115457439.commit-926ebd1", + "@dcl/protocol": "^1.0.0-9466805132.commit-365e0bb", "@protobuf-ts/protoc": "^2.8.2", "@types/fs-extra": "^11.0.1", "@types/glob": "^8.0.1", diff --git a/unity-renderer/Assets/DCLPlugins/ECS7/ECSComponents/UIText/UiTextHandler.cs b/unity-renderer/Assets/DCLPlugins/ECS7/ECSComponents/UIText/UiTextHandler.cs index 859df20cdf..7867b62440 100644 --- a/unity-renderer/Assets/DCLPlugins/ECS7/ECSComponents/UIText/UiTextHandler.cs +++ b/unity-renderer/Assets/DCLPlugins/ECS7/ECSComponents/UIText/UiTextHandler.cs @@ -38,7 +38,13 @@ public void OnComponentRemoved(IParcelScene scene, IDCLEntity entity) public void OnComponentModelUpdated(IParcelScene scene, IDCLEntity entity, PBUiText model) { + var wrapMode = WhiteSpace.NoWrap; // Default mode is No Wrap enabled + + if (model.HasTextWrap && model.TextWrap == TextWrap.TwWrap) + wrapMode = WhiteSpace.Normal; + uiElement.text = model.Value; + uiElement.style.whiteSpace = wrapMode; uiElement.style.color = model.GetColor().ToUnityColor(); uiElement.style.fontSize = model.GetFontSize(); uiElement.style.unityTextAlign = model.GetTextAlign().ToUnityTextAlign(); diff --git a/unity-renderer/Assets/Scripts/MainScripts/DCL/DecentralandProtocol/UiText.gen.cs b/unity-renderer/Assets/Scripts/MainScripts/DCL/DecentralandProtocol/UiText.gen.cs index c67d9c843e..fd57440d07 100644 --- a/unity-renderer/Assets/Scripts/MainScripts/DCL/DecentralandProtocol/UiText.gen.cs +++ b/unity-renderer/Assets/Scripts/MainScripts/DCL/DecentralandProtocol/UiText.gen.cs @@ -27,23 +27,34 @@ static UiTextReflection() { "CilkZWNlbnRyYWxhbmQvc2RrL2NvbXBvbmVudHMvdWlfdGV4dC5wcm90bxIb", "ZGVjZW50cmFsYW5kLnNkay5jb21wb25lbnRzGiBkZWNlbnRyYWxhbmQvY29t", "bW9uL2NvbG9ycy5wcm90bxouZGVjZW50cmFsYW5kL3Nkay9jb21wb25lbnRz", - "L2NvbW1vbi90ZXh0cy5wcm90byKbAgoIUEJVaVRleHQSDQoFdmFsdWUYASAB", + "L2NvbW1vbi90ZXh0cy5wcm90byLoAgoIUEJVaVRleHQSDQoFdmFsdWUYASAB", "KAkSLwoFY29sb3IYAiABKAsyGy5kZWNlbnRyYWxhbmQuY29tbW9uLkNvbG9y", "NEgAiAEBEkoKCnRleHRfYWxpZ24YAyABKA4yMS5kZWNlbnRyYWxhbmQuc2Rr", "LmNvbXBvbmVudHMuY29tbW9uLlRleHRBbGlnbk1vZGVIAYgBARI7CgRmb250", "GAQgASgOMiguZGVjZW50cmFsYW5kLnNkay5jb21wb25lbnRzLmNvbW1vbi5G", - "b250SAKIAQESFgoJZm9udF9zaXplGAUgASgFSAOIAQFCCAoGX2NvbG9yQg0K", - "C190ZXh0X2FsaWduQgcKBV9mb250QgwKCl9mb250X3NpemVCFKoCEURDTC5F", - "Q1NDb21wb25lbnRzYgZwcm90bzM=")); + "b250SAKIAQESFgoJZm9udF9zaXplGAUgASgFSAOIAQESPQoJdGV4dF93cmFw", + "GAYgASgOMiUuZGVjZW50cmFsYW5kLnNkay5jb21wb25lbnRzLlRleHRXcmFw", + "SASIAQFCCAoGX2NvbG9yQg0KC190ZXh0X2FsaWduQgcKBV9mb250QgwKCl9m", + "b250X3NpemVCDAoKX3RleHRfd3JhcConCghUZXh0V3JhcBILCgdUV19XUkFQ", + "EAASDgoKVFdfTk9fV1JBUBABQhSqAhFEQ0wuRUNTQ29tcG9uZW50c2IGcHJv", + "dG8z")); descriptor = pbr::FileDescriptor.FromGeneratedCode(descriptorData, new pbr::FileDescriptor[] { global::Decentraland.Common.ColorsReflection.Descriptor, global::DCL.ECSComponents.TextsReflection.Descriptor, }, - new pbr::GeneratedClrTypeInfo(null, null, new pbr::GeneratedClrTypeInfo[] { - new pbr::GeneratedClrTypeInfo(typeof(global::DCL.ECSComponents.PBUiText), global::DCL.ECSComponents.PBUiText.Parser, new[]{ "Value", "Color", "TextAlign", "Font", "FontSize" }, new[]{ "Color", "TextAlign", "Font", "FontSize" }, null, null, null) + new pbr::GeneratedClrTypeInfo(new[] {typeof(global::DCL.ECSComponents.TextWrap), }, null, new pbr::GeneratedClrTypeInfo[] { + new pbr::GeneratedClrTypeInfo(typeof(global::DCL.ECSComponents.PBUiText), global::DCL.ECSComponents.PBUiText.Parser, new[]{ "Value", "Color", "TextAlign", "Font", "FontSize", "TextWrap" }, new[]{ "Color", "TextAlign", "Font", "FontSize", "TextWrap" }, null, null, null) })); } #endregion } + #region Enums + public enum TextWrap { + [pbr::OriginalName("TW_WRAP")] TwWrap = 0, + [pbr::OriginalName("TW_NO_WRAP")] TwNoWrap = 1, + } + + #endregion + #region Messages public sealed partial class PBUiText : pb::IMessage #if !GOOGLE_PROTOBUF_REFSTRUCT_COMPATIBILITY_MODE @@ -86,6 +97,7 @@ public PBUiText(PBUiText other) : this() { textAlign_ = other.textAlign_; font_ = other.font_; fontSize_ = other.fontSize_; + textWrap_ = other.textWrap_; _unknownFields = pb::UnknownFieldSet.Clone(other._unknownFields); } @@ -99,7 +111,7 @@ public PBUiText Clone() { public const int ValueFieldNumber = 1; private string value_ = ""; /// - /// the text content + /// the text content, tag <b> and <i> are supported /// [global::System.Diagnostics.DebuggerNonUserCodeAttribute] [global::System.CodeDom.Compiler.GeneratedCode("protoc", null)] @@ -209,6 +221,34 @@ public void ClearFontSize() { _hasBits0 &= ~4; } + /// Field number for the "text_wrap" field. + public const int TextWrapFieldNumber = 6; + private global::DCL.ECSComponents.TextWrap textWrap_; + /// + /// wrap text when the border is reached (default: TW_WRAP) + /// + [global::System.Diagnostics.DebuggerNonUserCodeAttribute] + [global::System.CodeDom.Compiler.GeneratedCode("protoc", null)] + public global::DCL.ECSComponents.TextWrap TextWrap { + get { if ((_hasBits0 & 8) != 0) { return textWrap_; } else { return global::DCL.ECSComponents.TextWrap.TwWrap; } } + set { + _hasBits0 |= 8; + textWrap_ = value; + } + } + /// Gets whether the "text_wrap" field is set + [global::System.Diagnostics.DebuggerNonUserCodeAttribute] + [global::System.CodeDom.Compiler.GeneratedCode("protoc", null)] + public bool HasTextWrap { + get { return (_hasBits0 & 8) != 0; } + } + /// Clears the value of the "text_wrap" field + [global::System.Diagnostics.DebuggerNonUserCodeAttribute] + [global::System.CodeDom.Compiler.GeneratedCode("protoc", null)] + public void ClearTextWrap() { + _hasBits0 &= ~8; + } + [global::System.Diagnostics.DebuggerNonUserCodeAttribute] [global::System.CodeDom.Compiler.GeneratedCode("protoc", null)] public override bool Equals(object other) { @@ -229,6 +269,7 @@ public bool Equals(PBUiText other) { if (TextAlign != other.TextAlign) return false; if (Font != other.Font) return false; if (FontSize != other.FontSize) return false; + if (TextWrap != other.TextWrap) return false; return Equals(_unknownFields, other._unknownFields); } @@ -241,6 +282,7 @@ public override int GetHashCode() { if (HasTextAlign) hash ^= TextAlign.GetHashCode(); if (HasFont) hash ^= Font.GetHashCode(); if (HasFontSize) hash ^= FontSize.GetHashCode(); + if (HasTextWrap) hash ^= TextWrap.GetHashCode(); if (_unknownFields != null) { hash ^= _unknownFields.GetHashCode(); } @@ -279,6 +321,10 @@ public void WriteTo(pb::CodedOutputStream output) { output.WriteRawTag(40); output.WriteInt32(FontSize); } + if (HasTextWrap) { + output.WriteRawTag(48); + output.WriteEnum((int) TextWrap); + } if (_unknownFields != null) { _unknownFields.WriteTo(output); } @@ -309,6 +355,10 @@ public void WriteTo(pb::CodedOutputStream output) { output.WriteRawTag(40); output.WriteInt32(FontSize); } + if (HasTextWrap) { + output.WriteRawTag(48); + output.WriteEnum((int) TextWrap); + } if (_unknownFields != null) { _unknownFields.WriteTo(ref output); } @@ -334,6 +384,9 @@ public int CalculateSize() { if (HasFontSize) { size += 1 + pb::CodedOutputStream.ComputeInt32Size(FontSize); } + if (HasTextWrap) { + size += 1 + pb::CodedOutputStream.ComputeEnumSize((int) TextWrap); + } if (_unknownFields != null) { size += _unknownFields.CalculateSize(); } @@ -364,6 +417,9 @@ public void MergeFrom(PBUiText other) { if (other.HasFontSize) { FontSize = other.FontSize; } + if (other.HasTextWrap) { + TextWrap = other.TextWrap; + } _unknownFields = pb::UnknownFieldSet.MergeFrom(_unknownFields, other._unknownFields); } @@ -402,6 +458,10 @@ public void MergeFrom(pb::CodedInputStream input) { FontSize = input.ReadInt32(); break; } + case 48: { + TextWrap = (global::DCL.ECSComponents.TextWrap) input.ReadEnum(); + break; + } } } #endif @@ -440,6 +500,10 @@ public void MergeFrom(pb::CodedInputStream input) { FontSize = input.ReadInt32(); break; } + case 48: { + TextWrap = (global::DCL.ECSComponents.TextWrap) input.ReadEnum(); + break; + } } } }