From 6dd9512f0d8585b6c4d47fd954e251b736f6fdbd Mon Sep 17 00:00:00 2001 From: Jose Medrano Date: Mon, 11 Feb 2019 12:09:35 +0100 Subject: [PATCH] Differenciates between RadioButton and CheckBox frontend --- TestApps/Samples/Samples/ListView2.cs | 8 ++-- TestApps/Samples/Samples/ListViewCombos.cs | 8 ++-- TestApps/Samples/Samples/TreeViews.cs | 19 +++++---- .../CustomCellRendererToggle.cs | 14 ++++++- Xwt/Xwt.Backends/ICheckBoxCellViewFrontend.cs | 2 +- Xwt/Xwt.Backends/IComboBoxCellViewFrontend.cs | 12 ------ .../IRadioButtonCellViewFrontend.cs | 2 +- Xwt/Xwt.Backends/IToggleCellViewFrontend.cs | 3 +- Xwt/Xwt/CellEditingFinishedArgs.cs | 41 +++++++++++++++++++ Xwt/Xwt/RadioButtonCellView.cs | 4 +- 10 files changed, 78 insertions(+), 35 deletions(-) create mode 100644 Xwt/Xwt/CellEditingFinishedArgs.cs diff --git a/TestApps/Samples/Samples/ListView2.cs b/TestApps/Samples/Samples/ListView2.cs index 6fec8bc8e..c588578d9 100644 --- a/TestApps/Samples/Samples/ListView2.cs +++ b/TestApps/Samples/Samples/ListView2.cs @@ -37,7 +37,7 @@ public ListView2 () list.Columns.Add (new ListViewColumn("Not Editable", new CheckBoxCellView { Editable = false, ActiveField = nonEditableActiveField })); Xwt.Backends.IEditableCellViewFrontend stringCellView = new TextCellView { Editable = true, TextField = textField }; - stringCellView.EditingFinished += StringCellView_EditingFinished; + stringCellView.EditingFinished += CellView_EditingFinished; list.Columns.Add (new ListViewColumn("Editable",(CellView) stringCellView)); cellView = new CheckBoxCellView { EditableField = editableField, ActiveField = somewhatEditableData }; @@ -45,7 +45,7 @@ public ListView2 () list.Columns.Add(new ListViewColumn("Somewhat Editable",(CellView) cellView)); stringCellView = new TextCellView { EditableField = editableField, TextField = textField2 }; - stringCellView.EditingFinished += StringCellView_EditingFinished; + stringCellView.EditingFinished += CellView_EditingFinished; list.Columns.Add (new ListViewColumn("Somewhat Editable", (CellView)stringCellView)); @@ -64,12 +64,12 @@ public ListView2 () PackStart (list, true); } - void CellView_EditingFinished(object sender, Xwt.Backends.CellEditingFinishedArgs e) + void CellView_EditingFinished(object sender, Xwt.CellEditingFinishedArgs e) { Console.WriteLine("Your old value was '{0}' and now is '{1}'", e.OldValue, e.NewValue); } - void StringCellView_EditingFinished(object sender, Xwt.Backends.CellEditingFinishedArgs e) + void CellView_EditingFinished(object sender, Xwt.CellEditingFinishedArgs e) { Console.WriteLine("Your old value was '{0}' and now is '{1}'", e.OldValue, e.NewValue); } diff --git a/TestApps/Samples/Samples/ListViewCombos.cs b/TestApps/Samples/Samples/ListViewCombos.cs index d026bc883..3fb2e4c78 100644 --- a/TestApps/Samples/Samples/ListViewCombos.cs +++ b/TestApps/Samples/Samples/ListViewCombos.cs @@ -49,11 +49,11 @@ public ListViewCombos () comboCellView.Items.Add (1, "one"); comboCellView.Items.Add (2, "two"); comboCellView.Items.Add (3, "three"); - comboCellView.EditingFinished += TextCellView_EditingFinished; + comboCellView.EditingFinished += CellView_EditingFinished; list.Columns.Add (new ListViewColumn ("List 1", comboCellView)); var comboCellView2 = new ComboBoxCellView { Editable = true, SelectedIndexField = indexField2, ItemsField = itemsField }; - comboCellView2.EditingFinished += TextCellView_EditingFinished; + comboCellView2.EditingFinished += CellView_EditingFinished; list.Columns.Add (new ListViewColumn ("List 2", comboCellView2)); int p = 0; @@ -70,12 +70,12 @@ public ListViewCombos () PackStart (list, true); } - void ComboCellView_EditingFinished (object sender, Xwt.Backends.CellEditingFinishedArgs e) + void CellView_EditingFinished (object sender, CellEditingFinishedArgs e) { Console.WriteLine("Your old value was '{0}' and now is '{1}'", e.OldValue, e.NewValue); } - void TextCellView_EditingFinished(object sender, Xwt.Backends.CellEditingFinishedArgs e) + void CellView_EditingFinished(object sender, CellEditingFinishedArgs e) { Console.WriteLine("Your old value was '{0}' and now is '{1}'", e.OldValue, e.NewValue); } diff --git a/TestApps/Samples/Samples/TreeViews.cs b/TestApps/Samples/Samples/TreeViews.cs index a78e78b6b..db9ccb947 100644 --- a/TestApps/Samples/Samples/TreeViews.cs +++ b/TestApps/Samples/Samples/TreeViews.cs @@ -54,7 +54,7 @@ public TreeViews () store.GetNavigatorAt(view.CurrentEventRow).SetValue(text, "TriState Toggled"); } }; - triStateCellView.EditingFinished += CheckBoxCellView_EditingFinished; + triStateCellView.EditingFinished += CellView_EditingFinished; var checkCellView = new CheckBoxCellView (check) { Editable = true }; checkCellView.Toggled += (object sender, WidgetEventArgs e) => { if (view.CurrentEventRow == null) { @@ -64,7 +64,7 @@ public TreeViews () store.GetNavigatorAt(view.CurrentEventRow).SetValue(text, "Toggled " + checkCellView.Active); } }; - checkCellView.EditingFinished += CheckBoxCellView_EditingFinished; + checkCellView.EditingFinished += CellView_EditingFinished; var optionCellView1 = new RadioButtonCellView (option1) { Editable = true }; optionCellView1.Toggled += (object sender, WidgetEventArgs e) => { if (view.CurrentEventRow == null) { @@ -73,7 +73,7 @@ public TreeViews () store.GetNavigatorAt (view.CurrentEventRow).SetValue (option2, optionCellView1.Active); } }; - optionCellView1.EditingFinished += CheckBoxCellView_EditingFinished; + optionCellView1.EditingFinished += CellView_EditingFinished; var optionCellView2 = new RadioButtonCellView (option2) { Editable = true }; optionCellView2.Toggled += (object sender, WidgetEventArgs e) => { @@ -83,7 +83,7 @@ public TreeViews () store.GetNavigatorAt (view.CurrentEventRow).SetValue (option1, optionCellView2.Active); } }; - optionCellView2.EditingFinished += CheckBoxCellView_EditingFinished; + optionCellView2.EditingFinished += CellView_EditingFinished; TreePosition initialActive = null; var optionCellView3 = new RadioButtonCellView (option3) { Editable = true }; @@ -96,7 +96,7 @@ public TreeViews () initialActive = view.CurrentEventRow; } }; - optionCellView3.EditingFinished += CheckBoxCellView_EditingFinished; + optionCellView3.EditingFinished += CellView_EditingFinished; view.Columns.Add ("TriCheck", triStateCellView); view.Columns.Add ("Check", checkCellView); view.Columns.Add ("Radio", optionCellView1, optionCellView2, optionCellView3); @@ -235,12 +235,17 @@ public TreeViews () view.RowExpanded += (sender, e) => label.Text = "Row expanded: " + store.GetNavigatorAt (e.Position).GetValue (text); } - void CheckBoxCellView_EditingFinished (object sender, Xwt.Backends.CellEditingFinishedArgs e) + void CellView_EditingFinished(object sender, Xwt.CellEditingFinishedArgs e) { Console.WriteLine("Your old value was '{0}' and now is '{1}'", e.OldValue, e.NewValue); } - void StringCellView_EditingFinished(object sender, Xwt.Backends.CellEditingFinishedArgs e) + void CellView_EditingFinished(object sender, Xwt.CellEditingFinishedArgs e) + { + Console.WriteLine("Your old value was '{0}' and now is '{1}'", e.OldValue, e.NewValue); + } + + void CellView_EditingFinished(object sender, Xwt.CellEditingFinishedArgs e) { Console.WriteLine("Your old value was '{0}' and now is '{1}'", e.OldValue, e.NewValue); } diff --git a/Xwt.Gtk/Xwt.GtkBackend.CellViews/CustomCellRendererToggle.cs b/Xwt.Gtk/Xwt.GtkBackend.CellViews/CustomCellRendererToggle.cs index b87bfeefb..e40600838 100644 --- a/Xwt.Gtk/Xwt.GtkBackend.CellViews/CustomCellRendererToggle.cs +++ b/Xwt.Gtk/Xwt.GtkBackend.CellViews/CustomCellRendererToggle.cs @@ -92,12 +92,22 @@ void HandleToggled (object o, ToggledArgs args) (object) newState : (object) (newState == CheckBoxState.On); CellUtil.SetModelValue (TreeModel, iter, field.Index, type, newValue); - view.RaiseEditingFinished(new CellEditingFinishedArgs (lastValue, newState)); + + if (view is ICheckBoxCellViewFrontend) { + ((ICheckBoxCellViewFrontend)view).RaiseEditingFinished(new CellEditingFinishedArgs(lastValue, newState)); + } else if (view is IRadioButtonCellViewFrontend) { + ((IRadioButtonCellViewFrontend)view).RaiseEditingFinished(new CellEditingFinishedArgs(lastValue == CheckBoxState.On, newState == CheckBoxState.On)); + } + lastValue = newState; return; } - view.RaiseEditingFinished (new CellEditingFinishedArgs (lastValue, lastValue)); + if (view is ICheckBoxCellViewFrontend) { + ((ICheckBoxCellViewFrontend)view).RaiseEditingFinished(new CellEditingFinishedArgs(lastValue, lastValue)); + } else if (view is IRadioButtonCellViewFrontend) { + ((IRadioButtonCellViewFrontend)view).RaiseEditingFinished(new CellEditingFinishedArgs(lastValue == CheckBoxState.On, lastValue == CheckBoxState.On)); + } } } } diff --git a/Xwt/Xwt.Backends/ICheckBoxCellViewFrontend.cs b/Xwt/Xwt.Backends/ICheckBoxCellViewFrontend.cs index b7b79a137..714f3d433 100644 --- a/Xwt/Xwt.Backends/ICheckBoxCellViewFrontend.cs +++ b/Xwt/Xwt.Backends/ICheckBoxCellViewFrontend.cs @@ -27,7 +27,7 @@ namespace Xwt.Backends { - public interface ICheckBoxCellViewFrontend: IToggleCellViewFrontend + public interface ICheckBoxCellViewFrontend: IToggleCellViewFrontend, IEditableCellViewFrontend { CheckBoxState State { get; } bool AllowMixed { get; } diff --git a/Xwt/Xwt.Backends/IComboBoxCellViewFrontend.cs b/Xwt/Xwt.Backends/IComboBoxCellViewFrontend.cs index bccc67b3e..8aec8aa16 100644 --- a/Xwt/Xwt.Backends/IComboBoxCellViewFrontend.cs +++ b/Xwt/Xwt.Backends/IComboBoxCellViewFrontend.cs @@ -27,18 +27,6 @@ namespace Xwt.Backends { - public class CellEditingFinishedArgs : EventArgs - { - public CellEditingFinishedArgs(T oldValue, T newValue) - { - OldValue = oldValue; - NewValue = newValue; - } - - public T OldValue { get; set; } - public T NewValue { get; set; } - } - public interface IEditableCellViewFrontend { event EventHandler> EditingFinished; diff --git a/Xwt/Xwt.Backends/IRadioButtonCellViewFrontend.cs b/Xwt/Xwt.Backends/IRadioButtonCellViewFrontend.cs index 3ce06296d..b82071911 100644 --- a/Xwt/Xwt.Backends/IRadioButtonCellViewFrontend.cs +++ b/Xwt/Xwt.Backends/IRadioButtonCellViewFrontend.cs @@ -26,7 +26,7 @@ namespace Xwt.Backends { - public interface IRadioButtonCellViewFrontend: IToggleCellViewFrontend + public interface IRadioButtonCellViewFrontend: IToggleCellViewFrontend, IEditableCellViewFrontend { } } diff --git a/Xwt/Xwt.Backends/IToggleCellViewFrontend.cs b/Xwt/Xwt.Backends/IToggleCellViewFrontend.cs index 0ba888a6f..ed5e72440 100644 --- a/Xwt/Xwt.Backends/IToggleCellViewFrontend.cs +++ b/Xwt/Xwt.Backends/IToggleCellViewFrontend.cs @@ -26,8 +26,7 @@ namespace Xwt.Backends { - - public interface IToggleCellViewFrontend : ICellViewFrontend, IEditableCellViewFrontend + public interface IToggleCellViewFrontend : ICellViewFrontend { bool Active { get; } bool Editable { get; } diff --git a/Xwt/Xwt/CellEditingFinishedArgs.cs b/Xwt/Xwt/CellEditingFinishedArgs.cs new file mode 100644 index 000000000..b282b4c88 --- /dev/null +++ b/Xwt/Xwt/CellEditingFinishedArgs.cs @@ -0,0 +1,41 @@ +// +// IComboBoxCellViewFrontend.cs +// +// Author: +// Lluis Sanchez Gual +// +// Copyright (c) 2016 Xamarin, Inc (http://www.xamarin.com) +// +// Permission is hereby granted, free of charge, to any person obtaining a copy +// of this software and associated documentation files (the "Software"), to deal +// in the Software without restriction, including without limitation the rights +// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +// copies of the Software, and to permit persons to whom the Software is +// furnished to do so, subject to the following conditions: +// +// The above copyright notice and this permission notice shall be included in +// all copies or substantial portions of the Software. +// +// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +// THE SOFTWARE. +using System; + +namespace Xwt +{ + public class CellEditingFinishedArgs : EventArgs + { + public CellEditingFinishedArgs(T oldValue, T newValue) + { + OldValue = oldValue; + NewValue = newValue; + } + + public T OldValue { get; set; } + public T NewValue { get; set; } + } +} diff --git a/Xwt/Xwt/RadioButtonCellView.cs b/Xwt/Xwt/RadioButtonCellView.cs index 3ad1cef2d..096df96f1 100644 --- a/Xwt/Xwt/RadioButtonCellView.cs +++ b/Xwt/Xwt/RadioButtonCellView.cs @@ -80,9 +80,9 @@ public bool RaiseToggled () return false; } - public event EventHandler> EditingFinished; + public event EventHandler> EditingFinished; - public void RaiseEditingFinished (CellEditingFinishedArgs args) + public void RaiseEditingFinished (CellEditingFinishedArgs args) { EditingFinished?.Invoke (this, args); }