/****************************************************************************** * Product: Adempiere ERP & CRM Smart Business Solution * * Copyright (C) 1999-2006 ComPiere, Inc. All Rights Reserved. * * This program is free software; you can redistribute it and/or modify it * * under the terms version 2 of the GNU General Public License as published * * by the Free Software Foundation. This program is distributed in the hope * * that it will be useful, but WITHOUT ANY WARRANTY; without even the implied * * warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. * * See the GNU General Public License for more details. * * You should have received a copy of the GNU General Public License along * * with this program; if not, write to the Free Software Foundation, Inc., * * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. * * For the text or an alternative of this public license, you may reach us * * ComPiere, Inc., 2620 Augustine Dr. #245, Santa Clara, CA 95054, USA * * or via info@compiere.org or http://www.compiere.org/license.html * *****************************************************************************/ package org.compiere.process; import java.util.logging.Level; import org.compiere.model.MField; import org.compiere.model.MProcessPara; import org.compiere.model.MTab; import org.compiere.model.MWindow; import org.compiere.util.AdempiereUserError; import org.compiere.util.DB; /** * Copy all Tabs of a Window * * @author Jorg Janke * @version $Id: WindowCopy.java,v 1.3 2006/07/30 00:51:02 jjanke Exp $ */ @org.adempiere.base.annotation.Process public class WindowCopy extends SvrProcess { /** Window To */ private int p_AD_WindowTo_ID = 0; /** Window From */ private int p_AD_WindowFrom_ID = 0; /** * Prepare - e.g., get Parameters. */ 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 if (name.equals("AD_Window_ID")) p_AD_WindowFrom_ID = para[i].getParameterAsInt(); else MProcessPara.validateUnknownParameter(getProcessInfo().getAD_Process_ID(), para[i]); } p_AD_WindowTo_ID = getRecord_ID(); } // prepare /** * Process * @return message * @throws Exception */ protected String doIt() throws Exception { final String sqluptrlwin = "" + "UPDATE ad_window_trl " + "SET name = (SELECT name " + " FROM ad_window_trl t2 " + " WHERE t2.ad_window_id = ? AND t2.ad_language = ad_window_trl.ad_language), " + " description = (SELECT description " + " FROM ad_window_trl t2 " + " WHERE t2.ad_window_id = ? AND t2.ad_language = ad_window_trl.ad_language), " + " help = (SELECT help " + " FROM ad_window_trl t2 " + " WHERE t2.ad_window_id = ? AND t2.ad_language = ad_window_trl.ad_language), " + " istranslated = (SELECT istranslated " + " FROM ad_window_trl t2 " + " WHERE t2.ad_window_id = ? AND t2.ad_language = ad_window_trl.ad_language) " + "WHERE ad_window_id = ?"; final String sqluptrltab = "" + "UPDATE ad_tab_trl " + "SET name = (SELECT name " + " FROM ad_tab_trl t2 " + " WHERE t2.ad_tab_id = ? AND t2.ad_language = ad_tab_trl.ad_language), " + " description = (SELECT description " + " FROM ad_tab_trl t2 " + " WHERE t2.ad_tab_id = ? AND t2.ad_language = ad_tab_trl.ad_language), " + " help = (SELECT help " + " FROM ad_tab_trl t2 " + " WHERE t2.ad_tab_id = ? AND t2.ad_language = ad_tab_trl.ad_language), " + " commitwarning = (SELECT commitwarning " + " FROM ad_tab_trl t2 " + " WHERE t2.ad_tab_id = ? AND t2.ad_language = ad_tab_trl.ad_language), " + " istranslated = (SELECT istranslated " + " FROM ad_tab_trl t2 " + " WHERE t2.ad_tab_id = ? AND t2.ad_language = ad_tab_trl.ad_language) " + "WHERE ad_tab_id = ?"; final String sqluptrlfld = "" + "UPDATE ad_field_trl " + "SET name = (SELECT name " + " FROM ad_field_trl t2 " + " WHERE t2.ad_field_id = ? AND t2.ad_language = ad_field_trl.ad_language), " + " description = (SELECT description " + " FROM ad_field_trl t2 " + " WHERE t2.ad_field_id = ? AND t2.ad_language = ad_field_trl.ad_language), " + " help = (SELECT help " + " FROM ad_field_trl t2 " + " WHERE t2.ad_field_id = ? AND t2.ad_language = ad_field_trl.ad_language), " + " istranslated = (SELECT istranslated " + " FROM ad_field_trl t2 " + " WHERE t2.ad_field_id = ? AND t2.ad_language = ad_field_trl.ad_language) " + "WHERE ad_field_id = ?"; if (log.isLoggable(Level.INFO)) log.info("doIt - To AD_Window_ID=" + p_AD_WindowTo_ID + ", From=" + p_AD_WindowFrom_ID); MWindow from = new MWindow (getCtx(), p_AD_WindowFrom_ID, get_TrxName()); if (from.get_ID() == 0) throw new AdempiereUserError("@NotFound@ (from->) @AD_Window_ID@"); MWindow to = new MWindow (getCtx(), p_AD_WindowTo_ID, get_TrxName()); if (to.get_ID() == 0) throw new AdempiereUserError("@NotFound@ (to<-) @AD_Window_ID@"); DB.executeUpdateEx(sqluptrlwin, new Object[]{from.get_ID(),from.get_ID(),from.get_ID(),from.get_ID(),to.get_ID()}, get_TrxName()); int tabCount = 0; int fieldCount = 0; for (MTab oldTab : from.getTabs(false, get_TrxName())) { if (! oldTab.isActive()) continue; MTab newTab = new MTab (to, oldTab); if (newTab.save()) { DB.executeUpdateEx(sqluptrltab, new Object[]{oldTab.get_ID(),oldTab.get_ID(),oldTab.get_ID(),oldTab.get_ID(),oldTab.get_ID(),newTab.get_ID()}, get_TrxName()); tabCount++; // Copy Fields for (MField oldField : oldTab.getFields(false, get_TrxName())) { MField newField = new MField (newTab, oldField); if (! oldField.isActive()) newField.setIsActive(false); if (newField.save()) { DB.executeUpdateEx(sqluptrlfld, new Object[]{oldField.get_ID(),oldField.get_ID(),oldField.get_ID(),oldField.get_ID(),newField.get_ID()}, get_TrxName()); fieldCount++; } else { throw new AdempiereUserError("@Error@ @AD_Field_ID@"); } } } else throw new AdempiereUserError("@Error@ @AD_Tab_ID@"); } StringBuilder msgreturn = new StringBuilder("@Copied@ #").append(tabCount).append("/").append(fieldCount); return msgreturn.toString(); } // doIt } // WindowCopy