001 /**
002 * Copyright 2004-2014 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.kpme.tklm.time.rules.clocklocation.validation;
017
018 import java.util.List;
019
020 import org.apache.commons.collections.CollectionUtils;
021 import org.kuali.kpme.core.web.KpmeEffectiveDatePromptBase;
022 import org.kuali.kpme.tklm.time.rules.clocklocation.ClockLocationRule;
023 import org.kuali.kpme.tklm.time.service.TkServiceLocator;
024 import org.kuali.rice.krad.bo.PersistableBusinessObject;
025
026 public class ClockLocationRuleEffectiveDatePrompt extends KpmeEffectiveDatePromptBase {
027
028 @Override
029 protected boolean futureEffectiveDateExists(PersistableBusinessObject pbo) {
030 boolean futureEffectiveDateExists = false;
031 ClockLocationRule clr = (ClockLocationRule) pbo;
032 if(clr.getEffectiveLocalDate() != null) {
033 List<ClockLocationRule> lastClr = TkServiceLocator.getClockLocationRuleService().getNewerVersionClockLocationRule(clr.getDept(), clr.getWorkArea(), clr.getPrincipalId(), clr.getJobNumber(), clr.getEffectiveLocalDate());
034 futureEffectiveDateExists = CollectionUtils.isNotEmpty(lastClr);
035 }
036 return futureEffectiveDateExists;
037 }
038
039 }