From 045ffba4572b96f0bdd52a71517e543b47663a34 Mon Sep 17 00:00:00 2001 From: Maud Date: Tue, 30 Jan 2024 23:39:32 +0100 Subject: [PATCH] Listview with multiple selections --- .../behaviours/DataComponentSelectedItems.hx | 78 +++++++++++++++++++ .../behaviours/ListViewSelectedIndices.hx | 35 +++++++++ .../hxwidgets/creators/ListViewCreator.hx | 21 +++++ .../hxwidgets/custom/SimpleListView.hx | 2 +- haxe/ui/backend/native.xml | 4 +- 5 files changed, 138 insertions(+), 2 deletions(-) create mode 100644 haxe/ui/backend/hxwidgets/behaviours/DataComponentSelectedItems.hx create mode 100644 haxe/ui/backend/hxwidgets/behaviours/ListViewSelectedIndices.hx create mode 100644 haxe/ui/backend/hxwidgets/creators/ListViewCreator.hx diff --git a/haxe/ui/backend/hxwidgets/behaviours/DataComponentSelectedItems.hx b/haxe/ui/backend/hxwidgets/behaviours/DataComponentSelectedItems.hx new file mode 100644 index 0000000..5277968 --- /dev/null +++ b/haxe/ui/backend/hxwidgets/behaviours/DataComponentSelectedItems.hx @@ -0,0 +1,78 @@ +package haxe.ui.backend.hxwidgets.behaviours; + +import haxe.ui.data.DataSource; +import haxe.ui.behaviours.DataBehaviour; +import haxe.ui.components.DropDown; +import haxe.ui.containers.ListView; +import haxe.ui.core.IDataComponent; +import haxe.ui.util.Variant; + +class DataComponentSelectedItems extends DataBehaviour { + + public override function get():Variant { + if ((_component is IDataComponent) == false) { + return false; + } + + var dataComponent:IDataComponent = cast(_component, IDataComponent); + var ds = dataComponent.dataSource; + var selectedItems:Array = []; + + if ((_component is ListView)) { + var listview = cast(_component, ListView); + for (i in listview.selectedIndices) { + selectedItems.push(ds.get(i)); + } + } + + return selectedItems; + } + + public override function set(value:Variant):Void { + _value = value; + var dataComponent:IDataComponent = cast(_component, IDataComponent); + var selectedIndices = []; + + var ds = dataComponent.dataSource; + var values:Array = value; + for (item in values) { + var selectedIndex = findIndexOfItem(value, ds); + selectedIndices.push(selectedIndex); + } + + if ((_component is ListView)) { + var listview = cast(_component, ListView).selectedIndices = selectedIndices; + } + } + + private function findIndexOfItem(value:Dynamic, ds:DataSource) { + var n = -1; + + var text = valueToString(value); + if (text == null) { + return -1; + } + + for (i in 0...ds.size) { + if (text == valueToString(ds.get(i))) { + n = i; + break; + } + } + + return n; + } + + private function valueToString(value:Dynamic):String { + var text = null; + if (Type.typeof(value) == TObject) { + text = value.text; + if (text == null) { + text = value.value; + } + } else { + text = Std.string(value); + } + return text; + } +} \ No newline at end of file diff --git a/haxe/ui/backend/hxwidgets/behaviours/ListViewSelectedIndices.hx b/haxe/ui/backend/hxwidgets/behaviours/ListViewSelectedIndices.hx new file mode 100644 index 0000000..d68e7b2 --- /dev/null +++ b/haxe/ui/backend/hxwidgets/behaviours/ListViewSelectedIndices.hx @@ -0,0 +1,35 @@ +package haxe.ui.backend.hxwidgets.behaviours; + +import haxe.ui.behaviours.DataBehaviour; +import haxe.ui.util.Variant; +import hx.widgets.ListView; + +class ListViewSelectedIndices extends DataBehaviour { + + private override function validateData() { + if (_component.window == null) { + return; + } + + if (!_value.isArray) { + return; + } + + var view:ListView = cast(_component.window, ListView); + view.selectedIndexes = _value; + + for (i in (_value:Array)) { + view.ensureVisible(i); + } + } + + public override function get():Variant { + if (_component.window == null) { + return -1; + } + + var view:ListView = cast(_component.window, ListView); + return view.selectedIndexes; + + } +} \ No newline at end of file diff --git a/haxe/ui/backend/hxwidgets/creators/ListViewCreator.hx b/haxe/ui/backend/hxwidgets/creators/ListViewCreator.hx new file mode 100644 index 0000000..a09dbed --- /dev/null +++ b/haxe/ui/backend/hxwidgets/creators/ListViewCreator.hx @@ -0,0 +1,21 @@ +package haxe.ui.backend.hxwidgets.creators; +import haxe.ui.containers.ListView; +import haxe.ui.constants.SelectionMode; +import hx.widgets.Defs; +import hx.widgets.styles.ListCtrlStyle; + +class ListViewCreator extends Creator { + private var _listView:ListView; + + public function new(listView:ListView) { + super(listView); + _listView = listView; + } + + public override function createConstructorParams(params:Array):Array { + var style = 0; + if (_listView.selectionMode == SelectionMode.ONE_ITEM) style |= ListCtrlStyle.SINGLE_SEL; + params.push(style); + return params; + } +} \ No newline at end of file diff --git a/haxe/ui/backend/hxwidgets/custom/SimpleListView.hx b/haxe/ui/backend/hxwidgets/custom/SimpleListView.hx index 7252566..876350e 100644 --- a/haxe/ui/backend/hxwidgets/custom/SimpleListView.hx +++ b/haxe/ui/backend/hxwidgets/custom/SimpleListView.hx @@ -8,7 +8,7 @@ import hx.widgets.styles.ListCtrlStyle; class SimpleListView extends ListView { public function new(parent:Window, style:Int = 0, id:Int = -1) { - super(parent, ListCtrlStyle.REPORT | ListCtrlStyle.NO_HEADER | ListCtrlStyle.SINGLE_SEL | style, id); + super(parent, ListCtrlStyle.REPORT | ListCtrlStyle.NO_HEADER | style, id); appendColumn(""); bind(EventType.SIZE, onResized); } diff --git a/haxe/ui/backend/native.xml b/haxe/ui/backend/native.xml index cb2354f..a6f2a74 100644 --- a/haxe/ui/backend/native.xml +++ b/haxe/ui/backend/native.xml @@ -1,10 +1,12 @@ - + + +