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方法,则要显示的属性不会显示在 ...
随机推荐
- Docker架构
Docker使用客户端-服务器(C/S)架构模式,使用远程API来管理和创建Docker容器. Docker容器通过Docker镜像来创建. 容器与镜像的关系类似于面向对象编程中的对象和类. Dock ...
- websocket的简单使用
一 轮询 什么是轮询:设置每一段时间去访问一次服务器,然后服务器返回最新的数据.这样服务器的压力会非常的大,并且还会有延迟.适用于小型程序. 实现:再客户端的页面设置一个定时发送请求的任务,每个这段时 ...
- LOJ-10103(求删去割点后最多的连通分量)
题目链接:传送门 思路: (1)这道题的图可能不连通,所以需要多次Tarjan: (2)设置cut[i]=x数组表示第i个节点被删除后右多少个子图(这个只是在一个图中),如果是根节点就要-1,因为根节 ...
- python模块:json
r"""JSON (JavaScript Object Notation) <http://json.org> is a subset of JavaScri ...
- CUDA[3] Samples for accessing shared/global memory
memory model: programming model: Source: Udacity Class CS344
- C++与C语言在结构体上的区别
用Nios 实现逻辑上很清楚,只是C++用switch语句后,写的很麻烦,主要是Switch语句很长吧. 另外要记录下:struct在C++中,在a文件中定义在b文件中定义变量是可以的,但在C语言中, ...
- SpringMVC+JQuery实现头像编辑器
一.简单说明 本头像编辑器主要实现了图片的上传.显示(不溢出父窗口).旋转.裁剪功能! 图片的上传用到的是异步上传,页面不进行刷新,原理是通过JQuery的异步提交+SpringMVC的上传 上传完毕 ...
- Rabbit mq 简单应用
参考:http://rabbitmq.mr-ping.com/AMQP/AMQP_0-9-1_Model_Explained.html 简答模式(exchange不工作) import pika # ...
- 用Django ORM实现树状结构
前言 之前看对于用关系数据库实现树状结构的方法就知道一直做自关联的表,但是感觉自关联查询太慢了,最近看到一篇文章,感觉视野开拓了好多,文章:数据库表设计,没有最好只有最适合来自:微信. 下面就针对这里 ...
- git 删除本地分支、远程分支、本地回滚、远程回滚
一. git 删除分支 1. git 删除本地分支 git branch -D branchname 2. git 删除远程分支 git push origin :branchname (origin ...