/* * 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(); } }