diff --git a/src/Avalonia.Controls.TreeDataGrid/Models/TreeDataGrid/TextCell.cs b/src/Avalonia.Controls.TreeDataGrid/Models/TreeDataGrid/TextCell.cs index fe721f5b..5358b2cd 100644 --- a/src/Avalonia.Controls.TreeDataGrid/Models/TreeDataGrid/TextCell.cs +++ b/src/Avalonia.Controls.TreeDataGrid/Models/TreeDataGrid/TextCell.cs @@ -49,7 +49,10 @@ public TextCell( public string? Text { get => _value?.ToString(); - set{ + set + { + if (IsReadOnly || !_isEditing) return; + if (string.IsNullOrEmpty(value)) { Value = default(T?); diff --git a/tests/Avalonia.Controls.TreeDataGrid.Tests/Models/TextCellTests.cs b/tests/Avalonia.Controls.TreeDataGrid.Tests/Models/TextCellTests.cs index 44931703..6956d54f 100644 --- a/tests/Avalonia.Controls.TreeDataGrid.Tests/Models/TextCellTests.cs +++ b/tests/Avalonia.Controls.TreeDataGrid.Tests/Models/TextCellTests.cs @@ -1,13 +1,10 @@ using System; using System.Collections.Generic; -using System.Linq; +using System.Globalization; using System.Reactive.Subjects; -using System.Text; -using System.Threading.Tasks; using Avalonia.Controls.Models.TreeDataGrid; using Avalonia.Data; using Avalonia.Headless.XUnit; -using Avalonia.Media; using Xunit; namespace Avalonia.Controls.TreeDataGridTests.Models @@ -95,5 +92,38 @@ public void Modified_Value_Is_Not_Written_To_Binding_On_CancelEdit() Assert.Equal("initial", target.Value); Assert.Equal(new[] { "initial" }, result); } + + [AvaloniaFact(Timeout = 10000)] + public void Setting_Text_Does_Not_Change_ReadOnly_Value() + { + var binding = new BehaviorSubject>(value: new CustomValueObject(100)); + var target = new TextCell(binding, isReadOnly: true); + + Assert.Equal(100, target.Value.Value); + + // simulating TreeDataGridTextCell.OnModelPropertyChanged + target.PropertyChanged += (sender, args) => + { + if (args.PropertyName == nameof(ITextCell.Value)) + target.Text = target.Value.ToString(); + }; + + target.Value = new CustomValueObject(42); + Assert.Equal(42, target.Value.Value); + } + + private readonly struct CustomValueObject + { + private readonly int _value; + + public CustomValueObject(int value) + { + _value = value; + } + + public int Value => _value; + + public override string ToString() => _value.ToString(CultureInfo.InvariantCulture); + } } }