Java tutorial
/* * Copyright (c) 2011 Brown Bag Consulting. * This file is part of the ExpressUI project. * Author: Juan Osuna * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License Version 3 * as published by the Free Software Foundation with the addition of the * following permission added to Section 15 as permitted in Section 7(a): * FOR ANY PART OF THE COVERED WORK IN WHICH THE COPYRIGHT IS OWNED BY * Brown Bag Consulting, Brown Bag Consulting DISCLAIMS THE WARRANTY OF * NON INFRINGEMENT OF THIRD PARTY RIGHTS. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see <http://www.gnu.org/licenses/>. * * The interactive user interfaces in modified source and object code versions * of this program must display Appropriate Legal Notices, as required under * Section 5 of the GNU Affero General Public License. * * You can be released from the requirements of the license by purchasing * a commercial license. Buying such a license is mandatory as soon as you * develop commercial activities involving the ExpressUI software without * disclosing the source code of your own applications. These activities * include: offering paid services to customers as an ASP, providing * services from a web application, shipping ExpressUI with a closed * source product. * * For more information, please contact Brown Bag Consulting at this * address: juan@brownbagconsulting.com. */ package com.expressui.sample.view.contact; import com.expressui.core.dao.StructuredEntityQuery; import com.expressui.sample.dao.ContactDao; import com.expressui.sample.entity.Contact; import com.expressui.sample.entity.Country; import com.expressui.sample.entity.State; import org.springframework.context.annotation.Scope; import org.springframework.stereotype.Component; import javax.annotation.Resource; import javax.persistence.TypedQuery; import javax.persistence.criteria.*; import java.util.ArrayList; import java.util.HashSet; import java.util.List; import java.util.Set; @Component @Scope("prototype") @SuppressWarnings({ "rawtypes" }) public class ContactQuery extends StructuredEntityQuery<Contact> { @Resource private ContactDao contactDao; private String lastName; private Set<State> states = new HashSet<State>(); private Country country; public String getLastName() { return lastName; } public void setLastName(String lastName) { this.lastName = lastName; } public Set<State> getStates() { return states; } public void setStates(Set<State> states) { this.states = states; } public Country getCountry() { return country; } public void setCountry(Country country) { this.country = country; } @Override public List<Contact> execute() { return contactDao.execute(this); } @Override public List<Predicate> buildCriteria(CriteriaBuilder builder, Root<Contact> rootEntity) { List<Predicate> criteria = new ArrayList<Predicate>(); if (!isEmpty(lastName)) { ParameterExpression<String> p = builder.parameter(String.class, "lastName"); criteria.add(builder.like(builder.upper(rootEntity.<String>get("lastName")), p)); } if (!isEmpty(states)) { ParameterExpression<Set> p = builder.parameter(Set.class, "states"); criteria.add(builder.in(rootEntity.get("mailingAddress").get("state")).value(p)); } if (!isEmpty(country)) { ParameterExpression<Country> p = builder.parameter(Country.class, "country"); criteria.add(builder.equal(rootEntity.get("mailingAddress").get("country"), p)); } return criteria; } @Override public void setParameters(TypedQuery typedQuery) { if (!isEmpty(lastName)) { typedQuery.setParameter("lastName", "%" + lastName.toUpperCase() + "%"); } if (!isEmpty(states)) { typedQuery.setParameter("states", states); } if (!isEmpty(country)) { typedQuery.setParameter("country", country); } } @Override public Path buildOrderBy(Root<Contact> rootEntity) { if (getOrderByPropertyId().equals("mailingAddress.country")) { return rootEntity.join("mailingAddress", JoinType.LEFT).join("country", JoinType.LEFT); } else if (getOrderByPropertyId().equals("mailingAddress.state.code")) { return rootEntity.join("mailingAddress", JoinType.LEFT).join("state", JoinType.LEFT).get("code"); } else if (getOrderByPropertyId().equals("account.name")) { return rootEntity.join("account", JoinType.LEFT).get("name"); } else { return null; } } @Override public void addFetchJoins(Root<Contact> rootEntity) { rootEntity.fetch("mailingAddress", JoinType.LEFT).fetch("state", JoinType.LEFT); rootEntity.fetch("account", JoinType.LEFT); } @Override public String toString() { return "ContactQuery{" + "lastName='" + lastName + '\'' + ", states=" + states + '}'; } }