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

1guest203.88.138.2223dp74rjFeb 12, 2016 9:26:32 AMlink

resources

index.zulzul<?xml version="1.0" encoding="UTF-8"?> <zk xmlns="http://www.zkoss.org/2005/zul" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.zkoss.org/2005/zul http://www.zkoss.org/2005/zul/zul.xsd" xmlns:h="xhtml"> <vlayout hflex="1" vflex="1" spacing="0px" apply="org.zkoss.bind.BindComposer" viewModel="@id('vm') @init('pkg$.CompanyDetailVM')"> <div hflex="1" height="35px" style="background-color:#2b5797;padding-left: 10px;padding-right:5px;"> <h:i if="${not empty vm.icon}" sclass="fa fa-${vm.icon} fa-lg fa-inverse" style="float:left;vertical-align:middle;line-height:35px;"/> <label value="Company" style="color:#FFFFFF;font-size:16px;font-weight:bold;float:left;vertical-align:middle;line-height:35px;margin-left:10px;"/> <div width="35px" sclass="action-menu fa fa-bars fa-inverse" popup="companyDetailActionmenu, after_end" style="float:right;vertical-align:middle;line-height:35px;"/> </div> <include src="/zul/common/content-header.zul" icon="archive" title="${c:l('companies')}" backgroundColor="#2b5797" actionMenu="companyDetailActionmenu"/> <menupopup id="companyDetailActionmenu"> <menuitem label="${c:l('save')}" image="/images/menu/realvista_general_diskette_16.png" onClick="@command('save')"/> </menupopup> <grid width="400px" vflex="1" form="@id('fx') @load(vm.company) @save(vm.company, before='save')"> <auxhead> <auxheader label="${c:l('company_administration')}" colspan="2" align="center"/> </auxhead> <columns visible="false"> <column width="130px"/> <column hflex="1"/> </columns> <rows> <row> <cell sclass="row-title"> <label value="${c:l('number')}:" sclass="mandatory-label" tooltiptext="${c:l('asterisk_mandatory_field')}"/> </cell> <cell> <textbox value="@load(fx.number) @save(fx.number, before='save')" hflex="1" constraint="no empty" maxlength="10"/> </cell> </row> <row> <cell sclass="row-title"> <label value="${c:l('company_name_1')}:" sclass="mandatory-label" tooltiptext="${c:l('asterisk_mandatory_field')}"/> </cell> <cell> <textbox value="@load(fx.companyName) @save(fx.companyName, before='save')" hflex="1" constraint="no empty" maxlength="50"/> </cell> </row> <row> <cell sclass="row-title"> <label value="${c:l('company_name_2')}:"/> </cell> <cell> <textbox value="@load(fx.companyName2) @save(fx.companyName2, before='save')" hflex="1" maxlength="50"/> </cell> </row> <row> <cell sclass="row-title"> <label value="${c:l('managing_director')}:"/> </cell> <cell> </cell> </row> <row> <cell sclass="row-title"> <label value="${c:l('operating_status')}:"/> </cell> <cell> <radiogroup selectedItem="@load(fx.active) @save(fx.active, before='save') @converter('radiogroupBooleanConverter')"> <radio label="${c:l('active')}" value="true"/> <radio label="${c:l('inactive')}" value="false"/> </radiogroup> </cell> </row> <row> <cell sclass="row-title"> <label value="${c:l('comment')}:"/> </cell> <cell> <textbox value="@load(fx.comment) @save(fx.comment, before='save')" hflex="1" rows="3" maxlength="255"/> </cell> </row> <group label="${c:l('reachability')}" open="false" sclass="grid-group" onClick="self.setOpen(!self.isOpen())"/> <row> <cell sclass="row-title"> <label value="${c:l('phone')}:"/> </cell> <cell> <textbox value="@bind(fx.phone)" hflex="1" maxlength="20"/> </cell> </row> <row> <cell sclass="row-title"> <label value="${c:l('mobile')}:"/> </cell> <cell> <textbox value="@bind(fx.mobile)" hflex="1" maxlength="20"/> </cell> </row> <row> <cell sclass="row-title"> <label value="${c:l('fax')}:"/> </cell> <cell> <textbox value="@bind(fx.fax)" hflex="1" maxlength="20"/> </cell> </row> <row> <cell sclass="row-title"> <label value="${c:l('email')}:"/> </cell> <cell> <textbox value="@bind(fx.email)" hflex="1" maxlength="50" constraint="/.+@.+\.[a-z]+|/: ${c:l('invalid_email_address')}"/> </cell> </row> <row> <cell sclass="row-title"> <label value="${c:l('homepage')}:"/> </cell> <cell> <textbox value="@bind(fx.homepage)" hflex="1" maxlength="50"/> </cell> </row> </rows> </grid> </vlayout> </zk>CompanyDetailVM.javajavaimport org.zkoss.zk.ui.*; import org.zkoss.zk.ui.event.*; import org.zkoss.zk.ui.util.*; import org.zkoss.zk.ui.ext.*; import org.zkoss.zk.au.*; import org.zkoss.zk.au.out.*; import org.zkoss.zul.*; import org.zkoss.bind.BindUtils; import org.zkoss.bind.annotation.BindingParam; import org.zkoss.bind.annotation.Command; import org.zkoss.bind.annotation.GlobalCommand; import org.zkoss.bind.annotation.NotifyChange; import org.zkoss.zk.ui.select.annotation.WireVariable; import org.zkoss.zk.ui.util.Clients; public class TestComposer { private Company company; @Command("save") @NotifyChange("company") public void save() { } @GlobalCommand("addCompany") @NotifyChange("company") public void addCompany() { this.company = new Company(); } @GlobalCommand("selectCompany") @NotifyChange("company") public void selectCompany(@BindingParam("company") Company company) { this.company = company; } public Company getCompany() { return this.company; } public void setCompany(Company company) { this.company = company; } } Company.javajavaimport org.zkoss.zk.ui.*; import org.zkoss.zk.ui.event.*; import org.zkoss.zk.ui.util.*; import org.zkoss.zk.ui.ext.*; import org.zkoss.zk.au.*; import org.zkoss.zk.au.out.*; import org.zkoss.zul.*; public class Company { private String id; private String number; private String companyName; private String companyName2; private boolean active; // = true; private String comment; private String taxNumber; private String salesTaxId; private String email; private String phone; private String fax; private String mobile; private String homepage; public Company() { email = ""; phone = ""; fax = ""; mobile = ""; homepage = ""; } public String getId() { return id; } public void setId(String id) { this.id = id; } public String getNumber() { return number; } public void setNumber(String number) { this.number = number; } public String getCompanyName() { return companyName; } public void setCompanyName(String companyName) { this.companyName = companyName; } public String getCompanyName2() { return companyName2; } public void setCompanyName2(String companyName2) { this.companyName2 = companyName2; } public EmployeeDto getManagingDirectorDto() { return managingDirectorDto; } public void setManagingDirectorDto(EmployeeDto managingDirectorDto) { this.managingDirectorDto = managingDirectorDto; } public boolean isActive() { return active; } public void setActive(boolean active) { this.active = active; } public String getComment() { return comment; } public void setComment(String comment) { this.comment = comment; } public String getTaxNumber() { return taxNumber; } public void setTaxNumber(String taxNumber) { this.taxNumber = taxNumber; } public String getSalesTaxId() { return salesTaxId; } public void setSalesTaxId(String salesTaxId) { this.salesTaxId = salesTaxId; } public String getEmail() { return email; } public void setEmail(String email) { this.email = email; } public String getPhone() { return phone; } public void setPhone(String phone) { this.phone = phone; } public String getFax() { return fax; } public void setFax(String fax) { this.fax = fax; } public String getMobile() { return mobile; } public void setMobile(String mobile) { this.mobile = mobile; } public String getHomepage() { return homepage; } public void setHomepage(String homepage) { this.homepage = homepage; } }