📄 mrfqline.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.model;
import java.sql.*;
import java.util.*;
import java.util.logging.*;
import org.compiere.util.*;
/**
* RfQ Line
*
* @author Jorg Janke
* @version $Id: MRfQLine.java,v 1.13 2005/11/14 02:10:53 jjanke Exp $
*/
public class MRfQLine extends X_C_RfQLine
{
/**
* Get MRfQLine from Cache
* @param ctx context
* @param C_RfQLine_ID id
* @return MRfQLine
*/
public static MRfQLine get (Properties ctx, int C_RfQLine_ID, String trxName)
{
Integer key = new Integer (C_RfQLine_ID);
MRfQLine retValue = (MRfQLine) s_cache.get (key);
if (retValue != null)
return retValue;
retValue = new MRfQLine (ctx, C_RfQLine_ID, trxName);
if (retValue.get_ID () != 0)
s_cache.put (key, retValue);
return retValue;
} // get
/** Cache */
private static CCache<Integer,MRfQLine> s_cache = new CCache<Integer,MRfQLine>("C_RfQLine", 20);
/**
* Standard Constructor
* @param ctx context
* @param C_RfQLine_ID id
*/
public MRfQLine (Properties ctx, int C_RfQLine_ID, String trxName)
{
super (ctx, C_RfQLine_ID, trxName);
if (C_RfQLine_ID == 0)
{
setLine (0);
}
} // MRfQLine
/**
* Load Constructor
* @param ctx context
* @param rs result set
*/
public MRfQLine (Properties ctx, ResultSet rs, String trxName)
{
super(ctx, rs, trxName);
if (get_ID() > 0)
s_cache.put(new Integer(get_ID()), this);
} // MRfQLine
/**
* Parent Constructor
* @param rfq RfQ
*/
public MRfQLine (MRfQ rfq)
{
this (rfq.getCtx(), 0, rfq.get_TrxName());
setClientOrg(rfq);
setC_RfQ_ID(rfq.getC_RfQ_ID());
} // MRfQLine
/** Qyantities */
private MRfQLineQty[] m_qtys = null;
/**
* Get Quantities
* @return array of quantities
*/
public MRfQLineQty[] getQtys ()
{
return getQtys (false);
} // getQtys
/**
* Get Quantities
* @param requery requery
* @return array of quantities
*/
public MRfQLineQty[] getQtys (boolean requery)
{
if (m_qtys != null && !requery)
return m_qtys;
ArrayList<MRfQLineQty> list = new ArrayList<MRfQLineQty>();
String sql = "SELECT * FROM C_RfQLineQty "
+ "WHERE C_RfQLine_ID=? AND IsActive='Y' "
+ "ORDER BY Qty";
PreparedStatement pstmt = null;
try
{
pstmt = DB.prepareStatement (sql, get_TrxName());
pstmt.setInt (1, getC_RfQLine_ID());
ResultSet rs = pstmt.executeQuery ();
while (rs.next ())
list.add (new MRfQLineQty (getCtx(), rs, get_TrxName()));
rs.close ();
pstmt.close ();
pstmt = null;
}
catch (Exception e)
{
log.log(Level.SEVERE, sql, e);
}
try
{
if (pstmt != null)
pstmt.close ();
pstmt = null;
}
catch (Exception e)
{
pstmt = null;
}
// Create Default (1)
if (list.size() == 0)
{
MRfQLineQty qty = new MRfQLineQty(this);
qty.save();
list.add(qty);
}
m_qtys = new MRfQLineQty[list.size ()];
list.toArray (m_qtys);
return m_qtys;
} // getQtys
/**
* Get Product Details
* @return Product Name, etc.
*/
public String getProductDetailHTML()
{
if (getM_Product_ID() == 0)
return "";
StringBuffer sb = new StringBuffer();
MProduct product = MProduct.get (getCtx(), getM_Product_ID());
sb.append(product.getName());
if (product.getDescription() != null && product.getDescription().length() > 0)
sb.append("<br><i>").append(product.getDescription()).append("</i>");
return sb.toString();
} // getProductDetails
/**
* String Representation
* @return info
*/
public String toString ()
{
StringBuffer sb = new StringBuffer ("MRfQLine[");
sb.append(get_ID()).append(",").append(getLine())
.append ("]");
return sb.toString ();
} // toString
/**
* Before Save
* @param newRecord new
* @return true
*/
protected boolean beforeSave (boolean newRecord)
{
// Calculate Complete Date (also used to verify)
if (getDateWorkStart() != null && getDeliveryDays() != 0)
setDateWorkComplete (TimeUtil.addDays(getDateWorkStart(), getDeliveryDays()));
// Calculate Delivery Days
else if (getDateWorkStart() != null && getDeliveryDays() == 0 && getDateWorkComplete() != null)
setDeliveryDays (TimeUtil.getDaysBetween(getDateWorkStart(), getDateWorkComplete()));
// Calculate Start Date
else if (getDateWorkStart() == null && getDeliveryDays() != 0 && getDateWorkComplete() != null)
setDateWorkStart (TimeUtil.addDays(getDateWorkComplete(), getDeliveryDays() * -1));
return true;
} // beforeSave
} // MRfQLine
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -