Suggested case list:
Using timer to refresh a grid
383guest172.69.33.12125nk0uiMay 7, 2020 7:23:47 AMlinkuser model to move item to another listbox
120guest162.158.193.148d0n3krApr 2, 2020 5:28:28 AMlinkDisabled list item row passed to VM-1981
296fatih123160.83.36.13025nk0uiFeb 13, 2018 4:25:44 PMlinkDisabled list item row passed to VM-1981
295fatih123160.83.36.13025nk0uiFeb 13, 2018 4:25:16 PMlinkDisabled list item row passed to VM-1981
294fatih123160.83.36.13225nk0uiFeb 13, 2018 3:30:44 PMlinkgrid sample with ListModel/RowRenderer
816guest80.82.2.1312vah9ajFeb 21, 2017 11:42:21 AMlinkgrid sample with ListModel/RowRenderer
809guest175.98.113.1622vah9ajJan 26, 2017 9:19:33 AMlinkgrid sample with ListModel/RowRenderer
196guest79.185.142.402vah9ajApr 26, 2014 10:53:57 PMlinkgrid sample with ListModel/RowRenderer
195guest79.185.142.402vah9ajApr 26, 2014 10:53:54 PMlinkgrid sample with ListModel/RowRenderer
194guest79.185.142.402vah9ajApr 26, 2014 10:53:51 PMlinkgrid sample with ListModel/RowRenderer
193guest79.185.142.402vah9ajApr 26, 2014 10:53:48 PMlinkgrid sample with ListModel/RowRenderer
192guest79.185.142.402vah9ajApr 26, 2014 10:53:44 PMlinkgrid sample with ListModel/RowRenderer
191guest79.185.142.402vah9ajApr 26, 2014 10:53:40 PMlinkHierarchy table without using ZK PE/EE
1aaknai151.28.135.2131s871daJul 29, 2013 11:02:46 PMlinkgrid sample with ListModel/RowRenderer
128aaknai151.28.135.2132vah9ajJul 29, 2013 7:20:00 PMlinkuser model to move item to another listbox
1TonyQ114.25.109.94d0n3krApr 21, 2012 10:43:27 AMlinkUsing timer to refresh a grid
1TonyQ220.133.44.3725nk0uiFeb 17, 2012 3:17:34 AMlinkFire a event from child iframe
1TonyQ220.133.44.372eupjotFeb 3, 2012 5:04:52 AMlinkTextbox input restriction sample
1TonyQ72.21.245.2431b3nlr0Dec 20, 2011 10:09:10 AMlinkTest web core taglib in ZUL
1TonyQ198.203.175.175ofqkemDec 17, 2011 3:36:08 AMlinkLatest 10 Fiddles :
Listbox with Template
1guest162.158.22.1932ssr6bmDec 8, 2023 12:51:15 PMlinkListbox with Template
1guest162.158.22.19329sk0adDec 8, 2023 12:51:14 PMlinkListbox with Template
1guest162.158.22.1933jedcljDec 8, 2023 12:51:14 PMlinkAnother new ZK fiddle
5guest162.158.22.1542stdj2aDec 8, 2023 7:33:45 AMlinkListbox Responsive
1FelipeReyes172.70.255.641uahfaqDec 7, 2023 9:18:02 PMlinkIndexOutOfBoundsException empty select all listbox
2tbackhaus172.70.251.4521gs6qhDec 7, 2023 2:14:09 PMlinkZK-4380
1JamesChu162.158.90.105iunt15Dec 7, 2023 8:04:21 AMlinkfont awesome effects
233guest162.158.178.18520t2jmoDec 7, 2023 7:59:24 AMlinktest_swipe_touchSwipe
1guest162.158.91.581qiqnnbDec 6, 2023 2:58:56 PMlinkZK Chosenbox Sample
132guest162.158.54.1201e133otDec 6, 2023 11:12:32 AMlinkTime handling in ZK 9
4guest172.70.206.933gg6pptMar 11, 2022 11:02:36 AMlinkresources
index.zulzul<zk>
<div id="main" apply="pkg$.TimezoneComposer">
<timer id="uiUpdateTimer" repeats="true" delay="1000"></timer>
<vlayout>
<datebox id="userInputDatebox" width="300px"></datebox>
<searchbox id="timeZoneSearchBox" width="300px" autoclose="true"></searchbox>
<grid>
<auxhead>
<auxheader label="timezone info"></auxheader>
<auxheader label="value"></auxheader>
</auxhead>
<rows>
<row>
<cell>
<label value="user locale"></label>
</cell>
<cell >
<label id="userLocal" />
</cell>
</row>
<row>
<cell>
<label value="user local timezone"></label>
</cell>
<cell >
<label id="userLocalTimeZone" />
</cell>
</row>
<row>
<cell>
<label value="user local offset from GMT"></label>
</cell>
<cell >
<label id="userLocalGmtOffset" />
</cell>
</row>
<row>
<cell>
<label value="user selected time as GMT+0 timestamp"></label>
</cell>
<cell >
<label id="userToGmt" />
</cell>
</row>
<row>
<cell>
<label value="user selected time as user local timestamp"></label>
</cell>
<cell >
<label id="userToUser" />
</cell>
</row>
<row>
<cell>
<label value="user selected time as LOCALDATETIME"></label>
</cell>
<cell >
<label id="userLocalToUser" />
</cell>
</row>
<row>
<cell>
<label value="user selected time as server local timestamp"></label>
</cell>
<cell >
<label id="userToServer" />
</cell>
</row>
<row>
<cell>
<label value="server local timezone"></label>
</cell>
<cell>
<label id="serverLocal" />
</cell>
</row>
<row>
<cell>
<label value="server local offset from GMT"></label>
</cell>
<cell>
<label id="serverLocalGmtOffset" />
</cell>
</row>
<row>
<cell>
<label value="server time as GMT+0 timestamp"></label>
</cell>
<cell >
<label id="serverToGmt" />
</cell>
</row>
<row>
<cell>
<label value="server time as as a user local timestamp"></label>
</cell>
<cell >
<label id="serverToUser" />
</cell>
</row>
<row>
<cell>
<label value="server time as as a server local timestamp"></label>
</cell>
<cell >
<label id="serverToServer" />
</cell>
</row>
</rows>
</grid>
</vlayout>
</div>
</zk>TimezoneComposer.javajavaimport java.text.SimpleDateFormat;
import java.time.Instant;
import java.time.LocalDate;
import java.time.LocalDateTime;
import java.time.ZoneId;
import java.time.ZonedDateTime;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Date;
import java.util.Iterator;
import java.util.TimeZone;
import org.zkoss.util.TimeZones;
import org.zkoss.zk.ui.Component;
import org.zkoss.zk.ui.Page;
import org.zkoss.zk.ui.event.ClientInfoEvent;
import org.zkoss.zk.ui.event.Events;
import org.zkoss.zk.ui.event.SelectEvent;
import org.zkoss.zk.ui.metainfo.ComponentInfo;
import org.zkoss.zk.ui.select.SelectorComposer;
import org.zkoss.zk.ui.select.annotation.Listen;
import org.zkoss.zk.ui.select.annotation.Wire;
import org.zkoss.zkmax.zul.Searchbox;
import org.zkoss.zul.Datebox;
import org.zkoss.zul.Label;
import org.zkoss.zul.ListModelList;
public class TimezoneComposer extends SelectorComposer<Component> {
@Wire
private Datebox userInputDatebox;
@Wire
private Searchbox<String> timeZoneSearchBox;
@Wire
private Label userLocal, userLocalTimeZone, userLocalGmtOffset, userToGmt, userToUser, userLocalToUser, userToServer, serverLocal, serverLocalGmtOffset, serverToGmt, serverToUser, serverToServer;
private ZoneId clientZoneId;
private ZoneId serverZoneId = ZoneId.of("GMT+4");
private SimpleDateFormat userSimpleDateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
private SimpleDateFormat serverSimpleDateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
private SimpleDateFormat gmtSimpleDateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
private ListModelList<String> timeZoneSeachModel;
@Override
public ComponentInfo doBeforeCompose(Page page, Component parent, ComponentInfo compInfo) {
// TimeZone.setDefault(TimeZone.getTimeZone(serverZoneId));
return super.doBeforeCompose(page, parent, compInfo);
}
@Listen(Events.ON_CLIENT_INFO + "=#main")
public void handleClientInfo(ClientInfoEvent event) {
clientZoneId = event.getZoneId();
timeZoneSeachModel.addToSelection(clientZoneId.getId());
userSimpleDateFormat.setTimeZone(TimeZone.getTimeZone(clientZoneId));
userInputDatebox.setDisplayedTimeZones(Arrays.asList(TimeZone.getTimeZone(clientZoneId)));
userInputDatebox.setTimeZone(TimeZone.getTimeZone(clientZoneId));
updateAllTimeStamps();
}
@Listen(Events.ON_SELECT + "=#timeZoneSearchBox")
public void handleLocalTimeZoneChange(SelectEvent<Searchbox<String>, String> event) {
Iterator<String> valueIterator = event.getSelectedObjects().iterator();
if(valueIterator.hasNext()) {
clientZoneId = ZoneId.of(valueIterator.next());
userSimpleDateFormat.setTimeZone(TimeZone.getTimeZone(clientZoneId));
userInputDatebox.setDisplayedTimeZones(Arrays.asList(TimeZone.getTimeZone(clientZoneId)));
userInputDatebox.setTimeZone(TimeZone.getTimeZone(clientZoneId));
}
updateAllTimeStamps();
}
@Listen(Events.ON_CHANGE + "=#userInputDatebox")
public void handleUserInputDateboxChange() {
updateAllTimeStamps();
}
@Listen(Events.ON_TIMER + "=#uiUpdateTimer")
public void handleUpdateTimer() {
updateAllTimeStamps();
}
@Override
public void doAfterCompose(Component comp) throws Exception {
super.doAfterCompose(comp);
userInputDatebox.setValue(new Date());
userInputDatebox.setFormat("yyyy-MM-dd HH:mm:ss");
userInputDatebox.setTimeZonesReadonly(true);
userInputDatebox.setReadonly(true);
timeZoneSeachModel = new ListModelList<String>(TimeZone.getAvailableIDs());
timeZoneSeachModel.setMultiple(false);
timeZoneSearchBox.setModel(timeZoneSeachModel);
}
private void updateAllTimeStamps() {
serverSimpleDateFormat.setTimeZone(TimeZone.getTimeZone(serverZoneId.getId()));
userSimpleDateFormat.setTimeZone(TimeZone.getTimeZone(clientZoneId));
gmtSimpleDateFormat.setTimeZone(TimeZone.getTimeZone("GMT+0"));
userLocal.setValue(clientZoneId.getId());
userLocalTimeZone.setValue(TimeZone.getTimeZone(clientZoneId).getDisplayName());
userLocalGmtOffset.setValue(ZonedDateTime.ofInstant(Instant.now(), clientZoneId).getOffset().toString());
userToUser.setValue(userSimpleDateFormat.format(userInputDatebox.getValue()));
userLocalToUser.setValue(localDateTimeToString(userInputDatebox.getValueInLocalDateTime()));
userToServer.setValue(serverSimpleDateFormat.format(userInputDatebox.getValue()));
userToGmt.setValue(gmtSimpleDateFormat.format(userInputDatebox.getValue()));
serverLocal.setValue(serverZoneId.getId());
Date localDate = new Date();
serverLocalGmtOffset.setValue(ZonedDateTime.ofInstant(Instant.now(), serverZoneId).getOffset().toString());
serverToGmt.setValue(gmtSimpleDateFormat.format(localDate));
serverToUser.setValue(userSimpleDateFormat.format(localDate));
serverToServer.setValue(serverSimpleDateFormat.format(localDate));
}
private String localDateTimeToString(LocalDateTime valueInLocalDateTime) {
StringBuilder sb = new StringBuilder();
sb.append("Year: ");
sb.append(valueInLocalDateTime.getYear());
sb.append(", Month: ");
sb.append(valueInLocalDateTime.getMonth());
sb.append(", DayOfMonth: ");
sb.append(valueInLocalDateTime.getDayOfMonth());
sb.append(", Hour: ");
sb.append(valueInLocalDateTime.getHour());
sb.append(", Minute: ");
sb.append(valueInLocalDateTime.getMinute());
sb.append(" Second: ");
sb.append(valueInLocalDateTime.getSecond());
return sb.toString();
}
}