001 /* 002 * Copyright 2011 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.kfs.module.ld.service; 017 018 import java.util.Collection; 019 import java.util.Map; 020 021 import org.kuali.kfs.module.ld.businessobject.AccountStatusCurrentFunds; 022 import org.kuali.kfs.module.ld.businessobject.LedgerBalance; 023 import org.kuali.kfs.module.ld.businessobject.LedgerEntry; 024 import org.kuali.rice.kns.web.ui.Field; 025 import org.kuali.rice.kns.web.ui.Row; 026 027 /** 028 * The LaborInquiryOptionsService interface provides hooks for Pending Ledger and Consilidation options for balance inquiries. 029 */ 030 public interface LaborInquiryOptionsService { 031 032 /** 033 * The expected name of the consolidation option field name 034 * 035 * @return String 036 */ 037 public String getConsolidationFieldName(); 038 039 /** 040 * Examine a collection of <code>{@link Row}</code> instances for the consolidation field 041 * 042 * @param rows 043 * @return Field 044 */ 045 public Field getConsolidationField(Collection<Row> rows); 046 047 /** 048 * Get the current state of the consolidation option 049 * 050 * @return String 051 */ 052 public String getConsolidationOption(Map fieldValues); 053 054 /** 055 * This method tests if the user selects to see the details or consolidated results 056 * 057 * @param fieldValues the map containing the search fields and values 058 * @param rows 059 * @return true if consolidation is selected and subaccount is not specified 060 */ 061 public boolean isConsolidationSelected(Map fieldValues, Collection<Row> rows); 062 063 /** 064 * This method tests if the user selects to see the details or consolidated results 065 * 066 * @param fieldValues the map containing the search fields and values 067 * @return true if consolidation is selected and subaccount is not specified 068 */ 069 public boolean isConsolidationSelected(Map fieldValues); 070 071 /** 072 * update a given balance collection with the pending entry obtained from the given field values and pending entry option 073 * 074 * @param balanceCollection the given ledger balance collection 075 * @param fieldValues the given field values 076 * @param pendingEntryOption the given pending entry option: all, approved or none 077 * @param isConsolidated indicate if the collection balances have been consolidated 078 * @see org.kuali.kfs.module.ld.businessobject.LedgerBalance 079 */ 080 public void updateLedgerBalanceByPendingLedgerEntry(Collection<LedgerBalance> balanceCollection, Map fieldValues, String pendingEntryOption, boolean isConsolidated); 081 082 /** 083 * update a given balance collection with the pending entry obtained from the given field values and pending entry option 084 * 085 * @param balanceCollection the given ledger balance collection 086 * @param fieldValues the given field values 087 * @param pendingEntryOption the given pending entry option: all, approved or none 088 * @param isConsolidated indicate if the collection balances have been consolidated 089 * @see org.kuali.kfs.module.ld.businessobject.LedgerBalance 090 */ 091 public void updateCurrentFundsByPendingLedgerEntry(Collection<AccountStatusCurrentFunds> balanceCollection, Map fieldValues, String pendingEntryOption, boolean isConsolidated); 092 093 /** 094 * update a given ledger entry collection with the pending entry obtained from the given field values and pending entry option 095 * 096 * @param entryCollection the given ledger entry collection 097 * @param fieldValues the given field values 098 * @param pendingEntryOption the given pending entry option: all, approved or none 099 * @see org.kuali.kfs.module.ld.businessobject.LedgerEntry 100 */ 101 public void updateLedgerEntryByPendingLedgerEntry(Collection<LedgerEntry> entryCollection, Map fieldValues, String pendingEntryOption); 102 103 /** 104 * Get the Pending Entry Option selected 105 * 106 * @param fieldValues 107 * @return String 108 */ 109 public String getSelectedPendingEntryOption(Map fieldValues); 110 }