Fix 3121975 POS Query Product Vertical Scroll Problem

http://sourceforge.net/tracker/index.php?func=detail&aid=3121975&group_id=176962&atid=879332
IDEMPIERE-61
This commit is contained in:
dellph 2011-08-15 13:10:57 -05:00
parent f92ee90799
commit 40177e56e5
2 changed files with 34 additions and 15 deletions

View File

@ -38,10 +38,8 @@ import org.compiere.util.Msg;
/** /**
* POS Query Product * POS Query Product
* *
* @author Comunidad de Desarrollo OpenXpertya * @author Based on Modified Original Code, Revised and Optimized
* *Basado en Codigo Original Modificado, Revisado y Optimizado de:
* *Copyright (c) Jorg Janke * *Copyright (c) Jorg Janke
* @version $Id: QueryProduct.java,v 1.1 2004/07/12 04:10:04 jjanke Exp $
*/ */
public class QueryProduct extends PosQuery public class QueryProduct extends PosQuery
{ {
@ -159,10 +157,20 @@ public class QueryProduct extends PosQuery
+ " ORDER BY Margin, QtyAvailable"; + " ORDER BY Margin, QtyAvailable";
m_table.addMouseListener(this); m_table.addMouseListener(this);
m_table.getSelectionModel().addListSelectionListener(this); m_table.getSelectionModel().addListSelectionListener(this);
m_table.setColumnVisibility(m_table.getColumn(0), false);
m_table.getColumn(1).setPreferredWidth(175);
m_table.getColumn(2).setPreferredWidth(175);
m_table.getColumn(3).setPreferredWidth(100);
m_table.getColumn(4).setPreferredWidth(75);
m_table.getColumn(5).setPreferredWidth(75);
m_table.getColumn(6).setPreferredWidth(75);
m_table.getColumn(7).setPreferredWidth(75);
enableButtons(); enableButtons();
m_table.setFillsViewportHeight( true ); //@Trifon
// m_table.setFocusable( true ); //@Trifon
m_table.growScrollbars();
centerScroll = new CScrollPane(m_table); centerScroll = new CScrollPane(m_table);
panel.add (centerScroll, "growx, growy,south"); panel.add (centerScroll, "growx, growy,south");
m_table.growScrollbars();
panel.setPreferredSize(new Dimension(800,600)); panel.setPreferredSize(new Dimension(800,600));
f_value.requestFocus(); f_value.requestFocus();
} // init } // init
@ -209,6 +217,8 @@ public class QueryProduct extends PosQuery
if (row < 0) if (row < 0)
row = 0; row = 0;
m_table.getSelectionModel().setSelectionInterval(row, row); m_table.getSelectionModel().setSelectionInterval(row, row);
// https://sourceforge.net/tracker/?func=detail&atid=879332&aid=3121975&group_id=176962
m_table.scrollRectToVisible(m_table.getCellRect(row, 1, true)); //@Trifon - BF[3121975]
return; return;
} }
else if ("Next".equalsIgnoreCase(e.getActionCommand())) else if ("Next".equalsIgnoreCase(e.getActionCommand()))
@ -221,6 +231,8 @@ public class QueryProduct extends PosQuery
if (row >= rows) if (row >= rows)
row = rows - 1; row = rows - 1;
m_table.getSelectionModel().setSelectionInterval(row, row); m_table.getSelectionModel().setSelectionInterval(row, row);
// https://sourceforge.net/tracker/?func=detail&atid=879332&aid=3121975&group_id=176962
m_table.scrollRectToVisible(m_table.getCellRect(row, 1, true)); //@Trifon - BF[3121975]
return; return;
} }
// Exit // Exit

View File

@ -51,10 +51,9 @@ import org.compiere.util.Msg;
/** /**
* Current Line Sub Panel * Current Line Sub Panel
* *
* @author Comunidad de Desarrollo OpenXpertya * @author OpenXpertya
* *Basado en Codigo Original Modificado, Revisado y Optimizado de: * Based on Modified Original Code, Revised and Optimized
* *Copyright <EFBFBD> Jorg Janke * *Copyright Jorg Janke
* @version $Id: SubCurrentLine.java,v 1.3 2004/07/24 04:31:52 jjanke Exp $
* red1 - [2093355 ] Small bugs in OpenXpertya POS * red1 - [2093355 ] Small bugs in OpenXpertya POS
*/ */
public class SubCurrentLine extends PosSubPanel implements ActionListener, FocusListener, ListSelectionListener { public class SubCurrentLine extends PosSubPanel implements ActionListener, FocusListener, ListSelectionListener {
@ -66,12 +65,11 @@ public class SubCurrentLine extends PosSubPanel implements ActionListener, Focus
/** /**
* Constructor * Constructor
* *
* @param posPanel * @param posPanel POS Panel
* POS Panel
*/ */
public SubCurrentLine(PosBasePanel posPanel) { public SubCurrentLine(PosBasePanel posPanel) {
super(posPanel); super(posPanel);
} // PosSubCurrentLine }
private CButton f_up; private CButton f_up;
private CButton f_delete; private CButton f_delete;
@ -159,6 +157,7 @@ public class SubCurrentLine extends PosSubPanel implements ActionListener, Focus
m_table.getColumn(5).setPreferredWidth(75); m_table.getColumn(5).setPreferredWidth(75);
m_table.getColumn(6).setPreferredWidth(30); m_table.getColumn(6).setPreferredWidth(30);
m_table.setFocusable(false); m_table.setFocusable(false);
m_table.setFillsViewportHeight( true ); //@Trifon
m_table.growScrollbars(); m_table.growScrollbars();
add (scroll, "growx, spanx, growy, pushy, h 200:300:"); add (scroll, "growx, spanx, growy, pushy, h 200:300:");
@ -205,9 +204,7 @@ public class SubCurrentLine extends PosSubPanel implements ActionListener, Focus
setPrice(Env.ZERO); setPrice(Env.ZERO);
enableButtons(); enableButtons();
} //init
} // init
/** /**
@ -286,6 +283,12 @@ public class SubCurrentLine extends PosSubPanel implements ActionListener, Focus
qt.setQueryData(m_M_PriceList_Version_ID, m_M_Warehouse_ID); qt.setQueryData(m_M_PriceList_Version_ID, m_M_Warehouse_ID);
qt.setVisible(true); qt.setVisible(true);
findProduct(); findProduct();
int row = m_table.getSelectedRow();
if (row < 0) row = 0;
m_table.getSelectionModel().setSelectionInterval(row, row);
// https://sourceforge.net/tracker/?func=detail&atid=879332&aid=3121975&group_id=176962
m_table.scrollRectToVisible(m_table.getCellRect(row, 1, true)); //@Trifon - BF[3121975]
} }
// Name // Name
else if (e.getSource() == f_name) else if (e.getSource() == f_name)
@ -293,13 +296,15 @@ public class SubCurrentLine extends PosSubPanel implements ActionListener, Focus
if ("Previous".equalsIgnoreCase(e.getActionCommand())) if ("Previous".equalsIgnoreCase(e.getActionCommand()))
{ {
int rows = m_table.getRowCount(); int rows = m_table.getRowCount();
if (rows == 0) if (rows == 0)
return; return;
int row = m_table.getSelectedRow(); int row = m_table.getSelectedRow();
row--; row--;
if (row < 0) if (row < 0)
row = 0; row = 0;
m_table.getSelectionModel().setSelectionInterval(row, row); m_table.getSelectionModel().setSelectionInterval(row, row);
// https://sourceforge.net/tracker/?func=detail&atid=879332&aid=3121975&group_id=176962
m_table.scrollRectToVisible(m_table.getCellRect(row, 1, true)); //@Trifon - BF[3121975]
return; return;
} }
else if ("Next".equalsIgnoreCase(e.getActionCommand())) else if ("Next".equalsIgnoreCase(e.getActionCommand()))
@ -312,6 +317,8 @@ public class SubCurrentLine extends PosSubPanel implements ActionListener, Focus
if (row >= rows) if (row >= rows)
row = rows - 1; row = rows - 1;
m_table.getSelectionModel().setSelectionInterval(row, row); m_table.getSelectionModel().setSelectionInterval(row, row);
// https://sourceforge.net/tracker/?func=detail&atid=879332&aid=3121975&group_id=176962
m_table.scrollRectToVisible(m_table.getCellRect(row, 1, true)); //@Trifon - BF[3121975]
return; return;
} }
// Delete // Delete