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.lm.leave.approval.service; 017 018 import java.math.BigDecimal; 019 import java.util.Date; 020 import java.util.List; 021 import java.util.Map; 022 023 import org.kuali.hr.lm.leaveblock.LeaveBlock; 024 import org.kuali.hr.lm.workflow.LeaveCalendarDocumentHeader; 025 import org.kuali.hr.time.approval.web.ApprovalLeaveSummaryRow; 026 import org.kuali.hr.time.calendar.CalendarEntries; 027 import org.kuali.hr.time.person.TKPerson; 028 import org.kuali.rice.kew.api.note.Note; 029 030 public interface LeaveApprovalService { 031 public List<ApprovalLeaveSummaryRow> getLeaveApprovalSummaryRows(List<TKPerson> persons, CalendarEntries payCalendarEntries, List<Date> leaveSummaryDates); 032 033 public Map<Date, Map<String, BigDecimal>> getEarnCodeLeaveHours(List<LeaveBlock> leaveBlocks, List<Date> leaveSummaryDates); 034 035 public List<Map<String, Object>> getLeaveApprovalDetailSections(LeaveCalendarDocumentHeader lcdh); 036 037 public Map<Date, Map<String, BigDecimal>> getAccrualCategoryLeaveHours(List<LeaveBlock> leaveBlocks, List<Date> leaveSummaryDates); 038 039 /** 040 * Used to determine if there are notes on a document 041 * @param documentNumber 042 * @return list of note objects 043 */ 044 public List<Note> getNotesForDocument(String documentNumber); 045 046 public List<String> getUniqueLeavePayGroupsForPrincipalIds(List<String> principalIds); 047 048 /* 049 * returns all calendar entries with LeaveCalendarDocument created and can be approved by given principalId 050 */ 051 public List<CalendarEntries> getAllLeavePayCalendarEntriesForApprover(String principalId, Date currentDate); 052 053 /* 054 * remove the employees with no jobs that are eligible for leave fromt the given list of principal ids 055 * 056 * @param principalIds 057 * 058 */ 059 public void removeNonLeaveEmployees(List<String> principalIds); 060 061 /** 062 * Method to create a map that contains the principal's id and corresponding leave calendar document header. 063 * 064 *@param persons 065 * @param payBeginDate 066 * @param payEndDate 067 * @return A PrincipalId to LeaveCalendarDocumentHeader mapping. 068 */ 069 public Map<String, LeaveCalendarDocumentHeader> getPrincipalDocumehtHeader(List<TKPerson> persons, Date payBeginDate, Date payEndDate); 070 071 /** 072 * 073 * @param principalId 074 * @param flsaStatus 075 * @param chkForLeaveEligible 076 * @return 077 */ 078 public boolean isActiveAssignmentFoundOnJobFlsaStatus(String principalId, String flsaStatus, boolean chkForLeaveEligible); 079 080 /** 081 * Method to get a lit of principal ids based on work area list, calendarGroup and dates 082 * @param workAreaList 083 * @param calendarGroup 084 * @param effdt 085 * @param beginDate 086 * @param endDate 087 * @return 088 */ 089 public List<String> getLeavePrincipalIdsWithSearchCriteria( 090 List<String> workAreaList, String calendarGroup, java.sql.Date effdt, java.sql.Date beginDate, java.sql.Date endDate); 091 }