[ 1821870 ] Add column visibility control to grid

[ 1818041 ] Implement Favourite Pane Using SwingX
This commit is contained in:
Heng Sin Low 2007-10-29 01:10:00 +00:00
parent 7b15ae945d
commit 3d65b519e5
5 changed files with 56 additions and 172 deletions

View File

@ -7,6 +7,6 @@
<classpathentry kind="src" path="/looks"/> <classpathentry kind="src" path="/looks"/>
<classpathentry kind="lib" path="/tools/lib/jfreechart-1.0.2.jar"/> <classpathentry kind="lib" path="/tools/lib/jfreechart-1.0.2.jar"/>
<classpathentry kind="lib" path="/tools/lib/jcommon-1.0.5.jar"/> <classpathentry kind="lib" path="/tools/lib/jcommon-1.0.5.jar"/>
<classpathentry kind="lib" path="/tools/lib/swinglabs-0.8.0.jar"/> <classpathentry kind="lib" path="/tools/lib/swingx-0.9.0.jar"/>
<classpathentry kind="output" path="build"/> <classpathentry kind="output" path="build"/>
</classpath> </classpath>

View File

@ -18,11 +18,14 @@ package org.compiere.grid;
import java.awt.*; import java.awt.*;
import java.beans.*; import java.beans.*;
import javax.swing.Action;
import javax.swing.table.*; import javax.swing.table.*;
import org.compiere.grid.ed.*; import org.compiere.grid.ed.*;
import org.compiere.model.*; import org.compiere.model.*;
import org.compiere.swing.*; import org.compiere.swing.*;
import org.compiere.util.*; import org.compiere.util.*;
import org.jdesktop.swingx.action.BoundAction;
/** /**
* Table Grid based on CTable. * Table Grid based on CTable.
@ -36,6 +39,8 @@ import org.compiere.util.*;
public final class VTable extends CTable public final class VTable extends CTable
implements PropertyChangeListener implements PropertyChangeListener
{ {
private final static String PACK_ALL_COMMAND = CColumnControlButton.COLUMN_CONTROL_MARKER + "packAll";
/** /**
* Default Constructor * Default Constructor
*/ */
@ -45,7 +50,27 @@ public final class VTable extends CTable
setAutoscrolls(true); setAutoscrolls(true);
putClientProperty("terminateEditOnFocusLost", Boolean.TRUE); putClientProperty("terminateEditOnFocusLost", Boolean.TRUE);
new VTableExcelAdapter(this); // teo_sarca - FR [ 1753943 ] new VTableExcelAdapter(this); // teo_sarca - FR [ 1753943 ]
getActionMap().put(PACK_ALL_COMMAND, createPackAllAction());
} // VTable } // VTable
private Action createPackAllAction()
{
//TODO: localization
BoundAction action = new BoundAction("Size All Column", PACK_ALL_COMMAND);
action.setLongDescription("Size all column to fit content");
action.registerCallback(this, "packAll");
return action;
}
/**
* Size all column to fit content.
*/
public void packAll()
{
autoSize(true);
}
/** Logger */ /** Logger */
private static CLogger log = CLogger.getCLogger(VTable.class); private static CLogger log = CLogger.getCLogger(VTable.class);

View File

@ -1,144 +0,0 @@
/******************************************************************************
* 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.grid.ed;
import java.awt.*;
import java.util.*;
import javax.swing.*;
import javax.swing.event.*;
import javax.swing.table.*;
import org.compiere.util.*;
/**
* No Table Edit/Renderer
*
* @author Jorg Janke
* @version $Id: TableCellNone.java,v 1.2 2006/07/30 00:51:28 jjanke Exp $
*/
public class TableCellNone
implements TableCellRenderer, TableCellEditor
{
/**
* Table Cell None constructor
* @param ColumnName name
*/
public TableCellNone (String ColumnName)
{
m_ColumnName = ColumnName;
} // TableCellNone
/** Column Name */
private String m_ColumnName;
/** Object */
private Object m_value = null;
/** Logger */
private static CLogger log = CLogger.getCLogger (TableCellNone.class);
/**
* Get Table Cell Renderer Component
* @param table
* @param value
* @param isSelected
* @param hasFocus
* @param row
* @param col
* @return null
*/
public Component getTableCellRendererComponent (JTable table, Object value,
boolean isSelected, boolean hasFocus, int row, int col)
{
log.finest(m_ColumnName + ": Value=" + value + ", row=" + row + ", col=" + col);
m_value = value;
return null;
}
/**
* Get Table Cell Editor Component
* @param table
* @param value
* @param isSelected
* @param row
* @param col
* @return null
*/
public Component getTableCellEditorComponent (JTable table, Object value,
boolean isSelected, int row, int col)
{
log.finest(m_ColumnName + ": Value=" + value + ", row=" + row + ", col=" + col);
m_value = value;
return null;
}
/**
* Get Cell Editor Value
* @return null
*/
public Object getCellEditorValue ()
{
log.finest(m_ColumnName + "=" + m_value);
return m_value;
}
/**
* Is Cell Editable
* @param anEvent
* @return false
*/
public boolean isCellEditable (EventObject anEvent)
{
log.finest(m_ColumnName);
return false;
}
/**
* Should Select Cell
* @param anEvent
* @return false
*/
public boolean shouldSelectCell (EventObject anEvent)
{
log.finest(m_ColumnName);
return false;
}
/**
* Stop Cell Editing
* @return true
*/
public boolean stopCellEditing ()
{
return true;
}
/**
* Cancel Cell Editing
*/
public void cancelCellEditing ()
{
}
public void addCellEditorListener (CellEditorListener l)
{
}
public void removeCellEditorListener (CellEditorListener l)
{
}
} // TableCellNone

View File

@ -77,7 +77,7 @@ public final class VHeaderRenderer implements TableCellRenderer
if (table instanceof CTable) if (table instanceof CTable)
{ {
CTable cTable = (CTable)table; CTable cTable = (CTable)table;
if (cTable.getSortColumn() == column) if (cTable.getSortColumn() == table.convertColumnIndexToModel(column))
{ {
icon = cTable.isSortAscending() icon = cTable.isSortAscending()
? Env.getImageIcon2("uparrow") ? Env.getImageIcon2("uparrow")

View File

@ -36,6 +36,8 @@ import org.compiere.apps.*;
import org.compiere.model.*; import org.compiere.model.*;
import org.compiere.swing.*; import org.compiere.swing.*;
import org.compiere.util.*; import org.compiere.util.*;
import org.jdesktop.swingx.JXTaskPane;
import org.jdesktop.swingx.JXTaskPaneContainer;
/** /**
* Tree Panel displays trees. * Tree Panel displays trees.
@ -78,8 +80,7 @@ public final class VTreePanel extends CPanel
if (!hasBar) if (!hasBar)
{ {
bar.setPreferredSize(new Dimension(0,0)); bar.setPreferredSize(new Dimension(0,0));
//centerSplitPane.setDividerLocation(0); centerSplitPane.setDividerLocation(0);
centerSplitPane.setDividerLocation(1000);
centerSplitPane.setDividerSize(0); centerSplitPane.setDividerSize(0);
popMenuTree.remove(mBarAdd); popMenuTree.remove(mBarAdd);
} }
@ -130,7 +131,8 @@ public final class VTreePanel extends CPanel
jt.removeAll(); jt.removeAll();
toolbarMap = new HashMap<Integer, JToolBar>(); toolbarMap = new HashMap<Integer, JToolBar>();
Enumeration enTop =m_root.children(); Enumeration enTop =m_root.children();
JToolBar jt = null; JToolBar jt = null;
Map<JToolBar,String> titleMap = new HashMap<JToolBar, String>();
while (enTop.hasMoreElements()) while (enTop.hasMoreElements())
{ {
MTreeNode ndTop = (MTreeNode)enTop.nextElement(); MTreeNode ndTop = (MTreeNode)enTop.nextElement();
@ -142,7 +144,7 @@ public final class VTreePanel extends CPanel
if (nd.isOnBar()) { if (nd.isOnBar()) {
if (!labelDrawn) { if (!labelDrawn) {
jt = new JToolBar(JToolBar.VERTICAL); jt = new JToolBar(JToolBar.VERTICAL);
addToBar(ndTop, jt, true); titleMap.put(jt, ndTop.toString().trim());
labelDrawn=true; labelDrawn=true;
toolbarMap.put(ndTop.getNode_ID(), jt); toolbarMap.put(ndTop.getNode_ID(), jt);
} }
@ -160,15 +162,15 @@ public final class VTreePanel extends CPanel
jt2.setFloatable(false); jt2.setFloatable(false);
jt2.setRollover(true); jt2.setRollover(true);
jt2.setBorder(BorderFactory.createEmptyBorder()); jt2.setBorder(BorderFactory.createEmptyBorder());
CPanel barPart = new CPanel();
JXTaskPane barPart = new JXTaskPane();
barPart.setAnimated(true);
barPart.setLayout(new BorderLayout()); barPart.setLayout(new BorderLayout());
barPart.add(jt2, BorderLayout.NORTH); barPart.add(jt2, BorderLayout.NORTH);
barPart.setBorder(new ShadowBorder()); barPart.setTitle(titleMap.get(jt2));
bar.add(barPart); bar.add(barPart);
} }
if (toolbarMap.size()<=3){
bar.setLayout(new GridLayout(0, 1));
}
} }
return true; return true;
} // initTree } // initTree
@ -188,12 +190,10 @@ public final class VTreePanel extends CPanel
private JPopupMenu popMenuBar = new JPopupMenu(); private JPopupMenu popMenuBar = new JPopupMenu();
private CMenuItem mFrom = new CMenuItem(); private CMenuItem mFrom = new CMenuItem();
private CMenuItem mTo = new CMenuItem(); private CMenuItem mTo = new CMenuItem();
private CPanel bar = new CPanel(); private JXTaskPaneContainer bar = new JXTaskPaneContainer();
private java.util.List<JToolBar> toolbar; private java.util.List<JToolBar> toolbar;
private HashMap<Integer, JToolBar> toolbarMap; private HashMap<Integer, JToolBar> toolbarMap;
private int toolBarCols=3; private int toolBarCols=3;
//private int toolBarRows=2;
//private JToolBar toolbar = new JToolBar(JToolBar.VERTICAL);
private CMenuItem mBarAdd = new CMenuItem(); private CMenuItem mBarAdd = new CMenuItem();
private CMenuItem mBarRemove = new CMenuItem(); private CMenuItem mBarRemove = new CMenuItem();
private BorderLayout southLayout = new BorderLayout(); private BorderLayout southLayout = new BorderLayout();
@ -251,8 +251,12 @@ public final class VTreePanel extends CPanel
treePane.getViewport().add(tree, null); treePane.getViewport().add(tree, null);
treePane.setBorder(new ShadowBorder()); treePane.setBorder(new ShadowBorder());
tree.setBorder(BorderFactory.createEmptyBorder()); tree.setBorder(BorderFactory.createEmptyBorder());
// treePane.setPreferredSize(new Dimension(50,200));
// tree.setPreferredSize(new Dimension(100,150)); CPanel treePart = new CPanel();
treePart.setLayout(new BorderLayout());
treePart.add(treePane, BorderLayout.CENTER);
treePart.setBorder(BorderFactory.createEmptyBorder());
// //
treeExpand.setText(Msg.getMsg(Env.getCtx(), "ExpandTree")); treeExpand.setText(Msg.getMsg(Env.getCtx(), "ExpandTree"));
treeExpand.setActionCommand("Expand"); treeExpand.setActionCommand("Expand");
@ -269,22 +273,18 @@ public final class VTreePanel extends CPanel
southPanel.add(treeExpand, BorderLayout.WEST); southPanel.add(treeExpand, BorderLayout.WEST);
southPanel.add(treeSearchLabel, BorderLayout.CENTER); southPanel.add(treeSearchLabel, BorderLayout.CENTER);
southPanel.add(treeSearch, BorderLayout.EAST); southPanel.add(treeSearch, BorderLayout.EAST);
this.add(southPanel, BorderLayout.SOUTH); treePart.add(southPanel, BorderLayout.SOUTH);
// //
centerSplitPane.setOpaque(false); centerSplitPane.setOpaque(false);
centerSplitPane.add(treePane, JSplitPane.LEFT); //fcsku 3.7.2007 switch menu/favorites JScrollPane scrollPane = new JScrollPane();
centerSplitPane.add(bar, JSplitPane.RIGHT); scrollPane.getViewport().add(bar);
centerSplitPane.add(scrollPane, JSplitPane.LEFT); //hengsin, jxtaskpane
centerSplitPane.add(treePart, JSplitPane.RIGHT);
centerSplitPane.setBorder(BorderFactory.createEmptyBorder()); centerSplitPane.setBorder(BorderFactory.createEmptyBorder());
removeSplitPaneBorder(); removeSplitPaneBorder();
this.add(centerSplitPane, BorderLayout.CENTER); this.add(centerSplitPane, BorderLayout.CENTER);
GridLayout barLayout = new GridLayout(0, toolBarCols);
bar.setMinimumSize(new Dimension (50,50));
bar.setBorder(new ShadowBorder());
bar.setLayout(barLayout);
// //
mFrom.setText(Msg.getMsg(Env.getCtx(), "ItemMove")); mFrom.setText(Msg.getMsg(Env.getCtx(), "ItemMove"));
mFrom.setActionCommand("From"); mFrom.setActionCommand("From");
@ -916,17 +916,20 @@ public final class VTreePanel extends CPanel
if(ndTop.getNode_ID()==topParentId){ if(ndTop.getNode_ID()==topParentId){
log.fine("add new category: " + ndTop); log.fine("add new category: " + ndTop);
parent = new JToolBar(JToolBar.VERTICAL); parent = new JToolBar(JToolBar.VERTICAL);
addToBar(ndTop, parent, true);
toolbarMap.put(ndTop.getNode_ID(), parent); toolbarMap.put(ndTop.getNode_ID(), parent);
toolbar.add(parent); toolbar.add(parent);
parent.setOpaque(false); parent.setOpaque(false);
parent.setFloatable(false); parent.setFloatable(false);
parent.setRollover(true); parent.setRollover(true);
parent.setBorder(BorderFactory.createEmptyBorder()); parent.setBorder(BorderFactory.createEmptyBorder());
CPanel barPart = new CPanel();
JXTaskPane barPart = new JXTaskPane();
barPart.setTitle(ndTop.toString().trim());
barPart.setAnimated(true);
barPart.setLayout(new BorderLayout()); barPart.setLayout(new BorderLayout());
barPart.add(parent, BorderLayout.NORTH); barPart.add(parent, BorderLayout.NORTH);
barPart.setBorder(new ShadowBorder());
bar.add(barPart); bar.add(barPart);
return parent; return parent;
} }