/* * Electronic Logistics Management Information System (eLMIS) is a supply chain management system for health commodities in a developing country setting. * * Copyright (C) 2015 John Snow, Inc (JSI). This program was produced for the U.S. Agency for International Development (USAID). It was prepared under the USAID | DELIVER PROJECT, Task Order 4. * * 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.openlmis.ivdform.repository.mapper.reports; import org.apache.ibatis.annotations.*; import org.openlmis.ivdform.domain.reports.VitaminSupplementationLineItem; import org.springframework.stereotype.Repository; import java.util.List; @Repository public interface VitaminSupplementationLineItemMapper { @Insert("INSERT into vaccine_report_vitamin_supplementation_line_items " + " (reportId, vaccineVitaminId, vitaminAgeGroupId,vitaminName, displayOrder, maleValue, femaleValue, createdBy, createdDate, modifiedBy, modifiedDate) " + " values" + " (#{reportId}, #{vaccineVitaminId}, #{vitaminAgeGroupId}, #{vitaminName}, #{displayOrder}, #{maleValue}, #{femaleValue}, #{createdBy}, NOW(), #{modifiedBy}, NOW())") @Options(useGeneratedKeys = true) Integer insert(VitaminSupplementationLineItem lineItem); @Update("UPDATE vaccine_report_vitamin_supplementation_line_items " + " SET" + " maleValue = #{maleValue} " + " , skipped = #{skipped}" + " , femaleValue = #{femaleValue} " + " , modifiedBy = #{modifiedBy} " + " , modifiedDate = NOW()" + " WHERE id = #{id}") Integer update(VitaminSupplementationLineItem lineItem); @Select("select li.*, ag.name as ageGroup " + " from " + " vaccine_report_vitamin_supplementation_line_items li " + " join vaccine_vitamin_supplementation_age_groups ag " + " on ag.id = li.vitaminAgeGroupId " + " WHERE li.reportId = #{reportId} " + " order by id") List<VitaminSupplementationLineItem> getLineItems(@Param("reportId") Long reportId); }