/*
* 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.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;
/**
* アドレス帳会社情報の検索用データクラスです。
*
*/
public class AddressBookCompanySelectData extends
ALAbstractSelectData<EipMAddressbookCompany, EipMAddressbookCompany> {
/** logger */
private static final JetspeedLogger logger = JetspeedLogFactoryService
.getLogger(AddressBookCompanySelectData.class.getName());
/** 現在選択されているインデックス */
private String index;
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) {
try {
SelectQuery<EipMAddressbookCompany> query =
getSelectQuery(rundata, context);
buildSelectQueryForListView(query);
buildSelectQueryForListViewSort(query, rundata, context);
return query.getResultList();
} catch (Exception ex) {
logger.error("AddressBookCompanySelectData.selectList", ex);
return null;
}
}
/**
*
* @param rundata
* @param context
* @return
*/
@Override
protected EipMAddressbookCompany selectDetail(RunData rundata, Context context) {
try {
EipMAddressbookCompany record;
String companyId =
ALEipUtils.getTemp(rundata, context, ALEipConstants.ENTITY_ID);
if (companyId == null || Integer.valueOf(companyId) == null) {
return null;
}
AddressBookCompanyResultData rd = new AddressBookCompanyResultData();
rd.initField();
record =
Database.get(EipMAddressbookCompany.class, Integer.valueOf(companyId));
return record;
} catch (Exception ex) {
logger.error("AddressBookCompanySelectData.selectDetail", ex);
return null;
}
}
/**
*
* @param obj
* @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("AddressBookCompanySelectData.getResultData", ex);
return null;
}
}
/**
*
* @param obj
* @return
*/
@Override
protected Object getResultDataDetail(EipMAddressbookCompany record) {
try {
AddressBookCompanyResultData rd = new AddressBookCompanyResultData();
rd.initField();
rd.setCompanyId(record.getCompanyId().intValue());
rd.setCompanyName(record.getCompanyName());
rd.setCompanyNameKana(record.getCompanyNameKana());
rd.setPostName(record.getPostName());
rd.setZipcode(record.getZipcode());
rd.setAddress(record.getAddress());
rd.setTelephone(record.getTelephone());
rd.setFaxNumber(record.getFaxNumber());
rd.setUrl(record.getUrl());
return rd;
} catch (Exception ex) {
logger.error("AddressBookCompanySelectData.getResultDataDetail", ex);
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);
query.setQualifier(AddressBookUtils.excludeDefaultCompanyCriteria());
// インデックス指定時の条件文作成
String index_session = ALEipUtils.getTemp(rundata, context, LIST_INDEX_STR);
String index_rundata = rundata.getParameters().getString("idx");
if (index_rundata != null) {
if ("-1".equals(index_rundata) || "".equals(index_rundata)) {
ALEipUtils.setTemp(rundata, context, LIST_INDEX_STR, "-1");
context.put("idx", "-1");
} else {
index = index_rundata;
ALEipUtils.setTemp(rundata, context, LIST_INDEX_STR, index);
buildSelectQueryForAddressbookIndex(
query,
EipMAddressbookCompany.COMPANY_NAME_KANA_PROPERTY,
Integer.parseInt(index));
context.put("idx", index);
}
} else if (index_session != null) {
buildSelectQueryForAddressbookIndex(
query,
EipMAddressbookCompany.COMPANY_NAME_KANA_PROPERTY,
Integer.parseInt(index_session));
context.put("idx", index);
} else {
context.put("idx", "-1");
}
return buildSelectQueryForFilter(query, rundata, context);
}
/**
* 現在選択されているインデックスを取得します。
*
* @return
*/
public String getIndex() {
return index;
}
/**
* インデックス検索のためのユニコードマッピングによる条件文の追加。
*
* @param crt
* @param idx
*/
private void buildSelectQueryForAddressbookIndex(
SelectQuery<EipMAddressbookCompany> query, String companyNameKana, int idx) {
// インデックスによる検索
switch (idx) {
// ア行
case 1:
Expression exp01 =
ExpressionFactory.greaterOrEqualExp(companyNameKana, "ア");
Expression exp02 = ExpressionFactory.lessExp(companyNameKana, "カ");
query.andQualifier(exp01.andExp(exp02));
break;
// カ行
case 6:
Expression exp11 =
ExpressionFactory.greaterOrEqualExp(companyNameKana, "カ");
Expression exp12 = ExpressionFactory.lessExp(companyNameKana, "サ");
query.andQualifier(exp11.andExp(exp12));
break;
// サ行
case 11:
Expression exp21 =
ExpressionFactory.greaterOrEqualExp(companyNameKana, "サ");
Expression exp22 = ExpressionFactory.lessExp(companyNameKana, "タ");
query.andQualifier(exp21.andExp(exp22));
break;
// タ行
case 16:
Expression exp31 =
ExpressionFactory.greaterOrEqualExp(companyNameKana, "タ");
Expression exp32 = ExpressionFactory.lessExp(companyNameKana, "ナ");
query.andQualifier(exp31.andExp(exp32));
break;
// ナ行
case 21:
Expression exp41 =
ExpressionFactory.greaterOrEqualExp(companyNameKana, "ナ");
Expression exp42 = ExpressionFactory.lessExp(companyNameKana, "ハ");
query.andQualifier(exp41.andExp(exp42));
break;
// ハ行
case 26:
Expression exp51 =
ExpressionFactory.greaterOrEqualExp(companyNameKana, "ハ");
Expression exp52 = ExpressionFactory.lessExp(companyNameKana, "マ");
query.andQualifier(exp51.andExp(exp52));
break;
// マ行
case 31:
Expression exp61 =
ExpressionFactory.greaterOrEqualExp(companyNameKana, "マ");
Expression exp62 = ExpressionFactory.lessExp(companyNameKana, "ヤ");
query.andQualifier(exp61.andExp(exp62));
break;
// ヤ行
case 36:
Expression exp71 =
ExpressionFactory.greaterOrEqualExp(companyNameKana, "ヤ");
Expression exp72 = ExpressionFactory.lessExp(companyNameKana, "ラ");
query.andQualifier(exp71.andExp(exp72));
break;
// ラ行
case 41:
Expression exp81 =
ExpressionFactory.greaterOrEqualExp(companyNameKana, "ラ");
Expression exp82 = ExpressionFactory.lessExp(companyNameKana, "ワ");
query.andQualifier(exp81.andExp(exp82));
break;
// ワ行
case 46:
Expression exp91 =
ExpressionFactory.greaterOrEqualExp(companyNameKana, "ワ");
Expression exp92 =
ExpressionFactory.lessOrEqualExp(companyNameKana, "ヴ");
query.andQualifier(exp91.andExp(exp92));
break;
// 英数(上記以外)
case 52:
Expression exp100 = ExpressionFactory.lessExp(companyNameKana, "ア");
Expression exp101 =
ExpressionFactory.greaterOrEqualExp(companyNameKana, "ヴ");
query.andQualifier(exp100.orExp(exp101));
break;
// default
default:
Expression exp111 = ExpressionFactory.lessExp(companyNameKana, "");
Expression exp112 =
ExpressionFactory.greaterOrEqualExp(companyNameKana, "");
query.andQualifier(exp111.orExp(exp112));
}
}
public List<AddressBookGroupResultData> getGroupList() {
return groupList;
}
/**
* アクセス権限チェック用メソッド。 アクセス権限の機能名を返します。
*
* @return
*/
@Override
public String getAclPortletFeature() {
return ALAccessControlConstants.POERTLET_FEATURE_ADDRESSBOOK_COMPANY;
}
/**
* 現在ページを設定します。
*
* @param page
*/
public void setCurrentPage(int page) {
current_page = page;
}
}