/* * Aipo is a groupware program developed by TOWN, Inc. * Copyright (C) 2004-2015 TOWN, Inc. * http://www.aipo.com * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * 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/>. */ package com.aimluck.eip.addressbook; import java.util.List; import java.util.jar.Attributes; import org.apache.cayenne.exp.Expression; import org.apache.cayenne.exp.ExpressionFactory; import org.apache.jetspeed.services.logging.JetspeedLogFactoryService; import org.apache.jetspeed.services.logging.JetspeedLogger; import org.apache.turbine.util.RunData; import org.apache.velocity.context.Context; import com.aimluck.commons.field.ALStringField; import com.aimluck.commons.utils.ALStringUtil; import com.aimluck.eip.addressbook.util.AddressBookUtils; import com.aimluck.eip.cayenne.om.portlet.EipMAddressbookCompany; import com.aimluck.eip.common.ALAbstractSelectData; import com.aimluck.eip.common.ALDBErrorException; import com.aimluck.eip.common.ALEipConstants; import com.aimluck.eip.common.ALPageNotFoundException; import com.aimluck.eip.modules.actions.common.ALAction; import com.aimluck.eip.orm.Database; import com.aimluck.eip.orm.query.ResultList; import com.aimluck.eip.orm.query.SelectQuery; import com.aimluck.eip.services.accessctl.ALAccessControlConstants; import com.aimluck.eip.util.ALCommonUtils; import com.aimluck.eip.util.ALEipUtils; /** * アドレス帳での検索BOX用データです。 * */ public class AddressBookCompanyWordSelectData extends ALAbstractSelectData<EipMAddressbookCompany, EipMAddressbookCompany> { /** logger */ private static final JetspeedLogger logger = JetspeedLogFactoryService .getLogger(AddressBookCompanyWordSelectData.class.getName()); /** 検索ワード */ private ALStringField searchWord; private List<AddressBookGroupResultData> groupList; /** * * @param action * @param rundata * @param context * @throws ALPageNotFoundException * @throws ALDBErrorException */ @Override public void init(ALAction action, RunData rundata, Context context) throws ALPageNotFoundException, ALDBErrorException { String sort = ALEipUtils.getTemp(rundata, context, LIST_SORT_STR); if (sort == null || sort.equals("")) { ALEipUtils.setTemp(rundata, context, LIST_SORT_STR, "company_name_kana"); } groupList = AddressBookUtils.getMyGroups(rundata); super.init(action, rundata, context); } /** * * @param rundata * @param context * @return */ @Override protected ResultList<EipMAddressbookCompany> selectList(RunData rundata, Context context) { // ページャからきた場合に検索ワードをセッションへ格納する if (!rundata.getParameters().containsKey(ALEipConstants.LIST_START) && !rundata.getParameters().containsKey(ALEipConstants.LIST_SORT)) { ALEipUtils.setTemp(rundata, context, "AddressBooksCompanyword", rundata .getParameters() .getString("sword")); } // 検索ワードの設定 searchWord = new ALStringField(); searchWord.setTrim(true); // セッションから値を取得する。 // 検索ワード未指定時は空文字が入力される searchWord.setValue(ALEipUtils.getTemp( rundata, context, "AddressBooksCompanyword")); try { SelectQuery<EipMAddressbookCompany> query = getSelectQuery(rundata, context); buildSelectQueryForListView(query); buildSelectQueryForListViewSort(query, rundata, context); return query.getResultList(); } catch (Exception ex) { logger.error("AddressBookCompanyWordSelectData.selectList", ex); return null; } } /** * * @param rundata * @param context * @return */ @Override protected EipMAddressbookCompany selectDetail(RunData rundata, Context context) { return null; } /** * * @param record * @return */ @Override protected Object getResultData(EipMAddressbookCompany record) { try { AddressBookCompanyResultData rd = new AddressBookCompanyResultData(); rd.initField(); rd.setCompanyId(record.getCompanyId().intValue()); rd.setCompanyName(ALCommonUtils.compressString( record.getCompanyName(), getStrLength())); rd.setCompanyNameKana(record.getCompanyNameKana()); rd.setPostName(ALCommonUtils.compressString( record.getPostName(), getStrLength())); rd.setZipcode(record.getZipcode()); rd.setAddress(ALCommonUtils.compressString( record.getAddress(), getStrLength())); rd.setTelephone(record.getTelephone()); rd.setFaxNumber(record.getFaxNumber()); rd.setUrl(record.getUrl()); return rd; } catch (Exception ex) { logger.error("AddressBookCompanyWordSelectData.selectDetail", ex); return null; } } /** * * @param obj * @return */ @Override protected Object getResultDataDetail(EipMAddressbookCompany obj) { return null; } /** * * @return */ @Override protected Attributes getColumnMap() { Attributes map = new Attributes(); map.putValue( "company_name_kana", EipMAddressbookCompany.COMPANY_NAME_KANA_PROPERTY); return map; } /** * 検索条件を設定した SelectQuery を返します。 * * @param rundata * @param context * @return */ private SelectQuery<EipMAddressbookCompany> getSelectQuery(RunData rundata, Context context) { SelectQuery<EipMAddressbookCompany> query = Database.query(EipMAddressbookCompany.class); // exclude default company query.setQualifier(AddressBookUtils.excludeDefaultCompanyCriteria()); String word = searchWord.getValue(); String transWord = ALStringUtil.convertHiragana2Katakana(ALStringUtil .convertH2ZKana(searchWord.getValue())); Expression exp11 = ExpressionFactory.likeExp( EipMAddressbookCompany.COMPANY_NAME_PROPERTY, "%" + word + "%"); Expression exp12 = ExpressionFactory.likeExp( EipMAddressbookCompany.COMPANY_NAME_KANA_PROPERTY, "%" + word + "%"); Expression exp13 = ExpressionFactory.likeExp(EipMAddressbookCompany.POST_NAME_PROPERTY, "%" + word + "%"); Expression exp14 = ExpressionFactory.likeExp(EipMAddressbookCompany.ZIPCODE_PROPERTY, "%" + word + "%"); Expression exp15 = ExpressionFactory.likeExp(EipMAddressbookCompany.ADDRESS_PROPERTY, "%" + word + "%"); Expression exp16 = ExpressionFactory.likeExp(EipMAddressbookCompany.TELEPHONE_PROPERTY, "%" + word + "%"); Expression exp17 = ExpressionFactory.likeExp(EipMAddressbookCompany.FAX_NUMBER_PROPERTY, "%" + word + "%"); Expression exp18 = ExpressionFactory.likeExp(EipMAddressbookCompany.URL_PROPERTY, "%" + word + "%"); Expression exp21 = ExpressionFactory.likeExp( EipMAddressbookCompany.COMPANY_NAME_PROPERTY, "%" + transWord + "%"); Expression exp22 = ExpressionFactory.likeExp( EipMAddressbookCompany.COMPANY_NAME_KANA_PROPERTY, "%" + transWord + "%"); Expression exp23 = ExpressionFactory.likeExp(EipMAddressbookCompany.POST_NAME_PROPERTY, "%" + transWord + "%"); Expression exp24 = ExpressionFactory.likeExp(EipMAddressbookCompany.ZIPCODE_PROPERTY, "%" + transWord + "%"); Expression exp25 = ExpressionFactory.likeExp(EipMAddressbookCompany.ADDRESS_PROPERTY, "%" + transWord + "%"); Expression exp26 = ExpressionFactory.likeExp(EipMAddressbookCompany.TELEPHONE_PROPERTY, "%" + transWord + "%"); Expression exp27 = ExpressionFactory.likeExp(EipMAddressbookCompany.FAX_NUMBER_PROPERTY, "%" + transWord + "%"); Expression exp28 = ExpressionFactory.likeExp(EipMAddressbookCompany.URL_PROPERTY, "%" + transWord + "%"); query.andQualifier(exp11 .orExp(exp12) .orExp(exp13) .orExp(exp14) .orExp(exp15) .orExp(exp16) .orExp(exp17) .orExp(exp18) .orExp(exp21) .orExp(exp22) .orExp(exp23) .orExp(exp24) .orExp(exp25) .orExp(exp26) .orExp(exp27) .orExp(exp28)); return query; } /** * 検索ワードを取得します。 * * @return */ public ALStringField getSearchWord() { return searchWord; } /** * アクセス権限チェック用メソッド。 アクセス権限の機能名を返します。 * * @return */ @Override public String getAclPortletFeature() { return ALAccessControlConstants.POERTLET_FEATURE_ADDRESSBOOK_COMPANY; } public List<AddressBookGroupResultData> getGroupList() { return groupList; } /** * 現在ページを設定します。 * * @param page */ public void setCurrentPage(int page) { current_page = page; } }