IDEMPIERE-4662 Some problems of sort at window before save (#551)
* IDEMPIERE-4662 Some problems of sort at window before save * IDEMPIERE-4662 Some problems of sort at window before save Fixed the sequence of edit field -> sort -> edit field will wrongly trigger save automatically.
This commit is contained in:
parent
82e38002f7
commit
f233e29432
|
@ -2328,8 +2328,14 @@ public class GridTab implements DataStatusListener, Evaluatee, Serializable
|
|||
m_DataStatusEvent = e; // save it
|
||||
// when sorted set current row to 0
|
||||
String msg = m_DataStatusEvent.getAD_Message();
|
||||
if (msg != null && msg.equals("Sorted"))
|
||||
if (msg != null && msg.equals(GridTable.SORTED_DSE_EVENT))
|
||||
{
|
||||
oldCurrentRow = m_currentRow;
|
||||
if (e.getCurrentRow() >= 0)
|
||||
setCurrentRow(e.getCurrentRow());
|
||||
else
|
||||
setCurrentRow(0, true);
|
||||
}
|
||||
// set current row
|
||||
m_DataStatusEvent = e; // setCurrentRow clear it, need to save again
|
||||
m_DataStatusEvent.setCurrentRow(m_currentRow);
|
||||
|
@ -2651,6 +2657,8 @@ public class GridTab implements DataStatusListener, Evaluatee, Serializable
|
|||
//reset
|
||||
m_DataStatusEvent = null;
|
||||
|
||||
m_mTable.setCurrentRow(m_currentRow);
|
||||
|
||||
return m_currentRow;
|
||||
} // setCurrentRow
|
||||
|
||||
|
|
|
@ -103,7 +103,9 @@ public class GridTable extends AbstractTableModel
|
|||
/**
|
||||
*
|
||||
*/
|
||||
private static final long serialVersionUID = -1869219003783467319L;
|
||||
private static final long serialVersionUID = -5856409718243773243L;
|
||||
|
||||
protected static final String SORTED_DSE_EVENT = "Sorted";
|
||||
|
||||
public static final int DEFAULT_GRIDTABLE_LOAD_TIMEOUT_IN_SECONDS = 30;
|
||||
|
||||
|
@ -926,7 +928,14 @@ public class GridTable extends AbstractTableModel
|
|||
}
|
||||
|
||||
//cache changed row
|
||||
Object[] changedRow = m_rowChanged >= 0 ? getDataAtRow(m_rowChanged) : null;
|
||||
MSort changedRow = m_rowChanged >= 0 ? (MSort)m_sort.get(m_rowChanged) : null;
|
||||
if (m_rowChanged == m_newRow)
|
||||
changedRow = null;
|
||||
Object[] changedRowData = changedRow != null ? getDataAtRow(m_rowChanged) : null;
|
||||
|
||||
MSort newRow = m_newRow >= 0 ? (MSort)m_sort.get(m_newRow) : null;
|
||||
|
||||
MSort currentRow = m_currentRow >= 0 && m_currentRow < m_sort.size() ? (MSort)m_sort.get(m_currentRow) : null;
|
||||
|
||||
// RowIDs are not sorted
|
||||
if (field.getDisplayType() == DisplayType.RowID)
|
||||
|
@ -954,31 +963,52 @@ public class GridTable extends AbstractTableModel
|
|||
Collections.sort(m_sort, sort);
|
||||
if (m_virtual)
|
||||
{
|
||||
Object[] newRow = m_virtualBuffer.get(NEW_ROW_ID);
|
||||
Object[] newRowData = newRow != null ? m_virtualBuffer.get(NEW_ROW_ID) : null;
|
||||
m_virtualBuffer.clear();
|
||||
if (newRow != null && newRow.length > 0)
|
||||
m_virtualBuffer.put(NEW_ROW_ID, newRow);
|
||||
if (newRow != null)
|
||||
m_virtualBuffer.put(NEW_ROW_ID, newRowData);
|
||||
|
||||
if (changedRow != null && changedRow.length > 0)
|
||||
if (changedRow != null)
|
||||
{
|
||||
if (changedRow[m_indexKeyColumn] != null && (Integer)changedRow[m_indexKeyColumn] > 0)
|
||||
{
|
||||
m_virtualBuffer.put((Integer)changedRow[m_indexKeyColumn], changedRow);
|
||||
for(int i = 0; i < m_sort.size(); i++)
|
||||
{
|
||||
if (m_sort.get(i).index == (Integer)changedRow[m_indexKeyColumn])
|
||||
if (m_sort.get(i) == changedRow)
|
||||
{
|
||||
m_rowChanged = i;
|
||||
m_virtualBuffer.put(changedRow.index, changedRowData);
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
//release sort memory
|
||||
for (int i = 0; i < m_sort.size(); i++)
|
||||
{
|
||||
m_sort.get(i).data = null;
|
||||
if (newRow != null && m_sort.get(i) == newRow)
|
||||
{
|
||||
if (m_rowChanged == m_newRow)
|
||||
m_rowChanged = i;
|
||||
m_newRow = i;
|
||||
}
|
||||
|
||||
if (currentRow != null && m_sort.get(i) == currentRow)
|
||||
m_currentRow = i;
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
for (int i = 0; i < m_sort.size(); i++)
|
||||
{
|
||||
if (newRow != null && m_sort.get(i) == newRow)
|
||||
{
|
||||
if (m_rowChanged == m_newRow)
|
||||
m_rowChanged = i;
|
||||
m_newRow = i;
|
||||
}
|
||||
|
||||
if (currentRow != null && m_sort.get(i) == currentRow)
|
||||
m_currentRow = i;
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -987,7 +1017,7 @@ public class GridTable extends AbstractTableModel
|
|||
// update UI
|
||||
fireTableDataChanged();
|
||||
// Info detected by MTab.dataStatusChanged and current row set to 0
|
||||
fireDataStatusIEvent("Sorted", "#" + m_sort.size());
|
||||
fireDataStatusIEvent(SORTED_DSE_EVENT, "#" + m_sort.size());
|
||||
}
|
||||
} // sort
|
||||
|
||||
|
@ -1177,12 +1207,16 @@ public class GridTable extends AbstractTableModel
|
|||
.append(getKeyColumnName())
|
||||
.append(" IN (");
|
||||
Map<Integer, Integer>rowmap = new LinkedHashMap<Integer, Integer>(DEFAULT_FETCH_SIZE);
|
||||
int count = 0;
|
||||
for(int i = start; i < start+fetchSize && i < m_sort.size(); i++)
|
||||
{
|
||||
if(i > start)
|
||||
if (m_sort.get(i).index == NEW_ROW_ID)
|
||||
continue;
|
||||
if(count > 0)
|
||||
sql.append(",");
|
||||
sql.append(m_sort.get(i).index);
|
||||
rowmap.put(m_sort.get(i).index, i);
|
||||
count++;
|
||||
}
|
||||
sql.append(")");
|
||||
|
||||
|
@ -1192,13 +1226,6 @@ public class GridTable extends AbstractTableModel
|
|||
m_virtualBuffer = new HashMap<Integer, Object[]>(210);
|
||||
if (newRow != null && newRow.length > 0)
|
||||
m_virtualBuffer.put(NEW_ROW_ID, newRow);
|
||||
if (changedRow != null && changedRow.length > 0)
|
||||
{
|
||||
if (changedRow[m_indexKeyColumn] != null && (Integer)changedRow[m_indexKeyColumn] > 0)
|
||||
{
|
||||
m_virtualBuffer.put((Integer)changedRow[m_indexKeyColumn], changedRow);
|
||||
}
|
||||
}
|
||||
|
||||
PreparedStatement stmt = null;
|
||||
ResultSet rs = null;
|
||||
|
@ -1225,6 +1252,14 @@ public class GridTable extends AbstractTableModel
|
|||
m_sort.remove(row.intValue());
|
||||
}
|
||||
}
|
||||
|
||||
if (changedRow != null && changedRow.length > 0)
|
||||
{
|
||||
if (changedRow[m_indexKeyColumn] != null && (Integer)changedRow[m_indexKeyColumn] > 0)
|
||||
{
|
||||
m_virtualBuffer.put((Integer)changedRow[m_indexKeyColumn], changedRow);
|
||||
}
|
||||
}
|
||||
}
|
||||
catch (SQLException e)
|
||||
{
|
||||
|
@ -2528,6 +2563,8 @@ public class GridTable extends AbstractTableModel
|
|||
private boolean m_importing = false;
|
||||
private String m_trxName = null;
|
||||
|
||||
private int m_currentRow = -1;
|
||||
|
||||
/**
|
||||
* Reset LOB info
|
||||
*/
|
||||
|
@ -3421,6 +3458,8 @@ public class GridTable extends AbstractTableModel
|
|||
{
|
||||
DataStatusEvent e = createDSE();
|
||||
e.setInfo(AD_Message, info, false,false);
|
||||
if (SORTED_DSE_EVENT.equals(AD_Message) && m_currentRow >= 0)
|
||||
e.setCurrentRow(m_currentRow);
|
||||
fireDataStatusChanged (e);
|
||||
} // fireDataStatusEvent
|
||||
|
||||
|
@ -4070,4 +4109,12 @@ public class GridTable extends AbstractTableModel
|
|||
m_lastSortColumnIndex = -1;
|
||||
m_lastSortedAscending = false;
|
||||
}
|
||||
|
||||
/**
|
||||
* set current row of gridtable container (gridtab). use in sort to create dse event with new current row (after sort) data
|
||||
* @param m_currentRow
|
||||
*/
|
||||
protected void setCurrentRow(int m_currentRow) {
|
||||
this.m_currentRow = m_currentRow;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1937,6 +1937,7 @@ public abstract class AbstractADWindowContent extends AbstractUIPart implements
|
|||
FDialog.error(getWindowNo(), "GridTabLoadTimeoutError");
|
||||
} else {
|
||||
FDialog.error(getWindowNo(), "Error", e.getMessage());
|
||||
logger.log(Level.SEVERE, e.getMessage(), e);
|
||||
}
|
||||
adTabbox.getSelectedGridTab().reset();
|
||||
return;
|
||||
|
|
Loading…
Reference in New Issue