ItEr41S23CUImportarTraballoRealizadoPorSubcontrata: Added information about advance on order elements exportation.

This commit is contained in:
Manuel Rego Casasnovas 2009-12-30 21:18:50 +01:00 committed by Javier Moran Rua
parent 6c4af2533e
commit 706ed0334c
6 changed files with 110 additions and 7 deletions

View file

@ -0,0 +1,51 @@
/*
* This file is part of ###PROJECT_NAME###
*
* Copyright (C) 2009 Fundación para o Fomento da Calidade Industrial e
* Desenvolvemento Tecnolóxico de Galicia
*
* 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 org.navalplanner.ws.orders.api;
import java.math.BigDecimal;
import java.util.Date;
import javax.xml.bind.annotation.XmlAttribute;
import org.navalplanner.business.advance.entities.AdvanceMeasurement;
/**
* DTO for {@link AdvanceMeasurement} entity.
*
* @author Manuel Rego Casasnovas <mrego@igalia.com>
*/
public class AdvanceMeasurementDTO {
@XmlAttribute
public Date date;
@XmlAttribute
public BigDecimal value;
public AdvanceMeasurementDTO() {
}
public AdvanceMeasurementDTO(Date date, BigDecimal value) {
this.date = date;
this.value = value;
}
}

View file

@ -50,10 +50,11 @@ public class OrderDTO extends OrderLineGroupDTO {
public OrderDTO(String name, String code, Date initDate, Date deadline,
String description, Set<LabelDTO> labels,
Set<MaterialAssignmentDTO> materialAssignments,
Set<AdvanceMeasurementDTO> advanceMeasurements,
List<OrderElementDTO> children,
Boolean dependenciesConstraintsHavePriority, String calendarName) {
super(name, code, initDate, deadline, description, labels,
materialAssignments, children);
materialAssignments, advanceMeasurements, children);
this.dependenciesConstraintsHavePriority = dependenciesConstraintsHavePriority;
this.calendarName = calendarName;
}

View file

@ -62,12 +62,17 @@ public class OrderElementDTO {
@XmlElement(name = "material-assignment")
public Set<MaterialAssignmentDTO> materialAssignments = new HashSet<MaterialAssignmentDTO>();
@XmlElementWrapper(name = "advance-measurements")
@XmlElement(name = "advance-measurement")
public Set<AdvanceMeasurementDTO> advanceMeasurements = new HashSet<AdvanceMeasurementDTO>();
public OrderElementDTO() {
}
public OrderElementDTO(String name, String code, Date initDate,
Date deadline, String description, Set<LabelDTO> labels,
Set<MaterialAssignmentDTO> materialAssignments) {
Set<MaterialAssignmentDTO> materialAssignments,
Set<AdvanceMeasurementDTO> advanceMeasurements) {
this.name = name;
this.code = code;
this.initDate = initDate;
@ -75,6 +80,7 @@ public class OrderElementDTO {
this.description = description;
this.labels = labels;
this.materialAssignments = materialAssignments;
this.advanceMeasurements = advanceMeasurements;
}
}

View file

@ -49,8 +49,10 @@ public class OrderLineDTO extends OrderElementDTO {
public OrderLineDTO(String name, String code, Date initDate, Date deadline,
String description, Set<LabelDTO> labels,
Set<MaterialAssignmentDTO> materialAssignments,
Set<AdvanceMeasurementDTO> advanceMeasurements,
Set<HoursGroupDTO> hoursGroups) {
super(name, code, initDate, deadline, description, labels, materialAssignments);
super(name, code, initDate, deadline, description, labels,
materialAssignments, advanceMeasurements);
this.hoursGroups = hoursGroups;
}

View file

@ -54,9 +54,10 @@ public class OrderLineGroupDTO extends OrderElementDTO {
public OrderLineGroupDTO(String name, String code, Date initDate,
Date deadline, String description, Set<LabelDTO> labels,
Set<MaterialAssignmentDTO> materialAssignments,
Set<AdvanceMeasurementDTO> advanceMeasurements,
List<OrderElementDTO> children) {
super(name, code, initDate, deadline, description, labels,
materialAssignments);
materialAssignments, advanceMeasurements);
this.children = children;
}

View file

@ -22,6 +22,8 @@ package org.navalplanner.ws.orders.impl;
import static org.navalplanner.web.I18nHelper._;
import java.math.BigDecimal;
import java.math.RoundingMode;
import java.util.ArrayList;
import java.util.Date;
import java.util.HashSet;
@ -29,6 +31,8 @@ import java.util.List;
import java.util.Set;
import org.hibernate.NonUniqueResultException;
import org.navalplanner.business.advance.entities.AdvanceMeasurement;
import org.navalplanner.business.advance.entities.DirectAdvanceAssignment;
import org.navalplanner.business.calendars.entities.BaseCalendar;
import org.navalplanner.business.common.Registry;
import org.navalplanner.business.common.exceptions.InstanceNotFoundException;
@ -47,6 +51,7 @@ import org.navalplanner.business.resources.entities.ResourceEnum;
import org.navalplanner.ws.common.api.IncompatibleTypeException;
import org.navalplanner.ws.common.api.ResourceEnumDTO;
import org.navalplanner.ws.common.impl.ResourceEnumConverter;
import org.navalplanner.ws.orders.api.AdvanceMeasurementDTO;
import org.navalplanner.ws.orders.api.HoursGroupDTO;
import org.navalplanner.ws.orders.api.LabelDTO;
import org.navalplanner.ws.orders.api.MaterialAssignmentDTO;
@ -83,6 +88,9 @@ public final class OrderElementConverter {
materialAssignments.add(toDTO(materialAssignment));
}
Set<AdvanceMeasurementDTO> advanceMeasurements = toDTO(orderElement
.getReportGlobalAdvanceAssignment());
if (orderElement instanceof OrderLine) {
Set<HoursGroupDTO> hoursGroups = new HashSet<HoursGroupDTO>();
for (HoursGroup hoursGroup : ((OrderLine) orderElement)
@ -91,7 +99,8 @@ public final class OrderElementConverter {
}
return new OrderLineDTO(name, code, initDate, deadline,
description, labels, materialAssignments, hoursGroups);
description, labels, materialAssignments,
advanceMeasurements, hoursGroups);
} else { // orderElement instanceof OrderLineGroup
List<OrderElementDTO> children = new ArrayList<OrderElementDTO>();
for (OrderElement element : orderElement.getChildren()) {
@ -108,15 +117,48 @@ public final class OrderElementConverter {
}
return new OrderDTO(name, code, initDate, deadline,
description, labels, materialAssignments, children,
description, labels, materialAssignments,
advanceMeasurements, children,
dependenciesConstraintsHavePriority, calendarName);
} else { // orderElement instanceof OrderLineGroup
return new OrderLineGroupDTO(name, code, initDate, deadline,
description, labels, materialAssignments, children);
description, labels, materialAssignments,
advanceMeasurements, children);
}
}
}
public final static Set<AdvanceMeasurementDTO> toDTO(
DirectAdvanceAssignment advanceAssignment) {
Set<AdvanceMeasurementDTO> advanceMeasurements = new HashSet<AdvanceMeasurementDTO>();
if (advanceAssignment != null) {
BigDecimal maxValue = advanceAssignment.getMaxValue();
for (AdvanceMeasurement advanceMeasurement : advanceAssignment
.getAdvanceMeasurements()) {
advanceMeasurements.add(toDTO(maxValue, advanceAssignment
.getAdvanceType().getPercentage(), advanceMeasurement));
}
}
return advanceMeasurements;
}
public final static AdvanceMeasurementDTO toDTO(BigDecimal maxValue,
boolean isPercentage, AdvanceMeasurement advanceMeasurement) {
BigDecimal value;
if (isPercentage) {
value = advanceMeasurement.getValue();
} else {
value = advanceMeasurement.getValue().divide(maxValue,
RoundingMode.DOWN);
}
Date date = advanceMeasurement.getDate().toDateTimeAtStartOfDay()
.toDate();
return new AdvanceMeasurementDTO(date, value);
}
public final static MaterialAssignmentDTO toDTO(
MaterialAssignment materialAssignment) {
return new MaterialAssignmentDTO(materialAssignment.getMaterial()