/*
* 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.facilities;
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.eip.cayenne.om.portlet.EipMFacility;
import com.aimluck.eip.cayenne.om.portlet.EipMFacilityGroupMap;
import com.aimluck.eip.common.ALAbstractSelectData;
import com.aimluck.eip.common.ALDBErrorException;
import com.aimluck.eip.common.ALData;
import com.aimluck.eip.common.ALPageNotFoundException;
import com.aimluck.eip.facilities.util.FacilitiesUtils;
import com.aimluck.eip.modules.actions.common.ALAction;
import com.aimluck.eip.orm.Database;
import com.aimluck.eip.orm.query.Operations;
import com.aimluck.eip.orm.query.ResultList;
import com.aimluck.eip.orm.query.SelectQuery;
import com.aimluck.eip.util.ALEipUtils;
/**
* 設備検索データを管理するクラスです。 <BR>
*
*/
public class FacilitySelectData extends
ALAbstractSelectData<EipMFacility, EipMFacility> implements ALData {
/** logger */
private static final JetspeedLogger logger = JetspeedLogFactoryService
.getLogger(FacilitySelectData.class.getName());
/** 設備の総数 */
private int facilitySum;
/** 全設備グループの一覧 */
private List<FacilityGroupResultData> AllFacilitygroup;
/** <code>viewtype</code> 表示タイプ */
protected String viewtype;
/** フィルターなしの全設備リスト */
private List<FacilityResultData> facilityAllList;
/**
*
* @param action
* @param rundata
* @param context
*/
@Override
public void init(ALAction action, RunData rundata, Context context)
throws ALPageNotFoundException, ALDBErrorException {
loadFacilityAllList(rundata,context);
String sort = ALEipUtils.getTemp(rundata, context, LIST_SORT_STR);
if (sort == null || sort.equals("")) {
ALEipUtils.setTemp(rundata, context, LIST_SORT_STR, ALEipUtils
.getPortlet(rundata, context)
.getPortletConfig()
.getInitParameter("p2a-sort"));
}
AllFacilitygroup = FacilitiesUtils.getFacilityGroupAllList();
super.init(action, rundata, context);
viewtype = "facility";
}
/**
* 一覧データを取得します。 <BR>
*
* @param rundata
* @param context
* @return
*/
@Override
public ResultList<EipMFacility> selectList(RunData rundata, Context context) {
try {
SelectQuery<EipMFacility> query = getSelectQuery(rundata, context);
buildSelectQueryForListView(query);
buildSelectQueryForListViewSort(query, rundata, context);
ResultList<EipMFacility> list = query.getResultList();
// 設備の総数をセットする.
facilitySum = list.getTotalCount();
return list;
} catch (Exception ex) {
logger.error("facilities", ex);
return null;
}
}
/**
* 検索条件を設定した SelectQuery を返します。 <BR>
*
* @param rundata
* @param context
* @return
*/
private SelectQuery<EipMFacility> getSelectQuery(RunData rundata,
Context context) {
SelectQuery<EipMFacility> query = Database.query(EipMFacility.class);
return buildSelectQueryForFilter(query, rundata, context);
}
/**
* ResultData に値を格納して返します。(一覧データ) <BR>
*
* @param obj
* @return
*/
@Override
protected Object getResultData(EipMFacility record) {
try {
FacilityResultData rd = new FacilityResultData();
rd.initField();
rd.setFacilityId(record.getFacilityId().longValue());
rd.setFacilityName(record.getFacilityName());
return rd;
} catch (Exception ex) {
logger.error("facilities", ex);
return null;
}
}
/**
* queryにFilterをセットします。
*
* @param query
* @param rundata
* @param context
* @return
*/
@Override
protected SelectQuery<EipMFacility> buildSelectQueryForFilter(
SelectQuery<EipMFacility> query, RunData rundata, Context context) {
String filter = ALEipUtils.getTemp(rundata, context, LIST_FILTER_STR);
String filter_type =
ALEipUtils.getTemp(rundata, context, LIST_FILTER_TYPE_STR);
String crt_key = null;
Attributes map = getColumnMap();
if (filter == null || filter_type == null || filter.equals("")) {
return query;
}
crt_key = map.getValue(filter_type);
if (crt_key == null) {
return query;
}
if (crt_key.equals(EipMFacilityGroupMap.GROUP_ID_PROPERTY)) {
SelectQuery<EipMFacilityGroupMap> mapquery =
Database.query(EipMFacilityGroupMap.class);
mapquery.where(Operations.eq(
EipMFacilityGroupMap.GROUP_ID_PROPERTY,
Integer.valueOf(filter)));
List<EipMFacilityGroupMap> facilityGroupMapList = mapquery.fetchList();
List<Integer> facilityIdList = new ArrayList<Integer>();
for (EipMFacilityGroupMap fmap : facilityGroupMapList) {
facilityIdList.add(fmap.getFacilityId());
}
// if facility not exist, add no one match id
if (facilityIdList.size() == 0) {
facilityIdList.add(Integer.valueOf(0));
}
Expression exp =
ExpressionFactory.inDbExp(
EipMFacility.FACILITY_ID_PK_COLUMN,
facilityIdList);
query.andQualifier(exp);
} else {
Expression exp = ExpressionFactory.matchExp(crt_key, filter);
query.andQualifier(exp);
}
current_filter = filter;
current_filter_type = filter_type;
return query;
}
/**
* 詳細データを取得します。 <BR>
*
* @param rundata
* @param context
* @return
*/
@Override
public EipMFacility selectDetail(RunData rundata, Context context) {
return FacilitiesUtils.getEipMFacility(rundata, context);
}
/**
* ResultData に値を格納して返します。(詳細データ) <BR>
*
* @param obj
* @return
*/
@Override
protected Object getResultDataDetail(EipMFacility record) {
try {
FacilityResultData rd = new FacilityResultData();
rd.initField();
rd.setFacilityName(record.getFacilityName());
rd.setFacilityId(record.getFacilityId().longValue());
rd.setNote(record.getNote());
rd.setCreateDate(record.getCreateDate());
rd.setUpdateDate(record.getUpdateDate());
return rd;
} catch (Exception ex) {
logger.error("facilities", ex);
return null;
}
}
/**
* 設備の総数を返す. <BR>
*
* @return
*/
public int getFacilitySum() {
return facilitySum;
}
/**
* 表示タイプを取得します。
*
* @return
*/
public String getViewtype() {
return viewtype;
}
/**
* @return
*
*/
@Override
protected Attributes getColumnMap() {
Attributes map = new Attributes();
map.putValue("facility_name", EipMFacility.FACILITY_NAME_PROPERTY);
map.putValue("group_id", EipMFacilityGroupMap.GROUP_ID_PROPERTY);
map.putValue("sort", EipMFacility.SORT_PROPERTY);
return map;
}
/**
*
* @param id
* @return
*/
public boolean isMatch(int id1, long id2) {
return id1 == (int) id2;
}
public List<FacilityGroupResultData> getAllFacilityGroup() {
return AllFacilitygroup;
}
/**
*
* @param rundata
* @param context
*/
public void loadFacilityAllList(RunData rundata, Context context) {
facilityAllList = new ArrayList<FacilityResultData>();
facilityAllList.addAll(FacilitiesUtils.getFacilityAllList());
}
public int getAllFacilitySum() {
return facilityAllList.size();
}
}