001 /** 002 * Copyright 2004-2013 The Kuali Foundation 003 * 004 * Licensed under the Educational Community License, Version 2.0 (the "License"); 005 * you may not use this file except in compliance with the License. 006 * You may obtain a copy of the License at 007 * 008 * http://www.opensource.org/licenses/ecl2.php 009 * 010 * Unless required by applicable law or agreed to in writing, software 011 * distributed under the License is distributed on an "AS IS" BASIS, 012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 013 * See the License for the specific language governing permissions and 014 * limitations under the License. 015 */ 016 package org.kuali.hr.time.graceperiod.service; 017 018 import org.kuali.hr.time.graceperiod.dao.GracePeriodDao; 019 import org.kuali.hr.time.graceperiod.rule.GracePeriodRule; 020 021 import java.math.BigDecimal; 022 import java.sql.Date; 023 import java.sql.Timestamp; 024 import java.util.List; 025 026 public class GracePeriodServiceImpl implements GracePeriodService { 027 private GracePeriodDao gracePeriodDao; 028 029 public GracePeriodDao getGracePeriodDao() { 030 return gracePeriodDao; 031 } 032 033 public void setGracePeriodDao(GracePeriodDao gracePeriodDao) { 034 this.gracePeriodDao = gracePeriodDao; 035 } 036 037 @Override 038 public GracePeriodRule getGracePeriodRule(Date asOfDate){ 039 return gracePeriodDao.getGracePeriodRule(asOfDate); 040 } 041 042 043 @SuppressWarnings("deprecation") 044 public Timestamp processGracePeriodRule(Timestamp actualTime, Date asOfDate){ 045 GracePeriodRule gracePeriodRule = getGracePeriodRule(asOfDate); 046 if(gracePeriodRule!=null){ 047 //go ahead and round off seconds 048 actualTime.setSeconds(0); 049 050 BigDecimal minuteIncrement = gracePeriodRule.getHourFactor(); 051 BigDecimal minutes = new BigDecimal(actualTime.getMinutes()); 052 int bottomIntervalFactor = minutes.divide(minuteIncrement, 0, BigDecimal.ROUND_FLOOR).intValue(); 053 BigDecimal bottomInterval = new BigDecimal(bottomIntervalFactor).multiply(minuteIncrement); 054 BigDecimal topInterval = new BigDecimal(bottomIntervalFactor + 1).multiply(minuteIncrement); 055 if(bottomInterval.subtract(minutes).abs().intValue() < topInterval.subtract(minutes).abs().intValue()){ 056 actualTime.setMinutes(bottomInterval.setScale(0, BigDecimal.ROUND_HALF_UP).intValue()); 057 } else { 058 if(topInterval.equals(new BigDecimal(60))){ 059 actualTime.setHours(actualTime.getHours()+1); 060 actualTime.setMinutes(0); 061 } else { 062 actualTime.setMinutes(topInterval.setScale(0, BigDecimal.ROUND_HALF_UP).intValue()); 063 } 064 } 065 } 066 return actualTime; 067 } 068 069 @Override 070 public GracePeriodRule getGracePeriodRule(String tkGracePeriodId) { 071 return gracePeriodDao.getGracePeriodRule(tkGracePeriodId); 072 } 073 074 @Override 075 public List<GracePeriodRule> getGracePeriodRules(String hourFactor, String active, String showHistory) { 076 return gracePeriodDao.getGracePeriodRules(hourFactor, active, showHistory); 077 } 078 }