Processing...

Suggested case list:

Using timer to refresh a grid

383guest172.69.33.12125nk0uiMay 7, 2020 7:23:47 AMlink

user model to move item to another listbox

120guest162.158.193.148d0n3krApr 2, 2020 5:28:28 AMlink

Disabled list item row passed to VM-1981

296fatih123160.83.36.13025nk0uiFeb 13, 2018 4:25:44 PMlink

Disabled list item row passed to VM-1981

295fatih123160.83.36.13025nk0uiFeb 13, 2018 4:25:16 PMlink

Disabled list item row passed to VM-1981

294fatih123160.83.36.13225nk0uiFeb 13, 2018 3:30:44 PMlink

grid sample with ListModel/RowRenderer

816guest80.82.2.1312vah9ajFeb 21, 2017 11:42:21 AMlink

grid sample with ListModel/RowRenderer

809guest175.98.113.1622vah9ajJan 26, 2017 9:19:33 AMlink

grid sample with ListModel/RowRenderer

196guest79.185.142.402vah9ajApr 26, 2014 10:53:57 PMlink

grid sample with ListModel/RowRenderer

195guest79.185.142.402vah9ajApr 26, 2014 10:53:54 PMlink

grid sample with ListModel/RowRenderer

194guest79.185.142.402vah9ajApr 26, 2014 10:53:51 PMlink

grid sample with ListModel/RowRenderer

193guest79.185.142.402vah9ajApr 26, 2014 10:53:48 PMlink

grid sample with ListModel/RowRenderer

192guest79.185.142.402vah9ajApr 26, 2014 10:53:44 PMlink

grid sample with ListModel/RowRenderer

191guest79.185.142.402vah9ajApr 26, 2014 10:53:40 PMlink

Hierarchy table without using ZK PE/EE

1aaknai151.28.135.2131s871daJul 29, 2013 11:02:46 PMlink

grid sample with ListModel/RowRenderer

128aaknai151.28.135.2132vah9ajJul 29, 2013 7:20:00 PMlink

user model to move item to another listbox

1TonyQ114.25.109.94d0n3krApr 21, 2012 10:43:27 AMlink

Using timer to refresh a grid

1TonyQ220.133.44.3725nk0uiFeb 17, 2012 3:17:34 AMlink

Fire a event from child iframe

1TonyQ220.133.44.372eupjotFeb 3, 2012 5:04:52 AMlink

Textbox input restriction sample

1TonyQ72.21.245.2431b3nlr0Dec 20, 2011 10:09:10 AMlink

Test web core taglib in ZUL

1TonyQ198.203.175.175ofqkemDec 17, 2011 3:36:08 AMlink

Latest 10 Fiddles :

constraint binding textbox

3guest172.68.151.16220peldaDec 5, 2025 5:08:19 PMlink

Another new ZK fiddle

2guest172.68.151.16320peldaDec 5, 2025 5:07:51 PMlink

Another new ZK fiddle

1guest172.68.151.16220peldaDec 5, 2025 5:07:32 PMlink

Another new ZK fiddle

1peggypeng172.71.154.99364f4neDec 5, 2025 9:24:31 AMlink

tooltip example

2guest104.22.23.13rc1ntoDec 4, 2025 2:23:45 PMlink

Another new ZK fiddle

1guest172.69.134.2277t7602Dec 4, 2025 1:40:46 PMlink

Another new ZK fiddle

1peggypeng104.22.17.1802df6e3oDec 4, 2025 8:41:29 AMlink

onClose

1peggypeng172.68.87.248j8kd8aDec 3, 2025 4:10:26 AMlink

Another new ZK fiddle

1peggypeng172.69.134.2271rm7f4eNov 26, 2025 3:31:24 AMlink

ZK-5912-Suggestion

2rebeccalai104.22.20.1442qrmiiuNov 26, 2025 2:07:15 AMlink

Another new ZK fiddle

2guest114.249.149.41b6p3ciAug 20, 2014 5:18:04 AMlink

resources

index.zulzul<vlayout vflex="1" hflex="1" id="contentsDemo" class="page-content" apply="com.dbs.ux.bind.BindComposer" viewModel="@id('vm') @init('com.smartdot.icm.module.demo.vm.DemoListVM')"> <!-- <include src="content/alert.ul"/> --> <hlayout> <div hflex="1"> <button sclass="btn btn-primary pull-right" onClick="@command('new')">新建</button> </div> </hlayout> <separator/> <panel border="none" sclass="transparent"> <panelchildren style="padding-top:10px;"> <div class="form-horizontal"> <div class="form-body"> <div class="row"> <div class="col-md-6"> <div class="form-group"> <label class="control-label col-md-3" value="流程名称"/> <div class="col-md-9"> <textbox value="@bind(vm.processName)"/> </div> </div> </div> <div class="col-md-6"> <div class="form-group"> <label class="control-label col-md-3" value="流程编号"/> <div class="col-md-9"> <textbox value="@bind(vm.processCode)"/> </div> </div> </div> </div> <div class="row"> <div class="col-md-6"> <div class="form-group"> <label class="control-label col-md-3" value="级别"/> <div class="col-md-9"> <textbox value="@bind(vm.level)"/> </div> </div> </div> <div class="col-md-6"> <button type="button" class="btn btn-primary pull-right" iconSclass="z-icon-search" onClick="@command('search')">查询</button> </div> </div> </div> </div> </panelchildren> </panel> <grid id="listGrid" sclass="uxtable" mold="paging" pageSize="10" vflex="1" width="100%" emptyMessage="没找到相关数据." model="@load(vm.dataList)"> <columns> <column label="序号" width="50px"/> <column label="流程名称" /> <column width="100px" label="流程编号" /> <column width="80px" label="级别" /> <column width="100px" label="版本" /> <column width="100px" label="创建人" /> <column width="140px" label="创建时间" /> <column width="100px" label="操作" /> </columns> <rows> <template name="model" var="data"> <row sclass="task-orange" self="@{each='data'}"> <label value="@load(data.processName)"/> <label value="@load(data.processName)"/> <label value="@load(data.processCode)"/> <label value="@load(data.level)"/> <label value="@load(data.versionId)"/> <label value="@load(data.creatorName)"/> <label value="@load(data.createTime)@converter('formatedDate',format='yyyy-MM-dd HH:mm:ss')"/> <div style="padding-top:0px"> <a iconSclass="z-icon-search green" onClick="@command('view',entity=data)" /> <a iconSclass="z-icon-pencil blue" onClick="@command('edit',entity=data)" /> <a iconSclass="z-icon-trash-o red" onClick="@command('delete',entity=data)"/> </div> </row> </template> </rows> </grid> </vlayout> TestComposer.javajavapackage com.smartdot.icm.module.demo.vm; import java.util.ArrayList; import java.util.Date; import java.util.HashMap; import java.util.List; import java.util.Map; import com.dbs.ux.bind.Binder; import com.dbs.ux.bind.annotation.AfterCompose; import com.dbs.ux.bind.annotation.BindingParam; import com.dbs.ux.bind.annotation.Command; import com.dbs.ux.bind.annotation.ContextParam; import com.dbs.ux.bind.annotation.ContextType; import com.dbs.ux.bind.annotation.Init; import com.dbs.ux.bind.annotation.NotifyChange; import com.dbs.ux.bind.annotation.QueryParam; import com.dbs.ux.db.DaoService; import com.dbs.ux.db.TransactionManager; import com.dbs.ux.db.page.MxPage; import com.dbs.ux.db.page.MxPagingVM; import com.dbs.ux.ui.Component; import com.dbs.ux.ui.Executions; import com.dbs.ux.ui.MxConstants; import com.dbs.ux.ui.MxEvent; import com.dbs.ux.ui.event.Event; import com.dbs.ux.ui.event.EventListener; import com.dbs.ux.ui.event.Events; import com.dbs.ux.ui.select.Selectors; import com.dbs.ux.ui.select.annotation.Wire; import com.dbs.ux.ui.util.Clients; import com.dbs.uxul.Messagebox; import com.dbs.uxul.Vlayout; import com.dbs.uxul.Window; import com.smartdot.grcsp.commons.util.SysAccessUtils; import com.smartdot.grcsp.organization.entity.User; import com.smartdot.icm.module.docrule.entity.DocRule; import com.smartdot.icm.module.matrix.dao.MtxProcessMapper; import com.smartdot.icm.module.matrix.entity.MtxProcess; public class DemoListVM extends MxPagingVM{ private List<MtxProcess> dataList; @Wire private Vlayout contentsDemo; private String processName; private String processCode; private String level; @Init public void init(@ContextParam(ContextType.VIEW) Component view,@QueryParam("catalog") String catalog) { super.init(view); dataList = new ArrayList<MtxProcess>(); loadPageData(1, new HashMap()); } @AfterCompose public void afterComposer(@ContextParam(ContextType.VIEW) Component view){ Selectors.wireComponents(view, this, false); Selectors.wireEventListeners(view, this); binder = (Binder)view.getAttribute("binder"); } public void loadPageData(int pageNo, HashMap params){ super.loadPageData(pageNo); // 调用取得分析接口,返回策略ID列表 DaoService daoService = new DaoService(); MxPage<MtxProcess> resultList = null; try { resultList = (MxPage)daoService.get(MtxProcessMapper.class,page).findList(params); } catch (Exception e) { e.printStackTrace(); } page.setTotal(resultList.getTotal()); dataList.clear(); dataList.addAll(resultList); } @Command("new") @NotifyChange("dataList") public void onNew(){ User user = SysAccessUtils.getUser(); Map params = new HashMap(); MtxProcess process = new MtxProcess(); process.setCreatorId(user.getId()); process.setCreatorName(user.getName()); process.setCreateTime(new Date()); process.setModifyTime(new Date()); params.put("entity", process); params.put("mode", MxConstants.NEW_MODE); Window window = (Window)Executions.createComponents("module/docManage/demoEdit.ul", null, params); window.addEventListener(Events.ON_CLOSE, new EventListener(){ public void onEvent(Event event) throws Exception { if(event instanceof MxEvent){ MtxProcess mtxPrc = (MtxProcess)event.getData(); dataList.add(mtxPrc); } } }); window.doModal(); } @Command("edit") @NotifyChange("dataList") public void onEdit(@BindingParam("entity") MtxProcess entity){ Map params = new HashMap(); params.put("entity", entity); params.put("mode", MxConstants.EDIT_MODE); Window window = (Window)Executions.createComponents("module/docManage/demoEdit.ul", null, params); window.doModal(); } @Command("view") public void onView(@BindingParam("entity") MtxProcess entity){ Map params = new HashMap(); params.put("entity", entity); params.put("mode", MxConstants.VIEW_MODE); Window window = (Window)Executions.createComponents("module/docManage/demoEdit.ul", null, params); window.doModal(); } @Command("delete") public void onDelete(@BindingParam("entity") final MtxProcess entity){ try { int status = Messagebox.show("确认您要删除吗?", "信息", Messagebox.OK | Messagebox.CANCEL, Messagebox.QUESTION, new EventListener() { public void onEvent(Event evt) { switch (((Integer) evt.getData()).intValue()) { case Messagebox.OK: DaoService daoService = new DaoService(); daoService.get(MtxProcessMapper.class).markDelete(entity.getId()); TransactionManager.commit(); dataList.remove(entity); break; case Messagebox.CANCEL: break; } } }); } catch (Exception e) { TransactionManager.rollback(); e.printStackTrace(); } finally { TransactionManager.closeSession(); } } @Command("search") @NotifyChange("dataList") public void onSearch(@ContextParam(ContextType.VIEW) Component view){ // search.close(); HashMap<String, String> params = new HashMap<String, String>(); params.put("processName", processName); params.put("processCode", processCode); params.put("level", level); loadPageData(1, params); contentsDemo.invalidate(); Clients.resize(contentsDemo); } public List<MtxProcess> getDataList() { return dataList; } public void setDataList(List<MtxProcess> dataList) { this.dataList = dataList; } public String getProcessName() { return processName; } public void setProcessName(String processName) { this.processName = processName; } public String getProcessCode() { return processCode; } public void setProcessCode(String processCode) { this.processCode = processCode; } public String getLevel() { return level; } public void setLevel(String level) { this.level = level; } public Vlayout getContentsDemo() { return contentsDemo; } public void setContentsDemo(Vlayout contentsDemo) { this.contentsDemo = contentsDemo; } }