DZone
Thanks for visiting DZone today,
Edit Profile
  • Manage Email Subscriptions
  • How to Post to DZone
  • Article Submission Guidelines
Sign Out View Profile
  • Post an Article
  • Manage My Drafts
Over 2 million developers have joined DZone.
Log In / Join
Refcards Trend Reports Events Over 2 million developers have joined DZone. Join Today! Thanks for visiting DZone today,
Edit Profile Manage Email Subscriptions Moderation Admin Console How to Post to DZone Article Submission Guidelines
View Profile
Sign Out
Refcards
Trend Reports
Events
Zones
Culture and Methodologies Agile Career Development Methodologies Team Management
Data Engineering AI/ML Big Data Data Databases IoT
Software Design and Architecture Cloud Architecture Containers Integration Microservices Performance Security
Coding Frameworks Java JavaScript Languages Tools
Testing, Deployment, and Maintenance Deployment DevOps and CI/CD Maintenance Monitoring and Observability Testing, Tools, and Frameworks
Partner Zones AWS Cloud
by AWS Developer Relations
Culture and Methodologies
Agile Career Development Methodologies Team Management
Data Engineering
AI/ML Big Data Data Databases IoT
Software Design and Architecture
Cloud Architecture Containers Integration Microservices Performance Security
Coding
Frameworks Java JavaScript Languages Tools
Testing, Deployment, and Maintenance
Deployment DevOps and CI/CD Maintenance Monitoring and Observability Testing, Tools, and Frameworks
Partner Zones
AWS Cloud
by AWS Developer Relations

Implementing Load-on-Demand using ZK and Grails

Chanwit Kaewkasi user avatar by
Chanwit Kaewkasi
·
Mar. 24, 09 · Interview
Like (0)
Save
Tweet
Share
21.75K Views

Join the DZone community and get the full member experience.

Join For Free

This article is to implement a load-on-demand application in ZK and Grails to help you show a large number of data. It demonstrates a rapid way to build an Ajax application by combining the power of ZK and Grails.

ZK Plugin for Grails introduces GroovyGrails mode for ZK framework. It seamlessly integrates ZK into the Grails stack. The plugin brings ZK and Grails to the next level of rapid RIA developement, also with convention-over-configuration, Spring, and Hibernate powers. It features:

  • Accessing to Grails domain classes, transactional service classes, and a vast number of plugins.
  • Quick constructing ZK components with Gabe Hicks' ZK Groovy Builder syntax.
  • Auto-reloading composers via Spring beans. With ZK Plugin, you can use the MVC power of ZK's composers at the same development speed as scripting !
  • Scripting also fully supports Grails artifacts directly in .zul.
  • ZUL file and composer generators.
The following is a ZKGrails port of the program written in Use Load-On-Demand to Handle Huge Data. This tutorial is working for ZK Plugin for Grails 0.7.1 and later.

Create a Grails project

You need to prepare a Grails project for this tutorial by type:

$ grails create-app ondemand

Install ZKGrails

Next, you need to install ZKGrails. The latest version will be installed automatically, when type:

$ grails install-plugin zk

Create a domain class

I am going to demonstrate with a simple domain class, Employee. To create domain class in Grails, simply use the command create-domain-class, following by your class name:

$ grails create-domain-class employee

Adding Properties for Employee

I then add two properties into domain class Employee, namely fullname and username. Both are string.

class Employee {

String fullname
String username

static constraints = {
}
}

Create a zul page

There are two generator scripts comes with ZK Plugin for Grails. The following shows how to run create-zul to create web-app/employee.zul.

$ grails create-zul employee

This will also create grails-apps/composers/EmployeeComposer.groovy for you.

Edit employee.zul

Although the generator creates a ready-to-run zul file for you from the template, but it is just a skeleton to make you easier to start with. Open web-app/employee.zul, and delete all codes below vbox, then modify it as follows.

<window apply="${employeeComposer}">

<vbox>
<image src="images/grails_logo.jpg"/>
</vbox>

<listbox id="lstEmployee" width="100%" checkmark="true">
<listhead sizable="true">
<listheader label="ID" sort="auto" />
<listheader label="Full Name" sort="auto" />
<listheader label="User Name" sort="auto" />
</listhead>
</listbox>
<paging id="pagEmployee" pageSize="30" />

</window>

 Of course, the key components which will be used in the composer are lstEmployee, and pagEmployee.

Editing EmployeeComposer

From the code, you may see 2 properties lstEmployee, and pagEmployee. Both are injected by GrailsComposer, which is a subclass of ZK's GenericForwardComposer. They, apparently, represents listbox and paging components from your .zul file.

You may notice that there is afterCompose closure. This closure is executed in doAfterCompose, and it's a Groovy way to initialize your components.

The auto-wired event handle onPaging_pagEmployee will be called everytime you click pagEmployee to change the active page. Note that, the only argument of the handler must be ForwardEvent or Event to make it work.

I also show you the use of Groovy's default argument value declared at redraw method. That is, calling redraw() in afterCompose means redraw(0).

Also in redraw method, there are two places to use dynamic methods added by ZKGrails. The first one is clear(), a method to remove all items from a listbox. The second one is append(), which accepts component construction via ZK Groovy Builder.

import org.zkoss.zkgrails.*
import org.zkoss.zk.ui.event.*

class EmployeeComposer extends GrailsComposer {

def lstEmployee
def pagEmployee

def afterCompose = { c ->
pagEmployee.totalSize = Employee.count()
redraw()
}

def onPaging_pagEmployee(ForwardEvent fe) {
def e = fe.origin
redraw(e.activePage)
}

def redraw(page=0) {
def list = Employee.list(offset: page * pagEmployee.pageSize,
max: pagEmployee.pageSize)

lstEmployee.clear()
lstEmployee.append {
list.each { e ->
listitem(value: e) {
listcell(label: e.id)
listcell(label: e.fullname)
listcell(label: e.username)
}
}
}
}

}

Testing Data

Before getting your application run, you need some testing data to show.
Open grails-app/conf/BootStrap.groovy, and then add the following snippet into init closure.

     def init = { servletContext ->
1000.times { i ->
new Employee(fullname: "Name $i", username: "user$i").save()
}
}

With the above code, we loop 1,000 times to create 1,000 domain objects of class Employee.

Run the application

$ grails run-app

and point your browser to http://localhost:8080/ondemand/employee.zul

Grail (web browser)

Opinions expressed by DZone contributors are their own.

Popular on DZone

  • Getting a Private SSL Certificate Free of Cost
  • Specification by Example Is Not a Test Framework
  • Use Golang for Data Processing With Amazon Kinesis and AWS Lambda
  • GitLab vs Jenkins: Which Is the Best CI/CD Tool?

Comments

Partner Resources

X

ABOUT US

  • About DZone
  • Send feedback
  • Careers
  • Sitemap

ADVERTISE

  • Advertise with DZone

CONTRIBUTE ON DZONE

  • Article Submission Guidelines
  • Become a Contributor
  • Visit the Writers' Zone

LEGAL

  • Terms of Service
  • Privacy Policy

CONTACT US

  • 600 Park Offices Drive
  • Suite 300
  • Durham, NC 27709
  • support@dzone.com
  • +1 (919) 678-0300

Let's be friends: