| /* |
| * Licensed to the Apache Software Foundation (ASF) under one |
| * or more contributor license agreements. See the NOTICE file |
| * distributed with this work for additional information |
| * regarding copyright ownership. The ASF licenses this file |
| * to you under the Apache License, Version 2.0 (the |
| * "License"); you may not use this file except in compliance |
| * with the License. You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, |
| * software distributed under the License is distributed on an |
| * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY |
| * KIND, either express or implied. See the License for the |
| * specific language governing permissions and limitations |
| * under the License. |
| */ |
| |
| productId = request.getParameter("productId"); |
| if (!productId) { |
| productId = session.getAttribute("productId"); |
| } |
| |
| if (productId) { |
| product = from("Product").where("productId", productId).cache(true).queryOne(); |
| context.product = product; |
| |
| facilityId = request.getParameter("facilityId"); |
| resultOutput = runService('getInventoryAvailableByFacility', [productId : productId, facilityId : facilityId]); |
| quantitySummary = [:]; |
| quantitySummary.facilityId = facilityId; |
| quantitySummary.atp_qoh = ((Double)resultOutput.availableToPromiseTotal).intValue() + " / " + |
| ((Double)resultOutput.quantityOnHandTotal).intValue(); |
| context.quantitySummary = quantitySummary; |
| |
| // For now this just generates a visual list of locations set against the product for this facility. |
| // todo: Will need to be able to edit and change these values at some point in the future. |
| productFacilityLocList = from("ProductFacilityLocation").where("productId", productId, "facilityId", facilityId).queryList(); |
| facStr = null; |
| productFacilityLocList.each { facilityLoc -> |
| if (!facStr) { |
| facStr = facilityLoc.locationSeqId; |
| } else { |
| facStr = facStr + ", " + facilityLoc.locationSeqId; |
| } |
| } |
| context.productFacilityLocations = facStr; |
| |
| |
| // Now we build a list of locations for inventory items against the facility. |
| // todo: change this to a select from inv_items where productId and facilityId matches distinct (locationSeqId). |
| invItemList = from("InventoryItem").where("productId", productId, "facilityId", facilityId).queryList(); |
| |
| locations = [:]; |
| |
| boolean negativeQOH = false; |
| invItemList.each { invItem -> |
| int qoh = ((Double)invItem.quantityOnHandTotal).intValue(); |
| if (qoh < 0) { |
| negativeQOH = true; |
| } |
| locationFound = (String)invItem.locationSeqId; |
| if (!locationFound) { |
| locationFound = "nullField"; |
| } |
| if (!locations.get(locationFound)) { |
| locations.put(locationFound, locationFound); |
| } |
| } |
| |
| // Go through and build the list of atp/qoh against each location |
| productFacilityLocations = new ArrayList(); |
| locationsIter = locations.keySet().iterator(); |
| while (locationsIter.hasNext()) { |
| location = locationsIter.next(); |
| resultOutput = runService('getInventoryAvailableByLocation', [productId : productId, facilityId : facilityId, locationSeqId : location]); |
| quantitySummary = [:]; |
| quantitySummary.productId = productId; |
| quantitySummary.facilityId = facilityId; |
| if ("nullField".equals( location ) == true) { |
| quantitySummary.locationSeqId = ""; |
| } else { |
| quantitySummary.locationSeqId = location; |
| } |
| quantitySummary.atp_qoh = ((Double)resultOutput.availableToPromiseTotal).intValue() + " / " + |
| ((Double)resultOutput.quantityOnHandTotal).intValue(); |
| productFacilityLocations.add(quantitySummary); |
| } |
| |
| context.productQtyByLocations = productFacilityLocations; |
| if (negativeQOH) { |
| context.negativeQOH = "true"; |
| } |
| } |