diff --git a/src/main/java/edu/ucdavis/dss/ipa/api/components/course/CourseViewController.java b/src/main/java/edu/ucdavis/dss/ipa/api/components/course/CourseViewController.java index 0c8baac0c..c1f648a9c 100644 --- a/src/main/java/edu/ucdavis/dss/ipa/api/components/course/CourseViewController.java +++ b/src/main/java/edu/ucdavis/dss/ipa/api/components/course/CourseViewController.java @@ -129,6 +129,9 @@ public SectionGroup updateSectionGroup(@PathVariable long sectionGroupId, @Reque originalSectionGroup.setTeachingAssistantAppointments(sectionGroup.getTeachingAssistantAppointments()); originalSectionGroup.setReaderAppointments(sectionGroup.getReaderAppointments()); + originalSectionGroup.setTaAppointmentPercentage(sectionGroup.getTaAppointmentPercentage()); + originalSectionGroup.setReaderAppointmentPercentage(sectionGroup.getReaderAppointmentPercentage()); + return sectionGroupService.save(originalSectionGroup); } diff --git a/src/main/java/edu/ucdavis/dss/ipa/api/deserializers/SectionGroupDeserializer.java b/src/main/java/edu/ucdavis/dss/ipa/api/deserializers/SectionGroupDeserializer.java index a8979a250..09fe64c28 100644 --- a/src/main/java/edu/ucdavis/dss/ipa/api/deserializers/SectionGroupDeserializer.java +++ b/src/main/java/edu/ucdavis/dss/ipa/api/deserializers/SectionGroupDeserializer.java @@ -48,6 +48,14 @@ public Object deserialize(JsonParser jsonParser, DeserializationContext deserial sg.setReaderAppointments(node.get("readerAppointments").floatValue()); } + if (node.has("taAppointmentPercentage") && node.hasNonNull("taAppointmentPercentage")) { + sg.setTaAppointmentPercentage(node.get("taAppointmentPercentage").intValue()); + } + + if (node.has("readerAppointmentPercentage") && node.hasNonNull("readerAppointmentPercentage")) { + sg.setReaderAppointmentPercentage(node.get("readerAppointmentPercentage").intValue()); + } + if (node.has("showTheStaff")) { sg.setShowTheStaff(node.get("showTheStaff").booleanValue()); } diff --git a/src/main/java/edu/ucdavis/dss/ipa/entities/SectionGroup.java b/src/main/java/edu/ucdavis/dss/ipa/entities/SectionGroup.java index 719dad9cc..5a40530f4 100644 --- a/src/main/java/edu/ucdavis/dss/ipa/entities/SectionGroup.java +++ b/src/main/java/edu/ucdavis/dss/ipa/entities/SectionGroup.java @@ -33,7 +33,7 @@ public class SectionGroup extends BaseEntity { private List teachingAssignments = new ArrayList(); private List activities = new ArrayList(); private String termCode; - private Integer plannedSeats; + private Integer plannedSeats, taAppointmentPercentage, readerAppointmentPercentage; private Float teachingAssistantAppointments, readerAppointments; private Boolean showTheStaff = false; @@ -191,4 +191,14 @@ public Float getReaderAppointments() { public void setReaderAppointments(Float readerAppointments) { this.readerAppointments = readerAppointments; } + + @JsonProperty + public Integer getTaAppointmentPercentage() { return taAppointmentPercentage; } + + public void setTaAppointmentPercentage(Integer taAppointmentPercentage) { this.taAppointmentPercentage = taAppointmentPercentage; } + + @JsonProperty + public Integer getReaderAppointmentPercentage() { return readerAppointmentPercentage; } + + public void setReaderAppointmentPercentage(Integer readerAppointmentPercentage) { this.readerAppointmentPercentage = readerAppointmentPercentage; } } diff --git a/src/main/java/edu/ucdavis/dss/ipa/entities/SectionGroupCost.java b/src/main/java/edu/ucdavis/dss/ipa/entities/SectionGroupCost.java index 2af3e0c0f..601facbad 100644 --- a/src/main/java/edu/ucdavis/dss/ipa/entities/SectionGroupCost.java +++ b/src/main/java/edu/ucdavis/dss/ipa/entities/SectionGroupCost.java @@ -23,7 +23,7 @@ public class SectionGroupCost extends BaseEntity { private long id; private BudgetScenario budgetScenario; - private Integer sectionCount; + private Integer sectionCount, taAppointmentPercentage, readerAppointmentPercentage; private Long enrollment; private Instructor instructor; private Instructor originalInstructor; @@ -64,6 +64,10 @@ public void setTaCount(Float taCount) { this.taCount = taCount; } + public Integer getTaAppointmentPercentage() { return taAppointmentPercentage; } + + public void setTaAppointmentPercentage(Integer taAppointmentPercentage) { this.taAppointmentPercentage = taAppointmentPercentage; } + public Integer getSectionCount() { return sectionCount; } @@ -80,6 +84,10 @@ public void setReaderCount(Float readerCount) { this.readerCount = readerCount; } + public Integer getReaderAppointmentPercentage() { return readerAppointmentPercentage; } + + public void setReaderAppointmentPercentage(Integer readerAppointmentPercentage) { this.readerAppointmentPercentage = readerAppointmentPercentage; } + public BigDecimal getCost() { return cost; } diff --git a/src/main/java/edu/ucdavis/dss/ipa/services/jpa/JpaSectionGroupCostService.java b/src/main/java/edu/ucdavis/dss/ipa/services/jpa/JpaSectionGroupCostService.java index 1d24af3ff..163b89711 100644 --- a/src/main/java/edu/ucdavis/dss/ipa/services/jpa/JpaSectionGroupCostService.java +++ b/src/main/java/edu/ucdavis/dss/ipa/services/jpa/JpaSectionGroupCostService.java @@ -169,11 +169,21 @@ public SectionGroupCost updateFromSectionGroup(SectionGroup sectionGroup, Budget sectionGroupCost.setTaCount(sectionGroup.getTeachingAssistantAppointments()); } + if (sectionGroupCost.getTaAppointmentPercentage() != sectionGroup.getTaAppointmentPercentage()) { + updateRequired = true; + sectionGroupCost.setTaAppointmentPercentage(sectionGroup.getReaderAppointmentPercentage()); + } + if (sectionGroupCost.getReaderCount() != sectionGroup.getReaderAppointments()) { updateRequired = true; sectionGroupCost.setReaderCount(sectionGroup.getReaderAppointments()); } + if (sectionGroupCost.getReaderAppointmentPercentage() != sectionGroup.getReaderAppointmentPercentage()) { + updateRequired = true; + sectionGroupCost.setReaderAppointmentPercentage(sectionGroup.getReaderAppointmentPercentage()); + } + Instructor instructor = null; InstructorType instructorType = null; diff --git a/src/main/resources/db/migration/V228__Add_AppointmentPercentage_To_SectionGroups.sql b/src/main/resources/db/migration/V228__Add_AppointmentPercentage_To_SectionGroups.sql new file mode 100644 index 000000000..cf08de42b --- /dev/null +++ b/src/main/resources/db/migration/V228__Add_AppointmentPercentage_To_SectionGroups.sql @@ -0,0 +1,4 @@ +ALTER TABLE `SectionGroups` ADD COLUMN `TaAppointmentPercentage` INT(11) NULL; +ALTER TABLE `SectionGroups` ADD COLUMN `ReaderAppointmentPercentage` INT(11) NULL; +ALTER TABLE `SectionGroupCosts` ADD COLUMN `TaAppointmentPercentage` INT(11) NULL; +ALTER TABLE `SectionGroupCosts` ADD COLUMN `ReaderAppointmentPercentage` INT(11) NULL;