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 :

Object hashcode different with ZK form binding

2YannUnil172.69.108.13540rj0kApr 19, 2024 1:18:08 PMlink

Object hashcode different with ZK form binding

1YannUnil172.69.108.13040rj0kApr 19, 2024 1:04:31 PMlink

font awesome effects

1guest172.71.166.21232nla3hApr 18, 2024 6:04:43 PMlink

font awesome effects

245guest172.71.166.21220t2jmoApr 18, 2024 6:04:41 PMlink

ZK-5696

1JamesChu162.158.187.3739iuvhmApr 18, 2024 10:33:52 AMlink

Listbox colspan header version 2

3guest172.71.183.199jkpp6qApr 17, 2024 1:54:19 PMlink

ZK-5695

1guest162.158.90.1402is2rctApr 17, 2024 10:23:20 AMlink

LocalDate in datebox

2guest172.70.243.516v49n7Apr 17, 2024 6:05:17 AMlink

LocalDate in datebox

1guest172.70.243.516v49n7Apr 17, 2024 6:04:18 AMlink

LocalDate in datebox

1guest172.70.243.511m6i0gcApr 17, 2024 6:04:04 AMlink

MVVM paging list detail and back navigation

1guest220.133.44.1473g76ji5Feb 12, 2015 6:45:57 AMlink

resources

index.zulzul<?page title="" contentType="text/html;charset=UTF-8"?> <zk xmlns:w="client" xmlns:ca="client/attribute"> <window title="" border="normal" apply="org.zkoss.bind.BindComposer" viewModel="@id('vm') @init('pkg$.MainViewModel')" validationMessages="@id('vmsgs')"> <include src="@load(vm.includePath)" pojoParam="@load(vm.pojoParam)"/> </window> </zk>MainViewModel.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.GlobalCommand; import org.zkoss.bind.annotation.Init; public class MainViewModel { private static final String DETAILSVIEW_ZUL = "detailsview.zul"; private static final String LISTVIEW_ZUL = "listview.zul"; private Pojo pojoParam; private String includePath; @Init public void init() { navigateTo(LISTVIEW_ZUL, null); } @GlobalCommand("openDetailsView") public void openDetailsView(@BindingParam("detailsPojo") Pojo detailsPojo) { navigateTo(DETAILSVIEW_ZUL, detailsPojo); } @GlobalCommand("openListView") public void openListView(@BindingParam("searchPojo") Pojo searchPojo) { navigateTo(LISTVIEW_ZUL, searchPojo); } private void navigateTo(String path, Pojo pojo) { pojoParam = pojo; includePath = path; BindUtils.postNotifyChange(null, null, this, "pojoParam"); BindUtils.postNotifyChange(null, null, this, "includePath"); } public String getIncludePath() { return includePath; } public Pojo getPojoParam() { return pojoParam; } } listview.zulzul<zk> <div apply="org.zkoss.bind.BindComposer" viewModel="@id('vm') @init('pkg$.ListViewModel')" validationMessages="@id('vmsgs')"> <paging id="mypaging" totalSize="@load(vm.totalSize)" pageSize="@load(vm.pageSize)" activePage="@bind(vm.activePage)"/> <listbox mold="paging" paginal="${mypaging}" model="@init(vm.items)"> <template name="model"> <listitem onDoubleClick="@global-command('openDetailsView', detailsPojo=each)"> <listcell label="@load(each.id)"/> <listcell label="@load(each.label)"/> </listitem> </template> </listbox> </div> </zk> ListViewModel.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.annotation.ExecutionArgParam; import org.zkoss.bind.annotation.Init; public class ListViewModel { private int activePage; private int pageSize; private ListModelList<Pojo> items = new ListModelList<Pojo>(); @Init public void init(@ExecutionArgParam("pojoParam") Pojo searchPojo) { loadItems(); pageSize = 5; gotoPageOf(searchPojo); } private void gotoPageOf(Pojo pojo) { if(pojo == null) { return; } activePage = items.indexOf(pojo) / pageSize; } private void loadItems() { for(int index = 0; index < 100; index++) { items.add(new Pojo("ID" + index, "Label " + index)); } } public int getActivePage() { return activePage; } public void setActivePage(int activePage) { this.activePage = activePage; } public int getTotalSize() { return items.getSize(); } public int getPageSize() { return pageSize; } public ListModelList<Pojo> getItems() { return items; } } detailsview.zulzul<?page title="" contentType="text/html;charset=UTF-8"?> <zk xmlns:w="client" xmlns:ca="client/attribute"> <window title="" border="normal" apply="org.zkoss.bind.BindComposer" viewModel="@id('vm') @init('pkg$.DetailsViewModel')" validationMessages="@id('vmsgs')"> <div> Here the details for <label value="@load(vm.pojo.id)"/> </div> <div> The label is: <label value="@bind(vm.pojo.label)"/> </div> <button label="go back" onClick="@global-command('openListView', searchPojo=vm.pojo)"/> </window> </zk>DetailsViewModel.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.annotation.ExecutionArgParam; import org.zkoss.bind.annotation.Init; public class DetailsViewModel { private Pojo pojo; @Init public void init(@ExecutionArgParam("pojoParam") Pojo detailsPojo) { this.pojo = detailsPojo; } public Pojo getPojo() { return pojo; } }Pojo.javajavapublic class Pojo { private String id; private String label; public Pojo(String id, String label) { super(); this.id = id; this.label = label; } public String getId() { return id; } public String getLabel() { return label; } @Override public int hashCode() { final int prime = 31; int result = 1; result = prime * result + ((id == null) ? 0 : id.hashCode()); return result; } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (getClass() != obj.getClass()) return false; Pojo other = (Pojo) obj; if (id == null) { if (other.id != null) return false; } else if (!id.equals(other.id)) return false; return true; } }