View Javadoc

1   /*
2    * Copyright 2008 The Kuali Foundation
3    *
4    * Licensed under the Educational Community License, Version 2.0 (the "License");
5    * you may not use this file except in compliance with the License.
6    * You may obtain a copy of the License at
7    *
8    * http://www.opensource.org/licenses/ecl2.php
9    *
10   * Unless required by applicable law or agreed to in writing, software
11   * distributed under the License is distributed on an "AS IS" BASIS,
12   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13   * See the License for the specific language governing permissions and
14   * limitations under the License.
15   */
16  package org.kuali.ole.module.purap.document.service;
17  
18  import org.kuali.ole.module.purap.document.CorrectionReceivingDocument;
19  import org.kuali.ole.module.purap.document.LineItemReceivingDocument;
20  import org.kuali.ole.module.purap.document.PurchaseOrderDocument;
21  import org.kuali.ole.module.purap.document.ReceivingDocument;
22  import org.kuali.rice.kew.api.exception.WorkflowException;
23  
24  import java.util.HashMap;
25  import java.util.List;
26  
27  public interface ReceivingService {
28  
29      /**
30       * Populates a Receiving Line Document with information from a Purchase Order.
31       *
32       * @param rlDoc
33       */
34      public void populateReceivingLineFromPurchaseOrder(LineItemReceivingDocument rlDoc);
35  
36      /**
37       * Populates a Receiving Correction Document with information from a Receiving Line.
38       *
39       * @param rcDoc
40       */
41      public void populateCorrectionReceivingFromReceivingLine(CorrectionReceivingDocument rcDoc);
42  
43      /**
44       * A save is done passing the continue purap event so as to call a populate within
45       * prepare for save.
46       *
47       * @param rlDoc
48       * @throws WorkflowException
49       */
50      public void populateAndSaveLineItemReceivingDocument(LineItemReceivingDocument rlDoc) throws WorkflowException;
51  
52      /**
53       * Populates the receiving correction document.
54       *
55       * @param rcDoc
56       */
57      public void populateCorrectionReceivingDocument(CorrectionReceivingDocument rcDoc);
58  
59      /**
60       * Determines if a receiving line document can be created at the time the user requests it.
61       * This version looks up the current purchase order by po id and also excludes the current receiving
62       * document from the check.
63       *
64       * @param poId
65       * @param receivingDocumentNumber
66       * @return
67       * @throws RuntimeException
68       */
69      public boolean canCreateLineItemReceivingDocument(Integer poId, String receivingDocumentNumber) throws RuntimeException;
70  
71      /**
72       * Determines if a receiving line document can be created at the time the user requests it.
73       * This version requires the purchase order being evaluated to be passed in.
74       *
75       * @param po
76       * @return
77       * @throws RuntimeException
78       */
79      public boolean canCreateLineItemReceivingDocument(PurchaseOrderDocument po) throws RuntimeException;
80  
81      /**
82       * @param rl
83       * @return
84       * @throws RuntimeException
85       */
86      public boolean canCreateCorrectionReceivingDocument(LineItemReceivingDocument rl) throws RuntimeException;
87  
88      /**
89       * @param rl
90       * @param receivingCorrectionDocNumber
91       * @return
92       * @throws RuntimeException
93       */
94      public boolean canCreateCorrectionReceivingDocument(LineItemReceivingDocument rl, String receivingCorrectionDocNumber) throws RuntimeException;
95  
96      /**
97       * Checks for duplicate Receiving Line documents and passes back a list of those found
98       * where vendor date, packing slip number or bill of lading match on previous receiving line
99       * documents by purchase order.
100      *
101      * @param rlDoc
102      * @return
103      */
104     public HashMap<String, String> receivingLineDuplicateMessages(LineItemReceivingDocument rlDoc);
105 
106     /**
107      * This method deletes unneeded items and updates the totals on the po and does any additional processing based on items i.e. FYI etc
108      *
109      * @param receivingDocument receiving document
110      */
111     public void completeReceivingDocument(ReceivingDocument receivingDocument);
112 
113     /**
114      * This method updates the corrected quantities on the receiving document.
115      *
116      * @param receivingDocument receivingCorrectionDocument
117      */
118     public void completeCorrectionReceivingDocument(ReceivingDocument correctionDocument);
119 
120     /**
121      * Adds a note to a receiving document.
122      *
123      * @param receivingDocument
124      * @param note
125      * @throws Exception
126      */
127     public void addNoteToReceivingDocument(ReceivingDocument receivingDocument, String note) throws Exception;
128 
129     /**
130      * Returns a delivery campus code on a receiving document based on the purchase order passed in.
131      *
132      * @param po
133      * @return
134      */
135     public String getReceivingDeliveryCampusCode(PurchaseOrderDocument po);
136 
137     /**
138      * Determines if there is at least one receiving line document that has gone to final for a purchase order.
139      *
140      * @param poId
141      * @return
142      * @throws RuntimeException
143      */
144     public boolean isLineItemReceivingDocumentGeneratedForPurchaseOrder(Integer poId) throws RuntimeException;
145 
146     public void createNoteForReturnedAndDamagedItems(ReceivingDocument recDoc);
147 
148     /**
149      * This method iterates all the line item receiving documents with Awaiting Purchase Order Open Status and approves it if the
150      * associated PO is available for amedment.
151      */
152     public void approveReceivingDocsForPOAmendment();
153 
154     /**
155      * Returns a list of line item receiving documents in process for a purchase order
156      *
157      * @param receivingDocumentNumber
158      * @return
159      */
160     public List<String> getLineItemReceivingDocumentNumbersInProcessForPurchaseOrder(Integer poId, String receivingDocumentNumber);
161 
162     /**
163      * Returns a list of line item receiving documents in final status for a purchase order
164      *
165      * @param receivingDocumentNumber
166      * @return
167      */
168     public List<LineItemReceivingDocument> getLineItemReceivingDocumentsInFinalForPurchaseOrder(Integer poId);
169 
170 
171     /**
172      * Returns a list of correction receiving documents in process for a purchase order
173      *
174      * @param poId
175      * @param receivingDocumentNumber
176      * @return
177      */
178     public List<String> getCorrectionReceivingDocumentNumbersInProcessForPurchaseOrder(Integer poId, String receivingDocumentNumber);
179 
180     /**
181      * Returns true, if the po is active for receiving document creation
182      */
183     public boolean isPurchaseOrderActiveForLineItemReceivingDocumentCreation(Integer poId);
184 
185     /**
186      * Checks if there're newly added items in the given LineItemReceivingDocument.
187      *
188      * @param rlDoc the given LineItemReceivingDocument
189      * @return true if there're newly added (unordered) items; false otherwise.
190      */
191     public boolean hasNewUnorderedItem(LineItemReceivingDocument rlDoc);
192 
193 }