BPM实例分享:玩转数据字典新技能-字典库排序

有童鞋问到字典库的排序问题,这里简单介绍一个新技能。

数据字典使用场景:请假流程里的请假类型,有病假、事假、调休等。
定义数据字典,并且在流程中使用SheetDropDownListSheetRadioButtonList展现由用户来选择,如图:

数据字典

使用SheetDropDownList,并且设置该控件的属性MasterDataCategory为“请假类型”,其代码可能如下:

<SheetControls:SheetDropDownListID="SheetDropDownList1"runat="server"DataField="请假类型"MasterDataCategory="请假类型"></SheetControls:SheetDropDownList>
在表单中显示的效果如下:

SheetDropDownList使用数据字典

表单设计器中使用

对于SheetDropDownListSheetCheckBoxList、SheetRadioButtonList控件,可以直接绑定数据字典显示选项。

数据字典固然方便,一不小心就建多了,字典库多了用起来也是有点麻烦。

下面教给大家一个简单实用的排序技能.
首先找到

\Portal\Admin\MvcDesigner\MvcDesignerService.ashx

下面的这个函数

#region 获取数据字典

public void GetMasterDataCategory(HttpContext context)

{

List<string> items = new List<string>();

Dictionary<string, string> table = OThinker.H3.WorkSheet.AppUtility.Engine.MetadataRepository.GetCategoryTable();

foreach (string key in table.OrderBy(s=>s.Value).Select(x=>x.Key))

{

items.Add(table[key]);

}

context.Response.Write(JSSerializer.Serialize(items));

}

#endregion

把原来的 table.Keys 改成

table.OrderBy(s=>s.Value).Select(x=>x.Key)

可以任意改成喜欢的排序都可以。

时间: 2024-10-25 22:04:40

BPM实例分享:玩转数据字典新技能-字典库排序的相关文章

BPM实例分享:领导不通过某流程时,如何即可结束流程并告知发起人驳回通知

在很多业务场景中,你是否碰到这样的流程疑问: 领导不通过某审批单时,如何实现即刻结束流程并告知发起人该审批被驳回的通知?   鉴于近期有H3 BPM 10.0的用户向小编咨询这个问题, 且一些业务场景中一般都会涉及此流程, 小编特此整理此文并与大家共同分享! 系统版本:H3 BPM 10.0 用户:结束流程是指直接跳过中间流程直接结束?还是指该流程已作废? 回答:是中间节点全部跳过,直接结束流程.流程作废和流程结束是两个流程状态,不能混淆了. 用户:在哪个地方.如何设置流程结束通知? 我在属性-

BPM实例分享:DMZ内部网络转发https请求访问微信API

应用场景:H3 BPM部署在企业内部网络需要访问微信API但不能直接访问互联网 解决方案:通过DMZ服务器部署Nginx转发来自H3 BPM的https请求至微信服务器 1. 在H3 BPM服务器配置hosts文件添加一条记录,将访问微信API服务器重定向至内部的DMZ服务器 [DMZ IP] qyapi.weixin.qq.com 2.参考链接创建SSL服务器的无密码证书和key用于解密https加密内容 http://www.voidcn.com/blog/huplion/article/p

BPM实例分享:H3如何调试V3

问题描述: 使用H3写代码,用VS进行调试,遇到如下情况.   解决方案: 如果是使用IIS Express,修改IIS Express的配置文件applicationhost.config. site里面增加Portal的虚拟目录 复制代码 1 2 3 4 5 6 7 8 9 10 11 <site name="Portal" id="2"> <application path="/" applicationPool=&quo

BPM实例分享:如何设置表单字体样式

系统版本:V10.0 一些业务场景中,时尔需要改变表单字体 那如何设置表单字体样式? 本文将会针对全局表单和单个表单进行阐述! 1.全局表单:  修改WFRES\CSS\MvcSheet.css ,在body节点里面增加 font-family:"字体名" !important;  2.单个表单: 添加以下样式body{    font-family:"字体名" !important;  } PS:若设置后没有变化,按F12,并查看控制整个页面的div,找到相应的C

BPM实例分享:动态设置字段必填

一些业务场景中,需要动态设置字段的必填. 比如QA场景中,选择不合格的时候,必须要填写原因,合格时不需要. 设置必填后,提交时会进行验证. //设置字段的必填样式 function setRequired(field, flag, row) { var ele = $.MvcSheetUI.GetElement(field, row) var ui = ele.SheetUIManager(); if (ele != null) { ui.Required = flag; if (flag) {

BPM实例分享:如何设置开窗高度与宽度?

版本: V9.2.7 问题描述: DropDown的开窗查询中高度与宽度设置无效 解决方案: 修改MvcSheetAll,具体修改文件位置在: /Portal/WFRes/_Scripts/MVCSheet/Controls/SheetTextBox.js 修改内容如下图: 备注: H3中所有项目文件属性都默认为只读,打开长文本MvcSheetAll.js 时需更改后才能文本编辑格式化,至于压缩问题,需代码格式化.

BPM实例分享——日期自动计算

日期自动计算 在请假流程中通常我们需要获得请假开始到请假结束时间的天数,那么请假天数(可结合工作日历)是怎么实现系统计算呢?下面我们来看下配置的方法.  1.  首选建立业务服务BPMService,URL可使用系统已有的服务地址http://-/Portal/WebServices/BPMService.asmx,计算时间差方法GetDays(如设置工作日历会关联日历工作时间) 2.  在表单"休假开始时间","休假结束时间"控件中都配置onchange事件   

BPM实例分享——金额规则大写

金额规则大写 在涉及金额的流程中经常会遇到需要大写金额数据与小写金额匹配,如何实现输入数字后自动转换呢? 初级用法: 1.在默认表单基本属性javascript 中增加如下金额转换方法 /** 数字金额大写转换(可以处理整数,小数,负数) */ function chineseNumber(dValue) { var maxDec = 2; // 验证输入金额数值或数值字符串: dValue = dValue.toString().replace(/,/g, ""); dValue =

BPM实例分享:文件存储之FTP存储

H3BPM系统中默认的文件存储方式为数据库存储方式,不过也提供了另两种方式:文件服务器存储和FTP存储. 这里说的是FTP存储的方式.首先进入后台管理,依次打开系统管理----系统参数----文件存储. 页面左上角选择添加.基本信息:服务器存储类型中选择FTP存储,编码.显示名称.描述都可以自己定义.文件服务器(FTP)信息:服务器(FTP)的地址.账号.密码按照实际填入,文件存储根目录和客户端打开方式也是根据实际填入. 这里需要注意的是,因为H3默认的存储方式为数据库,所以需要将默认策略的复选