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:
hengsin 2021-01-25 16:31:21 +08:00 committed by GitHub
parent 82e38002f7
commit f233e29432
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 84 additions and 28 deletions

View File

@ -2328,8 +2328,14 @@ public class GridTab implements DataStatusListener, Evaluatee, Serializable
m_DataStatusEvent = e; // save it m_DataStatusEvent = e; // save it
// when sorted set current row to 0 // when sorted set current row to 0
String msg = m_DataStatusEvent.getAD_Message(); 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); setCurrentRow(0, true);
}
// set current row // set current row
m_DataStatusEvent = e; // setCurrentRow clear it, need to save again m_DataStatusEvent = e; // setCurrentRow clear it, need to save again
m_DataStatusEvent.setCurrentRow(m_currentRow); m_DataStatusEvent.setCurrentRow(m_currentRow);
@ -2651,6 +2657,8 @@ public class GridTab implements DataStatusListener, Evaluatee, Serializable
//reset //reset
m_DataStatusEvent = null; m_DataStatusEvent = null;
m_mTable.setCurrentRow(m_currentRow);
return m_currentRow; return m_currentRow;
} // setCurrentRow } // setCurrentRow

View File

@ -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; public static final int DEFAULT_GRIDTABLE_LOAD_TIMEOUT_IN_SECONDS = 30;
@ -926,7 +928,14 @@ public class GridTable extends AbstractTableModel
} }
//cache changed row //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 // RowIDs are not sorted
if (field.getDisplayType() == DisplayType.RowID) if (field.getDisplayType() == DisplayType.RowID)
@ -954,31 +963,52 @@ public class GridTable extends AbstractTableModel
Collections.sort(m_sort, sort); Collections.sort(m_sort, sort);
if (m_virtual) 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(); m_virtualBuffer.clear();
if (newRow != null && newRow.length > 0) if (newRow != null)
m_virtualBuffer.put(NEW_ROW_ID, newRow); 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++) 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_rowChanged = i;
m_virtualBuffer.put(changedRow.index, changedRowData);
break; break;
} }
} }
} }
}
//release sort memory //release sort memory
for (int i = 0; i < m_sort.size(); i++) for (int i = 0; i < m_sort.size(); i++)
{ {
m_sort.get(i).data = null; 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 // update UI
fireTableDataChanged(); fireTableDataChanged();
// Info detected by MTab.dataStatusChanged and current row set to 0 // Info detected by MTab.dataStatusChanged and current row set to 0
fireDataStatusIEvent("Sorted", "#" + m_sort.size()); fireDataStatusIEvent(SORTED_DSE_EVENT, "#" + m_sort.size());
} }
} // sort } // sort
@ -1177,12 +1207,16 @@ public class GridTable extends AbstractTableModel
.append(getKeyColumnName()) .append(getKeyColumnName())
.append(" IN ("); .append(" IN (");
Map<Integer, Integer>rowmap = new LinkedHashMap<Integer, Integer>(DEFAULT_FETCH_SIZE); 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++) 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(",");
sql.append(m_sort.get(i).index); sql.append(m_sort.get(i).index);
rowmap.put(m_sort.get(i).index, i); rowmap.put(m_sort.get(i).index, i);
count++;
} }
sql.append(")"); sql.append(")");
@ -1192,13 +1226,6 @@ public class GridTable extends AbstractTableModel
m_virtualBuffer = new HashMap<Integer, Object[]>(210); m_virtualBuffer = new HashMap<Integer, Object[]>(210);
if (newRow != null && newRow.length > 0) if (newRow != null && newRow.length > 0)
m_virtualBuffer.put(NEW_ROW_ID, newRow); 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; PreparedStatement stmt = null;
ResultSet rs = null; ResultSet rs = null;
@ -1225,6 +1252,14 @@ public class GridTable extends AbstractTableModel
m_sort.remove(row.intValue()); 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) catch (SQLException e)
{ {
@ -2528,6 +2563,8 @@ public class GridTable extends AbstractTableModel
private boolean m_importing = false; private boolean m_importing = false;
private String m_trxName = null; private String m_trxName = null;
private int m_currentRow = -1;
/** /**
* Reset LOB info * Reset LOB info
*/ */
@ -3421,6 +3458,8 @@ public class GridTable extends AbstractTableModel
{ {
DataStatusEvent e = createDSE(); DataStatusEvent e = createDSE();
e.setInfo(AD_Message, info, false,false); e.setInfo(AD_Message, info, false,false);
if (SORTED_DSE_EVENT.equals(AD_Message) && m_currentRow >= 0)
e.setCurrentRow(m_currentRow);
fireDataStatusChanged (e); fireDataStatusChanged (e);
} // fireDataStatusEvent } // fireDataStatusEvent
@ -4070,4 +4109,12 @@ public class GridTable extends AbstractTableModel
m_lastSortColumnIndex = -1; m_lastSortColumnIndex = -1;
m_lastSortedAscending = false; 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;
}
} }

View File

@ -1937,6 +1937,7 @@ public abstract class AbstractADWindowContent extends AbstractUIPart implements
FDialog.error(getWindowNo(), "GridTabLoadTimeoutError"); FDialog.error(getWindowNo(), "GridTabLoadTimeoutError");
} else { } else {
FDialog.error(getWindowNo(), "Error", e.getMessage()); FDialog.error(getWindowNo(), "Error", e.getMessage());
logger.log(Level.SEVERE, e.getMessage(), e);
} }
adTabbox.getSelectedGridTab().reset(); adTabbox.getSelectedGridTab().reset();
return; return;