📄 rfqresponserank.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.util.*;
import java.util.logging.*;
import org.compiere.model.*;
import org.compiere.util.*;
/**
* Rank RfQ Responses
*
* @author Jorg Janke
* @version $Id: RfQResponseRank.java,v 1.11 2005/11/14 02:10:53 jjanke Exp $
*/
public class RfQResponseRank extends SvrProcess
{
/** RfQ */
private int p_C_RfQ_ID = 0;
/**
* Prepare
*/
protected void prepare ()
{
ProcessInfoParameter[] para = getParameter();
for (int i = 0; i < para.length; i++)
{
String name = para[i].getParameterName();
if (para[i].getParameter() == null)
;
else
log.log(Level.SEVERE, "Unknown Parameter: " + name);
}
p_C_RfQ_ID = getRecord_ID();
} // prepare
/**
* Process.
* <pre>
* - ignore 0 or invalid responses
* - rank among qty
* - for selected PO qty select winner
* - if all lines are winner - select that
* </pre>
* @return message
*/
protected String doIt () throws Exception
{
MRfQ rfq = new MRfQ (getCtx(), p_C_RfQ_ID, get_TrxName());
if (rfq.get_ID() == 0)
throw new IllegalArgumentException("No RfQ found");
log.info(rfq.toString());
String error = rfq.checkQuoteTotalAmtOnly();
if (error != null && error.length() > 0)
throw new Exception (error);
// Get Completed, Active Responses
MRfQResponse[] responses = rfq.getResponses (true, true);
log.fine("doIt - #Responses=" + responses.length);
if (responses.length == 0)
throw new IllegalArgumentException("No completed RfQ Responses found");
if (responses.length == 1)
{
responses[0].setIsSelectedWinner(true);
responses[0].save();
throw new IllegalArgumentException("Only one completed RfQ Response found");
}
// Rank
if (rfq.isQuoteTotalAmtOnly())
rankResponses(rfq, responses);
else
rankLines (rfq, responses);
return "# " + responses.length;
} // doIt
/**************************************************************************
* Rank Lines
* @param rfq RfQ
* @param responses responses
*/
@SuppressWarnings("unchecked")
private void rankLines (MRfQ rfq, MRfQResponse[] responses)
{
MRfQLine[] rfqLines = rfq.getLines();
if (rfqLines.length == 0)
throw new IllegalArgumentException("No RfQ Lines found");
// for all lines
for (int i = 0; i < rfqLines.length; i++)
{
// RfQ Line
MRfQLine rfqLine = rfqLines[i];
if (!rfqLine.isActive())
continue;
log.fine("rankLines - " + rfqLine);
MRfQLineQty[] rfqQtys = rfqLine.getQtys();
for (int j = 0; j < rfqQtys.length; j++)
{
// RfQ Line Qty
MRfQLineQty rfqQty = rfqQtys[j];
if (!rfqQty.isActive() || !rfqQty.isRfQQty())
continue;
log.fine("rankLines Qty - " + rfqQty);
MRfQResponseLineQty[] respQtys = rfqQty.getResponseQtys(false);
for (int kk = 0; kk < respQtys.length; kk++)
{
// Response Line Qty
MRfQResponseLineQty respQty = respQtys[kk];
if (!respQty.isActive() || !respQty.isValidAmt())
{
respQty.setRanking(999);
respQty.save();
log.fine(" - ignored: " + respQty);
}
} // for all respones line qtys
// Rank RfQ Line Qtys
respQtys = rfqQty.getResponseQtys(false);
if (respQtys.length == 0)
log.fine(" - No Qtys with valid Amounts");
else
{
Arrays.sort(respQtys, respQtys[0]);
int lastRank = 1; // multiple rank #1
BigDecimal lastAmt = Env.ZERO;
for (int rank = 0; rank < respQtys.length; rank++)
{
MRfQResponseLineQty qty = respQtys[rank];
if (!qty.isActive() || qty.getRanking() == 999)
continue;
BigDecimal netAmt = qty.getNetAmt();
if (netAmt == null)
{
qty.setRanking(999);
log.fine(" - Rank 999: " + qty);
}
else
{
if (lastAmt.compareTo(netAmt) != 0)
{
lastRank = rank+1;
lastAmt = qty.getNetAmt();
}
qty.setRanking(lastRank);
log.fine(" - Rank " + lastRank + ": " + qty);
}
qty.save();
//
if (rank == 0) // Update RfQ
{
rfqQty.setBestResponseAmt(qty.getNetAmt());
rfqQty.save();
}
}
}
} // for all rfq line qtys
} // for all rfq lines
// Select Winner based on line ranking
MRfQResponse winner = null;
for (int ii = 0; ii < responses.length; ii++)
{
MRfQResponse response = responses[ii];
if (response.isSelectedWinner())
response.setIsSelectedWinner(false);
int ranking = 0;
MRfQResponseLine[] respLines = response.getLines(false);
for (int jj = 0; jj < respLines.length; jj++)
{
// Response Line
MRfQResponseLine respLine = respLines[jj];
if (!respLine.isActive())
continue;
if (respLine.isSelectedWinner())
respLine.setIsSelectedWinner(false);
MRfQResponseLineQty[] respQtys = respLine.getQtys(false);
for (int kk = 0; kk < respQtys.length; kk++)
{
// Response Line Qty
MRfQResponseLineQty respQty = respQtys[kk];
if (!respQty.isActive())
continue;
ranking += respQty.getRanking();
if (respQty.getRanking() == 1
&& respQty.getRfQLineQty().isPurchaseQty())
{
respLine.setIsSelectedWinner(true);
respLine.save();
break;
}
}
}
response.setRanking(ranking);
response.save();
log.fine("- Response Ranking " + ranking + ": " + response);
if (!rfq.isQuoteSelectedLines()) // no total selected winner if not all lines
{
if (winner == null && ranking > 0)
winner = response;
if (winner != null
&& response.getRanking() > 0
&& response.getRanking() < winner.getRanking())
winner = response;
}
}
if (winner != null)
{
winner.setIsSelectedWinner(true);
winner.save();
log.fine("- Response Winner: " + winner);
}
} // rankLines
/**************************************************************************
* Rank Response based on Header
* @param rfq RfQ
* @param responses responses
*/
private void rankResponses (MRfQ rfq, MRfQResponse[] responses)
{
int ranking = 1;
// Responses Ordered by Price
for (int ii = 0; ii < responses.length; ii++)
{
MRfQResponse response = responses[ii];
if (response.getPrice() != null
&& response.getPrice().compareTo(Env.ZERO) > 0)
{
if (response.isSelectedWinner() != (ranking == 1))
response.setIsSelectedWinner(ranking == 1);
response.setRanking(ranking);
//
ranking++;
}
else
{
response.setRanking(999);
if (response.isSelectedWinner())
response.setIsSelectedWinner(false);
}
response.save();
log.fine("rankResponse - " + response);
}
} // rankResponses
} // RfQResponseRank
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -