/**
* ***************************************************************************
* Copyright (c) 2010 Qcadoo Limited
* Project: Qcadoo MES
* Version: 1.4
*
* This file is part of Qcadoo.
*
* Qcadoo 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, write to the Free Software
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
* ***************************************************************************
*/
package com.qcadoo.mes.masterOrders.util;
import static com.qcadoo.model.api.search.SearchProjections.alias;
import static com.qcadoo.model.api.search.SearchProjections.field;
import static com.qcadoo.model.api.search.SearchProjections.id;
import static com.qcadoo.model.api.search.SearchProjections.list;
import static com.qcadoo.model.api.search.SearchProjections.rowCount;
import static com.qcadoo.model.api.search.SearchProjections.sum;
import static com.qcadoo.model.api.search.SearchRestrictions.belongsTo;
import static com.qcadoo.model.api.search.SearchRestrictions.eq;
import java.math.BigDecimal;
import java.util.Collection;
import java.util.List;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import com.qcadoo.mes.masterOrders.constants.OrderFieldsMO;
import com.qcadoo.mes.orders.constants.OrderFields;
import com.qcadoo.mes.orders.constants.OrdersConstants;
import com.qcadoo.model.api.DataDefinition;
import com.qcadoo.model.api.DataDefinitionService;
import com.qcadoo.model.api.Entity;
import com.qcadoo.model.api.search.JoinType;
import com.qcadoo.model.api.search.SearchCriteriaBuilder;
import com.qcadoo.model.api.search.SearchCriterion;
import com.qcadoo.model.api.search.SearchOrder;
import com.qcadoo.model.api.search.SearchOrders;
import com.qcadoo.model.api.search.SearchProjection;
import com.qcadoo.model.api.utils.EntityUtils;
@Service
public class MasterOrderOrdersDataProvider {
public static final SearchProjection ORDER_NUMBER_PROJECTION = list().add(
alias(field(OrderFields.NUMBER), OrderFields.NUMBER)).add(alias(id(), "id"));
private static final String QUANTITIES_SUM_ALIAS = "quantity";
@Autowired
private DataDefinitionService dataDefinitionService;
public long countBelongingOrders(final Entity masterOrder, final SearchCriterion additionalCriteria) {
List<Entity> ordersCountProjection = findBelongingOrders(masterOrder, alias(rowCount(), "count"), additionalCriteria,
SearchOrders.desc("count"));
for (Entity entity : ordersCountProjection) {
return (Long) entity.getField("count");
}
return 0L;
}
public BigDecimal sumBelongingOrdersPlannedQuantities(final Entity masterOrder, final Entity product) {
SearchProjection quantitiesSumProjection = list().add(alias(sum(OrderFields.PLANNED_QUANTITY), QUANTITIES_SUM_ALIAS))
.add(rowCount());
SearchCriterion productCriterion = belongsTo(OrderFields.PRODUCT, product);
List<Entity> quantitiesSumProjectionResults = findBelongingOrders(masterOrder, quantitiesSumProjection, productCriterion,
SearchOrders.desc(QUANTITIES_SUM_ALIAS));
for (Entity entity : quantitiesSumProjectionResults) {
return entity.getDecimalField(QUANTITIES_SUM_ALIAS);
}
return BigDecimal.ZERO;
}
public Collection<String> findBelongingOrderNumbers(final Entity masterOrder, final SearchCriterion searchCriteria) {
List<Entity> ordersProjection = findBelongingOrders(masterOrder, ORDER_NUMBER_PROJECTION, searchCriteria, null);
return EntityUtils.getFieldsView(ordersProjection, OrderFields.NUMBER);
}
public List<Entity> findBelongingOrders(final Entity masterOrder, final SearchProjection projection,
final SearchCriterion additionalCriteria, final SearchOrder searchOrder) {
SearchCriteriaBuilder scb = getOrderDD().find();
scb.createAlias(OrderFieldsMO.MASTER_ORDER, "mo_alias", JoinType.INNER);
scb.add(eq("mo_alias.id", masterOrder.getId()));
if (additionalCriteria != null) {
scb.add(additionalCriteria);
}
if (projection != null) {
scb.setProjection(projection);
}
if (searchOrder != null) {
scb.addOrder(searchOrder);
}
return scb.list().getEntities();
}
private DataDefinition getOrderDD() {
return dataDefinitionService.get(OrdersConstants.PLUGIN_IDENTIFIER, OrdersConstants.MODEL_ORDER);
}
public BigDecimal sumBelongingOrdersDoneQuantities(final Entity masterOrder, final Entity product) {
SearchProjection quantitiesSumProjection = list().add(alias(sum(OrderFields.DONE_QUANTITY), QUANTITIES_SUM_ALIAS))
.add(rowCount());
SearchCriterion productCriterion = belongsTo(OrderFields.PRODUCT, product);
List<Entity> quantitiesSumProjectionResults = findBelongingOrders(masterOrder, quantitiesSumProjection, productCriterion,
SearchOrders.desc(QUANTITIES_SUM_ALIAS));
for (Entity entity : quantitiesSumProjectionResults) {
return entity.getDecimalField(QUANTITIES_SUM_ALIAS);
}
return BigDecimal.ZERO;
}
}