/*
* 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.ArrayList;
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.utils.ALDateUtil;
import com.aimluck.commons.utils.ALStringUtil;
import com.aimluck.eip.addressbook.util.AddressBookUtils;
import com.aimluck.eip.cayenne.om.portlet.EipMAddressGroup;
import com.aimluck.eip.cayenne.om.portlet.EipMAddressbook;
import com.aimluck.eip.cayenne.om.portlet.EipMAddressbookCompany;
import com.aimluck.eip.cayenne.om.portlet.EipTAddressbookGroupMap;
import com.aimluck.eip.common.ALDBErrorException;
import com.aimluck.eip.common.ALEipUser;
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 AddressBookFilterdSelectData extends
AbstractAddressBookFilterdSelectData<EipMAddressbook, EipMAddressbook> {
/** logger */
private static final JetspeedLogger logger = JetspeedLogFactoryService
.getLogger(AddressBookFilterdSelectData.class.getName());
/** フィルタに利用するグループリスト */
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, "name_kana");
}
super.init(action, rundata, context);
}
/**
* アドレス情報の一覧を、グループ・一覧・社員単位で表示する。
*
* @param rundata
* @param context
* @return
*/
@Override
protected ResultList<EipMAddressbook> selectList(RunData rundata,
Context context) {
try {
SelectQuery<EipMAddressbook> query = getSelectQuery(rundata, context);
buildSelectQueryForListView(query);
buildSelectQueryForListViewSort(query, rundata, context);
return query.getResultList();
} catch (Exception ex) {
logger.error("AddressBookFilterdSelectData.selectList", ex);
return null;
}
}
/**
* 社外アドレスタブ選択時のアドレス帳の詳細情報を表示します。
*
* @param rundata
* @param context
* @return
*/
@Override
protected EipMAddressbook selectDetail(RunData rundata, Context context) {
try {
return AddressBookUtils.getEipMAddressbook(rundata, context);
} catch (Exception ex) {
logger.error("AddressBookFilterdSelectData.selectDetail", ex);
return null;
}
}
/**
*
* @param record
* @return
*/
@Override
protected Object getResultData(EipMAddressbook record) {
try {
AddressBookResultData rd = new AddressBookResultData();
rd.initField();
rd.setAddressId(record.getAddressId().intValue());
rd.setName(ALCommonUtils.compressString(new StringBuffer()
.append(record.getLastName())
.append(" ")
.append(record.getFirstName())
.toString(), getStrLength()));
rd.setNameKana(ALCommonUtils.compressString(new StringBuffer()
.append(record.getLastNameKana())
.append(' ')
.append(record.getFirstNameKana())
.toString(), getStrLength()));
EipMAddressbookCompany company = record.getEipMAddressbookCompany();
if (!AddressBookUtils.EMPTY_COMPANY_NAME.equals(company.getCompanyName())) {
// 「その他」の会社情報ではない場合
rd.setCompanyName(ALCommonUtils.compressString(
company.getCompanyName(),
getStrLength()));
rd.setCompanyId(company.getCompanyId().toString());
rd.setPostName(ALCommonUtils.compressString(
company.getPostName(),
getStrLength()));
rd.setCompanyNameKana(ALCommonUtils.compressString(company
.getCompanyNameKana(), getStrLength()));
rd.setPostName(ALCommonUtils.compressString(
company.getPostName(),
getStrLength()));
rd.setZipcode(ALCommonUtils.compressString(
company.getZipcode(),
getStrLength()));
rd.setCompanyAddress(ALCommonUtils.compressString(
company.getAddress(),
getStrLength()));
rd.setCompanyTelephone(ALCommonUtils.compressString(company
.getTelephone(), getStrLength()));
rd.setCompanyFaxNumber(ALCommonUtils.compressString(company
.getFaxNumber(), getStrLength()));
rd.setCompanyUrl(ALCommonUtils.compressString(
company.getUrl(),
getStrLength()));
}
rd.setPositionName(ALCommonUtils.compressString(
record.getPositionName(),
getStrLength()));
rd.setEmail(record.getEmail());
rd.setTelephone(record.getTelephone());
rd.setCellularPhone(record.getCellularPhone());
rd.setCellularMail(record.getCellularMail());
rd.setPublicFlag(record.getPublicFlag());
rd.setNote(record.getNote());
return rd;
} catch (Exception ex) {
logger.error("AddressBookFilterdSelectData.getResultData", ex);
return null;
}
}
/**
* 詳細情報の返却データ取得。
*
* @param record
* @return
*/
@Override
protected Object getResultDataDetail(EipMAddressbook record) {
try {
AddressBookResultData rd = new AddressBookResultData();
rd.initField();
// 登録ユーザ名の設定
ALEipUser createdUser =
ALEipUtils.getALEipUser(record.getCreateUserId().intValue());
String createdUserName = createdUser.getAliasName().getValue();
rd.setCreatedUser(createdUserName);
// 更新ユーザ名の設定
String updatedUserName;
if (record.getCreateUserId().equals(record.getUpdateUserId())) {
updatedUserName = createdUserName;
} else {
ALEipUser updatedUser =
ALEipUtils.getALEipUser(record.getUpdateUserId().intValue());
updatedUserName = updatedUser.getAliasName().getValue();
}
rd.setUpdatedUser(updatedUserName);
// アドレスID の設定
int addressId = record.getAddressId().intValue();
rd.setAddressId(addressId);
rd.setName(new StringBuffer()
.append(record.getLastName())
.append(' ')
.append(record.getFirstName())
.toString());
rd.setNameKana(new StringBuffer()
.append(record.getLastNameKana())
.append(' ')
.append(record.getFirstNameKana())
.toString());
rd.setEmail(record.getEmail());
rd.setTelephone(record.getTelephone());
rd.setCellularPhone(record.getCellularPhone());
rd.setCellularMail(record.getCellularMail());
rd.setPositionName(record.getPositionName());
rd.setNote(record.getNote());
rd.setPublicFlag(record.getPublicFlag());
EipMAddressbookCompany company = record.getEipMAddressbookCompany();
if (!AddressBookUtils.EMPTY_COMPANY_NAME.equals(company.getCompanyName())) {
// 「その他」の会社情報ではない場合、会社情報を設定する
rd.setCompanyName(company.getCompanyName());
rd.setCompanyNameKana(company.getCompanyNameKana());
rd.setPostName(company.getPostName());
rd.setZipcode(company.getZipcode());
rd.setCompanyAddress(company.getAddress());
rd.setCompanyTelephone(company.getTelephone());
rd.setCompanyFaxNumber(company.getFaxNumber());
rd.setCompanyUrl(company.getUrl());
}
rd.setCreateDate(ALDateUtil.format(record.getCreateDate(), "yyyy年M月d日"));
rd.setUpdateDate(ALDateUtil.format(record.getUpdateDate(), "yyyy年M月d日"));
rd.setCreatedUserId(record.getCreateUserId());
rd.setUpdatedUserId(record.getUpdateUserId());
return rd;
} catch (Exception ex) {
logger.error("AddressBookFilterdSelectData.getResultDataDetail", ex);
return null;
}
}
/**
*
* @return
*/
@Override
protected Attributes getColumnMap() {
Attributes map = new Attributes();
map.putValue("group", EipMAddressbook.EIP_TADDRESSBOOK_GROUP_MAP_PROPERTY
+ "."
+ EipTAddressbookGroupMap.EIP_TADDRESS_GROUP_PROPERTY
+ "."
+ EipMAddressGroup.GROUP_ID_PK_COLUMN);
map.putValue("name_kana", EipMAddressbook.LAST_NAME_KANA_PROPERTY);
map.putValue(
"company_name_kana",
EipMAddressbook.EIP_MADDRESSBOOK_COMPANY_PROPERTY
+ "."
+ EipMAddressbookCompany.COMPANY_NAME_KANA_PROPERTY);
return map;
}
/**
* 検索条件を設定した SelectQuery を返します。
*
* @param query
* @param rundata
* @param context
* @return
*/
protected SelectQuery<EipMAddressbook> getSelectQuery(RunData rundata,
Context context) {
SelectQuery<EipMAddressbook> query;
String word = searchWord.toString();
String transWord =
ALStringUtil.convertHiragana2Katakana(ALStringUtil
.convertH2ZKana(searchWord.toString()));
transWord = transWord.replace(" ", " "); // 全角スペースを半角スペースに変換する
String[] transWords = transWord.split(" ");
query = Database.query(EipMAddressbook.class);
for (int i = 0; i < transWords.length; i++) {
Expression exp01 =
ExpressionFactory.matchExp(EipMAddressbook.PUBLIC_FLAG_PROPERTY, "T");
Expression exp02 =
ExpressionFactory.matchExp(
EipMAddressbook.OWNER_ID_PROPERTY,
ALEipUtils.getUserId(rundata));
Expression exp03 =
ExpressionFactory.matchExp(EipMAddressbook.PUBLIC_FLAG_PROPERTY, "F");
query.setQualifier(exp01.orExp(exp02.andExp(exp03)));
Expression exp11 =
ExpressionFactory.likeExp(EipMAddressbook.FIRST_NAME_PROPERTY, "%"
+ word
+ "%");
Expression exp12 =
ExpressionFactory.likeExp(EipMAddressbook.LAST_NAME_PROPERTY, "%"
+ word
+ "%");
Expression exp13 =
ExpressionFactory.likeExp(EipMAddressbook.FIRST_NAME_KANA_PROPERTY, "%"
+ word
+ "%");
Expression exp14 =
ExpressionFactory.likeExp(EipMAddressbook.LAST_NAME_KANA_PROPERTY, "%"
+ word
+ "%");
Expression exp15 =
ExpressionFactory.likeExp(EipMAddressbook.EMAIL_PROPERTY, "%"
+ word
+ "%");
Expression exp16 =
ExpressionFactory.likeExp(EipMAddressbook.TELEPHONE_PROPERTY, "%"
+ word
+ "%");
Expression exp17 =
ExpressionFactory.likeExp(EipMAddressbook.CELLULAR_PHONE_PROPERTY, "%"
+ word
+ "%");
Expression exp18 =
ExpressionFactory.likeExp(EipMAddressbook.CELLULAR_MAIL_PROPERTY, "%"
+ word
+ "%");
Expression exp19 =
ExpressionFactory.likeExp(EipMAddressbook.NOTE_PROPERTY, "%"
+ word
+ "%");
Expression exp21 =
ExpressionFactory.likeExp(
EipMAddressbook.EIP_MADDRESSBOOK_COMPANY_PROPERTY
+ "."
+ EipMAddressbookCompany.COMPANY_NAME_PROPERTY,
"%" + word + "%");
Expression exp22 =
ExpressionFactory.likeExp(
EipMAddressbook.EIP_MADDRESSBOOK_COMPANY_PROPERTY
+ "."
+ EipMAddressbookCompany.COMPANY_NAME_KANA_PROPERTY,
"%" + word + "%");
Expression exp23 =
ExpressionFactory.likeExp(
EipMAddressbook.EIP_MADDRESSBOOK_COMPANY_PROPERTY
+ "."
+ EipMAddressbookCompany.TELEPHONE_PROPERTY,
"%" + word + "%");
Expression exp31 =
ExpressionFactory.likeExp(EipMAddressbook.FIRST_NAME_PROPERTY, "%"
+ transWords[i]
+ "%");
Expression exp32 =
ExpressionFactory.likeExp(EipMAddressbook.LAST_NAME_PROPERTY, "%"
+ transWords[i]
+ "%");
Expression exp33 =
ExpressionFactory.likeExp(EipMAddressbook.FIRST_NAME_KANA_PROPERTY, "%"
+ transWords[i]
+ "%");
Expression exp34 =
ExpressionFactory.likeExp(EipMAddressbook.LAST_NAME_KANA_PROPERTY, "%"
+ transWords[i]
+ "%");
Expression exp35 =
ExpressionFactory.likeExp(
EipMAddressbook.EIP_MADDRESSBOOK_COMPANY_PROPERTY
+ "."
+ EipMAddressbookCompany.COMPANY_NAME_PROPERTY,
"%" + transWords[i] + "%");
Expression exp36 =
ExpressionFactory.likeExp(
EipMAddressbook.EIP_MADDRESSBOOK_COMPANY_PROPERTY
+ "."
+ EipMAddressbookCompany.COMPANY_NAME_KANA_PROPERTY,
"%" + transWords[i] + "%");
Expression exp37 =
ExpressionFactory.likeExp(EipMAddressbook.NOTE_PROPERTY, "%"
+ transWords[i]
+ "%");
Expression exp41 =
ExpressionFactory.matchExp(EipMAddressbook.PUBLIC_FLAG_PROPERTY, "T");
Expression exp42 =
ExpressionFactory.matchExp(
EipMAddressbook.OWNER_ID_PROPERTY,
ALEipUtils.getUserId(rundata));
Expression exp43 =
ExpressionFactory.matchExp(EipMAddressbook.PUBLIC_FLAG_PROPERTY, "F");
if (word != null && !"".equals(word)) {
query.andQualifier((exp11.orExp(exp12).orExp(exp13).orExp(exp14).orExp(
exp15).orExp(exp16).orExp(exp17).orExp(exp18).orExp(exp19).orExp(
exp21).orExp(exp22).orExp(exp23).orExp(exp31).orExp(exp32).orExp(
exp33).orExp(exp34).orExp(exp35).orExp(exp36).orExp(exp37))
.andExp(exp41.orExp(exp42.andExp(exp43))));
}
}
// query.setQualifier(exp41.orExp(exp42.andExp(exp43)));
return getSelectQueryForIndex(query, rundata, context);
}
/**
* インデックス検索のためのカラムを返します。
*
* @return
*/
@Override
protected String getColumnForIndex() {
return EipMAddressbook.LAST_NAME_KANA_PROPERTY;
}
public List<AddressBookGroupResultData> getGroupList() {
return groupList;
}
/**
*
* @param rundata
* @param context
*/
public void loadGroups(RunData rundata, Context context) {
groupList = new ArrayList<AddressBookGroupResultData>();
try {
SelectQuery<EipMAddressGroup> query =
Database.query(EipMAddressGroup.class);
Expression exp =
ExpressionFactory.matchExp(EipMAddressGroup.OWNER_ID_PROPERTY, Integer
.valueOf(ALEipUtils.getUserId(rundata)));
query.setQualifier(exp);
query.orderAscending(EipMAddressGroup.GROUP_NAME_PROPERTY);
List<EipMAddressGroup> aList = query.fetchList();
int size = aList.size();
for (int i = 0; i < size; i++) {
EipMAddressGroup record = aList.get(i);
AddressBookGroupResultData rd = new AddressBookGroupResultData();
rd.initField();
rd.setGroupId(record.getGroupId().intValue());
rd.setGroupName(record.getGroupName());
groupList.add(rd);
}
} catch (Exception ex) {
logger.error("AddressBookFilterdSelectData.loadGroups", ex);
}
}
/**
* アクセス権限チェック用メソッド。 アクセス権限の機能名を返します。
*
* @return
*/
@Override
public String getAclPortletFeature() {
return ALAccessControlConstants.POERTLET_FEATURE_ADDRESSBOOK_ADDRESS_OUTSIDE;
}
/**
* 現在ページを設定します。
*
* @param page
*/
public void setCurrentPage(int page) {
current_page = page;
}
}