[ 1855851 ] Propose New Look for Collapseable Field Group

This commit is contained in:
Heng Sin Low 2007-12-25 09:15:59 +00:00
parent 87926396d6
commit a4140ab3b7
2 changed files with 42 additions and 55 deletions

View File

@ -447,31 +447,32 @@ public class GridController extends CPanel
int c = VTable.WHEN_ANCESTOR_OF_FOCUSED_COMPONENT;
vTable.getInputMap(c).put(KeyStroke.getKeyStroke(KeyEvent.VK_F4, 0), aPanel.aSave.getName());
vTable.getActionMap().put(aPanel.aSave.getName(), aPanel.aSave);
org.jdesktop.swingx.JXTaskPane taskpanetab = vPanel.getTaskPane(detail.getMTab().getAD_Tab_ID());
CollapsiblePanel section = vPanel.getIncludedSection(detail.getMTab().getAD_Tab_ID());
gc.isDetailGrid(true);
if(taskpanetab != null)
if(section != null)
{
APanel painel = new APanel(gc);
APanel panel = new APanel(gc);
String name = detail.getMTab().getName() + "";
taskpanetab.setTitle(name);
painel.add(detail);
taskpanetab.add(painel);
section.setTitle(name);
panel.add(detail);
section.getCollapsiblePane().getContentPane().setLayout(new BorderLayout());
section.getCollapsiblePane().getContentPane().add(panel, BorderLayout.CENTER);
}
JRootPane rt = SwingUtilities.getRootPane(this);
if (rt == null)
System.out.println("Root pane null");
log.info("Root pane null");
else
{
System.out.println("Root=" + rt);
log.info("Root=" + rt);
rt.addMouseListener(detail);
Component gp = rt.getGlassPane();
if (gp == null)
System.out.println("No Glass Pane");
log.info("No Glass Pane");
else
{
System.out.println("Glass=" + gp);
log.info("Glass=" + gp);
gp.addMouseListener(detail);
}

View File

@ -29,8 +29,7 @@ import org.compiere.grid.ed.*;
import org.compiere.model.*;
import org.compiere.swing.*;
import org.compiere.util.*;
import org.jdesktop.swingx.JXTaskPane;
import org.jdesktop.swingx.JXTaskPaneContainer;
import org.jdesktop.swingx.JXCollapsiblePane;
import org.jdesktop.swingx.border.DropShadowBorder;
/**
@ -167,11 +166,7 @@ public final class VPanel extends CTabbedPane
m_gbc.gridx = 0;
m_gbc.gridy = m_line++;
m_gbc.gridwidth = 4;
JXTaskPaneContainer GroupPaneContainer = createTaskPaneContainer();
JXTaskPane m_tab = new JXTaskPane();
m_tab.getContentPane().setBackground(AdempierePLAF.getFormBackground());
m_tab.setLayout(new BorderLayout());
GroupPaneContainer.add(m_tab);
CollapsiblePanel m_tab = new CollapsiblePanel("");
m_tabincludelist.put(AD_Tab_ID, m_tab);
m_gbc.anchor = GridBagConstraints.NORTHWEST;
m_gbc.gridx = 0;
@ -182,7 +177,7 @@ public final class VPanel extends CTabbedPane
m_gbc.fill = GridBagConstraints.HORIZONTAL;
m_gbc.weightx = 0;
m_gbc.ipadx = 0;
m_main.add(GroupPaneContainer,m_gbc);
m_main.add(m_tab,m_gbc);
return;
}
CLabel label = VEditorFactory.getLabel(mField);
@ -239,8 +234,8 @@ public final class VPanel extends CTabbedPane
}
else if (fieldGroupType.equals(X_AD_FieldGroup.FIELDGROUPTYPE_Collapse))
{
JXTaskPane m_tab = (JXTaskPane)m_tablist.get(fieldGroup);
m_tab.add(label, m_gbc);
CollapsiblePanel m_tab = (CollapsiblePanel) m_tablist.get(fieldGroup);
m_tab.getCollapsiblePane().getContentPane().add(label, m_gbc);
}
else // Label or null
{
@ -273,8 +268,8 @@ public final class VPanel extends CTabbedPane
}
else if (fieldGroupType.equals(X_AD_FieldGroup.FIELDGROUPTYPE_Collapse))
{
JXTaskPane m_tab = (JXTaskPane)m_tablist.get(fieldGroup);
m_tab.add(field, m_gbc);
CollapsiblePanel m_tab = (CollapsiblePanel) m_tablist.get(fieldGroup);
m_tab.getCollapsiblePane().getContentPane().add(field, m_gbc);
}
else // Label or null
{
@ -329,15 +324,11 @@ public final class VPanel extends CTabbedPane
}
else if (fieldGroupType.equals(X_AD_FieldGroup.FIELDGROUPTYPE_Collapse))
{
JXTaskPaneContainer GroupPaneContainer = createTaskPaneContainer();
JXTaskPane m_tab = new JXTaskPane();
CollapsiblePanel collapsibleSection = new CollapsiblePanel(fieldGroup);
JXCollapsiblePane m_tab = collapsibleSection.getCollapsiblePane();
m_tab.getContentPane().setBackground(AdempierePLAF.getFormBackground());
m_tab.setLayout(new GridBagLayout());
m_tab.setTitle(fieldGroup);
m_tab.getContentPane().setLayout(new GridBagLayout());
m_tab.setName(fieldGroup);
m_tab.setAnimated(true);
GroupPaneContainer.add(m_tab);
m_gbc.anchor = GridBagConstraints.NORTHWEST;
//m_gbc.gridy = 0; // line
m_gbc.gridx = 0;
@ -348,8 +339,8 @@ public final class VPanel extends CTabbedPane
m_gbc.fill = GridBagConstraints.HORIZONTAL;
m_gbc.weightx = 0;
m_gbc.ipadx = 0;
m_main.add(GroupPaneContainer,m_gbc);
m_tablist.put(fieldGroup, m_tab);
m_main.add(collapsibleSection,m_gbc);
m_tablist.put(fieldGroup, collapsibleSection);
}
else // Label or null
{
@ -368,16 +359,6 @@ public final class VPanel extends CTabbedPane
return true;
} // addGroup
private JXTaskPaneContainer createTaskPaneContainer() {
Color c = AdempierePLAF.getFormBackground();
Color containerBg = new Color(Math.max((int)(c.getRed() * 0.97), 0),
Math.max((int)(c.getGreen()*0.97), 0),
Math.max((int)(c.getBlue() *0.97), 0));
JXTaskPaneContainer GroupPaneContainer = new JXTaskPaneContainer();
GroupPaneContainer.setBackground(containerBg);
return GroupPaneContainer;
}
/**
* Add Top (10) and right (12) gap
*/
@ -610,9 +591,9 @@ public final class VPanel extends CTabbedPane
} // setBackground
//[ 1757088 ]
public JXTaskPane getTaskPane(int AD_Tab_ID)
public CollapsiblePanel getIncludedSection(int AD_Tab_ID)
{
return (JXTaskPane)m_tabincludelist.get(AD_Tab_ID);
return (CollapsiblePanel)m_tabincludelist.get(AD_Tab_ID);
}
private void findChildComponents(CPanel container, List list)
@ -621,25 +602,30 @@ public final class VPanel extends CTabbedPane
for (int c = 0; c < comp.length; c++)
{
list.add(comp[c]);
if ( comp [c] instanceof JXTaskPaneContainer)
if ( comp [c] instanceof CollapsiblePanel)
{
JXTaskPaneContainer panetaskcontainer = (JXTaskPaneContainer)comp [c];
CollapsiblePanel collapsiblePanel = (CollapsiblePanel)comp [c];
Component[] comppanetask = panetaskcontainer.getComponents();
Component[] nestedComps = collapsiblePanel.getCollapsiblePane()
.getContentPane().getComponents();
for (int y = 0; y < comppanetask.length; y++)
for (int y = 0; y < nestedComps.length; y++)
{
if ( comppanetask [y] instanceof JXTaskPane)
if ( nestedComps [y] instanceof CPanel)
{
JXTaskPane tabtask = (JXTaskPane)comppanetask[y];
Component[] comptabtask = tabtask.getContentPane().getComponents();
CPanel nestedPanel = (CPanel)nestedComps[y];
Component[] nestedPanelComps = nestedPanel.getComponents();
for (int x = 0; x < comptabtask.length; x++)
for (int x = 0; x < nestedPanelComps.length; x++)
{
list.add(comptabtask[x]);
list.add(nestedPanelComps[x]);
}
}
else
{
list.add(nestedComps[y]);
}
}
} else if (comp[c] instanceof CPanel)
{