📄 mproject.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.*;
/**
* Project Model
*
* @author Jorg Janke
* @version $Id: MProject.java,v 1.24 2006/01/04 05:39:21 jjanke Exp $
*/
public class MProject extends X_C_Project
{
/**
* Create new Project by copying
* @param ctx context
* @param C_Project_ID project
* @param dateDoc date of the document date
* @return Project
*/
public static MProject copyFrom (Properties ctx, int C_Project_ID, Timestamp dateDoc, String trxName)
{
MProject from = new MProject (ctx, C_Project_ID, trxName);
if (from.getC_Project_ID() == 0)
throw new IllegalArgumentException ("From Project not found C_Project_ID=" + C_Project_ID);
//
MProject to = new MProject (ctx, 0, trxName);
PO.copyValues(from, to, from.getAD_Client_ID(), from.getAD_Org_ID());
to.set_ValueNoCheck ("C_Project_ID", I_ZERO);
// Set Value with Time
String Value = to.getValue() + " ";
String Time = dateDoc.toString();
int length = Value.length() + Time.length();
if (length <= 40)
Value += Time;
else
Value += Time.substring (length-40);
to.setValue(Value);
to.setInvoicedAmt(Env.ZERO);
to.setProjectBalanceAmt(Env.ZERO);
to.setProcessed(false);
//
if (!to.save())
throw new IllegalStateException("Could not create Project");
if (to.copyDetailsFrom(from) == 0)
throw new IllegalStateException("Could not create Project Details");
return to;
} // copyFrom
/**************************************************************************
* Standard Constructor
* @param ctx context
* @param C_Project_ID id
*/
public MProject (Properties ctx, int C_Project_ID, String trxName)
{
super (ctx, C_Project_ID, trxName);
if (C_Project_ID == 0)
{
// setC_Project_ID(0);
// setValue (null);
// setC_Currency_ID (0);
setCommittedAmt (Env.ZERO);
setCommittedQty (Env.ZERO);
setInvoicedAmt (Env.ZERO);
setInvoicedQty (Env.ZERO);
setPlannedAmt (Env.ZERO);
setPlannedMarginAmt (Env.ZERO);
setPlannedQty (Env.ZERO);
setProjectBalanceAmt (Env.ZERO);
// setProjectCategory(PROJECTCATEGORY_General);
setIsCommitCeiling (false);
setIsCommitment (false);
setIsSummary (false);
setProcessed (false);
}
} // MProject
/**
* Load Constructor
* @param ctx context
* @param rs result set
*/
public MProject (Properties ctx, ResultSet rs, String trxName)
{
super(ctx, rs, trxName);
} // MProject
/** Cached PL */
private int m_M_PriceList_ID = 0;
/**
* Get Project Type as Int (is Button).
* @return C_ProjectType_ID id
*/
public int getC_ProjectType_ID_Int()
{
String pj = super.getC_ProjectType_ID();
if (pj == null)
return 0;
int C_ProjectType_ID = 0;
try
{
C_ProjectType_ID = Integer.parseInt (pj);
}
catch (Exception ex)
{
log.log(Level.SEVERE, pj, ex);
}
return C_ProjectType_ID;
} // getC_ProjectType_ID_Int
/**
* Set Project Type (overwrite r/o)
* @param C_ProjectType_ID id
*/
public void setC_ProjectType_ID (int C_ProjectType_ID)
{
if (C_ProjectType_ID == 0)
super.setC_ProjectType_ID (null);
else
super.setC_ProjectType_ID (String.valueOf(C_ProjectType_ID));
} // setC_ProjectType_ID
/**
* String Representation
* @return info
*/
public String toString()
{
StringBuffer sb = new StringBuffer ("MProject[").append(get_ID())
.append("-").append(getValue()).append(",ProjectCategory=").append(getProjectCategory())
.append("]");
return sb.toString();
} // toString
/**
* Get Price List from Price List Version
* @return price list or 0
*/
public int getM_PriceList_ID()
{
if (getM_PriceList_Version_ID() == 0)
return 0;
if (m_M_PriceList_ID > 0)
return m_M_PriceList_ID;
//
String sql = "SELECT M_PriceList_ID FROM M_PriceList_Version WHERE M_PriceList_Version_ID=?";
m_M_PriceList_ID = DB.getSQLValue(null, sql, getM_PriceList_Version_ID());
return m_M_PriceList_ID;
} // getM_PriceList_ID
/**
* Set PL Version
* @param M_PriceList_Version_ID id
*/
public void setM_PriceList_Version_ID (int M_PriceList_Version_ID)
{
super.setM_PriceList_Version_ID(M_PriceList_Version_ID);
m_M_PriceList_ID = 0; // reset
} // setM_PriceList_Version_ID
/**************************************************************************
* Get Project Lines
* @return Array of lines
*/
public MProjectLine[] getLines()
{
ArrayList<MProjectLine> list = new ArrayList<MProjectLine>();
String sql = "SELECT * FROM C_ProjectLine WHERE C_Project_ID=? ORDER BY Line";
PreparedStatement pstmt = null;
try
{
pstmt = DB.prepareStatement(sql, get_TrxName());
pstmt.setInt(1, getC_Project_ID());
ResultSet rs = pstmt.executeQuery();
while (rs.next())
list.add(new MProjectLine (getCtx(), rs, get_TrxName()));
rs.close();
pstmt.close();
pstmt = null;
}
catch (SQLException ex)
{
log.log(Level.SEVERE, sql, ex);
}
try
{
if (pstmt != null)
pstmt.close();
}
catch (SQLException ex1)
{
}
pstmt = null;
//
MProjectLine[] retValue = new MProjectLine[list.size()];
list.toArray(retValue);
return retValue;
} // getLines
/**
* Get Project Issues
* @return Array of issues
*/
public MProjectIssue[] getIssues()
{
ArrayList<MProjectIssue> list = new ArrayList<MProjectIssue>();
String sql = "SELECT * FROM C_ProjectIssue WHERE C_Project_ID=? ORDER BY Line";
PreparedStatement pstmt = null;
try
{
pstmt = DB.prepareStatement(sql, get_TrxName());
pstmt.setInt(1, getC_Project_ID());
ResultSet rs = pstmt.executeQuery();
while (rs.next())
list.add(new MProjectIssue (getCtx(), rs, get_TrxName()));
rs.close();
pstmt.close();
pstmt = null;
}
catch (SQLException ex)
{
log.log(Level.SEVERE, sql, ex);
}
try
{
if (pstmt != null)
pstmt.close();
}
catch (SQLException ex1)
{
}
pstmt = null;
//
MProjectIssue[] retValue = new MProjectIssue[list.size()];
list.toArray(retValue);
return retValue;
} // getIssues
/**
* Get Project Phases
* @return Array of phases
*/
public MProjectPhase[] getPhases()
{
ArrayList<MProjectPhase> list = new ArrayList<MProjectPhase>();
String sql = "SELECT * FROM C_ProjectPhase WHERE C_Project_ID=? ORDER BY SeqNo";
PreparedStatement pstmt = null;
try
{
pstmt = DB.prepareStatement(sql, get_TrxName());
pstmt.setInt(1, getC_Project_ID());
ResultSet rs = pstmt.executeQuery();
while (rs.next())
list.add(new MProjectPhase (getCtx(), rs, get_TrxName()));
rs.close();
pstmt.close();
pstmt = null;
}
catch (SQLException ex)
{
log.log(Level.SEVERE, sql, ex);
}
try
{
if (pstmt != null)
pstmt.close();
}
catch (SQLException ex1)
{
}
pstmt = null;
//
MProjectPhase[] retValue = new MProjectPhase[list.size()];
list.toArray(retValue);
return retValue;
} // getPhases
/**************************************************************************
* Copy Lines/Phase/Task from other Project
* @param project project
* @return number of total lines copied
*/
public int copyDetailsFrom (MProject project)
{
if (isProcessed() || project == null)
return 0;
int count = copyLinesFrom(project)
+ copyPhasesFrom(project);
return count;
} // copyDetailsFrom
/**
* Copy Lines From other Project
* @param project project
* @return number of lines copied
*/
public int copyLinesFrom (MProject project)
{
if (isProcessed() || project == null)
return 0;
int count = 0;
MProjectLine[] fromLines = project.getLines();
for (int i = 0; i < fromLines.length; i++)
{
MProjectLine line = new MProjectLine (getCtx(), 0, project.get_TrxName());
PO.copyValues(fromLines[i], line, getAD_Client_ID(), getAD_Org_ID());
line.setC_Project_ID(getC_Project_ID());
line.setInvoicedAmt(Env.ZERO);
line.setInvoicedQty(Env.ZERO);
line.setC_OrderPO_ID(0);
line.setC_Order_ID(0);
line.setProcessed(false);
if (line.save())
count++;
}
if (fromLines.length != count)
log.log(Level.SEVERE, "Lines difference - Project=" + fromLines.length + " <> Saved=" + count);
return count;
} // copyLinesFrom
/**
* Copy Phases/Tasks from other Project
* @param fromProject project
* @return number of items copied
*/
public int copyPhasesFrom (MProject fromProject)
{
if (isProcessed() || fromProject == null)
return 0;
int count = 0;
int taskCount = 0;
// Get Phases
MProjectPhase[] myPhases = getPhases();
MProjectPhase[] fromPhases = fromProject.getPhases();
// Copy Phases
for (int i = 0; i < fromPhases.length; i++)
{
// Check if Phase already exists
int C_Phase_ID = fromPhases[i].getC_Phase_ID();
boolean exists = false;
if (C_Phase_ID == 0)
exists = false;
else
{
for (int ii = 0; ii < myPhases.length; ii++)
{
if (myPhases[ii].getC_Phase_ID() == C_Phase_ID)
{
exists = true;
break;
}
}
}
// Phase exist
if (exists)
log.info("Phase already exists here, ignored - " + fromPhases[i]);
else
{
MProjectPhase toPhase = new MProjectPhase (getCtx (), 0, get_TrxName());
PO.copyValues (fromPhases[i], toPhase, getAD_Client_ID (), getAD_Org_ID ());
toPhase.setC_Project_ID (getC_Project_ID ());
toPhase.setC_Order_ID (0);
toPhase.setIsComplete (false);
if (toPhase.save ())
{
count++;
taskCount += toPhase.copyTasksFrom (fromPhases[i]);
}
}
}
if (fromPhases.length != count)
log.warning("Count difference - Project=" + fromPhases.length + " <> Saved=" + count);
return count + taskCount;
} // copyPhasesFrom
/**
* Set Project Type and Category.
* If Service Project copy Projet Type Phase/Tasks
* @param type project type
*/
public void setProjectType (MProjectType type)
{
if (type == null)
return;
setC_ProjectType_ID(type.getC_ProjectType_ID());
setProjectCategory(type.getProjectCategory());
if (PROJECTCATEGORY_ServiceChargeProject.equals(getProjectCategory()))
copyPhasesFrom(type);
} // setProjectType
/**
* Copy Phases from Type
* @param type Project Type
* @return count
*/
public int copyPhasesFrom (MProjectType type)
{
// create phases
int count = 0;
int taskCount = 0;
MProjectTypePhase[] typePhases = type.getPhases();
for (int i = 0; i < typePhases.length; i++)
{
MProjectPhase toPhase = new MProjectPhase (this, typePhases[i]);
if (toPhase.save())
{
count++;
taskCount += toPhase.copyTasksFrom(typePhases[i]);
}
}
log.fine("#" + count + "/" + taskCount
+ " - " + type);
if (typePhases.length != count)
log.log(Level.SEVERE, "Count difference - Type=" + typePhases.length + " <> Saved=" + count);
return count;
} // copyPhasesFrom
/**
* Before Save
* @param newRecord new
* @return true
*/
protected boolean beforeSave (boolean newRecord)
{
if (getAD_User_ID() == -1) // Summary Project in Dimensions
setAD_User_ID(0);
return true;
} // beforeSave
/**
* After Save
* @param newRecord new
* @param success success
* @return success
*/
protected boolean afterSave (boolean newRecord, boolean success)
{
if (newRecord & success)
{
insert_Accounting("C_Project_Acct", "C_AcctSchema_Default", null);
insert_Tree(MTree_Base.TREETYPE_Project);
}
// Value/Name change
if (success && !newRecord
&& (is_ValueChanged("Value") || is_ValueChanged("Name")))
MAccount.updateValueDescription(getCtx(), "C_Project_ID=" + getC_Project_ID(), get_TrxName());
return success;
} // afterSave
/**
* Before Delete
* @return true
*/
protected boolean beforeDelete ()
{
return delete_Accounting("C_Project_Acct");
} // beforeDelete
/**
* After Delete
* @param success
* @return deleted
*/
protected boolean afterDelete (boolean success)
{
if (success)
delete_Tree(MTree_Base.TREETYPE_Project);
return success;
} // afterDelete
} // MProject
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -