📄 distributionrun.java
字号:
/******************************************************************************
* The contents of this file are subject to the Compiere License Version 1.1
* ("License"); You may not use this file except in compliance with the License
* You may obtain a copy of the License at http://www.compiere.org/license.html
* Software distributed under the License is distributed on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License for
* the specific language governing rights and limitations under the License.
* The Original Code is Compiere ERP & CRM Smart Business Solution. The Initial
* Developer of the Original Code is Jorg Janke. Portions created by Jorg Janke
* are Copyright (C) 1999-2005 Jorg Janke.
* All parts are Copyright (C) 1999-2005 ComPiere, Inc. All Rights Reserved.
* Contributor(s): ______________________________________.
*****************************************************************************/
package org.compiere.process;
import java.math.*;
import java.sql.*;
import java.util.logging.*;
import org.compiere.model.*;
import org.compiere.util.*;
/**
* Create Distribution
*
* @author Jorg Janke
* @version $Id: DistributionRun.java,v 1.14 2006/01/28 01:28:28 jjanke Exp $
*/
public class DistributionRun extends SvrProcess
{
/** The Run to execute */
private int p_M_DistributionRun_ID = 0;
/** Date Promised */
private Timestamp p_DatePromised = null;
/** Dicument Type */
private int p_C_DocType_ID = 0;
/** Test Mode */
private boolean p_IsTest = false;
/** Distribution Run */
private MDistributionRun m_run = null;
/** Distribution Run Lines */
private MDistributionRunLine[] m_runLines = null;
/** Distribution Run Details */
private MDistributionRunDetail[] m_details = null;
/** Date Ordered */
private Timestamp m_DateOrdered = null;
/** Orders Created */
private int m_counter = 0;
/** Document Type */
private MDocType m_docType = null;
/**
* Prepare - e.g., get Parameters.
*/
protected void prepare()
{
ProcessInfoParameter[] para = getParameter();
for (int i = 0; i < para.length; i++)
{
String name = para[i].getParameterName();
// log.fine("prepare - " + para[i]);
if (para[i].getParameter() == null)
;
else if (name.equals("C_DocType_ID"))
p_C_DocType_ID = ((BigDecimal)para[i].getParameter()).intValue();
else if (name.equals("DatePromised"))
p_DatePromised = (Timestamp)para[i].getParameter();
else if (name.equals("IsTest"))
p_IsTest = "Y".equals(para[i].getParameter());
else
log.log(Level.SEVERE, "prepare - Unknown Parameter: " + name);
}
p_M_DistributionRun_ID = getRecord_ID();
} // prepare
/**
* Perform process.
* @return Message (text with variables)
* @throws Exception if not successful
*/
protected String doIt() throws Exception
{
log.info("M_DistributionRun_ID=" + p_M_DistributionRun_ID
+ ", C_DocType_ID=" + p_C_DocType_ID
+ ", DatePromised=" + p_DatePromised
+ ", Test=" + p_IsTest);
// Distribution Run
if (p_M_DistributionRun_ID == 0)
throw new IllegalArgumentException ("No Distribution Run ID");
m_run = new MDistributionRun(getCtx(), p_M_DistributionRun_ID, get_TrxName());
if (m_run.get_ID() == 0)
throw new Exception ("Distribution Run not found - M_DistributionRun_ID=" + p_M_DistributionRun_ID);
m_runLines = m_run.getLines(false);
if (m_runLines == null || m_runLines.length == 0)
throw new Exception ("No active, non-zero Distribution Run Lines found");
// Document Type
if (p_C_DocType_ID == 0)
throw new IllegalArgumentException ("No Document Type ID");
m_docType = new MDocType(getCtx(), p_C_DocType_ID, get_TrxName());
if (m_docType.get_ID() == 0)
throw new Exception ("Documentation Type not found - C_DocType_ID=" + p_C_DocType_ID);
//
m_DateOrdered = new Timestamp (System.currentTimeMillis());
if (p_DatePromised == null)
p_DatePromised = m_DateOrdered;
// Create Temp Lines
if (insertDetails() == 0)
throw new Exception ("No Lines");
// Order By Distribution Run Line
m_details = MDistributionRunDetail.get(getCtx(), p_M_DistributionRun_ID, false);
// First Run -- Add & Round
addAllocations ();
// Do Allocation
int loops = 0;
while (!isAllocationEqTotal ())
{
adjustAllocation();
addAllocations();
if (++loops > 10)
throw new Exception ("Loop detected - more than 10 Allocation attempts");
}
// Order By Business Partner
m_details = MDistributionRunDetail.get(getCtx(), p_M_DistributionRun_ID, true);
// Create Orders
createOrders();
return "@Created@ #" + m_counter;
} // doIt
/**
* Insert Details
* @return number of rows inserted
*/
private int insertDetails()
{
// Handle NULL
String sql = "UPDATE M_DistributionRunLine SET MinQty = 0 WHERE MinQty IS NULL";
int no = DB.executeUpdate(sql, get_TrxName());
sql = "UPDATE M_DistributionListLine SET MinQty = 0 WHERE MinQty IS NULL";
no = DB.executeUpdate(sql, get_TrxName());
// Total Ratio
sql = "UPDATE M_DistributionList l "
+ "SET RatioTotal = (SELECT SUM(Ratio) FROM M_DistributionListLine ll "
+ " WHERE l.M_DistributionList_ID=ll.M_DistributionList_ID) "
+ "WHERE EXISTS (SELECT * FROM M_DistributionRunLine rl"
+ " WHERE l.M_DistributionList_ID=rl.M_DistributionList_ID"
+ " AND rl.M_DistributionRun_ID=" + p_M_DistributionRun_ID + ")";
no = DB.executeUpdate(sql, get_TrxName());
// Delete Old
sql = "DELETE FROM T_DistributionRunDetail WHERE M_DistributionRun_ID="
+ p_M_DistributionRun_ID;
no = DB.executeUpdate(sql, get_TrxName());
log.fine("insertDetails - deleted #" + no);
// Insert New
sql = "INSERT INTO T_DistributionRunDetail "
+ "(M_DistributionRun_ID, M_DistributionRunLine_ID, M_DistributionList_ID, M_DistributionListLine_ID,"
+ "AD_Client_ID,AD_Org_ID, IsActive, Created,CreatedBy, Updated,UpdatedBy,"
+ "C_BPartner_ID, C_BPartner_Location_ID, M_Product_ID,"
+ "Ratio, MinQty, Qty) "
//
+ "SELECT rl.M_DistributionRun_ID, rl.M_DistributionRunLine_ID,"
+ "ll.M_DistributionList_ID, ll.M_DistributionListLine_ID, "
+ "rl.AD_Client_ID,rl.AD_Org_ID, rl.IsActive, rl.Created,rl.CreatedBy, rl.Updated,rl.UpdatedBy,"
+ "ll.C_BPartner_ID, ll.C_BPartner_Location_ID, rl.M_Product_ID, "
+ "ll.Ratio, "
+ "CASE WHEN rl.MinQty > ll.MinQty THEN rl.MinQty ELSE ll.MinQty END, "
+ "(ll.Ratio/l.RatioTotal*rl.TotalQty)"
+ "FROM M_DistributionRunLine rl"
+ " INNER JOIN M_DistributionList l ON (rl.M_DistributionList_ID=l.M_DistributionList_ID)"
+ " INNER JOIN M_DistributionListLine ll ON (rl.M_DistributionList_ID=ll.M_DistributionList_ID) "
+ "WHERE rl.M_DistributionRun_ID=" + p_M_DistributionRun_ID
+ " AND l.RatioTotal<>0 AND rl.IsActive='Y' AND ll.IsActive='Y'";
no = DB.executeUpdate(sql, get_TrxName());
log.fine("inserted #" + no);
return no;
} // insertDetails
/**************************************************************************
* Add up Allocations
*/
private void addAllocations ()
{
// Reset
for (int j = 0; j < m_runLines.length; j++)
{
MDistributionRunLine runLine = m_runLines[j];
runLine.resetCalculations();
}
// Add Up
for (int i = 0; i < m_details.length; i++)
{
MDistributionRunDetail detail = m_details[i];
for (int j = 0; j < m_runLines.length; j++)
{
MDistributionRunLine runLine = m_runLines[j];
if (runLine.getM_DistributionRunLine_ID() == detail.getM_DistributionRunLine_ID())
{
// Round
detail.round(runLine.getStandardPrecision());
// Add
runLine.addActualMin(detail.getMinQty());
runLine.addActualQty(detail.getQty());
runLine.addActualAllocation(detail.getActualAllocation());
runLine.setMaxAllocation(detail.getActualAllocation(), false);
//
log.fine("RunLine=" + runLine.getLine()
+ ": BP_ID=" + detail.getC_BPartner_ID()
+ ", Min=" + detail.getMinQty()
+ ", Qty=" + detail.getQty()
+ ", Allocation=" + detail.getActualAllocation());
continue;
}
}
} // for all detail lines
// Info
for (int j = 0; j < m_runLines.length; j++)
{
MDistributionRunLine runLine = m_runLines[j];
log.fine("Run - " + runLine.getInfo());
}
} // addAllocations
/**
* Is Allocation Equals Total
* @return true if allocation eq total
* @throws Exception
*/
private boolean isAllocationEqTotal() throws Exception
{
boolean allocationEqTotal = true;
// Check total min qty & delta
for (int j = 0; j < m_runLines.length; j++)
{
MDistributionRunLine runLine = m_runLines[j];
if (runLine.isActualMinGtTotal())
throw new Exception ("Line " + runLine.getLine()
+ " Sum of Min Qty=" + runLine.getActualMin()
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -