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 6上使用UDEV绑定共享存储
1.硬盘的查看方式 [root@cl6-11gr2-rac1 ~]# ls -ltr /dev/sd* brw-rw----. 1 root disk 8, 48 8月 16 13:34 /dev/s ...
- android开发笔记(3)
在android环境开发过程中,我最陌生的是虚拟机的创建以及使用,下面是虚拟机的创建以及使用过程. 创建虚拟机: 点击创建虚拟机的按钮,create->填写虚拟机相关的信息,确认之后创建. 创建 ...
- jupyter Notebook环境搭建
1.什么是jupyter notebook jupyter notebook是一种 Web 应用,能让用户将说明文本.数学方程.代码和可视化内容全部组合到一个易于共享的文档中.它可以直接在代码旁写出叙 ...
- PHP直接查看换取的图片
<!doctype html><head> <title></title> <meta http-equiv="Content-Type ...
- PLSQL基础知识-图片
什么是PL/SQL?
- Visual Studio 代码片段
管理界面 打开 工具 >> 代码片段管理器 界面 使用步骤 选择对应语言. 选择一个片段的文件夹. 打开该文件夹的位置. 复制任意一个片段. 对复制出来的片段进行修改.(具体修改内容见例子 ...
- WPF学习笔记(6):DataSet更新后台数据库个别列失败的问题
WPF窗体中建有一个DataGrid,运行后修改各行数据,通过Update方法更新后台数据库.发现在数据库中,其中一列FAcctID(文本型)每次都会变为0,还有一列FDebit(货币型)不能更新,其 ...
- C++数组,sort
cmake_minimum_required(VERSION 3.5) project(Test) add_executable( te test.cpp ) test.cpp #include &l ...
- [CocoaPods]Podfile文件
Podfile是一个描述一个或多个Xcode项目的目标依赖项的规范.该文件应该只是命名Podfile.指南中的所有示例都基于CocoaPods 1.0及更高版本. Podfile可以非常简单,这会将A ...
- JAVA基础语法——标识符、修饰符、关键字(个人整理总结)
JAVA基础语法——标识符.修饰符.关键字 一 . 标识符 1.1 什么是标识符 就是程序员在定义java程序时,自定义的一些名字,例如helloworld 程序里关键字class 后跟的Dem ...