* Implemented zoom across.

* Bug: Zoom to transaction screen failed.
This commit is contained in:
Heng Sin Low 2008-07-17 01:16:06 +00:00
parent 4bc63ab3b4
commit 998ab34d8d
4 changed files with 316 additions and 17 deletions

View File

@ -23,6 +23,9 @@ import java.util.List;
import java.util.logging.Level; import java.util.logging.Level;
import org.adempiere.webui.apps.ProcessDialog; import org.adempiere.webui.apps.ProcessDialog;
import org.adempiere.webui.component.Grid;
import org.adempiere.webui.component.Row;
import org.adempiere.webui.component.Rows;
import org.adempiere.webui.component.Tabpanel; import org.adempiere.webui.component.Tabpanel;
import org.adempiere.webui.component.Window; import org.adempiere.webui.component.Window;
import org.adempiere.webui.event.MenuListener; import org.adempiere.webui.event.MenuListener;
@ -46,6 +49,8 @@ import org.zkoss.zkex.zul.Borderlayout;
import org.zkoss.zkex.zul.Center; import org.zkoss.zkex.zul.Center;
import org.zkoss.zkex.zul.North; import org.zkoss.zkex.zul.North;
import org.zkoss.zkex.zul.West; import org.zkoss.zkex.zul.West;
import org.zkoss.zul.Caption;
import org.zkoss.zul.Groupbox;
import org.zkoss.zul.Iframe; import org.zkoss.zul.Iframe;
import org.zkoss.zul.Label; import org.zkoss.zul.Label;
@ -120,9 +125,27 @@ public class Desktop extends AbstractUIPart implements MenuListener, Serializabl
//TODO: dashboard //TODO: dashboard
Tabpanel homeTab = new Tabpanel(); Tabpanel homeTab = new Tabpanel();
windowContainer.addWindow(homeTab, "Home", false); windowContainer.addWindow(homeTab, "Home", false);
Label t = new Label();
t.setValue("My Home!"); Grid grid = new Grid();
t.setParent(homeTab); grid.setOddRowSclass("even");
grid.setSclass("grid-no-striped");
grid.setWidth("100%");
grid.setHeight("100%");
homeTab.appendChild(grid);
Rows rows = new Rows();
grid.appendChild(rows);
Row row = new Row();
rows.appendChild(row);
Groupbox groupBox = new Groupbox();
row.appendChild(groupBox);
Caption caption = new Caption("Favourites");
groupBox.appendChild(caption);
groupBox.setMold("3d");
groupBox.appendChild(new Label("My Favourites!"));
groupBox.setClosable(true);
//register as 0 //register as 0
registerWindow(homeTab); registerWindow(homeTab);

View File

@ -0,0 +1,238 @@
/******************************************************************************
* 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.adempiere.webui;
import java.sql.*;
import java.util.*;
import java.util.logging.*;
import org.adempiere.webui.apps.AEnv;
import org.compiere.model.*;
import org.compiere.util.*;
import org.zkoss.zk.ui.Component;
import org.zkoss.zk.ui.event.Event;
import org.zkoss.zk.ui.event.EventListener;
import org.zkoss.zk.ui.event.Events;
import org.zkoss.zul.Label;
import org.zkoss.zul.Menuitem;
import org.zkoss.zul.Menupopup;
/**
* Application Zoom Across Launcher.
* Called from APanel; Queries available Zoom Targets for Table.
*
* @author Jorg Janke
* @version $Id: AZoomAcross.java,v 1.2 2006/07/30 00:51:27 jjanke Exp $
*
* @author Teo Sarca, SC ARHIPAC SERVICE SRL - FR [ 1762465 ]
*
* ZK Port
* @author Low Heng Sin
*/
public class WZoomAcross implements EventListener
{
/**
* Constructor
* @param invoker component to display popup (optional)
* @param tableName table name
* @param query query
*/
public WZoomAcross (Component invoker, String tableName, MQuery query)
{
log.config("TableName=" + tableName + " - " + query);
m_tableName = tableName;
m_query = query;
// See What is there
getZoomTargets (invoker, tableName);
} // AReport
/** The Query */
private MQuery m_query;
/** The Popup */
private Menupopup m_popup = new Menupopup(); //"ZoomMenu"
/** The Option List */
private ArrayList<KeyNamePair> m_list = new ArrayList<KeyNamePair>();
/** Logger */
private static CLogger log = CLogger.getCLogger(WZoomAcross.class);
/** Table Name */
private String m_tableName;
private ArrayList<String> m_targets = new ArrayList<String>();
/**
* Get the Zomm Targets for the table.
* Fill the list and the popup menu
* @param invoker component to display popup (optional)
* @param tableName table
*/
private void getZoomTargets (Component invoker, String tableName)
{
String sql = "SELECT DISTINCT ws.AD_Window_ID,ws.Name, wp.AD_Window_ID,wp.Name, t.TableName "
+ "FROM AD_Table t ";
boolean baseLanguage = Env.isBaseLanguage(Env.getCtx(), "AD_Window");
if (baseLanguage)
sql += "INNER JOIN AD_Window ws ON (t.AD_Window_ID=ws.AD_Window_ID)"
+ " LEFT OUTER JOIN AD_Window wp ON (t.PO_Window_ID=wp.AD_Window_ID) ";
else
sql += "INNER JOIN AD_Window_Trl ws ON (t.AD_Window_ID=ws.AD_Window_ID AND ws.AD_Language=?)"
+ " LEFT OUTER JOIN AD_Window_Trl wp ON (t.PO_Window_ID=wp.AD_Window_ID AND wp.AD_Language=?) ";
//
sql += "WHERE t.TableName NOT LIKE 'I%'" // No Import
+ " AND EXISTS (SELECT * FROM AD_Tab tt " // First Tab
+ "WHERE (tt.AD_Window_ID=ws.AD_Window_ID OR tt.AD_Window_ID=wp.AD_Window_ID)"
+ " AND tt.AD_Table_ID=t.AD_Table_ID AND tt.SeqNo=10)"
+ " AND t.AD_Table_ID IN "
+ "(SELECT AD_Table_ID FROM AD_Column "
+ "WHERE ColumnName=? AND IsKey='N' AND IsParent='N') " // #x
+ "ORDER BY 2";
try
{
PreparedStatement pstmt = DB.prepareStatement(sql, null);
int index = 1;
if (!baseLanguage)
{
pstmt.setString (index++, Env.getAD_Language(Env.getCtx()));
pstmt.setString (index++, Env.getAD_Language(Env.getCtx()));
}
pstmt.setString (index++, tableName + "_ID");
ResultSet rs = pstmt.executeQuery();
while (rs.next())
{
int AD_Window_ID = rs.getInt(1);
String Name = rs.getString(2);
int PO_Window_ID = rs.getInt(3);
String targetTableName = rs.getString(5);
if (PO_Window_ID == 0)
addTarget(targetTableName, AD_Window_ID, Name, null);
else
addTarget(targetTableName, AD_Window_ID, Name, Boolean.TRUE);
// PO
if (PO_Window_ID != 0)
{
Name = rs.getString(4);
addTarget(targetTableName, PO_Window_ID, Name, Boolean.FALSE);
}
}
rs.close();
pstmt.close();
}
catch (SQLException e)
{
log.log(Level.SEVERE, sql, e);
}
// Begin - afalcone - Bug Fix [ 1659420 ] Usability: zoom across
/*
// No Zoom
if (m_list.size() == 0)
{
ADialog.info(0, invoker, "NoZoomTarget");
log.info("BaseLanguage=" + baseLanguage);
}
else if (invoker.isShowing())
m_popup.show(invoker, 0, invoker.getHeight()); // below button
*/
// No Zoom
if (m_list.size() == 0)
{
m_popup.appendChild(new Label(Msg.getMsg(Env.getCtx(), "NoZoomTarget"))); // Added
log.info("BaseLanguage=" + baseLanguage);
}
m_popup.setPage(invoker.getPage());
m_popup.open(invoker);
//End - afalcone - Bug Fix [ 1659420 ] Usability: zoom across
} // getZoomTargets
/**
* Check Target and Add to popup
* @param targetTableName table name
* @param AD_Window_ID window
* @param Name name
* @param isSO has po/so Window
* @return true if there is a record
*/
private boolean addTarget (String targetTableName,
int AD_Window_ID, String Name, Boolean isSO)
{
String key = targetTableName + AD_Window_ID + Name + isSO;
if (m_targets.contains(key))
return false;
else
m_targets.add(key);
String sql = "SELECT COUNT(*) FROM " + targetTableName
+ " WHERE " + m_query.getWhereClause(false);
String sqlAdd = "";
if (isSO != null)
{
/*
For RMA, Material Receipt window should be loaded for IsSOTrx=true
and Shipment for IsSOTrx=false
*/
if (MRMA.Table_Name.equals(m_tableName) && (AD_Window_ID == 169
|| AD_Window_ID == 184))
{
isSO = !isSO;
}
sqlAdd = " AND IsSOTrx=" + (isSO.booleanValue() ? "'Y'" : "'N'");
}
int count = DB.getSQLValue(null, sql+sqlAdd);
if (count < 0 && isSO != null) // error try again w/o SO
count = DB.getSQLValue(null, sql);
if (count <= 0)
return false;
//
System.err.println("AD_Window_ID=" + AD_Window_ID + " targetTable=" + targetTableName + " Name="+Name + " Count=" + count);
KeyNamePair pp = new KeyNamePair (AD_Window_ID, Name + " (#"+count+")");
m_list.add(pp);
Menuitem menuItem = new Menuitem(pp.toString());
menuItem.addEventListener(Events.ON_CLICK, this);
m_popup.appendChild(menuItem);
m_query.setRecordCount(count);
return true;
} // checkTarget
/**
* Launch Zoom
* @param pp KeyPair
*/
private void launchZoom (KeyNamePair pp)
{
int AD_Window_ID = pp.getKey();
AEnv.zoom(AD_Window_ID, m_query);
} // launchZoom
public void onEvent(Event e) throws Exception {
if (e.getTarget() instanceof Menuitem) {
String cmd = ((Menuitem)e.getTarget()).getLabel();
for (int i = 0; i < m_list.size(); i++)
{
KeyNamePair pp = (KeyNamePair)m_list.get(i);
if (cmd.equals(pp.getName()))
{
launchZoom (pp);
return;
}
}
}
}
} // AZoom

View File

@ -68,6 +68,8 @@ public class CWindowToolbar extends FToolbar implements EventListener
private ArrayList<ToolbarListener> listeners = new ArrayList<ToolbarListener>(); private ArrayList<ToolbarListener> listeners = new ArrayList<ToolbarListener>();
private Event event;
public CWindowToolbar() public CWindowToolbar()
{ {
init(); init();
@ -120,7 +122,7 @@ public class CWindowToolbar extends FToolbar implements EventListener
btnGridToggle = new ToolBarButton(""); btnGridToggle = new ToolBarButton("");
btnGridToggle.setName("btnGridToggle"); btnGridToggle.setName("btnGridToggle");
btnGridToggle.setImage("/images/ZoomAcross24.gif"); btnGridToggle.setImage("/images/Multi24.gif");
btnGridToggle.setTooltiptext(Msg.getMsg(Env.getCtx(),"Multi")); btnGridToggle.setTooltiptext(Msg.getMsg(Env.getCtx(),"Multi"));
btnHistoryRecords = new ToolBarButton(""); btnHistoryRecords = new ToolBarButton("");
@ -231,7 +233,7 @@ public class CWindowToolbar extends FToolbar implements EventListener
this.appendChild(btnArchive); this.appendChild(btnArchive);
this.appendChild(btnPrint); this.appendChild(btnPrint);
addSeparator(); addSeparator();
//this.appendChild(btnZoomAcross); this.appendChild(btnZoomAcross);
this.appendChild(btnActiveWorkflows); this.appendChild(btnActiveWorkflows);
this.appendChild(btnRequests); this.appendChild(btnRequests);
this.appendChild(btnProductInfo); this.appendChild(btnProductInfo);
@ -255,6 +257,8 @@ public class CWindowToolbar extends FToolbar implements EventListener
// Testing Purposes // Testing Purposes
btnGridToggle.setDisabled(false); btnGridToggle.setDisabled(false);
btnZoomAcross.setDisabled(false);
} }
protected void addSeparator() protected void addSeparator()
@ -286,6 +290,7 @@ public class CWindowToolbar extends FToolbar implements EventListener
{ {
if(eventComp instanceof ToolBarButton) if(eventComp instanceof ToolBarButton)
{ {
this.event = event;
ToolBarButton cComponent = (ToolBarButton) eventComp; ToolBarButton cComponent = (ToolBarButton) eventComp;
String compName = cComponent.getName(); String compName = cComponent.getName();
String methodName = "on" + compName.substring(3); String methodName = "on" + compName.substring(3);
@ -318,6 +323,7 @@ public class CWindowToolbar extends FToolbar implements EventListener
log.log(Level.SEVERE, "Could not invoke Toolbar listener method: " + methodName + "()", e); log.log(Level.SEVERE, "Could not invoke Toolbar listener method: " + methodName + "()", e);
} }
} }
this.event = null;
} }
} }
} }
@ -443,4 +449,9 @@ public class CWindowToolbar extends FToolbar implements EventListener
{ {
return true; return true;
} }
public Event getEvent()
{
return event;
}
} }

View File

@ -20,6 +20,7 @@ package org.adempiere.webui.panel;
import java.util.Properties; import java.util.Properties;
import java.util.logging.Level; import java.util.logging.Level;
import org.adempiere.webui.WZoomAcross;
import org.adempiere.webui.apps.AEnv; import org.adempiere.webui.apps.AEnv;
import org.adempiere.webui.apps.ProcessModalDialog; import org.adempiere.webui.apps.ProcessModalDialog;
import org.adempiere.webui.apps.WReport; import org.adempiere.webui.apps.WReport;
@ -234,7 +235,7 @@ public abstract class AbstractADWindowPanel extends AbstractUIPart implements To
Env.setContext(ctx, curWindowNo, "WindowName", gridWindow.getName()); Env.setContext(ctx, curWindowNo, "WindowName", gridWindow.getName());
curTab.getTableModel().setChanged(false); curTab.getTableModel().setChanged(false);
curTabIndex = 0; curTabIndex = 0;
curTabpanel.query(); curTabpanel.query(m_onlyCurrentRows, m_onlyCurrentDays, 0);
curTabpanel.activate(true); curTabpanel.activate(true);
//if (tabbox.getTabCount() > 0) //if (tabbox.getTabCount() > 0)
@ -251,7 +252,6 @@ public abstract class AbstractADWindowPanel extends AbstractUIPart implements To
if (gridWindow.isTransaction()) if (gridWindow.isTransaction())
{ {
toolbar.enableHistoryRecords(true); toolbar.enableHistoryRecords(true);
history(1);
} }
updateToolbar(); updateToolbar();
@ -950,6 +950,33 @@ public abstract class AbstractADWindowPanel extends AbstractUIPart implements To
} }
public void onZoomAcross() {
if (toolbar.getEvent() != null)
{
int record_ID = curTab.getRecord_ID();
if (record_ID <= 0)
return;
// Query
MQuery query = new MQuery();
// Current row
String link = curTab.getKeyColumnName();
// Link for detail records
if (link.length() == 0)
link = curTab.getLinkColumnName();
if (link.length() != 0)
{
if (link.endsWith("_ID"))
query.addRestriction(link, MQuery.EQUAL,
new Integer(Env.getContextAsInt(ctx, curWindowNo, link)));
else
query.addRestriction(link, MQuery.EQUAL,
Env.getContext(ctx, curWindowNo, link));
}
new WZoomAcross (toolbar.getEvent().getTarget(), curTab.getTableName(), query);
}
}
/************************************************************************** /**************************************************************************
* Start Button Process * Start Button Process
* @param vButton button * @param vButton button