📄 mprintformat.java
字号:
+ " LEFT OUTER JOIN AD_PrintPaper cpp ON (cpp.AD_Client_ID=c.AD_Client_ID AND cpp.IsDefault='Y'),"
+ " AD_PrintColor pc, AD_PrintFont pf, AD_PrintPaper pp "
+ "WHERE t.AD_Table_ID=? AND c.AD_Client_ID=?" // #1/2
+ " AND pc.IsDefault='Y' AND pf.IsDefault='Y' AND pp.IsDefault='Y'";
boolean error = true;
try
{
PreparedStatement pstmt = DB.prepareStatement(sql, null);
pstmt.setInt(1, AD_Table_ID);
pstmt.setInt(2, AD_Client_ID);
ResultSet rs = pstmt.executeQuery();
if (rs.next())
{
// Name
String TableName = rs.getString(1);
String ColumnName = TableName + "_ID";
String s = ColumnName;
if (!ColumnName.equals("T_Report_ID"))
{
s = Msg.translate (ctx, ColumnName);
if (ColumnName.equals (s)) // not found
s = Msg.translate (ctx, TableName);
}
int count = rs.getInt(2);
if (count > 0)
s += "_" + (count+1);
pf.setName(s);
//
pf.setAD_PrintColor_ID(rs.getInt(3));
pf.setAD_PrintFont_ID(rs.getInt(4));
pf.setAD_PrintPaper_ID(rs.getInt(5));
//
error = false;
}
else
s_log.log(Level.SEVERE, "No info found " + AD_Table_ID);
rs.close();
pstmt.close();
}
catch (SQLException e)
{
s_log.log(Level.SEVERE, sql, e);
}
if (error)
return null;
// Save & complete
if (!pf.save())
return null;
// pf.dump();
pf.setItems (createItems(ctx, pf));
//
return pf;
} // createFromTable
/**
* Create MPrintFormat for ReportView
* @param ctx context
* @param AD_ReportView_ID ReportView
* @param ReportName - optional Report Name
* @return print format
*/
static public MPrintFormat createFromReportView (Properties ctx, int AD_ReportView_ID, String ReportName)
{
int AD_Client_ID = Env.getAD_Client_ID(ctx);
s_log.info ("AD_ReportView_ID=" + AD_ReportView_ID + " - AD_Client_ID=" + AD_Client_ID + " - " + ReportName);
MPrintFormat pf = new MPrintFormat(ctx, 0, null);
pf.setAD_ReportView_ID (AD_ReportView_ID);
// Get Info
String sql = "SELECT t.TableName,"
+ " (SELECT COUNT(*) FROM AD_PrintFormat x WHERE x.AD_ReportView_ID=rv.AD_ReportView_ID AND x.AD_Client_ID=c.AD_Client_ID) AS Count,"
+ " COALESCE (cpc.AD_PrintColor_ID, pc.AD_PrintColor_ID) AS AD_PrintColor_ID,"
+ " COALESCE (cpf.AD_PrintFont_ID, pf.AD_PrintFont_ID) AS AD_PrintFont_ID,"
+ " COALESCE (cpp.AD_PrintPaper_ID, pp.AD_PrintPaper_ID) AS AD_PrintPaper_ID,"
+ " t.AD_Table_ID "
+ "FROM AD_ReportView rv"
+ " INNER JOIN AD_Table t ON (rv.AD_Table_ID=t.AD_Table_ID),"
+ " AD_Client c"
+ " LEFT OUTER JOIN AD_PrintColor cpc ON (cpc.AD_Client_ID=c.AD_Client_ID AND cpc.IsDefault='Y')"
+ " LEFT OUTER JOIN AD_PrintFont cpf ON (cpf.AD_Client_ID=c.AD_Client_ID AND cpf.IsDefault='Y')"
+ " LEFT OUTER JOIN AD_PrintPaper cpp ON (cpp.AD_Client_ID=c.AD_Client_ID AND cpp.IsDefault='Y'),"
+ " AD_PrintColor pc, AD_PrintFont pf, AD_PrintPaper pp "
+ "WHERE rv.AD_ReportView_ID=? AND c.AD_Client_ID=?"
+ " AND pc.IsDefault='Y' AND pf.IsDefault='Y' AND pp.IsDefault='Y'";
boolean error = true;
try
{
PreparedStatement pstmt = DB.prepareStatement(sql, null);
pstmt.setInt(1, AD_ReportView_ID);
pstmt.setInt(2, AD_Client_ID);
ResultSet rs = pstmt.executeQuery();
if (rs.next())
{
// Name
String name = ReportName;
if (name == null || name.length() == 0)
name = rs.getString(1); // TableName
int count = rs.getInt(2);
if (count > 0)
name += "_" + count;
pf.setName(name);
//
pf.setAD_PrintColor_ID(rs.getInt(3));
pf.setAD_PrintFont_ID(rs.getInt(4));
pf.setAD_PrintPaper_ID(rs.getInt(5));
//
pf.setAD_Table_ID (rs.getInt(6));
error = false;
}
else
s_log.log(Level.SEVERE, "Not found: AD_ReportView_ID=" + AD_ReportView_ID);
rs.close();
pstmt.close();
}
catch (SQLException e)
{
s_log.log(Level.SEVERE, sql, e);
}
if (error)
return null;
// Save & complete
if (!pf.save())
return null;
// pf.dump();
pf.setItems (createItems(ctx, pf));
//
return pf;
} // createFromReportView
/**
* Create Items.
* Using the display order of Fields in some Tab
* @param ctx context
* @param format print format
* @return items
*/
static private MPrintFormatItem[] createItems (Properties ctx, MPrintFormat format)
{
s_log.fine ("From window Tab ...");
ArrayList<MPrintFormatItem> list = new ArrayList<MPrintFormatItem>();
// Get Column List from Tab
String sql = "SELECT AD_Column_ID " //, Name, IsDisplayed, SeqNo
+ "FROM AD_Field "
+ "WHERE AD_Tab_ID=(SELECT AD_Tab_ID FROM AD_Tab WHERE AD_Table_ID=? AND ROWNUM=1)"
+ " AND IsEncrypted='N' AND ObscureType IS NULL "
+ "ORDER BY COALESCE(IsDisplayed,'N') DESC, SortNo, SeqNo, Name";
try
{
PreparedStatement pstmt = DB.prepareStatement(sql, format.get_TrxName());
pstmt.setInt(1, format.getAD_Table_ID());
ResultSet rs = pstmt.executeQuery();
int seqNo = 1;
while (rs.next())
{
MPrintFormatItem pfi = MPrintFormatItem.createFromColumn (format, rs.getInt(1), seqNo++);
if (pfi != null)
{
list.add (pfi);
s_log.finest("Tab: " + pfi);
}
}
rs.close();
pstmt.close();
}
catch (SQLException e)
{
s_log.log(Level.SEVERE, "(tab) - " + sql, e);
}
// No Tab found for Table
if (list.size() == 0)
{
s_log.fine("From Table ...");
sql = "SELECT AD_Column_ID "
+ "FROM AD_Column "
+ "WHERE AD_Table_ID=? "
+ "ORDER BY IsIdentifier DESC, SeqNo, Name";
try
{
PreparedStatement pstmt = DB.prepareStatement(sql, format.get_TrxName());
pstmt.setInt(1, format.getAD_Table_ID());
ResultSet rs = pstmt.executeQuery();
int seqNo = 1;
while (rs.next())
{
MPrintFormatItem pfi = MPrintFormatItem.createFromColumn (format, rs.getInt(1), seqNo++);
if (pfi != null)
{
list.add (pfi);
s_log.finest("Table: " + pfi);
}
}
rs.close();
pstmt.close();
}
catch (SQLException e)
{
s_log.log(Level.SEVERE, "(table) - " + sql, e);
}
}
//
MPrintFormatItem[] retValue = new MPrintFormatItem[list.size()];
list.toArray(retValue);
s_log.info(format + " - #" + retValue.length);
return retValue;
} // createItems
/**
* Copy Items
* @param fromFormat from print format
* @param toFormat to print format (client, id)
* @return items
*/
static private MPrintFormatItem[] copyItems (MPrintFormat fromFormat, MPrintFormat toFormat)
{
s_log.info("From=" + fromFormat);
ArrayList<MPrintFormatItem> list = new ArrayList<MPrintFormatItem>();
MPrintFormatItem[] items = fromFormat.getItems();
for (int i = 0; i < items.length; i++)
{
MPrintFormatItem pfi = items[i].copyToClient (toFormat.getAD_Client_ID(), toFormat.get_ID());
if (pfi != null)
list.add (pfi);
}
//
MPrintFormatItem[] retValue = new MPrintFormatItem[list.size()];
list.toArray(retValue);
return retValue;
} // copyItems
/**************************************************************************
* Copy existing Definition To Client
* @param ctx context
* @param from_AD_PrintFormat_ID format
* @param to_AD_PrintFormat_ID format
* @return print format
*/
public static MPrintFormat copy (Properties ctx,
int from_AD_PrintFormat_ID, int to_AD_PrintFormat_ID)
{
return copy (ctx, from_AD_PrintFormat_ID, to_AD_PrintFormat_ID, -1);
} // copy
/**
* Copy existing Definition To Client
* @param ctx context
* @param AD_PrintFormat_ID format
* @param to_Client_ID to client
* @return print format
*/
public static MPrintFormat copyToClient (Properties ctx,
int AD_PrintFormat_ID, int to_Client_ID)
{
return copy (ctx, AD_PrintFormat_ID, 0, to_Client_ID);
} // copy
/**
* Copy existing Definition To Client
* @param ctx context
* @param from_AD_PrintFormat_ID format
* @param to_AD_PrintFormat_ID to format or 0 for new
* @param to_Client_ID to client (ignored, if to_AD_PrintFormat_ID <> 0)
* @return print format
*/
private static MPrintFormat copy (Properties ctx, int from_AD_PrintFormat_ID,
int to_AD_PrintFormat_ID, int to_Client_ID)
{
s_log.info ("From AD_PrintFormat_ID=" + from_AD_PrintFormat_ID
+ ", To AD_PrintFormat_ID=" + to_AD_PrintFormat_ID
+ ", To Client_ID=" + to_Client_ID);
if (from_AD_PrintFormat_ID == 0)
throw new IllegalArgumentException ("From_AD_PrintFormat_ID is 0");
//
MPrintFormat from = new MPrintFormat(ctx, from_AD_PrintFormat_ID, null);
MPrintFormat to = new MPrintFormat (ctx, to_AD_PrintFormat_ID, null); // could be 0
MPrintFormat.copyValues (from, to);
// New
if (to_AD_PrintFormat_ID == 0)
{
if (to_Client_ID < 0)
to_Client_ID = Env.getAD_Client_ID(ctx);
to.setClientOrg (to_Client_ID, 0);
}
// Set Name - Remove TEMPLATE - add copy
to.setName(Util.replace(to.getName(), "TEMPLATE", String.valueOf(to_Client_ID)));
to.setName(to.getName()
+ " " + Msg.getMsg(ctx, "Copy")
+ " " + to.hashCode()); // unique name
//
to.save();
// Copy Items
to.setItems(copyItems(from,to));
return to;
} // copyToClient
/*************************************************************************/
/** Cached Formats */
static private CCache<Integer,MPrintFormat> s_formats = new CCache<Integer,MPrintFormat>("AD_PrintFormat", 30);
/**
* Get Format
* @param ctx context
* @param AD_PrintFormat_ID id
* @param readFromDisk refresh from disk
* @return Format
*/
static public MPrintFormat get (Properties ctx, int AD_PrintFormat_ID, boolean readFromDisk)
{
Integer key = new Integer(AD_PrintFormat_ID);
MPrintFormat pf = null;
if (!readFromDisk)
pf = (MPrintFormat)s_formats.get(key);
if (pf == null)
{
pf = new MPrintFormat (ctx, AD_PrintFormat_ID, null);
s_formats.put(key, pf);
}
return pf;
} // get
/**
* Get (default) Printformat for Report View or Table
* @param ctx context
* @param AD_ReportView_ID id or 0
* @param AD_Table_ID id or 0
* @return first print format found or null
*/
static public MPrintFormat get (Properties ctx, int AD_ReportView_ID, int AD_Table_ID)
{
MPrintFormat retValue = null;
PreparedStatement pstmt = null;
String sql = "SELECT * FROM AD_PrintFormat WHERE ";
if (AD_ReportView_ID > 0)
sql += "AD_ReportView_ID=?";
else
sql += "AD_Table_ID=?";
sql += " ORDER BY IsDefault DESC";
try
{
pstmt = DB.prepareStatement (sql, null);
pstmt.setInt (1, AD_ReportView_ID > 0 ? AD_ReportView_ID : AD_Table_ID);
ResultSet rs = pstmt.executeQuery ();
if (rs.next ())
retValue = new MPrintFormat (ctx, rs, null);
rs.close ();
pstmt.close ();
pstmt = null;
}
catch (Exception e)
{
s_log.log(Level.SEVERE, sql, e);
}
try
{
if (pstmt != null)
pstmt.close ();
pstmt = null;
}
catch (Exception e)
{
pstmt = null;
}
return retValue;
} // get
/**
* Delete Format from Cache
* @param AD_PrintFormat_ID id
*/
static public void deleteFromCache (int AD_PrintFormat_ID)
{
Integer key = new Integer(AD_PrintFormat_ID);
s_formats.put(key, null);
} // deleteFromCache
/**************************************************************************
* Test
* @param args arga
*/
static public void main (String[] args)
{
org.compiere.Compiere.startup(true);
/**
MPrintFormat.createFromTable(Env.getCtx(), 496); // Order
MPrintFormat.createFromTable(Env.getCtx(), 497);
MPrintFormat.createFromTable(Env.getCtx(), 516); // Invoice
MPrintFormat.createFromTable(Env.getCtx(), 495);
MPrintFormat.createFromTable(Env.getCtx(), 500); // Shipment
MPrintFormat.createFromTable(Env.getCtx(), 501);
MPrintFormat.createFromTable(Env.getCtx(), 498); // Check
MPrintFormat.createFromTable(Env.getCtx(), 499);
MPrintFormat.createFromTable(Env.getCtx(), 498); // Remittance
**/
} // main
} // MPrintFormat
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -