lightswitch Grid 控件添加 CheckBox 多选
ACTIVATING MULTI SELECTION WITH CHECKBOXES IN A LIGHTSWITCH GRID WITH A ONE-LINER
Introduction
In a business app grid, you often need the ability the select multiple rows and apply an action on the selected rows.
Wouldn’t it be great if we could inject this via following “one-liner”;
ObservableCollection<Product> SelectedProducts = new ObservableCollection<Product>(); partial void EditableProductsGrid1_InitializeDataWorkspace(List<IDataService> saveChangesTo) { this .FindControl( "grid" ).AddCheckBoxColumnForMultiSelection<Product>(SelectedProducts); } |
The line that really matters is the extension method “AddCheckBoxColumnForMultiSelection”. It takes at input an ObservableCollection which will hold the selected items.
As you can see, there is a button called “Do Something With Selection”. We can tweak also the CanExecute behavior as follows:
1
2
3
4
5
6
7
8
9
10
11
12
|
partial void DoSomethingWithSelection_Execute() { foreach ( var item in SelectedProducts) { this .ShowMessageBox(item.ProductName); } } partial void DoSomethingWithSelection_CanExecute(ref bool result) { result = this .Products.SelectedItem != null && SelectedProducts.Count >= 1 ; ; } |
This will make sure the button is not clickable if there are no checkboxes checked.
What’s our base infrastructure for doing this?
That’s a bit more involved. But it doesn’t matter, since it’s implemented as an extension method, the whole functionality becomes a … one liner.
using Microsoft.LightSwitch; using Microsoft.LightSwitch.Client; using Microsoft.LightSwitch.Presentation; using System; using System.Linq; using System.Collections.ObjectModel; using System.Net; using System.Windows; using System.Windows.Controls; using System.Windows.Documents; using System.Windows.Ink; using System.Windows.Input; using System.Windows.Markup; using System.Windows.Media; using System.Windows.Media.Animation; using System.Windows.Shapes; using Microsoft.LightSwitch.Framework.Client; using Microsoft.LightSwitch.Presentation.Extensions; using System.Diagnostics; using Microsoft.LightSwitch.Presentation.Implementation; using System.Collections.Generic; namespace LightSwitchApplication { public static class MultiSelectGridExtensions { public static void AddCheckBoxColumnForMultiSelection<T>( this IContentItemProxy gridProxy, ObservableCollection<T> selectedItems) where T : class ,IEntityObject { EventHandler<ControlAvailableEventArgs> gridProxy_ControlAvailable = null ; gridProxy_ControlAvailable = (s1, e1) => { DataGrid dataGrid = e1.Control as DataGrid; var contentItem = dataGrid.DataContext as IContentItem; var visualCollection = (contentItem.Value) as IVisualCollection; dataGrid.LoadingRow += new EventHandler<DataGridRowEventArgs>((s2, e2) => { DataGridColumn column = dataGrid.Columns[0]; var checkBox = column.GetCellContent(e2.Row) as CheckBox; T currentRowItem = e2.Row.DataContext as T; if (currentRowItem != null ) { checkBox.IsChecked = selectedItems.Contains(currentRowItem); } RoutedEventHandler checkboxClick = null ; checkboxClick = ( (s3, e3) => { var selectedItem = dataGrid.SelectedItem as T; if (selectedItem == null ) { return ; } if (checkBox.IsChecked ?? false ) { if (!selectedItems.Contains(selectedItem)) { selectedItems.Add(selectedItem); } } else { selectedItems.Remove(selectedItem); } TriggerCanExecute(visualCollection); }); checkBox.Click += checkboxClick; }); var col = new DataGridTemplateColumn(); var xaml = @"<DataTemplate xmlns=""http://schemas.microsoft.com/winfx/2006/xaml/presentation""> <CheckBox/> </DataTemplate>" ; var dataTemplate = XamlReader.Load(xaml) as DataTemplate; col.CellTemplate = dataTemplate; dataGrid.Columns.Insert(0, col); gridProxy.ControlAvailable -= gridProxy_ControlAvailable; }; gridProxy.ControlAvailable += gridProxy_ControlAvailable; } private static void TriggerCanExecute(IVisualCollection visualCollection) { //this will make sure that the CanExecute method is triggered in a potential button for doing something //with the selection result. //not elegant, but no other option... var currentItem = visualCollection.SelectedItem; var collection = visualCollection as IEnumerable<IEntityObject>; if (!visualCollection.SelectedItem.Equals(collection.Last())) { visualCollection.SelectedItem = collection.Last(); } else { visualCollection.SelectedItem = collection.First(); } visualCollection.SelectedItem = currentItem; } } } |
Can I download it?
No, you can’t because I stopped uploading samples, as from today. Full stop.
But, … you can directly inject the functionality with NuGet into the silverlight client project. (at least when you use the latest LightSwitch version)
lightswitch Grid 控件添加 CheckBox 多选的更多相关文章
- Android控件之CheckBox(复选框控件)
一.有两种状态: 选中状态(true).未选中状态(false) 二.属性 android:id = "@+id/checkbox" android:layout_width=&q ...
- Grid控件
Grid控件是WPF布局容器中功能最强大.最灵活的控件.Grid控件基本上能够完成其他WPF容器控件所能完成的功能,Microsoft建议大多数界面的布局都使用Grid控件来实现,因此默认情况下.vs ...
- FineUI Grid控件右键菜单的实现
FineUI官方Demo上一直没有Grid右键菜单的实现,其实从4.1.x的版本开始,允许添加自定义的事件监听(Listeners),所以要实现这个功能已经相当容易了. ExtJs右键菜单有很多种,对 ...
- 通过编写串口助手工具学习MFC过程——(五)添加CheckBox复选框
通过编写串口助手工具学习MFC过程 因为以前也做过几次MFC的编程,每次都是项目完成时,MFC基本操作清楚了,但是过好长时间不再接触MFC的项目,再次做MFC的项目时,又要从头开始熟悉.这次通过做一个 ...
- FineUI Grid控件高度自适应
引言 页面里使用f:Grid控件,添加分页功能,然后高度填充整个页面. 如何使用 使用FineUI 控件的每个页面都有一个f:PageManager控件,它包含属性:AutoSizePanelID,设 ...
- WPF平台Grid控件性能比较
WPF官方发布第一个版本至今已经有10年了, 我们几乎在同时也开始了XAML开发.即使经过多年打造,我们依旧尝试提高:我们真的成功打造了高效灵活的控件吗?我没有在其他地方找到任何关于优秀的WPF表格性 ...
- asp.net中的ListBox控件添加双击事件
问题:在Aspx页里的ListBox A中添加双击事件,将选中项添加到另一个ListBox B中,双击ListBox B中的选中项,删除当前选中项 页面: <asp:ListBox ID=&qu ...
- 实现控件WPF(4)----Grid控件实现六方格
PS:今天上午,非常郁闷,有很多简单基础的问题搞得我有些迷茫,哎,代码几天不写就忘.目前又不当COO,还是得用心记代码哦! 利用Grid控件能很轻松帮助我们实现各种布局.上面就是一个通过Grid单元格 ...
- 在C#中使用属性控件添加属性窗口
转自原文 在C#中使用属性控件添加属性窗口 第一步,创建在应用程序中将要展现的字段属性为public公有属性.其中,所有的属性必须有get和set的方法(如果不设置get方法,则要显示的属性不会显示在 ...
随机推荐
- linux python 安装到用户目录
在公司服务器中,python可能存在多个版本,而且python中的包也有多个不同版本,由于不同猿的需求不同,经常会引起程序冲突,影响工作效率.因此,给大家分享一个在没有root权限时,将python安 ...
- SQLite3命令操作大全
SQLite3命令操作大全 SQLite库包含一个名字叫做sqlite3的命令行,它可以让用户手工输入并执行面向SQLite数据库的SQL命令.本文档提供一个样使用sqlite3的简要说明. 一.ql ...
- JavaScript基础视频教程总结(011-020章)
<!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title&g ...
- bzoj3514(主席树+lct)
把边的编号看成边权,维护每个状态对应的最大生成树,得到一个数组a[i],表示第i条边在这个过程中替换的是那条边,询问时看一下a[l,r]内啊有多少个小于l的算一下答案就好:代码参考:http://bl ...
- first one
我说一句话你就知道我是干什么的 hello world
- zabbix docker - 安装和初始化配置
zabbix docker - 安装和初始化配置 安装zabbix server docker-mysql版本 zabbix server支持不同的数据库(详见zabbix的docker hub),这 ...
- 宽字符wchar_t和窄字符char——putwchar、wprintf
宽字符wchar_t 与 窄字符char 先说下窄字符char,这个大部分读者应该很清楚,char类型的变量占一个字节(byte)(也就是8个bit(比特)),能表示256个字符,那char的范围有两 ...
- 软件包管理之rpm与yum
软件包的安装和卸载时很平常的事,但在Linux上面却不简单..Linux的其中一个哲学就是一个程序只做一件事,并且做好.组合小程序来完成复杂的任务,这样做有很多好处,但是各个小程序之间往往会存在着复杂 ...
- Javascript百学不厌 - this
最近看了一本书,让自己的野路子走走正规路线 方法调用模式: 方法:当一个函数被保存为对象的一个属性时,我们称它为一个方法. var obj = { fun1: function() {this} // ...
- Java匹马行天下之JavaSE核心技术——面向对象
面向对象 注: 看此篇时强烈建议有一定的面向对象思想基础,有一定的基础后先翻到下面看第九条: 9.面向对象: 从未封装→封装→继承→多态→抽象类→接口的代码演变 按这个逻辑去看,,哪有不理解 ...