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 :

Use zAu.send to send data to server from client

411guest162.158.186.661hisp5kMay 9, 2024 2:37:53 AMlink

Another new ZK fiddle

7guest172.71.81.443gm6qr1May 8, 2024 4:07:58 PMlink

Another new ZK fiddle

6guest172.71.81.433gm6qr1May 8, 2024 4:06:19 PMlink

Another new ZK fiddle

5guest172.71.81.433gm6qr1May 8, 2024 4:05:04 PMlink

Another new ZK fiddle

4guest172.71.81.443gm6qr1May 8, 2024 4:04:19 PMlink

Another new ZK fiddle

3guest172.71.81.443gm6qr1May 8, 2024 4:03:46 PMlink

Another new ZK fiddle

2guest172.71.81.433gm6qr1May 8, 2024 3:55:04 PMlink

Another new ZK fiddle

1guest172.71.81.433gm6qr1May 8, 2024 3:54:06 PMlink

Use zAu.send to send data to server from client

2guest162.158.119.7343vscpMay 8, 2024 12:54:11 PMlink

Use zAu.send to send data to server from client

1guest162.158.119.7443vscpMay 8, 2024 12:54:01 PMlink

cascader missing label if selected before render

6guest172.70.207.412d6shcJun 17, 2023 9:39:01 AMlink

resources

index.zulzul<zk> <!-- <script><![CDATA[ zk.afterLoad("zkmax.inp", function () { var _xCascader = {}; zk.override(zkmax.inp.Cascader.prototype, _xCascader, { bind_: function bind_() { this.$supers(zkmax.inp.Cascader, 'bind_', arguments); jq(this.$n()).on('focusin', this.proxy(this._focusinContent)).on('focusout', this.proxy(this._focusoutContent)); jq(this.$n('pp')).on('mousedown', ".".concat(this.$s('item')), this._doItemMouseDown.bind(this)).on('click', ".".concat(this.$s('item')), this._doItemClick.bind(this)); // handle icon if (this._selectedUuids.length > 0) //selection is not empty this._updateIconClass('x');else { jq(this.$n('label')).css('display', 'none'); jq(this.$n('placeholder')).css('display', 'inline-block'); } zWatch.listen({ onFloatUp: this, onResponse: this, onSize: this }); } }); }); ]]></script> --> <window border="normal" title="Cascader selection Problem" viewModel="@id('vm') @init('pkg$.CascaderVM')"> <vlayout> <apply template="cascade" seq="@load(vm.seq)" /> <hlayout> <label value="VM Selected:"></label> <label value="@load(vm.selected)" /> </hlayout> </vlayout> <button label="Refresh" onClick="@command('refreshTemplate')" /> </window> <template name="cascade"> <label value="${seq}"/> <label value="${vm.selected}"/> <cascader width="350px" model="@load(vm.model)" selectedItem="@bind(vm.selected)" itemConverter="@init(vm.itemConverter)" itemRenderer="@init(vm.itemRenderer)" /> </template> </zk> CascaderVM.javajava import java.util.Collection; import java.util.stream.Collectors; import org.zkoss.bind.BindUtils; import org.zkoss.bind.Converter; import org.zkoss.bind.annotation.Command; import org.zkoss.bind.annotation.Init; import org.zkoss.zkmax.ui.util.Toast; import org.zkoss.zul.DefaultTreeModel; import org.zkoss.zul.ItemRenderer; import org.zkoss.zul.TreeNode; public class CascaderVM { private Object selected; private int seq = 0; private final DefaultTreeModel<MyNodeData> model = CascaderData.buildModel(); public org.zkoss.util.Converter<Collection<TreeNode<MyNodeData>>, String> getItemConverter() { return nodePath -> nodePath.stream().map(node -> node.getData().getLabel()) .collect(Collectors.joining(" > ")); } public ItemRenderer<TreeNode<MyNodeData>> getItemRenderer() { return (component, data, i) -> data.getData().getLabel(); } public DefaultTreeModel<MyNodeData> getModel() { return model; } public Object getSelected() { return selected; } public void setSelected(final Object selected) { this.selected = selected; org.zkoss.zkmax.ui.util.Toast.show("setSelected(" + selected + ")"); } @org.zkoss.bind.annotation.Command public void refreshTemplate() { seq++; org.zkoss.zkmax.ui.util.Toast.show("refresh clicked. seq=" + seq + "; selected=" + selected + "; model.selected=" + model.getSelection()); org.zkoss.bind.BindUtils.postNotifyChange(this, "seq"); } @Init public void init() { setSelected(model.getRoot().getChildAt(2)); } public int getSeq() { return seq; } }CascaderData.javajava import org.zkoss.zul.DefaultTreeModel; import org.zkoss.zul.DefaultTreeNode; import java.util.List; import static java.util.Arrays.asList; public class CascaderData { public static DefaultTreeModel<MyNodeData> buildModel() { org.zkoss.zkmax.ui.util.Toast.show("building model"); return new DefaultTreeModel<>(node("root", asList( node("Node-1"), node("Node-2", asList( node("Node-2.1"), node("Node-2.2", asList( node("Node-2.2.1"), node("Node-2.2.2"), node("Node-2.2.3"), node("Node-2.2.4"), node("Node-2.2.5")) ), node("Node-2.3", asList( node("Node-2.3.1"), node("Node-2.3.2", asList( node("Node-2.3.2.1"), node("Node-2.3.2.2")) ), node("Node-2.3.3")) ), node("Node-2.4")) ), node("Node-3"), node("Node-4")) )); } private static DefaultTreeNode<MyNodeData> node(String label) { return new DefaultTreeNode<>(new MyNodeData(label)); } private static DefaultTreeNode<MyNodeData> node(String label, List<DefaultTreeNode<MyNodeData>> children) { return new DefaultTreeNode<>(new MyNodeData(label), children); } }MyNodeData.javajavapublic class MyNodeData { private final String label; public MyNodeData(final String label) { this.label = label; } public String getLabel() { return label; } @Override public String toString() { return "MyNodeData{" + "label='" + label + '\'' + '}'; } }