/*
* 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.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.EipMFacilityGroup;
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.ResultList;
import com.aimluck.eip.orm.query.SelectQuery;
import com.aimluck.eip.util.ALEipUtils;
/**
* 設備検索データを管理するクラスです。 <BR>
*
*/
public class FacilityGroupSelectData extends
ALAbstractSelectData<EipMFacilityGroup, EipMFacilityGroup> implements
ALData {
/** logger */
private static final JetspeedLogger logger = JetspeedLogFactoryService
.getLogger(FacilityGroupSelectData.class.getName());
/** 設備グループの総数 */
private int facilitygroupSum;
/** フィルターなしの全設備グループリスト */
private List<FacilityGroupResultData> facilityGroupAllList;
/** <code>viewtype</code> 表示タイプ */
protected String viewtype;
/**
*
* @param action
* @param rundata
* @param context
*/
@Override
public void init(ALAction action, RunData rundata, Context context)
throws ALPageNotFoundException, ALDBErrorException {
loadFacilityGroupAllList(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"));
}
super.init(action, rundata, context);
viewtype = "group";
}
/**
* 一覧データを取得します。 <BR>
*
* @param rundata
* @param context
* @return
*/
@Override
public ResultList<EipMFacilityGroup> selectList(RunData rundata,
Context context) {
try {
SelectQuery<EipMFacilityGroup> query = getSelectQuery(rundata, context);
buildSelectQueryForListView(query);
buildSelectQueryForListViewSort(query, rundata, context);
ResultList<EipMFacilityGroup> list = query.getResultList();
// 設備の総数をセットする.
facilitygroupSum = list.getTotalCount();
return list;
} catch (Exception ex) {
logger.error("facilities", ex);
return null;
}
}
public static List<FacilityGroupResultData> getFacilityGroupList(
String groupname) {
SelectQuery<EipMFacilityGroup> query =
Database.query(EipMFacilityGroup.class);
query.orderAscending(EipMFacilityGroup.SORT_PROPERTY);
List<FacilityGroupResultData> list =
FacilitiesUtils.getFacilityGroupResultList(query.fetchList());
return list;
}
/**
* 検索条件を設定した SelectQuery を返します。 <BR>
*
* @param rundata
* @param context
* @return
*/
private SelectQuery<EipMFacilityGroup> getSelectQuery(RunData rundata,
Context context) {
SelectQuery<EipMFacilityGroup> query =
Database.query(EipMFacilityGroup.class);
return buildSelectQueryForFilter(query, rundata, context);
}
/**
* ResultData に値を格納して返します。(一覧データ) <BR>
*
* @param obj
* @return
*/
@Override
protected Object getResultData(EipMFacilityGroup record) {
try {
FacilityGroupResultData rd = new FacilityGroupResultData();
rd.initField();
rd.setGroupId(record.getGroupId().longValue());
rd.setGroupName(record.getGroupName());
return rd;
} catch (Exception ex) {
logger.error("facilities", ex);
return null;
}
}
/**
* 詳細データを取得します。 <BR>
*
* @param rundata
* @param context
* @return
*/
@Override
public EipMFacilityGroup selectDetail(RunData rundata, Context context) {
return FacilitiesUtils.getEipMFacilityGroup(rundata, context);
}
/**
* ResultData に値を格納して返します。(詳細データ) <BR>
*
* @param obj
* @return
*/
@Override
protected Object getResultDataDetail(EipMFacilityGroup record) {
try {
FacilityGroupResultData rd = new FacilityGroupResultData();
rd.initField();
rd.setGroupId(record.getGroupId());
rd.setGroupName(record.getGroupName());
return rd;
} catch (Exception ex) {
logger.error("facilities", ex);
return null;
}
}
public void loadFacilityGroupAllList(RunData rundata, Context context) {
facilityGroupAllList = new ArrayList<FacilityGroupResultData>();
facilityGroupAllList.addAll(FacilitiesUtils.getFacilityGroupAllList());
}
/**
* 設備の総数を返す. <BR>
*
* @return
*/
public int getFacilityGroupSum() {
return facilitygroupSum;
}
/**
* 表示タイプを取得します。
*
* @return
*/
public String getViewtype() {
return viewtype;
}
/**
* @return
*
*/
@Override
protected Attributes getColumnMap() {
Attributes map = new Attributes();
map.putValue("group_name", EipMFacilityGroup.GROUP_NAME_PROPERTY);
map.putValue("group_id", EipMFacilityGroupMap.GROUP_ID_PROPERTY);
map.putValue("sort", EipMFacilityGroup.SORT_PROPERTY);
return map;
}
/**
*
* @param id
* @return
*/
public boolean isMatch(int id1, long id2) {
return id1 == (int) id2;
}
}